summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTim Janik <timj@src.gnome.org>2008-06-20 10:57:08 +0000
committerTim Janik <timj@src.gnome.org>2008-06-20 10:57:08 +0000
commit2436a762e483665858c7f4d39157b0ade02fd74e (patch)
tree623f517a2b42d2f9fd3f81537c12b28743127573
parent2aa3a83bd4b6f0e86929e1c8eda33ba6dc75d88b (diff)
downloadgtk+-2436a762e483665858c7f4d39157b0ade02fd74e.tar.gz
Sealed GtkAccelGroup and added
* gtk/gtkaccelgroup.[ch]: Added GObject properties for lock_count, modifier_mask, acceleratables, n_accels and priv_accels. Added seal macro for public struct members which should be private. svn path=/trunk/; revision=20482
-rw-r--r--gtk/gtkaccelgroup.c138
-rw-r--r--gtk/gtkaccelgroup.h18
2 files changed, 148 insertions, 8 deletions
diff --git a/gtk/gtkaccelgroup.c b/gtk/gtkaccelgroup.c
index 55de4bb296..e7402f3144 100644
--- a/gtk/gtkaccelgroup.c
+++ b/gtk/gtkaccelgroup.c
@@ -39,9 +39,13 @@
/* --- prototypes --- */
-static void gtk_accel_group_finalize (GObject *object);
-static void accel_closure_invalidate (gpointer data,
- GClosure *closure);
+static void gtk_accel_group_finalize (GObject *object);
+static void gtk_accel_group_get_property (GObject *object,
+ guint param_id,
+ GValue *value,
+ GParamSpec *pspec);
+static void accel_closure_invalidate (gpointer data,
+ GClosure *closure);
/* --- variables --- */
@@ -56,6 +60,15 @@ static guint default_accel_mod_mask = (GDK_SHIFT_MASK |
GDK_META_MASK);
+enum {
+ PROP_0,
+ PROP_LOCK_COUNT,
+ PROP_MODIFIER_MASK,
+ PROP_ACCELERATABLES,
+ PROP_N_ACCELS,
+ PROP_PRIV_ACCELS
+};
+
G_DEFINE_TYPE (GtkAccelGroup, gtk_accel_group, G_TYPE_OBJECT)
/* --- functions --- */
@@ -67,9 +80,50 @@ gtk_accel_group_class_init (GtkAccelGroupClass *class)
quark_acceleratable_groups = g_quark_from_static_string ("gtk-acceleratable-accel-groups");
object_class->finalize = gtk_accel_group_finalize;
+ object_class->get_property = gtk_accel_group_get_property;
class->accel_changed = NULL;
+ g_object_class_install_property (object_class,
+ PROP_LOCK_COUNT,
+ g_param_spec_uint ("lock-count",
+ "Lock Count",
+ "Total locks on this accel group",
+ 0,
+ G_MAXUINT,
+ 0,
+ G_PARAM_READABLE));
+ g_object_class_install_property (object_class,
+ PROP_MODIFIER_MASK,
+ g_param_spec_enum ("modifier-mask",
+ "Modifier Mask",
+ "Modifier Mask",
+ gdk_modifier_type_get_type (),
+ 0,
+ G_PARAM_READABLE));
+ g_object_class_install_property (object_class,
+ PROP_ACCELERATABLES,
+ g_param_spec_pointer ("acceleratables",
+ "Acceleratables",
+ "Acceleratables",
+ G_PARAM_READABLE));
+ g_object_class_install_property (object_class,
+ PROP_N_ACCELS,
+ g_param_spec_uint ("n-accels",
+ "N Accels",
+ "Number of acceleraters",
+ 0,
+ G_MAXUINT,
+ 0,
+ G_PARAM_READABLE));
+ g_object_class_install_property (object_class,
+ PROP_PRIV_ACCELS,
+ g_param_spec_pointer ("priv-accels",
+ "Priv Accels",
+ "Private Acceleraters",
+ G_PARAM_READABLE));
+
+
/**
* GtkAccelGroup::accel-activate:
* @accel_group: the #GtkAccelGroup which received the signal
@@ -145,6 +199,36 @@ gtk_accel_group_finalize (GObject *object)
}
static void
+gtk_accel_group_get_property (GObject *object,
+ guint param_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+ GtkAccelGroup *accel_group = GTK_ACCEL_GROUP (object);
+
+ switch (param_id) {
+ case PROP_LOCK_COUNT:
+ g_value_set_uint (value, accel_group->lock_count);
+ break;
+ case PROP_MODIFIER_MASK:
+ g_value_set_enum (value, accel_group->modifier_mask);
+ break;
+ case PROP_ACCELERATABLES:
+ g_value_set_pointer (value, accel_group->acceleratables);
+ break;
+ case PROP_N_ACCELS:
+ g_value_set_uint (value, accel_group->n_accels);
+ break;
+ case PROP_PRIV_ACCELS:
+ g_value_set_pointer (value, accel_group->priv_accels);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, param_id, pspec);
+ break;
+ };
+}
+
+static void
gtk_accel_group_init (GtkAccelGroup *accel_group)
{
accel_group->lock_count = 0;
@@ -166,6 +250,46 @@ gtk_accel_group_new (void)
return g_object_new (GTK_TYPE_ACCEL_GROUP, NULL);
}
+guint
+gtk_accel_group_get_lock_count (GtkAccelGroup *accel_group)
+{
+ g_return_val_if_fail (GTK_IS_ACCEL_GROUP (accel_group), 0);
+
+ return accel_group->lock_count;
+}
+
+GdkModifierType
+gtk_accel_group_get_modifier_mask (GtkAccelGroup *accel_group)
+{
+ g_return_val_if_fail (GTK_IS_ACCEL_GROUP (accel_group), 0);
+
+ return accel_group->modifier_mask;
+}
+
+GSList *
+gtk_accel_group_get_acceleratables (GtkAccelGroup *accel_group)
+{
+ g_return_val_if_fail (GTK_IS_ACCEL_GROUP (accel_group), NULL);
+
+ return accel_group->acceleratables;
+}
+
+guint
+gtk_accel_group_get_n_accels (GtkAccelGroup *accel_group)
+{
+ g_return_val_if_fail (GTK_IS_ACCEL_GROUP (accel_group), 0);
+
+ return accel_group->n_accels;
+}
+
+GtkAccelGroupEntry *
+gtk_accel_group_get_priv_accels (GtkAccelGroup *accel_group)
+{
+ g_return_val_if_fail (GTK_IS_ACCEL_GROUP (accel_group), NULL);
+
+ return accel_group->priv_accels;
+}
+
static void
accel_group_weak_ref_detach (GSList *free_list,
GObject *stale_object)
@@ -179,6 +303,7 @@ accel_group_weak_ref_detach (GSList *free_list,
accel_group = slist->data;
accel_group->acceleratables = g_slist_remove (accel_group->acceleratables, stale_object);
g_object_unref (accel_group);
+ g_object_notify (G_OBJECT (accel_group), "acceleratables");
}
g_slist_free (free_list);
g_object_set_qdata (stale_object, quark_acceleratable_groups, NULL);
@@ -206,6 +331,7 @@ _gtk_accel_group_attach (GtkAccelGroup *accel_group,
g_object_weak_ref (object,
(GWeakNotify) accel_group_weak_ref_detach,
slist);
+ g_object_notify (G_OBJECT (accel_group), "acceleratables");
}
void
@@ -229,6 +355,7 @@ _gtk_accel_group_detach (GtkAccelGroup *accel_group,
g_object_weak_ref (object,
(GWeakNotify) accel_group_weak_ref_detach,
slist);
+ g_object_notify (G_OBJECT (accel_group), "acceleratables");
g_object_unref (accel_group);
}
@@ -304,6 +431,8 @@ gtk_accel_group_lock (GtkAccelGroup *accel_group)
g_return_if_fail (GTK_IS_ACCEL_GROUP (accel_group));
accel_group->lock_count += 1;
+
+ g_object_notify (G_OBJECT (accel_group), "lock-count");
}
/**
@@ -319,6 +448,8 @@ gtk_accel_group_unlock (GtkAccelGroup *accel_group)
g_return_if_fail (accel_group->lock_count > 0);
accel_group->lock_count -= 1;
+
+ g_object_notify (G_OBJECT (accel_group), "lock-count");
}
static void
@@ -371,6 +502,7 @@ quick_accel_add (GtkAccelGroup *accel_group,
accel_group->priv_accels[pos].closure = g_closure_ref (closure);
accel_group->priv_accels[pos].accel_path_quark = path_quark;
g_closure_sink (closure);
+ g_object_notify (G_OBJECT (accel_group), "priv-accels");
/* handle closure invalidation and reverse lookups */
g_closure_add_invalidate_notifier (closure, accel_group, accel_closure_invalidate);
diff --git a/gtk/gtkaccelgroup.h b/gtk/gtkaccelgroup.h
index c620a9e8b9..72c74e8844 100644
--- a/gtk/gtkaccelgroup.h
+++ b/gtk/gtkaccelgroup.h
@@ -73,11 +73,11 @@ typedef gboolean (*GtkAccelGroupFindFunc) (GtkAccelKey *key,
struct _GtkAccelGroup
{
GObject parent;
- guint lock_count;
- GdkModifierType modifier_mask;
- GSList *acceleratables;
- guint n_accels;
- GtkAccelGroupEntry *priv_accels;
+ guint GSEAL (lock_count);
+ GdkModifierType GSEAL (modifier_mask);
+ GSList *GSEAL (acceleratables);
+ guint GSEAL (n_accels);
+ GtkAccelGroupEntry *GSEAL (priv_accels);
};
struct _GtkAccelGroupClass
@@ -107,6 +107,14 @@ struct _GtkAccelKey
/* -- Accelerator Groups --- */
GType gtk_accel_group_get_type (void) G_GNUC_CONST;
GtkAccelGroup* gtk_accel_group_new (void);
+guint gtk_accel_group_get_lock_count (GtkAccelGroup *accel_group);
+GdkModifierType
+ gtk_accel_group_get_modifier_mask (GtkAccelGroup *accel_group);
+GSList* gtk_accel_group_get_acceleratables (GtkAccelGroup *accel_group);
+guint gtk_accel_group_get_n_accels (GtkAccelGroup *accel_group);
+GtkAccelGroupEntry*
+ gtk_accel_group_get_priv_accels (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,