[icedtea-web] RFC: backport changeset 9397074c2c39 to icedtea-web 1.0

Deepak Bhole dbhole at redhat.com
Thu Jan 20 09:57:52 PST 2011


* Omair Majid <omajid at redhat.com> [2011-01-20 12:46]:
> Hi,
> 
> I would like to backport changeset 9397074c2c39 from icedtea-web
> HEAD to icedtea-web 1.0.
> 
> This changeset adds symlinks for javaws and itweb-settings under
> JDK_HOME/jre/bin. Without this patch, JNLPs which require a new VM
> to start will fail:
> 
> $ javaws SweetHome3D.jnlp
> net.sourceforge.jnlp.LaunchException: Fatal: External Launch Error:
> Could not launch JNLP file.
> Caused by: java.io.IOException: Cannot run program
> "$JDK_HOME/jre/bin/javaws": java.io.IOException: error=2, No such
> file or directory
> 
> The backport is attached.
> 
> Ok to commit?
> 

The binary in jre/bin should be the actual file, not the one in
JAVA_HOME/bin. JAVA_HOME/bin is optional and installed as part of the
JDK. However the JRE (and all the components therein) should be
independently runnable.

Cheers,
Deepak

> Cheers,
> Omair

> diff -r bafc58e4df46 ChangeLog
> --- a/ChangeLog	Thu Jan 20 12:09:09 2011 -0500
> +++ b/ChangeLog	Thu Jan 20 12:39:16 2011 -0500
> @@ -48,6 +48,17 @@
>  	* netx/net/sourceforge/jnlp/runtime/JNLPSecurityManager.java:
>  	Make sure SecurityException is thrown if necessary. 
>  
> +2010-12-15  Omair Majid  <omajid at redhat.com>
> +
> +	* Makefile.am
> +	(install-exec-local): Install plugin.jar as data. If $(prefix)/jre/bin
> +	exists, then install symlinks to real javaws and itweb-settings binaries
> +	under it.
> +	($(NETX_DIR)/launcher/%.o): Set system property java.icedtea-web.bin to
> +	point to the installed location of the javaws binary.
> +	* netx/net/sourceforge/jnlp/Launcher.java (launchExternal): Use the system
> +	property java.icedtea-web.bin to locate javaws binary.
> +
>  2010-12-14  Andrew John Hughes  <ahughes at redhat.com>
>  
>  	* Makefile.am:
> diff -r bafc58e4df46 Makefile.am
> --- a/Makefile.am	Thu Jan 20 12:09:09 2011 -0500
> +++ b/Makefile.am	Thu Jan 20 12:39:16 2011 -0500
> @@ -106,12 +106,28 @@
>  if ENABLE_PLUGIN
>  	${INSTALL_PROGRAM} $(PLUGIN_DIR)/IcedTeaPlugin.so $(DESTDIR)$(prefix)/jre/lib/$(INSTALL_ARCH_DIR)/
>  	${INSTALL_PROGRAM} $(PLUGIN_DIR)/launcher/pluginappletviewer $(DESTDIR)$(bindir)
> -	${INSTALL_PROGRAM} $(abs_top_builddir)/liveconnect/lib/classes.jar $(DESTDIR)$(prefix)/jre/lib/plugin.jar
> +	${INSTALL_DATA} $(abs_top_builddir)/liveconnect/lib/classes.jar $(DESTDIR)$(prefix)/jre/lib/plugin.jar
>  endif
>  	${INSTALL_DATA} $(NETX_DIR)/lib/classes.jar $(DESTDIR)$(prefix)/jre/lib/netx.jar
>  	${INSTALL_PROGRAM} $(NETX_DIR)/launcher/javaws $(DESTDIR)$(bindir)
> +	if [ -d $(DESTDIR)$(prefix)/jre/bin ] ; then \
> +	  if [ -L $(DESTDIR)$(prefix)/jre/bin/javaws ] ; then \
> +	    rm -f $(DESTDIR)$(prefix)/jre/bin/javaws ; \
> +	  fi ; \
> +	  if [ ! -e $(prefix)/jre/bin/javaws ] ; then \
> +	    ln -s $(DESTDIR)$(bindir)/javaws $(DESTDIR)$(prefix)/jre/bin ; \
> +	  fi ; \
> +	fi
>  	${INSTALL_DATA} extra-lib/about.jar $(DESTDIR)$(prefix)/jre/lib
>  	${INSTALL_PROGRAM} $(NETX_DIR)/launcher/controlpanel/itweb-settings $(DESTDIR)$(bindir)
> +	if [ -d $(DESTDIR)$(prefix)/jre/bin ] ; then \
> +	  if [ -L $(DESTDIR)$(prefix)/jre/bin/itweb-settings ] ; then \
> +	    rm -f $(DESTDIR)$(prefix)/jre/bin/itweb-settings ; \
> +	  fi ; \
> +	  if [ ! -e $(prefix)/jre/bin/itweb-settings ] ; then \
> +	    ln -s $(DESTDIR)$(bindir)/itweb-settings $(DESTDIR)$(prefix)/jre/bin ; \
> +	  fi ; \
> +	fi
>  
>  install-data-local:
>  	${mkinstalldirs} -d $(DESTDIR)$(prefix)/man/man1
> @@ -142,7 +158,14 @@
>  	rm -f $(DESTDIR)$(prefix)/man/man1/javaws.1
>  	rm -f $(DESTDIR)$(bindir)/pluginappletviewer
>  	rm -f $(DESTDIR)$(bindir)/javaws
> +	if [ -L $(DESTDIR)$(prefix)/jre/bin/javaws ] ; then \
> +	  rm -f $(DESTDIR)$(prefix)/jre/bin/javaws ; \
> +	fi
> +	rm -f $(DESTDIR)$(prefix)/jre/bin/javaws
>  	rm -f $(DESTDIR)$(bindir)/itweb-settings
> +	if [ -L $(DESTDIR)$(prefix)/jre/bin/itweb-settings ] ; then \
> +	  rm -f $(DESTDIR)$(prefix)/jre/bin/itweb-settings ; \
> +	fi
>  	rm -rf $(DESTDIR)$(htmldir)
>  
>  # Plugin
> @@ -325,8 +348,9 @@
>  
>  $(NETX_DIR)/launcher/%.o: $(LAUNCHER_SRCDIR)/%.c
>  	mkdir -p $(NETX_DIR)/launcher && \
> -	$(CC) $(LAUNCHER_FLAGS) -DJAVA_ARGS='{ "-J-ms8m", "net.sourceforge.jnlp.runtime.Boot",  }' -DPROGNAME='"javaws"' \
> -	-c -o $@ $<
> +	$(CC) $(LAUNCHER_FLAGS) \
> +	  -DJAVA_ARGS='{ "-J-ms8m", "-J-Djava.icedtea-web.bin=$(DESTDIR)$(bindir)/javaws", "net.sourceforge.jnlp.runtime.Boot",  }' \
> +	  -DPROGNAME='"javaws"' -c -o $@ $<
>  
>  $(NETX_DIR)/launcher/controlpanel/%.o: $(LAUNCHER_SRCDIR)/%.c
>  	mkdir -p $(NETX_DIR)/launcher/controlpanel && \
> diff -r bafc58e4df46 netx/net/sourceforge/jnlp/Launcher.java
> --- a/netx/net/sourceforge/jnlp/Launcher.java	Thu Jan 20 12:09:09 2011 -0500
> +++ b/netx/net/sourceforge/jnlp/Launcher.java	Thu Jan 20 12:39:16 2011 -0500
> @@ -329,11 +329,8 @@
>  
>              List<String> commands = new LinkedList<String>();
>  
> -            String pathToWebstartBinary = System.getProperty("java.home") +
> -                                      File.separatorChar +
> -                                      "bin" +
> -                                      File.separatorChar +
> -                                      "javaws";
> +            // this property is set by the javaws launcher to point to the javaws binary
> +            String pathToWebstartBinary = System.getProperty("java.icedtea-web.bin");
>              commands.add(pathToWebstartBinary);
>              // use -Jargument format to pass arguments to the JVM through the launcher
>              for (String arg : vmArgs) {




More information about the distro-pkg-dev mailing list