|  |  |  | GNOME Data Access 4 manual |  | 
|---|---|---|---|---|
| A single ValueA single Value — Assorted functions for dealing with GValue values. | 
GValue* gda_value_new (GType type); #define gda_value_new_null () GValue* gda_value_copy (const GValue *value); void gda_value_free (GValue *value); GValue* gda_value_new_from_string (const gchar *as_string, GType type); gboolean gda_value_set_from_string (GValue *value, const gchar *as_string, GType type); gboolean gda_value_set_from_value (GValue *value, const GValue *from); void gda_value_set_null (GValue *value); gchar* gda_value_stringify (const GValue *value); gint gda_value_differ (const GValue *value1, const GValue *value2); gint gda_value_compare (const GValue *value1, const GValue *value2); GValue* gda_value_new_from_xml (const xmlNodePtr node); xmlNodePtr gda_value_to_xml (const GValue *value); void gda_value_reset_with_type (GValue *value, GType type); gboolean gda_value_is_null (const GValue *value); gboolean gda_value_is_number (const GValue *value); #define gda_value_isa (value, type) GdaBinary; GValue* gda_value_new_binary (const guchar *val, glong size); const GdaBinary* gda_value_get_binary (const GValue *value); void gda_value_set_binary (GValue *value, const GdaBinary *binary); void gda_value_take_binary (GValue *value, GdaBinary *binary); gpointer gda_binary_copy (gpointer boxed); void gda_binary_free (gpointer boxed); gchar* gda_binary_to_string (const GdaBinary *bin, guint maxlen); GdaBinary* gda_string_to_binary (const gchar *str); GdaBlob; GValue* gda_value_new_blob (const guchar *val, glong size); GValue* gda_value_new_blob_from_file (const gchar *filename); gpointer gda_blob_copy (gpointer boxed); void gda_blob_free (gpointer boxed); const GdaBlob* gda_value_get_blob (const GValue *value); void gda_value_set_blob (GValue *value, const GdaBlob *blob); void gda_value_take_blob (GValue *value, GdaBlob *blob); void gda_blob_set_op (GdaBlob *blob, GdaBlobOp *op); gchar* gda_blob_to_string (GdaBlob *blob, guint maxlen); GdaGeometricPoint; gpointer gda_geometricpoint_copy (gpointer boxed); void gda_geometricpoint_free (gpointer boxed); const GdaGeometricPoint* gda_value_get_geometric_point (const GValue *value); void gda_value_set_geometric_point (GValue *value, const GdaGeometricPoint *val); typedef GdaValueList; const GdaValueList* gda_value_get_list (const GValue *value); void gda_value_set_list (GValue *value, const GdaValueList *val); GdaNumeric; gpointer gda_numeric_copy (gpointer boxed); void gda_numeric_free (gpointer boxed); const GdaNumeric* gda_value_get_numeric (const GValue *value); void gda_value_set_numeric (GValue *value, const GdaNumeric *val); GdaTime; gpointer gda_time_copy (gpointer boxed); void gda_time_free (gpointer boxed); const GdaTime* gda_value_get_time (const GValue *value); void gda_value_set_time (GValue *value, const GdaTime *val); GdaTimestamp; gpointer gda_timestamp_copy (gpointer boxed); void gda_timestamp_free (gpointer boxed); const GdaTimestamp* gda_value_get_timestamp (const GValue *value); void gda_value_set_timestamp (GValue *value, const GdaTimestamp *val); GValue* gda_value_new_timestamp_from_timet (time_t val); gshort gda_value_get_short (const GValue *value); void gda_value_set_short (GValue *value, const gshort val); gushort gda_value_get_ushort (const GValue *value); void gda_value_set_ushort (GValue *value, const gushort val);
Libgda manages each individual value within an opaque GValue structure. Any GValue type can be used, and Libgda adds a few more data types usually found in DBMS such as NUMERIC, TIME, TIMESTAMP, GEOMETRIC POINT, BINARY and BLOB.
Libgda makes a distinction between binary and blob types
binary data can be inserted into an SQL statement using a (DBMS dependant) syntax, such as "X'ABCD'" syntax for SQLite or the binary strings syntax for PostgreSQL. Binary data is manipulated using a GdaBinary structure (which is basically a bytes buffer and a length attribute).
blob data are a special feature that some DBMS have which requires some non SQL code to manipulate them. Usually only a reference is stored in each table containing a blob, and the actual blob data resides somewhere on the disk (while still being managed transparently by the database). For example PotsgreSQL stores blobs as files on the disk and references them using object identifiers (Oid). Blob data is manipulated using a GdaBlob structure which encapsulates a GdaBinary structure and adds a reference to a GdaBlobOp object used to read and write data from and to the blob.
Please note that is distinction between binary data and blobs is Libgda only and does not reflect the DBMS's documentations; for instance MySQL has several BLOB types but Libgda interprets them as binary types.
  Each provider or connection can be queried about its blob support using the gda_server_provider_supports_feature() or
  gda_connection_supports_feature() methods.
