![]() |
![]() |
![]() |
GNOME Data Access manual | ![]() |
---|---|---|---|---|
Top | Description |
enum GdaBlobMode; GdaBlob; gint gda_blob_open (GdaBlob *blob, GdaBlobMode mode); gint gda_blob_read (GdaBlob *blob, gpointer buf, gint size, gint *bytes_read); gint gda_blob_write (GdaBlob *blob, gpointer buf, gint size, gint *bytes_written); gint gda_blob_lseek (GdaBlob *blob, gint offset, gint whence); gint gda_blob_close (GdaBlob *blob); gint gda_blob_remove (GdaBlob *blob); void gda_blob_free_data (GdaBlob *blob);
typedef enum { GDA_BLOB_MODE_READ = 1, GDA_BLOB_MODE_WRITE = 1 << 1, GDA_BLOB_MODE_RDWR = 0x03 } GdaBlobMode;
typedef struct { /* Private */ gint (* open) (GdaBlob *blob, GdaBlobMode mode); gint (* read) (GdaBlob *blob, gpointer buf, gint size, gint *bytes_read); gint (* write) (GdaBlob *blob, gpointer buf, gint size, gint *bytes_written); gint (* lseek) (GdaBlob *blob, gint offset, gint whence); gint (* close) (GdaBlob *blob); gint (* remove) (GdaBlob *blob); gchar * (* stringify) (GdaBlob *blob); void (* free_data) (GdaBlob *blob); gpointer priv_data; /* */ /* Public */ gpointer user_data; } GdaBlob;
gint gda_blob_open (GdaBlob *blob, GdaBlobMode mode);
Opens an existing BLOB. The BLOB must be initialized by gda_connection_create_blob or obtained from a GdaValue.
|
a GdaBlob structure obtained from a GdaValue or allocated by the user when he/she wants to create a new GdaBlob. |
|
see GdaBlobMode. |
Returns : |
0 if everything's ok. In case of error, -1 is returned and the provider should have added an error to the connection. |
gint gda_blob_read (GdaBlob *blob, gpointer buf, gint size, gint *bytes_read);
Reads a chunk of bytes from the BLOB into a user-provided location.
|
a GdaBlob which is opened with the flag GDA_BLOB_MODE_READ set. |
|
buffer to read the data into. |
|
maximum number of bytes to read. |
|
on return it will point to the number of bytes actually read. |
Returns : |
0 if everything's ok. In case of error, -1 is returned and the provider should have added an error to the connection. |
gint gda_blob_write (GdaBlob *blob, gpointer buf, gint size, gint *bytes_written);
Writes a chunk of bytes from a user-provided location to the BLOB.
|
a GdaBlob which is opened with the flag GDA_BLOB_MODE_WRITE set. |
|
buffer to write the data from. |
|
maximum number of bytes to read. |
|
on return it will point to the number of bytes actually written. |
Returns : |
0 if everything's ok. In case of error, -1 is returned and the provider should have added an error to the connection. |
gint gda_blob_lseek (GdaBlob *blob, gint offset, gint whence);
Sets the blob read/write position.
|
a opened GdaBlob. |
|
offset added to the position specified by whence .
|
|
SEEK_SET, SEEK_CUR or SEEK_END with the same meaning as in fseek(3). |
Returns : |
the current position in the blob or < 0 in case of error. In case of error the provider should have added an error to the connection. |
gint gda_blob_close (GdaBlob *blob);
Closes the BLOB. After calling this function, blob
should no longer be used.
|
a opened GdaBlob. |
Returns : |
0 if everything's ok. In case of error, -1 is returned and the provider should have added an error to the connection. |
gint gda_blob_remove (GdaBlob *blob);
Removes the BLOB from the database. After calling this function, blob
should no longer be used.
|
a valid GdaBlob. |
Returns : |
0 if everything's ok. In case of error, -1 is returned and the provider should have added an error to the connection. |