mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-10 04:30:11 +00:00
bf06cad5d9
We're currently overloading NULL to mean both "this value is undefined, and should be reset to its default" and "the value collection failed". Let's do error reporting right, by using GError to mean "the collection failed, for this specific reason"; then, we can use a NULL return value to signal that the accessible attribute should be reset to its default value. This is only relevant for pointer-sized attribute values: strings, references, and reference lists; numeric, boolean, tristate, and token values either cannot be undefined, or have a specific "undefined" value.
157 lines
8.3 KiB
C
157 lines
8.3 KiB
C
/* gtkaccessiblevalueprivate.h: Accessible value
|
|
*
|
|
* Copyright 2020 GNOME Foundation
|
|
*
|
|
* SPDX-License-Identifier: LGPL-2.1-or-later
|
|
*
|
|
* 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.1 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, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <glib-object.h>
|
|
|
|
#include "gtkaccessible.h"
|
|
#include "gtkenums.h"
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
#define GTK_TYPE_ACCESSIBLE_VALUE (gtk_accessible_value_get_type())
|
|
|
|
#define GTK_ACCESSIBLE_VALUE_ERROR (gtk_accessible_value_error_quark())
|
|
|
|
typedef struct _GtkAccessibleValue GtkAccessibleValue;
|
|
typedef struct _GtkAccessibleValueClass GtkAccessibleValueClass;
|
|
|
|
typedef enum {
|
|
GTK_ACCESSIBLE_VALUE_TYPE_UNDEFINED,
|
|
GTK_ACCESSIBLE_VALUE_TYPE_BOOLEAN,
|
|
GTK_ACCESSIBLE_VALUE_TYPE_TRISTATE,
|
|
GTK_ACCESSIBLE_VALUE_TYPE_TOKEN,
|
|
GTK_ACCESSIBLE_VALUE_TYPE_INTEGER,
|
|
GTK_ACCESSIBLE_VALUE_TYPE_NUMBER,
|
|
GTK_ACCESSIBLE_VALUE_TYPE_STRING,
|
|
GTK_ACCESSIBLE_VALUE_TYPE_REFERENCE,
|
|
GTK_ACCESSIBLE_VALUE_TYPE_REFERENCE_LIST
|
|
} GtkAccessibleValueType;
|
|
|
|
struct _GtkAccessibleValue
|
|
{
|
|
const GtkAccessibleValueClass *value_class;
|
|
|
|
int ref_count;
|
|
};
|
|
|
|
#define GTK_ACCESSIBLE_VALUE_INIT(klass) { .value_class = (klass), .ref_count = 1 }
|
|
|
|
struct _GtkAccessibleValueClass
|
|
{
|
|
GtkAccessibleValueType type;
|
|
const char *type_name;
|
|
gsize instance_size;
|
|
|
|
void (* init) (GtkAccessibleValue *self);
|
|
void (* finalize) (GtkAccessibleValue *self);
|
|
void (* print) (const GtkAccessibleValue *self,
|
|
GString *string);
|
|
gboolean (* equal) (const GtkAccessibleValue *value_a,
|
|
const GtkAccessibleValue *value_b);
|
|
};
|
|
|
|
#define GTK_IS_ACCESSIBLE_VALUE_TYPE(v,type) \
|
|
((v)->value_class->type == (type))
|
|
|
|
typedef enum {
|
|
GTK_ACCESSIBLE_VALUE_ERROR_READ_ONLY,
|
|
GTK_ACCESSIBLE_VALUE_ERROR_INVALID_VALUE,
|
|
GTK_ACCESSIBLE_VALUE_ERROR_INVALID_RANGE,
|
|
GTK_ACCESSIBLE_VALUE_ERROR_INVALID_TOKEN
|
|
} GtkAccessibleValueError;
|
|
|
|
GType gtk_accessible_value_get_type (void) G_GNUC_CONST;
|
|
GQuark gtk_accessible_value_error_quark (void);
|
|
|
|
GtkAccessibleValue * gtk_accessible_value_alloc (const GtkAccessibleValueClass *klass);
|
|
GtkAccessibleValue * gtk_accessible_value_ref (GtkAccessibleValue *self);
|
|
void gtk_accessible_value_unref (GtkAccessibleValue *self);
|
|
void gtk_accessible_value_print (const GtkAccessibleValue *self,
|
|
GString *buffer);
|
|
char * gtk_accessible_value_to_string (const GtkAccessibleValue *self);
|
|
gboolean gtk_accessible_value_equal (const GtkAccessibleValue *value_a,
|
|
const GtkAccessibleValue *value_b);
|
|
|
|
GtkAccessibleValue * gtk_accessible_value_get_default_for_state (GtkAccessibleState state);
|
|
GtkAccessibleValue * gtk_accessible_value_collect_for_state (GtkAccessibleState state,
|
|
GError **error,
|
|
va_list *args);
|
|
GtkAccessibleValue * gtk_accessible_value_collect_for_state_value (GtkAccessibleState state,
|
|
const GValue *value,
|
|
GError **error);
|
|
|
|
GtkAccessibleValue * gtk_accessible_value_get_default_for_property (GtkAccessibleProperty property);
|
|
GtkAccessibleValue * gtk_accessible_value_collect_for_property (GtkAccessibleProperty property,
|
|
GError **error,
|
|
va_list *args);
|
|
GtkAccessibleValue * gtk_accessible_value_collect_for_property_value (GtkAccessibleProperty property,
|
|
const GValue *value,
|
|
GError **error);
|
|
|
|
GtkAccessibleValue * gtk_accessible_value_get_default_for_relation (GtkAccessibleRelation relation);
|
|
GtkAccessibleValue * gtk_accessible_value_collect_for_relation (GtkAccessibleRelation relation,
|
|
GError **error,
|
|
va_list *args);
|
|
GtkAccessibleValue * gtk_accessible_value_collect_for_relation_value (GtkAccessibleRelation relation,
|
|
const GValue *value,
|
|
GError **error);
|
|
|
|
/* Basic values */
|
|
GtkAccessibleValue * gtk_undefined_accessible_value_new (void);
|
|
int gtk_undefined_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
GtkAccessibleValue * gtk_boolean_accessible_value_new (gboolean value);
|
|
gboolean gtk_boolean_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
GtkAccessibleValue * gtk_tristate_accessible_value_new (GtkAccessibleTristate value);
|
|
GtkAccessibleTristate gtk_tristate_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
GtkAccessibleValue * gtk_int_accessible_value_new (int value);
|
|
int gtk_int_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
GtkAccessibleValue * gtk_number_accessible_value_new (double value);
|
|
double gtk_number_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
GtkAccessibleValue * gtk_string_accessible_value_new (const char *value);
|
|
const char * gtk_string_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
GtkAccessibleValue * gtk_reference_accessible_value_new (GtkAccessible *value);
|
|
GtkAccessible * gtk_reference_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
GtkAccessibleValue * gtk_reference_list_accessible_value_new (GList *value);
|
|
GList * gtk_reference_list_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
/* Token values */
|
|
GtkAccessibleValue * gtk_invalid_accessible_value_new (GtkAccessibleInvalidState value);
|
|
GtkAccessibleInvalidState gtk_invalid_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
GtkAccessibleValue * gtk_autocomplete_accessible_value_new (GtkAccessibleAutocomplete value);
|
|
GtkAccessibleAutocomplete gtk_autocomplete_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
GtkAccessibleValue * gtk_orientation_accessible_value_new (GtkOrientation value);
|
|
GtkOrientation gtk_orientation_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
GtkAccessibleValue * gtk_sort_accessible_value_new (GtkAccessibleSort value);
|
|
GtkAccessibleSort gtk_sort_accessible_value_get (const GtkAccessibleValue *value);
|
|
|
|
G_END_DECLS
|