The NULL value is a special case value: it is represented by to a zero-filled (uninitialized) GValue and has a type equal to GDA_TYPE_NULL.
GValue* gda_value_new (GType type);
Makes a new GValue of type type.
| 
 | the new value type. | 
| Returns : | the newly created GValue with the specified type. 
You need to set the value in the returned GValue. | 
GValue* gda_value_copy (const GValue *value);
Creates a new GValue from an existing one.
| 
 | value to get a copy from. | 
| Returns : | a newly allocated GValue with a copy of the data in value. | 
void gda_value_free (GValue *value);
Deallocates all memory associated to a GValue.
| 
 | the resource to free. | 
GValue* gda_value_new_from_string (const gchar *as_string, GType type);
Makes a new GValue of type type from its string representation. 
For more information
about the string format, see the gda_value_set_from_string() function.
This function is typically used when reading configuration files or other non-user input that should be locale 
independent.
gboolean gda_value_set_from_string (GValue *value, const gchar *as_string, GType type);
Stores the value data from its string representation as type.
The accepted formats are:
G_TYPE_BOOLEAN: a caseless comparison is made with "true" or "false"
numerical types: C locale format (dot as a fraction separator)
G_TYPE_DATE: see gda_parse_iso8601_date()
GDA_TYPE_TIME: see gda_parse_iso8601_time()
GDA_TYPE_TIMESTAMP: see gda_parse_iso8601_timestamp()
This function is typically used when reading configuration files or other non-user input that should be locale independent.
| 
 | a GValue that will store val. | 
| 
 | the stringified representation of the value. | 
| 
 | the type of the value | 
| Returns : | TRUEif the value has been converted totypefrom
its string representation; it not means that the value is converted 
successfully, just that the transformation is avairable.FALSEotherwise. | 
gboolean gda_value_set_from_value (GValue *value, const GValue *from);
Sets the value of a GValue from another GValue. This
is different from gda_value_copy, which creates a new GValue.
gda_value_set_from_value, on the other hand, copies the contents
of copy into value, which must already be allocated.
void gda_value_set_null (GValue *value);
Sets the type of value to GDA_TYPE_NULL.
| 
 | a GValue that will store a value of type GDA_TYPE_NULL. | 
gchar* gda_value_stringify (const GValue *value);
Converts a GValue to its string representation which is a human readable value. Note that the returned string does not take into account the current locale of the user (on the contrary to the GdaDataHandler objects). Using this function should be limited to debugging and values serialization purposes.
Dates are converted in a YYYY-MM-DD format.
gint gda_value_differ (const GValue *value1, const GValue *value2);
Tells if two values are equal or not, by comparing memory representations. Unlike gda_value_compare(),
the returned value is boolean, and gives no idea about ordering.
The two values must be of the same type, with the exception that a value of any type can be compared to a GDA_TYPE_NULL value, specifically:
if value1 and value2 are both GDA_TYPE_NULL values then the returned value is 0
if value1 is a GDA_TYPE_NULL value and value2 is of another type then the returned value is 1
if value1 is of another type and value2 is a GDA_TYPE_NULL value then the returned value is 1
in all other cases, value1 and value2 must be of the same type and their values are compared
gint gda_value_compare (const GValue *value1, const GValue *value2);
Compares two values of the same type, with the exception that a value of any type can be compared to a GDA_TYPE_NULL value, specifically:
if value1 and value2 are both GDA_TYPE_NULL values then the returned value is 0
if value1 is a GDA_TYPE_NULL value and value2 is of another type then the returned value is -1
if value1 is of another type and value2 is a GDA_TYPE_NULL value then the returned value is 1
in all other cases, value1 and value2 must be of the same type and their values are compared
| 
 | a GValue to compare (not NULL) | 
