2002-04-22 10:11:31 +08:00
|
|
|
-*-text-*-
|
|
|
|
|
2006-02-12 03:02:21 +08:00
|
|
|
-------------------------------------------------------------------------------
|
2012-01-16 10:29:20 +08:00
|
|
|
Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011,
|
|
|
|
2012 Free Software Foundation, Inc.
|
|
|
|
This file is part of GNU Make.
|
2006-02-12 03:02:21 +08:00
|
|
|
|
|
|
|
GNU Make is free software; you can redistribute it and/or modify it under the
|
|
|
|
terms of the GNU General Public License as published by the Free Software
|
2007-07-05 03:35:15 +08:00
|
|
|
Foundation; either version 3 of the License, or (at your option) any later
|
|
|
|
version.
|
2006-02-12 03:02:21 +08:00
|
|
|
|
|
|
|
GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
|
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
|
|
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License along with
|
2007-07-05 03:35:15 +08:00
|
|
|
this program. If not, see <http://www.gnu.org/licenses/>.
|
2006-02-12 03:02:21 +08:00
|
|
|
-------------------------------------------------------------------------------
|
|
|
|
|
2002-04-22 10:11:31 +08:00
|
|
|
Obtaining CVS Code
|
|
|
|
------------------
|
|
|
|
|
|
|
|
This seems redundant, since if you're reading this you most likely have
|
|
|
|
already performed this step; however, for completeness, you can obtain
|
|
|
|
the GNU make source code via anonymous CVS from the FSF's Savannah
|
|
|
|
project <http://savannah.gnu.org/projects/make/>:
|
|
|
|
|
2006-02-01 15:54:22 +08:00
|
|
|
$ cvs -d:pserver:anoncvs@cvs.savannah.gnu.org:/sources/make co make
|
2002-04-22 10:11:31 +08:00
|
|
|
|
|
|
|
You might want to use the "-z3" option to get compression, and you most
|
|
|
|
certainly will want the -P option to avoid unneeded directories
|
|
|
|
cluttering up your source. Personally I add these (as well as -dP for
|
|
|
|
update) to my ~/.cvsrc file.
|
|
|
|
|
|
|
|
|
|
|
|
If you have an older version of CVS, you might have to login first.
|
|
|
|
There is no password; just hit the ENTER key if you are asked for one.
|
|
|
|
|
|
|
|
|
|
|
|
Building From CVS
|
|
|
|
-----------------
|
|
|
|
|
2004-03-04 21:42:51 +08:00
|
|
|
To build GNU make from CVS, you will need Autoconf, Automake, and
|
|
|
|
Gettext, and any tools that those utilities require (GNU m4, Perl,
|
|
|
|
etc.). See the configure.in file to find the minimum versions of each
|
|
|
|
of these tools. You will also need a copy of wget.
|
2002-04-22 10:11:31 +08:00
|
|
|
|
2006-04-01 14:36:40 +08:00
|
|
|
When building from CVS you must build in the source directory: "VPATH
|
|
|
|
builds" from remote directories are not supported. Once you've created
|
|
|
|
a distribution, of course, you can unpack it and do a VPATH build from
|
|
|
|
there.
|
|
|
|
|
2002-04-22 10:11:31 +08:00
|
|
|
After checking out the code, you will need to perform these steps to get
|
2002-07-08 21:05:02 +08:00
|
|
|
to the point where you can run "make".
|
2002-04-22 10:11:31 +08:00
|
|
|
|
|
|
|
|
2006-03-18 02:55:26 +08:00
|
|
|
1) $ autoreconf -i
|
2002-04-22 10:11:31 +08:00
|
|
|
|
2003-03-25 08:15:25 +08:00
|
|
|
This rebuilds all the things that need rebuilding, installing
|
|
|
|
missing files as symbolic links.
|
2002-04-22 10:11:31 +08:00
|
|
|
|
2003-10-22 12:35:27 +08:00
|
|
|
You may get warnings here about missing files like README, etc.
|
|
|
|
Ignore them, they are harmless.
|
|
|
|
|
2002-04-22 10:11:31 +08:00
|
|
|
|
2003-03-25 08:15:25 +08:00
|
|
|
2) $ ./configure
|
2002-07-08 21:05:02 +08:00
|
|
|
|
|
|
|
Generate a Makefile
|
|
|
|
|
|
|
|
|
2003-03-25 08:15:25 +08:00
|
|
|
3) $ make update
|
2002-07-08 21:05:02 +08:00
|
|
|
|
|
|
|
Use wget to retrieve various other files that GNU make relies on,
|
|
|
|
but does not keep in its own source tree.
|
|
|
|
|
2003-05-02 09:44:59 +08:00
|
|
|
NB: You may need GNU make to correctly perform this step; if you use
|
|
|
|
a platform-local make you may get problems with missing files in doc/.
|
|
|
|
|
2002-07-08 21:05:02 +08:00
|
|
|
|
2002-04-22 10:11:31 +08:00
|
|
|
At this point you have successfully brought your CVS copy of the GNU
|
|
|
|
make source directory up to the point where it can be treated
|
|
|
|
more-or-less like the official package you would get from ftp.gnu.org.
|
|
|
|
That is, you can just run:
|
|
|
|
|
2002-07-08 21:05:02 +08:00
|
|
|
$ make && make check && make install
|
2002-04-22 10:11:31 +08:00
|
|
|
|
|
|
|
to build and install GNU make.
|
|
|
|
|
|
|
|
|
2006-03-20 10:36:36 +08:00
|
|
|
Windows builds from CVS
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
If you have a UNIX emulation like CYGWIN you can opt to run the general
|
|
|
|
build procedure above; it will work. Be sure to read
|
|
|
|
README.W32.template for information on options you might want to use
|
|
|
|
when running ./configure.
|
|
|
|
|
|
|
|
If you can't or don't want to do that, then rename the file
|
|
|
|
README.W32.template to README.W32 and follow those instructions.
|
|
|
|
|
|
|
|
|
2002-04-22 10:11:31 +08:00
|
|
|
Creating a Package
|
|
|
|
------------------
|
|
|
|
|
|
|
|
Once you have performed the above steps (including the configuration and
|
|
|
|
build) you can create a GNU make package. This is very simple, just
|
|
|
|
run:
|
|
|
|
|
|
|
|
$ make dist-gzip
|
|
|
|
|
|
|
|
and, if you like:
|
|
|
|
|
|
|
|
$ make dist-bzip2
|
|
|
|
|
2002-04-22 12:35:19 +08:00
|
|
|
Even better, you should run this:
|
|
|
|
|
|
|
|
$ make distcheck
|
|
|
|
|
|
|
|
Which will build both .gz and .bz2 package files, then unpack them into
|
|
|
|
a temporary location, try to build them, and repack them, verifying that
|
|
|
|
everything works, you get the same results, _and_ no extraneous files
|
|
|
|
are left over after the "distclean" rule--whew!! Now, _that_ is why
|
|
|
|
converting to Automake is worth the trouble! A big "huzzah!" to Tom
|
|
|
|
T. and the AutoToolers!
|
|
|
|
|
|
|
|
|
2006-03-20 10:36:36 +08:00
|
|
|
Steps to Release
|
|
|
|
----------------
|
2002-04-22 12:35:19 +08:00
|
|
|
|
2006-03-20 10:36:36 +08:00
|
|
|
Here are the things that need to be done (in more or less this order)
|
|
|
|
before making an official release:
|
2002-04-22 12:35:19 +08:00
|
|
|
|
2006-03-20 10:36:36 +08:00
|
|
|
* Update the configure.in file with the new release number.
|
|
|
|
* Update the NEWS file with the release number and date.
|
|
|
|
* Create the new release in the Savannah "Bugs" Administration for
|
|
|
|
both the "Component Version" and "Fixed Release" fields.
|
|
|
|
* Create the new release in the Savannah "Patches" Administration for
|
|
|
|
the "Fixed Release" field.
|
|
|
|
* Update the Savannah bug list URL in the NEWS file to use the correct
|
|
|
|
"Fixed Release" ID number.
|
|
|
|
* Run "make distcheck" to be sure it all works.
|
|
|
|
* Commit everything.
|
2006-04-01 14:37:45 +08:00
|
|
|
* cvs tag <RTAG> where RTAG is constructed by replacing each "." in
|
2006-03-20 10:36:36 +08:00
|
|
|
the version with "-" and prefixing it with "make-".
|
2006-02-01 15:54:22 +08:00
|
|
|
|
|
|
|
|
2006-03-20 10:36:36 +08:00
|
|
|
Publishing a Package
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
In order to publish a package on the FSF FTP site, either the release
|
|
|
|
site ftp://ftp.gnu.org, or the prerelease site ftp://alpha.gnu.org, you
|
|
|
|
first need to have my GPG private key and my passphrase to unlock it.
|
|
|
|
And, you can't have them! So there! But, just so I remember here's
|
|
|
|
what you do:
|
|
|
|
|
|
|
|
Make sure the "Steps to Release" are complete and committed and tagged.
|
|
|
|
|
2006-03-20 11:03:04 +08:00
|
|
|
cvs -d :pserver:anonymous@cvs.savannah.gnu.org:/sources/make \
|
2006-03-20 10:36:36 +08:00
|
|
|
export -r<RTAG> -d make-release make
|
|
|
|
|
|
|
|
cd make-release
|
|
|
|
|
|
|
|
<run the commands above to build the release>
|
|
|
|
|
|
|
|
make upload-alpha # for alpha.gnu.org (pre-releases)
|
|
|
|
-OR-
|
|
|
|
make upload-ftp # for ftp.gnu.org (official releases)
|
|
|
|
|
|
|
|
It will ask for the GPG passphrase _THREE_ times. Sigh.
|
|
|
|
|
|
|
|
|
2006-10-01 13:38:38 +08:00
|
|
|
For both final releases and pre-releases, send an email with the URL of
|
|
|
|
the package to the GNU translation robot to allow the translators to
|
|
|
|
work on it:
|
|
|
|
|
|
|
|
<translation@iro.umontreal.ca>
|
|
|
|
|
|
|
|
|
2006-03-20 10:36:36 +08:00
|
|
|
Where to Announce
|
|
|
|
-----------------
|
|
|
|
|
2006-04-01 14:36:40 +08:00
|
|
|
Create the announcement in a text file, then sign it with GPG.
|
|
|
|
|
|
|
|
gpg --clearsign <announcement.txt>
|
|
|
|
|
|
|
|
Upload to gnu.org, then login and send from my account there.
|
2006-03-20 10:36:36 +08:00
|
|
|
|
|
|
|
Email to: make-alpha@gnu.org, bug-make@gnu.org, help-make@gnu.org, make-w32@gnu.org.
|
|
|
|
Email to: info-gnu@gnu.org
|
|
|
|
|
|
|
|
Add a news item to the Savannah project site.
|
|
|
|
|
|
|
|
Add an update to freshmeat.net.
|
2006-02-01 15:54:22 +08:00
|
|
|
|
|
|
|
|
2002-04-22 12:35:19 +08:00
|
|
|
Appendix A - For The Brave
|
|
|
|
--------------------------
|
|
|
|
|
|
|
|
For those of you who trust me implicitly, or are just brave (or
|
|
|
|
foolhardy), here is a canned sequence of commands to build a GNU make
|
|
|
|
distribution package from a virgin CVS source checkout (assuming all the
|
|
|
|
prerequisites are available of course).
|
|
|
|
|
2002-08-10 09:27:16 +08:00
|
|
|
This list is eminently suitable for a quick swipe o' the mouse and a
|
|
|
|
swift click o' mouse-2 into an xterm. Go for it!
|
2002-04-22 12:35:19 +08:00
|
|
|
|
2006-03-18 02:55:26 +08:00
|
|
|
autoreconf -i
|
2002-04-22 12:35:19 +08:00
|
|
|
./configure
|
2002-07-08 21:05:02 +08:00
|
|
|
make update
|
2002-04-22 12:35:19 +08:00
|
|
|
make
|
|
|
|
make check
|
2006-03-18 02:55:26 +08:00
|
|
|
|
2010-07-13 09:20:10 +08:00
|
|
|
Or, for a debugging version:
|
|
|
|
|
|
|
|
autoreconf -i && ./configure CFLAGS=-g && make update && make && make check
|
|
|
|
|
2006-03-18 02:55:26 +08:00
|
|
|
Or, all-in-one:
|
|
|
|
|
|
|
|
autoreconf -i && ./configure && make update && make && make check
|