summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2013-02-22 18:14:30 +0000
committerDavid Robillard <d@drobilla.net>2013-02-22 18:14:30 +0000
commit61a8166c4fda5e3486ae9d19ff102e36a14bfcb0 (patch)
treeeb19360d8ea5be0e266b55453a375c45c1942ee3 /src
parent701cc9265c3958473e2dc20e62da6c82890b2cd0 (diff)
downloadsuil-61a8166c4fda5e3486ae9d19ff102e36a14bfcb0.tar.gz
suil-61a8166c4fda5e3486ae9d19ff102e36a14bfcb0.tar.bz2
suil-61a8166c4fda5e3486ae9d19ff102e36a14bfcb0.zip
Maybe fix crash on close caused by key filter for X11 in Gtk.
git-svn-id: http://svn.drobilla.net/lad/trunk/suil@5063 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src')
-rw-r--r--src/x11_in_gtk2.c39
1 files changed, 22 insertions, 17 deletions
diff --git a/src/x11_in_gtk2.c b/src/x11_in_gtk2.c
index 2e3cdf9..0adc408 100644
--- a/src/x11_in_gtk2.c
+++ b/src/x11_in_gtk2.c
@@ -42,11 +42,33 @@ GType suil_x11_wrapper_get_type(void); // Accessor for SUIL_TYPE_X11_WRAPPER
G_DEFINE_TYPE(SuilX11Wrapper, suil_x11_wrapper, GTK_TYPE_SOCKET)
+#ifdef SUIL_FORWARD_KEYS
+static GdkFilterReturn
+event_filter(GdkXEvent* xevent, GdkEvent* event, gpointer data)
+{
+ SuilX11Wrapper* wrap = (SuilX11Wrapper*)data;
+ XEvent* ev = (XEvent*)xevent;
+ if (wrap->instance &&
+ wrap->instance->handle &&
+ (ev->type == KeyPress || ev->type == KeyRelease)) {
+ // Forward keyboard events to UI window
+ XSendEvent(ev->xkey.display, (Window)wrap->instance->ui_widget, 1, 0, ev);
+ XSync(ev->xkey.display, TRUE);
+ }
+ return GDK_FILTER_CONTINUE;
+}
+#endif
+
static gboolean
on_plug_removed(GtkSocket* sock, gpointer data)
{
SuilX11Wrapper* const self = SUIL_X11_WRAPPER(sock);
+#ifdef SUIL_FORWARD_KEYS
+ GdkWindow* window = gtk_widget_get_window(GTK_WIDGET(self));
+ gdk_window_remove_filter(window, event_filter, self);
+#endif
+
if (self->instance->handle) {
self->instance->descriptor->cleanup(self->instance->handle);
self->instance->handle = NULL;
@@ -130,23 +152,6 @@ wrapper_free(SuilWrapper* wrapper)
}
}
-#ifdef SUIL_FORWARD_KEYS
-static GdkFilterReturn
-event_filter(GdkXEvent* xevent, GdkEvent* event, gpointer data)
-{
- SuilX11Wrapper* wrap = (SuilX11Wrapper*)data;
- XEvent* ev = (XEvent*)xevent;
- if (wrap->instance &&
- wrap->instance->handle &&
- (ev->type == KeyPress || ev->type == KeyRelease)) {
- // Forward keyboard events to UI window
- XSendEvent(ev->xkey.display, (Window)wrap->instance->ui_widget, 1, 0, ev);
- XSync(ev->xkey.display, TRUE);
- }
- return GDK_FILTER_CONTINUE;
-}
-#endif
-
SUIL_LIB_EXPORT
SuilWrapper*
suil_wrapper_new(SuilHost* host,