From: Andrew Cagney Date: Thu, 9 Jan 2003 00:45:08 +0000 (+0000) Subject: 2003-01-08 Andrew Cagney X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=c9a1dc08aaf6cb16b9d07fcee5420c3c73b9dd72;p=binutils-gdb.git 2003-01-08 Andrew Cagney * gdb_mbuild.sh: Add --keep option. When specified, keep the build directories. Save edited gdb output in Mbuild.log. If a build fails, remove any final GDB executable. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 6e4ed54f2ff..b123f4a9904 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -3,6 +3,12 @@ * alpha-linux-tdep.c (alpha_linux_sigcontext_addr): Use get_frame_base. +2003-01-08 Andrew Cagney + + * gdb_mbuild.sh: Add --keep option. When specified, keep the + build directories. Save edited gdb output in Mbuild.log. If a + build fails, remove any final GDB executable. + 2003-01-08 Andrew Cagney * gdb_mbuild.sh: Edit the output of `maint print architecture' diff --git a/gdb/gdb_mbuild.sh b/gdb/gdb_mbuild.sh index 49d18cfbd26..a108de0bc41 100755 --- a/gdb/gdb_mbuild.sh +++ b/gdb/gdb_mbuild.sh @@ -29,6 +29,7 @@ Usage: gdb_mbuild.sh [ ... ] -j Run in parallel. Passed to make. On a single cpu machine, 2 is recommended. -k Keep going. Do not stop after the first build fails. + --keep Keep builds. Do not remove each build when finished. -e Regular expression for selecting the targets to build. -f Force rebuild. Even rebuild previously built directories. -v Be more (and more, and more) verbose. @@ -53,6 +54,7 @@ keepgoing= force=false targexp="" verbose=0 +keep=false while test $# -gt 0 do case "$1" in @@ -72,6 +74,9 @@ do # Should we soldier on after the first build fails? keepgoing=-k ;; + --keep ) + keep=true + ;; -e ) # A regular expression for selecting targets shift @@ -261,8 +266,13 @@ do if test ! -x gdb/gdb -a ! -x gdb/gdb.exe then + # Iff the build fails remove the final build target so that + # the follow-on code knows things failed. Stops the follow-on + # code thinking that a failed rebuild succedded (executable + # left around from previous build). echo ... ${make} ${keepgoing} ${makejobs} ${target} - ${make} ${keepgoing} ${makejobs} all-gdb 2>&1 | log 1 Build.log + ( ${make} ${keepgoing} ${makejobs} all-gdb || rm -f gdb/gdb gdb/gdb.exe + ) 2>&1 | log 1 Build.log fi fail "compile failed" ! -x gdb/gdb -a ! -x gdb/gdb.exe @@ -284,7 +294,6 @@ EOF # Create a sed script that cleans up the output from GDB. rm -f mbuild.sed touch mbuild.sed || exit 1 - # Rules to replace <0xNNNN> with the corresponding function's # name. sed -n -e '/<0x0*>/d' -e 's/^.*<0x\([0-9a-f]*\)>.*$/0x\1/p' Gdb.log \ @@ -295,18 +304,25 @@ EOF test ${verbose} -gt 0 && echo "${addr} ${func}" 1>&2 echo "s/<${addr}>/<${func}>/g" done >> mbuild.sed - # Rules to strip the leading paths off of file names. echo 's/"\/.*\/gdb\//"gdb\//g' >> mbuild.sed + # Run the script + sed -f mbuild.sed Gdb.log > Mbuild.log # Replace the build directory with a file as semaphore that stops # a rebuild. (should the logs be saved?) cd ${builddir} - rm -f ${target}.tmp - sed -f ${target}/mbuild.sed ${target}/Gdb.log > ${target}.tmp - rm -rf ${target} - mv ${target}.tmp ${target} + + if ${keep} + then + : + else + rm -f ${target}.tmp + mv ${target}/Mbuild.log ${target}.tmp + rm -rf ${target} + mv ${target}.tmp ${target} + fi # Success! echo ... ${target} built