switch: Remove in_switch flag

It's pretty simple and less code to just check whether the gesture
coords are inside the widget at the one place where we actually used the
flag.
This commit is contained in:
Timm Bäder 2017-06-17 14:18:14 +02:00 committed by Matthias Clasen
parent 63ba8fa355
commit 24abbac114

View File

@ -85,7 +85,6 @@ struct _GtkSwitchPrivate
guint state : 1; guint state : 1;
guint is_active : 1; guint is_active : 1;
guint in_switch : 1;
GtkWidget *on_label; GtkWidget *on_label;
GtkWidget *off_label; GtkWidget *off_label;
@ -209,12 +208,14 @@ gtk_switch_multipress_gesture_released (GtkGestureMultiPress *gesture,
gdouble y, gdouble y,
GtkSwitch *sw) GtkSwitch *sw)
{ {
GtkSwitchPrivate *priv = sw->priv;
GdkEventSequence *sequence; GdkEventSequence *sequence;
GdkRectangle own_alloc;
sequence = gtk_gesture_single_get_current_sequence (GTK_GESTURE_SINGLE (gesture)); sequence = gtk_gesture_single_get_current_sequence (GTK_GESTURE_SINGLE (gesture));
if (priv->in_switch && gtk_widget_get_own_allocation (GTK_WIDGET (sw), &own_alloc);
if (gdk_rectangle_contains_point (&own_alloc, x, y) &&
gtk_gesture_handles_sequence (GTK_GESTURE (gesture), sequence)) gtk_gesture_handles_sequence (GTK_GESTURE (gesture), sequence))
gtk_switch_begin_toggle_animation (sw); gtk_switch_begin_toggle_animation (sw);
} }
@ -277,28 +278,6 @@ gtk_switch_pan_gesture_drag_end (GtkGestureDrag *gesture,
gtk_widget_queue_allocate (GTK_WIDGET (sw)); gtk_widget_queue_allocate (GTK_WIDGET (sw));
} }
static gboolean
gtk_switch_enter (GtkWidget *widget,
GdkEventCrossing *event)
{
GtkSwitchPrivate *priv = GTK_SWITCH (widget)->priv;
priv->in_switch = TRUE;
return FALSE;
}
static gboolean
gtk_switch_leave (GtkWidget *widget,
GdkEventCrossing *event)
{
GtkSwitchPrivate *priv = GTK_SWITCH (widget)->priv;
priv->in_switch = FALSE;
return FALSE;
}
static void static void
gtk_switch_activate (GtkSwitch *sw) gtk_switch_activate (GtkSwitch *sw)
{ {
@ -593,8 +572,6 @@ gtk_switch_class_init (GtkSwitchClass *klass)
widget_class->measure = gtk_switch_measure; widget_class->measure = gtk_switch_measure;
widget_class->size_allocate = gtk_switch_size_allocate; widget_class->size_allocate = gtk_switch_size_allocate;
widget_class->snapshot = gtk_switch_snapshot; widget_class->snapshot = gtk_switch_snapshot;
widget_class->enter_notify_event = gtk_switch_enter;
widget_class->leave_notify_event = gtk_switch_leave;
klass->activate = gtk_switch_activate; klass->activate = gtk_switch_activate;
klass->state_set = state_set; klass->state_set = state_set;