diff options
author | Michal Hruby <michal.mhr@gmail.com> | 2011-10-03 14:58:08 +0200 |
---|---|---|
committer | Michal Hruby <michal.mhr@gmail.com> | 2011-10-03 14:58:08 +0200 |
commit | ae22267afe6a82527449c08fd10a29d66fb39d8c (patch) | |
tree | 53ceedcc1f6bca4de1663fa6da24369fc9aa9ac6 | |
parent | 4dd0ca962c0875c3474feebeab3079aba1b17845 (diff) | |
download | ayatana-ido-ae22267afe6a82527449c08fd10a29d66fb39d8c.tar.gz ayatana-ido-ae22267afe6a82527449c08fd10a29d66fb39d8c.tar.bz2 ayatana-ido-ae22267afe6a82527449c08fd10a29d66fb39d8c.zip |
Use the grab-notify workaround only when using Gtk3
-rw-r--r-- | src/idorange.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/idorange.c b/src/idorange.c index 31d17ec..b11cb4e 100644 --- a/src/idorange.c +++ b/src/idorange.c @@ -40,8 +40,10 @@ static void ido_range_get_property (GObject *object, guint prop_id, GValue *value, GParamSpec *pspec); +#ifdef USE_GTK3 static void ido_range_grab_notify (GtkWidget *widget, gboolean was_grabbed); +#endif #define IDO_RANGE_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), IDO_TYPE_RANGE, IdoRangePrivate)) @@ -62,7 +64,9 @@ ido_range_class_init (IdoRangeClass *class) gobject_class->set_property = ido_range_set_property; gobject_class->get_property = ido_range_get_property; +#ifdef USE_GTK3 widget_class->grab_notify = ido_range_grab_notify; +#endif g_object_class_install_property (gobject_class, PROP_STYLE, @@ -134,11 +138,21 @@ ido_range_set_property (GObject *object, } } +#ifdef USE_GTK3 static void ido_range_grab_notify (GtkWidget *widget, gboolean was_grabbed) { + /* + * FIXME: workaround for lp bug #865122. + * Without this handler, GtkRange will call remove_grab which results + * in an infinite loop of grab_notifies. + * + * The widget will still work properly, because grab-broken-event will get + * properly fired and internal state of GtkRange will be properly updated. + */ g_return_if_fail (IDO_IS_RANGE (widget)); } +#endif static void ido_range_constructed (GObject *object) |