Merge branch 'aclocal-trace-macrodir'
[platform/upstream/automake.git] / Makefile.am
index 5fa11e0..f05e82d 100644 (file)
@@ -27,6 +27,37 @@ EXTRA_DIST =
 ##  Top level.  ##
 ## ------------ ##
 
+# We want a handful of substitutions to be fully-expanded by make;
+# then use config.status to substitute the remainder where a single
+# expansion is sufficient.  We use a funny notation here to avoid
+# configure substitutions in our text.
+do_subst = ( sed \
+  -e "s,[@]configure_input[@],Generated from $$in; do not edit by hand.,g" \
+  -e 's,[@]datadir[@],$(datadir),g' \
+  -e 's,[@]amdir[@],$(amdir),g' \
+  -e 's,[@]bindir[@],$(bindir),g' \
+  -e 's,[@]docdir[@],$(docdir),g' \
+  -e 's,[@]pkgvdatadir[@],$(pkgvdatadir),g' \
+  -e 's,[@]scriptdir[@],$(scriptdir),g' \
+  -e 's,[@]automake_acdir[@],$(automake_acdir),g' \
+  -e 's,[@]system_acdir[@],$(system_acdir),g' \
+## Hack to avoid a spurious substitution in the Automake script (part 1).
+  -e 's,[@]am__isrc[@],!!@!!am__isrc!!@!!,g' \
+  | $(SHELL) ./config.status --file=- \
+## Hack to avoid a spurious substitution in the Automake script (part 2).
+  | sed -e 's,!!@!!am__isrc!!@!!,@''am__isrc@,g' \
+  )
+
+# Generated  files shouldn't contain unexpanded '@substitutions@', and
+# should be made read-only, to prevent them from being edited by mistake
+# instead of the file the are generated from.
+generated_file_finalize = $(AM_V_at) \
+  if LC_ALL=C grep '@[a-zA-Z0-9_][a-zA-Z0-9_]*@' $@-t; then \
+    echo "$@ contains unexpanded substitution (see lines above)"; \
+    exit 1; \
+  fi; \
+  chmod a-w $@-t && mv -f $@-t $@
+
 bin_SCRIPTS = automake aclocal
 
 CLEANFILES += $(bin_SCRIPTS)
@@ -36,7 +67,7 @@ TAGS_FILES = $(AUTOMAKESOURCES)
 
 EXTRA_DIST += \
   $(AUTOMAKESOURCES) \
-  bootstrap \
+  bootstrap.sh \
   GNUmakefile \
   syntax-checks.mk \
   HACKING
@@ -61,32 +92,16 @@ uninstall-hook:
          rm -f "$(DESTDIR)$(bindir)/$$fv"; \
        done
 
-## We can't use configure to do the substitution here; we must do it
-## by hand.  We use a funny notation here to avoid configure
-## substitutions in our text.
-do_subst = sed \
-  -e 's,[@]APIVERSION[@],$(APIVERSION),g' \
-  -e 's,[@]PACKAGE[@],$(PACKAGE),g' \
-  -e 's,[@]PACKAGE_BUGREPORT[@],$(PACKAGE_BUGREPORT),g' \
-  -e 's,[@]PACKAGE_URL[@],$(PACKAGE_URL),g' \
-  -e 's,[@]PATH_SEPARATOR[@],$(PATH_SEPARATOR),g' \
-  -e 's,[@]PERL[@],$(PERL),g' \
-  -e 's,[@]PERL_THREADS[@],$(PERL_THREADS),g' \
-  -e 's,[@]SHELL[@],$(SHELL),g' \
-  -e 's,[@]am_AUTOCONF[@],$(am_AUTOCONF),g' \
-  -e 's,[@]am_AUTOM4TE[@],$(am_AUTOM4TE),g' \
-  -e 's,[@]VERSION[@],$(VERSION),g' \
-  -e 's,[@]configure_input[@],Generated from $@.in; do not edit by hand.,g' \
-  -e 's,[@]datadir[@],$(datadir),g'
-
 ## These files depend on Makefile so they are rebuilt if $(VERSION),
 ## $(datadir) or other do_subst'ituted variables change.
-## Use chmod a-w to prevent people from editing the wrong file by accident.
 automake: automake.in
 aclocal: aclocal.in
 automake aclocal: Makefile
        $(AM_V_at)rm -f $@ $@-t
