source: trunk/src/gcc/contrib/gcc_update@ 46

Last change on this file since 46 was 2, checked in by bird, 23 years ago

Initial revision

  • Property cvs2svn:cvs-rev set to 1.1
  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 7.7 KB
RevLine 
[2]1#! /bin/sh
2#
3# Update a local CVS tree from the GCC repository, with an emphasis
4# on treating generated files correctly, so that autoconf, gperf et
5# al are not required for the ``end'' user.
6#
7# By default all command-line options are passed to `cvs update` in
8# addition to $UPDATE_OPTIONS (defined below). If the first parameter
9# reads --nostdflags, $UPDATE_OPTIONS as well as this parameter itself
10# are omitted.
11#
12# If the first parameter reads --patch, the second parameter is considered
13# a patch file.
14#
15# If the first parameter is --touch, no cvs operation will be performed,
16# only generated files that appear to be out of date in the local tree
17# will be touched.
18#
19# If the first parameter is --list, a list of the generated files and
20# their dependencies will be printed; --help prints this message.
21#
22# Examples:
23#
24# contrib/gcc_update -r gcc_latest_snapshot
25# contrib/gcc_update -A
26# contrib/gcc_update --nostdflags -P -r gcc-2_95-branch gcc/testsuite
27# contrib/gcc_update --patch some-patch
28# contrib/gcc_update --touch
29# contrib/gcc_update --list
30#
31#
32# (C) 1998, 1999, 2000, 2001, 2002, 2003 Free Software Foundation
33# Originally by Gerald Pfeifer <[email protected]>, August 1998.
34#
35# This script is Free Software, and it can be copied, distributed and
36# modified as defined in the GNU General Public License. A copy of
37# its license can be downloaded from http://www.gnu.org/copyleft/gpl.html
38
39
40# Default options used when updating via CVS.
41UPDATE_OPTIONS=-Pd
42# Use -P to prune empty directories.
43# Use -d to create any directories that exist in the repository but not
44# locally.
45# Use -A to reset any sticky tags, dates, or `-k' options.
46
47######## Anything below shouldn't be changed by regular users.
48
49# Arrange for the value of $0 to be available for functions
50self=$0
51
52# This function prints a list of all generated files, along with their
53# dependencies. Note that only one target is supported per line: the
54# colon is stripped from the output.
55files_and_dependencies () {
56 sed -e 's/ *#.*//' -e '/^$/d' -e 's/://' <<\EOF
57# All automake dependencies within texinfo
58# In fact, not all, since we do not care about sub-directories that
59# we do not build. In particular, *.po and *.gmo are not touched.
60texinfo/aclocal.m4: texinfo/configure.in texinfo/acinclude.m4
61texinfo/Makefile.in: texinfo/Makefile.am texinfo/configure.in texinfo/aclocal.m4
62texinfo/configure: texinfo/configure.in texinfo/aclocal.m4
63texinfo/stamp-h.in: texinfo/configure.in texinfo/aclocal.m4 texinfo/acconfig.h
64texinfo/lib/Makefile.in: texinfo/lib/Makefile.am texinfo/configure.in texinfo/aclocal.m4
65texinfo/makeinfo/Makefile.in: texinfo/makeinfo/Makefile.am texinfo/configure.in texinfo/aclocal.m4
66texinfo/util/Makefile.in: texinfo/util/Makefile.am texinfo/configure.in texinfo/aclocal.m4
67# Now, proceed to gcc automatically generated files
68gcc/configure: gcc/configure.in
69gcc/cstamp-h.in: gcc/configure.in gcc/acconfig.h
70gcc/config.in: gcc/cstamp-h.in
71gcc/fixinc/fixincl.x: gcc/fixinc/fixincl.tpl gcc/fixinc/inclhack.def
72gcc/intl/plural.c: gcc/intl/plural.y
73# And then, language-specific files
74gcc/f/intdoc.texi: gcc/f/intdoc.in gcc/f/intdoc.c gcc/f/intrin.h gcc/f/intrin.def
75gcc/cp/cfns.h: gcc/cp/cfns.gperf