2020-04-19 17:08:06 +02:00
<?xml version='1.0'?> <!-- * - nxml - * -->
< !DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
2023-12-25 15:48:33 +01:00
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
2020-11-09 13:23:58 +09:00
<!-- SPDX - License - Identifier: LGPL - 2.1 - or - later -->
2020-04-19 17:08:06 +02:00
<refentry id= "sd_bus_add_object_manager"
xmlns:xi="http://www.w3.org/2001/XInclude">
<refentryinfo >
<title > sd_bus_add_object_manager</title>
<productname > systemd</productname>
</refentryinfo>
<refmeta >
<refentrytitle > sd_bus_add_object_manager</refentrytitle>
<manvolnum > 3</manvolnum>
</refmeta>
<refnamediv >
<refname > sd_bus_add_object_manager</refname>
<refpurpose > Add a D-Bus object manager for a D-Bus object sub-tree</refpurpose>
</refnamediv>
<refsynopsisdiv >
<funcsynopsis >
<funcsynopsisinfo > #include < systemd/sd-bus.h> </funcsynopsisinfo>
<funcprototype >
<funcdef > int <function > sd_bus_add_object_manager</function> </funcdef>
<paramdef > sd_bus *<parameter > bus</parameter> </paramdef>
<paramdef > sd_bus_slot **<parameter > slot</parameter> </paramdef>
<paramdef > const char *<parameter > path</parameter> </paramdef>
</funcprototype>
</funcsynopsis>
</refsynopsisdiv>
<refsect1 >
<title > Description</title>
<para > <function > sd_bus_add_object_manager()</function> installs a handler for the given path
that implements the <function > GetManagedObjects()</function> method of the
<constant > org.freedesktop.DBus.ObjectManager</constant> interface. See
<ulink url= "https://dbus.freedesktop.org/doc/dbus-specification.html#standard-interfaces-objectmanager" >
org.freedesktop.DBus.ObjectManager</ulink> for more information.</para>
<para > To implement the <function > InterfacesAdded</function> and
<function > InterfacesRemoved</function> signals of the
<constant > org.freedesktop.DBus.ObjectManager</constant> interface, call
<citerefentry > <refentrytitle > sd_bus_emit_interfaces_added</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> and
<citerefentry > <refentrytitle > sd_bus_emit_interfaces_removed</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry>
whenever interfaces are added or removed from the sub-tree, respectively.</para>
2020-04-20 08:23:30 +02:00
<para > When <function > sd_bus_add_object_manager()</function> succeeds, a slot is created
2020-04-19 17:08:06 +02:00
internally. If the output parameter <replaceable > slot</replaceable> is <constant > NULL</constant> ,
a "floating" slot object is created, see
<citerefentry > <refentrytitle > sd_bus_slot_set_floating</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> .
Otherwise, a pointer to the slot object is returned. In that case, the reference to the slot
object should be dropped when the object manager is not needed anymore, see
<citerefentry > <refentrytitle > sd_bus_slot_unref</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> .
</para>
</refsect1>
<refsect1 >
<title > Return Value</title>
<para > On success, <function > sd_bus_add_object_manager()</function> returns a non-negative
integer. On failure, it returns a negative errno-style error code.</para>
<refsect2 >
<title > Errors</title>
<para > Returned errors may indicate the following problems:</para>
<variablelist >
<varlistentry >
<term > <constant > -EINVAL</constant> </term>
<listitem > <para > One of the required parameters is <constant > NULL</constant> or
2024-04-18 09:45:51 +09:00
<parameter > path</parameter> is not a valid object path.</para> </listitem>
2020-04-19 17:08:06 +02:00
</varlistentry>
<varlistentry >
<term > <constant > -ENOPKG</constant> </term>
2024-04-18 09:45:51 +09:00
<listitem > <para > The bus cannot be resolved.</para> </listitem>
2020-04-19 17:08:06 +02:00
</varlistentry>
<varlistentry >
<term > <constant > -ECHILD</constant> </term>
2024-04-18 09:45:51 +09:00
<listitem > <para > The bus was created in a different process, library or module instance.</para> </listitem>
2020-04-19 17:08:06 +02:00
</varlistentry>
<varlistentry >
<term > <constant > -ENOMEM</constant> </term>
2024-04-18 09:45:51 +09:00
<listitem > <para > Memory allocation failed.</para> </listitem>
2020-04-19 17:08:06 +02:00
</varlistentry>
</variablelist>
</refsect2>
</refsect1>
<xi:include href= "libsystemd-pkgconfig.xml" />
2023-09-04 13:46:35 +01:00
<refsect1 >
<title > History</title>
2024-04-18 09:45:51 +09:00
<para > <function > sd_bus_add_object_manager()</function> was added in version 221.</para>
2023-09-04 13:46:35 +01:00
</refsect1>
2020-04-19 17:08:06 +02:00
<refsect1 >
<title > See Also</title>
2023-12-22 19:09:32 +01:00
<para > <simplelist type= "inline" >
<member > <citerefentry > <refentrytitle > sd-bus</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > busctl</refentrytitle> <manvolnum > 1</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_bus_add_object_vtable</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_bus_emit_interfaces_added</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_bus_slot_unref</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
</simplelist> </para>
2020-04-19 17:08:06 +02:00
</refsect1>
</refentry>