| Index: gdb/testsuite/gdb.cp/ovldbreak.exp
|
| diff --git a/gdb/testsuite/gdb.cp/ovldbreak.exp b/gdb/testsuite/gdb.cp/ovldbreak.exp
|
| index f8cd42f5660c4fde5b7ffc671eaebdd75f1f9e18..1aad559c080812e7c00bda495794d2669bae254c 100644
|
| --- a/gdb/testsuite/gdb.cp/ovldbreak.exp
|
| +++ b/gdb/testsuite/gdb.cp/ovldbreak.exp
|
| @@ -25,39 +25,25 @@
|
|
|
| global timeout
|
| set timeout 15
|
| -if $tracelevel then {
|
| - strace $tracelevel
|
| - }
|
| -
|
| #
|
| # test running programs
|
| #
|
|
|
| if { [skip_cplus_tests] } { continue }
|
|
|
| -set testfile "ovldbreak"
|
| -set srcfile ${testfile}.cc
|
| -set binfile ${objdir}/${subdir}/${testfile}
|
| +standard_testfile .cc
|
|
|
| -if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug c++}] != "" } {
|
| - untested ovldbreak.exp
|
| - return -1
|
| +if {[prepare_for_testing $testfile.exp $testfile $srcfile {debug c++}]} {
|
| + return -1
|
| }
|
|
|
| -gdb_exit
|
| -gdb_start
|
| -gdb_reinitialize_dir $srcdir/$subdir
|
| -gdb_load ${binfile}
|
| -
|
| # set it up at a breakpoint so we can play with the variable values
|
| #
|
| -if ![runto_main] then {
|
| +if {![runto_main]} {
|
| perror "couldn't run to breakpoint"
|
| continue
|
| }
|
|
|
| -
|
| -
|
| # When I ask gdb to set a breakpoint on an overloaded function,
|
| # gdb gives me a choice menu. I might get stuck in that choice menu
|
| # (for example, if C++ name mangling is not working properly).
|
| @@ -124,68 +110,113 @@ proc set_bp_overloaded {name expectedmenu mychoice bpnumber linenumber} {
|
| }
|
| }
|
|
|
| -# This is the expected menu for overload1arg.
|
| +# Compute the expected menu for overload1arg.
|
| # Note the arg type variations for void and integer types.
|
| # This accommodates different versions of g++.
|
|
|
| -set menu_overload1arg "\\\[0\\\] cancel\r\n"
|
| -append menu_overload1arg "\\\[1\\\] all\r\n"
|
| -append menu_overload1arg "\\\[2\\\] .*$srcfile:foo::overload1arg\\(double\\)\r\n"
|
| -append menu_overload1arg "\\\[3\\\] .*$srcfile:foo::overload1arg\\(float\\)\r\n"
|
| -append menu_overload1arg "\\\[4\\\] .*$srcfile:foo::overload1arg\\((unsigned long|long unsigned)( int)?\\)\r\n"
|
| -append menu_overload1arg "\\\[5\\\] .*$srcfile:foo::overload1arg\\(long( int)?\\)\r\n"
|
| -append menu_overload1arg "\\\[6\\\] .*$srcfile:foo::overload1arg\\((unsigned int|unsigned)\\)\r\n"
|
| -append menu_overload1arg "\\\[7\\\] .*$srcfile:foo::overload1arg\\(int\\)\r\n"
|
| -append menu_overload1arg "\\\[8\\\] .*$srcfile:foo::overload1arg\\((unsigned short|short unsigned)( int)?\\)\r\n"
|
| -append menu_overload1arg "\\\[9\\\] .*$srcfile:foo::overload1arg\\(short( int)?\\)\r\n"
|
| -append menu_overload1arg "\\\[10\\\] .*$srcfile:foo::overload1arg\\(unsigned char\\)\r\n"
|
| -append menu_overload1arg "\\\[11\\\] .*$srcfile:foo::overload1arg\\(signed char\\)\r\n"
|
| -append menu_overload1arg "\\\[12\\\] .*$srcfile:foo::overload1arg\\(char\\)\r\n"
|
| -append menu_overload1arg "\\\[13\\\] .*$srcfile:foo::overload1arg\\((void|)\\)\r\n"
|
| -append menu_overload1arg "> $"
|
| +# Probe for the real types. This will do some unnecessary checking
|
| +# for some simple types (like "int"), but it's just easier to loop
|
| +# over all_types instead of calling out just the exceptions.
|
| +# This list /must/ remain in the same order that the methods are
|
| +# called in the source code. Otherwise the order in which breakpoints
|
| +# are hit (tested below) will be incorrect.
|
| +set all_types [list void char signed_char unsigned_char short_int \
|
| + unsigned_short_int int unsigned_int long_int \
|
| + unsigned_long_int float double]
|
| +
|
| +# ARGUMENTS is an array that will map from synthetic type to argument
|
| +# expressions in the source code, which is of the form "arg = $decimal".
|
| +# ARGUMENTS stores this decimal number.
|
| +array set arguments {
|
| + void ""
|
| + char 2
|
| + signed_char 3
|
| + unsigned_char 4
|
| + short_int 5
|
| + unsigned_short_int 6
|
| + int 7
|
| + unsigned_int 8
|
| + long_int 9
|
| + unsigned_long_int 10
|
| + float 100(.0)?
|
| + double 200(.0)?
|
| +}
|
| +
|
| +unset -nocomplain line types
|
| +foreach type $all_types {
|
| + # TYPES is an array that maps the synthetic names in ALL_TYPES
|
| + # to the real type used in the debugger. These will be checked
|
| + # below and changed if the debugger thinks they are different from
|
| + # their default values.
|
| + set types($type) [join [split $type "_"] " "]
|
| +
|
| + # LINE is an array that will map from synthetic type to line number.
|
| + # in the source code.
|
| + set line($type) [gdb_get_line_number "fo1 $type"]
|
| +
|
| + # Probe for the actual type.
|
| + gdb_test_multiple "print &foo::overload1arg($types($type))" \
|
| + "probe $types($type)" {
|
| + -re ".*\<foo::.*\>.*$gdb_prompt $" {
|
| + regexp {<.*>} $expect_out(0,string) func
|
| + regexp {\(.*\)} $func real_type
|
| +
|
| + # Store the real type into TYPES.
|
| + set types($type) [string trim $real_type {()}]
|
| +
|
| + # Create an inverse mapping of the actual type to
|
| + # the synthetic type.
|
| + set type_map("$types($type)") $type
|
| + pass "detect $type"
|
| + }
|
| + }
|
| +}
|
| +
|
| +# This is a list of the actual overloaded method arguments.
|
| +set overloads {}
|
| +foreach type $all_types {
|
| + lappend overloads $types($type)
|
| +}
|
| +
|
| +# Sort this list alphabetically.
|
| +set overloads [lsort $overloads]
|
| +
|
| +# Create the menu list.
|
| +set items {"cancel" "all"}
|
| +foreach ovld $overloads {
|
| + lappend items "$srcfile:foo::overload1arg\\($ovld\\)"
|
| +}
|
| +set menu_items {}
|
| +set idx 0
|
| +foreach item $items {
|
| + lappend menu_items ".$idx. .*$item"
|
| + incr idx
|
| +}
|
| +set menu_overload1arg [join $menu_items {[\r\n]*}]
|
| +append menu_overload1arg {[\r\n]*> $}
|
|
|
| # Set multiple-symbols to "ask", to allow us to test the use
|
| # of the multiple-choice menu when breaking on an overloaded method.
|
| gdb_test_no_output "set multiple-symbols ask"
|
|
|
| # Set breakpoints on foo::overload1arg, one by one.
|
| -
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 12 2 111
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 11 3 112
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 10 4 113
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 9 5 114
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 8 6 115
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 7 7 116
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 6 8 117
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 5 9 118
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 4 10 119
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 3 11 120
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 2 12 121
|
| -set_bp_overloaded "foo::overload1arg" "$menu_overload1arg" 13 13 110
|
| -
|
| -
|
| +set bpnum 1
|
| +set method "foo::overload1arg"
|
| +for {set idx 0} {$idx < [llength $overloads]} {incr idx} {
|
| + set type [lindex $overloads $idx]
|
| + set_bp_overloaded $method $menu_overload1arg \
|
| + [expr {$idx + 2}] [incr bpnum] $line($type_map("$type"))
|
| +}
|
|
|
| # Verify the breakpoints.
|
| -
|
| -gdb_test "info break" \
|
| - "Num Type\[\t \]+Disp Enb Address\[\t \]+What.*
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in main(\\((|void)\\))? at.*$srcfile:49\r
|
| -\[\t \]+breakpoint already hit 1 time\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(char\\) at.*$srcfile:111\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(signed char\\) at.*$srcfile:112\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(unsigned char\\) at.*$srcfile:113\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(short( int)?\\) at.*$srcfile:114\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((unsigned short|short unsigned)( int)?\\) at.*$srcfile:115\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(int\\) at.*$srcfile:116\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((unsigned|unsigned int)\\) at.*$srcfile:117\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(long( int)?\\) at.*$srcfile:118\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((unsigned long|long unsigned)( int)?\\) at.*$srcfile:119\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(float\\) at.*$srcfile:120\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(double\\) at.*$srcfile:121\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((void|)\\) at.*$srcfile:110" \
|
| - "breakpoint info (after setting one-by-one)"
|
| -
|
| -
|
| +set bptable "Num Type\[\t \]+Disp Enb Address\[\t \]+What.*"
|
| +append bptable "\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in main(\\((|void)\\))? at.*$srcfile:49\[\r\n\]+"
|
| +append bptable "\[\t \]+breakpoint already hit 1 time\[\r\n\]+"
|
| +foreach ovld $overloads {
|
| + append bptable [format "\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(%s\\) at.*$srcfile:%d\[\r\n\]+" $ovld \
|
| + $line($type_map("$ovld"))]
|
| +}
|
| +gdb_test "info break" $bptable "breakpoint info (after setting one-by-one)"
|
|
|
| # Test choice "cancel".
|
| # This is copy-and-paste from set_bp_overloaded.
|
| @@ -225,25 +256,7 @@ gdb_expect {
|
| }
|
| }
|
|
|
| -gdb_test "info break" \
|
| - "Num Type\[\t \]+Disp Enb Address\[\t \]+What.*
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in main(\\((|void)\\))? at.*$srcfile:49\r
|
| -\[\t \]+breakpoint already hit 1 time\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(char\\) at.*$srcfile:111\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(signed char\\) at.*$srcfile:112\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(unsigned char\\) at.*$srcfile:113\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(short( int)?\\) at.*$srcfile:114\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((unsigned short|short unsigned)( int)?\\) at.*$srcfile:115\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(int\\) at.*$srcfile:116\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((unsigned|unsigned int)\\) at.*$srcfile:117\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(long( int)?\\) at.*$srcfile:118\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((unsigned long|long unsigned)( int)?\\) at.*$srcfile:119\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(float\\) at.*$srcfile:120\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(double\\) at.*$srcfile:121\r
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((void|)\\) at.*$srcfile:110" \
|
| - "breakpoint info (after cancel)"
|
| -
|
| -
|
| +gdb_test "info break" $bptable "breakpoint info (after cancel)"
|
|
|
| # Delete these breakpoints.
|
|
|
| @@ -304,67 +317,73 @@ gdb_expect {
|
| }
|
| }
|
|
|
| -gdb_test "info break" \
|
| - "Num Type\[\t \]+Disp Enb Address\[\t \]+What.*
|
| -\[0-9\]+\[\t \]+breakpoint keep y\[\t \]+<MULTIPLE>\[\t \]*\r
|
| -\[0-9\]+.1\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(double\\) at.*$srcfile:121\r
|
| -\[0-9\]+.2\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(float\\) at.*$srcfile:120\r
|
| -\[0-9\]+.3\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((unsigned long|long unsigned)( int)?\\) at.*$srcfile:119\r
|
| -\[0-9\]+.4\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(long( int)?\\) at.*$srcfile:118\r
|
| -\[0-9\]+.5\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((unsigned|unsigned int)\\) at.*$srcfile:117\r
|
| -\[0-9\]+.6\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(int\\) at.*$srcfile:116\r
|
| -\[0-9\]+.7\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((unsigned short|short unsigned)( int)?\\) at.*$srcfile:115\r
|
| -\[0-9\]+.8\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(short( int)?\\) at.*$srcfile:114\r
|
| -\[0-9\]+.9\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(unsigned char\\) at.*$srcfile:113\r
|
| -\[0-9\]+.10\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(signed char\\) at.*$srcfile:112\r
|
| -\[0-9\]+.11\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(char\\) at.*$srcfile:111\r
|
| -\[0-9\]+.12\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\((void|)\\) at.*$srcfile:110" \
|
| - "breakpoint info (after setting on all)"
|
| -
|
| +# Create the breakpoint table for "info breakpoint".
|
| +set bptable "Num Type\[\t \]+Disp Enb Address\[\t \]+What.*\[\r\n]+"
|
| +append bptable "\[0-9\]+\[\t \]+breakpoint\[\t \]+keep\[\t \]y\[\t \]+<MULTIPLE>.*\[\r\n\]+"
|
| +foreach ovld {void char signed_char unsigned_char short_int \
|
| + unsigned_short_int int unsigned_int long_int \
|
| + unsigned_long_int float double} {
|
| + append bptable [format "\[0-9\]+.\[0-9\]+\[\t \]+y\[\t \]+$hex\[\t \]+in foo::overload1arg\\(%s\\) at.*$srcfile:%d\[\r\n\]+" \
|
| + $types($ovld) $line($ovld)]
|
| +}
|
|
|
| +gdb_test "info break" $bptable "breakpoint info (after setting on all)"
|
|
|
| # Run through each breakpoint.
|
| +proc continue_to_bp_overloaded {bpnumber might_fail line argtype argument} {
|
| + global gdb_prompt hex decimal srcfile
|
| +
|
| + if {$argument == ""} {
|
| + set actuals ""
|
| + } else {
|
| + set actuals "arg=$argument"
|
| + if {[regexp {char} $argtype]} {
|
| + append actuals " \\'\\\\00$argument\\'"
|
| + }
|
| + }
|
|
|
| -# NOTE: carlton/2003-02-03: I'm seeing failures on some of the tests,
|
| -# with the wrong arg being printed out. Michael Chastain sees
|
| -# failures at times, too, albeit fewer than I do.
|
| + if {[string match $argtype "void"]} {
|
| + set body "return $decimal;"
|
| + } else {
|
| + set body "arg = 0; return $decimal;"
|
| + }
|
|
|
| -proc continue_to_bp_overloaded {might_kfail bpnumber argtype actuals} {
|
| - global gdb_prompt hex decimal srcfile
|
| + gdb_test_multiple "continue" "continue to bp overloaded : $argtype" {
|
| + -re "Continuing.\r\n\r\nBreakpoint $bpnumber, foo::overload1arg \\(this=${hex}(, )?$actuals\\) at .*$srcfile:$line\r\n$decimal\[\t \]+{ $body }.*$gdb_prompt $" {
|
| + pass "continue to bp overloaded : $argtype"
|
| + }
|
|
|
| - send_gdb "continue\n"
|
| - gdb_expect {
|
| - -re "Continuing.\r\n\r\nBreakpoint ${bpnumber}, foo::overload1arg \\(this=${hex}(, )?${actuals}\\) at.*${srcfile}:${decimal}\r\n${decimal}\[\t \]+int foo::overload1arg \\(${argtype}( arg)?\\).*\r\n.*$gdb_prompt $" {
|
| - pass "continue to bp overloaded : ${argtype}"
|
| - }
|
| - -re "Continuing.\r\n\r\nBreakpoint ${bpnumber}, foo::overload1arg \\(this=${hex}, arg=.*\\) at.*${srcfile}:${decimal}\r\n${decimal}\[\t \]+int foo::overload1arg \\(${argtype}( arg)?\\).*\r\n.*$gdb_prompt $" {
|
| - if $might_kfail {
|
| - kfail "gdb/1025" "continue to bp overloaded : ${argtype}"
|
| - } else {
|
| - fail "continue to bp overloaded : ${argtype}"
|
| - }
|
| - }
|
| - -re ".*$gdb_prompt $" {
|
| - fail "continue to bp overloaded : ${argtype}"
|
| - }
|
| - timeout {
|
| - fail "continue to bp overloaded : ${argtype} (timeout)"
|
| - }
|
| + -re "Continuing.\r\n\r\nBreakpoint $bpnumber, foo::overload1arg \\(this=${hex}, arg=.*\\) at .*$srcfile:$line\r\n$decimal\[\t \]+{ $body }.*$gdb_prompt $" {
|
| + if $might_kfail {
|
| + kfail "c++/8130" "continue to bp overloaded : $argtype"
|
| + } else {
|
| + fail "continue to bp overloaded : $argtype"
|
| + }
|
| + }
|
| }
|
| }
|
|
|
| -continue_to_bp_overloaded 0 14 "(void|)" ""
|
| -continue_to_bp_overloaded 1 14 "char" "arg=2 \\'\\\\002\\'"
|
| -continue_to_bp_overloaded 1 14 "signed char" "arg=3 \\'\\\\003\\'"
|
| -continue_to_bp_overloaded 1 14 "unsigned char" "arg=4 \\'\\\\004\\'"
|
| -continue_to_bp_overloaded 1 14 "short" "arg=5"
|
| -continue_to_bp_overloaded 1 14 "unsigned short" "arg=6"
|
| -continue_to_bp_overloaded 0 14 "int" "arg=7"
|
| -continue_to_bp_overloaded 0 14 "(unsigned|unsigned int)" "arg=8"
|
| -continue_to_bp_overloaded 0 14 "long" "arg=9"
|
| -continue_to_bp_overloaded 0 14 "unsigned long" "arg=10"
|
| -continue_to_bp_overloaded 0 14 "float" "arg=100"
|
| -continue_to_bp_overloaded 1 14 "double" "arg=200"
|
| +# An array which describes which of these methods might be expected
|
| +# to kfail on GCC 2.95. See C++/8210.
|
| +array set might_fail {
|
| + void 0
|
| + char 1
|
| + signed_char 1
|
| + unsigned_char 1
|
| + short_int 1
|
| + unsigned_short_int 1
|
| + int 0
|
| + unsigned_int 0
|
| + long_int 0
|
| + unsigned_long_int 0
|
| + float 0
|
| + double 1
|
| +}
|
| +
|
| +foreach type $all_types {
|
| + continue_to_bp_overloaded 14 $might_fail($type) $line($type) \
|
| + $type $arguments($type)
|
| +}
|
|
|
| # Test breaking on an overloaded function when multiple-symbols
|
| # is set to "cancel"
|
| @@ -380,4 +399,5 @@ gdb_test "break foo::foofunc" \
|
|
|
| # That's all, folks.
|
|
|
| +unset -nocomplain line types
|
| gdb_continue_to_end "finish program"
|
|
|