forked from AuroraMiddleware/gtk
Drop use of factories for cell accessibles
This commit is contained in:
parent
5a10e9b0b4
commit
b83122dc05
@ -70,7 +70,6 @@ gail_private_h_sources = \
|
||||
gailcontainercell.h \
|
||||
gtkentryaccessible.h \
|
||||
gtkexpanderaccessible.h \
|
||||
gailfactory.h \
|
||||
gtkframeaccessible.h \
|
||||
gtkimageaccessible.h \
|
||||
gailimagecell.h \
|
||||
|
@ -23,17 +23,9 @@
|
||||
#include <stdlib.h>
|
||||
|
||||
#include <gtk/gtkx.h>
|
||||
#include "gailbooleancell.h"
|
||||
#include "gailcell.h"
|
||||
#include "gailcontainercell.h"
|
||||
#include "gailimagecell.h"
|
||||
#include "gailrenderercell.h"
|
||||
#include "gailtextcell.h"
|
||||
#include "gailtoplevel.h"
|
||||
#include "gailutil.h"
|
||||
|
||||
#include "gailfactory.h"
|
||||
|
||||
#define GNOME_ACCESSIBILITY_ENV "GNOME_ACCESSIBILITY"
|
||||
|
||||
static gboolean gail_focus_watcher (GSignalInvocationHint *ihint,
|
||||
@ -76,11 +68,6 @@ static guint focus_notify_handler = 0;
|
||||
static guint focus_tracker_id = 0;
|
||||
static GQuark quark_focus_object = 0;
|
||||
|
||||
GAIL_IMPLEMENT_FACTORY_WITH_FUNC_DUMMY (GAIL_TYPE_RENDERER_CELL, GailRendererCell, gail_renderer_cell, GTK_TYPE_CELL_RENDERER, gail_renderer_cell_new)
|
||||
GAIL_IMPLEMENT_FACTORY_WITH_FUNC_DUMMY (GAIL_TYPE_BOOLEAN_CELL, GailBooleanCell, gail_boolean_cell, GTK_TYPE_CELL_RENDERER_TOGGLE, gail_boolean_cell_new)
|
||||
GAIL_IMPLEMENT_FACTORY_WITH_FUNC_DUMMY (GAIL_TYPE_IMAGE_CELL, GailImageCell, gail_image_cell, GTK_TYPE_CELL_RENDERER_PIXBUF, gail_image_cell_new)
|
||||
GAIL_IMPLEMENT_FACTORY_WITH_FUNC_DUMMY (GAIL_TYPE_TEXT_CELL, GailTextCell, gail_text_cell, GTK_TYPE_CELL_RENDERER_TEXT, gail_text_cell_new)
|
||||
|
||||
static AtkObject*
|
||||
gail_get_accessible_for_widget (GtkWidget *widget,
|
||||
gboolean *transient)
|
||||
@ -820,11 +807,6 @@ gail_accessibility_module_init (void)
|
||||
if (a_t_support)
|
||||
fprintf (stderr, "GTK Accessibility Module initialized\n");
|
||||
|
||||
GAIL_WIDGET_SET_FACTORY (GTK_TYPE_CELL_RENDERER_TEXT, gail_text_cell);
|
||||
GAIL_WIDGET_SET_FACTORY (GTK_TYPE_CELL_RENDERER_TOGGLE, gail_boolean_cell);
|
||||
GAIL_WIDGET_SET_FACTORY (GTK_TYPE_CELL_RENDERER_PIXBUF, gail_image_cell);
|
||||
GAIL_WIDGET_SET_FACTORY (GTK_TYPE_CELL_RENDERER, gail_renderer_cell);
|
||||
|
||||
atk_focus_tracker_init (gail_focus_tracker_init);
|
||||
focus_tracker_id = atk_add_focus_tracker (gail_focus_tracker);
|
||||
|
||||
|
@ -1,110 +0,0 @@
|
||||
/* GAIL - The GNOME Accessibility Implementation Library
|
||||
* Copyright 2002 Sun Microsystems Inc.
|
||||
* Copyright (C) 1998-1999, 2000-2001 Tim Janik and Red Hat, Inc.
|
||||
* Copyright (C) 2007 Christian Persch
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Library 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
|
||||
* Library General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Library 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.
|
||||
*/
|
||||
|
||||
#ifndef _GAIL_FACTORY_H__
|
||||
#define _GAIL_FACTORY_H__
|
||||
|
||||
#include <glib-object.h>
|
||||
#include <atk/atk.h>
|
||||
|
||||
#define _GAIL_IMPLEMENT_FACTORY_CREATE_ACCESSIBLE(GAIL_TYPE, TYPE) \
|
||||
{ \
|
||||
AtkObject *accessible; \
|
||||
\
|
||||
g_return_val_if_fail (G_TYPE_CHECK_INSTANCE_TYPE (object, TYPE), NULL); \
|
||||
\
|
||||
accessible = g_object_new (GAIL_TYPE, NULL); \
|
||||
atk_object_initialize (accessible, object); \
|
||||
\
|
||||
return accessible; \
|
||||
}
|
||||
|
||||
#define _GAIL_IMPLEMENT_FACTORY_BEGIN(GAIL_TYPE, TypeName, type_name) \
|
||||
\
|
||||
static GType \
|
||||
type_name##_factory_get_accessible_type (void) \
|
||||
{ \
|
||||
return GAIL_TYPE; \
|
||||
} \
|
||||
\
|
||||
static AtkObject* \
|
||||
type_name##_factory_create_accessible (GObject *object) \
|
||||
{
|
||||
|
||||
#define _GAIL_IMPLEMENT_FACTORY_END(GAIL_TYPE, TypeName, type_name) \
|
||||
} \
|
||||
\
|
||||
static void \
|
||||
type_name##_factory_class_init (AtkObjectFactoryClass *klass) \
|
||||
{ \
|
||||
klass->create_accessible = type_name ## _factory_create_accessible; \
|
||||
klass->get_accessible_type = type_name ## _factory_get_accessible_type;\
|
||||
} \
|
||||
\
|
||||
GType \
|
||||
type_name##_factory_get_type (void) \
|
||||
{ \
|
||||
static volatile gsize g_define_type_id__volatile = 0; \
|
||||
if (g_once_init_enter (&g_define_type_id__volatile)) \
|
||||
{ \
|
||||
GType g_define_type_id = \
|
||||
g_type_register_static_simple (ATK_TYPE_OBJECT_FACTORY, \
|
||||
g_intern_static_string (#TypeName "Factory"), \
|
||||
sizeof (AtkObjectFactoryClass), \
|
||||
(GClassInitFunc) type_name##_factory_class_init, \
|
||||
sizeof (AtkObjectFactory), \
|
||||
(GInstanceInitFunc) NULL, \
|
||||
(GTypeFlags) 0); \
|
||||
g_once_init_leave (&g_define_type_id__volatile, g_define_type_id); \
|
||||
} \
|
||||
return g_define_type_id__volatile; \
|
||||
}
|
||||
|
||||
/* Implements a AtkObjectFactory creating accessibles of type
|
||||
* @GAIL_TYPE for objects of type @TYPE.
|
||||
*/
|
||||
#define GAIL_IMPLEMENT_FACTORY(GAIL_TYPE, TypeName, type_name, TYPE) \
|
||||
_GAIL_IMPLEMENT_FACTORY_BEGIN (GAIL_TYPE, TypeName, type_name) \
|
||||
_GAIL_IMPLEMENT_FACTORY_CREATE_ACCESSIBLE (GAIL_TYPE, TYPE) \
|
||||
_GAIL_IMPLEMENT_FACTORY_END (GAIL_TYPE, TypeName, type_name)
|
||||
|
||||
/* Implements a AtkObjectFactory creating accessibles of type
|
||||
* @GAIL_TYPE with creation func @create_accessible.
|
||||
*/
|
||||
#define GAIL_IMPLEMENT_FACTORY_WITH_FUNC(GAIL_TYPE, TypeName, type_name, create_accessible) \
|
||||
_GAIL_IMPLEMENT_FACTORY_BEGIN (GAIL_TYPE, TypeName, type_name) \
|
||||
{ return create_accessible (GTK_WIDGET (object)); } \
|
||||
_GAIL_IMPLEMENT_FACTORY_END (GAIL_TYPE, TypeName, type_name)
|
||||
|
||||
#define GAIL_IMPLEMENT_FACTORY_WITH_FUNC_DUMMY(GAIL_TYPE, TypeName, type_name, TYPE, create_accessible) \
|
||||
_GAIL_IMPLEMENT_FACTORY_BEGIN (GAIL_TYPE, TypeName, type_name) \
|
||||
{ \
|
||||
g_return_val_if_fail (G_TYPE_CHECK_INSTANCE_TYPE (object, TYPE), NULL);\
|
||||
return create_accessible (); \
|
||||
} \
|
||||
_GAIL_IMPLEMENT_FACTORY_END (GAIL_TYPE, TypeName, type_name)
|
||||
|
||||
#define GAIL_WIDGET_SET_FACTORY(widget_type, type_as_function) \
|
||||
atk_registry_set_factory_type (atk_get_default_registry (), \
|
||||
widget_type, \
|
||||
type_as_function ## _factory_get_type ())
|
||||
|
||||
#endif /* _GAIL_FACTORY_H__ */
|
@ -27,6 +27,7 @@
|
||||
#include "gtktreeviewaccessible.h"
|
||||
#include "gailrenderercell.h"
|
||||
#include "gailbooleancell.h"
|
||||
#include "gailimagecell.h"
|
||||
#include "gailcontainercell.h"
|
||||
#include "gailtextcell.h"
|
||||
#include "gailcellparent.h"
|
||||
@ -477,8 +478,6 @@ gtk_tree_view_accessible_ref_child (AtkObject *obj,
|
||||
GtkTreeViewColumn *tv_col;
|
||||
GtkTreeSelection *selection;
|
||||
GtkTreePath *path;
|
||||
AtkRegistry *default_registry;
|
||||
AtkObjectFactory *factory;
|
||||
AtkObject *child;
|
||||
AtkObject *parent;
|
||||
GtkTreeViewColumn *expander_tv;
|
||||
@ -579,11 +578,7 @@ gtk_tree_view_accessible_ref_child (AtkObject *obj,
|
||||
GtkCellRenderer *fake_renderer;
|
||||
|
||||
fake_renderer = g_object_new (GTK_TYPE_CELL_RENDERER_TEXT, NULL);
|
||||
default_registry = atk_get_default_registry ();
|
||||
factory = atk_registry_get_factory (default_registry,
|
||||
G_OBJECT_TYPE (fake_renderer));
|
||||
child = atk_object_factory_create_accessible (factory,
|
||||
G_OBJECT (fake_renderer));
|
||||
child = gail_text_cell_new ();
|
||||
cell = GAIL_CELL (child);
|
||||
renderer_cell = GAIL_RENDERER_CELL (child);
|
||||
renderer_cell->renderer = fake_renderer;
|
||||
@ -610,13 +605,17 @@ gtk_tree_view_accessible_ref_child (AtkObject *obj,
|
||||
renderer = GTK_CELL_RENDERER (l->data);
|
||||
|
||||
if (GTK_IS_CELL_RENDERER_TEXT (renderer))
|
||||
g_object_get (G_OBJECT (renderer), "editable", &editable, NULL);
|
||||
{
|
||||
g_object_get (G_OBJECT (renderer), "editable", &editable, NULL);
|
||||
child = gail_text_cell_new ();
|
||||
}
|
||||
else if (GTK_IS_CELL_RENDERER_TOGGLE (renderer))
|
||||
child = gail_boolean_cell_new ();
|
||||
else if (GTK_IS_CELL_RENDERER_PIXBUF (renderer))
|
||||
child = gail_image_cell_new ();
|
||||
else
|
||||
child = gail_renderer_cell_new ();
|
||||
|
||||
default_registry = atk_get_default_registry ();
|
||||
factory = atk_registry_get_factory (default_registry,
|
||||
G_OBJECT_TYPE (renderer));
|
||||
child = atk_object_factory_create_accessible (factory,
|
||||
G_OBJECT (renderer));
|
||||
cell = GAIL_CELL (child);
|
||||
renderer_cell = GAIL_RENDERER_CELL (child);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user