|  |  |  | GNOME Data Access 4.0 manual |  | 
|---|---|---|---|---|
                    GdaServerOperation;
enum                GdaServerOperationType;
GdaServerOperationType gda_server_operation_get_op_type (GdaServerOperation *op);
const gchar*        gda_server_operation_op_type_to_string
                                                        (GdaServerOperationType type);
const GValue*       gda_server_operation_get_value_at   (GdaServerOperation *op,
                                                         const gchar *path_format,
                                                         ...);
gboolean            gda_server_operation_set_value_at   (GdaServerOperation *op,
                                                         const gchar *value,
                                                         GError **error,
                                                         const gchar *path_format,
                                                         ...);
xmlNodePtr          gda_server_operation_save_data_to_xml
                                                        (GdaServerOperation *op,
                                                         GError **error);
gboolean            gda_server_operation_load_data_from_xml
                                                        (GdaServerOperation *op,
                                                         xmlNodePtr node,
                                                         GError **error);
gboolean            gda_server_operation_is_valid       (GdaServerOperation *op,
                                                         const gchar *xml_file,
                                                         GError **error);
"connection" GdaConnection* : Read / Write / Construct Only "op-type" gint : Read / Write / Construct Only "provider" GdaServerProvider* : Read / Write / Construct Only "spec-filename" gchar* : Write / Construct Only
  This object is basically just a data store: it can store named values, the values being
  organized hirarchically by their name which are similar to a Unix file path. For example a value can be read from its path
  using the gda_server_operation_get_value_at() method, or set using the gda_server_operation_set_value_at() method.
Each GdaServerOperation contains some structure which is usually defined by a database provider to implement a specific operation. The structure is composed of the following building blocks:
Named values (internally represented as a GdaHolder object)
Named values in a vector (internally represented as a GdaSet object)
Values in an array (internally represented as a GdaDataModel object)
Sequences of one or more of the previous blocks. A sequence can contain any number of instances of the template block (there may be lower and upper boundaries to the number of instances)
  Important note: GdaServerOperation objects are usually not created 
  manually using gda_server_operation_new(), but
  using a GdaServerProvider object with gda_server_provider_create_operation().
  See the global introduction about DDL for more information.
  Alternatively one can use the Convenience functions
  which internally manipulate GdaServerOperation objects.
typedef enum {
	GDA_SERVER_OPERATION_CREATE_DB,
	GDA_SERVER_OPERATION_DROP_DB,
		
	GDA_SERVER_OPERATION_CREATE_TABLE,
	GDA_SERVER_OPERATION_DROP_TABLE,
	GDA_SERVER_OPERATION_RENAME_TABLE,
	GDA_SERVER_OPERATION_ADD_COLUMN,
	GDA_SERVER_OPERATION_DROP_COLUMN,
	GDA_SERVER_OPERATION_CREATE_INDEX,
	GDA_SERVER_OPERATION_DROP_INDEX,
	GDA_SERVER_OPERATION_CREATE_VIEW,
	GDA_SERVER_OPERATION_DROP_VIEW,
	GDA_SERVER_OPERATION_LAST
} GdaServerOperationType;
GdaServerOperationType gda_server_operation_get_op_type (GdaServerOperation *op);
Get the type of operation op is for
| 
 | a GdaServerOperation object | 
| Returns : | a GdaServerOperationType enum | 
const gchar* gda_server_operation_op_type_to_string (GdaServerOperationType type);
Get a string version of type
| 
 | a GdaServerOperationType value | 
| Returns : | a non NULLstring (do not free or modify) | 
const GValue* gda_server_operation_get_value_at (GdaServerOperation *op, const gchar *path_format, ...);
Get the value for the node at the path formed using path_format and ... (the rules are the same as
for g_strdup_printf())
| 
 | a GdaServerOperation object | 
| 
 | a complete path to a node (starting with "/") | 
| 
 | arguments to use with path_formatto make a complete path | 
