[RFC] netx: only create one instance of JNLPClassLoader for entire application

Omair Majid omajid at redhat.com
Thu Jul 8 11:18:16 PDT 2010


On 07/08/2010 01:56 PM, Deepak Bhole wrote:
> * Omair Majid<omajid at redhat.com>  [2010-07-08 09:59]:
>> Hi,
>>
>> The attached patch modifies the JNLPClassLoader so only one instance
>> of the loader is created per application. This patch also makes the
>> classloader keep track of each JNLP file and the resources it loads.
>> For applets, it only keeps track of the main applet JNLP (the
>> PluginBridge) and uses that.
>>
>> Any comments?
>>
>> Cheers,
>> Omair
>
> We already use a single classloader (by merging extension loader paths
> into the base loader)...
>
> What bug required this change?
>

We merge the paths, but lose all the other information. Consider this: 
anyplace where the current code does a file.foo(), we dont know which 
JNLPFile file actually is.

Also, this updated version (which knows about the main application JNLP 
and the extension JNLPs) will make it easier to implement the new cache 
for netx that I have been planning. During the application's startup, 
when the Jars are being downloaded and verified, we can ensure that all 
of the application's jars are treated the same way and we present a 
consistent cache to the application. In the current implementation 
sincle multiple classloaders are created, each JNLPClassLoader considres 
the jars individually for updates and caching.

Still, because of how this patch affects the ClassLoader, I would 
appreciate it people could test it out for a bit before it commit it.

Thanks,
Omair



More information about the distro-pkg-dev mailing list