| Top |  |  |  |  | 
JSON-GLib provides API for serializing and deserializing GObject instances to and from JSON data streams.
Simple GObject classes can be (de)serialized into JSON objects, if the properties have compatible types with the native JSON types (integers, booleans, strings, string vectors). If the class to be (de)serialized has complex data types for properties (like boxed types or other objects) then the class should implement the provided JsonSerializable interface and its virtual functions.
JsonNode *
json_gobject_serialize (GObject *gobject);
Creates a JsonNode representing the passed GObject instance. Each member of the returned JSON object will map to a property of the GObject
the newly created JsonNode
of type JSON_NODE_OBJECT. Use json_node_unref() to free
the resources allocated by this function. 
[transfer full]
Since: 0.10
GObject * json_gobject_deserialize (GType gtype,JsonNode *node);
Creates a new GObject of type gtype
, and constructs it
using the members of the passed JsonObject
| gtype | the type of the GObject to create | |
| node | a JsonNode of type  | 
The newly created GObject
instance. Use g_object_unref() to free the resources
allocated by this function. 
[transfer full]
Since: 0.10
gchar * json_gobject_to_data (GObject *gobject,gsize *length);
Serializes a GObject into a JSON data stream, iterating recursively over each property.
If gobject
 implements the JsonSerializableIface interface, it will
be asked to serialize all its properties; otherwise, the default
implementation will be use to translate the compatible types into
JSON native types.
Since: 0.10
GObject * json_gobject_from_data (GType gtype,const gchar *data,gssize length,GError **error);
Deserializes a JSON data stream and creates the corresponding
GObject class. If gtype
 implements the JsonSerializableIface
interface, it will be asked to deserialize all the JSON members
into the respective properties; otherwise, the default implementation
will be used to translate the compatible JSON native types.
Note: the JSON data stream must be an object declaration.
Since: 0.10
GObject * json_construct_gobject (GType gtype,const gchar *data,gsize length,GError **error);
json_construct_gobject has been deprecated since version 0.10 and should not be used in newly-written code.
Use json_gobject_from_data() instead
Deserializes a JSON data stream and creates the corresponding
GObject class. If gtype
 implements the JsonSerializableIface
interface, it will be asked to deserialize all the JSON members
into the respective properties; otherwise, the default implementation
will be used to translate the compatible JSON native types.
Note: the JSON data stream must be an object declaration.
Since: 0.4
gchar * json_serialize_gobject (GObject *gobject,gsize *length);
json_serialize_gobject has been deprecated since version 0.10 and should not be used in newly-written code.
Use json_gobject_to_data() instead
Serializes a GObject into a JSON data stream. If gobject
 implements
the JsonSerializableIface interface, it will be asked to serizalize all
its properties; otherwise, the default implementation will be use to
translate the compatible types into JSON native types.