mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-14 22:30:22 +00:00
Merge branch 'class-action-init' into 'master'
Reshuffle action muxer initialization See merge request GNOME/gtk!1789
This commit is contained in:
commit
b47e721ab6
@ -533,24 +533,15 @@ prop_action_notify (GObject *object,
|
||||
GParamSpec *pspec,
|
||||
gpointer user_data)
|
||||
{
|
||||
GtkActionMuxer *muxer = user_data;
|
||||
GtkWidgetClass *klass = GTK_WIDGET_GET_CLASS (muxer->widget);
|
||||
GtkWidgetClassPrivate *priv = klass->priv;
|
||||
GtkWidgetAction *action = NULL;
|
||||
GtkWidget *widget = GTK_WIDGET (object);
|
||||
GtkWidgetAction *action = user_data;
|
||||
GtkActionMuxer *muxer = _gtk_widget_get_action_muxer (widget, TRUE);
|
||||
GVariant *state;
|
||||
|
||||
g_assert ((GObject *)muxer->widget == object);
|
||||
|
||||
for (action = priv->actions; action; action = action->next)
|
||||
{
|
||||
if (action->pspec == pspec)
|
||||
break;
|
||||
}
|
||||
|
||||
g_assert (action != NULL);
|
||||
g_assert (muxer->widget == widget);
|
||||
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);
|
||||
g_variant_unref (state);
|
||||
}
|
||||
@ -561,6 +552,7 @@ prop_actions_connect (GtkActionMuxer *muxer)
|
||||
GtkWidgetClassPrivate *priv;
|
||||
GtkWidgetAction *action;
|
||||
GtkWidgetClass *klass;
|
||||
guint signal_id;
|
||||
|
||||
if (!muxer->widget)
|
||||
return;
|
||||
@ -570,17 +562,20 @@ prop_actions_connect (GtkActionMuxer *muxer)
|
||||
if (!priv->actions)
|
||||
return;
|
||||
|
||||
signal_id = g_signal_lookup ("notify", G_TYPE_OBJECT);
|
||||
|
||||
for (action = priv->actions; action; action = action->next)
|
||||
{
|
||||
char *detailed;
|
||||
|
||||
if (!action->pspec)
|
||||
continue;
|
||||
|
||||
detailed = g_strconcat ("notify::", action->pspec->name, NULL);
|
||||
g_signal_connect (muxer->widget, detailed,
|
||||
G_CALLBACK (prop_action_notify), muxer);
|
||||
g_free (detailed);
|
||||
g_signal_connect_closure_by_id (muxer->widget,
|
||||
signal_id,
|
||||
g_param_spec_get_name_quark (action->pspec),
|
||||
g_cclosure_new (G_CALLBACK (prop_action_notify),
|
||||
action,
|
||||
NULL),
|
||||
FALSE);
|
||||
}
|
||||
}
|
||||
|
||||
@ -864,14 +859,10 @@ gtk_action_muxer_dispose (GObject *object)
|
||||
->dispose (object);
|
||||
}
|
||||
|
||||
static void
|
||||
gtk_action_muxer_constructed (GObject *object)
|
||||
void
|
||||
gtk_action_muxer_connect_class_actions (GtkActionMuxer *muxer)
|
||||
{
|
||||
GtkActionMuxer *muxer = GTK_ACTION_MUXER (object);
|
||||
|
||||
prop_actions_connect (muxer);
|
||||
|
||||
G_OBJECT_CLASS (gtk_action_muxer_parent_class)->constructed (object);
|
||||
}
|
||||
|
||||
static void
|
||||
@ -949,7 +940,6 @@ gtk_action_muxer_class_init (GObjectClass *class)
|
||||
{
|
||||
class->get_property = gtk_action_muxer_get_property;
|
||||
class->set_property = gtk_action_muxer_set_property;
|
||||
class->constructed = gtk_action_muxer_constructed;
|
||||
class->finalize = gtk_action_muxer_finalize;
|
||||
class->dispose = gtk_action_muxer_dispose;
|
||||
|
||||
|
@ -81,6 +81,7 @@ gtk_action_muxer_action_state_changed (GtkActionMuxer *muxer,
|
||||
const gchar *action_name,
|
||||
GVariant *state);
|
||||
|
||||
void gtk_action_muxer_connect_class_actions (GtkActionMuxer *muxer);
|
||||
|
||||
/* No better place for these... */
|
||||
gchar * gtk_print_action_and_target (const gchar *action_namespace,
|
||||
|
@ -865,6 +865,20 @@ gtk_widget_real_unroot (GtkWidget *widget)
|
||||
gtk_widget_forall (widget, (GtkCallback) gtk_widget_unroot, NULL);
|
||||
}
|
||||
|
||||
static void
|
||||
gtk_widget_constructed (GObject *object)
|
||||
{
|
||||
G_OBJECT_CLASS (gtk_widget_parent_class)->constructed (object);
|
||||
|
||||
if (GTK_WIDGET_GET_CLASS (object)->priv->actions)
|
||||
{
|
||||
GtkActionMuxer *muxer;
|
||||
|
||||
muxer = _gtk_widget_get_action_muxer (GTK_WIDGET (object), TRUE);
|
||||
gtk_action_muxer_connect_class_actions (muxer);
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
gtk_widget_class_init (GtkWidgetClass *klass)
|
||||
{
|
||||
@ -882,6 +896,7 @@ gtk_widget_class_init (GtkWidgetClass *klass)
|
||||
quark_font_options = g_quark_from_static_string ("gtk-widget-font-options");
|
||||
quark_font_map = g_quark_from_static_string ("gtk-widget-font-map");
|
||||
|
||||
gobject_class->constructed = gtk_widget_constructed;
|
||||
gobject_class->dispose = gtk_widget_dispose;
|
||||
gobject_class->finalize = gtk_widget_finalize;
|
||||
gobject_class->set_property = gtk_widget_set_property;
|
||||
|
Loading…
Reference in New Issue
Block a user