]> Pileus Git - ~andy/gtk/blobdiff - gtk/gtkaccelgroup.h
Minor doc cleanup
[~andy/gtk] / gtk / gtkaccelgroup.h
index afa63485723ee8b1db2d4fb732109c407af4d87b..fe8b1f779ba624a2730f83dade33e1ffaebfbf1f 100644 (file)
 /* GTK - The GIMP Toolkit
- * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
- *
- * GtkAccelGroup: Accelerator manager for GtkObjects.
- * Copyright (C) 1998 Tim Janik
+ * Copyright (C) 1998, 2001 Tim Janik
  *
  * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Library General Public
+ * modify it under the terms of the GNU Lesser 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.
+ * Lesser 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.
+ * 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/>.
+ */
+
+/*
+ * Modified by the GTK+ Team and others 1997-2000.  See the AUTHORS
+ * file for a list of people on the GTK+ Team.  See the ChangeLog
+ * files for a list of changes.  These files are distributed with
+ * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
  */
+
 #ifndef __GTK_ACCEL_GROUP_H__
 #define __GTK_ACCEL_GROUP_H__
 
 
+#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
+#error "Only <gtk/gtk.h> can be included directly."
+#endif
+
 #include <gdk/gdk.h>
-#include <gtk/gtkobject.h>
 #include <gtk/gtkenums.h>
 
+G_BEGIN_DECLS
 
