[icedtea-web] RFC: replace binary launchers with shell scripts

Dr Andrew John Hughes ahughes at redhat.com
Wed Mar 9 13:36:48 PST 2011


On 14:33 Wed 09 Mar     , Omair Majid wrote:
> On 03/01/2011 08:38 PM, Dr Andrew John Hughes wrote:
> > On 13:38 Tue 01 Mar     , Omair Majid wrote:
> >>
> >> Yeah, that was the plan. Removing all that code in this patch would have
> >> created a large (and hard-to-understand) diff. I take it that you are
> >> okay with the actual idea behind the patch (replacing launchers with
> >> shell scripts)?
> >>
> >
> > Yes, it will be good to get rid of that launcher code.
> >
> 
> The updated attached patch should address all the issues you pointed out.
> 

snip...

> >
> > We can't have --prefix broken.  That effectively breaks the whole install process.
> >
> 
> It only breaks "make --prefix", not "configure --prefix", but yes, I am 
> trying to avoid that.
> 

err... there's no such thing as make --prefix as far as I'm aware.

> 
> Okay to commit?
> 
> Thanks,
> Omair

Yes, looks good.

> diff -r d91d02e798ff ChangeLog
> --- a/ChangeLog	Wed Mar 09 13:51:48 2011 -0500
> +++ b/ChangeLog	Wed Mar 09 14:32:08 2011 -0500
> @@ -1,3 +1,33 @@
> +2011-03-01  Omair Majid  <omajid at redhat.com>
> +
> +	Replace native launchers with shell scripts
> +	* NEWS: Update.
> +	* Makefile.am
> +	(LAUNCHER_BOOTCLASSPATH): Remove leading -J.
> +	(LAUNCHER_SRCDIR),
> +	(LAUNCHER_OBJECTS),
> +	(NETX_LAUNCHER_OBJECTS),
> +	(CONTROLPANEL_LAUNCHER_OBJECTS),
> +	(LAUNCHER_FLAGS),
> +	(LAUNCHER_LINK): Remove.
> +	(edit_launcher_script): New function.
> +	(all-local): Depend on new launcher targets.
> +	(clean-local): Depend on clean-launchers.
> +	(.PHONY): Add clean-launchers.
> +	(install-exec-local): Use new launcher paths.
> +	(clean-launchers): New target.
> +	($(NETX_DIR)/launcher/%.o),
> +	($(NETX_DIR)/launcher/controlpanel/%.o),
> +	($(NETX_DIR)/launcher/javaws),
> +	($(NETX_DIR)/launcher/controlpanel/itweb-settings): Remove.
> +	(launcher.build/javaws): New launcher.
> +	(launcher.build/itweb-settings): Likewise.
> +	* launcher/itweb-settings.in,
> +	* launcher/javaws.in: New file.
> +	* netx/net/sourceforge/jnlp/Launcher.java (launchExternal),
> +	* netx/net/sourceforge/jnlp/controlpanel/CommandLine.java (CommandLine):
> +	Use new system properties to find paths and program names.
> +
>  2011-03-09  Denis Lila  <dlila at redhat.com>
>  
>  	* netx/net/sourceforge/jnlp/Parser.java
> diff -r d91d02e798ff Makefile.am
> --- a/Makefile.am	Wed Mar 09 13:51:48 2011 -0500
> +++ b/Makefile.am	Wed Mar 09 14:32:08 2011 -0500
> @@ -25,7 +25,7 @@
>  IT_JAVACFLAGS=$(IT_JAVAC_SETTINGS) -source $(IT_LANGUAGE_SOURCE_VERSION) -target $(IT_CLASS_TARGET_VERSION)
>  
>  JRE='"$(SYSTEM_JDK_DIR)/jre"'
> -LAUNCHER_BOOTCLASSPATH="-J-Xbootclasspath/a:$(DESTDIR)$(datadir)/$(PACKAGE_NAME)/netx.jar$(RHINO_RUNTIME)"
> +LAUNCHER_BOOTCLASSPATH="-Xbootclasspath/a:$(DESTDIR)$(datadir)/$(PACKAGE_NAME)/netx.jar$(RHINO_RUNTIME)"
>  PLUGIN_BOOTCLASSPATH='"-Xbootclasspath/a:$(DESTDIR)$(datadir)/$(PACKAGE_NAME)/netx.jar:$(DESTDIR)$(datadir)/$(PACKAGE_NAME)/plugin.jar$(RHINO_RUNTIME)"'
>  
>  # Fake update version to shut up the plugin detector hosted by Oracle.
> @@ -72,40 +72,36 @@
>  endif
>  endif
>  
> -# Launcher
> -
> -LAUNCHER_SRCDIR = $(abs_top_srcdir)/launcher
> -LAUNCHER_OBJECTS = java.o java_md.o splashscreen_stubs.o jli_util.o parse_manifest.o version_comp.o wildcard.o
> -NETX_LAUNCHER_OBJECTS = $(addprefix $(NETX_DIR)/launcher/,$(LAUNCHER_OBJECTS))
> -CONTROLPANEL_LAUNCHER_OBJECTS = $(addprefix $(NETX_DIR)/launcher/controlpanel/,$(LAUNCHER_OBJECTS))
> -LAUNCHER_FLAGS = -O2 -fno-strict-aliasing -fPIC -pthread -W -Wall -Wno-unused -Wno-parentheses -pipe -fno-omit-frame-pointer \
> -	-g -D_LARGEFILE64_SOURCE -D_GNU_SOURCE -D_REENTRANT -DLAUNCHER_NAME='"java"' -I$(LAUNCHER_SRCDIR) \
> -	-DJDK_MAJOR_VERSION='"1"' -DJDK_MINOR_VERSION='"6"' -DLIBARCHNAME='"$(JRE_ARCH_DIR)"' \
> -	-DEXPAND_CLASSPATH_WILDCARDS
> -LAUNCHER_LINK = -o $@ -pthread -Xlinker -O1 -Xlinker -z -Xlinker defs -L$(BOOT_DIR)/lib/$(INSTALL_ARCH_DIR) \
> -	-Wl,-soname=lib.so -Wl,-z -Wl,origin -Wl,--allow-shlib-undefined $(X11_CFLAGS) $(X11_LIBS) -ldl -lz
>  PLUGIN_VERSION = IcedTea-Web $(FULL_VERSION)
>  
>  EXTRA_DIST = $(top_srcdir)/netx $(top_srcdir)/plugin javaws.png javaws.desktop.in extra launcher \
>   itweb-settings.desktop.in
>  
> +# the launcher needs to know $(bindir) and $(datadir) which can be different at
> +# make-time from configure-time
> +edit_launcher_script = sed \
> +  -e 's|[@]LAUNCHER_BOOTCLASSPATH[@]|$(LAUNCHER_BOOTCLASSPATH)|g' \
> +  -e 's|[@]JAVAWS_BIN_LOCATION[@]|$(bindir)/javaws|g' \
> +  -e 's|[@]ITWEB_SETTINGS_BIN_LOCATION[@]|$(bindir)/itweb-settings|g' \
> +  -e 's|[@]JAVA[@]|$(JAVA)|g'
> +
>  # Top-Level Targets
>  # =================
>  
> -all-local: stamps/netx-dist.stamp extra-lib/about.jar stamps/plugin.stamp $(NETX_DIR)/launcher/javaws \
> - javaws.desktop stamps/docs.stamp $(NETX_DIR)/launcher/controlpanel/itweb-settings itweb-settings.desktop
> +all-local: stamps/netx-dist.stamp extra-lib/about.jar stamps/plugin.stamp launcher.build/javaws \
> + javaws.desktop stamps/docs.stamp launcher.build/itweb-settings itweb-settings.desktop
>  
>  check-local: check-pac-functions
>  
>  clean-local: clean-netx clean-plugin clean-liveconnect clean-extra clean-bootstrap-directory \
> - clean-native-ecj clean-desktop-files clean-docs clean-tests
> + clean-native-ecj clean-launchers clean-desktop-files clean-docs clean-tests
>  	if [ -e stamps ] ; then \
>  	  rmdir stamps ; \
>  	fi
>  
>  .PHONY: clean-IcedTeaPlugin clean-add-netx clean-add-netx-debug clean-add-plugin clean-add-plugin-debug \
>   clean-bootstrap-directory clean-native-ecj clean-desktop-files clean-netx-docs clean-docs clean-plugin-docs \
> - clean-tests check-local
> + clean-tests check-local clean-launchers
>  
>  install-exec-local:
>  	${mkinstalldirs} $(DESTDIR)$(bindir) $(DESTDIR)$(datadir)/$(PACKAGE_NAME)/ $(DESTDIR)$(libdir)
> @@ -114,9 +110,9 @@
>  	${INSTALL_DATA} $(abs_top_builddir)/liveconnect/lib/classes.jar $(DESTDIR)$(datadir)/$(PACKAGE_NAME)/plugin.jar
>  endif
>  	${INSTALL_DATA} $(NETX_DIR)/lib/classes.jar $(DESTDIR)$(datadir)/$(PACKAGE_NAME)/netx.jar
> -	${INSTALL_PROGRAM} $(NETX_DIR)/launcher/javaws $(DESTDIR)$(bindir)
> +	${INSTALL_PROGRAM} launcher.build/javaws $(DESTDIR)$(bindir)
>  	${INSTALL_DATA} extra-lib/about.jar $(DESTDIR)$(datadir)/$(PACKAGE_NAME)/about.jar
> -	${INSTALL_PROGRAM} $(NETX_DIR)/launcher/controlpanel/itweb-settings $(DESTDIR)$(bindir)
> +	${INSTALL_PROGRAM} launcher.build/itweb-settings $(DESTDIR)$(bindir)
>  
>  install-data-local:
>  	${mkinstalldirs} -d $(DESTDIR)$(mandir)/man1
> @@ -322,23 +318,20 @@
>  extra-lib/about.jar: stamps/extra-class-files.stamp
>  	$(BOOT_DIR)/bin/jar cf $@ -C extra-lib net ;
>  
> -$(NETX_DIR)/launcher/%.o: $(LAUNCHER_SRCDIR)/%.c
> -	mkdir -p $(NETX_DIR)/launcher && \
> -	$(CC) $(LAUNCHER_FLAGS) \
> -	  -DJAVA_ARGS='{ $(LAUNCHER_BOOTCLASSPATH), "-J-ms8m", "-J-Djava.icedtea-web.bin=$(DESTDIR)$(bindir)/javaws", "net.sourceforge.jnlp.runtime.Boot",  }' \
> -	  -DICEDTEA_WEB_JRE=$(JRE) -DPROGNAME='"javaws"' -c -o $@ $<
> +launcher.build/javaws: launcher/javaws.in
> +	mkdir -p launcher.build
> +	$(edit_launcher_script) < $< > $@
>  
> -$(NETX_DIR)/launcher/controlpanel/%.o: $(LAUNCHER_SRCDIR)/%.c
> -	mkdir -p $(NETX_DIR)/launcher/controlpanel && \
> -	$(CC) $(LAUNCHER_FLAGS) \
> -	-DJAVA_ARGS='{ $(LAUNCHER_BOOTCLASSPATH), "-J-ms8m", "-Dprogram.name=itweb-settings", "net.sourceforge.jnlp.controlpanel.CommandLine",  }' \
> -	-DICEDTEA_WEB_JRE=$(JRE) -DPROGNAME='"itweb-settings"' -c -o $@ $<
> +launcher.build/itweb-settings: launcher/itweb-settings.in
> +	mkdir -p launcher.build
> +	$(edit_launcher_script) < $< > $@
>  
> -$(NETX_DIR)/launcher/javaws: $(NETX_LAUNCHER_OBJECTS)
> -	$(CC) $(NETX_LAUNCHER_OBJECTS) $(LAUNCHER_LINK)
> -
> -$(NETX_DIR)/launcher/controlpanel/itweb-settings: $(CONTROLPANEL_LAUNCHER_OBJECTS)
> -	$(CC) $(CONTROLPANEL_LAUNCHER_OBJECTS) $(LAUNCHER_LINK)
> +clean-launchers:
> +	rm -f launcher.build/javaws
> +	rm -f launcher.build/itweb-settings
> +	if [ -e launcher.build ] ; then \
> +	  rmdir launcher.build ; \
> +	fi
>  
>  javaws.desktop: javaws.desktop.in
>  	sed "s#PATH_TO_JAVAWS#$(DESTDIR)$(bindir)/javaws#" < $(srcdir)/javaws.desktop.in > javaws.desktop
> diff -r d91d02e798ff NEWS
> --- a/NEWS	Wed Mar 09 13:51:48 2011 -0500
> +++ b/NEWS	Wed Mar 09 14:32:08 2011 -0500
> @@ -15,6 +15,7 @@
>  * New Features
>    - IcedTea-Web now installs to a FHS-compliant location
>    - IcedTea-Web can now handle Proxy Auto Config files
> +  - Binary launchers replaced with simple shell scripts
>  * Common Fixes and Improvements
>    - PR497: Mercurial revision detection not very reliable
>    - PR638: JNLPClassLoader.loadClass(String name) can return null
> diff -r d91d02e798ff launcher/itweb-settings.in
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/launcher/itweb-settings.in	Wed Mar 09 14:32:08 2011 -0500
> @@ -0,0 +1,15 @@
> +#!/bin/bash
> +
> +JAVA=@JAVA@
> +LAUNCHER_BOOTCLASSPATH=@LAUNCHER_BOOTCLASSPATH@
> +LAUNCHER_FLAGS=-Xms8m
> +CLASSNAME=net.sourceforge.jnlp.controlpanel.CommandLine
> +BINARY_LOCATION=@ITWEB_SETTINGS_BIN_LOCATION@
> +PROGRAM_NAME=itweb-settings
> +
> +${JAVA} ${LAUNCHER_BOOTCLASSPATH} ${LAUNCHER_FLAGS} \
> +  -Dicedtea-web.bin.name=${PROGRAM_NAME} \
> +  -Dicedtea-web.bin.location=${BINARY_LOCATION} \
> +  ${CLASSNAME} \
> +  $@
> +
> diff -r d91d02e798ff launcher/javaws.in
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/launcher/javaws.in	Wed Mar 09 14:32:08 2011 -0500
> @@ -0,0 +1,14 @@
> +#!/bin/bash
> +
> +JAVA=@JAVA@
> +LAUNCHER_BOOTCLASSPATH=@LAUNCHER_BOOTCLASSPATH@
> +LAUNCHER_FLAGS=-Xms8m
> +CLASSNAME=net.sourceforge.jnlp.runtime.Boot
> +BINARY_LOCATION=@JAVAWS_BIN_LOCATION@
> +PROGRAM_NAME=javaws
> +
> +${JAVA} ${LAUNCHER_BOOTCLASSPATH} ${LAUNCHER_FLAGS} \
> +  -Dicedtea-web.bin.name=${PROGRAM_NAME} \
> +  -Dicedtea-web.bin.location=${BINARY_LOCATION} \
> +  ${CLASSNAME} \
> +  $@
> diff -r d91d02e798ff netx/net/sourceforge/jnlp/Launcher.java
> --- a/netx/net/sourceforge/jnlp/Launcher.java	Wed Mar 09 13:51:48 2011 -0500
> +++ b/netx/net/sourceforge/jnlp/Launcher.java	Wed Mar 09 14:32:08 2011 -0500
> @@ -327,7 +327,7 @@
>              List<String> commands = new LinkedList<String>();
>  
>              // this property is set by the javaws launcher to point to the javaws binary
> -            String pathToWebstartBinary = System.getProperty("java.icedtea-web.bin");
> +            String pathToWebstartBinary = System.getProperty("icedtea-web.bin.location");
>              commands.add(pathToWebstartBinary);
>              // use -Jargument format to pass arguments to the JVM through the launcher
>              for (String arg : vmArgs) {
> diff -r d91d02e798ff netx/net/sourceforge/jnlp/controlpanel/CommandLine.java
> --- a/netx/net/sourceforge/jnlp/controlpanel/CommandLine.java	Wed Mar 09 13:51:48 2011 -0500
> +++ b/netx/net/sourceforge/jnlp/controlpanel/CommandLine.java	Wed Mar 09 14:32:08 2011 -0500
> @@ -74,7 +74,7 @@
>       * Creates a new instance
>       */
>      public CommandLine() {
> -        PROGRAM_NAME = System.getProperty("program.name");
> +        PROGRAM_NAME = System.getProperty("icedtea-web.bin.name");
>  
>          config = new DeploymentConfiguration();
>          try {


-- 
Andrew :)

Free Java Software Engineer
Red Hat, Inc. (http://www.redhat.com)

Support Free Java!
Contribute to GNU Classpath and IcedTea
http://www.gnu.org/software/classpath
http://icedtea.classpath.org
PGP Key: F5862A37 (https://keys.indymedia.org/)
Fingerprint = EA30 D855 D50F 90CD F54D  0698 0713 C3ED F586 2A37



More information about the distro-pkg-dev mailing list