| Returns : | a constant GValue if a value has been defined, or NULLif the value is undefined or
if thepathis not defined orpathdoes not hold any value. | 
gboolean gda_server_operation_set_value_at (GdaServerOperation *op, const gchar *value, GError **error, const gchar *path_format, ...);
Set the value for the node at the path formed using path_format and the ... ellipse (the rules are the same as
for g_strdup_printf()). 
Note that trying to set a value for a path which is not used by the current provider, such as "/TABLE_OPTIONS_P/TABLE_ENGINE" for a PostgreSQL connection (this option is only supported for MySQL), will not generate any error; this allows one to give values to a superset of the parameters and thus use the same code for several providers.
Here are the possible formats of path_format:
If the path corresponds to a GdaHolder, then the parameter is set to "@value"
If the path corresponds to a sequence item like for example "/SEQUENCE_NAME/5/NAME" for the "NAME" value of the 6th item of the "SEQUENCE_NAME" sequence then:
if the sequence already has 6 or more items, then the value is just set to the corresponding value in the 6th item of the sequence
if the sequence has less then 6 items, then items are added up to the 6th one before setting the value to the corresponding in the 6th item of the sequence
If the path corresponds to a GdaDataModel, like for example "/ARRAY/@COLUMN/5" for the value at the
    6th row of the "COLUMN" column of the "ARRAY" data model, then:
    
if the data model already contains 6 or more rows, then the value is just set
if the data model has less than 6 rows, then rows are added up to the 6th one before setting the value
| 
 | a GdaServerOperation object | 
| 
 | a string | 
| 
 | a place to store errors or NULL | 
| 
 | a complete path to a node (starting with "/") | 
| 
 | arguments to use with path_formatto make a complete path | 
| Returns : | TRUE if no error occurred | 
xmlNodePtr          gda_server_operation_save_data_to_xml
                                                        (GdaServerOperation *op,
                                                         GError **error);
Creates a new xmlNodePtr tree which can be used to save the op object. This XML structure can then be saved to disk if necessary. Use xmlFreeNode to free the associated memory when not needed anymore.
| 
 | a GdaServerOperation object | 
| 
 | a place to store errors or NULL | 
| Returns : | a new xmlNodePtr structure, or NULL | 
gboolean gda_server_operation_load_data_from_xml (GdaServerOperation *op, xmlNodePtr node, GError **error);
Loads the contents of node into op. The XML tree passed through the node
argument must correspond to an XML tree saved using gda_server_operation_save_data_to_xml().
| 
 | a GdaServerOperation object | 
| 
 | a xmlNodePtr | 
| 
 | a place to store errors or NULL | 
| Returns : | TRUEif no error occurred | 
gboolean gda_server_operation_is_valid (GdaServerOperation *op, const gchar *xml_file, GError **error);
Tells if all the required values in op have been defined.
if xml_file is not NULL, the validity of op is tested against that specification, 
and not againts the current op's specification.
| 
 | a GdaServerOperation widget | 
| 
 | an XML specification file (see gda_server_operation_new()) | 
| 
 | a place to store an error, or NULL | 
| Returns : | TRUE if opis valid | 
"connection" property"connection" GdaConnection* : Read / Write / Construct Only
Connection to use.
"op-type" property"op-type" gint : Read / Write / Construct Only
Type of operation to be done.
Allowed values: [0,10]
Default value: 0
"provider" property"provider" GdaServerProvider* : Read / Write / Construct Only
Database provider which created the object.
"spec-filename" property"spec-filename" gchar* : Write / Construct Only
XML file which contains the object's data structure.
Default value: NULL
"sequence-item-added" signalvoid user_function (GdaServerOperation *op, gchar *seq_path, gint item_index, gpointer user_data) : Run First
Gets emitted whenever a new sequence item (from a sequence template) has been added
| 
 | the GdaServerOperation | 
| 
 | the path to the new sequence item | 
| 
 | the index (starting from 0) of the new sequence item in the sequence | 
| 
 | user data set when the signal handler was connected. | 
"sequence-item-remove" signalvoid user_function (GdaServerOperation *op, gchar *seq_path, gint item_index, gpointer user_data) : Run First
Gets emitted whenever a sequence item is about to be removed
| 
 | the GdaServerOperation | 
| 
 | the path to the sequence item to be removed | 
| 
 | the index (starting from 0) of the sequence item in the sequence | 
| 
 | user data set when the signal handler was connected. |