forked from AuroraMiddleware/gtk
Speed up class action hookup
No need to construct a detailed signal name for every action when we can just look up the signal ID once and use the quark that the GParamSpec already has. Also, we don't need to loop over the actions every time we get a notification.
This commit is contained in:
parent
b968ced567
commit
c4a47e218f
@ -533,24 +533,15 @@ prop_action_notify (GObject *object,
|
|||||||
GParamSpec *pspec,
|
GParamSpec *pspec,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
GtkActionMuxer *muxer = user_data;
|
GtkWidget *widget = GTK_WIDGET (object);
|
||||||
GtkWidgetClass *klass = GTK_WIDGET_GET_CLASS (muxer->widget);
|
GtkWidgetAction *action = user_data;
|
||||||
GtkWidgetClassPrivate *priv = klass->priv;
|
GtkActionMuxer *muxer = _gtk_widget_get_action_muxer (widget, TRUE);
|
||||||
GtkWidgetAction *action = NULL;
|
|
||||||
GVariant *state;
|
GVariant *state;
|
||||||
|
|
||||||
g_assert ((GObject *)muxer->widget == object);
|
g_assert (muxer->widget == widget);
|
||||||
|
|
||||||
for (action = priv->actions; action; action = action->next)
|
|
||||||
{
|
|
||||||
if (action->pspec == pspec)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
g_assert (action != NULL);
|
|
||||||
g_assert (action->pspec == pspec);
|
g_assert (action->pspec == pspec);
|
||||||
|
|
||||||
state = prop_action_get_state (muxer->widget, action);
|
state = prop_action_get_state (widget, action);
|
||||||
gtk_action_muxer_action_state_changed (muxer, action->name, state);
|
gtk_action_muxer_action_state_changed (muxer, action->name, state);
|
||||||
g_variant_unref (state);
|
g_variant_unref (state);
|
||||||
}
|
}
|
||||||
@ -561,6 +552,7 @@ prop_actions_connect (GtkActionMuxer *muxer)
|
|||||||
GtkWidgetClassPrivate *priv;
|
GtkWidgetClassPrivate *priv;
|
||||||
GtkWidgetAction *action;
|
GtkWidgetAction *action;
|
||||||
GtkWidgetClass *klass;
|
GtkWidgetClass *klass;
|
||||||
|
guint signal_id;
|
||||||
|
|
||||||
if (!muxer->widget)
|
if (!muxer->widget)
|
||||||
return;
|
return;
|
||||||
@ -570,17 +562,20 @@ prop_actions_connect (GtkActionMuxer *muxer)
|
|||||||
if (!priv->actions)
|
if (!priv->actions)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
signal_id = g_signal_lookup ("notify", G_TYPE_OBJECT);
|
||||||
|
|
||||||
for (action = priv->actions; action; action = action->next)
|
for (action = priv->actions; action; action = action->next)
|
||||||
{
|
{
|
||||||
char *detailed;
|
|
||||||
|
|
||||||
if (!action->pspec)
|
if (!action->pspec)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
detailed = g_strconcat ("notify::", action->pspec->name, NULL);
|
g_signal_connect_closure_by_id (muxer->widget,
|
||||||
g_signal_connect (muxer->widget, detailed,
|
signal_id,
|
||||||
G_CALLBACK (prop_action_notify), muxer);
|
g_param_spec_get_name_quark (action->pspec),
|
||||||
g_free (detailed);
|
g_cclosure_new (G_CALLBACK (prop_action_notify),
|
||||||
|
action,
|
||||||
|
NULL),
|
||||||
|
FALSE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user