Robin Gareus
ad51c7c2ba
This is intended mainly for GNU/Linux distros who will remove GTK2 support in the near future.
148 lines
4.3 KiB
C
148 lines
4.3 KiB
C
/* ATK - Accessibility Toolkit
|
|
* Copyright 2001 Sun Microsystems Inc.
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
* Boston, MA 02111-1307, USA.
|
|
*/
|
|
|
|
#include "config.h"
|
|
|
|
#include "atkobjectfactory.h"
|
|
#include "atknoopobjectfactory.h"
|
|
|
|
/**
|
|
* SECTION:atkobjectfactory
|
|
* @Short_description: The base object class for a factory used to
|
|
* create accessible objects for objects of a specific GType.
|
|
* @Title:AtkObjectFactory
|
|
*
|
|
* This class is the base object class for a factory used to create an
|
|
* accessible object for a specific GType. The function
|
|
* atk_registry_set_factory_type() is normally called to store in the
|
|
* registry the factory type to be used to create an accessible of a
|
|
* particular GType.
|
|
*/
|
|
|
|
static void atk_object_factory_class_init (AtkObjectFactoryClass *klass);
|
|
|
|
static gpointer parent_class = NULL;
|
|
|
|
GType
|
|
atk_object_factory_get_type (void)
|
|
{
|
|
static GType type = 0;
|
|
|
|
if (!type) {
|
|
GTypeInfo tinfo =
|
|
{
|
|
sizeof (AtkObjectFactoryClass),
|
|
(GBaseInitFunc) NULL, /* base init */
|
|
(GBaseFinalizeFunc) NULL, /* base finalize */
|
|
(GClassInitFunc) atk_object_factory_class_init, /* class init */
|
|
(GClassFinalizeFunc) NULL, /* class finalize */
|
|
NULL, /* class data */
|
|
sizeof (AtkObjectFactory), /* instance size */
|
|
0, /* nb preallocs */
|
|
(GInstanceInitFunc) NULL, /* instance init */
|
|
NULL /* value table */
|
|
};
|
|
|
|
type = g_type_register_static (G_TYPE_OBJECT, "AtkObjectFactory", &tinfo, 0);
|
|
}
|
|
return type;
|
|
}
|
|
|
|
static void
|
|
atk_object_factory_class_init (AtkObjectFactoryClass *klass)
|
|
{
|
|
parent_class = g_type_class_peek_parent (klass);
|
|
|
|
}
|
|
|
|
/**
|
|
* atk_object_factory_create_accessible:
|
|
* @factory: The #AtkObjectFactory associated with @obj's
|
|
* object type
|
|
* @obj: a #GObject
|
|
*
|
|
* Provides an #AtkObject that implements an accessibility interface
|
|
* on behalf of @obj
|
|
*
|
|
* Returns: (transfer full): an #AtkObject that implements an accessibility
|
|
* interface on behalf of @obj
|
|
**/
|
|
AtkObject*
|
|
atk_object_factory_create_accessible (AtkObjectFactory *factory,
|
|
GObject *obj)
|
|
{
|
|
AtkObjectFactoryClass *klass;
|
|
AtkObject *accessible = NULL;
|
|
|
|
g_return_val_if_fail (ATK_IS_OBJECT_FACTORY (factory), NULL);
|
|
g_return_val_if_fail (G_IS_OBJECT (obj), NULL);
|
|
|
|
klass = ATK_OBJECT_FACTORY_GET_CLASS (factory);
|
|
|
|
if (klass->create_accessible)
|
|
{
|
|
accessible = klass->create_accessible (obj);
|
|
}
|
|
return accessible;
|
|
}
|
|
|
|
/**
|
|
* atk_object_factory_invalidate:
|
|
* @factory: an #AtkObjectFactory to invalidate
|
|
*
|
|
* Inform @factory that it is no longer being used to create
|
|
* accessibles. When called, @factory may need to inform
|
|
* #AtkObjects which it has created that they need to be re-instantiated.
|
|
* Note: primarily used for runtime replacement of #AtkObjectFactorys
|
|
* in object registries.
|
|
**/
|
|
void
|
|
atk_object_factory_invalidate (AtkObjectFactory *factory)
|
|
{
|
|
AtkObjectFactoryClass *klass;
|
|
|
|
g_return_if_fail (ATK_OBJECT_FACTORY (factory));
|
|
|
|
klass = ATK_OBJECT_FACTORY_GET_CLASS (factory);
|
|
if (klass->invalidate)
|
|
(klass->invalidate) (factory);
|
|
}
|
|
|
|
/**
|
|
* atk_object_factory_get_accessible_type:
|
|
* @factory: an #AtkObjectFactory
|
|
*
|
|
* Gets the GType of the accessible which is created by the factory.
|
|
* Returns: the type of the accessible which is created by the @factory.
|
|
* The value G_TYPE_INVALID is returned if no type if found.
|
|
**/
|
|
GType
|
|
atk_object_factory_get_accessible_type (AtkObjectFactory *factory)
|
|
{
|
|
AtkObjectFactoryClass *klass;
|
|
|
|
g_return_val_if_fail (ATK_OBJECT_FACTORY (factory), G_TYPE_INVALID);
|
|
|
|
klass = ATK_OBJECT_FACTORY_GET_CLASS (factory);
|
|
if (klass->get_accessible_type)
|
|
return (klass->get_accessible_type) ();
|
|
else
|
|
return G_TYPE_INVALID;
|
|
}
|