1 /* ATK - Accessibility Toolkit
2 * Copyright 2001 Sun Microsystems Inc.
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.
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.
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.
22 #define NUM_POSSIBLE_STATES (sizeof(AtkState)*8)
24 static gchar* state_names[NUM_POSSIBLE_STATES] = {
56 * atk_state_type_register:
57 * @name: a character string describing the new state.
59 * Returns: an #AtkState value for the new state.
62 atk_state_type_register (const gchar *name)
64 static guint type = ATK_STATE_LAST_DEFINED;
65 if (type < NUM_POSSIBLE_STATES)
67 state_names[++type] = g_strdup (name);
70 return ATK_STATE_INVALID; /* caller needs to check */
74 * atk_state_type_get_name:
75 * @type: The #AtkStateType whose name is required
77 * Returns: the string describing the state
80 atk_state_type_get_name (AtkStateType state)
87 for (n=0; n<NUM_POSSIBLE_STATES; n++)
90 return state_names[n];
97 * atk_state_type_for_name:
98 * @name: a character string state name
100 * Returns: an #AtkStateType corresponding to @name
103 atk_state_type_for_name (const gchar *name)
107 g_return_val_if_fail (name != NULL, 0);
108 g_return_val_if_fail (strlen (name) > 0, 0);
110 for (i = 0; i < NUM_POSSIBLE_STATES; i++)
112 if (state_names[i] == NULL)
114 if (!strcmp(name, state_names[i]))