Revert "Using abstract atk_object_get_name to check accessible-name notification"
[platform/upstream/atk.git] / atk / atkgobjectaccessible.c
1 /* ATK - Accessibility Toolkit
2  * Copyright 2001, 2002, 2003 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 Lesser 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  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser 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
20 #include <atk/atkgobjectaccessible.h>
21
22 static void       atk_gobject_accessible_class_init       (AtkGObjectAccessibleClass   *klass);
23 static void       atk_real_gobject_accessible_initialize  (AtkObject         *atk_obj,
24                                                            gpointer          data);
25 static void       atk_gobject_accessible_dispose          (gpointer          data);
26
27 static GQuark quark_accessible_object = 0;
28 static GQuark quark_object = 0;
29 static gpointer parent_class = NULL;
30
31 GType
32 atk_gobject_accessible_get_type (void)
33 {
34   static GType type = 0;
35
36   if (!type)
37     {
38       static const GTypeInfo tinfo =
39       {
40         sizeof (AtkGObjectAccessibleClass),
41         (GBaseInitFunc) NULL, /* base init */
42         (GBaseFinalizeFunc) NULL, /* base finalize */
43         (GClassInitFunc) atk_gobject_accessible_class_init,
44         (GClassFinalizeFunc) NULL, /* class finalize */
45         NULL, /* class data */
46         sizeof (AtkGObjectAccessible),
47         0, /* nb preallocs */
48         (GInstanceInitFunc) NULL, /* instance init */
49         NULL /* value table */
50       };
51
52       type = g_type_register_static (ATK_TYPE_OBJECT,
53                                      "AtkGObjectAccessible", &tinfo, 0);
54     }
55
56   return type;
57 }
58
59 /**
60  * atk_gobject_accessible_for_object:
61  * @obj: a #GObject
62  *
63  * Gets the accessible object for the specified @obj.
64  *
65  * Returns: (transfer none): a #AtkObject which is the accessible object for
66  * the @obj
67  **/
68 AtkObject*
69 atk_gobject_accessible_for_object (GObject *obj)
70 {
71   AtkObject* accessible;
72
73   g_return_val_if_fail (G_IS_OBJECT (obj), NULL);
74   /* See if we have a cached accessible for this object */
75
76   accessible = g_object_get_qdata (obj,
77                                    quark_accessible_object);
78
79   if (!accessible)
80     {
81       AtkObjectFactory *factory;
82       AtkRegistry *default_registry;
83
84       default_registry = atk_get_default_registry ();
85       factory = atk_registry_get_factory (default_registry, 
86                                           G_OBJECT_TYPE (obj));
87       accessible = atk_object_factory_create_accessible (factory,
88                                                          obj);
89       if (!ATK_IS_GOBJECT_ACCESSIBLE (accessible))
90         {
91           /*
92            * The AtkObject which was created was not a AtkGObjectAccessible
93            */
94           g_object_weak_ref (obj,
95                              (GWeakNotify) g_object_unref,
96                              accessible); 
97           if (!quark_accessible_object)
98             quark_accessible_object = g_quark_from_static_string ("accessible-object");
99         }
100       g_object_set_qdata (obj, quark_accessible_object, accessible);
101     }
102   return accessible;
103 }
104
105 /**
106  * atk_gobject_accessible_get_object:
107  * @obj: a #AtkGObjectAccessible
108  *
109  * Gets the GObject for which @obj is the accessible object.
110  *
111  * Returns: (transfer none): a #GObject which is the object for which @obj is
112  * the accessible object
113  **/
114 GObject *
115 atk_gobject_accessible_get_object (AtkGObjectAccessible *obj)
116 {
117   g_return_val_if_fail (ATK_IS_GOBJECT_ACCESSIBLE (obj), NULL);
118
119   return g_object_get_qdata (G_OBJECT (obj), quark_object);
120 }
121  
122 static void
123 atk_real_gobject_accessible_initialize (AtkObject  *atk_obj,
124                                         gpointer   data)
125 {
126   AtkGObjectAccessible *atk_gobj;
127
128   atk_gobj = ATK_GOBJECT_ACCESSIBLE (atk_obj);
129
130   g_object_set_qdata (G_OBJECT (atk_gobj), quark_object, data);
131   atk_obj->layer = ATK_LAYER_WIDGET;
132
133   g_object_weak_ref (data,
134                      (GWeakNotify) atk_gobject_accessible_dispose,
135                      atk_gobj);
136 }
137
138 static void
139 atk_gobject_accessible_dispose (gpointer  data)
140 {
141   g_return_if_fail (ATK_IS_GOBJECT_ACCESSIBLE (data));
142
143   g_object_set_qdata (G_OBJECT (data), quark_object, NULL);
144   atk_object_notify_state_change (ATK_OBJECT (data), ATK_STATE_DEFUNCT,
145                                   TRUE); 
146   g_object_unref (data);
147 }
148
149 static void
150 atk_gobject_accessible_class_init (AtkGObjectAccessibleClass *klass)
151
152   AtkObjectClass *class;
153
154   class = ATK_OBJECT_CLASS (klass);
155
156   parent_class = g_type_class_peek_parent (klass);
157
158   class->initialize = atk_real_gobject_accessible_initialize;
159
160   if (!quark_accessible_object)
161     quark_accessible_object = g_quark_from_static_string ("accessible-object");
162   quark_object = g_quark_from_static_string ("object-for-accessible");
163 }