}
set bp_location1 {main.T.Foo}
-set bp_location2 {main.(*T).Bar}
-set bp_location2_regexp {main.\(\*T\).Bar}
+set bp_location2 {main.T.Bar}
if { [go_runto_main] < 0 } {
untested "could not run to main"
exp_continue
}
-re "^\r\n void main.T.Bar\[^\r\n\]*(?=\r\n)" {
- set found_wrong_bar 2
exp_continue
}
-re "\r\n$gdb_prompt $" {
# <1><528>: Abbrev Number: 19 (DW_TAG_subprogram)
# <529> DW_AT_name : main.Bar.pN6_main.T
setup_xfail "*-*-*"
-} elseif { $found_wrong_bar == 2 } {
+} else {
# We have with gccgo-8/9/10:
# <1><6e4>: Abbrev Number: 24 (DW_TAG_subprogram)
# <6e5> DW_AT_name : main.Bar..1main.T
# <6ec> DW_AT_linkage_name: main.T.Bar
- # xfail for GCC PR93866
- setup_xfail "*-*-*"
-} else {
+
# For reference: with go1.11.13:
# <1><6c49a>: Abbrev Number: 2 (DW_TAG_subprogram)
# <6c49b> DW_AT_name : main.(*T).Bar
- }
+
+ # It has been clarified in PR gcc/93866 that it's ok that symbols names
+ # diverge between gc and gccgo. So, we accept the main.T.Bar as valid.
+}
if { [gdb_breakpoint ${bp_location2} message] } {
- gdb_test "cont" "Breakpoint .*, ${bp_location2_regexp}.*" \
+ gdb_test "cont" "Breakpoint .*, ${bp_location2}.*" \
"going to second breakpoint"
}