2 * AT-SPI - Assistive Technology Service Provider Interface
3 * (Gnome Accessibility Project; http://developer.gnome.org/projects/gap)
5 * Copyright 2008 Novell, Inc.
6 * Copyright 2001, 2002 Sun Microsystems Inc.,
7 * Copyright 2001, 2002 Ximian, Inc.
9 * This library is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU Library General Public
11 * License as published by the Free Software Foundation; either
12 * version 2 of the License, or (at your option) any later version.
14 * This library is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * Library General Public License for more details.
19 * You should have received a copy of the GNU Library General Public
20 * License along with this library; if not, write to the
21 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
22 * Boston, MA 02111-1307, USA.
26 #include <droute/droute.h>
30 #include "introspection.h"
34 get_hyperlink (void *user_data)
36 if (ATK_IS_HYPERLINK (user_data))
37 return ATK_HYPERLINK (user_data);
38 if (ATK_IS_HYPERLINK_IMPL (user_data))
39 return atk_hyperlink_impl_get_hyperlink (ATK_HYPERLINK_IMPL (user_data));
44 impl_get_NAnchors (DBusMessageIter * iter, void *user_data)
46 AtkHyperlink *link = get_hyperlink (user_data);
47 g_return_val_if_fail (ATK_IS_HYPERLINK (link), FALSE);
48 return droute_return_v_int32 (iter, atk_hyperlink_get_n_anchors (link));
53 impl_get_StartIndex (DBusMessageIter * iter, void *user_data)
55 AtkHyperlink *link = get_hyperlink (user_data);
56 g_return_val_if_fail (ATK_IS_HYPERLINK (link), FALSE);
57 return droute_return_v_int32 (iter, atk_hyperlink_get_start_index (link));
61 impl_get_EndIndex (DBusMessageIter * iter, void *user_data)
63 AtkHyperlink *link = get_hyperlink (user_data);
64 g_return_val_if_fail (ATK_IS_HYPERLINK (link), FALSE);
65 return droute_return_v_int32 (iter, atk_hyperlink_get_end_index (link));
69 impl_GetObject (DBusConnection * bus, DBusMessage * message, void *user_data)
71 AtkHyperlink *link = get_hyperlink (user_data);
73 AtkObject *atk_object;
75 g_return_val_if_fail (ATK_IS_HYPERLINK (link),
76 droute_not_yet_handled_error (message));
77 if (!dbus_message_get_args
78 (message, NULL, DBUS_TYPE_INT32, &i, DBUS_TYPE_INVALID))
80 return droute_invalid_arguments_error (message);
82 atk_object = atk_hyperlink_get_object (link, i);
83 return spi_object_return_reference (message, atk_object);
87 impl_GetURI (DBusConnection * bus, DBusMessage * message, void *user_data)
89 AtkHyperlink *link = get_hyperlink (user_data);
94 g_return_val_if_fail (ATK_IS_HYPERLINK (link),
95 droute_not_yet_handled_error (message));
96 if (!dbus_message_get_args
97 (message, NULL, DBUS_TYPE_INT32, &i, DBUS_TYPE_INVALID))
99 return droute_invalid_arguments_error (message);
102 rv = atk_hyperlink_get_uri (link, i);
105 reply = dbus_message_new_method_return (message);
108 dbus_message_append_args (reply, DBUS_TYPE_STRING, &rv,
116 impl_IsValid (DBusConnection * bus, DBusMessage * message, void *user_data)
118 AtkHyperlink *link = get_hyperlink (user_data);
122 g_return_val_if_fail (ATK_IS_HYPERLINK (link),
123 droute_not_yet_handled_error (message));
125 rv = atk_hyperlink_is_valid (link);
126 reply = dbus_message_new_method_return (message);
129 dbus_message_append_args (reply, DBUS_TYPE_BOOLEAN, &rv,
135 static DRouteMethod methods[] = {
136 {impl_GetObject, "GetObject"},
137 {impl_GetURI, "GetURI"},
138 {impl_IsValid, "IsValid"},
142 static DRouteProperty properties[] = {
143 {impl_get_NAnchors, NULL, "NAnchors"},
144 {impl_get_StartIndex, NULL, "StartIndex"},
145 {impl_get_EndIndex, NULL, "EndIndex"},
150 spi_initialize_hyperlink (DRoutePath * path)
152 spi_atk_add_interface (path,
153 ATSPI_DBUS_INTERFACE_HYPERLINK,
154 spi_org_a11y_atspi_Hyperlink,
155 methods, properties);