/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @author Michael Danilov, Pavel Dolgov
* @version $Revision$
*/
package java.awt;
import org.apache.harmony.awt.wtk.NativeEvent;
import org.apache.harmony.awt.wtk.NativeEventQueue;
class EventDispatchThread extends Thread {
private static final class MarkerEvent extends AWTEvent {
MarkerEvent(Object source, int id) {
super(source, id);
}
}
final Dispatcher dispatcher;
final Toolkit toolkit;
private NativeEventQueue nativeQueue;
protected volatile boolean shutdownPending = false;
/**
* Initialise and run the main event loop
*/
@Override
public void run() {
nativeQueue = toolkit.getNativeEventQueue();
try {
runModalLoop(null);
} finally {
toolkit.shutdownWatchdog.forceShutdown();
}
}
void runModalLoop(ModalContext context) {
long lastPaintTime = System.currentTimeMillis();
while (!shutdownPending && (context == null || context.isModalLoopRunning())) {
try {
EventQueue eventQueue = toolkit.getSystemEventQueueImpl();
NativeEvent ne = nativeQueue.getNextEvent();
if (ne != null) {
dispatcher.onEvent(ne);
MarkerEvent marker = new MarkerEvent(this, 0);
eventQueue.postEvent(marker);
for (AWTEvent ae = eventQueue.getNextEventNoWait();
(ae != null) && (ae != marker);
ae = eventQueue.getNextEventNoWait()) {
eventQueue.dispatchEvent(ae);
}
} else {
toolkit.shutdownWatchdog.setNativeQueueEmpty(true);
AWTEvent ae = eventQueue.getNextEventNoWait();
if (ae != null) {
eventQueue.dispatchEvent(ae);
long curTime = System.currentTimeMillis();
if (curTime - lastPaintTime > 10) {
toolkit.onQueueEmpty();
lastPaintTime = System.currentTimeMillis();
}
} else {
toolkit.shutdownWatchdog.setAwtQueueEmpty(true);
toolkit.onQueueEmpty();
lastPaintTime = System.currentTimeMillis();
waitForAnyEvent();
}
}
} catch (Throwable t) {
// TODO: Exception handler should be implemented
// t.printStackTrace();
}
}
}
private void waitForAnyEvent() {
EventQueue eventQueue = toolkit.getSystemEventQueueImpl();
if (!eventQueue.isEmpty() || !nativeQueue.isEmpty()) {
return;
}
Object eventMonitor = nativeQueue.getEventMonitor();
synchronized(eventMonitor) {
try {
eventMonitor.wait();
} catch (InterruptedException e) {}
}
}
void shutdown() {
shutdownPending = true;
}
EventDispatchThread(Toolkit toolkit, Dispatcher dispatcher ) {
this.toolkit = toolkit;
this.dispatcher = dispatcher;
setName("AWT-EventDispatchThread"); //$NON-NLS-1$
setDaemon(true);
}
}
|