aboutsummaryrefslogtreecommitdiff
path: root/src/macosx/classes/com/apple
diff options
context:
space:
mode:
authorchegar <none@none>2013-07-25 19:03:29 +0100
committerchegar <none@none>2013-07-25 19:03:29 +0100
commit264320f005dc1aac69078f8972ce14c31bc56ef6 (patch)
tree8aab15335e58ff4f1763a792874a2b9b7609bf86 /src/macosx/classes/com/apple
parente0d980f1838d94682e931c9c114a527ae4937269 (diff)
parent2e8e47214427bd90f15518c997278e103eea42c4 (diff)
Merge
Diffstat (limited to 'src/macosx/classes/com/apple')
-rw-r--r--src/macosx/classes/com/apple/eawt/FullScreenHandler.java3
-rw-r--r--src/macosx/classes/com/apple/eawt/_AppEventHandler.java100
-rw-r--r--src/macosx/classes/com/apple/eawt/event/GestureHandler.java4
-rw-r--r--src/macosx/classes/com/apple/laf/ScreenMenu.java9
4 files changed, 76 insertions, 40 deletions
diff --git a/src/macosx/classes/com/apple/eawt/FullScreenHandler.java b/src/macosx/classes/com/apple/eawt/FullScreenHandler.java
index f5a843bcd..64e81b08a 100644
--- a/src/macosx/classes/com/apple/eawt/FullScreenHandler.java
+++ b/src/macosx/classes/com/apple/eawt/FullScreenHandler.java
@@ -32,6 +32,7 @@ import java.util.List;
import javax.swing.RootPaneContainer;
import com.apple.eawt.AppEvent.FullScreenEvent;
+import sun.awt.SunToolkit;
import java.lang.annotation.Native;
@@ -75,7 +76,7 @@ final class FullScreenHandler {
static void handleFullScreenEventFromNative(final Window window, final int type) {
if (!(window instanceof RootPaneContainer)) return; // handles null
- EventQueue.invokeLater(new Runnable() {
+ SunToolkit.executeOnEventHandlerThread(window, new Runnable() {
public void run() {
final FullScreenHandler handler = getHandlerFor((RootPaneContainer)window);
if (handler != null) handler.notifyListener(new FullScreenEvent(window), type);
diff --git a/src/macosx/classes/com/apple/eawt/_AppEventHandler.java b/src/macosx/classes/com/apple/eawt/_AppEventHandler.java
index a380e8412..b98d57395 100644
--- a/src/macosx/classes/com/apple/eawt/_AppEventHandler.java
+++ b/src/macosx/classes/com/apple/eawt/_AppEventHandler.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -31,6 +31,8 @@ import java.io.File;
import java.net.*;
import java.util.*;
import java.util.List;
+import sun.awt.AppContext;
+import sun.awt.SunToolkit;
import com.apple.eawt.AppEvent.*;
@@ -269,11 +271,9 @@ class _AppEventHandler {
}
class _AppReOpenedDispatcher extends _AppEventMultiplexor<AppReOpenedListener> {
- void performOnListeners(final List<AppReOpenedListener> listeners, final _NativeEvent event) {
+ void performOnListener(AppReOpenedListener listener, final _NativeEvent event) {
final AppReOpenedEvent e = new AppReOpenedEvent();
- for (final AppReOpenedListener listener : listeners) {
- listener.appReOpened(e);
- }
+ listener.appReOpened(e);
}
}
@@ -415,50 +415,67 @@ class _AppEventHandler {
}
abstract class _AppEventMultiplexor<L> {
- final List<L> _listeners = new ArrayList<L>(0);
+ private final Map<L, AppContext> listenerToAppContext =
+ new IdentityHashMap<L, AppContext>();
boolean nativeListenerRegistered;
// called from AppKit Thread-0
void dispatch(final _NativeEvent event, final Object... args) {
- // grab a local ref to the listeners
- final List<L> localListeners;
+ // grab a local ref to the listeners and its contexts as an array of the map's entries
+ final ArrayList<Map.Entry<L, AppContext>> localEntries;
synchronized (this) {
- if (_listeners.size() == 0) return;
- localListeners = new ArrayList<L>(_listeners);
+ if (listenerToAppContext.size() == 0) {
+ return;
+ }
+ localEntries = new ArrayList<Map.Entry<L, AppContext>>(listenerToAppContext.size());
+ localEntries.addAll(listenerToAppContext.entrySet());
}
- EventQueue.invokeLater(new Runnable() {
- public void run() {
- performOnListeners(localListeners, event);
- }
- });
+ for (final Map.Entry<L, AppContext> e : localEntries) {
+ final L listener = e.getKey();
+ final AppContext listenerContext = e.getValue();
+ SunToolkit.invokeLaterOnAppContext(listenerContext, new Runnable() {
+ public void run() {
+ performOnListener(listener, event);
+ }
+ });
+ }
}
synchronized void addListener(final L listener) {
+ setListenerContext(listener, AppContext.getAppContext());
+
if (!nativeListenerRegistered) {
registerNativeListener();
nativeListenerRegistered = true;
}
- _listeners.add(listener);
}
synchronized void removeListener(final L listener) {
- _listeners.remove(listener);
+ listenerToAppContext.remove(listener);
}
- abstract void performOnListeners(final List<L> listeners, final _NativeEvent event);
+ abstract void performOnListener(L listener, final _NativeEvent event);
void registerNativeListener() { }
+
+ private void setListenerContext(L listener, AppContext listenerContext) {
+ if (listenerContext == null) {
+ throw new RuntimeException(
+ "Attempting to add a listener from a thread group without AppContext");
+ }
+ listenerToAppContext.put(listener, AppContext.getAppContext());
+ }
}
abstract class _BooleanAppEventMultiplexor<L, E> extends _AppEventMultiplexor<L> {
@Override
- void performOnListeners(final List<L> listeners, final _NativeEvent event) {
+ void performOnListener(L listener, final _NativeEvent event) {
final boolean isTrue = Boolean.TRUE.equals(event.get(0));
final E e = createEvent(isTrue);
if (isTrue) {
- for (final L listener : listeners) performTrueEventOn(listener, e);
+ performTrueEventOn(listener, e);
} else {
- for (final L listener : listeners) performFalseEventOn(listener, e);
+ performFalseEventOn(listener, e);
}
}
@@ -479,30 +496,34 @@ class _AppEventHandler {
*/
abstract class _AppEventDispatcher<H> {
H _handler;
+ AppContext handlerContext;
// called from AppKit Thread-0
void dispatch(final _NativeEvent event) {
- EventQueue.invokeLater(new Runnable() {
- public void run() {
- // grab a local ref to the handler
- final H localHandler;
- synchronized (_AppEventDispatcher.this) {
- localHandler = _handler;
- }
+ // grab a local ref to the handler
+ final H localHandler;
+ final AppContext localHandlerContext;
+ synchronized (_AppEventDispatcher.this) {
+ localHandler = _handler;
+ localHandlerContext = handlerContext;
+ }
- // invoke the handler outside of the synchronized block
- if (localHandler == null) {
- performDefaultAction(event);
- } else {
+ if (localHandler == null) {
+ performDefaultAction(event);
+ } else {
+ SunToolkit.invokeLaterOnAppContext(localHandlerContext, new Runnable() {
+ public void run() {
performUsing(localHandler, event);
}
- }
- });
+ });
+ }
}
synchronized void setHandler(final H handler) {
this._handler = handler;
+ setHandlerContext(AppContext.getAppContext());
+
// if a new handler is installed, block addition of legacy ApplicationListeners
if (handler == legacyHandler) return;
legacyHandler.blockLegacyAPI();
@@ -510,6 +531,15 @@ class _AppEventHandler {
void performDefaultAction(final _NativeEvent event) { } // by default, do nothing
abstract void performUsing(final H handler, final _NativeEvent event);
+
+ protected void setHandlerContext(AppContext ctx) {
+ if (ctx == null) {
+ throw new RuntimeException(
+ "Attempting to set a handler from a thread group without AppContext");
+ }
+
+ handlerContext = ctx;
+ }
}
abstract class _QueuingAppEventDispatcher<H> extends _AppEventDispatcher<H> {
@@ -531,6 +561,8 @@ class _AppEventHandler {
synchronized void setHandler(final H handler) {
this._handler = handler;
+ setHandlerContext(AppContext.getAppContext());
+
// dispatch any events in the queue
if (queuedEvents != null) {
// grab a local ref to the queue, so the real one can be nulled out
diff --git a/src/macosx/classes/com/apple/eawt/event/GestureHandler.java b/src/macosx/classes/com/apple/eawt/event/GestureHandler.java
index 1378a2c80..4514da90c 100644
--- a/src/macosx/classes/com/apple/eawt/event/GestureHandler.java
+++ b/src/macosx/classes/com/apple/eawt/event/GestureHandler.java
@@ -25,6 +25,8 @@
package com.apple.eawt.event;
+import sun.awt.SunToolkit;
+
import java.awt.*;
import java.util.*;
import java.util.List;
@@ -70,7 +72,7 @@ final class GestureHandler {
static void handleGestureFromNative(final Window window, final int type, final double x, final double y, final double a, final double b) {
if (window == null) return; // should never happen...
- EventQueue.invokeLater(new Runnable() {
+ SunToolkit.executeOnEventHandlerThread(window, new Runnable() {
public void run() {
final Component component = SwingUtilities.getDeepestComponentAt(window, (int)x, (int)y);
diff --git a/src/macosx/classes/com/apple/laf/ScreenMenu.java b/src/macosx/classes/com/apple/laf/ScreenMenu.java
index 23c55c8d2..5f78ff6e0 100644
--- a/src/macosx/classes/com/apple/laf/ScreenMenu.java
+++ b/src/macosx/classes/com/apple/laf/ScreenMenu.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -32,6 +32,7 @@ import java.util.Hashtable;
import javax.swing.*;
+import sun.awt.SunToolkit;
import sun.lwawt.LWToolkit;
import sun.lwawt.macosx.*;
@@ -144,7 +145,7 @@ class ScreenMenu extends Menu implements ContainerListener, ComponentListener, S
updateItems();
fItemBounds = new Rectangle[invoker.getMenuComponentCount()];
}
- }, null);
+ }, invoker);
} catch (final Exception e) {
System.err.println(e);
e.printStackTrace();
@@ -172,7 +173,7 @@ class ScreenMenu extends Menu implements ContainerListener, ComponentListener, S
fItemBounds = null;
}
- }, null);
+ }, invoker);
} catch (final Exception e) {
e.printStackTrace();
}
@@ -200,7 +201,7 @@ class ScreenMenu extends Menu implements ContainerListener, ComponentListener, S
if (kind == 0) return;
if (fItemBounds == null) return;
- SwingUtilities.invokeLater(new Runnable() {
+ SunToolkit.executeOnEventHandlerThread(fInvoker, new Runnable() {
@Override
public void run() {
Component target = null;