[icedtea-web-1.0] RFC: The Devil's in the DESTDIR
Deepak Bhole
dbhole at redhat.com
Tue Feb 1 14:35:30 PST 2011
* Dr Andrew John Hughes <ahughes at redhat.com> [2011-02-01 16:58]:
> When installing IcedTea-Web under Gentoo, DESTDIR is used to do a
> staged install in /var during make. The portage system copies it to
> the main tree later.
>
> Trying this with IcedTea-Web revealed a number of issues with DESTDIR
> that I've resolved in the attached patch, mainly because there was
> an implicit assumption that ${DESTDIR}${prefix} == ${prefix}.
>
> * We need to check if there is a ${prefix}/jre/bin not a
> ${DESTDIR}${prefix}/jre/bin as this may only contain what was installed by us.
> * The plugin install needs to go last or the installation of pluginappletviewer
> (which I believe is unnecessary anyway) will have already created the bin
> directory, causing mkinstalldirs to fail.
> * We should only create ${DESTDIR}${prefix}/jre/lib/${INSTALL_ARCH_DIR} if we are installing
> the plugin.
>
> I also tied things up a little to make it clearer. The two binaries are tested and
> linked at the same time rather than in separate if blocks.
>
Nice catch! Patch looks good to me. Okay for 1.0.
Thanks,
Deepak
> 2010-02-01 Andrew John Hughes <ahughes at redhat.com>
>
> Fix issues with use of DESTDIR pointing
> to an empty tree for staging.
> * Makefile.am:
> (install-exec-local): Create just bin and
> jre/lib for the main (NetX) install, creating
> jre/lib/$(INSTALL_ARCH_DIR) only for the plugin
> install. Amalgamate the if blocks and test for
> ${prefix}/jre/bin not ${DESTDIR}${prefix}/jre/bin
> to ensure we check the installed JDK and not the
> staging tree. Move plugin installation to the end
> to avoid mkinstalldirs from failing by trying to
> create ${DESTDIR}${prefix}/bin a second time.
>
> Ok for 1.0?
> --
> 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: 94EFD9D8 (http://subkeys.pgp.net)
> Fingerprint = F8EF F1EA 401E 2E60 15FA 7927 142C 2591 94EF D9D8
> diff -r 0db0d2392ef2 Makefile.am
> --- a/Makefile.am Tue Feb 01 21:20:37 2011 +0000
> +++ b/Makefile.am Tue Feb 01 21:51:55 2011 +0000
> @@ -102,32 +102,32 @@
> clean-bootstrap-directory clean-native-ecj clean-desktop-files clean-netx-docs clean-docs clean-plugin-docs
>
> install-exec-local:
> - ${mkinstalldirs} $(DESTDIR)$(prefix)/bin $(DESTDIR)$(prefix)$(JRE_DIR_PREFIX)/lib/$(INSTALL_ARCH_DIR)
> -if ENABLE_PLUGIN
> - ${INSTALL_PROGRAM} $(PLUGIN_DIR)/IcedTeaPlugin.so $(DESTDIR)$(prefix)$(JRE_DIR_PREFIX)/lib/$(INSTALL_ARCH_DIR)/
> - ${INSTALL_PROGRAM} $(PLUGIN_DIR)/launcher/pluginappletviewer $(DESTDIR)$(bindir)
> - ${INSTALL_DATA} $(abs_top_builddir)/liveconnect/lib/classes.jar $(DESTDIR)$(prefix)$(JRE_DIR_PREFIX)/lib/plugin.jar
> -endif
> + ${mkinstalldirs} $(DESTDIR)$(prefix)/bin $(DESTDIR)$(prefix)$(JRE_DIR_PREFIX)/lib
> ${INSTALL_DATA} $(NETX_DIR)/lib/classes.jar $(DESTDIR)$(prefix)$(JRE_DIR_PREFIX)/lib/netx.jar
> ${INSTALL_PROGRAM} $(NETX_DIR)/launcher/javaws $(DESTDIR)$(prefix)/bin
> - if [ -d $(DESTDIR)$(prefix)/jre/bin ] ; then \
> + ${INSTALL_DATA} extra-lib/about.jar $(DESTDIR)$(prefix)$(JRE_DIR_PREFIX)/lib
> + ${INSTALL_PROGRAM} $(NETX_DIR)/launcher/controlpanel/itweb-settings $(DESTDIR)$(prefix)/bin
> + if [ -d $(prefix)/jre/bin ] ; then \
> + ${mkinstalldirs} $(DESTDIR)$(prefix)/jre/bin ; \
> if [ -L $(DESTDIR)$(prefix)/jre/bin/javaws ] ; then \
> rm -f $(DESTDIR)$(prefix)/jre/bin/javaws ; \
> fi ; \
> + if [ -L $(DESTDIR)$(prefix)/jre/bin/itweb-settings ] ; then \
> + rm -f $(DESTDIR)$(prefix)/jre/bin/itweb-settings ; \
> + fi ; \
> if [ ! -e $(prefix)/jre/bin/javaws ] ; then \
> ln -s ../../bin/javaws $(DESTDIR)$(prefix)/jre/bin ; \
> fi ; \
> - fi
> - ${INSTALL_DATA} extra-lib/about.jar $(DESTDIR)$(prefix)$(JRE_DIR_PREFIX)/lib
> - ${INSTALL_PROGRAM} $(NETX_DIR)/launcher/controlpanel/itweb-settings $(DESTDIR)$(prefix)/bin
> - 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 ../../bin/itweb-settings $(DESTDIR)$(prefix)/jre/bin ; \
> fi ; \
> fi
> +if ENABLE_PLUGIN
> + ${mkinstalldirs} $(DESTDIR)$(prefix)$(JRE_DIR_PREFIX)/lib/$(INSTALL_ARCH_DIR)
> + ${INSTALL_PROGRAM} $(PLUGIN_DIR)/IcedTeaPlugin.so $(DESTDIR)$(prefix)$(JRE_DIR_PREFIX)/lib/$(INSTALL_ARCH_DIR)/
> + ${INSTALL_PROGRAM} $(PLUGIN_DIR)/launcher/pluginappletviewer $(DESTDIR)$(bindir)
> + ${INSTALL_DATA} $(abs_top_builddir)/liveconnect/lib/classes.jar $(DESTDIR)$(prefix)$(JRE_DIR_PREFIX)/lib/plugin.jar
> +endif
>
> install-data-local:
> ${mkinstalldirs} -d $(DESTDIR)$(prefix)/man/man1
More information about the distro-pkg-dev
mailing list