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>
28 #include "spi-common/spi-dbus.h"
31 impl_getNLinks (DBusConnection * bus, DBusMessage * message, void *user_data)
33 AtkHypertext *hypertext = (AtkHypertext *) user_data;
37 g_return_val_if_fail (ATK_IS_HYPERTEXT (user_data),
38 droute_not_yet_handled_error (message));
39 rv = atk_hypertext_get_n_links (hypertext);
40 reply = dbus_message_new_method_return (message);
43 dbus_message_append_args (reply, DBUS_TYPE_INT32, &rv,
50 impl_getLink (DBusConnection * bus, DBusMessage * message, void *user_data)
52 AtkHypertext *hypertext = (AtkHypertext *) user_data;
54 dbus_int32_t linkIndex;
57 g_return_val_if_fail (ATK_IS_HYPERTEXT (user_data),
58 droute_not_yet_handled_error (message));
59 dbus_error_init (&error);
60 if (!dbus_message_get_args
61 (message, &error, DBUS_TYPE_INT32, &linkIndex, DBUS_TYPE_INVALID))
63 return droute_invalid_arguments_error (message);
65 link = atk_hypertext_get_link (hypertext, linkIndex);
66 return spi_dbus_return_object (message, ATK_OBJECT (link), FALSE);
70 impl_getLinkIndex (DBusConnection * bus, DBusMessage * message,
73 AtkHypertext *hypertext = (AtkHypertext *) user_data;
75 dbus_int32_t characterIndex;
79 g_return_val_if_fail (ATK_IS_HYPERTEXT (user_data),
80 droute_not_yet_handled_error (message));
81 dbus_error_init (&error);
82 if (!dbus_message_get_args
83 (message, &error, DBUS_TYPE_INT32, &characterIndex, DBUS_TYPE_INVALID))
85 return droute_invalid_arguments_error (message);
87 rv = atk_hypertext_get_link_index (hypertext, characterIndex);
88 reply = dbus_message_new_method_return (message);
91 dbus_message_append_args (reply, DBUS_TYPE_INT32, &rv,
97 static DRouteMethod methods[] = {
98 {impl_getNLinks, "getNLinks"},
99 {impl_getLink, "getLink"},
100 {impl_getLinkIndex, "getLinkIndex"},
105 spi_initialize_hypertext (DRoutePath *path)
107 droute_path_add_interface (path,
108 SPI_DBUS_INTERFACE_HYPERTEXT,