OSDN Git Service

* compare_tests: Handle multilibs better.
[pf3gnuchains/gcc-fork.git] / contrib / compare_tests
index 7a1d76c..bcf678c 100755 (executable)
@@ -2,14 +2,16 @@
 # This script automatically test the given tool with the tool's test cases,
 # reporting anything of interest.
 
 # This script automatically test the given tool with the tool's test cases,
 # reporting anything of interest.
 
-# exits with 1 if there is nothing of interest
-# exits with 0 if there is something interesting
+# exits with 0 if there is nothing of interest
+# exits with 1 if there is something interesting
 # exits with 2 if an error occurred
 
 # Give two .sum files to compare them
 
 # Written by Mike Stump <mrs@cygnus.com>
 
 # exits with 2 if an error occurred
 
 # Give two .sum files to compare them
 
 # Written by Mike Stump <mrs@cygnus.com>
 
+tool=gxx
+
 tmp1=/tmp/$tool-testing.$$a
 tmp2=/tmp/$tool-testing.$$b
 now_s=/tmp/$tool-testing.$$d
 tmp1=/tmp/$tool-testing.$$a
 tmp2=/tmp/$tool-testing.$$b
 now_s=/tmp/$tool-testing.$$d
@@ -20,19 +22,20 @@ if [ "$2" = "" ]; then
        exit 2
 fi
 
        exit 2
 fi
 
-sed 's/^XFAIL/FAIL/; s/^XPASS/PASS/' < "$1" >$tmp1
-sed 's/^XFAIL/FAIL/; s/^XPASS/PASS/' < "$2" >$tmp2
+sed 's/^XFAIL/FAIL/; s/^XPASS/PASS/' < "$1" | awk '/^Running target / {target = $3} { if (target != "unix") { sub(/: /, "&"target": " ); }; print $0; }' >$tmp1
+sed 's/^XFAIL/FAIL/; s/^XPASS/PASS/' < "$2" | awk '/^Running target / {target = $3} { if (target != "unix") { sub(/: /, "&"target": " ); }; print $0; }' >$tmp2
 
 before=$tmp1
 now=$tmp2
 
 
 before=$tmp1
 now=$tmp2
 
+exit_status=0
 trap "rm -f $tmp1 $tmp2 $now_s $before_s" 0 1 2 3 5 9 13 15
 
 trap "rm -f $tmp1 $tmp2 $now_s $before_s" 0 1 2 3 5 9 13 15
 
-sort +0.4 "$now" > "$now_s"
-sort +0.4 "$before" > "$before_s"
+sort -t ':' +1 "$now" > "$now_s"
+sort -t ':' +1 "$before" > "$before_s"
 
 
-grep '^FAIL' "$now_s" | sed 's/^....:  //' >$tmp1
-grep '^PASS' "$before_s" | sed 's/^....:       //' | comm -12 $tmp1 - >$tmp2
+grep '^FAIL:' "$now_s" | sed 's/^[^:]*:[       ]//' >$tmp1
+grep '^PASS' "$before_s" | sed 's/^[^:]*:[     ]//' | comm -12 $tmp1 - >$tmp2
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
@@ -40,10 +43,11 @@ if [ $? = 0 ]; then
        echo
        cat $tmp2
        echo
        echo
        cat $tmp2
        echo
+       exit_status=1
 fi
 
 fi
 
-grep '^PASS' "$now_s" | sed 's/^....:  //' >$tmp1
-grep '^FAIL' "$before_s" | sed 's/^....:       //' | comm -12 $tmp1 - >$tmp2
+grep '^PASS' "$now_s" | sed 's/^[^:]*:[        ]//' >$tmp1
+grep '^FAIL' "$before_s" | sed 's/^[^:]*:[     ]//' | comm -12 $tmp1 - >$tmp2
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
@@ -53,8 +57,8 @@ if [ $? = 0 ]; then
        echo
 fi
 
        echo
 fi
 
-grep '^FAIL' "$now_s" | sed 's/^....:  //' >$tmp1
-grep '^[PF]A[SI][SL]' "$before_s" | sed 's/^....:      //' | comm -23 $tmp1 - >$tmp2
+grep '^FAIL' "$now_s" | sed 's/^[^:]*:[        ]//' >$tmp1
+grep '^[PF]A[SI][SL]' "$before_s" | sed 's/^[^:]*:[    ]//' | comm -23 $tmp1 - >$tmp2
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
@@ -62,10 +66,11 @@ if [ $? = 0 ]; then
        echo
        cat $tmp2
        echo
        echo
        cat $tmp2
        echo
+       exit_status=1
 fi
 
 fi
 
-grep '^PASS' "$now_s" | sed 's/^....:  //' >$tmp1
-grep '^[PF]A[SI][SL]' "$before_s" | sed 's/^....:      //' | comm -23 $tmp1 - >$tmp2
+grep '^PASS' "$now_s" | sed 's/^[^:]*:[        ]//' >$tmp1
+grep '^[PF]A[SI][SL]' "$before_s" | sed 's/^[^:]*:[    ]//' | comm -23 $tmp1 - >$tmp2
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
@@ -75,8 +80,8 @@ if [ $? = 0 ]; then
        echo
 fi
 
        echo
 fi
 
-grep '^[PF]A[SI][SL]' "$now_s" | sed 's/^....: //' >$tmp1
-grep '^PASS' "$before_s" | sed 's/^....:       //' | comm -13 $tmp1 - >$tmp2
+grep '^[PF]A[SI][SL]' "$now_s" | sed 's/^[^:]*:[       ]//' >$tmp1
+grep '^PASS' "$before_s" | sed 's/^[^:]*:[     ]//' | comm -13 $tmp1 - >$tmp2
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
@@ -86,8 +91,8 @@ if [ $? = 0 ]; then
        echo
 fi
 
        echo
 fi
 
-grep '^[PF]A[SI][SL]' "$now_s" | sed 's/^....: //' >$tmp1
-grep '^FAIL' "$before_s" | sed 's/^....:       //' | comm -13 $tmp1 - >$tmp2
+grep '^[PF]A[SI][SL]' "$now_s" | sed 's/^[^:]*:[       ]//' >$tmp1
+grep '^FAIL' "$before_s" | sed 's/^[^:]*:[     ]//' | comm -13 $tmp1 - >$tmp2
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
 
 grep -s . $tmp2 >/dev/null
 if [ $? = 0 ]; then
@@ -96,3 +101,5 @@ if [ $? = 0 ]; then
        cat $tmp2
        echo
 fi
        cat $tmp2
        echo
 fi
+
+exit $exit_status