[icedtea-web] RFC: Fix make distcheck

Dr Andrew John Hughes ahughes at redhat.com
Tue Nov 30 06:16:28 PST 2010


On 11:03 Mon 29 Nov     , Deepak Bhole wrote:
> * Dr Andrew John Hughes <ahughes at redhat.com> [2010-11-26 23:21]:
> > This cleans up the icedtea-web build, mainly fixing install/uninstall
> > issues such as the permission of installed files and the non-removal
> > of documentation.
> > 
> > 2010-11-26  Andrew John Hughes  <ahughes at redhat.com>
> > 
> > 	Make distcheck work.
> > 	* Makefile.am:
> > 	(EXTRA_DIST): Use relative paths for netx
> > 	and the plugin.
> > 	(clean-local): Remove empty stamps directory.
> > 	(install-exec-local): Use install to install
> > 	programs and data with the correct permissions.
> > 	(install-data-local): Likewise.
> > 	(uninstall-local): Remove documentation.
> > 	(netx): Use ${INSTALL_DATA} to add resources so
> > 	that read-only files aren't copied.
> > 	(extra-files): Likewise.
> > 	($(NETX_DIR)/launcher/javaws): Don't create empty launcher
> > 	directory.
> > 	(clean-docs): Remove empty docs directory.
> > 	(clean-bootstrap-directory): Remove empty bootstrap
> > 	directory.
> > 
> > Ok?
> 
> I tested it with a clean icedtea-web build, tried a make distcheck and
> then tried building from resulting tarball -- everything seems to be
> working correctly.
> 

Good to hear.  Err... you do realise that exactly what make distcheck does is build from the tarball, right? :-D

> OK for HEAD.
> 

Thanks!

