[RFC][icedtea-web]: Adding control panel to icedtea-web

Deepak Bhole dbhole at redhat.com
Fri Nov 26 13:56:41 PST 2010


* Omair Majid <omajid at redhat.com> [2010-11-26 16:51]:
> 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.
> 
> 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?
> 

Good point. Are there any other name suggestions? I will start off with
my terrible suggestion :) .. "icedtea-settings"

Deepak

> 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.*.
> 
> 5. Please get rid of CertificateViewer. CertificatePanel should be
> moved to org.classpath.controlpanel, along with the rest of the
> classes.
> 
> 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
> 
> 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.
> 
> 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



More information about the distro-pkg-dev mailing list