[RFC][icedtea-web]: Adding control panel to icedtea-web
Andrew Su
asu at redhat.com
Fri Nov 26 14:29:21 PST 2010
----- "Omair Majid" <omajid at redhat.com> wrote:
> From: "Omair Majid" <omajid at redhat.com>
> To: "Andrew Su" <asu at redhat.com>
> Cc: distro-pkg-dev at openjdk.java.net
> Sent: Friday, November 26, 2010 4:49:22 PM GMT -05:00 US/Canada Eastern
> Subject: Re: [RFC][icedtea-web]: Adding control panel to icedtea-web
>
> On 11/26/2010 04:11 PM, Andrew Su wrote:
> > Hello,
> >
> > I have attached a patch to add a control panel for icedtea-web. This
> can be used to modify deployments.properties.
> >
> > Current features:
> > - Enable/Disable caching.
> > - Set cache location.
> > - Set max space cache may use. (in MB)
> > - Set compression level of jar files.
> > - Import/View/Export/Remove certificates.
> > - Turn tracing on/off.
> > - Turn debugging on/off.
> > - Set behaviour of Java Console.
> > - Set whether to create desktop shortcut for javaws or not.
> > - Set proxy settings.
> > - Set how security warning behaviours.
> >
> > ChangeLog:
> >
> > * Makefile.am:
> > (CONTROLPANEL_DIR): Build directory for control panel.
> > (CONTROLPANEL_SRCDIR): Source directory for control panel.
> > (CONTROLPANEL_LAUNCHER_OBJECTS): Objects used to compile binary
> > control panel.
> > (all-local): Add stamps/controlpanel-dist.stamp
> > stamps/controlpanel.stamp
> $(CONTROLPANEL_DIR)/launcher/controlpanel.
> > (clean-local): Add clean-controlpanel.
> > (install-exec-local): Install the control panel jar file and
> control
> > panel binary.
> > (uninstall-local): Delete controlpanel.jar and controlpanel binary
> > from installed location.
> > (controlpanel-source-files.txt): Get the list of source files for
> > control panel.
> > (stamps/controlpanel.stamp): Compile the java files for control
> panel.
> > (stamps/controlpanel-dist.stamp): Depend on
> stamps/controlpanel.stamp.
> > Create the jar file for control panel.
> > ($(CONTROLPANEL_DIR)/launcher/%.o): Create the launcher objects.
> > ($(CONTROLPANEL_DIR)/launcher/controlpanel): Link the objects to
> make
> > the launcher.
> > (clean-controlpanel): Remove the compiled control panel.
> > (controlpanel): Calls stamps/controlpanel.stamp.
> > (controlpanel-dist): Calls stamps/controlpanel-dist.stamp.
> > * controlpanel/org/classpath/controlpanel/AboutPanel.java,
> > * controlpanel/org/classpath/controlpanel/ComboItem.java,
> > * controlpanel/org/classpath/controlpanel/ControlPanel.java,
> > * controlpanel/org/classpath/controlpanel/DebuggingPanel.java,
> > *
> controlpanel/org/classpath/controlpanel/DesktopShortcutPanel.java,
> > * controlpanel/org/classpath/controlpanel/JREPanel.java,
> > * controlpanel/org/classpath/controlpanel/NamedBorderPanel.java,
> > *
> controlpanel/org/classpath/controlpanel/SecuritySettingsPanel.java,
> > *
> controlpanel/org/classpath/controlpanel/TemporaryInternetFilesPanel.java,
> > *
> controlpanel/org/classpath/controlpanel/network/AdvancedProxySettingsDialog.java,
> > *
> controlpanel/org/classpath/controlpanel/network/AdvancedProxySettingsPane.java,
> > *
> controlpanel/org/classpath/controlpanel/network/NetworkSettingsPanel.java,
> > *
> controlpanel/org/classpath/controlpanel/security/viewer/CertificatePane.java,
> > *
> controlpanel/org/classpath/controlpanel/security/viewer/CertificateViewer.java,
> > *
> controlpanel/org/classpath/controlpanel/translator/Translator.java:
> > New classes. All methods are new as well.
> > * netx/net/sourceforge/jnlp/resources/Messages.properties: Added
> > messages for control panel.
> >
> > Comments? Question? Concerns?
> >
>
> A few quick thoughts are listed below. Please dont let any of that
> discourage you. These are all thing that should be improved. But what
>
> you have so far is great work. It's just not perfect yet ;) We really
>
> needed something like this in netx/plugin though. Thanks for doing
> this!
>
> 1. Some of these settings dont do anything yet, right? I am looking at
>
> the cache stuff here. Perhaps you might want to leave it out for now,
> or
> clearly indicate that it does not do anything.
Ah, yes. I will put on the description noting that it currently doesn't do anything but just sets the deployment.properties file.
>
> 2. Why does the binary have the name controlpanel? I dont really care
>
> about the name itself, but if you are going to make it so close to the
>
> one used by proprietary JDK, why not just call it ControlPanel?
The proprietary JDK actually calls it jcontrol then symlinked to it calling ControlPanel :)
>
> 3. We should look into adding a desktop file so users would be able to
>
> launch it from the menu.
>
> 4. It is customary to have the package names be representative of the
>
> url. IcedTea is under the url icedtea.classpath.org. So itt would make
> a
> lot more sense to use org.classpath.icedtea.* rather than
> org.classpath.*.
I'll change this for the updated patch later.
>
> 5. Please get rid of CertificateViewer. CertificatePanel should be
> moved
> to org.classpath.controlpanel, along with the rest of the classes.
Ah yes, I completely forgot about CertificateViewer not being used.
Move will also be done.
>
> 6. Please dont create copies of classes. There is already a translator
>
> class in netx. The new Translator class still has a dependency on
> JNLPRuntime, so I really dont see the point of duplicating it.
> Personally I think it would be best if we separate the user-visible
> strings in ControlPanel from those in netx. We should have a separate
>
> properties file in control panel. Then the translator class would not
> be
> an exact duplicate (since it would read strings from another
> location).
>
> 7. Typo in the patch to ChangeLog:
> + (load): Do a security check at start. * security exception
Oops, replaced wrong text! I'll fix this.
>
> 8. Nice work on the launcher! The -Xbootclasspath way avoids adding
> redundant things to boot classpath.
>
> 9. I see that some files list asu as the author. Please use your full
>
> name (and email address) instead.
Ok. =)
>
> 10. You know you can do static imports right? Something like
> import static org.classpath.controlpanel.translator.Translator.R
> would mean you can just do R("foo") instead of Translator.R everytime.
>
> This is more of a style thing, so feel free to ignore it.
>
> Anyway, this looks great as a start! Thanks again for doing this.
>
> Cheers,
> Omair
Thanks for the review too Omair!
Cheers,
Andrew
More information about the distro-pkg-dev
mailing list