[icedtea-web] RFC: Patch to support plugin classloader sharing
Omair Majid
omajid at redhat.com
Fri Mar 4 14:16:48 PST 2011
On 03/04/2011 05:09 PM, Deepak Bhole wrote:
> * Omair Majid<omajid at redhat.com> [2011-03-04 16:56]:
>> On 03/04/2011 03:55 PM, Deepak Bhole wrote:
> <snip>
>>>
>>
>> Just to summarize (and to make sure I understand this): the key here
>> is to create another ClassLoader. This ClassLoader only contains the
>> codebase (can there be more than one?) and is only used as a last
>> resort. This avoids contacting the server needlessly.
>>
>
> Yep, that is absolutely correct!
>
>>> ChangeLog:
>>> 2011-03-04 Deepak Bhole<dbhole at redhat.com>
>>>
> <snip>
>>> + baseLoader.merge(loader);
>>> + }
>>> loader = baseLoader;
>>> }
>>>
>>
>> This logic is getting quite convoluted. What's the purpose of this
>> hunk (and the one before this)?
>>
>
> Yeah I am not a big fan of it either, but the else was necessary.
>
> The original if says:
>
> <If there is no loader or the loader with the same key as this one is for
> another JNLP file>:
>
> 1. Create a new loader (CL)
> 2. Creation of CL may create additional extension loaders (jnlps can have
> exts), so if any were created, ccumulate those, and merge it all into one.
>
> The above logic is only valid for JNLPs, as plugins have no concept of
> extension loaders. Even for applets from the same page, creation of the
> initial loader does no trigger any additional loader creation. So I
> added an else logic which says:
>
Hm... I wonder how (or if, even) the code handles plugins using JNLP
extensions. AFAIK that's how JavaFX applets (do those exist any more?
:P) run.
> Else, if loader for given key (page) is not null:
> 1. Create a new loader for this applet
> 2. Merge contents of new loader into existing loader that exists for this
> page
>
Was there an actual problem being caused by this? If the existing code
working, then why are we changing it now?
>
> I think the "or the loader with the same key..." condition can probably be
> removed, but it is outside the scope of this patch. I will take a look
> at it later.
>
Good idea.
>>> @@ -529,7 +541,7 @@
>>> * loaded from the codebase are not cached.
>>> */
>>> public void enableCodeBase() {
> <snip>
>>> + }
>>> + }
>>
>> Much better than those crazy reflection calls :)
>>
>
> :)
>
>>> }
>>> diff -r 64b9d3a8239c netx/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java
>>> --- a/netx/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java Thu Mar 03 17:56:00 2011 -0500
>
> <snip>
>>> +++ b/netx/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java Fri Mar 04 15:46:36 2011 -0500
>>> @@ -199,8 +199,16 @@
>>> appletPanels.removeElement(p);
>>
>> Other than the change in JNLPClassLoader.getInstance, this looks fine.
>>
>
> Great, thanks for reviewing this so quickly!
>
No problem.
Cheers,
Omair
More information about the distro-pkg-dev
mailing list