| 
 | the other GValue to be compared to value1(notNULL) | 
| Returns : | if both values have the same type, returns 0 if both contain
the same value, an integer less than 0 if value1is less thanvalue2or
an integer greater than 0 ifvalue1is greater thanvalue2. | 
GValue* gda_value_new_from_xml (const xmlNodePtr node);
Creates a GValue from an XML representation of it. That XML node corresponds to the following string representation: <value type="gdatype">value</value>
For more information
about the string format, see the gda_value_set_from_string() function.
This function is typically used when reading configuration files or other non-user input that should be locale 
independent.
| 
 | an XML node representing the value. | 
| Returns : | the newly created GValue. | 
xmlNodePtr gda_value_to_xml (const GValue *value);
Serializes the given GValue to an XML node string.
| 
 | a GValue. | 
| Returns : | the XML node. Once not needed anymore, you should free it. | 
void gda_value_reset_with_type (GValue *value, GType type);
| 
 | |
| 
 | 
gboolean gda_value_is_null (const GValue *value);
Tests if a given value is of type GDA_TYPE_NULL.
| 
 | value to test. | 
| Returns : | a boolean that says whether or not valueis of type
GDA_TYPE_NULL. | 
gboolean gda_value_is_number (const GValue *value);
Gets whether the value stored in the given GValue is of numeric type or not.
GValue* gda_value_new_binary (const guchar *val, glong size);
Makes a new GValue of type GDA_TYPE_BINARY with value val.
const GdaBinary* gda_value_get_binary (const GValue *value);
| 
 | a GValue whose value we want to get. | 
| Returns : | the value stored in value. | 
void gda_value_set_binary (GValue *value, const GdaBinary *binary);
Stores val into value.
void gda_value_take_binary (GValue *value, GdaBinary *binary);
Stores val into value, but on the contrary to gda_value_set_binary(), the binary
argument is not copied, but used as-is and it should be considered owned by value.
gpointer gda_binary_copy (gpointer boxed);
Creates a new GdaBinary structure from an existing one.
| 
 | source to get a copy from. | 
| Returns : | a newly allocated GdaBinary which contains a copy of
information in boxed. | 
void gda_binary_free (gpointer boxed);
Deallocates all memory associated to the given GdaBinary.
| 
 | GdaBinary to free. | 
gchar* gda_binary_to_string (const GdaBinary *bin, guint maxlen);
Converts all the non printable characters of bin->data into the "\xyz" representation where "xyz" is the octal representation of the byte, and the '\' (backslash) character is converted to "\\".
| 
 | a correctly filled GdaBinarystructure | 
| 
 | a maximum len used to truncate, or 0 for no maximum length | 
| Returns : | a new string from bin | 
GdaBinary* gda_string_to_binary (const gchar *str);
Performs the reverse of gda_binary_to_string() (note that for any "\xyz" succession
of 4 characters where "xyz" represents a valid octal value, the resulting read value will
be modulo 256)
| 
 | a string to convert | 
| Returns : | a new GdaBinary if no error were found in str, or NULL otherwise | 
typedef struct {
	GdaBinary  data;
	GdaBlobOp *op; /* set up by providers if the GdaBlob is linked to something actually existing in the database, 
			  useable by anyone */
} GdaBlob;
GValue* gda_value_new_blob (const guchar *val, glong size);
Makes a new GValue of type GDA_TYPE_BLOB with the data contained by val.
GValue* gda_value_new_blob_from_file (const gchar *filename);
| 
 | |
| Returns : | 
gpointer gda_blob_copy (gpointer boxed);
Creates a new GdaBlob structure from an existing one.
| 
 | source to get a copy from. | 
| Returns : | a newly allocated GdaBlob which contains a copy of
information in boxed. | 
void gda_blob_free (gpointer boxed);
Deallocates all memory associated to the given GdaBlob.
| 
 | GdaBlob to free. | 
