X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=Makefile.am;h=5ab3b6d41df5fb6e3e796e50c037b4ad3f9c3c41;hp=44fc8933b7a3d7b07f900b0494d0c22e81b6e516;hb=204d54609b4b3e4ca637f0ce2fe98c33ce9d008b;hpb=d868221d9f746ab17b83e7220cef9227fcad3696 diff --git a/Makefile.am b/Makefile.am index 44fc893..5ab3b6d 100644 --- a/Makefile.am +++ b/Makefile.am @@ -19,7 +19,8 @@ include $(top_srcdir)/subdir-rules.mk ACLOCAL_AMFLAGS = -I m4 -SUBDIRS = gnulib/lib src +# Basic source for the library. +SUBDIRS = gnulib/lib images generator src examples po if ENABLE_DAEMON SUBDIRS += daemon @@ -28,24 +29,16 @@ if ENABLE_APPLIANCE SUBDIRS += appliance endif -SUBDIRS += fish po examples images +# Tests and the test-tool. SUBDIRS += gnulib/tests capitests regressions test-tool +# Guestfish. +SUBDIRS += fish + +# Language bindings. if HAVE_PERL SUBDIRS += perl endif - -if HAVE_INSPECTOR -SUBDIRS += inspector -endif -if HAVE_TOOLS -SUBDIRS += tools -endif - -if HAVE_FUSE -SUBDIRS += fuse -endif - if HAVE_OCAML SUBDIRS += ocaml ocaml/examples endif @@ -61,11 +54,30 @@ endif if HAVE_HASKELL SUBDIRS += haskell endif +if HAVE_PHP +SUBDIRS += php +endif + +# Virt-inspector, tools and guestmount. +if HAVE_INSPECTOR +SUBDIRS += inspector +endif + +if HAVE_TOOLS +SUBDIRS += tools +endif + +if HAVE_FUSE +SUBDIRS += fuse +endif + +# po-docs must come after tools, inspector. +SUBDIRS += po-docs EXTRA_DIST = \ $(generator_built) \ html/pod.css \ - HACKING TODO \ + BUGS HACKING RELEASE-NOTES TODO \ libguestfs.pc libguestfs.pc.in \ recipes/LICENSE \ recipes/README \ @@ -102,10 +114,11 @@ html/guestfs.3.html: src/guestfs.pod \ --htmldir html \ --outfile $@ -html/guestfish.1.html: fish/guestfish.pod fish/guestfish-actions.pod +html/guestfish.1.html: fish/guestfish.pod fish/guestfish-actions.pod fish/guestfish-commands.pod mkdir -p html sed \ -e '/@ACTIONS@/rfish/guestfish-actions.pod' -e 's/@ACTIONS@//' \ + -e '/@FISH_COMMANDS@/rguestfish-commands.pod' -e 's/@FISH_COMMANDS@//' \ < $< | \ pod2html \ --css 'pod.css' \ @@ -152,29 +165,19 @@ website: $(HTMLFILES) $(TEXTFILES) -e "s/SUBST_DATE/$$date/" \ < index.html.in > index.html -# Generate the ChangeLog automatically from the gitlog. - +# When doing 'make dist' update a few files automatically. dist-hook: $(top_srcdir)/build-aux/gitlog-to-changelog > ChangeLog cp ChangeLog $(distdir)/ChangeLog + $(top_srcdir)/update-bugs > BUGS-t + mv BUGS-t BUGS + cp BUGS $(distdir)/BUGS # Update the list of translatable files in po/POTFILES.in. all-local: cd $(srcdir); \ find $(DIST_SUBDIRS) \ - -name '*.c' -o -name '*.pl' -o -name '*.pm' -o \ - -name 'virt-cat' -o \ - -name 'virt-df' -o \ - -name 'virt-edit' -o \ - -name 'virt-inspector' -o \ - -name 'virt-list-filesystems' -o \ - -name 'virt-list-partitions' -o \ - -name 'virt-ls' -o \ - -name 'virt-make-fs' -o \ - -name 'virt-rescue' -o \ - -name 'virt-resize' -o \ - -name 'virt-tar' -o \ - -name 'virt-win-reg' | \ + -name '*.c' -o -name '*.pl' -o -name '*.pm' | \ grep -v '^perl/blib/' | \ grep -v '^capitests/' | \ grep -v '^daemon/lib/' | \ @@ -185,6 +188,7 @@ all-local: grep -v '/guestfs_protocol.c' | \ grep -v '/rc_protocol.c' | \ grep -v 'appliance/debian/root' | \ + grep -v '^po-docs/' | \ LC_ALL=C sort | \ sed 's,^\./,,' > po/POTFILES.in @@ -209,6 +213,33 @@ clean-local: # is NOT a substitute for proper testing! quickcheck: - LIBGUESTFS_PATH=appliance \ - test-tool/libguestfs-test-tool \ - --helper test-tool/libguestfs-test-tool-helper + test-tool/run-test-tool-locally + +# Mostly static binary distribution. +# +# Some binaries are relinked partially statically. You can make these +# binaries "more static" by making sure that as many foo-static +# packages are installed as possible. +# +# We remove the supermin appliance and adjust some directories to make +# them non-Fedora-specific. + +BINTMPDIR = /tmp/libguestfs-bin +bindist: + rm -rf $(BINTMPDIR) + mkdir $(BINTMPDIR) + $(MAKE) + $(MAKE) DESTDIR=$(BINTMPDIR) install + rm -r $(BINTMPDIR)$(libdir)/guestfs/supermin.d + rm $(BINTMPDIR)$(libdir)/guestfs/kmod.whitelist + mv $(BINTMPDIR)$(prefix)/lib64/* $(BINTMPDIR)$(libdir) + mv $(BINTMPDIR)/usr/lib64/* $(BINTMPDIR)$(libdir) + -find $(BINTMPDIR) -type d -exec rmdir --ignore-fail-on-non-empty {} \; + $(MAKE) -C fish guestfish.static + cp fish/guestfish.static $(BINTMPDIR)$(bindir)/guestfish + $(MAKE) -C fuse guestmount.static + cp fuse/guestmount.static $(BINTMPDIR)$(bindir)/guestmount + $(MAKE) -C test-tool libguestfs-test-tool.static + cp test-tool/libguestfs-test-tool.static $(BINTMPDIR)$(bindir)/libguestfs-test-tool + (cd $(BINTMPDIR) && tar cf - .) | \ + gzip -c -9 > libguestfs-$(VERSION)-$(host_cpu).tar.gz