AtkState
- From: "Padraig O'Briain" <Padraig Obriain Sun COM>
- To: otaylor redhat com
- Cc: timj gtk org, hp redhat com, gnome-accessibility-list gnome org
- Subject: AtkState
- Date: Tue, 1 May 2001 15:18:21 +0100 (BST)
>
> * I think the way AtkState currently works with the extensible
> enum and:
>
> typedef guint64 AtkStateMask
> #define ATK_STATE(state_enum) ((AtkStateMask)(1 <<
((guint64)(state_enum)%64)))
>
> Is going to cause fits for language bindings. It probably
> would be better to simply have functions to get/set a
> list/array of AtkState for the AtkObject.
>
I propose to change
AtkState atk_object_get_state (AtkObject *ac
cessible);
to
AtkStateSet atk_object_get_state_set (AtkObject *ac
cessible);
and define the AtkStateSet interface as in the attached file.
Hopefully, this interface will work for language bindings.
Padraig
/* 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 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 __ATK_STATE_SET_H__
#define __ATK_STATE_SET_H__
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
#include <glib-object.h>
#include <atk/atkobject.h>
#define ATK_TYPE_STATE_SET (atk_state_set_get_type ())
#define ATK_STATE_SET(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), ATK_TYPE_STATE_SET, AtkStateSet))
#define ATK_STATE_SET_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), ATK_TYPE_STATE_SET, AtkStateSetClass))
#define ATK_IS_STATE_SET(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), ATK_TYPE_STATE_SET))
#define ATK_IS_STATE_SET_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), ATK_TYPE_STATE_SET))
#define ATK_STATE_SET_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), ATK_TYPE_STATE_SET, AtkStateSetClass))
typedef struct _AtkStateSetClass AtkStateSetClass;
struct _AtkStateSet
{
GObject parent;
};
struct _AtkStateSetClass
{
GObjectClass parent;
};
GType atk_state_set_get_type (void);
/*
* Create an empty state set.
*/
AtkStateSet* atk_state_set_new (void);
/*
* Checks whether a state set is empty.
*/
gboolean atk_state_set_is_empty (AtkStateSet *set);
/*
* Add a new state for the specified type to the current state set if
* it is not already present
*
*/
gboolean atk_state_set_add_state (AtkStateSet *set,
AtkStateType type);
/*
* Add all the states for all the specified types to the current state set
*
*/
void atk_state_set_add_states (AtkStateSet *set,
AtkStateType *types,
gint n_types);
/*
* Remove all states from the state set.
*/
void atk_state_set_clear_states (AtkStateSet *set);
/*
* Checks whether the state for the specified type is in the specified set.
*/
void atk_state_set_contains_state (AtkStateSet *set,
AtkStateType type);
/*
* Removes a state for the specified type the current state set.
*
*/
gboolean atk_state_set_remove_state (AtkStateSet *set,
AtkStateType type);
/*
* Constructs the intersection of two state sets, returning NULL if the
* intersection is empty.
*/
AtkStateSet* atk_state_set_and_sets (AtkStateSet *set,
AtkStateSet *compare_set);
/*
* Constructs the union of two state sets.
*/
AtkStateSet* atk_state_set_or_sets (AtkStateSet *set,
AtkStateSet *compare_set);
/*
* Constructs the xor of two sets, returning NULL if it empty.
* The sets returned by this operation contains the state in exactly one
* of the sets.
*/
AtkStateSet* atk_state_set_xor_sets (AtkStateSet *set,
AtkStateSet *compare_set);
/*
* Determines whether states for all the specified types are in the state set.
*/
gboolean atk_state_set_contains_states (AtkStateSet *set,
AtkStateType *types,
gint n_types);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* __ATK_STATE_SET_H__ */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]