GIO Reference Manual | ||||
---|---|---|---|---|
Top | Description | Object Hierarchy |
#include <gio/gio.h> GDBusAnnotationInfo; GDBusArgInfo; GDBusMethodInfo; GDBusSignalInfo; enum GDBusPropertyInfoFlags; GDBusPropertyInfo; GDBusInterfaceInfo; GDBusNodeInfo; const gchar * g_dbus_annotation_info_lookup (GDBusAnnotationInfo **annotations
,const gchar *name
); GDBusMethodInfo * g_dbus_interface_info_lookup_method (GDBusInterfaceInfo *info
,const gchar *name
); GDBusSignalInfo * g_dbus_interface_info_lookup_signal (GDBusInterfaceInfo *info
,const gchar *name
); GDBusPropertyInfo * g_dbus_interface_info_lookup_property (GDBusInterfaceInfo *info
,const gchar *name
); void g_dbus_interface_info_cache_build (GDBusInterfaceInfo *info
); void g_dbus_interface_info_cache_release (GDBusInterfaceInfo *info
); void g_dbus_interface_info_generate_xml (GDBusInterfaceInfo *info
,guint indent
,GString *string_builder
); GDBusNodeInfo * g_dbus_node_info_new_for_xml (const gchar *xml_data
,GError **error
); GDBusInterfaceInfo * g_dbus_node_info_lookup_interface (GDBusNodeInfo *info
,const gchar *name
); void g_dbus_node_info_generate_xml (GDBusNodeInfo *info
,guint indent
,GString *string_builder
); #define G_TYPE_DBUS_NODE_INFO #define G_TYPE_DBUS_INTERFACE_INFO #define G_TYPE_DBUS_METHOD_INFO #define G_TYPE_DBUS_SIGNAL_INFO #define G_TYPE_DBUS_PROPERTY_INFO #define G_TYPE_DBUS_ARG_INFO #define G_TYPE_DBUS_ANNOTATION_INFO GDBusNodeInfo * g_dbus_node_info_ref (GDBusNodeInfo *info
); GDBusInterfaceInfo * g_dbus_interface_info_ref (GDBusInterfaceInfo *info
); GDBusMethodInfo * g_dbus_method_info_ref (GDBusMethodInfo *info
); GDBusSignalInfo * g_dbus_signal_info_ref (GDBusSignalInfo *info
); GDBusPropertyInfo * g_dbus_property_info_ref (GDBusPropertyInfo *info
); GDBusArgInfo * g_dbus_arg_info_ref (GDBusArgInfo *info
); GDBusAnnotationInfo * g_dbus_annotation_info_ref (GDBusAnnotationInfo *info
); void g_dbus_node_info_unref (GDBusNodeInfo *info
); void g_dbus_interface_info_unref (GDBusInterfaceInfo *info
); void g_dbus_method_info_unref (GDBusMethodInfo *info
); void g_dbus_signal_info_unref (GDBusSignalInfo *info
); void g_dbus_property_info_unref (GDBusPropertyInfo *info
); void g_dbus_arg_info_unref (GDBusArgInfo *info
); void g_dbus_annotation_info_unref (GDBusAnnotationInfo *info
);
GBoxed +----GDBusAnnotationInfo
GBoxed +----GDBusArgInfo
GBoxed +----GDBusMethodInfo
GBoxed +----GDBusSignalInfo
GBoxed +----GDBusPropertyInfo
GBoxed +----GDBusInterfaceInfo
GBoxed +----GDBusNodeInfo
Various data structures and convenience routines to parse and
generate D-Bus introspection XML. Introspection information is
used when registering objects with g_dbus_connection_register_object()
.
The format of D-Bus introspection XML is specified in the D-Bus specification.
typedef struct { volatile gint ref_count; gchar *key; gchar *value; GDBusAnnotationInfo **annotations; } GDBusAnnotationInfo;
Information about an annotation.
volatile gint |
The reference count or -1 if statically allocated. |
gchar * |
The name of the annotation, e.g. "org.freedesktop.DBus.Deprecated". |
gchar * |
The value of the annotation. |
GDBusAnnotationInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusAnnotationInfo structures or NULL if there are no annotations. [array zero-terminated=1]
|
Since 2.26
typedef struct { volatile gint ref_count; gchar *name; gchar *signature; GDBusAnnotationInfo **annotations; } GDBusArgInfo;
Information about an argument for a method or a signal.
volatile gint |
The reference count or -1 if statically allocated. |
gchar * |
Name of the argument, e.g. unix_user_id . |
gchar * |
D-Bus signature of the argument (a single complete type). |
GDBusAnnotationInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusAnnotationInfo structures or NULL if there are no annotations. [array zero-terminated=1]
|
Since 2.26
typedef struct { volatile gint ref_count; gchar *name; GDBusArgInfo **in_args; GDBusArgInfo **out_args; GDBusAnnotationInfo **annotations; } GDBusMethodInfo;
Information about a method on an D-Bus interface.
volatile gint |
The reference count or -1 if statically allocated. |
gchar * |
The name of the D-Bus method, e.g. RequestName . |
GDBusArgInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusArgInfo structures or NULL if there are no in arguments. [array zero-terminated=1]
|
GDBusArgInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusArgInfo structures or NULL if there are no out arguments. [array zero-terminated=1]
|
GDBusAnnotationInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusAnnotationInfo structures or NULL if there are no annotations. [array zero-terminated=1]
|
Since 2.26
typedef struct { volatile gint ref_count; gchar *name; GDBusArgInfo **args; GDBusAnnotationInfo **annotations; } GDBusSignalInfo;
Information about a signal on a D-Bus interface.
volatile gint |
The reference count or -1 if statically allocated. |
gchar * |
The name of the D-Bus signal, e.g. "NameOwnerChanged". |
GDBusArgInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusArgInfo structures or NULL if there are no arguments. [array zero-terminated=1]
|
GDBusAnnotationInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusAnnotationInfo structures or NULL if there are no annotations. [array zero-terminated=1]
|
Since 2.26
typedef enum { G_DBUS_PROPERTY_INFO_FLAGS_NONE = 0, G_DBUS_PROPERTY_INFO_FLAGS_READABLE = (1<<0), G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE = (1<<1) } GDBusPropertyInfoFlags;
Flags describing the access control of a D-Bus property.
No flags set. | |
Property is readable. | |
Property is writable. |
Since 2.26
typedef struct { volatile gint ref_count; gchar *name; gchar *signature; GDBusPropertyInfoFlags flags; GDBusAnnotationInfo **annotations; } GDBusPropertyInfo;
Information about a D-Bus property on a D-Bus interface.
volatile gint |
The reference count or -1 if statically allocated. |
gchar * |
The name of the D-Bus property, e.g. "SupportedFilesystems". |
gchar * |
The D-Bus signature of the property (a single complete type). |
GDBusPropertyInfoFlags |
Access control flags for the property. |
GDBusAnnotationInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusAnnotationInfo structures or NULL if there are no annotations. [array zero-terminated=1]
|
Since 2.26
typedef struct { volatile gint ref_count; gchar *name; GDBusMethodInfo **methods; GDBusSignalInfo **signals; GDBusPropertyInfo **properties; GDBusAnnotationInfo **annotations; } GDBusInterfaceInfo;
Information about a D-Bus interface.
volatile gint |
The reference count or -1 if statically allocated. |
gchar * |
The name of the D-Bus interface, e.g. "org.freedesktop.DBus.Properties". |
GDBusMethodInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusMethodInfo structures or NULL if there are no methods. [array zero-terminated=1]
|
GDBusSignalInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusSignalInfo structures or NULL if there are no signals. [array zero-terminated=1]
|
GDBusPropertyInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusPropertyInfo structures or NULL if there are no properties. [array zero-terminated=1]
|
GDBusAnnotationInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusAnnotationInfo structures or NULL if there are no annotations. [array zero-terminated=1]
|
Since 2.26
typedef struct { volatile gint ref_count; gchar *path; GDBusInterfaceInfo **interfaces; GDBusNodeInfo **nodes; GDBusAnnotationInfo **annotations; } GDBusNodeInfo;
Information about nodes in a remote object hierarchy.
volatile gint |
The reference count or -1 if statically allocated. |
gchar * |
The path of the node or NULL if omitted. Note that this may be a relative path. See the D-Bus specification for more details. |
GDBusInterfaceInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusInterfaceInfo structures or NULL if there are no interfaces. [array zero-terminated=1]
|
GDBusNodeInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusNodeInfo structures or NULL if there are no nodes. [array zero-terminated=1]
|
GDBusAnnotationInfo ** |
A pointer to a NULL -terminated array of pointers to GDBusAnnotationInfo structures or NULL if there are no annotations. [array zero-terminated=1]
|
Since 2.26
const gchar * g_dbus_annotation_info_lookup (GDBusAnnotationInfo **annotations
,const gchar *name
);
Looks up the value of an annotation.
The cost of this function is O(n) in number of annotations.
|
A NULL -terminated array of annotations or NULL . [array zero-terminated=1][allow-none]
|
|
The name of the annotation to look up. |
Returns : |
The value or NULL if not found. Do not free, it is owned by annotations . |
Since 2.26
GDBusMethodInfo * g_dbus_interface_info_lookup_method (GDBusInterfaceInfo *info
,const gchar *name
);
Looks up information about a method.
The cost of this function is O(n) in number of methods unless
g_dbus_interface_info_cache_build()
has been used on info
.
|
A GDBusInterfaceInfo. |
|
A D-Bus method name (typically in CamelCase) |
Returns : |
A GDBusMethodInfo or NULL if not found. Do not free, it is owned by info . [transfer none]
|
Since 2.26
GDBusSignalInfo * g_dbus_interface_info_lookup_signal (GDBusInterfaceInfo *info
,const gchar *name
);
Looks up information about a signal.
The cost of this function is O(n) in number of signals unless
g_dbus_interface_info_cache_build()
has been used on info
.
|
A GDBusInterfaceInfo. |
|
A D-Bus signal name (typically in CamelCase) |
Returns : |
A GDBusSignalInfo or NULL if not found. Do not free, it is owned by info . [transfer none]
|
Since 2.26
GDBusPropertyInfo * g_dbus_interface_info_lookup_property (GDBusInterfaceInfo *info
,const gchar *name
);
Looks up information about a property.
The cost of this function is O(n) in number of properties unless
g_dbus_interface_info_cache_build()
has been used on info
.
|
A GDBusInterfaceInfo. |
|
A D-Bus property name (typically in CamelCase). |
Returns : |
A GDBusPropertyInfo or NULL if not found. Do not free, it is owned by info . [transfer none]
|
Since 2.26
void g_dbus_interface_info_cache_build (GDBusInterfaceInfo *info
);
Builds a lookup-cache to speed up
g_dbus_interface_info_lookup_method()
,
g_dbus_interface_info_lookup_signal()
and
g_dbus_interface_info_lookup_property()
.
If this has already been called with info
, the existing cache is
used and its use count is increased.
Note that info
cannot be modified until
g_dbus_interface_info_cache_release()
is called.
|
A GDBusInterfaceInfo. |
Since 2.30
void g_dbus_interface_info_cache_release (GDBusInterfaceInfo *info
);
Decrements the usage count for the cache for info
built by
g_dbus_interface_info_cache_build()
(if any) and frees the
resources used by the cache if the usage count drops to zero.
|
A GDBusInterfaceInfo |
Since 2.30
void g_dbus_interface_info_generate_xml (GDBusInterfaceInfo *info
,guint indent
,GString *string_builder
);
Appends an XML representation of info
(and its children) to string_builder
.
This function is typically used for generating introspection XML
documents at run-time for handling the
org.freedesktop.DBus.Introspectable.Introspect
method.
|
A GDBusNodeInfo |
|
Indentation level. |
|
A GString to to append XML data to. [out] |
Since 2.26
GDBusNodeInfo * g_dbus_node_info_new_for_xml (const gchar *xml_data
,GError **error
);
Parses xml_data
and returns a GDBusNodeInfo representing the data.
The introspection XML must contain exactly one top-level
<node>
element.
Note that this routine is using a GMarkup-based parser that only accepts a subset of valid XML documents.
|
Valid D-Bus introspection XML. |
|
Return location for error. |
Returns : |
A GDBusNodeInfo structure or NULL if error is set. Free
with g_dbus_node_info_unref() . |
Since 2.26
GDBusInterfaceInfo * g_dbus_node_info_lookup_interface (GDBusNodeInfo *info
,const gchar *name
);
Looks up information about an interface.
The cost of this function is O(n) in number of interfaces.
|
A GDBusNodeInfo. |
|
A D-Bus interface name. |
Returns : |
A GDBusInterfaceInfo or NULL if not found. Do not free, it is owned by info . [transfer none]
|
Since 2.26
void g_dbus_node_info_generate_xml (GDBusNodeInfo *info
,guint indent
,GString *string_builder
);
Appends an XML representation of info
(and its children) to string_builder
.
This function is typically used for generating introspection XML documents at run-time for
handling the org.freedesktop.DBus.Introspectable.Introspect
method.
|
A GDBusNodeInfo. |
|
Indentation level. |
|
A GString to to append XML data to. [out] |
Since 2.26
#define G_TYPE_DBUS_NODE_INFO (g_dbus_node_info_get_type ())
The GType for a boxed type holding a GDBusNodeInfo.
Since 2.26
#define G_TYPE_DBUS_INTERFACE_INFO (g_dbus_interface_info_get_type ())
The GType for a boxed type holding a GDBusInterfaceInfo.
Since 2.26
#define G_TYPE_DBUS_METHOD_INFO (g_dbus_method_info_get_type ())
The GType for a boxed type holding a GDBusMethodInfo.
Since 2.26
#define G_TYPE_DBUS_SIGNAL_INFO (g_dbus_signal_info_get_type ())
The GType for a boxed type holding a GDBusSignalInfo.
Since 2.26
#define G_TYPE_DBUS_PROPERTY_INFO (g_dbus_property_info_get_type ())
The GType for a boxed type holding a GDBusPropertyInfo.
Since 2.26
#define G_TYPE_DBUS_ARG_INFO (g_dbus_arg_info_get_type ())
The GType for a boxed type holding a GDBusArgInfo.
Since 2.26
#define G_TYPE_DBUS_ANNOTATION_INFO (g_dbus_annotation_info_get_type ())
The GType for a boxed type holding a GDBusAnnotationInfo.
Since 2.26
GDBusNodeInfo * g_dbus_node_info_ref (GDBusNodeInfo *info
);
If info
is statically allocated does nothing. Otherwise increases
the reference count.
|
A GDBusNodeInfo |
Returns : |
The same info . |
Since 2.26
GDBusInterfaceInfo * g_dbus_interface_info_ref (GDBusInterfaceInfo *info
);
If info
is statically allocated does nothing. Otherwise increases
the reference count.
|
A GDBusInterfaceInfo |
Returns : |
The same info . |
Since 2.26
GDBusMethodInfo * g_dbus_method_info_ref (GDBusMethodInfo *info
);
If info
is statically allocated does nothing. Otherwise increases
the reference count.
|
A GDBusMethodInfo |
Returns : |
The same info . |
Since 2.26
GDBusSignalInfo * g_dbus_signal_info_ref (GDBusSignalInfo *info
);
If info
is statically allocated does nothing. Otherwise increases
the reference count.
|
A GDBusSignalInfo |
Returns : |
The same info . |
Since 2.26
GDBusPropertyInfo * g_dbus_property_info_ref (GDBusPropertyInfo *info
);
If info
is statically allocated does nothing. Otherwise increases
the reference count.
|
A GDBusPropertyInfo |
Returns : |
The same info . |
Since 2.26
GDBusArgInfo * g_dbus_arg_info_ref (GDBusArgInfo *info
);
If info
is statically allocated does nothing. Otherwise increases
the reference count.
|
A GDBusArgInfo |
Returns : |
The same info . |
Since 2.26
GDBusAnnotationInfo * g_dbus_annotation_info_ref (GDBusAnnotationInfo *info
);
If info
is statically allocated does nothing. Otherwise increases
the reference count.
|
A GDBusNodeInfo |
Returns : |
The same info . |
Since 2.26
void g_dbus_node_info_unref (GDBusNodeInfo *info
);
If info
is statically allocated, does nothing. Otherwise decreases
the reference count of info
. When its reference count drops to 0,
the memory used is freed.
|
A GDBusNodeInfo. |
Since 2.26
void g_dbus_interface_info_unref (GDBusInterfaceInfo *info
);
If info
is statically allocated, does nothing. Otherwise decreases
the reference count of info
. When its reference count drops to 0,
the memory used is freed.
|
A GDBusInterfaceInfo. |
Since 2.26
void g_dbus_method_info_unref (GDBusMethodInfo *info
);
If info
is statically allocated, does nothing. Otherwise decreases
the reference count of info
. When its reference count drops to 0,
the memory used is freed.
|
A GDBusMethodInfo. |
Since 2.26
void g_dbus_signal_info_unref (GDBusSignalInfo *info
);
If info
is statically allocated, does nothing. Otherwise decreases
the reference count of info
. When its reference count drops to 0,
the memory used is freed.
|
A GDBusSignalInfo. |
Since 2.26
void g_dbus_property_info_unref (GDBusPropertyInfo *info
);
If info
is statically allocated, does nothing. Otherwise decreases
the reference count of info
. When its reference count drops to 0,
the memory used is freed.
|
A GDBusPropertyInfo. |
Since 2.26
void g_dbus_arg_info_unref (GDBusArgInfo *info
);
If info
is statically allocated, does nothing. Otherwise decreases
the reference count of info
. When its reference count drops to 0,
the memory used is freed.
|
A GDBusArgInfo. |
Since 2.26
void g_dbus_annotation_info_unref (GDBusAnnotationInfo *info
);
If info
is statically allocated, does nothing. Otherwise decreases
the reference count of info
. When its reference count drops to 0,
the memory used is freed.
|
A GDBusAnnotationInfo. |
Since 2.26