> Thanks!
> Deepak
> 
> > -- 
> > Andrew :)
> > 
> > Free Java Software Engineer
> > Red Hat, Inc. (http://www.redhat.com)
> > 
> > Support Free Java!
> > Contribute to GNU Classpath and the OpenJDK
> > http://www.gnu.org/software/classpath
> > http://openjdk.java.net
> > PGP Key: 94EFD9D8 (http://subkeys.pgp.net)
> > Fingerprint = F8EF F1EA 401E 2E60 15FA  7927 142C 2591 94EF D9D8
> 
> > diff -r 243ab4185293 Makefile.am
> > --- a/Makefile.am	Fri Nov 26 15:21:56 2010 +0000
> > +++ b/Makefile.am	Sat Nov 27 04:04:56 2010 +0000
> > @@ -83,7 +83,7 @@
> >  	-Wl,\$$ORIGIN/../jre/lib/$(INSTALL_ARCH_DIR)/jli $(X11_CFLAGS) $(X11_LIBS) -ljli  -ldl -lz
> >  PLUGIN_VERSION = IcedTea $(PACKAGE_VERSION)$(ICEDTEA_REV)$(ICEDTEA_PKG)
> >  
> > -EXTRA_DIST = $(NETX_SRCDIR) $(abs_top_srcdir)/plugin javaws.png javaws.desktop.in extra launcher
> > +EXTRA_DIST = $(top_srcdir)/netx $(top_srcdir)/plugin javaws.png javaws.desktop.in extra launcher
> >  
> >  # Top-Level Targets
> >  # =================
> > @@ -93,31 +93,41 @@
> >  
> >  clean-local: clean-netx clean-plugin clean-liveconnect clean-extra clean-bootstrap-directory \
> >   clean-native-ecj clean-desktop-files clean-docs
> > +	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
> >  
> >  install-exec-local:
> > -	mkdir -p $(DESTDIR)$(bindir)
> > -	mkdir -p $(DESTDIR)$(prefix)/jre/lib/$(INSTALL_ARCH_DIR)
> > +	${mkinstalldirs} $(DESTDIR)$(bindir) $(DESTDIR)$(prefix)/jre/lib/$(INSTALL_ARCH_DIR)
> >  if ENABLE_PLUGIN
> > -	cp -pPRf $(PLUGIN_DIR)/IcedTeaPlugin.so $(DESTDIR)$(prefix)/jre/lib/$(INSTALL_ARCH_DIR)/
> > -	cp -pPRf $(PLUGIN_DIR)/launcher/pluginappletviewer $(DESTDIR)$(bindir)
> > -	cp -pPRf $(abs_top_builddir)/liveconnect/lib/classes.jar $(DESTDIR)$(prefix)/jre/lib/plugin.jar
> > +	${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
> >  endif
> > -	cp -pPRf $(NETX_DIR)/lib/classes.jar $(DESTDIR)$(prefix)/jre/lib/netx.jar
> > -	cp -pPRf $(NETX_DIR)/launcher/javaws $(DESTDIR)$(bindir)
> > -	cp extra-lib/about.jar $(DESTDIR)$(prefix)/jre/lib
> > +	${INSTALL_DATA} $(NETX_DIR)/lib/classes.jar $(DESTDIR)$(prefix)/jre/lib/netx.jar
> > +	${INSTALL_PROGRAM} $(NETX_DIR)/launcher/javaws $(DESTDIR)$(bindir)
> > +	${INSTALL_DATA} extra-lib/about.jar $(DESTDIR)$(prefix)/jre/lib
> >  
> >  install-data-local:
> > -	mkdir -p $(DESTDIR)$(prefix)/man/man1
> > -	cp $(NETX_SRCDIR)/javaws.1 $(DESTDIR)$(prefix)/man/man1
> > -	cp $(NETX_RESOURCE_DIR)/about.jnlp $(DESTDIR)$(prefix)/jre/lib
> > +	${mkinstalldirs} -d $(DESTDIR)$(prefix)/man/man1
> > +	${INSTALL_DATA} $(NETX_SRCDIR)/javaws.1 $(DESTDIR)$(prefix)/man/man1
> > +	${INSTALL_DATA} $(NETX_RESOURCE_DIR)/about.jnlp $(DESTDIR)$(prefix)/jre/lib
> >  if ENABLE_DOCS
> > -	mkdir -p $(DESTDIR)$(htmldir)
> > -	cp -pPRf ${abs_top_builddir}/docs/netx $(DESTDIR)$(htmldir)
> > +	${mkinstalldirs} $(DESTDIR)$(htmldir)
> > +	(cd ${abs_top_builddir}/docs/netx; \
> > +	 for files in $$(find . -type f); \
> > +	 do \
> > +	   ${INSTALL_DATA} -D $${files} $(DESTDIR)$(htmldir)/netx/$${files}; \
> > +	 done)
> >  if ENABLE_PLUGIN
> > -	cp -pPRf ${abs_top_builddir}/docs/plugin $(DESTDIR)$(htmldir)
> > +	(cd ${abs_top_builddir}/docs/plugin; \
> > +	 for files in $$(find . -type f); \
> > +	 do \
> > +	   ${INSTALL_DATA} -D $${files} $(DESTDIR)$(htmldir)/plugin/$${files}; \
> > +	 done)
> >  endif
> >  endif
> >  
> > @@ -130,6 +140,7 @@
> >  	rm -f $(DESTDIR)$(prefix)/man/man1/javaws.1
> >  	rm -f $(DESTDIR)$(bindir)/pluginappletviewer
> >  	rm -f $(DESTDIR)$(bindir)/javaws
> > +	rm -rf $(DESTDIR)$(htmldir)
> >  
> >  # Plugin
> >  
> > @@ -250,7 +261,12 @@
> >  	    -sourcepath $(NETX_SRCDIR) \
> >  	    -bootclasspath $(RUNTIME) \
> >  	    @netx-source-files.txt
> > -	cp -r $(NETX_RESOURCE_DIR) $(NETX_DIR)/net/sourceforge/jnlp
> > +	(cd $(NETX_RESOURCE_DIR); \
> > +	 for files in $$(find . -type f); \
> > +	 do \
> > +	   ${INSTALL_DATA} -D $${files} \
> > +	   $(NETX_DIR)/net/sourceforge/jnlp/resources/$${files}; \
> > +	 done)
> >  	mkdir -p stamps
> >  	touch $@
> >  
> > @@ -285,7 +301,12 @@
> >  	$(BOOT_DIR)/bin/javac $(IT_JAVACFLAGS) -d extra-lib \
> >            -sourcepath $(abs_top_srcdir)/extra -cp netx.build \
> >            -bootclasspath $(RUNTIME) @extra-source-files.txt
> > -	cp -r $(NETX_EXTRA_DIR) extra-lib/net/sourceforge/jnlp/about
> > +	(cd $(NETX_EXTRA_DIR); \
> > +	 for files in $$(find . -type f); \
> > +	 do \
> > +	   ${INSTALL_DATA} -D $${files} \
> > +	   ${abs_top_builddir}/extra-lib/net/sourceforge/jnlp/about/resources/$${files}; \
> > +	 done)
> >  	mkdir -p stamps
> >  	touch $@
> >  
> > @@ -303,7 +324,6 @@
> >  	-c -o $@ $<
> >  
> >  $(NETX_DIR)/launcher/javaws: $(NETX_LAUNCHER_OBJECTS)
> > -	mkdir -p launcher
> >  	$(CC) $(NETX_LAUNCHER_OBJECTS) $(LAUNCHER_LINK)
> >  
> >  javaws.desktop: javaws.desktop.in
> > @@ -315,6 +335,9 @@
> >  	touch stamps/docs.stamp
> >  
> >  clean-docs: clean-netx-docs clean-plugin-docs
> > +	if [ -e ${abs_top_builddir}/docs ] ; then \
> > +	  rmdir ${abs_top_builddir}/docs ; \
> > +	fi
> >  	rm -f stamps/docs.stamp
> >  
> >  stamps/netx-docs.stamp: stamps/bootstrap-directory.stamp
> > @@ -416,6 +439,9 @@
> >  
> >  clean-bootstrap-directory:
> >  	rm -rf $(BOOT_DIR)
> > +	if [ -e ${abs_top_builddir}/bootstrap ] ; then \
> > +	  rmdir ${abs_top_builddir}/bootstrap ; \
> > +	fi
> >  	rm -f stamps/bootstrap-directory.stamp
> >  
> >  # Target Aliases
> 

-- 
Andrew :)

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

Support Free Java!
Contribute to GNU Classpath and the OpenJDK
http://www.gnu.org/software/classpath
http://openjdk.java.net
PGP Key: 94EFD9D8 (http://subkeys.pgp.net)
Fingerprint = F8EF F1EA 401E 2E60 15FA  7927 142C 2591 94EF D9D8



More information about the distro-pkg-dev mailing list