78
|
1 /*******************************************************************************
|
|
2 * Copyright (c) 2006, 2008 IBM Corporation and others.
|
|
3 * All rights reserved. This program and the accompanying materials
|
|
4 * are made available under the terms of the Eclipse Public License v1.0
|
|
5 * which accompanies this distribution, and is available at
|
|
6 * http://www.eclipse.org/legal/epl-v10.html
|
|
7 *
|
|
8 * Contributors:
|
|
9 * IBM Corporation - initial API and implementation
|
|
10 *******************************************************************************/
|
|
11 module org.eclipse.jface.internal.databinding.provisional.swt.SWTUtil;
|
|
12
|
|
13 import java.lang.all;
|
|
14
|
|
15 import java.util.HashMap;
|
|
16 import java.util.Map;
|
|
17
|
|
18 import org.eclipse.jface.util.SafeRunnable;
|
|
19 import org.eclipse.swt.graphics.RGB;
|
|
20 import org.eclipse.swt.widgets.Display;
|
|
21
|
|
22 /**
|
|
23 * NON-API - Utility methods, mainly having to do with posting runnables to the UI thread
|
|
24 * in a particular way.
|
|
25 * @since 1.1
|
|
26 *
|
|
27 */
|
|
28 public class SWTUtil {
|
|
29 /**
|
|
30 * Stores a work queue for each display
|
|
31 */
|
|
32 private static Map mapDisplayOntoWorkQueue = new HashMap();
|
|
33
|
|
34 private this() {
|
|
35 }
|
|
36
|
|
37 /**
|
|
38 * Runs the given runnable on the given display as soon as possible. If
|
|
39 * possible, the runnable will be executed before the next widget is
|
|
40 * repainted, but this behavior is not guaranteed. Use this method to
|
|
41 * schedule work will affect the way one or more widgets are drawn.
|
|
42 *
|
|
43 * <p>
|
|
44 * This is threadsafe.
|
|
45 * </p>
|
|
46 *
|
|
47 * @param d
|
|
48 * display
|
|
49 * @param r
|
|
50 * runnable to execute in the UI thread.
|
|
51 */
|
|
52 public static void greedyExec(Display d, Runnable r) {
|
|
53 if (d.isDisposed()) {
|
|
54 return;
|
|
55 }
|
|
56
|
|
57 // if (Display.getCurrent() is d) {
|
|
58 // r.run();
|
|
59 // } else {
|
|
60 WorkQueue queue = getQueueFor(d);
|
|
61 queue.asyncExec(r);
|
|
62 // }
|
|
63 }
|
|
64
|
|
65 /**
|
|
66 * Runs the given runnable on the given display as soon as possible. Unlike
|
|
67 * greedyExec, this has no effect if the given runnable has already been
|
|
68 * scheduled for execution. Use this method to schedule work that will
|
|
69 * affect the way one or more wigdets are drawn, but that should only happen
|
|
70 * once.
|
|
71 *
|
|
72 * <p>
|
|
73 * This is threadsafe.
|
|
74 * </p>
|
|
75 *
|
|
76 * @param d
|
|
77 * display
|
|
78 * @param r
|
|
79 * runnable to execute in the UI thread. Has no effect if the
|
|
80 * given runnable has already been scheduled but has not yet run.
|
|
81 */
|
|
82 public static void runOnce(Display d, Runnable r) {
|
|
83 if (d.isDisposed()) {
|
|
84 return;
|
|
85 }
|
|
86 WorkQueue queue = getQueueFor(d);
|
|
87 queue.runOnce(r);
|
|
88 }
|
|
89
|
|
90 /**
|
|
91 * Cancels a greedyExec or runOnce that was previously scheduled on the
|
|
92 * given display. Has no effect if the given runnable is not in the queue
|
|
93 * for the given display
|
|
94 *
|
|
95 * @param d
|
|
96 * target display
|
|
97 * @param r
|
|
98 * runnable to execute
|
|
99 */
|
|
100 public static void cancelExec(Display d, Runnable r) {
|
|
101 if (d.isDisposed()) {
|
|
102 return;
|
|
103 }
|
|
104 WorkQueue queue = getQueueFor(d);
|
|
105 queue.cancelExec(r);
|
|
106 }
|
|
107
|
|
108 /**
|
|
109 * Returns the work queue for the given display. Creates a work queue if
|
|
110 * none exists yet.
|
|
111 *
|
|
112 * @param d
|
|
113 * display to return queue for
|
|
114 * @return a work queue (never null)
|
|
115 */
|
|
116 private static WorkQueue getQueueFor(Display d) {
|
|
117 WorkQueue result;
|
|
118 synchronized (mapDisplayOntoWorkQueue) {
|
|
119 // Look for existing queue
|
|
120 result = cast(WorkQueue) mapDisplayOntoWorkQueue.get(d);
|
|
121
|
|
122 if (result is null) {
|
|
123 // If none, create new queue
|
|
124 result = new WorkQueue(d);
|
|
125 final WorkQueue q = result;
|
|
126 mapDisplayOntoWorkQueue.put(d, result);
|
|
127 d.asyncExec(dgRunnable( (Display d_) {
|
|
128 d_.disposeExec(new class() Runnable {
|
|
129 public void run() {
|
|
130 synchronized (mapDisplayOntoWorkQueue) {
|
|
131 q.cancelAll();
|
|
132 mapDisplayOntoWorkQueue.remove(d_);
|
|
133 }
|
|
134 }
|
|
135 });
|
|
136 }, d));
|
|
137 }
|
|
138 return result;
|
|
139 }
|
|
140 }
|
|
141
|
|
142 /**
|
|
143 * @param rgb1
|
|
144 * @param rgb2
|
|
145 * @param ratio
|
|
146 * @return the RGB object
|
|
147 */
|
|
148 public static RGB mix(RGB rgb1, RGB rgb2, double ratio) {
|
|
149 return new RGB(interp(rgb1.red, rgb2.red, ratio),
|
|
150 interp(rgb1.green, rgb2.green, ratio),
|
|
151 interp(rgb1.blue, rgb2.blue, ratio));
|
|
152 }
|
|
153
|
|
154 private static int interp(int i1, int i2, double ratio) {
|
|
155 int result = cast(int)(i1 * ratio + i2 * (1.0 - ratio));
|
|
156 if (result < 0) result = 0;
|
|
157 if (result > 255) result = 255;
|
|
158 return result;
|
|
159 }
|
|
160
|
|
161 /**
|
|
162 * Logs an exception as though it was thrown by a SafeRunnable being run
|
|
163 * with the default ISafeRunnableRunner. Will not open modal dialogs or spin
|
|
164 * the event loop.
|
|
165 *
|
|
166 * @param t
|
|
167 * throwable to log
|
|
168 * @deprecated
|
|
169 * @noreference This method is not intended to be referenced by clients. It
|
|
170 * remains here for API backwards compatibility.
|
|
171 */
|
|
172 public static void logException(Exception t) {
|
|
173 SafeRunnable.run(new class(t) SafeRunnable {
|
|
174 Exception t_;
|
|
175 this(Exception a){ t_=a; }
|
|
176 public void run() {
|
|
177 throw t_;
|
|
178 }
|
|
179 public void handleException(Throwable e) {
|
|
180 // IMPORTANT: Do not call the super implementation, since
|
|
181 // it opens a modal dialog, and may cause *syncExecs to run
|
|
182 // too early.
|
|
183 }
|
|
184 });
|
|
185 }
|
|
186
|
|
187 }
|