1 ## Process this file with automake to create Makefile.in
3 ## Makefile for Automake.
5 ## Copyright (C) 1995, 1996, 1997, 1998, 1999, 2001, 2002, 2003, 2004,
6 ## 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
8 ## This program is free software; you can redistribute it and/or modify
9 ## it under the terms of the GNU General Public License as published by
10 ## the Free Software Foundation; either version 3, or (at your option)
13 ## This program is distributed in the hope that it will be useful,
14 ## but WITHOUT ANY WARRANTY; without even the implied warranty of
15 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 ## GNU General Public License for more details.
18 ## You should have received a copy of the GNU General Public License
19 ## along with this program. If not, see <http://www.gnu.org/licenses/>.
21 ## lib goes first, because it builds Config.pm, used by aclocal and
22 ## automake (run in doc, tests, and in the rebuild rules.)
23 ## `.' goes before doc and tests, because the latter two directories
24 ## run aclocal and automake.
25 SUBDIRS = lib . doc m4 tests
27 bin_SCRIPTS = automake aclocal
29 CLEANFILES = $(bin_SCRIPTS)
30 AUTOMAKESOURCES = automake.in aclocal.in
32 TAGS_FILES = $(AUTOMAKESOURCES)
44 ## Make versioned links. We only run the transform on the root name;
45 ## then we make a versioned link with the transformed base name. This
46 ## seemed like the most reasonable approach.
49 @for p in $(bin_SCRIPTS); do \
50 f="`echo $$p|sed '$(transform)'`"; \
51 fv="$$f-$(APIVERSION)"; \
52 rm -f $(DESTDIR)$(bindir)/$$fv; \
53 echo " $(LN) $(DESTDIR)$(bindir)/$$f $(DESTDIR)$(bindir)/$$fv"; \
54 $(LN) $(DESTDIR)$(bindir)/$$f $(DESTDIR)$(bindir)/$$fv; \
58 @for p in $(bin_SCRIPTS); do \
59 f="`echo $$p|sed '$(transform)'`"; \
60 fv="$$f-$(APIVERSION)"; \
61 rm -f $(DESTDIR)$(bindir)/$$fv; \
65 ## We can't use configure to do the substitution here; we must do it
66 ## by hand. We use a funny notation here to avoid configure
67 ## substitutions in our text.
69 -e 's,[@]APIVERSION[@],$(APIVERSION),g' \
70 -e 's,[@]PACKAGE[@],$(PACKAGE),g' \
71 -e 's,[@]PATH_SEPARATOR[@],$(PATH_SEPARATOR),g' \
72 -e 's,[@]PERL[@],$(PERL),g' \
73 -e 's,[@]SHELL[@],$(SHELL),g' \
74 -e 's,[@]VERSION[@],$(VERSION),g' \
75 -e 's,[@]configure_input[@],Generated from $@.in; do not edit by hand.,g' \
76 -e 's,[@]datadir[@],$(datadir),g'
78 ## These files depend on Makefile so they are rebuilt if $(VERSION),
79 ## $(datadir) or other do_subst'ituted variables change.
80 ## Use chmod a-w to prevent people from editing the wrong file by accident.
83 automake aclocal: Makefile
85 $(do_subst) $(srcdir)/$@.in >$@.tmp
90 ## The master location for INSTALL is lib/INSTALL.
91 ## This is where `make fetch' will install new versions.
92 ## Make sure we also update this copy.
94 cp $(srcdir)/lib/INSTALL $@
96 ################################################################
98 ## Everything past here is useful to the maintainer, but probably not
102 # Ensure tests are world-executable
104 cd $(distdir)/tests && chmod a+rx *.test
106 # Some simple checks, and then ordinary check. These are only really
107 # guaranteed to work on my machine.
108 maintainer-check: automake aclocal
109 ## This check avoids accidental configure substitutions in the source.
110 ## There are exactly 6 lines that should be modified. This works out
111 ## to 22 lines of diffs.
112 @if test `diff $(srcdir)/automake.in automake | wc -l` -ne 22; then \
113 echo "found too many diffs between automake.in and automake"; 1>&2; \
114 diff -c $(srcdir)/automake.in automake; \
117 ## Syntax check with default Perl (on my machine, Perl 5).
118 perllibdir="./lib$(PATH_SEPARATOR)$(srcdir)/lib" $(PERL) -c -w automake
119 perllibdir="./lib$(PATH_SEPARATOR)$(srcdir)/lib" $(PERL) -c -w aclocal
120 ## expect no instances of '${...}'. However, $${...} is ok, since that
121 ## is a shell construct, not a Makefile construct.
122 @if grep -F '$${' $(srcdir)/lib/am/[a-z]*.am | \
123 grep -F -v '$$$$'; then \
124 echo "Found too many uses of '\$${' in the lines above." 1>&2; \
127 ## Make sure `rm' is called with `-f'.
128 @if grep -v '^#' $(srcdir)/lib/am/[a-z]*.am $(srcdir)/tests/*.test | \
129 grep -E '\<rm ([^-]|\-[^f ]*\>)'; then \
130 echo "Suspicious 'rm' invocation." 1>&2; \
133 ## Never use something like `for file in $(FILES)', this doesn't work
134 ## if FILES is empty or if it contains shell meta characters (e.g. $ is
135 ## commonly used in Java filenames).
136 @if grep 'for .* in \$$(' $(srcdir)/lib/am/[a-z]*.am; then \
137 echo 'Use "list=$$(mumble); for var in $$$$list".' 1>&2 ; \
140 ## Make sure all invocations of mkinstalldirs are correct.
141 @if grep -n 'mkinstalldirs' $(srcdir)/lib/am/[a-z]*.am | \
142 grep -F -v '$$(mkinstalldirs)'; then \
143 echo "Found incorrect use of mkinstalldirs in the lines above" 1>&2; \
146 ## Make sure all calls to PRE/NORMAL/POST_INSTALL/UNINSTALL
147 @if grep -E -n '\((PRE|NORMAL|POST)_(|UN)INSTALL\)' \
148 $(srcdir)/lib/am/[a-z]*.am | \
149 grep -v ':##' | grep -v ': @\$$('; then \
150 echo "Found incorrect use of PRE/NORMAL/POST_INSTALL/UNINSTALL in the lines above" 1>&2; \
153 ## We never want to use "undef", only "delete", but for $/.
154 @if grep -n -w 'undef ' $(srcdir)/automake.in | \
155 grep -F -v 'undef $$/'; then \
156 echo "Found undef in automake.in; use delete instead" 1>&2; \
159 ## We never want split (/ /,...), only split (' ', ...).
160 @if grep -n 'split (/ /' $(srcdir)/automake.in; then \
161 echo "Found bad split in the lines above." 1>&2; \
164 ## Look for cd within backquotes
165 @if grep -n '^[^#]*` *cd ' $(srcdir)/automake.in \
166 $(srcdir)/lib/am/*.am; then \
167 echo "Consider using \$$(am__cd) in the lines above." 1>&2; \
170 ## Look for cd to a relative directory (may be influenced by CDPATH).
171 ## Skip some known directories that are OK.
172 @if grep -n '^[^#]*cd ' $(srcdir)/automake.in \
173 $(srcdir)/lib/am/*.am | \
174 grep -v 'echo.*cd ' | \
175 grep -v 'am__cd =' | \
176 grep -v '^[^#]*cd [./]' | \
177 grep -v '^[^#]*cd \$$(top_builddir)' | \
178 grep -v '^[^#]*cd "\$$\$$am__cwd' | \
179 grep -v '^[^#]*cd \$$(abs' | \
180 grep -v '^[^#]*cd "\$$(DESTDIR)'; then \
181 echo "Consider using \$$(am__cd) in the lines above." 1>&2; \
184 ## Using @_ in a scalar context is most probably a programming error.
185 @if grep -Hn '[^@_A-Za-z0-9][_A-Za-z0-9]*[^) ] *= *@_' $(srcdir)/automake.in; then \
186 echo "Using @_ in a scalar context in the lines above." 1>&2; \
189 ## Forbid using parens with `local' to ease counting.
190 @if grep '^[ \t]*local *(' $(srcdir)/automake.in; then \
191 echo "Don't use \`local' with parens: use several \`local' above." >&2; \
194 ## Allow only `local $_' in Automake.
195 @if grep -v '^[ \t]*local \$$_;' $(srcdir)/automake.in | \
196 grep '^[ \t]*local [^*]'; then \
197 echo "Please avoid \`local'." 1>&2; \
200 ## Don't let AMDEP_TRUE substitution appear in automake.in.
201 @if grep '@AMDEP''_TRUE@' $(srcdir)/automake.in; then \
202 echo "Don't put AMDEP_TRUE substitution in automake.in" 1>&2; \
205 ## Tests should never call make directly.
206 @if grep '^[^#].*(MAKE) ' $(srcdir)/lib/am/*.am $(srcdir)/automake.in |\
207 grep -v 'AM_MAKEFLAGS'; then \
208 echo 'Use $$(MAKE) $$(AM_MAKEFLAGS).' 1>&2; \
211 ## Tests should never call make directly.
212 @if grep -v '^#' $(srcdir)/tests/*.test | grep ':[ ]*make'; then \
213 echo 'Do not run "make" in the above tests. Use "$$MAKE" instead.' 1>&2; \
216 ## Tests should never call autoconf directly.
217 @if grep -v '^#' $(srcdir)/tests/*.test | grep ':[ ]*autoconf'; then \
218 echo 'Do not run "autoconf" in the above tests. Use "$$AUTOCONF" instead.' 1>&2; \
221 ## Tests should never call autoupdate directly.
222 @if grep -v '^#' $(srcdir)/tests/*.test | grep ':[ ]*autoupdate'; then \
223 echo 'Do not run "autoupdate" in the above tests. Use "$$AUTOUPDATE" instead.' 1>&2; \
226 ## Tests should never call automake directly.
227 @if grep -v '^#' $(srcdir)/tests/*.test | grep -E ':[ ]*automake([^:]|$$)'; then \
228 echo 'Do not run "automake" in the above tests. Use "$$AUTOMAKE" instead.' 1>&2; \
231 ## Tests should only use END and EOF for here documents
232 ## (so that the next test is effective).
233 @if grep '<<' $(srcdir)/tests/*.test | grep -v 'END' | grep -v 'EOF'; then \
234 echo 'Use here documents with "END" and "EOF" only, for greppability.' 1>&2; \
237 ## Tests should never call exit directly, but use Exit.
238 ## This is so that the exit status is transported correctly across the 0 trap.
239 ## Ignore comments, and ignore one perl line in ext2.test.
240 @found=false; for file in $(srcdir)/tests/*.test; do \
241 res=`sed -n '/^#/d; /^\$$PERL/d; /<<.*END/,/^END/{b;}; /<<.*EOF/,/^EOF/{b;}; /exit [$$0-9]/p' $$file`; \
242 if test -n "$$res"; then \
243 echo "$$file:$$res"; \
248 echo 'Do not call plain "exit", use "Exit" instead, in above tests.' 1>&2; \
251 ## Use AUTOMAKE_fails when appropriate
252 @if grep -v '^#' $(srcdir)/tests/*.test | grep '\$$AUTOMAKE.*&&.*[eE]xit'; then \
253 echo 'Use AUTOMAKE_fails + grep to catch automake failures in the above tests.' 1>&2; \
256 ## Tests should never call aclocal directly.
257 @if grep -v '^#' $(srcdir)/tests/*.test | grep ':[ ]*aclocal'; then \
258 echo 'Do not run "aclocal" in the above tests. Use "$$ACLOCAL" instead.' 1>&2; \
261 ## Tests should never call perl directly.
262 @if grep -v '^#' $(srcdir)/tests/*.test | grep ':[ ]*perl'; then \
263 echo 'Do not run "perl" in the above tests. Use "$$PERL" instead.' 1>&2; \
266 ## Setting `required' after sourcing `./defs' is a bug.
267 @for file in $(srcdir)/tests/*.test; do \
268 if out=`sed -n '/defs/,$${/required=/p;}' $$file`; test -n "$$out"; then \
269 echo 'Do not set "required" after sourcing "defs" in '"$$file: $$out" 1>&2; \
273 ## Overriding a Makefile macro on the command line is not portable when
274 ## recursive targets are used. Better use an envvar. SHELL is an exception,
275 ## POSIX says it can't come from the environment.
276 @if grep -E '\$$MAKE .*(SHELL=.*=|=.*SHELL=)' $(srcdir)/tests/*.test; then \
277 echo 'Rewrite "$$MAKE foo=bar SHELL=$$SHELL" as "foo=bar $$MAKE -e SHELL=$$SHELL"' 1>&2; \
278 echo ' in the above lines, it is more portable.' 1>&2; \
281 @if grep -v SHELL $(srcdir)/tests/*.test | grep '\$$MAKE .*=' ; then \
282 echo 'Rewrite "$$MAKE foo=bar" as "foo=bar $$MAKE -e" in the above lines,' 1>&2; \
283 echo 'it is more portable.' 1>&2; \
286 @if grep 'SHELL=.*\$$MAKE' $(srcdir)/tests/*.test; then \
287 echo '$$MAKE ignores the SHELL envvar, use "$$MAKE SHELL=$$SHELL" in' 1>&2; \
288 echo 'the above lines.' 1>&2; \
291 ## Never use `sleep 1' to create files with different timestamps.
292 ## Use `$sleep' instead. Some filesystems (e.g., Windows') have only
293 ## a 2sec resolution.
294 @if grep -E '\bsleep +[12345]\b' $(srcdir)/tests/*.test; then \
295 echo 'Do not use "sleep x" in the above tests. Use "$$sleep" instead.' 1>&2; \
298 ## fgrep and egrep are not required by POSIX.
299 @if grep -E '\b[ef]grep\b' $(srcdir)/tests/*.test ; then \
300 echo 'Do not use egrep or fgrep in test cases. Use $$FGREP or $$EGREP.' 1>&2; \
303 @if grep -E '\b[ef]grep\b' $(srcdir)/lib/am/*.am $(srcdir)/m4/*.m4; then \
304 echo 'Do not use egrep or fgrep in the above files, they are not portable.' 1>&2; \
307 @if grep 'mkdir_p' $(srcdir)/automake.in \
308 $(srcdir)/lib/am/*.am $(srcdir)/tests/*.test; then \
309 echo 'Do not use mkdir_p in the above files, use MKDIR_P.' 1>&2; \
312 ## Try to make sure all @...@ substitutions are covered by our
313 ## substitution rule.
314 @if test `grep -E '^[^#]*@[A-Za-z_0-9]+@' aclocal | wc -l` -ne 0; then \
315 echo "Unresolved @...@ substitution in aclocal" 1>&2; \
318 @if test `grep -E '^[^#]*@[A-Za-z_0-9]+@' automake | wc -l` -ne 0; then \
319 echo "Unresolved @...@ substitution in automake" 1>&2; \
322 if grep -E "[^\'\"]\\\$$\(DESTDIR" $(srcdir)/lib/am/*.am; then \
323 echo 'Suspicious unquoted DESTDIR uses.' 1>&2 ; \
326 @if grep ' ' $(srcdir)/doc/automake.texi; then \
327 echo 'Do not use tabs in the manual.' 1>&2; \
330 @if grep -E '([^@]|^)@([ ][^@]|$$)' $(srcdir)/doc/automake.texi; \
332 echo 'Unescaped @.' 1>&2; \
337 git-dist: maintainer-check
338 ## Make sure clcommit exists (we use it at the end of git-dist).
339 @if (clcommit --version)>/dev/null 2>/dev/null; then :; else \
340 echo "Get clcommit from module cvs-utils on Savannah."; \
343 ## Make sure the NEWS file is up-to-date.
344 @if sed 1q $(srcdir)/NEWS | grep -e "$(VERSION)" > /dev/null; then :; else \
345 echo "NEWS not updated; not releasing" 1>&2; \
348 ## Build the distribution
350 ## Finally, if anything was successful, commit the last changes and tag
351 ## the release in the repository. We don't use RCS keywords so it's OK
352 ## to distribute the files before they were committed.
353 cd $(srcdir) && clcommit && \
354 git tag -s `echo "Release-$(VERSION)" | sed 's/\./-/g'`
356 git-release: git-dist
358 *[a-z]) dest=alpha;; \
361 $(srcdir)/lib/gnupload $(GNUPLOADFLAGS) \
362 --to sources.redhat.com:~ftp/pub/automake \
363 --to $$dest.gnu.org:automake $(DIST_ARCHIVES)
366 thisver=`echo "Release-$(VERSION)" | sed 's/\./-/g'`; \
367 if test -z "$$OLDVERSION"; then \
368 prevno=`echo "$(VERSION)" - 0.01 | bc | sed 's/^\./0./'`; \
369 else prevno="$$OLDVERSION"; fi; \
370 prevver=Release-`echo $$prevno | sed 's/\./-/g'`; \
371 cvs -f rdiff -c -r $$prevver -r $$thisver $(PACKAGE) \
372 > $(PACKAGE)-$$prevno-$(VERSION).diff
375 thisver=`echo "Release-$(VERSION)" | sed 's/\./-/g'`; \
376 if test -z "$$OLDVERSION"; then \
377 prevno=`echo "$(VERSION)" - 0.01 | bc | sed 's/^\./0./'`; \
378 else prevno="$$OLDVERSION"; fi; \
379 prevver=Release-`echo $$prevno | sed 's/\./-/g'`; \
380 git diff $$prevver $$thisver $(PACKAGE) \
381 > $(PACKAGE)-$$prevno-$(VERSION).diff
383 ## Check our path lengths.
386 ## FIXME there's got to be a better way! pathchk should take the list
387 ## of files on stdin, at least.
388 find . -print | xargs pathchk -p); \
390 chmod -R a+w $(distdir) > /dev/null 2>&1; rm -rf $(distdir); \
393 ## Program to use to fetch files.
395 WGET_SV_CVS = $(WGET) http://savannah.gnu.org/cgi-bin/viewcvs/~checkout~/
396 WGET_SV_GIT_CF = $(WGET) 'http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;hb=HEAD;f='
397 WGET_SV_GIT_AC = $(WGET) 'http://git.savannah.gnu.org/gitweb/?p=autoconf.git;a=blob_plain;hb=HEAD;f='
398 WGET_SV_GIT_GL = $(WGET) 'http://git.savannah.gnu.org/gitweb/?p=gnulib.git;a=blob_plain;hb=HEAD;f='
399 WGET_GCC = $(WGET) 'http://gcc.gnu.org/viewcvs/*checkout*/trunk/'
401 ## Files that we fetch and which we compare against.
402 ## FIXME should be a lot more here
411 ## Fetch the latest versions of files we care about.
413 rm -rf Fetchdir > /dev/null 2>&1
415 ## If a get fails then that is a problem.
417 $(WGET_SV_GIT_CF)config.guess -O config.guess && \
418 $(WGET_SV_GIT_CF)config.sub -O config.sub && \
419 $(WGET_SV_CVS)texinfo/texinfo/doc/texinfo.tex -O texinfo.tex && \
420 $(WGET_SV_GIT_GL)doc/INSTALL -O INSTALL && \
421 $(WGET_GCC)config-ml.in -O config-ml.in && \
422 $(WGET_GCC)symlink-tree -O symlink-tree)
423 ## Don't exit after test because we want to give as many errors as
425 @stat=0; for file in $(FETCHFILES); do \
426 if diff -u $(srcdir)/lib/$$file Fetchdir/$$file \
427 >>Fetchdir/update.patch 2>/dev/null; then :; \
430 echo "Updating $(srcdir)/lib/$$file..."; \
431 cp Fetchdir/$$file $(srcdir)/lib/$$file; \
435 echo "See Fetchdir/update.patch for a log of the changes."; \