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:
Matthias Clasen 2020-04-28 20:22:26 -04:00
parent b968ced567
commit c4a47e218f

View File

@ -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);
} }
} }