Improved checking, documentation of modes (RHBZ#582901, RHBZ#582929).
[libguestfs.git] / Makefile.am
index c33710a..44fc893 100644 (file)
@@ -1,5 +1,5 @@
 # libguestfs
-# Copyright (C) 2009 Red Hat Inc.
+# Copyright (C) 2009-2010 Red Hat Inc.
 #
 # This program is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -19,12 +19,18 @@ include $(top_srcdir)/subdir-rules.mk
 
 ACLOCAL_AMFLAGS = -I m4
 
-SUBDIRS = gnulib/lib hivex src daemon appliance fish po examples images \
-       gnulib/tests capitests regressions test-tool
+SUBDIRS = gnulib/lib src
+
+if ENABLE_DAEMON
+SUBDIRS += daemon
+endif
+if ENABLE_APPLIANCE
+SUBDIRS += appliance
+endif
+
+SUBDIRS += fish po examples images
+SUBDIRS += gnulib/tests capitests regressions test-tool
 
-# NB: Must build inspector directory after perl and before ocaml.
-# We could relax this if we combined the inspector_generator with
-# the ordinary generator, but that brings other problems.
 if HAVE_PERL
 SUBDIRS += perl
 endif
@@ -56,16 +62,8 @@ if HAVE_HASKELL
 SUBDIRS += haskell
 endif
 
-generator_built = \
-       guestfs-actions.pod \
-       guestfs-availability.pod \
-       guestfs-structs.pod \
-       guestfish-actions.pod
-
 EXTRA_DIST = \
        $(generator_built) \
-       guestfs.pod \
-       guestfish.pod \
        html/pod.css \
        HACKING TODO \
        libguestfs.pc libguestfs.pc.in \
@@ -78,58 +76,24 @@ EXTRA_DIST = \
        make-recipes.sh \
        contrib/README \
        bindtests \
-       libguestfs.3
-
-# Manual pages.
-# guestfs-actions.pod, guestfs-availability.pod and guestfs-structs
-# are autogenerated.  There is no include mechanism for POD, so we
-# have to do it by hand.
+       .gitignore \
+       m4/.gitignore
 
-man_MANS = guestfs.3 libguestfs.3 guestfish.1
-
-guestfs.3: guestfs.pod \
-               guestfs-actions.pod \
-               guestfs-availability.pod \
-               guestfs-structs.pod
-       sed \
-         -e '/@ACTIONS@/rguestfs-actions.pod' \
-         -e 's/@ACTIONS@//' \
-         -e '/@AVAILABILITY@/rguestfs-availability.pod' \
-         -e 's/@AVAILABILITY@//' \
-         -e '/@STRUCTS@/rguestfs-structs.pod' \
-         -e 's/@STRUCTS@//' \
-         < $< | \
-       $(POD2MAN) \
-         --section 3 \
-         -c "Virtualization Support" \
-         --name "guestfs" \
-         --release "$(PACKAGE_NAME)-$(PACKAGE_VERSION)" \
-         > $@
-
-guestfish.1: guestfish.pod guestfish-actions.pod
-       sed \
-         -e '/@ACTIONS@/rguestfish-actions.pod' -e 's/@ACTIONS@//' \
-         < $< | \
-       $(POD2MAN) \
-         --section 1 \
-         -c "Virtualization Support" \
-         --name "guestfish" \
-         --release "$(PACKAGE_NAME)-$(PACKAGE_VERSION)" \
-         > $@
+# HTML versions of manual pages.
 
 noinst_DATA = html/guestfs.3.html html/guestfish.1.html
 
-html/guestfs.3.html: guestfs.pod \
-               guestfs-actions.pod \
-               guestfs-availability.pod \
-               guestfs-structs.pod
+html/guestfs.3.html: src/guestfs.pod \
+               src/guestfs-actions.pod \
+               src/guestfs-availability.pod \
+               src/guestfs-structs.pod
        mkdir -p html
        sed \
-         -e '/@ACTIONS@/rguestfs-actions.pod' \
+         -e '/@ACTIONS@/rsrc/guestfs-actions.pod' \
          -e 's/@ACTIONS@//' \
-         -e '/@AVAILABILITY@/rguestfs-availability.pod' \
+         -e '/@AVAILABILITY@/rsrc/guestfs-availability.pod' \
          -e 's/@AVAILABILITY@//' \
-         -e '/@STRUCTS@/rguestfs-structs.pod' \
+         -e '/@STRUCTS@/rsrc/guestfs-structs.pod' \
          -e 's/@STRUCTS@//' \
          < $< | \
        pod2html \
@@ -138,10 +102,10 @@ html/guestfs.3.html: guestfs.pod \
          --htmldir html \
          --outfile $@
 
-html/guestfish.1.html: guestfish.pod guestfish-actions.pod
+html/guestfish.1.html: fish/guestfish.pod fish/guestfish-actions.pod
        mkdir -p html
        sed \
-         -e '/@ACTIONS@/rguestfish-actions.pod' -e 's/@ACTIONS@//' \
+         -e '/@ACTIONS@/rfish/guestfish-actions.pod' -e 's/@ACTIONS@//' \
          < $< | \
        pod2html \
          --css 'pod.css' \
@@ -160,16 +124,16 @@ HTMLFILES = \
        html/guestfs.3.html \
        html/guestfish.1.html \
        html/guestmount.1.html \
-       html/hivex.3.html \
-       html/hivexget.1.html \
-       html/hivexml.1.html \
        html/virt-cat.1.html \
        html/virt-df.1.html \
        html/virt-edit.1.html \
        html/virt-inspector.1.html \
        html/virt-list-filesystems.1.html \
+       html/virt-list-partitions.1.html \
        html/virt-ls.1.html \
+       html/virt-make-fs.1.html \
        html/virt-rescue.1.html \
+       html/virt-resize.1.html \
        html/virt-tar.1.html \
        html/virt-win-reg.1.html \
        html/recipes.html \
@@ -204,8 +168,11 @@ all-local:
            -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' | \
        grep -v '^perl/blib/' | \
@@ -236,3 +203,12 @@ CLEANFILES = $(fs_DATA) \
 
 clean-local:
        rm -rf initramfs
+
+# If you don't want to run all of the tests ('make check') then this
+# will just run libguestfs-test-tool for a quick check.  Note this
+# is NOT a substitute for proper testing!
+
+quickcheck:
+       LIBGUESTFS_PATH=appliance \
+       test-tool/libguestfs-test-tool \
+         --helper test-tool/libguestfs-test-tool-helper