-#ifdef __cplusplus
-extern "C" {
-#endif /* __cplusplus */
 
+/* --- type macros --- */
+#define GTK_TYPE_ACCEL_GROUP              (gtk_accel_group_get_type ())
+#define GTK_ACCEL_GROUP(object)           (G_TYPE_CHECK_INSTANCE_CAST ((object), GTK_TYPE_ACCEL_GROUP, GtkAccelGroup))
+#define GTK_ACCEL_GROUP_CLASS(klass)      (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_ACCEL_GROUP, GtkAccelGroupClass))
+#define GTK_IS_ACCEL_GROUP(object)        (G_TYPE_CHECK_INSTANCE_TYPE ((object), GTK_TYPE_ACCEL_GROUP))
+#define GTK_IS_ACCEL_GROUP_CLASS(klass)   (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_ACCEL_GROUP))
+#define GTK_ACCEL_GROUP_GET_CLASS(obj)    (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_ACCEL_GROUP, GtkAccelGroupClass))
 
-typedef struct _GtkAccelGroup  GtkAccelGroup;
-typedef struct _GtkAccelEntry  GtkAccelEntry;
 
+/* --- accel flags --- */
 typedef enum
 {
-  /* should the accelerator appear in
-   * the widget's display?
-   */
-  GTK_ACCEL_VISIBLE        = 1 << 0,
-  /* should the signal associated with
-   * this accelerator be also visible?
-   */
-  GTK_ACCEL_SIGNAL_VISIBLE = 1 << 1,
-  /* may the accelerator be removed
-   * again?
-   */
-  GTK_ACCEL_LOCKED         = 1 << 2,
+  GTK_ACCEL_VISIBLE        = 1 << 0,   /* display in GtkAccelLabel? */
+  GTK_ACCEL_LOCKED         = 1 << 1,   /* is it removable? */
   GTK_ACCEL_MASK           = 0x07
 } GtkAccelFlags;
 
+
+/* --- typedefs & structures --- */
+typedef struct _GtkAccelGroup            GtkAccelGroup;
+typedef struct _GtkAccelGroupClass        GtkAccelGroupClass;
+typedef struct _GtkAccelGroupPrivate      GtkAccelGroupPrivate;
+typedef struct _GtkAccelKey               GtkAccelKey;
+typedef struct _GtkAccelGroupEntry        GtkAccelGroupEntry;
+typedef gboolean (*GtkAccelGroupActivate) (GtkAccelGroup  *accel_group,
+                                          GObject        *acceleratable,
+                                          guint           keyval,
+                                          GdkModifierType modifier);
+
+/**
+ * GtkAccelGroupFindFunc:
+ * @key: 
+ * @closure: 
+ * @data: (closure):
+ * 
+ * Since: 2.2
+ */
+typedef gboolean (*GtkAccelGroupFindFunc) (GtkAccelKey    *key,
+                                          GClosure       *closure,
+                                          gpointer        data);
+
+/**
+ * GtkAccelGroup:
+ * 
+ * An object representing and maintaining a group of accelerators.
+ */
 struct _GtkAccelGroup
 {
-  guint                  ref_count;
-  guint                  lock_count;
-  GdkModifierType modifier_mask;
-  GSList         *attach_objects;
+  GObject               parent;
+  GtkAccelGroupPrivate *priv;
 };
 
-struct _GtkAccelEntry
+struct _GtkAccelGroupClass
 {
-  /* key portion
-   */
-  GtkAccelGroup                *accel_group;
-  guint                         accelerator_key;
-  GdkModifierType       accelerator_mods;
+  GObjectClass parent_class;
+
+  void (*accel_changed)        (GtkAccelGroup  *accel_group,
+                                guint           keyval,
+                                GdkModifierType modifier,
+                                GClosure       *accel_closure);
   
-  GtkAccelFlags                 accel_flags;
-  GtkObject            *object;
-  guint                         signal_id;
+  /* Padding for future expansion */
+  void (*_gtk_reserved1) (void);
+  void (*_gtk_reserved2) (void);
+  void (*_gtk_reserved3) (void);
+  void (*_gtk_reserved4) (void);
 };
 
+struct _GtkAccelKey
+{
+  guint           accel_key;
+  GdkModifierType accel_mods;
+  guint           accel_flags : 16;
+};
 
-/* Accelerator Groups
- */
-GtkAccelGroup*  gtk_accel_group_new            (void);
-GtkAccelGroup*  gtk_accel_group_get_default            (void);
-GtkAccelGroup*  gtk_accel_group_ref            (GtkAccelGroup  *accel_group);
-void           gtk_accel_group_unref           (GtkAccelGroup  *accel_group);
-gboolean        gtk_accel_group_activate       (GtkAccelGroup  *accel_group,
-                                                guint           accel_key,
-                                                GdkModifierType accel_mods);
-gboolean        gtk_accel_groups_activate              (GtkObject      *object,
-                                                guint           accel_key,
-                                                GdkModifierType accel_mods);
-void           gtk_accel_group_attach          (GtkAccelGroup  *accel_group,
-                                                GtkObject      *object);
-void           gtk_accel_group_detach          (GtkAccelGroup  *accel_group,
-                                                GtkObject      *object);
-void           gtk_accel_group_lock            (GtkAccelGroup  *accel_group);
-void           gtk_accel_group_unlock          (GtkAccelGroup  *accel_group);
-
-/* Accelerator Group Entries
- */
-GtkAccelEntry*         gtk_accel_group_get_entry       (GtkAccelGroup  *accel_group,
-                                                guint           accel_key,
-                                                GdkModifierType accel_mods);
-void           gtk_accel_group_lock_entry      (GtkAccelGroup  *accel_group,
-                                                guint           accel_key,
-                                                GdkModifierType accel_mods);
-void           gtk_accel_group_unlock_entry    (GtkAccelGroup  *accel_group,
-                                                guint           accel_key,
-                                                GdkModifierType accel_mods);
-void           gtk_accel_group_add             (GtkAccelGroup  *accel_group,
-                                                guint           accel_key,
-                                                GdkModifierType accel_mods,
-                                                GtkAccelFlags   accel_flags,
-                                                GtkObject      *object,
-                                                const gchar    *accel_signal);
-void           gtk_accel_group_remove          (GtkAccelGroup  *accel_group,
-                                                guint           accel_key,
-                                                GdkModifierType accel_mods,
-                                                GtkObject      *object);
 
-/* Accelerator Signals
- */
-void           gtk_accel_group_handle_add      (GtkObject      *object,
-                                                guint           accel_signal_id,
-                                                GtkAccelGroup  *accel_group,
-                                                guint           accel_key,
-                                                GdkModifierType accel_mods,
-                                                GtkAccelFlags   accel_flags);
-void           gtk_accel_group_handle_remove   (GtkObject      *object,
-                                                GtkAccelGroup  *accel_group,
+/* -- Accelerator Groups --- */
+GType          gtk_accel_group_get_type           (void) G_GNUC_CONST;
+GtkAccelGroup* gtk_accel_group_new               (void);
+gboolean       gtk_accel_group_get_is_locked      (GtkAccelGroup  *accel_group);
+GdkModifierType 
+               gtk_accel_group_get_modifier_mask  (GtkAccelGroup  *accel_group);
+void          gtk_accel_group_lock               (GtkAccelGroup  *accel_group);
+void          gtk_accel_group_unlock             (GtkAccelGroup  *accel_group);
+void          gtk_accel_group_connect            (GtkAccelGroup  *accel_group,
+                                                  guint           accel_key,
+                                                  GdkModifierType accel_mods,
+                                                  GtkAccelFlags   accel_flags,
+                                                  GClosure       *closure);
+void           gtk_accel_group_connect_by_path    (GtkAccelGroup  *accel_group,
+                                                  const gchar    *accel_path,
+                                                  GClosure       *closure);
+gboolean       gtk_accel_group_disconnect        (GtkAccelGroup  *accel_group,
+                                                  GClosure       *closure);
+gboolean       gtk_accel_group_disconnect_key    (GtkAccelGroup  *accel_group,
+                                                  guint           accel_key,
+                                                  GdkModifierType accel_mods);
+gboolean       gtk_accel_group_activate           (GtkAccelGroup   *accel_group,
+                                                   GQuark         accel_quark,
+                                                   GObject       *acceleratable,
+                                                   guint          accel_key,
+                                                   GdkModifierType accel_mods);
+
+
+/* --- GtkActivatable glue --- */
+void           _gtk_accel_group_attach         (GtkAccelGroup  *accel_group,
+                                                GObject        *object);
+void           _gtk_accel_group_detach         (GtkAccelGroup  *accel_group,
+                                                GObject        *object);
+gboolean        gtk_accel_groups_activate              (GObject        *object,
                                                 guint           accel_key,
                                                 GdkModifierType accel_mods);
-guint          gtk_accel_group_create_add      (GtkType         class_type,
-                                                GtkSignalRunType signal_flags,
-                                                guint           handler_offset);
-guint          gtk_accel_group_create_remove   (GtkType         class_type,
-                                                GtkSignalRunType signal_flags,
-                                                guint           handler_offset);
-void           gtk_accel_group_marshal_add     (GtkObject      *object,
-                                                GtkSignalFunc   func,
-                                                gpointer        func_data,
-                                                GtkArg         *args);
-void           gtk_accel_group_marshal_remove  (GtkObject      *object,
-                                                GtkSignalFunc   func,
-                                                gpointer        func_data,
-                                                GtkArg         *args);
-
-/* Miscellaneous
- */
-GSList*        gtk_accel_groups_from_object            (GtkObject      *object);
-GSList*        gtk_accel_group_entries_from_object     (GtkObject      *object);
+GSList*                gtk_accel_groups_from_object    (GObject        *object);
+GtkAccelKey*   gtk_accel_group_find            (GtkAccelGroup        *accel_group,
+                                                GtkAccelGroupFindFunc find_func,
+                                                gpointer              data);
+GtkAccelGroup* gtk_accel_group_from_accel_closure (GClosure    *closure);
 
 
-/* Accelerators
- */
+/* --- Accelerators--- */
 gboolean gtk_accelerator_valid               (guint            keyval,
-                                              GdkModifierType  modifiers);
+                                              GdkModifierType  modifiers) G_GNUC_CONST;
 void    gtk_accelerator_parse                (const gchar     *accelerator,
                                               guint           *accelerator_key,
                                               GdkModifierType *accelerator_mods);
+GDK_AVAILABLE_IN_3_4
+void gtk_accelerator_parse_with_keycode       (const gchar     *accelerator,
+                                               guint           *accelerator_key,
+                                               guint          **accelerator_codes,
+                                               GdkModifierType *accelerator_mods);
 gchar*  gtk_accelerator_name                 (guint            accelerator_key,
                                               GdkModifierType  accelerator_mods);
+GDK_AVAILABLE_IN_3_4
+gchar*  gtk_accelerator_name_with_keycode    (GdkDisplay      *display,
+                                               guint            accelerator_key,
+                                               guint            keycode,
+                                               GdkModifierType  accelerator_mods);
+gchar*   gtk_accelerator_get_label            (guint           accelerator_key,
+                                               GdkModifierType accelerator_mods);
+GDK_AVAILABLE_IN_3_4
+gchar*   gtk_accelerator_get_label_with_keycode (GdkDisplay      *display,
+                                                 guint            accelerator_key,
+                                                 guint            keycode,
+                                                 GdkModifierType  accelerator_mods);
 void    gtk_accelerator_set_default_mod_mask (GdkModifierType  default_mod_mask);
-guint   gtk_accelerator_get_default_mod_mask (void);
+GdkModifierType
+        gtk_accelerator_get_default_mod_mask (void);
+
 
+/* --- internal --- */
+GtkAccelGroupEntry*    gtk_accel_group_query   (GtkAccelGroup  *accel_group,
+                                                guint           accel_key,
+                                                GdkModifierType accel_mods,
+                                                guint          *n_entries);
+
+void                _gtk_accel_group_reconnect (GtkAccelGroup *accel_group,
+                                                GQuark         accel_path_quark);
+GSList*       _gtk_accel_group_get_accelerables (GtkAccelGroup *accel_group);
+
+struct _GtkAccelGroupEntry
+{
+  GtkAccelKey  key;
+  GClosure    *closure;
+  GQuark       accel_path_quark;
+};
 
 
-#ifdef __cplusplus
-}
-#endif /* __cplusplus */
+G_END_DECLS
 
 
 #endif /* __GTK_ACCEL_GROUP_H__ */