From 4257b2dafc0a80b62c4316d54ac26971b709de63 Mon Sep 17 00:00:00 2001 From: tromey Date: Wed, 20 Jan 2010 03:11:17 +0000 Subject: [PATCH] gdb PR c++/8000: * dwarf2read.c (partial_die_parent_scope): Put enumeration type into parent scope, and enumerator into grandparent scope. gdb/testsuite PR c++/8000: * gdb.cp/namespace.exp: Use new enum. Fix line numbers in existing tests. * gdb.cp/namespace.cc (AAA::SomeEnum): New enum. (main): Use AAA::SomeEnum. --- gdb/ChangeLog | 6 ++++++ gdb/dwarf2read.c | 5 +++-- gdb/testsuite/ChangeLog | 8 ++++++++ gdb/testsuite/gdb.cp/namespace.cc | 6 ++++++ gdb/testsuite/gdb.cp/namespace.exp | 9 ++++++--- 5 files changed, 29 insertions(+), 5 deletions(-) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index b34eb93a8d..84f6736fe8 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2010-01-19 Tom Tromey + + PR c++/8000: + * dwarf2read.c (partial_die_parent_scope): Put enumeration type + into parent scope, and enumerator into grandparent scope. + 2010-01-19 Joel Brobecker * NEWS: Add entry for "set/show ada trust-PAD-over-XVS" commands. diff --git a/gdb/dwarf2read.c b/gdb/dwarf2read.c index 4903ac4a0b..db51653902 100644 --- a/gdb/dwarf2read.c +++ b/gdb/dwarf2read.c @@ -2386,7 +2386,8 @@ partial_die_parent_scope (struct partial_die_info *pdi, || parent->tag == DW_TAG_structure_type || parent->tag == DW_TAG_class_type || parent->tag == DW_TAG_interface_type - || parent->tag == DW_TAG_union_type) + || parent->tag == DW_TAG_union_type + || parent->tag == DW_TAG_enumeration_type) { if (grandparent_scope == NULL) parent->scope = parent->name; @@ -2394,7 +2395,7 @@ partial_die_parent_scope (struct partial_die_info *pdi, parent->scope = typename_concat (&cu->comp_unit_obstack, grandparent_scope, parent->name, cu); } - else if (parent->tag == DW_TAG_enumeration_type) + else if (parent->tag == DW_TAG_enumerator) /* Enumerators should not get the name of the enumeration as a prefix. */ parent->scope = grandparent_scope; else diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index 9c3dc8084c..e302bcb22d 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,11 @@ +2010-01-19 Tom Tromey + + PR c++/8000: + * gdb.cp/namespace.exp: Use new enum. Fix line numbers in + existing tests. + * gdb.cp/namespace.cc (AAA::SomeEnum): New enum. + (main): Use AAA::SomeEnum. + 2010-01-19 Jan Kratochvil * gdb.mi/mi-break.exp (set line_callme_head, set line_callme_body): New. diff --git a/gdb/testsuite/gdb.cp/namespace.cc b/gdb/testsuite/gdb.cp/namespace.cc index 4ac918764c..f918b63de9 100644 --- a/gdb/testsuite/gdb.cp/namespace.cc +++ b/gdb/testsuite/gdb.cp/namespace.cc @@ -8,6 +8,11 @@ namespace AAA { int xx; int fum (int); }; + enum SomeEnum { + ALPHA, + BETA, + DELTA + }; }; int AAA::inA::fum (int i) @@ -174,6 +179,7 @@ int main () { using AAA::inA; char c1; + AAA::SomeEnum var = AAA::ALPHA; using namespace BBB; diff --git a/gdb/testsuite/gdb.cp/namespace.exp b/gdb/testsuite/gdb.cp/namespace.exp index a2b8242e8c..4362fd840f 100644 --- a/gdb/testsuite/gdb.cp/namespace.exp +++ b/gdb/testsuite/gdb.cp/namespace.exp @@ -164,7 +164,7 @@ gdb_expect { # Break on a function in a namespace gdb_test "break AAA::xyzq" \ - "Breakpoint.*at $hex: file.*namespace.cc, line 42\\." + "Breakpoint.*at $hex: file.*namespace.cc, line 47\\." # Call a function in a nested namespace @@ -189,7 +189,7 @@ gdb_expect { # Break on a function in a nested namespace gdb_test "break BBB::CCC::xyzq" \ - "Breakpoint.*at $hex: file.*namespace.cc, line 58\\." + "Breakpoint.*at $hex: file.*namespace.cc, line 63\\." # Print address of a function in a class in a namespace @@ -214,7 +214,7 @@ gdb_expect { # Break on a function in a class in a namespace gdb_test "break BBB::Class::xyzq" \ - "Breakpoint.*at $hex: file.*namespace.cc, line 63\\." + "Breakpoint.*at $hex: file.*namespace.cc, line 68\\." # Test to see if the appropriate namespaces are in scope when trying # to print out stuff from within a function defined within a @@ -271,3 +271,6 @@ gdb_test "print G::Xg" "\\$\[0-9\].* = 10" gdb_test "print G::XgX" "\\$\[0-9\].* = 11" gdb_test "print cXOtherFile" "No symbol \"cXOtherFile\" in current context." gdb_test "print XOtherFile" "No symbol \"XOtherFile\" in current context." + +# Enum tests. +gdb_test "print AAA::ALPHA" "\\$\[0-9\].* = AAA::ALPHA" -- 2.11.0