diff --git a/ChangeLog b/ChangeLog index 9459bcfc..df802172 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2001-06-09 Akim Demaille + + * Makefile.maint, GNUmakefile: New, from Jim Meyering. + * config/prev-version.txt: New. + * config/move-if-change: New, for GNU libc. + 2001-06-06 Pavel Roskin * tests/atgeneral.m4 (AT_INIT): Remove "/bin/sh" after $SHELL. diff --git a/GNUmakefile b/GNUmakefile new file mode 100644 index 00000000..0c5a0715 --- /dev/null +++ b/GNUmakefile @@ -0,0 +1,32 @@ +# Having a separate GNUmakefile lets me `include' the dynamically +# generated rules created via Makefile.maint as well as Makefile.maint itself. +# This makefile is used only if you run GNU Make. +# It is necessary if you want to build targets usually of interest +# only to the maintainer. + +# Systems where /bin/sh is not the default shell need this. The $(shell) +# command below won't work with e.g. stock DOS/Windows shells. +SHELL = /bin/sh + +have-Makefile := $(shell test -f Makefile && echo yes) + +# If the user runs GNU make but has not yet run ./configure, +# give them a diagnostic. +ifeq ($(have-Makefile),yes) + +include Makefile +include $(srcdir)/Makefile.maint + +else + +all: + @echo There seems to be no Makefile in this directory. + @echo "You must run ./configure before running \`make'." + @exit 1 + +endif + +# Tell version 3.79 and up of GNU make to not build goals in this +# directory in parallel. This is necessary in case someone tries to +# build multiple targets on one command line. +.NOTPARALLEL: diff --git a/Makefile.am b/Makefile.am index 0a9b1388..48d12e93 100644 --- a/Makefile.am +++ b/Makefile.am @@ -52,7 +52,8 @@ EXTRA_DIST = ChangeLog.0 ChangeLog.1 ChangeLog.2 \ acversion.in \ autoconf.in autoheader.in autoreconf.in autoupdate.in ifnames.in \ autoscan.in \ - $(distpkgdataDATA) + $(distpkgdataDATA) \ + GNUmakefile Makefile.maint # Files that should be removed, but which Automake does not know: # the frozen files and the scripts. @@ -90,8 +91,8 @@ MAINTAINERCLEANFILES = acversion.m4 INSTALL.txt ## maintainer-check ## - -maintainer-check: +maintainer-check: maintainer-check-tests +maintainer-check-tests: cd tests && make maintainer-check ## ----------------------------------- ## @@ -203,13 +204,19 @@ autoscan: $(srcdir)/autoscan.in $(srcdir)/configure.in autoconf.m4f: $(m4sources) -## ---------- ## -## Updating. ## -## ---------- ## +## ---------------------------- ## +## Customizing Makefile.maint. ## +## ---------------------------- ## -wget-update: - $(WGET) ftp://ftp.gnu.org/gnu/GNUinfo/standards.texi -O $(srcdir)/doc/standards.texi - $(WGET) ftp://ftp.gnu.org/gnu/GNUinfo/make-stds.texi -O $(srcdir)/doc/make-stds.texi - $(WGET) ftp://ftp.gnu.org/gnu/texinfo/texinfo.tex -O $(srcdir)/doc/texinfo.tex - $(WGET) ftp://ftp.gnu.org/gnu/config/config.guess -O $(srcdir)/config/config.guess - $(WGET) ftp://ftp.gnu.org/gnu/config/config.sub -O $(srcdir)/config/config.sub +move_if_change = $(srcdir)/config/move_if_change +prev_version_file = $(srcdir)/config/prev-version.txt + +# Uploading betas. +hosts = alpha +alpha_host = alpha.gnu.org +alpha_url_dir = gnu/autoconf + +# Files to update automatically. +wget_files = $(srcdir)/config/config.guess $(srcdir)/config/config.sub \ + $(srcdir)/doc/texinfo.tex \ + $(srcdir)/doc/install.texi $(srcdir)/doc/make-stds.texi diff --git a/Makefile.in b/Makefile.in index ce956480..437b159d 100644 --- a/Makefile.in +++ b/Makefile.in @@ -93,7 +93,7 @@ nodistpkgdataDATA = autoconf.m4f pkgdata_DATA = $(distpkgdataDATA) $(nodistpkgdataDATA) -EXTRA_DIST = ChangeLog.0 ChangeLog.1 ChangeLog.2 BUGS INSTALL.txt acversion.in autoconf.in autoheader.in autoreconf.in autoupdate.in ifnames.in autoscan.in $(distpkgdataDATA) +EXTRA_DIST = ChangeLog.0 ChangeLog.1 ChangeLog.2 BUGS INSTALL.txt acversion.in autoconf.in autoheader.in autoreconf.in autoupdate.in ifnames.in autoscan.in $(distpkgdataDATA) GNUmakefile Makefile.maint # Files that should be removed, but which Automake does not know: @@ -105,6 +105,18 @@ MAINTAINERCLEANFILES = acversion.m4 INSTALL.txt edit = sed -e 's,@SHELL\@,$(SHELL),g' -e 's,@PERL\@,$(PERL),g' -e 's,@datadir\@,$(pkgdatadir),g' -e 's,@bindir\@,$(bindir),g' -e 's,@autoconf-name\@,'`echo autoconf | sed '$(transform)'`',g' -e 's,@autoheader-name\@,'`echo autoheader | sed '$(transform)'`',g' -e 's,@M4\@,$(M4),g' -e 's,@AWK\@,$(AWK),g' -e 's,@VERSION\@,$(VERSION),g' -e 's,@PACKAGE_NAME\@,$(PACKAGE_NAME),g' + +move_if_change = $(srcdir)/config/move_if_change +prev_version_file = $(srcdir)/config/prev-version.txt + +# Uploading betas. +hosts = alpha +alpha_host = alpha.gnu.org +alpha_url_dir = gnu/autoconf + +# Files to update automatically. +wget_files = $(srcdir)/config/config.guess $(srcdir)/config/config.sub $(srcdir)/doc/texinfo.tex $(srcdir)/doc/install.texi $(srcdir)/doc/make-stds.texi + ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 mkinstalldirs = $(SHELL) $(top_srcdir)/config/mkinstalldirs CONFIG_CLEAN_FILES = @@ -426,7 +438,8 @@ INSTALL.txt: $(top_srcdir)/doc/install.texi $(MAKEINFO) $< --no-headers --no-validate --no-split --output=$@ if test '$(srcdir)' != '.'; then cp $@ $(srcdir); rm -f $@; fi -maintainer-check: +maintainer-check: maintainer-check-tests +maintainer-check-tests: cd tests && make maintainer-check install-data-hook: INSTALL.txt @@ -505,13 +518,6 @@ autoscan: $(srcdir)/autoscan.in $(srcdir)/configure.in autoconf.m4f: $(m4sources) -wget-update: - $(WGET) ftp://ftp.gnu.org/gnu/GNUinfo/standards.texi -O $(srcdir)/doc/standards.texi - $(WGET) ftp://ftp.gnu.org/gnu/GNUinfo/make-stds.texi -O $(srcdir)/doc/make-stds.texi - $(WGET) ftp://ftp.gnu.org/gnu/texinfo/texinfo.tex -O $(srcdir)/doc/texinfo.tex - $(WGET) ftp://ftp.gnu.org/gnu/config/config.guess -O $(srcdir)/config/config.guess - $(WGET) ftp://ftp.gnu.org/gnu/config/config.sub -O $(srcdir)/config/config.sub - # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: diff --git a/Makefile.maint b/Makefile.maint new file mode 100644 index 00000000..b76bee85 --- /dev/null +++ b/Makefile.maint @@ -0,0 +1,223 @@ +# -*-Makefile-*- +# This Makefile fragment is shared between fileutils, sh-utils, textutils. + +maintainer-check: + if head ChangeLog| grep 'Version $(VERSION)' > /dev/null; then \ + :; \ + else \ + echo "$(VERSION) not in ChangeLog; not tagging" 1>&2; \ + exit 1; \ + fi + $(MAKE) distcheck + $(MAKE) my-distcheck + +prev_version_file ?= .prev-version + +THIS_VERSION_REGEXP = $(subst .,\.,$(VERSION)) +PREV_VERSION := $(shell cat $(prev_version_file)) +PREV_VERSION_REGEXP := $(shell echo $(PREV_VERSION)|sed 's/\./\\./g') + +tag-package = $(shell echo "$(PACKAGE)" | tr '[:lower:]' '[:upper:]') +tag-this-version = $(subst .,_,$(VERSION)) +tag-prev-version = $(subst .,_,$(PREV_VERSION)) +this-cvs-tag = $(tag-package)-$(tag-this-version) +prev-cvs-tag = $(tag-package)-$(tag-prev-version) +my_distdir = $(PACKAGE)-$(VERSION) + +# Verify that all source files using _() are listed in po/POTFILES.in. +po-check: + if test -f po/POTFILES.in; then \ + grep -E -v '^(#|$$)' po/POTFILES.in | sort > $@-1; \ + grep -E -l '\b_\(' lib/*.c src/*.c | sort > $@-2; \ + diff -u $@-1 $@-2 || exit 1; \ + rm -f $@-1 $@-2; \ + fi + +# Do not save the original name or timestamp in the .tar.gz file. +GZIP_ENV = --no-name + +# Tag before making distribution. Also, don't make a distribution if +# checks fail. Also, make sure the NEWS file is up-to-date. +# FIXME: use dist-hook/my-dist like distcheck-hook/my-distcheck. +cvs-dist: maintainer-check + echo $(this-cvs-tag); \ + if cvs -n log -h README| grep -e $(this-cvs-tag): > /dev/null; then \ + echo "VERSION not new; not tagging" 1>&2; \ + exit 1; \ + fi; \ + cvs update po; \ + cvs tag -c $(this-cvs-tag) + $(MAKE) dist + +# Use this to make sure we don't run these programs when building +# from a virgin tgz file, below. +null_AM_MAKEFLAGS = \ + ACLOCAL=false \ + AUTOCONF=false \ + AUTOMAKE=false \ + AUTOHEADER=false \ + MAKEINFO=false + +# Detect format-string/arg-list mismatches that would normally be obscured +# by the use of _(). The --disable-nls effectively defines away that macro, +# and building with CFLAGS='-Wformat -Werror' causes any format warning to be +# treated as a failure. +t=./=test +my-distcheck: writable-files po-check + -rm -rf $(t) + mkdir $(t) + GZIP=$(GZIP) $(AMTAR) -C $(t) -zxf $(distdir).tar.gz + cd $(t)/$(distdir) \ + && ./configure --disable-nls \ + && $(MAKE) CFLAGS='-Wformat -Werror' \ + AM_MAKEFLAGS='$(null_AM_MAKEFLAGS)' \ + && $(MAKE) dvi \ + && $(MAKE) check \ + && $(MAKE) distclean + cd $(t) && mv $(distdir) $(distdir).old \ + && $(AMTAR) -zxf ../$(distdir).tar.gz + diff -ur $(t)/$(distdir).old $(t)/$(distdir) + -rm -rf $(t) + @echo "========================"; \ + echo "$(distdir).tar.gz is ready for distribution"; \ + echo "========================" + +# This must be the same name on both hosts. +# Make it a symlink that points to the right place. +real_dir = fetish-ftp + +url_dir_list = $(foreach x,$(hosts),ftp://$($(x)_host)/$($(x)_url_dir)) + +md5 = $(shell md5sum < $(my_distdir).tar.gz|sed 's/ -//') +sha1 = $(shell sha1sum < $(my_distdir).tar.gz|sed 's/ -//') +tgz-size = $(shell du --human $(my_distdir).tar.gz|sed 's/M.*/MB/') +xd-size = $(shell du --human $(xd-delta)|sed 's/M.*/MB/') + +rel-check: + tarz=/tmp/rel-check-tarz-$$$$; \ + md5_tmp=/tmp/rel-check-md5-$$$$; \ + set -e; \ + trap 'status=$$?; rm -f $$tarz $$md5_tmp; exit $$status' 0 1 2 3 15; \ + wget -q --output-document=$$tarz $(url); \ + echo "$(md5) -" > $$md5_tmp; \ + md5sum -c $$md5_tmp < $$tarz + +release-archive-dir = ../release +prev-tgz = $(PACKAGE)-$(PREV_VERSION).tar.gz +xd-delta = $(PACKAGE)-$(PREV_VERSION)-$(VERSION).xdelta + +announcement: NEWS ChangeLog $(distdir).tar.gz + @( \ + echo Subject: $(my_distdir) released; \ + echo; \ + echo FIXME: put comments here; \ + echo; \ + for url in $(url_dir_list); do \ + echo " $$url/$(my_distdir).tar.gz ($(tgz-size))"; \ + done; \ + echo; \ + echo And here are xdelta-style diffs; \ + echo; \ + for url in $(url_dir_list); do \ + echo " $$url/$(xd-delta) ($(xd-size))"; \ + done; \ + echo; \ + echo "Here are the MD5 and SHA1 signatures for the .tar.gz file"; \ + echo; \ + echo "$(md5) $(my_distdir).tar.gz"; \ + echo "$(sha1) $(my_distdir).tar.gz"; \ + echo; \ + echo NEWS:; \ + sed -n "/$(THIS_VERSION_REGEXP)/,/^\[$(PREV_VERSION_REGEXP)/p" NEWS \ + | grep -v '^\['; \ + echo; \ + echo ChangeLog entries:; \ + find . -name ChangeLog -maxdepth 2 \ + | xargs cvs diff -up -r$(prev-cvs-tag) -rHEAD \ + | sed -n 's/^+//p' \ + | perl -ne 'm!^\+\+ (\./)?! or print,next;' \ + -e 'print "\n"."*"x70 ."\n"; s///; print; print "*"x70 ."\n"'; \ + ) + +writable-files: + for file in $(distdir).tar.gz $(xd-delta) \ + ../release/$(distdir).tar.gz ../release/$(xd-delta); do \ + test -e $$file || continue; \ + test -w $$file \ + || { echo ERROR: $$file is not writable; fail=1; }; \ + done; \ + test "$$fail" && exit 1 || : + +WGET = wget +ftp-gnu = ftp://ftp.gnu.org/gnu + +# Use mv, if you don't have/want move-if-change. +move-if-change ?= move-if-change + +# The following pseudo table associates a local directory and a URL +# with each of the files that belongs to some other package and is +# regularly updated from the specified URL. +wget_files ?= $(srcdir)/config.guess $(srcdir)/config.sub \ + $(srcdir)/src/ansi2knr.c \ + $(srcdir)/doc/texinfo.tex +get-targets = $(patsubst %, get-%, $(wget_files)) + +config.guess-url_prefix = $(ftp-gnu)/config/ +config.sub-url_prefix = $(ftp-gnu)/config/ + +ansi2knr.c-url_prefix = ftp://ftp.cs.wisc.edu/ghost/ + +texinfo.tex-url_prefix = $(ftp-gnu)/texinfo/ + +standards.texi-url_prefix = $(ftp-gnu)/GNUinfo/ +make-stds.texi-url_prefix = $(ftp-gnu)/GNUinfo/ + +target = $(patsubst get-%, %, $@) +url = $($(notdir $(target))-url_prefix)$(notdir $(target)) +local_file = $($(target)-local_dir)/$(target) + +.PHONY: $(get-targets) +$(get-targets): + $(WGET) $(url) -O $(target).t \ + && $(move-if-change) $(target).t $(local_file) + +automake_repo=:pserver:anoncvs@anoncvs.cygnus.com:/cvs/automake +.PHONY: wget-update +wget-update: $(get-targets) + for f in depcomp missing; do \ + test -f $$f || continue; \ + echo checking out $$f...; \ + cvs -d $(automake_repo) co -p automake/lib/$$f > $$f.t \ + && $(move-if-change) $$f.t $$f; \ + done + +define emit-rsync-commands + echo ===================================== + echo ===================================== + echo 'for host in $(a_host) $(b_host); do \' + echo ' rsync -e ssh --pro -av $(xd-delta) $(my_distdir).tar.gz \' + echo ' $$host:$(real_dir); done' + echo '# send the /tmp/announcement e-mail' + echo ===================================== + echo ===================================== +endef + +# Make sure that the copyright date in lib/version-etc.c is up to date. +check-copyright: + @if test -f lib/version-etc.c; then \ + grep 'N_("Copyright (C) $(shell date +%Y) Free' lib/version-etc.c > /dev/null \ + || { echo 'out of date copyright in $<; update it' 1>&2; exit 1; }; \ + fi + +alpha: writable-files po-check check-copyright + $(MAKE) cvs-dist + $(MAKE) -s announcement > /tmp/announce-$(my_distdir) + ln $(distdir).tar.gz ../release + chmod a-w $(distdir).tar.gz + cd $(release-archive-dir) \ + && xdelta delta -9 $(prev-tgz) $(distdir).tar.gz $(xd-delta) || : + ln $(release-archive-dir)/$(xd-delta) . + chmod a-w $(release-archive-dir)/$(xd-delta) + echo $(VERSION) > $(prev_version_file) + cvs ci -m. $(prev_version_file) + @$(emit-rsync-commands) diff --git a/config/Makefile.am b/config/Makefile.am index 234c412f..02f2cc74 100644 --- a/config/Makefile.am +++ b/config/Makefile.am @@ -1 +1 @@ -## Nothing to do here. +EXTRA_DIST = move-if-change prev-version.txt diff --git a/config/Makefile.in b/config/Makefile.in index 9cd94a5e..d472a4e6 100644 --- a/config/Makefile.in +++ b/config/Makefile.in @@ -66,6 +66,8 @@ PACKAGE_NAME = @PACKAGE_NAME@ PERL = @PERL@ PERLSCRIPTS = @PERLSCRIPTS@ VERSION = @VERSION@ + +EXTRA_DIST = move-if-change prev-version.txt mkinstalldirs = $(SHELL) $(top_srcdir)/config/mkinstalldirs CONFIG_CLEAN_FILES = DIST_COMMON = Makefile.am Makefile.in config.guess config.sub \ diff --git a/config/move-if-change b/config/move-if-change new file mode 100755 index 00000000..66d8b8ad --- /dev/null +++ b/config/move-if-change @@ -0,0 +1,17 @@ +#!/bin/sh +# Like mv $1 $2, but if the files are the same, just delete $1. +# Status is 0 if $2 is changed, 1 otherwise. +if +test -r $2 +then +if +cmp -s $1 $2 +then +echo $2 is unchanged +rm -f $1 +else +mv -f $1 $2 +fi +else +mv -f $1 $2 +fi