[RFC] Netx: setting context classloader properly for all threads
Man Wong
mwong at redhat.com
Fri Jul 30 13:40:12 PDT 2010
----- "Deepak Bhole" <dbhole at redhat.com> wrote:
> * Man Wong <mwong at redhat.com> [2010-07-29 14:23]:
> > This patch forces the creation of Event Awt thread before the
> thread
> > launching the application sets the contextclassloader for itself,
> > and its child(ren). This essentially make sure Event Awt thread
> gets
> > the correct contextclassloader.
> >
> > It also fixes along with changesets
> > 4bcc2702e0ec and 867af494861c the issue with launching the set of
> > simulation applications mentioned in icedtea bug 486 (which
> > effectively allows us to close that bug).
> >
> > Ok to push?
> >
>
> Looks good. Please go ahead and commit to HEAD, 1.6, 1.7 and 1.8.
>
Committed as:
6aee53732aa2 - 1.6
9e75f57aae29 - 1.7
846a4c007c96 - 1.8
4bd31caf5e07 - head
Thanks,
Man Lung Wong
> Cheers,
> Deepak
>
> > Thanks,
> > Man Lung Wong
>
> > diff -r dd4d9f50ac7c netx/net/sourceforge/jnlp/Launcher.java
> > --- a/netx/net/sourceforge/jnlp/Launcher.java Mon Jul 26 09:38:47
> 2010 +0100
> > +++ b/netx/net/sourceforge/jnlp/Launcher.java Tue Jul 27 17:08:46
> 2010 -0400
> > @@ -42,6 +42,8 @@
> > 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>
> > *
> > @@ -442,6 +444,11 @@
> > 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.getThreadGroup(),
> app.getClassLoader());
> >
> > if (splashScreen != null) {
> > diff -r dd4d9f50ac7c
> netx/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java
> > --- a/netx/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java Mon
> Jul 26 09:38:47 2010 +0100
> > +++ b/netx/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java Tue
> Jul 27 17:08:46 2010 -0400
> > @@ -104,43 +104,9 @@
> > /** 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.
> > */
> > @@ -524,8 +490,6 @@
> > 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