2002-06-10 Roger Sayle <roger@eyesopen.com>
[official-gcc.git] / contrib / gcc_build
blob4d0eea30b6b1a5f0d17df09330760404098781d1
1 #! /bin/sh
3 ########################################################################
5 # File: gcc_build
6 # Author: Mark Mitchell
7 # Date: 07/10/2000
9 # Contents:
10 # Script to automatically download and build GCC.
12 # Copyright (c) 2000, 2001 Free Software Foundation.
14 # This file is part of GNU CC.
16 # GNU CC is free software; you can redistribute it and/or modify
17 # it under the terms of the GNU General Public License as published by
18 # the Free Software Foundation; either version 2, or (at your option)
19 # any later version.
21 # GNU CC is distributed in the hope that it will be useful,
22 # but WITHOUT ANY WARRANTY; without even the implied warranty of
23 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
24 # GNU General Public License for more details.
26 # You should have received a copy of the GNU General Public License
27 # along with GNU CC; see the file COPYING. If not, write to
28 # the Free Software Foundation, 59 Temple Place - Suite 330,
29 # Boston, MA 02111-1307, USA.
31 ########################################################################
33 ########################################################################
34 # Notes
35 ########################################################################
37 # If you are using password-based CVS, you must manually log in, and
38 # not log out from, the CVS server before running this script.
40 # You can set the following variables in the environment. They
41 # have no corresponding command-line options because they should
42 # only be needed infrequently:
44 # MAKE The path to `make'.
46 ########################################################################
47 # Functions
48 ########################################################################
50 # Issue the error message given by $1 and exit with a non-zero
51 # exit code.
53 error() {
54 echo "gcc_build: error: $1"
55 exit 1
58 # Issue a usage message explaining how to use this script.
60 usage() {
61 cat <<EOF
62 gcc_build [-c configure_options]
63 [-d destination_directory]
64 [-m make_boot_options]
65 [-o objdir]
66 [-u username]
67 [-p protocol]
68 [-t tarfile]
69 [bootstrap]
70 [build]
71 [checkout]
72 [configure]
73 [export]
74 [install]
75 [test]
76 [update]
77 EOF
78 exit 1
81 # Change to the directory given by $1.
83 changedir() {
84 cd $1 || \
85 error "Could not change directory to $1"
88 # Set up CVS environment variables
90 cvs_setup() {
91 CVSROOT=":${CVS_PROTOCOL}:${CVS_USERNAME}@"
92 CVSROOT="${CVSROOT}${CVS_SERVER}:${CVS_REPOSITORY}"
93 export CVSROOT
96 # Checkout a fresh copy of the GCC build tree.
98 checkout_gcc() {
99 # Tell CVS where to find everything.
100 cvs_setup
102 # If the destination already exists, don't risk destroying it.
103 test -e ${DESTINATION} && \
104 error "${DESTINATION} already exists"
106 # CVS doesn't allow an absolute path for the destination directory.
107 DESTINATION_PARENT=`dirname ${DESTINATION}`
108 test -d ${DESTINATION_PARENT} || \
109 error "${DESTINATION_PARENT} is not a directory"
110 changedir ${DESTINATION_PARENT}
112 # Checkout the tree
113 cvs -z 9 co -d `basename ${DESTINATION}` gcc || \
114 error "Could not check out GCC"
117 # Update GCC.
119 update_gcc() {
120 # Tell CVS where to find everything
121 cvs_setup
123 # If the destination does not already exist, complain.
124 test -d ${DESTINATION} || \
125 error "{$DESTINATION} does not exist"
126 # Enter the destination directory.
127 changedir ${DESTINATION}
129 # Update the tree
130 ./contrib/gcc_update -d || \
131 error "Could not update GCC"
134 # Configure for a build of GCC.
136 configure_gcc() {
137 # Go to the source directory.
138 changedir ${DESTINATION}
140 # Remove the object directory.
141 rm -rf ${OBJDIR}
142 # Create it again.
143 mkdir ${OBJDIR} || \
144 error "Could not create ${OBJDIR}"
145 # Enter it.
146 changedir ${OBJDIR}
148 # Configure the tree.
149 echo "Configuring: ${DESTINATION}/configure ${CONFIGURE_OPTIONS}"
150 eval ${DESTINATION}/configure ${CONFIGURE_OPTIONS} || \
151 error "Could not configure the compiler"
154 # Bootstrap GCC. Assume configuration has already occurred.
156 bootstrap_gcc() {
157 # Go to the source directory.
158 changedir ${DESTINATION}
159 # Go to the object directory.
160 changedir ${OBJDIR}
162 # Bootstrap the compiler
163 echo "Building: ${MAKE} ${MAKE_BOOTSTRAP_OPTIONS} bootstrap"
164 eval ${MAKE} ${MAKE_BOOTSTRAP_OPTIONS} bootstrap || \
165 error "Could not bootstrap the compiler"
168 # Test GCC.
170 test_gcc() {
171 # Go to the source directory.
172 changedir ${DESTINATION}
173 # Go to the object directory.
174 changedir ${OBJDIR}
176 echo "Running tests... This will take a while."
177 ${MAKE} -k check
178 ${DESTINATION}/contrib/test_summary
181 # Export the GCC source tree.
183 export_gcc() {
184 # Go to the source directory.
185 changedir ${DESTINATION}
186 # Go up one level.
187 changedir ..
188 # Build a tarball of the source directory.
189 tar czf ${TARFILE} \
190 --exclude=${OBJDIR} \
191 --exclude=CVS \
192 --exclude='.#*' \
193 --exclude='*~' \
194 `basename ${DESTINATION}`
197 # Install GCC.
199 install_gcc() {
200 # Go to the source directory.
201 changedir ${DESTINATION}
202 # Go to the object directory.
203 changedir ${OBJDIR}
205 ${MAKE} install || error "Installation failed"
208 ########################################################################
209 # Initialization
210 ########################################################################
212 # The CVS server containing the GCC repository.
213 CVS_SERVER="gcc.gnu.org"
214 # The path to the repository on that server.
215 CVS_REPOSITORY="/cvs/gcc"
216 # The CVS protocol to use.
217 CVS_PROTOCOL="pserver"
218 # The username to use when connecting to the server.
219 CVS_USERNAME="anoncvs"
221 # The directory where the checked out GCC will be placed.
222 DESTINATION="${HOME}/dev/gcc"
223 # The relative path from the top of the source tree to the
224 # object directory.
225 OBJDIR="objdir"
227 # The file where the tarred up sources will be placed.
228 TARFILE="${HOME}/dev/gcc.tgz"
230 # Options to pass to configure.
231 CONFIGURE_OPTIONS=
232 # The `make' program.
233 MAKE=${MAKE:-make}
234 # Options to pass to make.
235 MAKE_BOOTSTRAP_OPTIONS=
237 # Modes of operation
238 BOOTSTRAP=0
239 CHECKOUT=0
240 CONFIGURE=0
241 EXPORT=0
242 INSTALL=0
243 TEST=0
244 UPDATE=0
246 ########################################################################
247 # Main Program
248 ########################################################################
250 # Parse the options.
251 while getopts "c:d:m:o:p:t:u:" ARG; do
252 case $ARG in
253 c) CONFIGURE_OPTIONS="${OPTARG}";;
254 d) DESTINATION="${OPTARG}";;
255 m) MAKE_BOOTSTRAP_OPTIONS="${OPTARG}";;
256 o) OBJDIR="${OPTARG}";;
257 p) CVS_PROTOCOL="${OPTARG}";;
258 t) CVS_TARGFILE="${OPTARG}";;
259 u) CVS_USERNAME="${OPTARG}";;
260 \?) usage;;
261 esac
262 done
263 shift `expr ${OPTIND} - 1`
265 # Handle the major modes.
266 while [ $# -ne 0 ]; do
267 case $1 in
268 bootstrap) BOOTSTRAP=1;;
269 build) CONFIGURE=1; BOOTSTRAP=1;;
270 checkout) CHECKOUT=1;;
271 configure) CONFIGURE=1;;
272 export) EXPORT=1;;
273 install) INSTALL=1;;
274 test) TEST=1;;
275 update) UPDATE=1;;
276 *) usage;;
277 esac
278 shift
279 done
281 # Check the arguments for sanity.
282 if [ ${CHECKOUT} -ne 0 ] && [ ${UPDATE} -ne 0 ]; then
283 error "Cannot checkout and update simultaneously"
286 # Checkout the tree.
287 if [ ${CHECKOUT} -ne 0 ]; then
288 checkout_gcc
289 elif [ ${UPDATE} -ne 0 ]; then
290 update_gcc
293 # Configure to build the tree.
294 if [ ${CONFIGURE} -ne 0 ]; then
295 configure_gcc
298 # Bootstrap the compiler.
299 if [ ${BOOTSTRAP} -ne 0 ]; then
300 bootstrap_gcc
303 # Test the compiler
304 if [ ${TEST} -ne 0 ]; then
305 test_gcc
308 # Install the compiler.
309 if [ ${INSTALL} -ne 0 ]; then
310 install_gcc
313 # Export the sources
314 if [ ${EXPORT} -ne 0 ]; then
315 export_gcc