-       $(AM_V_GEN)$(do_subst) $(srcdir)/$@.in >$@-t
+       $(AM_V_GEN)in=$@.in; $(do_subst) <$(srcdir)/$@.in >$@-t
+## We can't use '$(generated_file_finalize)' here, because currently
+## Automake contains occurrences of unexpanded @substitutions@ in
+## comments, and that is perfectly legit.
        $(AM_V_at)chmod a+x,a-w $@-t && mv -f $@-t $@
 
 ## The master location for INSTALL is lib/INSTALL.
@@ -182,23 +197,12 @@ dist_perllib_DATA = \
 nodist_perllib_DATA = lib/Automake/Config.pm
 CLEANFILES += $(nodist_perllib_DATA)
 
-## This file depends on Makefile so it is rebuilt if $(VERSION),
-## $(datadir) or other do_subst'ituted variables change.
-## Use chmod a-w to prevent people from editing the wrong file by accident.
 lib/Automake/Config.pm: lib/Automake/Config.in Makefile
        $(AM_V_at)rm -f $@ $@-t
        $(AM_V_at)test -d lib/Automake || $(MKDIR_P) lib/Automake
-       $(AM_V_GEN)sed <$(srcdir)/lib/Automake/Config.in >$@-t \
-         -e 's,[@]APIVERSION[@],$(APIVERSION),g' \
-         -e 's,[@]PACKAGE[@],$(PACKAGE),g' \
-         -e 's,[@]PACKAGE_BUGREPORT[@],$(PACKAGE_BUGREPORT),g' \
-         -e 's,[@]PERL[@],$(PERL),g' \
-         -e 's,[@]PERL_THREADS[@],$(PERL_THREADS),g' \
-         -e 's,[@]SHELL[@],$(SHELL),g' \
-         -e 's,[@]VERSION[@],$(VERSION),g' \
-         -e "s,[@]configure_input[@],Generated from Config.in; do not edit by hand.,g" \
-         -e 's,[@]datadir[@],$(datadir),g'
-       $(AM_V_at)chmod a-w $@-t && mv -f $@-t $@
+       $(AM_V_GEN)in=Config.in \
+         && $(do_subst) <$(srcdir)/lib/Automake/Config.in >$@-t
+       $(generated_file_finalize)
 EXTRA_DIST += lib/Automake/Config.in
 
 
@@ -257,14 +261,13 @@ dist_automake_ac_DATA = \
   m4/ar-lib.m4 \
   m4/as.m4 \
   m4/auxdir.m4 \
-  m4/ccstdc.m4 \
   m4/cond.m4 \
   m4/cond-if.m4 \
   m4/depend.m4 \
   m4/depout.m4 \
   m4/dmalloc.m4 \
+  m4/extra-recurs.m4 \
   m4/gcj.m4 \
-  m4/header.m4 \
   m4/init.m4 \
   m4/install-sh.m4 \
   m4/lead-dot.m4 \
@@ -274,10 +277,6 @@ dist_automake_ac_DATA = \
   m4/make.m4 \
   m4/minuso.m4 \
   m4/missing.m4 \
-  m4/mkdirp.m4 \
-  m4/obsol-gt.m4 \
-  m4/obsol-lt.m4 \
-  m4/obsolete.m4 \
   m4/options.m4 \
   m4/protos.m4 \
   m4/python.m4 \
@@ -300,12 +299,10 @@ dist_system_ac_DATA = m4/acdir/README
 # Use '$(top_srcdir)/m4' for the benefit of non-GNU makes: this is
 # how amversion.m4 appears in our dependencies.
 $(top_srcdir)/m4/amversion.m4: $(srcdir)/configure.ac $(srcdir)/m4/amversion.in
-       $(AM_V_at)sed \
-           -e 's,[@]VERSION[@],$(VERSION),g' \
-           -e 's,[@]APIVERSION[@],$(APIVERSION),g' \
-           -e "s,[@]configure_input[@],Generated from amversion.in; do not edit by hand.,g" \
-           $(srcdir)/m4/amversion.in > $@-t
-       $(AM_V_at)chmod a-w $@-t && mv -f $@-t $@
+       $(AM_V_at)rm -f $@-t $@
+       $(AM_V_GEN)in=amversion.in \
+         && $(do_subst) <$(srcdir)/m4/amversion.in >$@-t
+       $(generated_file_finalize)
 EXTRA_DIST += m4/amversion.in
 
 
@@ -313,8 +310,8 @@ EXTRA_DIST += m4/amversion.in
 ##  Testsuite.  ##
 ## ------------ ##
 
