forked from AuroraMiddleware/gtk
c63087a563
To build a better world sometimes means having to tear the old one down. -- Alexander Pierce, "Captain America: The Winter Soldier" ATK served us well for nearly 20 years, but the world has changed, and GTK has changed with it. Now ATK is mostly a hindrance towards improving the accessibility stack: - it maps to a very specific implementation, AT-SPI, which is Linux and Unix specific - it requires implementing the same functionality in three different layers of the stack: AT-SPI, ATK, and GTK - only GTK uses it; every other Linux and Unix toolkit and application talks to AT-SPI directly, including assistive technologies Sadly, we cannot incrementally port GTK to a new accessibility stack; since ATK insulates us entirely from the underlying implementation, we cannot replace it piecemeal. Instead, we're going to remove everything and then incrementally build on a clean slate: - add an "accessible" interface, implemented by GTK objects directly, which describe the accessible role and state changes for every UI element - add an "assistive technology context" to proxy a native accessibility API, and assign it to every widget - implement the AT context depending on the platform For more information, see: https://gitlab.gnome.org/GNOME/gtk/-/issues/2833
160 lines
6.4 KiB
C
160 lines
6.4 KiB
C
/* gtkcombobox.h
|
||
* Copyright (C) 2002, 2003 Kristian Rietveld <kris@gtk.org>
|
||
*
|
||
* 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, see <http://www.gnu.org/licenses/>.
|
||
*/
|
||
|
||
#ifndef __GTK_COMBO_BOX_H__
|
||
#define __GTK_COMBO_BOX_H__
|
||
|
||
#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
|
||
#error "Only <gtk/gtk.h> can be included directly."
|
||
#endif
|
||
|
||
#include <gtk/gtkwidget.h>
|
||
#include <gtk/gtktreemodel.h>
|
||
#include <gtk/gtktreeview.h>
|
||
|
||
G_BEGIN_DECLS
|
||
|
||
#define GTK_TYPE_COMBO_BOX (gtk_combo_box_get_type ())
|
||
#define GTK_COMBO_BOX(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_COMBO_BOX, GtkComboBox))
|
||
#define GTK_COMBO_BOX_CLASS(vtable) (G_TYPE_CHECK_CLASS_CAST ((vtable), GTK_TYPE_COMBO_BOX, GtkComboBoxClass))
|
||
#define GTK_IS_COMBO_BOX(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_COMBO_BOX))
|
||
#define GTK_IS_COMBO_BOX_CLASS(vtable) (G_TYPE_CHECK_CLASS_TYPE ((vtable), GTK_TYPE_COMBO_BOX))
|
||
#define GTK_COMBO_BOX_GET_CLASS(inst) (G_TYPE_INSTANCE_GET_CLASS ((inst), GTK_TYPE_COMBO_BOX, GtkComboBoxClass))
|
||
|
||
typedef struct _GtkComboBox GtkComboBox;
|
||
typedef struct _GtkComboBoxClass GtkComboBoxClass;
|
||
|
||
struct _GtkComboBox
|
||
{
|
||
GtkWidget parent_instance;
|
||
};
|
||
|
||
/**
|
||
* GtkComboBoxClass:
|
||
* @parent_class: The parent class.
|
||
* @changed: Signal is emitted when the active item is changed.
|
||
* @format_entry_text: Signal which allows you to change how the text
|
||
* displayed in a combo box’s entry is displayed.
|
||
*/
|
||
struct _GtkComboBoxClass
|
||
{
|
||
GtkWidgetClass parent_class;
|
||
|
||
/*< public >*/
|
||
|
||
/* signals */
|
||
void (* changed) (GtkComboBox *combo_box);
|
||
char *(* format_entry_text) (GtkComboBox *combo_box,
|
||
const char *path);
|
||
|
||
/*< private >*/
|
||
|
||
gpointer padding[8];
|
||
};
|
||
|
||
|
||
/* construction */
|
||
GDK_AVAILABLE_IN_ALL
|
||
GType gtk_combo_box_get_type (void) G_GNUC_CONST;
|
||
GDK_AVAILABLE_IN_ALL
|
||
GtkWidget *gtk_combo_box_new (void);
|
||
GDK_AVAILABLE_IN_ALL
|
||
GtkWidget *gtk_combo_box_new_with_entry (void);
|
||
GDK_AVAILABLE_IN_ALL
|
||
GtkWidget *gtk_combo_box_new_with_model (GtkTreeModel *model);
|
||
GDK_AVAILABLE_IN_ALL
|
||
GtkWidget *gtk_combo_box_new_with_model_and_entry (GtkTreeModel *model);
|
||
|
||
/* get/set active item */
|
||
GDK_AVAILABLE_IN_ALL
|
||
int gtk_combo_box_get_active (GtkComboBox *combo_box);
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_set_active (GtkComboBox *combo_box,
|
||
int index_);
|
||
GDK_AVAILABLE_IN_ALL
|
||
gboolean gtk_combo_box_get_active_iter (GtkComboBox *combo_box,
|
||
GtkTreeIter *iter);
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_set_active_iter (GtkComboBox *combo_box,
|
||
GtkTreeIter *iter);
|
||
|
||
/* getters and setters */
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_set_model (GtkComboBox *combo_box,
|
||
GtkTreeModel *model);
|
||
GDK_AVAILABLE_IN_ALL
|
||
GtkTreeModel *gtk_combo_box_get_model (GtkComboBox *combo_box);
|
||
|
||
GDK_AVAILABLE_IN_ALL
|
||
GtkTreeViewRowSeparatorFunc gtk_combo_box_get_row_separator_func (GtkComboBox *combo_box);
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_set_row_separator_func (GtkComboBox *combo_box,
|
||
GtkTreeViewRowSeparatorFunc func,
|
||
gpointer data,
|
||
GDestroyNotify destroy);
|
||
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_set_button_sensitivity (GtkComboBox *combo_box,
|
||
GtkSensitivityType sensitivity);
|
||
GDK_AVAILABLE_IN_ALL
|
||
GtkSensitivityType gtk_combo_box_get_button_sensitivity (GtkComboBox *combo_box);
|
||
|
||
GDK_AVAILABLE_IN_ALL
|
||
gboolean gtk_combo_box_get_has_entry (GtkComboBox *combo_box);
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_set_entry_text_column (GtkComboBox *combo_box,
|
||
int text_column);
|
||
GDK_AVAILABLE_IN_ALL
|
||
int gtk_combo_box_get_entry_text_column (GtkComboBox *combo_box);
|
||
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_set_popup_fixed_width (GtkComboBox *combo_box,
|
||
gboolean fixed);
|
||
GDK_AVAILABLE_IN_ALL
|
||
gboolean gtk_combo_box_get_popup_fixed_width (GtkComboBox *combo_box);
|
||
|
||
/* programmatic control */
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_popup (GtkComboBox *combo_box);
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_popup_for_device (GtkComboBox *combo_box,
|
||
GdkDevice *device);
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_popdown (GtkComboBox *combo_box);
|
||
|
||
GDK_AVAILABLE_IN_ALL
|
||
int gtk_combo_box_get_id_column (GtkComboBox *combo_box);
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_set_id_column (GtkComboBox *combo_box,
|
||
int id_column);
|
||
GDK_AVAILABLE_IN_ALL
|
||
const char * gtk_combo_box_get_active_id (GtkComboBox *combo_box);
|
||
GDK_AVAILABLE_IN_ALL
|
||
gboolean gtk_combo_box_set_active_id (GtkComboBox *combo_box,
|
||
const char *active_id);
|
||
|
||
GDK_AVAILABLE_IN_ALL
|
||
void gtk_combo_box_set_child (GtkComboBox *combo_box,
|
||
GtkWidget *child);
|
||
GDK_AVAILABLE_IN_ALL
|
||
GtkWidget * gtk_combo_box_get_child (GtkComboBox *combo_box);
|
||
|
||
|
||
G_END_DECLS
|
||
|
||
#endif /* __GTK_COMBO_BOX_H__ */
|