* Makefile.am (git-dist, git-release): Renamed and adjusted from ...
(cvs-dist, cvs-release): ... these.
(git-diff): New target, taken and adjusted from cvs-diff.
* Makefile.in: Regenerate.
* bootstrap: Adjust.
* NEWS: Announce change.
* doc/automake.texi (General Operation): cvs-dist is git-dist now.
(Timeline): Mention change.
+2007-10-29 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
+
+ Move to git as primary source repository.
+ * Makefile.am (git-dist, git-release): Renamed and adjusted from ...
+ (cvs-dist, cvs-release): ... these.
+ (git-diff): New target, taken and adjusted from cvs-diff.
+ * Makefile.in: Regenerate.
+ * bootstrap: Adjust.
+ * NEWS: Announce change.
+ * doc/automake.texi (General Operation): cvs-dist is git-dist now.
+ (Timeline): Mention change.
+
2007-10-09 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
* automake.in: Treat extension .sx also like preprocessed
================================================================
-= Working with CVS
+= Working with git/CVS
* To regenerate dependent files created by aclocal and automake,
use the `bootstrap' script. It uses the code from the source
automake and use it to generate those files.
* Dependent files aclocal.m4, configure and Makefile.in in all
- directories should be up to date in the CVS repository, so that
+ directories should be up to date in the git repository, so that
the changes in them can be easily noticed and analyzed.
+* Avoid merge commits on the master branch of the public git repository.
+ For unpublished changes in your development tree, it's easiest to
+ rebase against the current master before applying them, this preserves
+ a linear history.
+
+* For changes to appear in more than one branch, apply them to the
+ master branch and then cherry-pick them to the stable branch from
+ master if possible. This keeps the master uncluttered and preserves
+ meta-data on the stable branches.
+
================================================================
= Test suite
* Run ./bootstrap, ./configure, make.
-* Run `make cvs-release'.
+* NOTE: the next step has not been tested yet with git, so be careful.
+
+* Run `make git-release'.
This will run distcheck to create the tarballs, commit the last
NEWS/configure.ac/ChangeLog changes, tag the repository, sign
the tarballs, and upload them.
- Use `make GNUPLOADFLAGS="--user key" cvs-release' to sign with
+ Use `make GNUPLOADFLAGS="--user key" git-release' to sign with
a non-default key.
* Update version number in configure.ac to next alpha number.
-----
-Copyright (C) 2003 Free Software Foundation, Inc.
+Copyright (C) 2003, 2007 Free Software Foundation, Inc.
This file is part of GNU Automake.
## Makefile for Automake.
## Copyright (C) 1995, 1996, 1997, 1998, 1999, 2001, 2002, 2003, 2004,
-## 2005, 2006 Free Software Foundation, Inc.
+## 2005, 2006, 2007 Free Software Foundation, 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
fi
-cvs-dist: maintainer-check
-## Make sure clcommit exists (we use it at the end of cvs-dist).
+git-dist: maintainer-check
+## Make sure clcommit exists (we use it at the end of git-dist).
@if (clcommit --version)>/dev/null 2>/dev/null; then :; else \
echo "Get clcommit from module cvs-utils on Savannah."; \
exit 1; \
## the release in the repository. We don't use RCS keywords so it's OK
## to distribute the files before they were committed.
cd $(srcdir) && clcommit && \
- cvs -q tag -c `echo "Release-$(VERSION)" | sed 's/\./-/g'`
+ git tag -s `echo "Release-$(VERSION)" | sed 's/\./-/g'`
-cvs-release: cvs-dist
+git-release: git-dist
case $(VERSION) in \
*[a-z]) dest=alpha;; \
*) dest=ftp;; \
cvs -f rdiff -c -r $$prevver -r $$thisver $(PACKAGE) \
> $(PACKAGE)-$$prevno-$(VERSION).diff
+git-diff:
+ thisver=`echo "Release-$(VERSION)" | sed 's/\./-/g'`; \
+ if test -z "$$OLDVERSION"; then \
+ prevno=`echo "$(VERSION)" - 0.01 | bc | sed 's/^\./0./'`; \
+ else prevno="$$OLDVERSION"; fi; \
+ prevver=Release-`echo $$prevno | sed 's/\./-/g'`; \
+ git diff $$prevver $$thisver $(PACKAGE) \
+ > $(PACKAGE)-$$prevno-$(VERSION).diff
+
## Check our path lengths.
path-check: distdir
(cd $(distdir) && \
exit 1; \
fi
-cvs-dist: maintainer-check
+git-dist: maintainer-check
@if (clcommit --version)>/dev/null 2>/dev/null; then :; else \
echo "Get clcommit from module cvs-utils on Savannah."; \
exit 1; \
fi
$(MAKE) distcheck
cd $(srcdir) && clcommit && \
- cvs -q tag -c `echo "Release-$(VERSION)" | sed 's/\./-/g'`
+ git tag -s `echo "Release-$(VERSION)" | sed 's/\./-/g'`
-cvs-release: cvs-dist
+git-release: git-dist
case $(VERSION) in \
*[a-z]) dest=alpha;; \
*) dest=ftp;; \
cvs -f rdiff -c -r $$prevver -r $$thisver $(PACKAGE) \
> $(PACKAGE)-$$prevno-$(VERSION).diff
+git-diff:
+ thisver=`echo "Release-$(VERSION)" | sed 's/\./-/g'`; \
+ if test -z "$$OLDVERSION"; then \
+ prevno=`echo "$(VERSION)" - 0.01 | bc | sed 's/^\./0./'`; \
+ else prevno="$$OLDVERSION"; fi; \
+ prevver=Release-`echo $$prevno | sed 's/\./-/g'`; \
+ git diff $$prevver $$thisver $(PACKAGE) \
+ > $(PACKAGE)-$$prevno-$(VERSION).diff
+
path-check: distdir
(cd $(distdir) && \
find . -print | xargs pathchk -p); \
* Miscellaneous changes:
+ - Automake development is done in a git repository on Savannah now, see
+
+ http://git.sv.gnu.org/gitweb/?p=automake.git
+
+ A read-only CVS mirror is provided at
+
+ cvs -d :pserver:anonymous@pserver.git.sv.gnu.org:/automake.git \
+ checkout -d automake HEAD
+
- "make dist" can now create lzma-compressed tarballs.
- Automake is licensed under GPLv3+. `automake --add-missing' will
#! /bin/sh
-# This script helps bootstrap automake, when checked out from CVS.
+# This script helps bootstrap automake, when checked out from git.
#
-# Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc.
+# Copyright (C) 2002, 2003, 2004, 2007 Free Software Foundation, Inc.
# written by Pavel Roskin <proski@gnu.org> September 2002
#
# This program is free software; you can redistribute it and/or modify
@cindex Non-standard targets
@cindex @code{cvs-dist}, non-standard example
@trindex cvs-dist
+@trindex git-dist
The variable definitions and rules in the @file{Makefile.am} are
copied verbatim into the generated file. This allows you to add
arbitrary code into the generated @file{Makefile.in}. For instance,
the Automake distribution includes a non-standard rule for the
-@code{cvs-dist} target, which the Automake maintainer uses to make
+@code{git-dist} target, which the Automake maintainer uses to make
distributions from his source control system.
@cindex GNU make extensions
publicly accessible CVS repository. This CVS repository is a copy of
the one Tom was using on his machine, which in turn is based on
a copy of the CVS repository of David MacKenzie. This is why we still
-have to full source history. (Automake is still on Sourceware today,
-but the host has been renamed to @code{sources.redhat.com}.)
+have to full source history. (Automake was on Sourceware until 2007-10-29,
+when it moved to a git repository on @code{savannah.gnu.org},
+but the Sourceware host had been renamed to @code{sources.redhat.com}.)
The oldest file in the administrative directory of the CVS repository
that was created on Sourceware is dated 1998-09-19, while the
Automake has ten years. This chapter of the manual was initially
written for this occasion.
+@itemx 2007-10-29 Automake repository moves to @code{savannah.gnu.org} and uses
+git as primary repository.
+
@end table
@node Dependency Tracking Evolution