spin button: Stop using ::focus-out-event

Just use the generic ::event signal.
This commit is contained in:
Matthias Clasen 2018-01-06 17:53:20 -05:00
parent 4f3065a5e8
commit 5cb1c606bb

View File

@ -258,8 +258,8 @@ static void gtk_spin_button_size_allocate (GtkWidget *widget,
const GtkAllocation *allocation, const GtkAllocation *allocation,
int baseline, int baseline,
GtkAllocation *out_clip); GtkAllocation *out_clip);
static gint gtk_spin_button_focus_out (GtkWidget *widget, static gboolean gtk_spin_button_event (GtkWidget *widget,
GdkEventFocus *event); GdkEvent *event);
static void gtk_spin_button_grab_notify (GtkWidget *widget, static void gtk_spin_button_grab_notify (GtkWidget *widget,
gboolean was_grabbed); gboolean was_grabbed);
static void gtk_spin_button_state_flags_changed (GtkWidget *widget, static void gtk_spin_button_state_flags_changed (GtkWidget *widget,
@ -321,7 +321,7 @@ gtk_spin_button_class_init (GtkSpinButtonClass *class)
widget_class->measure = gtk_spin_button_measure; widget_class->measure = gtk_spin_button_measure;
widget_class->size_allocate = gtk_spin_button_size_allocate; widget_class->size_allocate = gtk_spin_button_size_allocate;
widget_class->key_release_event = gtk_spin_button_key_release; widget_class->key_release_event = gtk_spin_button_key_release;
widget_class->focus_out_event = gtk_spin_button_focus_out; widget_class->event = gtk_spin_button_event;
widget_class->grab_notify = gtk_spin_button_grab_notify; widget_class->grab_notify = gtk_spin_button_grab_notify;
widget_class->state_flags_changed = gtk_spin_button_state_flags_changed; widget_class->state_flags_changed = gtk_spin_button_state_flags_changed;
@ -1086,16 +1086,27 @@ gtk_spin_button_size_allocate (GtkWidget *widget,
gtk_widget_size_allocate (priv->box, allocation, baseline, out_clip); gtk_widget_size_allocate (priv->box, allocation, baseline, out_clip);
} }
static gint static gboolean
gtk_spin_button_focus_out (GtkWidget *widget, gtk_spin_button_event (GtkWidget *widget,
GdkEventFocus *event) GdkEvent *event)
{ {
GtkSpinButton *spin_button = GTK_SPIN_BUTTON (widget); GtkSpinButton *spin_button = GTK_SPIN_BUTTON (widget);
if (gtk_editable_get_editable (GTK_EDITABLE (spin_button->priv->entry))) if (gdk_event_get_event_type (event) == GDK_FOCUS_CHANGE)
gtk_spin_button_update (spin_button); {
gboolean focus_in;
return GTK_WIDGET_CLASS (gtk_spin_button_parent_class)->focus_out_event (widget, event); gdk_event_get_focus_in (event, &focus_in);
if (!focus_in)
{
if (gtk_editable_get_editable (GTK_EDITABLE (spin_button->priv->entry)))
gtk_spin_button_update (spin_button);
}
return GDK_EVENT_PROPAGATE;
}
return GDK_EVENT_PROPAGATE;
} }
static void static void