gdbusGIODeveloperDavidZeuthenzeuthen@gmail.comgdbus-codegen1User Commandsgdbus-codegenD-Bus code and documentation generatorgdbus-codegen, org.project.PrefixOUTFILESYourProjectOUTFILESFILEELEMENTKEYVALUEFILEFILEDescriptiongdbus-codegen is used to generate code and/or
documentation for one or more D-Bus interfaces. The tool reads
D-Bus
Introspection XML files and generates output files. The
tool currently supports generating C code (via
) and Docbook XML (via
).
Generating C code
When generating C code, a
#GInterface-derived type is generated for each D-Bus
interface. Additionally, for every generated type,
FooBar, two concrete instantiable types,
FooBarProxy and FooBarSkeleton, implementing
said interface are also generated. The former is derived from
#GDBusProxy and intended for use on the client side
while the latter is derived from the
#GDBusInterfaceSkeleton type making it easy to export on a
#GDBusConnection either directly or via a
#GDBusObjectManagerServer instance.
The name of each generated C type is derived from the D-Bus
interface name stripped with the prefix given with
and with the dots removed and
initial characters capitalized. For example, for the D-Bus
interface com.acme.Coyote the name used is
ComAcmeCoyote. For the D-Bus interface
org.project.Bar.Frobnicator with
org.project., the name used is
BarFrobnicator.
For methods, signals and properties, if not specified, the name
defaults to the name of the method, signal or property.
Two forms of the name are used - the CamelCase form and the
lower-case form. The CamelCase form is used for the #GType and
struct name, while lower-case form is used in function names. The
lower-case form is calculated by converting from CamelCase to
lower-case and inserting underscores at word boundaries (using
certain heuristics).
If the value given by the org.gtk.GDBus.C.Name
annotation or the option contains
an underscore (sometimes called Ugly_Case),
then the camel-case name is derived by removing all underscores,
and the lower-case name is derived by lower-casing the
string. This is useful in some situations where abbreviations are
used. For example, if the annotation is used on the interface
net.MyCorp.MyApp.iSCSITarget with the value
iSCSI_Target the CamelCase form is
iSCSITarget while the lower-case form is
iscsi_target. If the annotation is used on the
method EjectTheiPod with the value
Eject_The_iPod, the lower-case form is
eject_the_ipod.
Generating Docbook documentation
Each generated Docbook XML file (see the
option for details) is a RefEntry
article describing the D-Bus interface.
Options
The following options are supported:
,
Show help and exit.
FILE
The D-Bus introspection XML file.
org.project.Prefix.
A prefix to strip from all D-Bus interface names when
calculating the typename for the C binding and the Docbook
sortas
attribute.
OUTFILES
Generate Docbook Documentation for each D-Bus interface and
put it in OUTFILES-NAME.xml where
NAME is a place-holder for the interface
name, e.g. net.Corp.FooBar and so on.
OUTFILES
Generate C code for all D-Bus interfaces and put it in
OUTFILES.c and
OUTFILES.h.
YourProject
The namespace to use for generated C code. This is expected
to be in CamelCase
or Ugly_Case (see above).
If this option is passed, suitable #GDBusObject,
#GDBusObjectProxy, #GDBusObjectSkeleton and
#GDBusObjectManagerClient subclasses are generated.
ELEMENTKEYVALUE
Used to inject D-Bus annotations into the given XML
files. It can be used with interfaces, methods, signals,
properties and arguments in the following way:
Any UTF-8 string can be used for KEY and VALUE.
Supported D-Bus Annotations
The following D-Bus annotations are supported by
gdbus-codegen:
org.freedesktop.DBus.Deprecated
Can be used on any <interface>,
<method>,
<signal> and
<property> element to specify that
the element is deprecated if its value is
true. Note that this annotation is
defined in the D-Bus
specification and can only assume the values
true and false. In
particular, you cannot specify the version that the element
was deprecated in nor any helpful deprecation message. Such
information should be added to the element documentation
instead.
When generating C code, this annotation is used to add
#G_GNUC_DEPRECATED to generated functions for the element.
When generating Docbook XML, a deprecation warning will
appear along the documentation for the element.
org.gtk.GDBus.Since
Can be used on any <interface>,
<method>,
<signal> and
<property> element to specify the
version (any free-form string but compared using a
version-aware sort function) the element appeared in.
When generating C code, this field is used to ensure
function pointer order for preserving ABI/API, see .
When generating Docbook XML, the value of this tag appears
in the documentation.
org.gtk.GDBus.DocString
A string with Docbook content for documentation. This annotation can
be used on <interface>,
<method>,
<signal>,
<property> and
<arg> elements.
org.gtk.GDBus.DocString.Short
A string with Docbook content for short/brief
documentation. This annotation can only be used on
<interface> elements.
org.gtk.GDBus.C.Name
Can be used on any <interface>,
<method>,
<signal> and
<property> element to specify the
name to use when generating C code. The value is expected to
be in CamelCase
or Ugly_Case (see above).
org.gtk.GDBus.C.ForceGVariant
If set to a non-empty string, a #GVariant instance will
be used instead of the natural C type. This annotation can
be used on any <arg> and
<property> element.
org.gtk.GDBus.C.UnixFD
If set to a non-empty string, the generated code will
include parameters to exchange file descriptors using the
#GUnixFDList type. This annotation can be used on
<method> elements.
As an easier alternative to using the
org.gtk.GDBus.DocString annotation, note that
parser used by gdbus-codegen parses XML
comments in a way similar to gtk-doc:
longer description.
This is a new paragraph.
-->
]]>
Note that can be used in any inline
documentation bit (e.g. for interfaces, methods, signals and
properties) to set the org.gtk.GDBus.Since
annotation. For the org.gtk.GDBus.DocString
annotation (and inline comments), note that substrings of the form
,
,
and
are all
expanded to links to the respective interface, method, signal and
property.
Additionally, substrings starting with @ and % characters are rendered as
parameter and
constant respectively.
If both XML comments and
org.gtk.GDBus.DocString or
org.gtk.GDBus.DocString.Short annotations are
present, the latter wins.
Example
Consider the following D-Bus Introspection XML.
]]>
If gdbus-codegen is used on this file like this:
two files called
myapp-generated.[ch] are
generated. The files provide an abstract
#GTypeInterface-derived type called
MyAppFrobber as well as two instantiable types with
the same name but suffixed with Proxy and
Skeleton. The generated file, roughly, contains the
following facilities:
Thus, for every D-Bus method, there will be three C functions for
calling the method, one #GObject signal for handling an incoming
call and one C function for completing an incoming call. For every
D-Bus signal, there's one #GObject signal and one C function for
emitting it. For every D-Bus property, two C functions are
generated (one setter, one getter) and one #GObject property. The
following table summarizes the generated facilities and where they
are applicable:
ClientServerTypesUse MyAppFrobberProxyAny type implementing the MyAppFrobber interfaceMethodsUse m_a_f_hello_world() to call.Receive via the handle_hello_world() signal handler. Complete the call with m_a_f_complete_hello_world()SignalsConnect to the ::notification GObject signal.Use m_a_f_emit_notification() to emit signal.Properties (Reading)Use m_a_f_get_verbose() or :verbose.Implement #GObject's get_property() vfunc.Properties (writing)Use m_a_f_set_verbose() or :verbose.Implement #GObject's set_property() vfunc.Client-side usage
You can use the generated proxy type with the generated
constructors:
Instead of using the generic #GDBusProxy facilities, one can use
the generated methods such as
my_app_frobber_call_hello_world() to invoke
the net.Corp.MyApp.Frobber.HelloWorld()
D-Bus method, connect to the the
::notification GObject signal to receive
the net.Corp.MyApp.Frobber::Notication
D-Bus signal and get/set the
net.Corp.MyApp.Frobber:Verbose D-Bus
Property using either the GObject property
:verbose or the
my_app_get_verbose() and
my_app_set_verbose() methods. Use the
standard #GObject::notify signal to listen to property changes.
Note that all property access is via #GDBusProxy's
property cache so no I/O is ever done when reading properties.
Also note that setting a property will cause the
org.freedesktop.DBus.Properties.Set method to be
called on the remote object. This call, however, is asynchronous
so setting a property won't block. Further, the change is
delayed and no error checking is possible.
Server-side usage
The generated MyAppFrobber interface is designed so
it is easy to implement it in a #GObject
subclass. For example, to handle
HelloWorld() method invocations, set the
vfunc for handle_hello_hello_world() in the
MyAppFrobberIface structure. Similary, to handle
the net.Corp.MyApp.Frobber:Verbose
property override the :verbose #GObject
property from the subclass. To emit a signal, use
e.g. my_app_emit_signal() or
g_signal_emit_by_name().
Instead of subclassing, it is often easier to use the generated
MyAppFrobberSkeleton subclass. To handle incoming
method calls, use g_signal_connect() with
the ::handle-* signals and instead of
overriding #GObject's
get_property() and
set_property() vfuncs, use
g_object_get() and
g_object_set() or the generated property
getters and setters (the generated class has an internal
property bag implementation).
To facilitate atomic changesets (multiple properties changing at
the same time), #GObject::notify signals are queued up when
received. The queue is drained in an idle handler (which is called from the
thread-default main loop
of the thread where the skeleton object was
contructed) and will cause emissions of the org.freedesktop.DBus.Properties::PropertiesChanged
signal with all the properties that have changed. Use
g_dbus_interface_skeleton_flush() or
g_dbus_object_skeleton_flush() to empty the queue
immediately. Use g_object_freeze_notify() and
g_object_thaw_notify() for atomic changesets if on a different
thread.
C Type Mapping
Scalar types
(type-strings
'b',
'y',
'n',
'q',
'i',
'u',
'x',
't' and
'd')
),
strings (type-strings
's',
'ay',
'o' and
'g') and
arrays of string (type-strings
'as',
'ao' and
'aay')
are mapped to the natural types,
e.g. #gboolean, #gdouble, #gint, gchar*,
gchar** and
so on. Everything else is mapped to the #GVariant
type.
This automatic mapping can be turned off by using the annotation
org.gtk.GDBus.C.ForceGVariant - if used then a
#GVariant is always exchanged instead of the
corresponding native C type. This annotation may be convenient to
use when using
bytestrings (type-string 'ay')
for data that could have embedded NUL bytes.
Stability Guarantees
The generated C functions are guaranteed to not change their ABI
that is, if a method, signal or property does not change its
signature in the introspection XML, the generated C functions will
not change its C ABI either. The ABI of the generated instance and
class structures will be preserved as well.
The ABI of the generated #GTypes will be preserved only if
the org.gtk.GDBus.Since annotation is used
judiciously — this is because the VTable for the #GInterface
relies on functions pointers for signal handlers. Specifically, if
a D-Bus method, property or signal or is added to a D-Bus
interface, then ABI of the generated #GInterface type is preserved
if, and only if, each added method, property signal is annotated
with they org.gtk.GDBus.Since annotation using
a greater version number than previous versions.
The generated C code currently happens to be annotated with gtk-doc / GObject
Introspection comments / annotations. The layout and
contents might change in the future so no guarantees about
e.g. SECTION usage etc. is given.
While the generated Docbook for D-Bus interfaces isn't expected to
change, no guarantees are given at this point.
It is important to note that the generated code should not be
checked into revision control systems, nor it should be included
in distributed source archives.
Bugs
Please send bug reports to either the distribution bug tracker
or the upstream bug tracker at
https://bugzilla.gnome.org/enter_bug.cgi?product=glib.
See alsogdbus1