1 #!/bin/bash -eu 2 # 3 # Script to reproduce a test failure from a dejagnu .log file. 4 # 5 # Contributed by Diego Novillo <dnovillo (at] google.com> 6 # 7 # Copyright (C) 2011, 2012, 2013 Free Software Foundation, Inc. 8 # 9 # This file is part of GCC. 10 # 11 # GCC is free software; you can redistribute it and/or modify 12 # it under the terms of the GNU General Public License as published by 13 # the Free Software Foundation; either version 3, or (at your option) 14 # any later version. 15 # 16 # GCC is distributed in the hope that it will be useful, 17 # but WITHOUT ANY WARRANTY; without even the implied warranty of 18 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 19 # GNU General Public License for more details. 20 # 21 # You should have received a copy of the GNU General Public License 22 # along with GCC; see the file COPYING. If not, write to 23 # the Free Software Foundation, 51 Franklin Street, Fifth Floor, 24 # Boston, MA 02110-1301, USA. 25 26 # This script will search a line starting with 'spawn' that includes the 27 # pattern you are looking for (typically a source file name). 28 # 29 # Once it finds that pattern, it re-executes the whole command 30 # in the spawn line. If the pattern matches more than one spawn 31 # command, it asks which one you want. 32 33 if [ $# -lt 2 ] ; then 34 echo "usage: $0 [--debug|--debug-tui] pattern file.log [additional-args]" 35 echo 36 echo "Finds the 'spawn' line matching PATTERN in FILE.LOG and executes" 37 echo "the command with any arguments in ADDITIONAL-ARGS." 38 echo 39 echo "If --debug is used, the compiler is invoked with -wrapper gdb,--args" 40 echo "If --debug-tui is used, the compiler is invoked with -wrapper "\ 41 "gdb,--tui,--args" 42 exit 1 43 fi 44 45 if [ "$1" = "--debug" ] ; then 46 debug_args="-wrapper gdb,--args" 47 shift 48 elif [ "$1" = "--debug-tui" ] ; then 49 debug_args="-wrapper gdb,--tui,--args" 50 shift 51 else 52 debug_args="" 53 fi 54 pattern="$1" 55 logf="$2" 56 shift 2 57 58 # Find the commands in LOGF that reference PATTERN. 59 lines=$(grep -E "^spawn .*$pattern" $logf \ 60 | sed -e 's/^spawn -ignore SIGHUP //' \ 61 | sed -e 's/^spawn //') 62 if [ -z "$lines" ] ; then 63 echo "Could not find a spawn command for pattern $pattern" 64 exit 1 65 fi 66 67 # Collect all the command lines into the COMMANDS array. 68 old_IFS="$IFS" 69 IFS=" " 71 num_lines=0 72 for line in $lines ; do 73 num_lines=$[$num_lines + 1] 74 echo "[$num_lines] $line" 75 commands[$num_lines]=$line 76 done 77 78 # If we found more than one line for PATTERN, ask which one we should run. 79 cmds_to_run='0' 80 if [ $num_lines -gt 1 ] ; then 81 echo 82 echo 83 echo -n "Enter the list of commands to run or '0' to run them all: " 84 read cmds_to_run 85 fi 86 if [ "$cmds_to_run" = "0" ] ; then 87 cmds_to_run=$(seq 1 $num_lines) 88 fi 89 IFS="$old_IFS" 90 91 # Finally, execute all the commands we were told to execute. 92 for cmd_num in $cmds_to_run ; do 93 cmd=${commands[$cmd_num]} 94 set -x +e 95 $cmd $debug_args "$@" 96 set +x -e 97 done 98