class PG::TypeMapByClass
This type map casts values based on the class or the ancestors of the given value to be sent.
This type map is usable for type casting query bind parameters and COPY data for PG::Connection#put_copy_data
. Therefore only encoders might be assigned by the []=
method.
Public Instance Methods
Source
static VALUE pg_tmbk_aref( VALUE self, VALUE klass ) { t_tmbk *this = RTYPEDDATA_DATA( self ); return rb_hash_lookup(this->klass_to_coder, klass); }
Returns the encoder object for the given class
Source
static VALUE pg_tmbk_aset( VALUE self, VALUE klass, VALUE coder ) { t_tmbk *this = RTYPEDDATA_DATA( self ); rb_check_frozen(self); if(NIL_P(coder)){ rb_hash_delete( this->klass_to_coder, klass ); }else{ rb_hash_aset( this->klass_to_coder, klass, coder ); } /* The cache lookup key can be a derivation of the klass. * So we can not expire the cache selectively. */ memset( &this->cache_row, 0, sizeof(this->cache_row) ); return coder; }
Assigns a new PG::Coder
object to the type map. The encoder is chosen for all values that are a kind of the given class
.
coder
can be one of the following:
-
nil
- Values are forwarded to thedefault_type_map
. -
a
PG::Coder
- Values are encoded by the given encoder -
a Symbol - The method of this type map (or a derivation) that is called for each value to sent. It must return a
PG::Coder
ornil
. -
a Proc - The Proc object is called for each value. It must return a
PG::Coder
ornil
.
Source
static VALUE pg_tmbk_coders( VALUE self ) { t_tmbk *this = RTYPEDDATA_DATA( self ); return rb_obj_freeze(rb_hash_dup(this->klass_to_coder)); }
Returns all classes and their assigned encoder object.