-# Run the tests with the shell detected at configure time.
-LOG_COMPILER = $(SHELL)
+# Run the tests with a proper shell detected at configure time.
+LOG_COMPILER = $(AM_TEST_RUNNER_SHELL)
 
 TEST_EXTENSIONS = .pl .sh .tap
 SH_LOG_COMPILER = $(LOG_COMPILER)
@@ -326,7 +323,7 @@ TAP_LOG_DRIVER = AM_TAP_AWK='$(AWK)' $(SHELL) $(srcdir)/lib/tap-driver.sh
 
 AM_TAP_LOG_DRIVER_FLAGS = --merge
 
-EXTRA_DIST += t/ax/is
+EXTRA_DIST += t/README t/ax/is t/ax/is_newest
 
 TESTS = ## Will be updated later.
 
@@ -334,10 +331,9 @@ TESTS = ## Will be updated later.
 # test scripts, but not from the environment.
 AM_TESTS_ENVIRONMENT = \
   for v in \
-    me \
     required \
     am_using_tap \
-    am_parallel_tests \
+    am_serial_tests \
     am_test_prefer_config_shell \
     am_original_AUTOMAKE \
     am_original_ACLOCAL \
@@ -377,86 +373,35 @@ $(srcdir)/t/testsuite-part.am:
        $(AM_V_at)mv -f t/testsuite-part.tmp $@
 EXTRA_DIST += gen-testsuite-part
 
-$(generated_TESTS) $(srcdir)/t/testsuite-part.am: \
-  $(srcdir)/gen-testsuite-part \
-  t/list-of-tests.mk \
-  Makefile.am \
-  $(handwritten_TESTS)
+## The dependecies declared here are not truly complete, but such
+## completeness would cause more issues than it would solve.  See
+## automake bug#11347.
+$(generated_TESTS): $(srcdir)/gen-testsuite-part
+$(srcdir)/t/testsuite-part.am: $(srcdir)/gen-testsuite-part Makefile.am
+
+# Hand-written tests for stuff in 'contrib/'.
+include $(srcdir)/contrib/t/local.am
+TESTS += $(contrib_TESTS)
+EXTRA_DIST += $(contrib_TESTS)
 
 # Static dependencies valid for each test case.
 check_SCRIPTS = t/wrap/aclocal-$(APIVERSION) t/wrap/automake-$(APIVERSION)
-dist_check_DATA = t/ax/plain-functions.sh t/ax/tap-functions.sh
-check_DATA = defs defs-static
+dist_check_DATA = \
+  t/ax/test-init.sh  \
+  t/ax/plain-functions.sh  \
+  t/ax/tap-functions.sh
+nodist_check_DATA = defs-static
 
 # Few more static dependencies.
 t/distcheck-missing-m4.log: t/ax/distcheck-hook-m4.am
 t/distcheck-outdated-m4.log: t/ax/distcheck-hook-m4.am
 EXTRA_DIST += t/ax/distcheck-hook-m4.am
 
