[rfc][icedtea-web] policytool in itweb-settings
Andrew Azores
aazores at redhat.com
Fri Jan 17 13:08:23 PST 2014
On 01/17/2014 11:52 AM, Jiri Vanek wrote:
>> This is why I was launching PolicyTool in a new process in the first
>> place, actually. In all its
>> wisdom, PolicyTool exits the JVM when its window closes.
>
> It should not be so hard -
> By refelction get 'tw' field, and remove the only (nasty words)
> WindowListener it have - the one responsible for system.exit and
> nothing else:-/
>
> Unluckily, this listener is added in
> PolicyTool.main in tw.displayToolWindow(args);
>
> So you have to work on it a bit more. But again, nothing hard, and no
> copy pasting;)
>
> Not sure if we will backport this, but probably yes.. Depends on final
> compelxiity.
'tw' isn't a field though, it's just a local variable within main(), so
we can't just grab it via reflection.
I've got the hackiest hack ever with reflection to get around this, and
it is *seriously* ugly. System.exit(0) is also called by PolicyTool
indirectly in other places. I've removed the ToolWindowListener so that
hitting the window close button on PolicyTool doesn't exit the JVM, but
File>Exit still exits the JVM. This case comes from
ToolDialog#userSaveContinue I believe, and I don't see a way to work
around this, really. We're going to need to do some extend/override
voodoo to get rid of this, unless we start introducing runtime code
injection/modification in itweb-settings control panel :) either that,
or get some patches into the JDK to fix PolicyTool.
The attached patch is the super crazy ugly hack that at least makes the
window close button behave nicely, but I feel like a monster for even
having written this. Be warned.
Oh, and try this - launch itweb-settings from terminal. Open policytool
from itweb-settings. Close policytool with the window close button.
Press Ok in itweb-settings. The itweb-settings process doesn't even
exit! Wonderful! I'm not really sure what's keeping it open.
Something else I noticed while testing this is that policytool prompts
you if you want to save your changes if you select File>Exit, but simply
closing the window does not prompt you. This is without the reflection
patch applied. Ugh. PolicyTool is really in need of a serious overhaul...
> ok. Ok to head, and please elaborate on backport to 1.4 it is worthy.
> Also please fix the closing of window asap (as new chngeset)
>
>
> Good work!
> J.
1.4 doesn't have DirectoryValidator... what should we do here then? Also
backport DirectoryValidator? Or just let the 1.4 backport have less of a
guarantee that the policy tool will be able to successfully launch, and
try to provide useful errors if not?
Thanks,
--
Andrew A
-------------- next part --------------
A non-text attachment was scrubbed...
Name: custompolicy-incredible-hack.diff
Type: text/x-patch
Size: 5435 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20140117/f2cf7d29/custompolicy-incredible-hack.diff
More information about the distro-pkg-dev
mailing list