X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=atk-adaptor%2Faccessible-register.c;h=14f256f2dae29d6eb48cd05916be2da860fe3eb9;hb=770fcb6cf42143eebe5ebd9660a1c8737edaca6b;hp=83c1c6d51d60d4324e05c7e68627b1e9ce3e1bb8;hpb=c72a4b4b0330733b2c2e0ed768d76ff85cd31500;p=platform%2Fcore%2Fuifw%2Fat-spi2-atk.git diff --git a/atk-adaptor/accessible-register.c b/atk-adaptor/accessible-register.c index 83c1c6d..14f256f 100644 --- a/atk-adaptor/accessible-register.c +++ b/atk-adaptor/accessible-register.c @@ -121,11 +121,26 @@ spi_register_init (SpiRegister * reg) } static void +deregister_object (gpointer data, GObject * gobj) +{ + SpiRegister *reg = SPI_REGISTER (data); + + spi_register_deregister_object (reg, gobj, FALSE); +} + +static void +spi_register_remove_weak_ref (gpointer key, gpointer val, gpointer reg) +{ + g_object_weak_unref (val, deregister_object, reg); +} + +static void spi_register_finalize (GObject * object) { SpiRegister *reg = SPI_REGISTER (object); - g_free (reg->ref2ptr); + g_hash_table_foreach (reg->ref2ptr, spi_register_remove_weak_ref, reg); + g_hash_table_unref (reg->ref2ptr); G_OBJECT_CLASS (spi_register_parent_class)->finalize (object); } @@ -186,16 +201,8 @@ ref_to_path (guint ref) * Removes the AtkObject from the reference lookup tables, meaning * it is no longer exposed over D-Bus. */ -static void -deregister_object (gpointer data, GObject * gobj) -{ - SpiRegister *reg = SPI_REGISTER (data); - - spi_register_deregister_object (reg, gobj); -} - void -spi_register_deregister_object (SpiRegister *reg, GObject *gobj) +spi_register_deregister_object (SpiRegister *reg, GObject *gobj, gboolean unref) { guint ref; @@ -206,6 +213,8 @@ spi_register_deregister_object (SpiRegister *reg, GObject *gobj) register_signals [OBJECT_DEREGISTERED], 0, gobj); + if (unref) + g_object_weak_unref (gobj, deregister_object, reg); g_hash_table_remove (reg->ref2ptr, GINT_TO_POINTER (ref)); #ifdef SPI_ATK_DEBUG