X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=atk-adaptor%2Fadaptors%2Faccessible-adaptor.c;h=a8789c9436a9238c55313160362e8266e87b9b46;hb=a75394295fca667976b703a376e4034cc2031540;hp=688537b19aa98c7a59b2c7f02fdfb52613309e8c;hpb=41506b34b47d6401430286eeef9ee29b6e394fb2;p=platform%2Fcore%2Fuifw%2Fat-spi2-atk.git diff --git a/atk-adaptor/adaptors/accessible-adaptor.c b/atk-adaptor/adaptors/accessible-adaptor.c index 688537b..a8789c9 100644 --- a/atk-adaptor/adaptors/accessible-adaptor.c +++ b/atk-adaptor/adaptors/accessible-adaptor.c @@ -141,12 +141,14 @@ static dbus_bool_t impl_get_ChildCount (DBusMessageIter * iter, void *user_data) { AtkObject *object = (AtkObject *) user_data; + int childCount; g_return_val_if_fail (ATK_IS_OBJECT (user_data), FALSE); - return droute_return_v_int32 (iter, - atk_object_get_n_accessible_children - (object)); + childCount = (ATK_IS_SOCKET (object) && atk_socket_is_occupied (ATK_SOCKET (object))) + ? 1 + : atk_object_get_n_accessible_children (object); + return droute_return_v_int32 (iter, childCount); } static DBusMessage * @@ -154,6 +156,7 @@ impl_GetChildAtIndex (DBusConnection * bus, DBusMessage * message, void *user_data) { AtkObject *object = (AtkObject *) user_data; + DBusMessage *reply; DBusError error; dbus_int32_t i; AtkObject *child; @@ -166,8 +169,35 @@ impl_GetChildAtIndex (DBusConnection * bus, { return droute_invalid_arguments_error (message); } + + if (ATK_IS_SOCKET (object) && atk_socket_is_occupied (ATK_SOCKET (object)) && i == 0) + { + AtkSocket *socket = ATK_SOCKET (object); + gchar *child_name, *child_path; + child_name = g_strdup (socket->embedded_plug_id); + child_path = g_utf8_strchr (child_name + 1, -1, ':'); + if (child_path) + { + DBusMessageIter iter, iter_socket; + *(child_path++) = '\0'; + reply = dbus_message_new_method_return (message); + if (!reply) + return NULL; + dbus_message_iter_init_append (reply, &iter); + dbus_message_iter_open_container (&iter, DBUS_TYPE_STRUCT, NULL, + &iter_socket); + dbus_message_iter_append_basic (&iter_socket, DBUS_TYPE_STRING, &child_name); + dbus_message_iter_append_basic (&iter_socket, DBUS_TYPE_OBJECT_PATH, &child_path); + dbus_message_iter_close_container (&iter, &iter_socket); + return reply; + } + g_free (child_name); + } child = atk_object_ref_accessible_child (object, i); - return spi_object_return_reference (message, child); + reply = spi_object_return_reference (message, child); + g_object_unref (child); + + return reply; } static DBusMessage * @@ -247,6 +277,7 @@ spi_init_relation_type_table (Accessibility_RelationType * types) types[ATK_RELATION_DESCRIPTION_FOR] = Accessibility_RELATION_DESCRIPTION_FOR; types[ATK_RELATION_DESCRIBED_BY] = Accessibility_RELATION_DESCRIBED_BY; + types[ATK_RELATION_NODE_PARENT_OF] = Accessibility_RELATION_NODE_PARENT_OF; return TRUE; } @@ -292,7 +323,9 @@ impl_GetRelationSet (DBusConnection * bus, { goto oom; } - count = atk_relation_set_get_n_relations (set); + count = 0; + if (set) + count = atk_relation_set_get_n_relations (set); for (i = 0; i < count; i++) { AtkRelation *r = atk_relation_set_get_relation (set, i); @@ -466,8 +499,7 @@ static DBusMessage * impl_GetApplication (DBusConnection * bus, DBusMessage * message, void *user_data) { - AtkObject *root = g_object_ref (atk_get_root ()); - return spi_object_return_reference (message, root); + return spi_object_return_reference (message, atk_get_root ()); } static DBusMessage * @@ -475,8 +507,6 @@ impl_GetInterfaces (DBusConnection * bus, DBusMessage * message, void *user_data) { AtkObject *object = (AtkObject *) user_data; - gint role; - const char *role_name; DBusMessage *reply; DBusMessageIter iter, iter_array; @@ -494,27 +524,6 @@ impl_GetInterfaces (DBusConnection * bus, return reply; } -static DBusMessage * -impl_Embedded (DBusConnection *bus, - DBusMessage *message, - void *user_data) -{ - AtkObject *object = (AtkObject *) user_data; - char *path; - gchar *id; - - if (!dbus_message_get_args (message, NULL, DBUS_TYPE_STRING, &path, DBUS_TYPE_INVALID)) - { - return droute_invalid_arguments_error (message); - } - id = g_object_get_data (G_OBJECT (object), "dbus-plug-parent"); - if (id) - g_free (id); - id = g_strconcat (dbus_message_get_sender (message), ":", path, NULL); - g_object_set_data (G_OBJECT (object), "dbus-plug-parent", id); - return dbus_message_new_method_return (message); -} - static DRouteMethod methods[] = { {impl_GetChildAtIndex, "GetChildAtIndex"}, {impl_GetChildren, "GetChildren"}, @@ -527,7 +536,6 @@ static DRouteMethod methods[] = { {impl_GetAttributes, "GetAttributes"}, {impl_GetApplication, "GetApplication"}, {impl_GetInterfaces, "GetInterfaces"}, - {impl_Embedded, "Embedded"}, {NULL, NULL} }; @@ -544,6 +552,6 @@ spi_initialize_accessible (DRoutePath * path) { droute_path_add_interface (path, SPI_DBUS_INTERFACE_ACCESSIBLE, - spi_org_freedesktop_atspi_Accessible, + spi_org_a11y_atspi_Accessible, methods, properties); };