Well, I consider it a leak and need it cleaned up.
In gobject.c g_object_base_class_finalize() there is a call to _g_signals_destroy() but I don't see exactly how this ties into the type system of glib.
Anders
This message is subject to the following terms and conditions: MAIL DISCLAIMER<http://www.barco.com/en/maildisclaimer>
-----Original Message-----
From: Tristan Van Berkom [mailto:tristan upstairslabs com]
Sent: 9. februar 2015 16:35
To: Norman, Anders
Cc: gtk-list gnome org
Subject: Re: Memory leak in gdbus-codegen generated code
On Tue, 2015-02-10 at 00:32 +0900, Tristan Van Berkom wrote:
> On Mon, 2015-02-09 at 15:05 +0000, Norman, Anders wrote:
> [...]
> > But the application ends up leaking the signal generated in `dbus_foo_default_init()` which looks like this:
> >
> > 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);
> >
> > }
> >
> > Am I using the generated code wrong or is it a bug in glib/gdbus-codegen?
>
> This is not considered a leak, a signal connection leaking would be a
> leak, but a signal declaration as such, is expected to be kept with
> the statically registered GTypeInstance.
Err, I should have just said GType, the GTypeInstance is indeed instance data and freed with every object, sorry for the confusion.
Cheers,
-Tristan
_______________________________________________
gtk-list mailing list
gtk-list gnome org
https://mail.gnome.org/mailman/listinfo/gtk-list