X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=gdb%2Ftestsuite%2Fgdb.cp%2Fm-static.exp;h=10239a3b7513fe1010602e0eeb511cccaa47ddb3;hb=e68cb8e00166d2f8a9e23c60f68bec04ef0a90f0;hp=7d82d29e1f483d10dcf62995965f9858516a81cb;hpb=02e7ea18235aafdf5ebe7c6736914b5a2f2db2c1;p=deliverable%2Fbinutils-gdb.git diff --git a/gdb/testsuite/gdb.cp/m-static.exp b/gdb/testsuite/gdb.cp/m-static.exp index 7d82d29e1f..10239a3b75 100644 --- a/gdb/testsuite/gdb.cp/m-static.exp +++ b/gdb/testsuite/gdb.cp/m-static.exp @@ -1,4 +1,4 @@ -# Copyright 2002, 2004, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. +# Copyright 2002-2017 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 @@ -19,49 +19,31 @@ # This file is part of the gdb testsuite -if $tracelevel then { - strace $tracelevel - } - if { [skip_cplus_tests] } { continue } # # test running programs # -set testfile "m-static" -set srcfile "${testfile}.cc" -set srcfile1 "${testfile}1.cc" -set objfile "${testfile}.o" -set objfile1 "${testfile}1.o" -set binfile "${objdir}/${subdir}/${testfile}" - -if { [gdb_compile "$srcdir/$subdir/$srcfile" "$objdir/$subdir/$objfile" object {debug c++}] != "" } { - untested m-static.exp - return -1 -} +standard_testfile .cc m-static1.cc -if { [gdb_compile "$srcdir/$subdir/$srcfile1" "$objdir/$subdir/$objfile1" object {debug c++}] != "" } { - untested m-static.exp - return -1 +if [get_compiler_info] { + return -1 } -if { [gdb_compile "$objdir/$subdir/$objfile $objdir/$subdir/$objfile1" "${binfile}" executable {debug c++}] != "" } { - untested m-static.exp - return -1 +if {[prepare_for_testing "failed to prepare" $testfile \ + [list $srcfile $srcfile2] {debug c++}]} { + return -1 } -gdb_exit -gdb_start -gdb_reinitialize_dir $srcdir/$subdir -gdb_load ${binfile} - - if ![runto_main] then { perror "couldn't run to breakpoint" continue } +get_debug_format +set non_dwarf [expr ! [test_debug_format "DWARF 2"]] + # First, run to after we've constructed all the objects: gdb_breakpoint [gdb_get_line_number "constructs-done"] @@ -82,6 +64,58 @@ gdb_test "print test1.key2" "\\$\[0-9\]* = 77" "simple object, static long" # simple object, static enum gdb_test "print test1.value" "\\$\[0-9\]* = oriental" "simple object, static enum" +if { [is_aarch32_target] } { + gdb_test "print test5.single_constructor" \ + { = {single_constructor \*\(single_constructor \* const\)} 0x[0-9a-f]+ } \ + "simple object instance, print constructor" + gdb_test "ptype test5.single_constructor" \ + {type = class single_constructor {\r\n public:\r\n single_constructor\(void\);\r\n ~single_constructor\(\);\r\n} \*\(single_constructor \* const\)} \ + "simple object instance, ptype constructor" + gdb_test "ptype single_constructor::single_constructor" \ + {type = class single_constructor {\r\n public:\r\n single_constructor\(void\);\r\n ~single_constructor\(\);\r\n} \*\(single_constructor \* const\)} \ + "simple object class, ptype constructor" + + gdb_test "print test1.~gnu_obj_1" \ + { = {void \*\(gnu_obj_1 \* const, int\)} 0x[0-9a-f]+ } \ + "simple object instance, print destructor" + gdb_test "ptype test1.~gnu_obj_1" \ + {type = void \*\(gnu_obj_1 \* const, int\)} \ + "simple object instance, ptype destructor" + + gdb_test "print test1.'~gnu_obj_1'" \ + { = {void \*\(gnu_obj_1 \*( const)?, int\)} 0x[0-9a-f]+ } \ + "simple object instance, print quoted destructor" + + gdb_test "ptype gnu_obj_1::'~gnu_obj_1'" \ + {type = void \*\(gnu_obj_1 \* const\)} \ + "simple object class, ptype quoted destructor" +} else { + gdb_test "print test5.single_constructor" \ + { = {void \(single_constructor \* const\)} 0x[0-9a-f]+ } \ + "simple object instance, print constructor" + gdb_test "ptype test5.single_constructor" \ + {type = void \(single_constructor \* const\)} \ + "simple object instance, ptype constructor" + gdb_test "ptype single_constructor::single_constructor" \ + {type = void \(single_constructor \* const\)} \ + "simple object class, ptype constructor" + + gdb_test "print test1.~gnu_obj_1" \ + { = {void \(gnu_obj_1 \* const, int\)} 0x[0-9a-f]+ } \ + "simple object instance, print destructor" + gdb_test "ptype test1.~gnu_obj_1" \ + {type = void \(gnu_obj_1 \* const, int\)} \ + "simple object instance, ptype destructor" + + gdb_test "print test1.'~gnu_obj_1'" \ + { = {void \(gnu_obj_1 \*( const)?, int\)} 0x[0-9a-f]+ } \ + "simple object instance, print quoted destructor" + + gdb_test "ptype gnu_obj_1::'~gnu_obj_1'" \ + {type = void \(gnu_obj_1 \* const\)} \ + "simple object class, ptype quoted destructor" +} + # Two. # derived template object, base static const bool @@ -123,7 +157,27 @@ gdb_test "print test3.data.value_derived" "\\$\[0-9\].* = etruscan" "template ob gdb_test "print test4.elsewhere" "\\$\[0-9\].* = 221" "static const int initialized elsewhere" # static const int that nobody initializes. From PR gdb/635. -gdb_test "print test4.nowhere" "field nowhere is nonexistent or has been optimised out" "static const int initialized nowhere" +if {[test_compiler_info {gcc-[0-3]-*}] + || [test_compiler_info {gcc-4-[0-4]-*}]} { + # There was an extra CU-level DW_TAG_variable as DW_AT_declaration + # with DW_AT_name = nowhere + # and DW_AT_MIPS_linkage_name = _ZN9gnu_obj_47nowhereE . + setup_xfail *-*-* +} +gdb_test "print test4.nowhere" "" "static const int initialized nowhere (print field)" + +# Same, but print the whole struct. +gdb_test "print test4" "static nowhere = .*" "static const int initialized nowhere (whole struct)" + +# static const initialized in the class definition, PR gdb/11702. +if { $non_dwarf } { setup_xfail *-*-* } +gdb_test "print test4.everywhere" "\\$\[0-9\].* = 317" "static const int initialized in class definition" +if { $non_dwarf } { setup_xfail *-*-* } +gdb_test "print test4.somewhere" "\\$\[0-9\].* = 3.14\[0-9\]*" "static const float initialized in class definition" + +# Also make sure static const members can be found via "info var". +if { $non_dwarf } { setup_xfail *-*-* } +gdb_test "info variable everywhere" "File .*/m-static\[.\]h.*const int gnu_obj_4::everywhere;" "info variable everywhere" # Perhaps at some point test4 should also include a test for a static # const int that was initialized in the header file. But I'm not sure