diff options
author | Bogdan Gheorghe <gheorghe@ca.ibm.com> | 2012-08-08 17:35:58 -0400 |
---|---|---|
committer | Bogdan Gheorghe <gheorghe@ca.ibm.com> | 2012-08-08 17:36:32 -0400 |
commit | b84a972a97895b84f13dc7405df20866130f726b (patch) | |
tree | 5c4cc4b769850bd355eb8bd33db0e2fa8c82aa4e /bundles/org.eclipse.swt/Eclipse SWT/gtk/org/eclipse/swt | |
parent | a61caa1cfed4d2ec7b9bccff2e9d74f32593118d (diff) | |
download | eclipse.platform.swt-b84a972a97895b84f13dc7405df20866130f726b.tar.gz eclipse.platform.swt-b84a972a97895b84f13dc7405df20866130f726b.tar.xz eclipse.platform.swt-b84a972a97895b84f13dc7405df20866130f726b.zip |
Bug 379590 - Run event loop while Tracker is up
Diffstat (limited to 'bundles/org.eclipse.swt/Eclipse SWT/gtk/org/eclipse/swt')
-rw-r--r-- | bundles/org.eclipse.swt/Eclipse SWT/gtk/org/eclipse/swt/widgets/Tracker.java | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/bundles/org.eclipse.swt/Eclipse SWT/gtk/org/eclipse/swt/widgets/Tracker.java b/bundles/org.eclipse.swt/Eclipse SWT/gtk/org/eclipse/swt/widgets/Tracker.java index af86c4f365..9d16684e8f 100644 --- a/bundles/org.eclipse.swt/Eclipse SWT/gtk/org/eclipse/swt/widgets/Tracker.java +++ b/bundles/org.eclipse.swt/Eclipse SWT/gtk/org/eclipse/swt/widgets/Tracker.java @@ -709,14 +709,18 @@ public boolean open () { /* Tracker behaves like a Dialog with its own OS event loop. */ GdkEvent gdkEvent = new GdkEvent(); + Display display = this.display; while (tracking) { if (parent != null && parent.isDisposed ()) break; int /*long*/ eventPtr; while (true) { + display.runSkin (); + display.runDeferredLayouts (); eventPtr = OS.gdk_event_get (); if (eventPtr != 0) { break; } else { + display.runAsyncMessages (false); try { Thread.sleep(50); } catch (Exception ex) {} } } @@ -744,6 +748,7 @@ public boolean open () { OS.gtk_main_do_event (eventPtr); } OS.gdk_event_free (eventPtr); + display.runAsyncMessages (false); } if (!isDisposed ()) { update (); |