From 74921315b6734554793a37f7a152878c45b7d4ac Mon Sep 17 00:00:00 2001 From: Keith Seitz Date: Wed, 13 Nov 2013 12:33:34 -0800 Subject: PR c++/7539 PR c++/10541 This patch fixes some namespace alias bugs reported in the above bugs. Links to all mailing list discussion: https://sourceware.org/ml/gdb-patches/2013-07/msg00649.html https://sourceware.org/ml/gdb-patches/2013-09/msg00557.html https://sourceware.org/ml/gdb-patches/2013-11/msg00156.html --- gdb/testsuite/ChangeLog | 9 ++ gdb/testsuite/gdb.cp/nsalias.cc | 23 +++ gdb/testsuite/gdb.cp/nsalias.exp | 322 ++++++++++++++++++++++++++++++++++++++ gdb/testsuite/gdb.cp/nsrecurs.exp | 10 +- 4 files changed, 360 insertions(+), 4 deletions(-) create mode 100644 gdb/testsuite/gdb.cp/nsalias.cc create mode 100644 gdb/testsuite/gdb.cp/nsalias.exp (limited to 'gdb/testsuite') diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index 5c9d579..5d1de05 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,12 @@ +2013-09-17 Keith Seitz + + PR c++/7935 + PR c++/10541 + * gdb.cp/nsalias.exp: New file. + * gdb.cp/nsalias.cc: New file. + * gdb.cp/nsrecurs.exp: Remove kfails. Conditionally run + tests only on known, working compiler versions. + 2013-11-13 Tom Tromey * gdb.multi/multi-arch-exec.exp: Define BASEDIR when compiling. diff --git a/gdb/testsuite/gdb.cp/nsalias.cc b/gdb/testsuite/gdb.cp/nsalias.cc new file mode 100644 index 0000000..be2dfbe --- /dev/null +++ b/gdb/testsuite/gdb.cp/nsalias.cc @@ -0,0 +1,23 @@ +/* This testcase is part of GDB, the GNU debugger. + + Copyright 2013 Free Software Foundation, Inc. + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . */ + +int +main () +{ + return 0; +} + diff --git a/gdb/testsuite/gdb.cp/nsalias.exp b/gdb/testsuite/gdb.cp/nsalias.exp new file mode 100644 index 0000000..61bf72f --- /dev/null +++ b/gdb/testsuite/gdb.cp/nsalias.exp @@ -0,0 +1,322 @@ +# Copyright 2013 Free Software Foundation, Inc. + +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +# Test namespace aliases. +# PRs c++/7935, c++/10541 + +load_lib dwarf.exp + +if {![dwarf2_support]} { + return 0 +} + +if {[skip_cplus_tests]} { + continue +} + +standard_testfile .cc nsalias-dw.S + +# Make the DWARF used for the test. This is necessary to work +# around compiler issues. Not all versions of gcc output the +# correct debuginfo we need. +# +# This should create the equivalent DWARF to: +# +# namespace outer +# { +# namespace inner +# { +# namespace innermost +# { +# const int x = 2; +# int foo (void) { return x; } +# } +# +# namespace Innermost = innermost; +# +# const int x = 1; +# int foo (void) { return x + Innermost::foo (); } +# } +# +# namespace Inner = inner; +# +# const int x = 0; +# int foo (void) { return x + Inner::foo (); } +# } +# +# namespace Outer = outer; +# namespace oi = Outer::Inner; + +set asm_file [standard_output_file $srcfile2] +Dwarf::assemble $asm_file { + cu {} { + compile_unit {{language @DW_LANG_C_plus_plus}} { + declare_labels int_label outer_label inner_label innermost_label + declare_labels im_foo_label i_foo_label o_foo_label + declare_labels OuterInner_label oi1_label oi2_label + + int_label: base_type { + {name int} + {encoding @DW_ATE_signed} + {byte_size 4 DW_FORM_sdata} + } + + outer_label: DW_TAG_namespace { + {name outer} + } { + inner_label: DW_TAG_namespace { + {name inner} + } { + innermost_label: DW_TAG_namespace { + {name innermost} + } { + DW_TAG_variable { + {name x} + {type :$int_label} + {const_value 2 DW_FORM_data1} + } + + im_foo_label: DW_TAG_subprogram { + {name foo} + {external 1} + {declaration 1} + } + } + + imported_declaration { + {name Innermost} + {import :$innermost_label} + } + + DW_TAG_variable { + {name x} + {type :$int_label} + {const_value 1 DW_FORM_data1} + } + + i_foo_label: subprogram { + {name foo} + {external 1} + {declaration 1} + } + } + + OuterInner_label: imported_declaration { + {name Inner} + {import :$inner_label} + } + + DW_TAG_variable { + {name x} + {type :$int_label} + {const_value 0 DW_FORM_data1} + } + + o_foo_label: subprogram { + {name foo} + {external 1} + {declaration 1} + } + } + + imported_declaration { + {name Outer} + {import :$outer_label} + } + + oi1_label: imported_declaration { + {name oi1} + {import :$OuterInner_label} + } + + oi2_label: imported_declaration { + {name oi2} + {import :$oi1_label} + } + + imported_declaration { + {name oi3} + {import :$oi2_label} + } + + subprogram { + {specification :$im_foo_label} + {low_pc 0x0} + {high_pc 0x1} + } + + subprogram { + {specification :$i_foo_label} + {low_pc 0x2} + {high_pc 0x3} + } + + subprogram { + {specification :$o_foo_label} + {low_pc 0x4} + {high_pc 0x5} + } + } + } +} + +if {[gdb_compile $srcdir/$subdir/$srcfile ${binfile}1.o \ + object {c++ debug}] != ""} { + return -1 +} + +if {[gdb_compile $asm_file ${binfile}2.o object {nodebug}] != ""} { + return -1 +} + +if {[gdb_compile [list ${binfile}1.o ${binfile}2.o] \ + $binfile executable {c++}] != ""} { + return -1 +} + +clean_restart $testfile + +# A procedure to run various tests on aliased namespaces. +proc do_alias_tests {ns {real ""} {x ""}} { + + # The "real" namespace is simply NS in all lowercase. + if {$real == ""} { + set real [string tolower $ns] + } + + # The value of `x' is the number of '::' in NS. + if {$x == ""} { + set x [expr {[llength [split $ns ":"]] / 2}] + } + + # Test "whatis" + gdb_test "whatis $ns" "type = $real" + + # Test "ptype" + gdb_test "ptype $ns" "type = namespace $real" + + # Print 'x' + send_log "expecting x = $x\n" + gdb_test "print ${ns}::x" " = $x" + + # Attempt to list the function. + gdb_test_no_output "list ${ns}::foo" + + # Attempt to break on the start of the function. + gdb_breakpoint "*${ns}::foo" + + # And then erase it + with_test_prefix "($ns)" { + gdb_test_no_output "delete \$bpnum" + } +} + +# This is a list of all the permutations to be tested. For troubleshooting +# purposes, this list is explicitly enumerated. + +set permutations {} +lappend permutations "outer" +lappend permutations "Outer" +lappend permutations "outer::inner" +lappend permutations "Outer::inner" +lappend permutations "outer::Inner" +lappend permutations "Outer::Inner" +lappend permutations "outer::inner::innermost" +lappend permutations "outer::inner::Innermost" +lappend permutations "outer::Inner::innermost" +lappend permutations "outer::Inner::Innermost" +lappend permutations "Outer::inner::innermost" +lappend permutations "Outer::inner::Innermost" +lappend permutations "Outer::Inner::innermost" +lappend permutations "Outer::Inner::Innermost" + +foreach p $permutations { + do_alias_tests $p +} + +# Test recursively imported aliases. +foreach ns {"oi1" "oi2" "oi3"} { + do_alias_tests $ns "outer::inner" 1 + do_alias_tests "${ns}::innermost" "outer::inner::innermost" 2 + do_alias_tests "${ns}::Innermost" "outer::inner::innermost" 2 +} + +# Generate another objfile with nested imported declarations. + +set imports { + declare_labels n0_label + + n0_label: DW_TAG_namespace { + {name n0} + } { + DW_TAG_variable { + {name x} + {type :$int_label} + {const_value 3 DW_FORM_data1} + } + } + + declare_labels n0_import + n0_import: imported_declaration { + {name N0} + {import :$n0_label} + } +} + +for {set i 1} {$i <= 100} {incr i} { + append imports [format " + declare_labels n%d_import + n%d_import: imported_declaration { + {name N%d} + {import :\$n%d_import} + }" $i $i $i [expr {$i - 1}]] +} + +standard_testfile .cc nsalias-r-dw.S + +set asm_file [standard_output_file $srcfile2] +set the_dwarf [format { + cu {} { + compile_unit {{language @DW_LANG_C_plus_plus}} { + declare_labels int_label n0_label + + int_label: base_type { + {name int} + {encoding @DW_ATE_signed} + {byte_size 4 DW_FORM_sdata} + } + +%s + } + } +} $imports] + +Dwarf::assemble $asm_file $the_dwarf + +if {[gdb_compile $asm_file ${binfile}3.o object {nodebug}] != ""} { + return -1 +} + +if {[gdb_compile [list ${binfile}1.o ${binfile}3.o] \ + ${binfile}-r executable {c++}] != ""} { + return -1 +} + +clean_restart ${testfile}-r + +gdb_test_no_output "set complaints 1" +gdb_test "print N100::x" \ + ".* has too many recursively imported declarations.*" \ + "compaint for too many recursively imported declarations" diff --git a/gdb/testsuite/gdb.cp/nsrecurs.exp b/gdb/testsuite/gdb.cp/nsrecurs.exp index 0537e89..9cf4331 100644 --- a/gdb/testsuite/gdb.cp/nsrecurs.exp +++ b/gdb/testsuite/gdb.cp/nsrecurs.exp @@ -52,8 +52,10 @@ gdb_test "print xx" "= 999" # Test printing using recursive namespace # aliases. -setup_kfail "gdb/10541" "*-*-*" -gdb_test "ptype G::GF" "= namespace F" +if {![test_compiler_info {gcc-[0-3]-*}]} { + gdb_test "ptype G::GF" "= namespace F" -setup_kfail "gdb/10541" "*-*-*" -gdb_test "print G::GF::FE::ex" "= 9999" + if {![test_compiler_info {gcc-4-[0-3]-*}]} { + gdb_test "print G::GF::FE::ex" "= 9999" + } +} -- cgit v1.1