This is the base class for all type cast classes for COPY data,
The character that separates columns within each row (line) of the file.
static VALUE
pg_copycoder_delimiter_get(VALUE self)
{
t_pg_copycoder *this = RTYPEDDATA_DATA(self);
return rb_str_new(&this->delimiter, 1);
}
Specifies the character that separates columns within each row (line) of the file. The default is a tab character in text format. This must be a single one-byte character.
This option is ignored when using binary format.
static VALUE
pg_copycoder_delimiter_set(VALUE self, VALUE delimiter)
{
t_pg_copycoder *this = RTYPEDDATA_DATA(self);
rb_check_frozen(self);
StringValue(delimiter);
if(RSTRING_LEN(delimiter) != 1)
rb_raise( rb_eArgError, "delimiter size must be one byte");
this->delimiter = *RSTRING_PTR(delimiter);
return delimiter;
}
The string that represents a null value.
static VALUE
pg_copycoder_null_string_get(VALUE self)
{
t_pg_copycoder *this = RTYPEDDATA_DATA(self);
return this->null_string;
}
Specifies the string that represents a null value. The default is \N (backslash-N) in text format. You might prefer an empty string even in text format for cases where you don’t want to distinguish nulls from empty strings.
This option is ignored when using binary format.
static VALUE
pg_copycoder_null_string_set(VALUE self, VALUE null_string)
{
t_pg_copycoder *this = RTYPEDDATA_DATA(self);
rb_check_frozen(self);
StringValue(null_string);
RB_OBJ_WRITE(self, &this->null_string, null_string);
return null_string;
}
def to_h
{ **super,
type_map: type_map,
delimiter: delimiter,
null_string: null_string,
}
end
The PG::TypeMap
that will be used for encoding and decoding of columns.
static VALUE
pg_copycoder_type_map_get(VALUE self)
{
t_pg_copycoder *this = RTYPEDDATA_DATA( self );
return this->typemap;
}
Defines how single columns are encoded or decoded. map
must be a kind of PG::TypeMap
.
Defaults to a PG::TypeMapAllStrings
, so that PG::TextEncoder::String
respectively PG::TextDecoder::String
is used for encoding/decoding of each column.
static VALUE
pg_copycoder_type_map_set(VALUE self, VALUE type_map)
{
t_pg_copycoder *this = RTYPEDDATA_DATA( self );
rb_check_frozen(self);
if ( !rb_obj_is_kind_of(type_map, rb_cTypeMap) ){
rb_raise( rb_eTypeError, "wrong elements type %s (expected some kind of PG::TypeMap)",
rb_obj_classname( type_map ) );
}
RB_OBJ_WRITE(self, &this->typemap, type_map);
return type_map;
}