X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=atk-adaptor%2Faccessible-register.c;h=14f256f2dae29d6eb48cd05916be2da860fe3eb9;hb=08cd4311cdcfd3355fbde0c1e3389dbfd1417cee;hp=97ada1db348cdb3b86d4dea66fb6cf9cf8f623f7;hpb=0c6971bdf4c2c0f3e64580287cd17555c32881dd;p=platform%2Fcore%2Fuifw%2Fat-spi2-atk.git diff --git a/atk-adaptor/accessible-register.c b/atk-adaptor/accessible-register.c index 97ada1d..14f256f 100644 --- a/atk-adaptor/accessible-register.c +++ b/atk-adaptor/accessible-register.c @@ -47,16 +47,18 @@ * */ -#define SPI_ATK_PATH_PREFIX_LENGTH 22 -#define SPI_ATK_OBJECT_PATH_PREFIX "/org/at_spi/accessible" -#define SPI_ATK_OBJECT_PATH_DESKTOP SPI_ATK_OBJECT_PATH_PREFIX "/desktop" +#define SPI_ATK_PATH_PREFIX_LENGTH 27 +#define SPI_ATK_OBJECT_PATH_PREFIX "/org/a11y/atspi/accessible/" +#define SPI_ATK_OBJECT_PATH_ROOT "root" -#define SPI_ATK_OBJECT_REFERENCE_TEMPLATE SPI_ATK_OBJECT_PATH_PREFIX "/%d" +#define SPI_ATK_OBJECT_REFERENCE_TEMPLATE SPI_ATK_OBJECT_PATH_PREFIX "%d" #define SPI_DBUS_ID "spi-dbus-id" SpiRegister *spi_global_register = NULL; +static const gchar * spi_register_root_path = SPI_ATK_OBJECT_PATH_PREFIX SPI_ATK_OBJECT_PATH_ROOT; + enum { OBJECT_REGISTERED, @@ -119,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); } @@ -184,10 +201,9 @@ 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) +void +spi_register_deregister_object (SpiRegister *reg, GObject *gobj, gboolean unref) { - SpiRegister *reg = SPI_REGISTER (data); guint ref; ref = object_to_ref (gobj); @@ -197,6 +213,8 @@ deregister_object (gpointer data, 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 @@ -243,14 +261,12 @@ spi_register_path_to_object (SpiRegister * reg, const char *path) != 0) return NULL; - path += SPI_ATK_PATH_PREFIX_LENGTH; /* Skip over the prefix */ + path += SPI_ATK_PATH_PREFIX_LENGTH; /* Skip over the prefix */ - if (!g_strcmp0 (SPI_ATK_OBJECT_PATH_DESKTOP, path)) - return G_OBJECT (atk_get_root ()); - if (path[0] != '/') - return NULL; + /* Map the root path to the root object. */ + if (!g_strcmp0 (SPI_ATK_OBJECT_PATH_ROOT, path)) + return G_OBJECT (spi_global_app_data->root); - path++; index = atoi (path); data = g_hash_table_lookup (reg->ref2ptr, GINT_TO_POINTER (index)); if (data) @@ -279,6 +295,10 @@ spi_register_object_to_path (SpiRegister * reg, GObject * gobj) if (gobj == NULL) return NULL; + /* Map the root object to the root path. */ + if ((void *)gobj == (void *)spi_global_app_data->root) + return g_strdup (spi_register_root_path); + ref = object_to_ref (gobj); if (!ref) { @@ -304,9 +324,9 @@ spi_register_object_to_ref (GObject * gobj) * within any particular application. */ gchar * -spi_register_desktop_object_path () +spi_register_root_object_path () { - return g_strdup (SPI_ATK_OBJECT_PATH_PREFIX SPI_ATK_OBJECT_PATH_DESKTOP); + return g_strdup (SPI_ATK_OBJECT_PATH_PREFIX SPI_ATK_OBJECT_PATH_ROOT); } /*END------------------------------------------------------------------------*/