const GdaBlob* gda_value_get_blob (const GValue *value);
| 
 | a GValue whose value we want to get. | 
| Returns : | the value stored in value. | 
void gda_value_set_blob (GValue *value, const GdaBlob *blob);
Stores val into value.
void gda_value_take_blob (GValue *value, GdaBlob *blob);
Stores val into value, but on the contrary to gda_value_set_blob(), the blob
argument is not copied, but used as-is and it should be considered owned by value.
void gda_blob_set_op (GdaBlob *blob, GdaBlobOp *op);
correctly assigns op to blob
gchar* gda_blob_to_string (GdaBlob *blob, guint maxlen);
Converts all the non printable characters of blob->data into the \xxx representation where xxx is the octal representation of the byte, and the '\' (backslash) character is converted to "\\".
| 
 | a correctly filled GdaBlobstructure | 
| 
 | a maximum len used to truncate, or 0 for no maximum length | 
| Returns : | a new string from blob | 
const GdaGeometricPoint* gda_value_get_geometric_point (const GValue *value);
| 
 | a GValue whose value we want to get. | 
| Returns : | the value stored in value. | 
void gda_value_set_geometric_point (GValue *value, const GdaGeometricPoint *val);
Stores val into value.
| 
 | a GValue that will store val. | 
| 
 | value to be stored in value. | 
const GdaValueList* gda_value_get_list (const GValue *value);
| 
 | a GValue whose value we want to get. | 
| Returns : | the value stored in value. | 
void gda_value_set_list (GValue *value, const GdaValueList *val);
Stores val into value.
| 
 | a GValue that will store val. | 
| 
 | value to be stored in value. | 
typedef struct {
	gchar   *number;
	glong    precision;
	glong    width;
	gpointer reserved; /* reserved for future usage with GMP (http://gmplib.org/) */
} GdaNumeric;
gpointer gda_numeric_copy (gpointer boxed);
Creates a new GdaNumeric structure from an existing one.
| 
 | source to get a copy from. | 
| Returns : | a newly allocated GdaNumeric which contains a copy of
information in boxed. | 
void gda_numeric_free (gpointer boxed);
Deallocates all memory associated to the given boxed
| 
 | a GdaNumeric pointer | 
const GdaNumeric* gda_value_get_numeric (const GValue *value);
| 
 | a GValue whose value we want to get. | 
| Returns : | the value stored in value. | 
void gda_value_set_numeric (GValue *value, const GdaNumeric *val);
Stores val into value.
| 
 | a GValue that will store val. | 
| 
 | value to be stored in value. | 
typedef struct {
	gushort hour;
	gushort minute;
	gushort second;
	gulong  fraction;
	glong   timezone;	/* # of seconds to the east UTC */
} GdaTime;
const GdaTime* gda_value_get_time (const GValue *value);
| 
 | a GValue whose value we want to get. | 
| Returns : | the value stored in value. | 
void gda_value_set_time (GValue *value, const GdaTime *val);
Stores val into value.
| 
 | a GValue that will store val. | 
| 
 | value to be stored in value. | 
typedef struct {
	gshort  year;
	gushort month;
	gushort day;
	gushort hour;
	gushort minute;
	gushort second;
	gulong  fraction;
	glong   timezone;	/* # of seconds to the east UTC */
} GdaTimestamp;
const GdaTimestamp* gda_value_get_timestamp (const GValue *value);
| 
 | a GValue whose value we want to get. | 
| Returns : | the value stored in value. | 
void gda_value_set_timestamp (GValue *value, const GdaTimestamp *val);
Stores val into value.
| 
 | a GValue that will store val. | 
| 
 | value to be stored in value. | 
GValue* gda_value_new_timestamp_from_timet (time_t val);
Makes a new GValue of type GDA_TYPE_TIMESTAMP with value val
(of type time_t).
gshort gda_value_get_short (const GValue *value);
| 
 | a GValue whose value we want to get. | 
| Returns : | the value stored in value. | 
void gda_value_set_short (GValue *value, const gshort val);
Stores val into value.
| 
 | a GValue that will store val. | 
| 
 | value to be stored in value. | 
gushort gda_value_get_ushort (const GValue *value);
| 
 | a GValue whose value we want to get. | 
| Returns : | the value stored in value. |