-# Keep in sync with AC_SUBST'd stuff in defs-static.in.
-do_subst_t = sed \
-  -e 's|@abs_srcdir[@]|$(abs_srcdir)|g' \
-  -e 's|@abs_top_srcdir[@]|$(abs_top_srcdir)|g' \
-  -e 's|@abs_builddir[@]|$(abs_builddir)|g' \
-  -e 's|@abs_top_builddir[@]|$(abs_top_builddir)|g' \
-  -e 's|@prefix[@]|$(prefix)|g' \
-  -e 's|@amdir[@]|$(amdir)|g' \
-  -e 's|@bindir[@]|$(bindir)|g' \
-  -e 's|@datadir[@]|$(datadir)|g' \
-  -e 's|@docdir[@]|$(docdir)|g' \
-  -e 's|@automake_acdir[@]|$(automake_acdir)|g' \
-  -e 's|@system_acdir[@]|$(system_acdir)|g' \
-  -e 's|@scriptdir[@]|$(scriptdir)|g' \
-  -e 's|@pkgvdatadir[@]|$(pkgvdatadir)|g' \
-  -e 's|@host_alias[@]|$(host_alias)|g' \
-  -e 's|@build_alias[@]|$(build_alias)|g' \
-  -e 's|@APIVERSION[@]|$(APIVERSION)|g' \
-  -e 's|@PATH_SEPARATOR[@]|$(PATH_SEPARATOR)|g' \
-  -e 's|@SHELL[@]|$(SHELL)|g' \
-  -e 's|@AWK[@]|$(AWK)|g' \
-  -e 's|@PERL[@]|$(PERL)|g' \
-  -e 's|@EGREP[@]|$(EGREP)|g' \
-  -e 's|@FGREP[@]|$(FGREP)|g' \
-  -e 's|@CPPFLAGS[@]|$(CPPFLAGS)|g' \
-  -e 's|@CC[@]|$(CC)|g' \
-  -e 's|@CFLAGS[@]|$(CFLAGS)|g' \
-  -e 's|@CXX[@]|$(CXX)|g' \
-  -e 's|@CXXFLAGS[@]|$(CXXFLAGS)|g' \
-  -e 's|@F77[@]|$(F77)|g' \
-  -e 's|@FFLAGS[@]|$(FFLAGS)|g' \
-  -e 's|@FC[@]|$(FC)|g' \
-  -e 's|@FCFLAGS[@]|$(FCFLAGS)|g' \
-  -e 's|@GNU_CC[@]|$(GNU_CC)|g' \
-  -e 's|@GNU_CFLAGS[@]|$(GNU_CFLAGS)|g' \
-  -e 's|@GNU_CXX[@]|$(GNU_CXX)|g' \
-  -e 's|@GNU_CXXFLAGS[@]|$(GNU_CXXFLAGS)|g' \
-  -e 's|@GNU_F77[@]|$(GNU_F77)|g' \
-  -e 's|@GNU_FFLAGS[@]|$(GNU_FFLAGS)|g' \
-  -e 's|@GNU_FC[@]|$(GNU_FC)|g' \
-  -e 's|@GNU_FCFLAGS[@]|$(GNU_FCFLAGS)|g' \
-  -e 's|@GNU_GCJ[@]|$(GNU_GCJ)|g' \
-  -e 's|@GNU_GCJFLAGS[@]|$(GNU_GCJFLAGS)|g' \
-  -e 's|@YACC[@]|$(YACC)|g' \
-  -e 's|@LEX[@]|$(LEX)|g' \
-  -e 's|@TEX[@]|$(TEX)|g' \
-  -e 's|@MODIFICATION_DELAY[@]|$(MODIFICATION_DELAY)|g' \
-  -e 's|@am_AUTOCONF[@]|$(am_AUTOCONF)|g' \
-  -e 's|@am_AUTOM4TE[@]|$(am_AUTOM4TE)|g' \
-  -e 's|@am_AUTORECONF[@]|$(am_AUTORECONF)|g' \
-  -e 's|@am_AUTOHEADER[@]|$(am_AUTOHEADER)|g' \
-  -e 's|@am_AUTOUPDATE[@]|$(am_AUTOUPDATE)|g' \
-  -e 's|@sh_errexit_works[@]|$(sh_errexit_works)|g' \
-  -e 's|@configure_input[@]|Generated from $@.in.  DO NOT EDIT BY HAND!|'
-
-defs-static: defs-static.in
+defs-static: defs-static.in Makefile
        $(AM_V_at)rm -f $@ $@-t
-       $(AM_V_GEN)$(do_subst_t) $(srcdir)/defs-static.in >$@-t
-       $(AM_V_at) : Sanity check on the substitutions; \
-       if LC_ALL=C grep '@[a-zA-Z0-9_][a-zA-Z0-9_]*@' $@-t; then \
-         echo "$@ contains unexpanded substitution (see lines above)"; \
-         exit 1; \
-       fi
-       $(AM_V_at)chmod a-w $@-t && mv -f $@-t $@
+       $(AM_V_GEN)in=defs-static.in\
+         && $(do_subst) <$(srcdir)/defs-static.in >$@-t
+       $(generated_file_finalize)
 EXTRA_DIST += defs-static.in
 CLEANFILES += defs-static
 
@@ -476,7 +421,7 @@ check-local: check-no-repeated-test-name
 .PHONY: check-no-repeated-test-name
 
 ## Checking the list of tests.
-test_subdirs = t t/pm
+test_subdirs = t t/pm t/perf
 include $(srcdir)/t/CheckListOfTests.am
 
 # Run the testsuite with the installed aclocal and automake.
@@ -504,31 +449,33 @@ info_TEXINFOS = doc/automake.texi doc/automake-history.texi
 doc_automake_TEXINFOS = doc/fdl.texi
 doc_automake_history_TEXINFOS = doc/fdl.texi
 
