[icedtea-web] RFC: Patch to correct classloader sharing rules

Deepak Bhole dbhole at redhat.com
Mon Mar 28 10:50:34 PDT 2011


* Dr Andrew John Hughes <ahughes at redhat.com> [2011-03-28 13:27]:
> On 12:30 Mon 28 Mar     , Deepak Bhole wrote:
> > * Dr Andrew John Hughes <ahughes at redhat.com> [2011-03-25 20:43]:
> > > On 19:43 Fri 25 Mar     , Deepak Bhole wrote:
> > > > Hi,
> > > > 
> > > > Omair found a page earlier that specifies some rules on plugin classloader
> > > > sharing. Currently we share it based on site address -- attached patch fixes
> > > > that to do it as per the proprietary plugin rules:
> > > > http://download.oracle.com/javase/6/docs/technotes/guides/deployment/deployment-guide/applet-compatibility.html
> > > > 
> > > > ChangeLog:
> > > > 2011-03-25  Deepak Bhole <dbhole at redhat.com>
> > > > 
> > > >     * netx/net/sourceforge/jnlp/PluginBridge.java
> > > >     (PluginBridge): Construct unique key based on a combination of codebase, 
> > > >     cache_archive, java_archive, and archive. This automatically ensures are 
> > > >     loaders are shared only when appropriate.
> > > > 
> > > > Cheers,
> > > > Deepak
> > > 
> > > AFAICS, atts is a hashtable with generic types so the casts don't need to be there.
> > > 
> > 
> > Doh! Didn't even think to check for generics.. just went with old habit
> > of casting :/ Fixed now.
> > 
> > > Some of the lines seem too long.  I guess there isn't much that can be done
> > > with the URL, but the later comments and the String assignments could certainly
> > > be split.
> > > 
> > 
> > Fixed as well. New patch okay?
> > 
> > Cheers,
> > Deepak
> 
> Looks good, thanks.  Please commit.

Thanks for reviewing. Pushed.

Cheers,
Deepak

> 
> > diff -r 92486f15be36 netx/net/sourceforge/jnlp/PluginBridge.java
> > --- a/netx/net/sourceforge/jnlp/PluginBridge.java	Thu Mar 24 09:34:51 2011 -0400
> > +++ b/netx/net/sourceforge/jnlp/PluginBridge.java	Mon Mar 28 12:27:24 2011 -0400
> > @@ -132,10 +132,33 @@
> >          else
> >              security = null;
> >  
> > -        // Plugin needs to share classloaders so that applet instances from 
> > -        // same page can communicate (there are applets known to require 
> > -        // such communication for proper functionality)
> > -        this.uniqueKey = documentBase.toString();
> > +        /* According to http://download.oracle.com/javase/6/docs/technotes/guides/deployment/deployment-guide/applet-compatibility.html, 
> > +         * classloaders are shared iff these properties match:
> > +         * codebase, cache_archive, java_archive, archive
> > +         * 
> > +         * To achieve this, we create the uniquekey based on those 4 values,
> > +         * always in the same order. The initial "<NAME>=" parts ensure a 
> > +         * bad tag cannot trick the loader into getting shared with another.
> > +         */
> > +
> > +        // Firefox sometimes skips the codebase if it is default  -- ".", 
> > +        // so set it that way if absent
> > +        String codebaseAttr =      atts.get("codebase") != null ?
> > +                                   atts.get("codebase") : ".";
> > +
> > +        String cache_archiveAttr = atts.get("cache_archive") != null ? 
> > +                                   atts.get("cache_archive") : "";
> > +
> > +        String java_archiveAttr =  atts.get("java_archive") != null ? 
> > +                                   atts.get("java_archive") : "";
> > +
> > +        String archiveAttr =       atts.get("archive") != null ? 
> > +                                   atts.get("archive") : "";
> > +
> > +        this.uniqueKey = "codebase=" + codebaseAttr +
> > +                         "cache_archive=" + cache_archiveAttr + 
> > +                         "java_archive=" + java_archiveAttr + 
> > +                         "archive=" +  archiveAttr;
> >  
> >          usePack = false;
> >          useVersion = false;
> 
> 
> -- 
> Andrew :)
> 
> Free Java Software Engineer
> Red Hat, Inc. (http://www.redhat.com)
> 
> Support Free Java!
> Contribute to GNU Classpath and IcedTea
> http://www.gnu.org/software/classpath
> http://icedtea.classpath.org
> PGP Key: F5862A37 (https://keys.indymedia.org/)
> Fingerprint = EA30 D855 D50F 90CD F54D  0698 0713 C3ED F586 2A37



More information about the distro-pkg-dev mailing list