Update configure.in to create Makefile in tests directory.
[atk.git] / atk / atkhyperlink.h
blob39b35112a4eb9246ae07c201273edb3a0c7934d3
1 /* ATK - Accessibility Toolkit
2 * Copyright 2001 Sun Microsystems Inc.
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Library General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Library General Public License for more details.
14 * You should have received a copy of the GNU Library General Public
15 * License along with this library; if not, write to the
16 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17 * Boston, MA 02111-1307, USA.
20 #ifndef __ATK_HYPERLINK_H__
21 #define __ATK_HYPERLINK_H__
23 #ifdef __cplusplus
24 extern "C" {
25 #endif /* __cplusplus */
27 #include <atk/atkaction.h>
30 * AtkHyperLink encapsulates a link or set of links in a hypertext document.
32 * It implements the AtkAction interface.
35 #define ATK_TYPE_HYPERLINK (atk_hyperlink_get_type ())
36 #define ATK_HYPERLINK(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), ATK_TYPE_HYPERLINK, AtkHyperlink))
37 #define ATK_HYPERLINK_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), ATK_TYPE_HYPERLINK, AtkHyperlinkClass))
38 #define ATK_IS_HYPERLINK(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), ATK_TYPE_HYPERLINK))
39 #define ATK_IS_HYPERLINK_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), ATK_TYPE_HYPERLINK))
40 #define ATK_HYPERLINK_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), ATK_TYPE_HYPERLINK, AtkHyperlinkClass))
42 typedef struct _AtkHyperlink AtkHyperlink;
43 typedef struct _AtkHyperlinkClass AtkHyperlinkClass;
45 struct _AtkHyperlink
47 GObject parent;
50 struct _AtkHyperlinkClass
52 GObjectClass parent;
55 * Returns an object which represents the link anchor, as appropriate for
56 * that link.
58 GObject* (* get_anchor) (AtkHyperlink *link,
59 gint i);
61 * Returns an object which represents the link action, as appropriate for
62 * that link.
64 GObject* (* get_object) (AtkHyperlink *link,
65 gint i);
67 * Gets the index with the hypertext document at which this link ends
69 gint (* get_end_index) (AtkHyperlink *link);
70 /*
71 * Gets the index with the hypertext document at which this link begins
73 gint (* get_start_index) (AtkHyperlink *link);
75 * Since the document a link is associated with may have changed, this
76 * method returns whether or not this link is still valid (with respect
77 * to the document is references)
79 gboolean (* is_valid) (AtkHyperlink *link);
82 GType atk_hyperlink_get_type (void);
84 GObject* atk_hyperlink_get_anchor (AtkHyperlink *link,
85 gint i);
87 GObject* atk_hyperlink_get_object (AtkHyperlink *link,
88 gint i);
90 gint atk_hyperlink_get_end_index (AtkHyperlink *link);
92 gint atk_hyperlink_get_start_index (AtkHyperlink *link);
94 gboolean atk_hyperlink_is_valid (AtkHyperlink *link);
97 #ifdef __cplusplus
99 #endif /* __cplusplus */
102 #endif /* __ATK_HYPERLINK_H__ */