summaryrefslogtreecommitdiff
path: root/gio/gsimpleactiongroup.c
diff options
context:
space:
mode:
authorRyan Lortie <desrt@desrt.ca>2010-08-30 17:31:06 +0200
committerRyan Lortie <desrt@desrt.ca>2010-08-30 19:26:37 +0200
commit6cd62920bbb8ed42c7381bb56deca820515500f9 (patch)
treed23fcc6b0d997a1df4b4cb8e4385e55b5c57e21e /gio/gsimpleactiongroup.c
parent75891001bc5ed5a99c9a9af17407b0a797f79df4 (diff)
downloadglib-6cd62920bbb8ed42c7381bb56deca820515500f9.tar.gz
GActionGroup is now an interface
- make GAction.get_state() return a reference - fix some leaks/warnings in the tests - fix signal propagation in GSimpleActionGroup
Diffstat (limited to 'gio/gsimpleactiongroup.c')
-rw-r--r--gio/gsimpleactiongroup.c89
1 files changed, 34 insertions, 55 deletions
diff --git a/gio/gsimpleactiongroup.c b/gio/gsimpleactiongroup.c
index dc3451d60..dd170223e 100644
--- a/gio/gsimpleactiongroup.c
+++ b/gio/gsimpleactiongroup.c
@@ -36,7 +36,11 @@ struct _GSimpleActionGroupPrivate
GHashTable *table; /* string -> GAction */
};
-G_DEFINE_TYPE (GSimpleActionGroup, g_simple_action_group, G_TYPE_ACTION_GROUP)
+static void g_simple_action_group_iface_init (GActionGroupInterface *);
+G_DEFINE_TYPE_WITH_CODE (GSimpleActionGroup,
+ g_simple_action_group, G_TYPE_OBJECT,
+ G_IMPLEMENT_INTERFACE (G_TYPE_ACTION_GROUP,
+ g_simple_action_group_iface_init))
static gchar **
g_simple_action_group_list_actions (GActionGroup *group)
@@ -176,23 +180,27 @@ g_simple_action_group_activate (GActionGroup *group,
}
static void
-action_enabled_changed (GAction *action,
- gboolean enabled,
- gpointer user_data)
+action_enabled_notify (GAction *action,
+ GParamSpec *pspec,
+ gpointer user_data)
{
g_action_group_action_enabled_changed (user_data,
g_action_get_name (action),
- enabled);
+ g_action_get_enabled (action));
}
static void
-action_state_changed (GAction *action,
- GVariant *value,
- gpointer user_data)
+action_state_notify (GAction *action,
+ GParamSpec *pspec,
+ gpointer user_data)
{
+ GVariant *value;
+
+ value = g_action_get_state (action);
g_action_group_action_state_changed (user_data,
g_action_get_name (action),
value);
+ g_variant_unref (value);
}
static void
@@ -200,9 +208,9 @@ g_simple_action_group_disconnect (gpointer key,
gpointer value,
gpointer user_data)
{
- g_signal_handlers_disconnect_by_func (value, action_enabled_changed,
+ g_signal_handlers_disconnect_by_func (value, action_enabled_notify,
user_data);
- g_signal_handlers_disconnect_by_func (value, action_state_changed,
+ g_signal_handlers_disconnect_by_func (value, action_state_notify,
user_data);
}
@@ -233,24 +241,27 @@ g_simple_action_group_init (GSimpleActionGroup *simple)
static void
g_simple_action_group_class_init (GSimpleActionGroupClass *class)
{
- GActionGroupClass *group_class = G_ACTION_GROUP_CLASS (class);
GObjectClass *object_class = G_OBJECT_CLASS (class);
object_class->finalize = g_simple_action_group_finalize;
- group_class->list_actions = g_simple_action_group_list_actions;
- group_class->has_action = g_simple_action_group_has_action;
- group_class->get_parameter_type = g_simple_action_group_get_parameter_type;
- group_class->get_state_type = g_simple_action_group_get_state_type;
- group_class->get_state_hint = g_simple_action_group_get_state_hint;
- group_class->get_enabled = g_simple_action_group_get_enabled;
- group_class->get_state = g_simple_action_group_get_state;
- group_class->set_state = g_simple_action_group_set_state;
- group_class->activate = g_simple_action_group_activate;
-
g_type_class_add_private (class, sizeof (GSimpleActionGroupPrivate));
}
+static void
+g_simple_action_group_iface_init (GActionGroupInterface *iface)
+{
+ iface->list_actions = g_simple_action_group_list_actions;
+ iface->has_action = g_simple_action_group_has_action;
+ iface->get_parameter_type = g_simple_action_group_get_parameter_type;
+ iface->get_state_type = g_simple_action_group_get_state_type;
+ iface->get_state_hint = g_simple_action_group_get_state_hint;
+ iface->get_enabled = g_simple_action_group_get_enabled;
+ iface->get_state = g_simple_action_group_get_state;
+ iface->set_state = g_simple_action_group_set_state;
+ iface->activate = g_simple_action_group_activate;
+}
+
/**
* g_simple_action_group_new:
*
@@ -325,11 +336,11 @@ g_simple_action_group_insert (GSimpleActionGroup *simple,
}
g_signal_connect (action, "notify::enabled",
- G_CALLBACK (action_enabled_changed), simple);
+ G_CALLBACK (action_enabled_notify), simple);
if (g_action_get_state_type (action) != NULL)
g_signal_connect (action, "notify::state",
- G_CALLBACK (action_state_changed), simple);
+ G_CALLBACK (action_state_notify), simple);
g_hash_table_insert (simple->priv->table,
g_strdup (action_name),
@@ -367,35 +378,3 @@ g_simple_action_group_remove (GSimpleActionGroup *simple,
g_hash_table_remove (simple->priv->table, action_name);
}
}
-
-/**
- * g_simple_action_group_set_enabled:
- * @simple: a #GSimpleActionGroup
- * @action_name: the name of an action
- * @enabled: if the action should be enabled
- *
- * Sets an action in the group as being enabled or not.
- *
- * This is a convenience function, equivalent to calling
- * g_simple_action_group_lookup() and using g_action_set_enabled() on
- * the result.
- *
- * If no action named @action_name exists then this function does
- * nothing.
- *
- * Since: 2.26
- **/
-void
-g_simple_action_group_set_enabled (GSimpleActionGroup *simple,
- const gchar *action_name,
- gboolean enabled)
-{
- GAction *action;
-
- g_return_if_fail (G_IS_SIMPLE_ACTION_GROUP (simple));
-
- action = g_hash_table_lookup (simple->priv->table, action_name);
-
- if (action != NULL)
- g_action_set_enabled (action, enabled);
-}