|  |  |  | Libmergeant Reference Manual |  | 
|---|
#define MG_XML_STORAGE_TYPE #define MG_XML_STORAGE (obj) #define IS_MG_XML_STORAGE (obj) #define MG_XML_STORAGE_GET_IFACE (obj) struct MgXmlStorage; struct MgXmlStorageIface; GType mg_xml_storage_get_type (void); gchar* mg_xml_storage_get_xml_id (MgXmlStorage *iface); xmlNodePtr mg_xml_storage_save_to_xml (MgXmlStorage *iface, GError **error); gboolean mg_xml_storage_load_from_xml (MgXmlStorage *iface, xmlNodePtr node, GError **error);
MgXmlStorage is implemented by MgTarget, MgDatabase, MgQfFunc, MgDbField, MgQuery, MgDbTable, MgServer, MgCondition, MgQfField, MgQfValue, MgDbConstraint, MgJoin, MgServerAggregate, MgServerFunction, MgServerDataType and MgQfAll.
Any object which implements this interface can be streamed and restored to and from an XML file.
#define MG_XML_STORAGE(obj) G_TYPE_CHECK_INSTANCE_CAST (obj, mg_xml_storage_get_type(), MgXmlStorage)
| obj : | 
 | 
#define IS_MG_XML_STORAGE(obj) G_TYPE_CHECK_INSTANCE_TYPE (obj, mg_xml_storage_get_type ())
| obj : | 
 | 
#define MG_XML_STORAGE_GET_IFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), MG_XML_STORAGE_TYPE, MgXmlStorageIface))
| obj : | 
 | 
struct MgXmlStorageIface {
	GTypeInterface           g_iface;
	/* virtual table */
	gchar      *(* get_xml_id)      (MgXmlStorage *iface);
	xmlNodePtr  (* save_to_xml)     (MgXmlStorage *iface, GError **error);
	gboolean    (* load_from_xml)   (MgXmlStorage *iface, xmlNodePtr node, GError **error);
};gchar* mg_xml_storage_get_xml_id (MgXmlStorage *iface);
Fetch the xml id string of the object, it's up to the caller to free the string.
| iface : | an object which implements the MgXmlStorage interface | 
| Returns : | the xml id. | 
xmlNodePtr mg_xml_storage_save_to_xml (MgXmlStorage *iface, GError **error);
Creates a new xmlNodePtr structure and fills it with data representing the object given as argument.
| iface : | an object which implements the MgXmlStorage interface | 
| error : | location to store error, or NULL | 
| Returns : | the new XML node, or NULL if an error occured. | 
gboolean mg_xml_storage_load_from_xml (MgXmlStorage *iface, xmlNodePtr node, GError **error);
Updates the object with data stored in the XML node. The object MUST already exist and be of the correct type before calling this function. This is a virtual function.
| iface : | an object which implements the MgXmlStorage interface | 
| node : | an XML node from an XML structure | 
| error : | location to store error, or NULL | 
| Returns : | TRUE if no error occured. | 
| <<< Interfaces | MgDataHandler >>> |