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>
29 #include "introspection.h"
33 get_hyperlink (void *user_data)
35 if (ATK_IS_HYPERLINK (user_data))
36 return ATK_HYPERLINK (user_data);
37 if (ATK_IS_HYPERLINK_IMPL (user_data))
38 return atk_hyperlink_impl_get_hyperlink (ATK_HYPERLINK_IMPL (user_data));
43 impl_get_NAnchors (DBusMessageIter * iter, void *user_data)
45 AtkHyperlink *link = get_hyperlink (user_data);
46 g_return_val_if_fail (ATK_IS_HYPERLINK (link), FALSE);
47 return droute_return_v_int32 (iter, atk_hyperlink_get_n_anchors (link));
52 impl_get_StartIndex (DBusMessageIter * iter, void *user_data)
54 AtkHyperlink *link = get_hyperlink (user_data);
55 g_return_val_if_fail (ATK_IS_HYPERLINK (link), FALSE);
56 return droute_return_v_int32 (iter, atk_hyperlink_get_start_index (link));
60 impl_get_EndIndex (DBusMessageIter * iter, void *user_data)
62 AtkHyperlink *link = get_hyperlink (user_data);
63 g_return_val_if_fail (ATK_IS_HYPERLINK (link), FALSE);
64 return droute_return_v_int32 (iter, atk_hyperlink_get_end_index (link));
68 impl_GetObject (DBusConnection * bus, DBusMessage * message, void *user_data)
70 AtkHyperlink *link = get_hyperlink (user_data);
72 AtkObject *atk_object;
74 g_return_val_if_fail (ATK_IS_HYPERLINK (link),
75 droute_not_yet_handled_error (message));
76 if (!dbus_message_get_args
77 (message, NULL, DBUS_TYPE_INT32, &i, DBUS_TYPE_INVALID))
79 return droute_invalid_arguments_error (message);
81 atk_object = atk_hyperlink_get_object (link, i);
82 return spi_object_return_reference (message, atk_object);
86 impl_GetURI (DBusConnection * bus, DBusMessage * message, void *user_data)
88 AtkHyperlink *link = get_hyperlink (user_data);
93 g_return_val_if_fail (ATK_IS_HYPERLINK (link),
94 droute_not_yet_handled_error (message));
95 if (!dbus_message_get_args
96 (message, NULL, DBUS_TYPE_INT32, &i, DBUS_TYPE_INVALID))
98 return droute_invalid_arguments_error (message);
101 rv = atk_hyperlink_get_uri (link, i);
104 reply = dbus_message_new_method_return (message);
107 dbus_message_append_args (reply, DBUS_TYPE_STRING, &rv,
115 impl_IsValid (DBusConnection * bus, DBusMessage * message, void *user_data)
117 AtkHyperlink *link = get_hyperlink (user_data);
121 g_return_val_if_fail (ATK_IS_HYPERLINK (link),
122 droute_not_yet_handled_error (message));
124 rv = atk_hyperlink_is_valid (link);
125 reply = dbus_message_new_method_return (message);
128 dbus_message_append_args (reply, DBUS_TYPE_BOOLEAN, &rv,
134 static DRouteMethod methods[] = {
135 {impl_GetObject, "GetObject"},
136 {impl_GetURI, "GetURI"},
137 {impl_IsValid, "IsValid"},
141 static DRouteProperty properties[] = {
142 {impl_get_NAnchors, NULL, "NAnchors"},
143 {impl_get_StartIndex, NULL, "StartIndex"},
144 {impl_get_EndIndex, NULL, "EndIndex"},
149 spi_initialize_hyperlink (DRoutePath * path)
151 droute_path_add_interface (path,
152 ATSPI_DBUS_INTERFACE_HYPERLINK,
153 spi_org_a11y_atspi_Hyperlink,
154 methods, properties);