You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

76 lines
2.9 KiB

  1. /* ATK - Accessibility Toolkit
  2. * Copyright 2001 Sun Microsystems Inc.
  3. *
  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.
  8. *
  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.
  13. *
  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.
  18. */
  19. #if defined(ATK_DISABLE_SINGLE_INCLUDES) && !defined (__ATK_H_INSIDE__) && !defined (ATK_COMPILATION)
  20. #error "Only <atk/atk.h> can be included directly."
  21. #endif
  22. #ifndef __ATK_HYPERLINK_IMPL_H__
  23. #define __ATK_HYPERLINK_IMPL_H__
  24. #include <atk/atkobject.h>
  25. #include <atk/atkhyperlink.h>
  26. G_BEGIN_DECLS
  27. /*
  28. * The AtkHyperlinkImpl interface should be supported by objects
  29. * exposed within the hierarchy as children of an AtkHypertext container
  30. * which correspond to "links" or embedded content within the text.
  31. * HTML anchors are not, for instance, normally exposed this way,
  32. * but embedded images and components which appear inline in the
  33. * content of a text object are. The AtkHyperlinkIface interface
  34. * allows a means of determining which children are hyperlinks in this
  35. * sense of the word, and for obtaining their corresponding AtkHyperlink
  36. * object, from which the embedding range, URI, etc. can be obtained.
  37. *
  38. * To some extent this interface exists because, for historical
  39. * reasons, AtkHyperlink was defined as an object type, not an interface.
  40. * Thus, in order to interact with AtkObjects via AtkHyperlink semantics,
  41. * a new interface was required.
  42. */
  43. #define ATK_TYPE_HYPERLINK_IMPL (atk_hyperlink_impl_get_type ())
  44. #define ATK_IS_HYPERLINK_IMPL(obj) G_TYPE_CHECK_INSTANCE_TYPE ((obj), ATK_TYPE_HYPERLINK_IMPL)
  45. #define ATK_HYPERLINK_IMPL(obj) G_TYPE_CHECK_INSTANCE_CAST ((obj), ATK_TYPE_HYPERLINK_IMPL, AtkHyperlinkImpl)
  46. #define ATK_HYPERLINK_IMPL_GET_IFACE(obj) G_TYPE_INSTANCE_GET_INTERFACE ((obj), ATK_TYPE_HYPERLINK_IMPL, AtkHyperlinkImplIface)
  47. #ifndef _TYPEDEF_ATK_HYPERLINK_IMPL_
  48. #define _TYPEDEF_ATK_HYPERLINK_IMPL__
  49. typedef struct _AtkHyperlinkImpl AtkHyperlinkImpl;
  50. #endif
  51. typedef struct _AtkHyperlinkImplIface AtkHyperlinkImplIface;
  52. struct _AtkHyperlinkImplIface
  53. {
  54. GTypeInterface parent;
  55. AtkHyperlink* (* get_hyperlink) (AtkHyperlinkImpl *impl);
  56. AtkFunction pad1;
  57. };
  58. GType atk_hyperlink_impl_get_type (void);
  59. AtkHyperlink *atk_hyperlink_impl_get_hyperlink (AtkHyperlinkImpl *obj);
  60. G_END_DECLS
  61. #endif /* __ATK_HYPERLINK_IMPL_H__ */