Как устранить утечку памяти при использовании кода, сгенерированного gdbus-codegen?

У меня есть интерфейс, описанный в формате DBus Introspection XML:

<!DOCTYPE node PUBLIC "-//freedesktop//DTD D-BUS Object Introspection 1.0//EN""http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd">
<node>
<interface name="com.example.foo">
<method name="Bar" />
</interface>
</node>

Я запускаю gdbus-codegen так:

gdbus-codegen --interface-prefix=com.example --generate-c-code=foo-dbus --c-namespace=Dbus foo.xml

Я использую код так:

int main()
{
DbusFoo * skeleton = dbus_foo_skeleton_new();
g_object_unref(skeleton);

return 0;
}

Но приложение заканчивает тем, что пропускало сигнал, сгенерированный в dbus_foo_default_init() который выглядит так:

static void
dbus_foo_default_init (DbusFooIface *iface)
{
/* GObject signals for incoming D-Bus method calls: */
/**
* DbusFoo::handle-bar:
* @object: A #DbusFoo.
* @invocation: A #GDBusMethodInvocation.
*
* Signal emitted when a remote caller is invoking the <link linkend="gdbus-method-com-example-foo.Bar">Bar()</link> D-Bus method.
*
* If a signal handler returns %TRUE, it means the signal handler will handle the invocation (e.g. take a reference to @invocation and eventually call dbus_foo_complete_bar() or e.g. g_dbus_method_invocation_return_error() on it) and no order signal handlers will run. If no signal handler handles the invocation, the %G_DBUS_ERROR_UNKNOWN_METHOD error is returned.
*
* Returns: %TRUE if the invocation was handled, %FALSE to let other signal handlers run.
*/
g_signal_new ("handle-bar",
G_TYPE_FROM_INTERFACE (iface),
G_SIGNAL_RUN_LAST,
G_STRUCT_OFFSET (DbusFooIface, handle_bar),
g_signal_accumulator_true_handled,
NULL,
g_cclosure_marshal_generic,
G_TYPE_BOOLEAN,
1,
G_TYPE_DBUS_METHOD_INVOCATION);

}

Мой вопрос:

Как выполнить очистку после использования кода, сгенерированного gdbus-codegen?

1

Решение

Я подозреваю, что вы найдете это, если вы запустите свою программу под Valgrind, используя последний файл подавлений GLib, нет утечки. Как сказал @ptomato в комментарии выше, сигналы считаются данными типа, и GObject никогда не освобождает это (за исключением динамически зарегистрированных типов). Тип данных выделяется один раз (при первом использовании) и никогда не освобождается. Не беспокойся об этом.

0

Другие решения


По вопросам рекламы [email protected]