* tests/Makefile.am: Add it.
* lib/am/distdir.an (distdir): When a distribuable directory
exists both in `.' and $(srcdir), merge both directories. This
works around a failure of extra6.test on Tru64 reported by
Nicolas Joly.
+2002-03-26 Alexandre Duret-Lutz <duret_g@epita.fr>
+
+ * tests/extra7.test: New file.
+ * tests/Makefile.am: Add it.
+ * lib/am/distdir.an (distdir): When a distribuable directory
+ exists both in `.' and $(srcdir), merge both directories. This
+ works around a failure of extra6.test on Tru64 reported by
+ Nicolas Joly.
+
2002-03-26 Alexandre Duret-Lutz <duret_g@epita.fr>
* tests/pr87.test, tests/yaccvpath.test: Require GNU make.
dir=''; \
fi; \
##
-## In loop, test for file existence because sometimes a file gets
-## included in DISTFILES twice. For example this happens when a single
-## source file is used in building more than one program. Also, there
-## are situations in which "ln" can fail. For instance a file to
-## distribute could actually be a cross-filesystem symlink -- this can
-## easily happen if "gettextize" was run on the distribution.
+## Use cp, not ln. There are situations in which "ln" can fail. For
+## instance a file to distribute could actually be a cross-filesystem
+## symlink -- this can easily happen if "gettextize" was run on the
+## distribution.
##
if test -d $$d/$$file; then \
## Don't mention $$file in destination argument, since this fails if
## destination directory already exists. Also, use `-R' and not `-r'.
## `-r' is almost always incorrect.
- cp -pR $$d/$$file $(distdir)$$dir \
- || exit 1; \
+##
+## If a directory exists both in `.' and $(srcdir), then
+## We copy the files from $(srcdir) first and then install those from
+## `.'. This can help people who distribute directories made of
+## source files _and_ generated files. It is also important when the
+## directory exists only in $(srcdir), because some vendor Make (such
+## as Tru64) will magically create an empty directory in `.'
+ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+ cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+ fi; \
+ cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
else \
+## Test for file existence because sometimes a file gets included in
+## DISTFILES twice. For example this happens when a single source
+## file is used in building more than one program.
test -f $(distdir)/$$file \
|| cp -p $$d/$$file $(distdir)/$$file \
|| exit 1; \
extra4.test \
extra5.test \
extra6.test \
+extra7.test \
flibs.test \
fnoc.test \
fo.test \
extra4.test \
extra5.test \
extra6.test \
+extra7.test \
flibs.test \
fnoc.test \
fo.test \
dir=''; \
fi; \
if test -d $$d/$$file; then \
- cp -pR $$d/$$file $(distdir)$$dir \
- || exit 1; \
+ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+ cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+ fi; \
+ cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
else \
test -f $(distdir)/$$file \
|| cp -p $$d/$$file $(distdir)/$$file \
--- /dev/null
+#! /bin/sh
+
+# Check to make sure that when distdir is invoked in a VPATH
+# configuration and has to distribute directory X, it actually merge
+# $(srcdir)/X and ./X, with the files from the later overriding the
+# files from the former.
+
+. $srcdir/defs || exit 1
+
+set -e
+
+echo AC_OUTPUT >> configure.in
+
+cat > Makefile.am << 'END'
+EXTRA_DIST=foo/bar baz
+
+check: distdir
+ test -f $(distdir)/foo/bar/baz
+ test -f $(distdir)/foo/bar/baz2
+ test -f $(distdir)/baz/foo
+ test -f $(distdir)/baz/foo2
+ grep source $(distdir)/foo/bar/baz
+ grep build $(distdir)/foo/bar/baz2
+ grep source $(distdir)/baz/foo
+ grep build $(distdir)/baz/foo2
+END
+
+# Create some files in $(srcdir)
+mkdir foo
+mkdir foo/bar
+echo source > foo/bar/baz
+echo source > foo/bar/baz2
+mkdir baz
+echo source > baz/foo
+echo source > baz/foo2
+
+$ACLOCAL
+$AUTOMAKE
+$AUTOCONF
+mkdir build
+cd build
+../configure
+
+# Create some files in $(builddir) that will override part of the
+# files if $(srcdir) when the distribution is made.
+mkdir foo
+mkdir foo/bar
+echo build > foo/bar/baz2
+mkdir baz
+echo build > baz/foo2
+
+$MAKE check