revert 2007-01-11 Nathan Sidwell <nathan@codesourcery.com>
authorNathan Sidwell <nathan@codesourcery.com>
Fri, 12 Jan 2007 11:36:21 +0000 (11:36 +0000)
committerNathan Sidwell <nathan@codesourcery.com>
Fri, 12 Jan 2007 11:36:21 +0000 (11:36 +0000)
* lib/gdb.exp (gdb_compile_test): New.
(skip_ada_tests, skip_java_tests): New.
(gdb_compile): Use gdb_compile_test for f77.
* lib/ada.exp (gdb_compile_ada): Use gdb_compile_test to record result.
* lib/java.exp (compile_java_from_source): Remove runtests check,
use gdb_compile_test to record result.
* gdb.ada/packed_array.exp, gdb.ada/fixed_points.exp,
gdb.ada/exec_changed.exp, gdb.ada/start.exp,
gdb.ada/watch_arg.exp, gdb.ada/null_record.exp,
gdb.ada/array_return.exp, gdb.ada/arrayidx.exp,
gdb.mi/mi-var-child-f.exp, gdb.fortran/types.exp,
gdb.fortran/array-element.exp, gdb.fortran/subarray.exp,
gdb.fortran/derived-type.exp, gdb.fortran/exprs.exp,
gdb.java/jmisc.exp, gdb.java/jprint.exp,
gdb.java/jv-print.exp, gdb.java/jmain.exp: Add language skip,
adjust gdb_compile invocations.

22 files changed:
gdb/testsuite/ChangeLog
gdb/testsuite/gdb.ada/array_return.exp
gdb/testsuite/gdb.ada/arrayidx.exp
gdb/testsuite/gdb.ada/exec_changed.exp
gdb/testsuite/gdb.ada/fixed_points.exp
gdb/testsuite/gdb.ada/null_record.exp
gdb/testsuite/gdb.ada/packed_array.exp
gdb/testsuite/gdb.ada/start.exp
gdb/testsuite/gdb.ada/watch_arg.exp
gdb/testsuite/gdb.fortran/array-element.exp
gdb/testsuite/gdb.fortran/derived-type.exp
gdb/testsuite/gdb.fortran/exprs.exp
gdb/testsuite/gdb.fortran/subarray.exp
gdb/testsuite/gdb.fortran/types.exp
gdb/testsuite/gdb.java/jmain.exp
gdb/testsuite/gdb.java/jmisc.exp
gdb/testsuite/gdb.java/jprint.exp
gdb/testsuite/gdb.java/jv-print.exp
gdb/testsuite/gdb.mi/mi-var-child-f.exp
gdb/testsuite/lib/ada.exp
gdb/testsuite/lib/gdb.exp
gdb/testsuite/lib/java.exp

index a1a6a4ed3c224b9ee04dfb67821dd288b0624356..ed56619570da0ac629cb73933b6339d71bbbe67a 100644 (file)
@@ -4,25 +4,6 @@
        Make sure the variable we're using is in scope.
        (reference_to_pointer): Likewise.
 
-2007-01-11  Nathan Sidwell  <nathan@codesourcery.com>
-
-       * lib/gdb.exp (gdb_compile_test): New.
-       (skip_ada_tests, skip_java_tests): New.
-       (gdb_compile): Use gdb_compile_test for f77.
-       * lib/ada.exp (gdb_compile_ada): Use gdb_compile_test to record result.
-       * lib/java.exp (compile_java_from_source): Remove runtests check,
-       use gdb_compile_test to record result.
-       * gdb.ada/packed_array.exp, gdb.ada/fixed_points.exp,
-       gdb.ada/exec_changed.exp, gdb.ada/start.exp,
-       gdb.ada/watch_arg.exp, gdb.ada/null_record.exp,
-       gdb.ada/array_return.exp, gdb.ada/arrayidx.exp,
-       gdb.mi/mi-var-child-f.exp, gdb.fortran/types.exp,
-       gdb.fortran/array-element.exp, gdb.fortran/subarray.exp,
-       gdb.fortran/derived-type.exp, gdb.fortran/exprs.exp,
-       gdb.java/jmisc.exp, gdb.java/jprint.exp,
-       gdb.java/jv-print.exp, gdb.java/jmain.exp: Add language skip,
-       adjust gdb_compile invocations.
-
 2007-01-09  Daniel Jacobowitz  <dan@codesourcery.com>
 
        * gdb.ada/catch_ex.exp: Call unsupported and stop if the runtime
