/hg/release/icedtea6-1.6: Force Event Dispatch Thread to always ...

mwong at icedtea.classpath.org mwong at icedtea.classpath.org
Fri Jul 30 13:37:42 PDT 2010


changeset 6aee53732aa2 in /hg/release/icedtea6-1.6
details: http://icedtea.classpath.org/hg/release/icedtea6-1.6?cmd=changeset;node=6aee53732aa2
author: Man Lung Wong <mwong at redhat.com>
date: Fri Jul 30 16:37:21 2010 -0400

	Force Event Dispatch Thread to always get created so its
	contextclassloader will be set properly.


diffstat:

3 files changed, 19 insertions(+), 36 deletions(-)
ChangeLog                                                |   12 ++++
rt/net/sourceforge/jnlp/Launcher.java                    |    7 ++
rt/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java |   36 --------------

diffs (98 lines):

diff -r f96b5fc36263 -r 6aee53732aa2 ChangeLog
--- a/ChangeLog	Mon Jul 26 23:38:19 2010 +0100
+++ b/ChangeLog	Fri Jul 30 16:37:21 2010 -0400
@@ -1,3 +1,15 @@ 2010-07-26  Andrew John Hughes  <ahughes
+2010-07-30  Man Lung Wong  <mwong at redhat.com>
+	* netx/net/sourceforge/jnlp/Launcher.java
+	(launchApplication): Make sure an Event Dispatch Thread
+	is created before contextclassloader gets set.
+	* netx/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java
+	(ContextUpdater): Removed it as it is no longer useful after
+	the above change.
+	(checkTopLevelWindow): Removed the line that adds
+	ContextUpdater as it no longer exists.
+	* NEWS: This fixes one of the problems launching the link
+	mentioned in icedtea bug 486.
+	
 2010-07-26  Andrew John Hughes  <ahughes at redhat.com>
 
 	* NEWS: Set date of 1.6.3 release.
diff -r f96b5fc36263 -r 6aee53732aa2 rt/net/sourceforge/jnlp/Launcher.java
--- a/rt/net/sourceforge/jnlp/Launcher.java	Mon Jul 26 23:38:19 2010 +0100
+++ b/rt/net/sourceforge/jnlp/Launcher.java	Fri Jul 30 16:37:21 2010 -0400
@@ -42,6 +42,8 @@ import net.sourceforge.jnlp.services.Ins
 import net.sourceforge.jnlp.services.InstanceExistsException;
 import net.sourceforge.jnlp.services.ServiceUtil;
 import net.sourceforge.jnlp.util.Reflect;
+
+import javax.swing.SwingUtilities;
 
 /**
  * Launches JNLPFiles either in the foreground or background.<p>
@@ -426,6 +428,11 @@ public class Launcher {
 
             Method main = mainClass.getDeclaredMethod("main", new Class[] {String[].class} );
             String args[] = file.getApplication().getArguments();
+            
+            SwingUtilities.invokeAndWait(new Runnable() {
+                // dummy method to force Event Dispatch Thread creation
+                public void run(){}
+            });
 
             setContextClassLoaderForAllThreads(app.getClassLoader());
 
diff -r f96b5fc36263 -r 6aee53732aa2 rt/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java
--- a/rt/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java	Mon Jul 26 23:38:19 2010 +0100
+++ b/rt/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java	Fri Jul 30 16:37:21 2010 -0400
@@ -101,42 +101,8 @@ class JNLPSecurityManager extends Securi
     /** weak reference to most app who's windows was most recently activated */
     private WeakReference activeApplication = null;
 
-    /** listener installs the app's classloader on the event dispatch thread */
-    private ContextUpdater contextListener = new ContextUpdater();
-    
     /** Sets whether or not exit is allowed (in the context of the plugin, this is always false) */
     private boolean exitAllowed = true;
-
-    private class ContextUpdater extends WindowAdapter implements PrivilegedAction {
-        private ApplicationInstance app = null;
-
-        public void windowActivated(WindowEvent e) {
-            app = getApplication(e.getWindow());
-            AccessController.doPrivileged(this);
-            app = null;
-        }
-
-        public Object run() {
-            if (app != null) {
-                Thread.currentThread().setContextClassLoader(app.getClassLoader());
-                activeApplication = new WeakReference(app);
-            }
-            else
-                Thread.currentThread().setContextClassLoader(this.getClass().getClassLoader());
-
-            return null;
-        }
-
-        public void windowDeactivated(WindowEvent e) {
-            activeApplication = null;
-        }
-        
-        public void windowClosing(WindowEvent e) {
-        	System.err.println("Disposing window");
-        	e.getWindow().dispose();
-        }
-    };
-
 
     /**
      * Creates a JNLP SecurityManager.
@@ -410,8 +376,6 @@ class JNLPSecurityManager extends Securi
             weakWindows.add(window); // for mapping window -> app
             weakApplications.add(app);
 
-            w.addWindowListener(contextListener); // for dynamic context classloader
-
             app.addWindow(w);
         }
 



More information about the distro-pkg-dev mailing list