GSimpleAction: Fix to comply with constructor rules

foo_new_*() must be pure wrappers around g_object_new(), otherwise
their functionality is inaccessible to bindings.
This commit is contained in:
Colin Walters 2011-11-30 17:26:59 -05:00 committed by Ryan Lortie
parent 76527e5cd5
commit 41e5ba86a7
2 changed files with 57 additions and 37 deletions

View File

@ -77,7 +77,8 @@ g_action_default_init (GActionInterface *iface)
P_("Action Name"), P_("Action Name"),
P_("The name used to invoke the action"), P_("The name used to invoke the action"),
NULL, NULL,
G_PARAM_READABLE | G_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY |
G_PARAM_STATIC_STRINGS)); G_PARAM_STATIC_STRINGS));
/** /**
@ -93,7 +94,8 @@ g_action_default_init (GActionInterface *iface)
P_("Parameter Type"), P_("Parameter Type"),
P_("The type of GVariant passed to activate()"), P_("The type of GVariant passed to activate()"),
G_TYPE_VARIANT_TYPE, G_TYPE_VARIANT_TYPE,
G_PARAM_READABLE | G_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY |
G_PARAM_STATIC_STRINGS)); G_PARAM_STATIC_STRINGS));
/** /**
@ -111,7 +113,8 @@ g_action_default_init (GActionInterface *iface)
P_("Enabled"), P_("Enabled"),
P_("If the action can be activated"), P_("If the action can be activated"),
TRUE, TRUE,
G_PARAM_READABLE | G_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY |
G_PARAM_STATIC_STRINGS)); G_PARAM_STATIC_STRINGS));
/** /**
@ -143,7 +146,8 @@ g_action_default_init (GActionInterface *iface)
P_("The state the action is in"), P_("The state the action is in"),
G_VARIANT_TYPE_ANY, G_VARIANT_TYPE_ANY,
NULL, NULL,
G_PARAM_READABLE | G_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY |
G_PARAM_STATIC_STRINGS)); G_PARAM_STATIC_STRINGS));
} }

View File

@ -207,6 +207,37 @@ g_simple_action_activate (GAction *action,
g_variant_unref (parameter); g_variant_unref (parameter);
} }
static void
g_simple_action_set_property (GObject *object,
guint prop_id,
const GValue *value,
GParamSpec *pspec)
{
GSimpleAction *action = G_SIMPLE_ACTION (object);
switch (prop_id)
{
case PROP_NAME:
action->name = g_strdup (g_value_get_string (value));
break;
case PROP_PARAMETER_TYPE:
action->parameter_type = g_value_dup_boxed (value);
break;
case PROP_ENABLED:
action->enabled = g_value_get_boolean (value);
break;
case PROP_STATE:
action->state = g_value_dup_variant (value);
break;
default:
g_assert_not_reached ();
}
}
static void static void
g_simple_action_get_property (GObject *object, g_simple_action_get_property (GObject *object,
guint prop_id, guint prop_id,
@ -280,6 +311,7 @@ g_simple_action_class_init (GSimpleActionClass *class)
{ {
GObjectClass *object_class = G_OBJECT_CLASS (class); GObjectClass *object_class = G_OBJECT_CLASS (class);
object_class->set_property = g_simple_action_set_property;
object_class->get_property = g_simple_action_get_property; object_class->get_property = g_simple_action_get_property;
object_class->finalize = g_simple_action_finalize; object_class->finalize = g_simple_action_finalize;
@ -367,7 +399,8 @@ g_simple_action_class_init (GSimpleActionClass *class)
P_("Action Name"), P_("Action Name"),
P_("The name used to invoke the action"), P_("The name used to invoke the action"),
NULL, NULL,
G_PARAM_READABLE | G_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY |
G_PARAM_STATIC_STRINGS)); G_PARAM_STATIC_STRINGS));
/** /**
@ -383,7 +416,8 @@ g_simple_action_class_init (GSimpleActionClass *class)
P_("Parameter Type"), P_("Parameter Type"),
P_("The type of GVariant passed to activate()"), P_("The type of GVariant passed to activate()"),
G_TYPE_VARIANT_TYPE, G_TYPE_VARIANT_TYPE,
G_PARAM_READABLE | G_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY |
G_PARAM_STATIC_STRINGS)); G_PARAM_STATIC_STRINGS));
/** /**
@ -401,7 +435,8 @@ g_simple_action_class_init (GSimpleActionClass *class)
P_("Enabled"), P_("Enabled"),
P_("If the action can be activated"), P_("If the action can be activated"),
TRUE, TRUE,
G_PARAM_READABLE | G_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY |
G_PARAM_STATIC_STRINGS)); G_PARAM_STATIC_STRINGS));
/** /**
@ -433,7 +468,8 @@ g_simple_action_class_init (GSimpleActionClass *class)
P_("The state the action is in"), P_("The state the action is in"),
G_VARIANT_TYPE_ANY, G_VARIANT_TYPE_ANY,
NULL, NULL,
G_PARAM_READABLE | G_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY |
G_PARAM_STATIC_STRINGS)); G_PARAM_STATIC_STRINGS));
} }
@ -483,19 +519,10 @@ GSimpleAction *
g_simple_action_new (const gchar *name, g_simple_action_new (const gchar *name,
const GVariantType *parameter_type) const GVariantType *parameter_type)
{ {
GSimpleAction *simple; return (GSimpleAction*) g_object_new (G_TYPE_SIMPLE_ACTION,
"name", name,
g_return_val_if_fail (name != NULL, NULL); "parameter-type", parameter_type,
NULL);
simple = g_object_new (G_TYPE_SIMPLE_ACTION, NULL);
simple->name = g_strdup (name);
if (parameter_type)
simple->parameter_type = g_variant_type_copy (parameter_type);
simple->enabled = TRUE;
return simple;
} }
/** /**
@ -520,20 +547,9 @@ g_simple_action_new_stateful (const gchar *name,
const GVariantType *parameter_type, const GVariantType *parameter_type,
GVariant *state) GVariant *state)
{ {
GSimpleAction *simple; return (GSimpleAction*) g_object_new (G_TYPE_SIMPLE_ACTION,
"name", name,
g_return_val_if_fail (name != NULL, NULL); "parameter-type", parameter_type,
g_return_val_if_fail (state != NULL, NULL); "state", state,
NULL);
simple = g_object_new (G_TYPE_SIMPLE_ACTION, NULL);
simple->name = g_strdup (name);
if (parameter_type)
simple->parameter_type = g_variant_type_copy (parameter_type);
simple->state = g_variant_ref_sink (state);
simple->enabled = TRUE;
return simple;
} }