-dist_man1_MANS = \
-  $(srcdir)/doc/aclocal.1 \
-  $(srcdir)/doc/automake.1 \
-  $(srcdir)/doc/aclocal-$(APIVERSION).1 \
-  $(srcdir)/doc/automake-$(APIVERSION).1
+man1_MANS = \
+  doc/aclocal.1 \
+  doc/automake.1 \
+  doc/aclocal-$(APIVERSION).1 \
+  doc/automake-$(APIVERSION).1
 
-$(dist_man1_MANS): $(srcdir)/configure.ac
+$(man1_MANS): $(srcdir)/configure.ac
 
-MAINTAINERCLEANFILES += $(dist_man1_MANS)
+CLEANFILES += $(man1_MANS)
+EXTRA_DIST += doc/help2man
 
 update_mans = \
   $(AM_V_GEN): \
-    && $(MAKE) $(AM_MAKEFLAGS) lib/Automake/Config.pm \
+    && $(MKDIR_P) doc \
     && PATH="$(abs_builddir)/t/wrap$(PATH_SEPARATOR)$$PATH" \
     && export PATH \
-    && $(HELP2MAN) --output=$@
+    && $(PERL) $(srcdir)/doc/help2man --output=$@
 
-$(srcdir)/doc/aclocal.1 $(srcdir)/doc/automake.1:
+doc/aclocal.1 doc/automake.1:
        $(AM_V_GEN): \
+         && $(MKDIR_P) doc \
          && f=`echo $@ | sed 's|.*/||; s|\.1$$||; $(transform)'` \
          && echo ".so man1/$$f-$(APIVERSION).1" > $@
 
-$(srcdir)/doc/aclocal-$(APIVERSION).1: $(srcdir)/aclocal.in
+doc/aclocal-$(APIVERSION).1: aclocal.in aclocal lib/Automake/Config.pm
        $(update_mans) aclocal-$(APIVERSION)
-$(srcdir)/doc/automake-$(APIVERSION).1: $(srcdir)/automake.in
+doc/automake-$(APIVERSION).1: automake.in automake lib/Automake/Config.pm
        $(update_mans) automake-$(APIVERSION)
 
 
@@ -666,11 +613,6 @@ ChangeLog: am--changelog-regen-hook
          exit 1; \
        fi
 
-# Ensure tests are world-executable.
-# FIXME: this should be turned into a maintainer check...
-dist-hook:
-       $(am__cd) $(distdir)/t && chmod a+rx *.sh *.tap
-
 
 ## --------------------------- ##
 ##  Perl coverage statistics.  ##
@@ -752,9 +694,6 @@ git-tag-release: maintainer-check
        esac; \
        $(determine_release_type); \
        $(git_must_have_clean_workdir); \
-## Make sure the NEWS file is up-to-date.
-       sed 1q $(srcdir)/NEWS | grep '$(VERSION)' >/dev/null \
-         || fatal "NEWS not updated"; \
 ## If all was successful, tag the release in the local repository.
        $$run $(GIT) tag -s "v$(VERSION)" -m "$$release_type $(VERSION)"
 
@@ -797,7 +736,7 @@ autodiffs:
               && $(am__cd) tmp \
               && $(GIT) checkout -q "$$rev" \
               && echo "$@: bootstrapping $$rev" \
-              && $(SHELL) ./bootstrap \
+              && $(SHELL) ./bootstrap.sh \
               && echo "$@: copying files from $$rev" \
               && makefile_ins=`find . -name Makefile.in` \
               && (tar cf - configure aclocal.m4 $$makefile_ins) | \
@@ -915,7 +854,12 @@ update_copyright_env = \
 
 .PHONY: update-copyright
 update-copyright:
-       $(AM_V_GEN)excluded_re=`echo $(FETCHFILES) \
+       $(AM_V_GEN)set -e; \
+       current_year=`date +%Y` && test -n "$$current_year" \
+         || { echo "$@: cannot get current year" >&2; exit 1; }; \
+       sed -i "/^RELEASE_YEAR=/s/=.*$$/=$$current_year/" \
+         bootstrap.sh configure.ac; \
+       excluded_re=`echo $(FETCHFILES) \
          | sed -e 's|^|lib/|' -e 's| | lib/|g' -e 's, ,|,g'`; \
        $(GIT) ls-files \
          | grep -Ev '^(lib/)?(COPYING|INSTALL)$$' \