index 2071dfdd175041f52111d3bfdc5380aae8e16f98..ad8f53cc9ae491406854caa67957f77210e88d01 100644 (file)
@@ -21,16 +21,14 @@ if $tracelevel then {
 
 load_lib "ada.exp"
 
-if { [skip_ada_tests] } { return -1 }
-
 set testdir "array_return"
 set testfile "${testdir}/p"
 set srcfile ${srcdir}/${subdir}/${testfile}.adb
 set binfile ${objdir}/${subdir}/${testfile}
 
 file mkdir ${objdir}/${subdir}/${testdir}
-if {[gdb_compile_ada "${srcfile}" "${binfile}" executable {debug}] != ""} {
-    return -1
+if {[gdb_compile_ada "${srcfile}" "${binfile}" executable [list debug ]] != "" } {
+  return -1
 }
 
 gdb_exit
index ce4c0573305a98e977a420255940b71a40c0b198..a967d5a6d25285216f37143f91f7549ba6b2108e 100644 (file)
@@ -21,16 +21,14 @@ if $tracelevel then {
 
 load_lib "ada.exp"
 
-if { [skip_ada_tests] } { return -1 }
-
 set testdir "arrayidx"
 set testfile "${testdir}/p"
 set srcfile ${srcdir}/${subdir}/${testfile}.adb
 set binfile ${objdir}/${subdir}/${testfile}
 
 file mkdir ${objdir}/${subdir}/${testdir}
-if {[gdb_compile_ada "${srcfile}" "${binfile}" executable {debug}] != ""} {
-    return -1
+if {[gdb_compile_ada "${srcfile}" "${binfile}" executable [list debug ]] != "" } {
+  return -1
 }
 
 gdb_exit
index dbdccf2d63a3933f1cae5e2e04c0fa73628f3fb6..a4f4d9bda2c24de21c43e937f691ca690e141f1b 100644 (file)
@@ -20,8 +20,6 @@ if $tracelevel then {
 
 load_lib "ada.exp"
 
-if { [skip_ada_tests] } { return -1 }
-
 set testdir "exec_changed"
 file mkdir ${objdir}/${subdir}/${testdir}
 
@@ -30,8 +28,8 @@ set testfile1 "${testdir}/first"
 set srcfile1 ${srcdir}/${subdir}/${testfile1}.adb
 set binfile1 ${objdir}/${subdir}/${testfile1}$EXEEXT
 
-if {[gdb_compile_ada "${srcfile1}" "${binfile1}" executable {debug}] != ""} {
-    return -1
+if {[gdb_compile_ada "${srcfile1}" "${binfile1}" executable [list debug ]] != "" } {
+  return -1
 }
 
 # Build the second test program
@@ -39,8 +37,8 @@ set testfile2 "${testdir}/second"
 set srcfile2 ${srcdir}/${subdir}/${testfile2}.adb
 set binfile2 ${objdir}/${subdir}/${testfile2}$EXEEXT
 
-if {[gdb_compile_ada "${srcfile2}" "${binfile2}" executable {debug}] != ""} {
-    return -1
+if {[gdb_compile_ada "${srcfile2}" "${binfile2}" executable [list debug ]] != "" } {
+  return -1
 }
 
 # Start with a fresh gdb.
index 1a288c76082a29c0820be21e233fcd581fa4b955..b9c25ec42bd857a9f34b2f494bd012b3364c3860 100644 (file)
@@ -21,16 +21,14 @@ if $tracelevel then {
 
 load_lib "ada.exp"
 
-if { [skip_ada_tests] } { return -1 }
-
 set testdir "fixed_points"
 set testfile "${testdir}/fixed_points"
 set srcfile ${srcdir}/${subdir}/${testfile}.adb
 set binfile ${objdir}/${subdir}/${testfile}
 
 file mkdir ${objdir}/${subdir}/${testdir}
-if {[gdb_compile_ada "${srcfile}" "${binfile}" executable {debug}] != ""} {
-    return -1
+if {[gdb_compile_ada "${srcfile}" "${binfile}" executable [list debug ]] != "" } {
+  return -1
 }
 
 gdb_exit
index 745ebd74939a0d7db480d73db02166b0d03bdc81..8f5cb86cb97bac42d5c11bc65a2ec7bca03370c2 100644 (file)
@@ -21,16 +21,14 @@ if $tracelevel then {
 
 load_lib "ada.exp"
 
-if { [skip_ada_tests] } { return -1 }
-
 set testdir "null_record"
 set testfile "${testdir}/null_record"
 set srcfile ${srcdir}/${subdir}/${testfile}.adb
 set binfile ${objdir}/${subdir}/${testfile}
 
 file mkdir ${objdir}/${subdir}/${testdir}
-if {[gdb_compile_ada "${srcfile}" "${binfile}" executable {debug}] != ""} {
-    return -1
+if {[gdb_compile_ada "${srcfile}" "${binfile}" executable [list debug ]] != "" } {
+  return -1
 }
 
 gdb_exit
index deaf6d89fa608ca3e0c33e9a634a33aecb428218..5331108ed54e9ecb30e87e8d8b6551c99b88291f 100644 (file)
@@ -21,16 +21,14 @@ if $tracelevel then {
 
 load_lib "ada.exp"
 
-if { [skip_ada_tests] } { return -1 }
-
 set testdir "packed_array"
 set testfile "${testdir}/pa"
 set srcfile ${srcdir}/${subdir}/${testfile}.adb
 set binfile ${objdir}/${subdir}/${testfile}
 
 file mkdir ${objdir}/${subdir}/${testdir}
-if {[gdb_compile_ada "${srcfile}" "${binfile}" executable {debug}] != ""} {
-    return -1
+if {[gdb_compile_ada "${srcfile}" "${binfile}" executable [list debug ]] != "" } {
+  return -1
 }
 
 gdb_exit
index d1e4907d3c5025d538a7050743c7996b273f04d5..a658bd7cdfd32270426e291a0c036d874a9b880f 100644 (file)
@@ -21,16 +21,14 @@ if $tracelevel then {
 
 load_lib "ada.exp"
 
-if { [skip_ada_tests] } { return -1 }
-
 set testdir "start"
 set testfile "${testdir}/dummy"
 set srcfile ${srcdir}/${subdir}/${testfile}.adb
 set binfile ${objdir}/${subdir}/${testfile}
 
 file mkdir ${objdir}/${subdir}/${testdir}
-if {[gdb_compile_ada "${srcfile}" "${binfile}" executable {debug}] != ""} {
-    return -1
+if {[gdb_compile_ada "${srcfile}" "${binfile}" executable [list debug ]] != "" } {
+  return -1
 }
 
 gdb_exit
index ff5a5b4fe47657e8a60fa6377210e69cab5a0fb8..a49f0df01c9fc7082da69a93eeefd7162788cabb 100644 (file)
@@ -21,16 +21,14 @@ if $tracelevel then {
 
 load_lib "ada.exp"
 
-if { [skip_ada_tests] } { return -1 }
-
 set testdir "watch_arg"
 set testfile "${testdir}/watch"
 set srcfile ${srcdir}/${subdir}/${testfile}.adb
 set binfile ${objdir}/${subdir}/${testfile}
 
 file mkdir ${objdir}/${subdir}/${testdir}
-if {[gdb_compile_ada "${srcfile}" "${binfile}" executable {debug}] != ""} {
-    return -1
+if {[gdb_compile_ada "${srcfile}" "${binfile}" executable [list debug ]] != "" } {
+  return -1
 }
 
 gdb_exit
index 8e7d59c429e83bc9e3ecc16f733d5466e7ce3c21..2e9c914cba25f1a92c3f95ab3e036a7ad648b712 100644 (file)
@@ -23,14 +23,12 @@ if $tracelevel then {
        strace $tracelevel
 }
 
-if { [skip_fortran_tests] } { return -1 }
-
 set testfile "array-element"
 set srcfile ${testfile}.f
 set binfile ${objdir}/${subdir}/${testfile}
 
-if {[gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" \
-        executable {debug f77}] != ""} {
+if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug f77 quiet}] != "" } {
+    untested "Couldn't compile ${srcfile}"
     return -1
 }
 
index 98b63f63909666c24ad481ca4a4959b9fdee2efa..8e053ab9cfdabd1c72f62177318f069a18c2b24e 100644 (file)
@@ -23,14 +23,12 @@ if $tracelevel then {
        strace $tracelevel
 }
 
-if { [skip_fortran_tests] } { return -1 }
-
 set testfile "derived-type"
 set srcfile ${testfile}.f90
 set binfile ${objdir}/${subdir}/${testfile}
 
-if {[gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" \
-        executable {debug f77}] != ""} {
+if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug f77 quiet}] != "" } {
+    untested "Couldn't compile ${srcfile}"
     return -1
 }
 
index fa77d0e42a1acd1b240f270e6e8d36acf8c07624..fa8385ca8f0987b3668249111d76706e12280873 100644 (file)
@@ -24,8 +24,6 @@ if $tracelevel then {
        strace $tracelevel
 }
 
-if { [skip_fortran_tests] } { continue }
-
 set prms_id 0
 set bug_id 0
 
index adb756007787d2dc88efe539fb711511421e0066..fb5ddb5bea78dcaba73c8496ea36c8d7255b378c 100644 (file)
@@ -23,14 +23,12 @@ if $tracelevel then {
        strace $tracelevel
 }
 
-if { [skip_fortran_tests] } { return -1 }
-
 set testfile "subarray"
 set srcfile ${testfile}.f
 set binfile ${objdir}/${subdir}/${testfile}
 
-if {[gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" \
-       executable {debug f77}] != ""} {
+if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug f77 quiet}] != "" } {
+    untested "Couldn't compile ${srcfile}"
     return -1
 }
 
index 9ca4790f182c5c546bda63fe0bdc3c20cf9faedf..e18b76e9aa8351c036304a4dea4bd544db757ac9 100644 (file)
@@ -24,8 +24,6 @@ if $tracelevel then {
        strace $tracelevel
 }
 
-if { [skip_fortran_tests] } { continue }
-
 set prms_id 0
 set bug_id 0
 
index 6b62708ed46af8b3e25ab2a3576fc5ae39324a2b..79cb1dd1f3d1f8090e507f4c7fcf12221722132d 100644 (file)
@@ -23,13 +23,12 @@ if $tracelevel then {
 
 load_lib "java.exp"
 
-if { [skip_java_tests] } { continue }
-
 set testfile "jmain"
 set srcfile ${srcdir}/$subdir/${testfile}.java
 set binfile ${objdir}/${subdir}/${testfile}
-if {[compile_java_from_source ${srcfile} ${binfile} "-g"] != ""} {
-    continue
+if  { [compile_java_from_source ${srcfile} ${binfile} "-g"] != "" } {
+    untested "Couldn't compile ${srcfile}"
+    return -1
 }
 
 set prms_id 0
index 74557bd420695ed6a00e381f9accdb10c844f558..1901cecca0505718bffc0b9b55ff03ce65439f48 100644 (file)
@@ -26,13 +26,12 @@ if $tracelevel then {
 
 load_lib "java.exp"
 
-if { [skip_java_tests] } { continue }
-
 set testfile "jmisc"
 set srcfile ${srcdir}/$subdir/${testfile}.java
 set binfile ${objdir}/${subdir}/${testfile}
-if {[compile_java_from_source ${srcfile} ${binfile} "-g"] != ""} {
-    continue
+if  { [compile_java_from_source ${srcfile} ${binfile} "-g"] != "" } {
+    untested "Couldn't compile ${srcfile}"
+    return -1
 }
 
 # Set the current language to java.  This counts as a test.  If it
index 4926babceb0bc936d012b88e801a45c60cc23a5f..73c422fad170dbb28a281d0985749da3920dced1 100644 (file)
@@ -23,13 +23,12 @@ if $tracelevel then {
 
 load_lib "java.exp"
 
-if { [skip_java_tests] } { continue }
-
 set testfile "jprint"
 set srcfile ${srcdir}/$subdir/${testfile}.java
 set binfile ${objdir}/${subdir}/${testfile}
-if {[compile_java_from_source ${srcfile} ${binfile} "-g"] != ""} {
-    continue
+if  { [compile_java_from_source ${srcfile} ${binfile} "-g"] != "" } {
+    untested "Couldn't compile ${srcfile}"
+    return -1
 }
 
 # Set the current language to java.  This counts as a test.  If it
index c31fbf77dea92cb0f8bd819964570979cf1e00d6..26e7495e31aa90daa5eb5bbb0bac7ea9d2103d8c 100644 (file)
@@ -21,10 +21,6 @@ if $tracelevel then {
        strace $tracelevel
 }
 
-load_lib "java.exp"
-
-if { [skip_java_tests] } { continue }
-
 set prms_id 0
 set bug_id 0
 
index 63b909c1b5625c01feb5743ded8146d25ee4c19a..8e600145dccb5796f278efaf58a643089e2158e4 100644 (file)
@@ -20,8 +20,6 @@
 load_lib mi-support.exp
 set MIFLAGS "-i=mi"
 
-if { [skip_fortran_tests] } { return -1 }
-
 gdb_exit
 if [mi_gdb_start] {
     continue
@@ -30,8 +28,8 @@ if [mi_gdb_start] {
 set testfile "array"
 set srcfile ${testfile}.f
 set binfile ${objdir}/${subdir}/${testfile}
-if {[gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" \
-        executable {debug f77}] != ""} {
+if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug f77 quiet}] != "" } {
+    untested "Couldn't compile ${srcfile}"
     return -1
 }
 
index 44d38a74e6331d8775686189cc8b41646b9dce46..bf9c41238b10444c7fd1c23c94083fd11897d3ab 100644 (file)
@@ -425,8 +425,9 @@ proc gdb_compile_ada {source dest type options} {
     # gdb_compile to determine whether the build has succeeded or not.
     # We therefore simply check whether the dest file has been created
     # or not. Unless not present, the build has succeeded.
-    if [file exists $dest] { set result "" }
-    gdb_compile_test $source $result
-    return $result
+    if ![file exists $dest] {
+        unsupported "Ada compilation failed: $result"
+        return "Ada compilation failed."
+    }
 }
 
index 9c87cc75d88b7ebef47bc79027f8807b18063366..4c440248040021bbcf81c82713afed7d7f8e082a 100644 (file)
@@ -1142,22 +1142,6 @@ proc default_gdb_start { } {
     return 0;
 }
 
-# Examine the output of compilation to determine whether compilation
-# failed or not.  If it failed determine whether it is due to missing
-# compiler or due to compiler error.  Report pass, fail or unsupported
-# as appropriate
-
-proc gdb_compile_test {src output} {
-    if { $output == "" } {
-       pass "compilation [file tail $src]"
-    } elseif { [regexp {^[a-zA-Z_0-9]+: Can't find [^ ]+\.$} $output] } {
-       unsupported "compilation [file tail $src]"
-    } else {
-       verbose -log "compilation failed: $output" 2
-       fail "compilation [file tail $src]"
-    }
-}
-
 # Return a 1 for configurations for which we don't even want to try to
 # test C++.
 
@@ -1168,6 +1152,7 @@ proc skip_cplus_tests {} {
     if { [istarget "h8300-*-*"] } {
        return 1
     }
+
     # The C++ IO streams are too large for HC11/HC12 and are thus not
     # available.  The gdb C++ tests use them and don't compile.
     if { [istarget "m6811-*-*"] } {
@@ -1185,18 +1170,6 @@ proc skip_fortran_tests {} {
     return 0
 }
 
-# Return a 1 if I don't even want to try to test ada.
-
-proc skip_ada_tests {} {
-    return 0
-}
-
-# Return a 1 if I don't even want to try to test java.
-
-proc skip_java_tests {} {
-    return 0
-}
-
 # Run a test on the target to see if it supports vmx hardware.  Return 0 if so, 
 # 1 if it does not.  Based on 'check_vmx_hw_available' from the GCC testsuite.
 
@@ -1547,15 +1520,8 @@ proc gdb_compile {source dest type options} {
     set result [target_compile $source $dest $type $options];
     regsub "\[\r\n\]*$" "$result" "" result;
     regsub "^\[\r\n\]*" "$result" "" result;
-    
-    if {[lsearch $options quiet] < 0} {
-       # We shall update this on a per language basis, to avoid
-       # changing the entire testsuite in one go.
-       if {[lsearch $options f77] >= 0} {
-           gdb_compile_test $source $result
-       } elseif { $result != "" } {
-           clone_output "gdb compile failed, $result"
-       }
+    if { $result != "" && [lsearch $options quiet] == -1} {
+       clone_output "gdb compile failed, $result"
     }
     return $result;
 }
index c445f9824efd429d4004f912dff45256b3aa5e93..7916772e0be3de2714687f010d2c4da34a1b0131 100644 (file)
@@ -91,19 +91,31 @@ proc java_init { args } {
 #
 proc compile_java_from_source { srcfile binfile compile_args } {
     global GCJ_UNDER_TEST
+    global runtests
     global java_initialized
 
     if { $java_initialized != 1 } { java_init }
 
+    set errname [file rootname [file tail $srcfile]]
+    if {! [runtest_file_p $runtests $errname]} {
+        return
+    }
+
     set args "compiler=$GCJ_UNDER_TEST"
     lappend args "additional_flags=--main=[file rootname [file tail $srcfile]]"
     if { $compile_args != "" } {
        lappend args "additional_flags=$compile_args"
     }
 
-    set result [target_compile $srcfile ${binfile} ${binfile} executable $args]
-    gdb_compile_test $srcfile $result
-    return $result
+    if { $compile_args != "" } {
+       set errname "$errname $compile_args"
+    }
+
+    set x [target_compile $srcfile ${binfile} executable $args]
+    if { $x != "" } {
+       verbose "target_compile failed: $x" 2
+       return "$errname compilation from source";
+    }
 }
 
 # Local Variables: