X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=atk-adaptor%2Fadaptors%2Faccessible-adaptor.c;h=51aa4aaaefbeac748884a414f4f308770c69d999;hb=f0061858ec3c9151fe4b20e390678093ea8f32df;hp=2dd6cd7c1039403086452430f7d6ea3189625255;hpb=28768375ed57f134647674cf9816b6dec163247a;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 2dd6cd7..51aa4aa 100644 --- a/atk-adaptor/adaptors/accessible-adaptor.c +++ b/atk-adaptor/adaptors/accessible-adaptor.c @@ -28,6 +28,7 @@ #include "common/spi-dbus.h" #include "common/spi-stateset.h" #include "object.h" +#include "introspection.h" static dbus_bool_t impl_get_Name (DBusMessageIter * iter, void *user_data) @@ -140,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 * @@ -153,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; @@ -165,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 * @@ -291,7 +322,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); @@ -465,8 +498,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 * @@ -493,27 +525,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"}, @@ -526,7 +537,6 @@ static DRouteMethod methods[] = { {impl_GetAttributes, "GetAttributes"}, {impl_GetApplication, "GetApplication"}, {impl_GetInterfaces, "GetInterfaces"}, - {impl_Embedded, "Embedded"}, {NULL, NULL} }; @@ -543,5 +553,6 @@ spi_initialize_accessible (DRoutePath * path) { droute_path_add_interface (path, SPI_DBUS_INTERFACE_ACCESSIBLE, + spi_org_a11y_atspi_Accessible, methods, properties); };