OSDN Git Service

* arm.c (arm_print_operand): Use output_operand_lossage where possible
[pf3gnuchains/gcc-fork.git] / contrib / gcc_build
index 2989628..b36685e 100755 (executable)
@@ -9,22 +9,22 @@
 # Contents:
 #   Script to automatically download and build GCC.
 #
-# Copyright (c) 2000 Free Software Foundation.
+# Copyright (c) 2000, 2001, 2003 Free Software Foundation.
 #
-# This file is part of GNU CC.
+# This file is part of GCC.
 #
-# GNU CC is free software; you can redistribute it and/or modify
+# GCC 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 Foundation; either version 2, or (at your option)
 # any later version.
 #
-# GNU CC is distributed in the hope that it will be useful,
+# GCC 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 GNU CC; see the file COPYING.  If not, write to
+# along with GCC; see the file COPYING.  If not, write to
 # the Free Software Foundation, 59 Temple Place - Suite 330,
 # Boston, MA 02111-1307, USA.
 #
@@ -62,9 +62,11 @@ cat <<EOF
 gcc_build        [-c configure_options] 
                 [-d destination_directory]
                 [-m make_boot_options]
+                [-o objdir]
                 [-u username]
                 [-p protocol]
                 [-t tarfile]
+                 [-x make_check_options]
                 [bootstrap]
                 [build]
                 [checkout]
@@ -109,7 +111,7 @@ checkout_gcc() {
     changedir ${DESTINATION_PARENT}
 
     # Checkout the tree
-    cvs -z 9 co -d `basename ${DESTINATION}` gcc || \
+    $GCC_CVS -z 9 co -d `basename ${DESTINATION}` gcc || \
        error "Could not check out GCC"
 }
 
@@ -126,7 +128,7 @@ update_gcc() {
     changedir ${DESTINATION}
 
     # Update the tree
-    (./contrib/gcc_update | tee -a ${LOGFILE}) || \
+    ./contrib/gcc_update -d || \
        error "Could not update GCC"
 }
 
@@ -145,8 +147,8 @@ configure_gcc() {
     changedir ${OBJDIR}
 
     # Configure the tree.
-    (eval ${DESTINATION}/configure ${CONFIGURE_OPTIONS} 2>&1 | 
-        tee -a ${LOGFILE}) || \
+    echo "Configuring: ${DESTINATION}/configure ${CONFIGURE_OPTIONS}"
+    eval ${DESTINATION}/configure ${CONFIGURE_OPTIONS} || \
        error "Could not configure the compiler"
 }
 
@@ -159,8 +161,8 @@ bootstrap_gcc() {
     changedir ${OBJDIR}
 
     # Bootstrap the compiler
-    (eval ${MAKE} ${MAKE_BOOTSTRAP_OPTIONS} bootstrap 2>&1 |
-       tee -a ${LOGFILE}) || \
+    echo "Building: ${MAKE} ${MAKE_BOOTSTRAP_OPTIONS} bootstrap"
+    eval ${MAKE} ${MAKE_BOOTSTRAP_OPTIONS} bootstrap || \
        error "Could not bootstrap the compiler"
 }
 
@@ -173,8 +175,8 @@ test_gcc() {
     changedir ${OBJDIR}
 
     echo "Running tests...  This will take a while."
-    (${MAKE} -k check 2>&1 | tee -a ${LOGFILE})
-    (${DESTINATION}/contrib/test_summary | tee -a ${LOGFILE})
+    eval \${MAKE} -k ${MAKE_CHECK_OPTIONS} check
+    ${DESTINATION}/contrib/test_summary
 }
 
 # Export the GCC source tree.
@@ -201,14 +203,15 @@ install_gcc() {
     # Go to the object directory.
     changedir ${OBJDIR}
 
-    (${MAKE} install 2>&1 | tee -a ${LOGFILE}) || \
-       error "Installation failed"
+    ${MAKE} install || error "Installation failed"
 }
 
 ########################################################################
 # Initialization
 ########################################################################
 
+# CVS command
+GCC_CVS=${GCC_CVS-${CVS-cvs}}
 # The CVS server containing the GCC repository.
 CVS_SERVER="gcc.gnu.org"
 # The path to the repository on that server.
@@ -224,8 +227,6 @@ DESTINATION="${HOME}/dev/gcc"
 # object directory.
 OBJDIR="objdir"
 
-# The file where information will be logged.
-LOGFILE=${HOME}/build-gcc.$$.log
 # The file where the tarred up sources will be placed.
 TARFILE="${HOME}/dev/gcc.tgz"
 
@@ -233,8 +234,10 @@ TARFILE="${HOME}/dev/gcc.tgz"
 CONFIGURE_OPTIONS=
 # The `make' program.
 MAKE=${MAKE:-make}
-# Options to pass to make.
+# Options to pass to "make bootstrap".
 MAKE_BOOTSTRAP_OPTIONS=
+# Options to pass to "make check".
+MAKE_CHECK_OPTIONS=
 
 # Modes of operation
 BOOTSTRAP=0
@@ -250,13 +253,15 @@ UPDATE=0
 ########################################################################
 
 # Parse the options.
-while getopts "c:d:m:p:t:u:" ARG; do
+while getopts "c:d:m:o:p:t:u:x:" ARG; do
     case $ARG in
     c)    CONFIGURE_OPTIONS="${OPTARG}";;
     d)    DESTINATION="${OPTARG}";;
     m)    MAKE_BOOTSTRAP_OPTIONS="${OPTARG}";;
+    o)    OBJDIR="${OPTARG}";;
     p)    CVS_PROTOCOL="${OPTARG}";;
-    t)    CVS_TARGFILE="${OPTARG}";;
+    t)    TARFILE="${OPTARG}";;
+    x)    MAKE_CHECK_OPTIONS="${OPTARG}";;
     u)    CVS_USERNAME="${OPTARG}";;
     \?)   usage;;
     esac
@@ -284,11 +289,6 @@ if [ ${CHECKOUT} -ne 0 ] && [ ${UPDATE} -ne 0 ]; then
     error "Cannot checkout and update simultaneously"
 fi
 
-# Remove any old logfiles.
-rm -f ${LOGFILE}
-# Tell the user where to find the logfile.
-echo "gcc_build: The logfile for this run is ${LOGFILE}"
-
 # Checkout the tree.
 if [ ${CHECKOUT} -ne 0 ]; then
     checkout_gcc