aboutsummaryrefslogtreecommitdiff
path: root/gdb/testsuite
diff options
context:
space:
mode:
authorChris Moller <cmoller@cygnus>2010-02-08 18:04:17 +0000
committerChris Moller <cmoller@cygnus>2010-02-08 18:04:17 +0000
commit99903ae39ebb2032c28aa7bb8b24d6d0f901a2f1 (patch)
tree4c8294d3740d607126be4f34839c0dfd3df153dc /gdb/testsuite
parente3e9f5a2912a498fb804786da7afb83bc04c39cf (diff)
downloadgdb-99903ae39ebb2032c28aa7bb8b24d6d0f901a2f1.zip
gdb-99903ae39ebb2032c28aa7bb8b24d6d0f901a2f1.tar.gz
gdb-99903ae39ebb2032c28aa7bb8b24d6d0f901a2f1.tar.bz2
PR gdb/9067
* cp-valprint.c (cp_print_value_fields) Fix use of obstacks. cp_print_static_field) Fix use of obstacks. * gdb.cp/pr9067.exp: New * gdb.cp/pr9067.cc: New * gdb.cp/Makefile.in (EXECUTABLES): Add pr9067
Diffstat (limited to 'gdb/testsuite')
-rw-r--r--gdb/testsuite/ChangeLog7
-rw-r--r--gdb/testsuite/gdb.cp/Makefile.in2
-rw-r--r--gdb/testsuite/gdb.cp/pr9067.cc17
-rw-r--r--gdb/testsuite/gdb.cp/pr9067.exp46
4 files changed, 71 insertions, 1 deletions
diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog
index f323e65..d121ff2 100644
--- a/gdb/testsuite/ChangeLog
+++ b/gdb/testsuite/ChangeLog
@@ -1,3 +1,10 @@
+Mon Feb 8 12:54:54 2010 Chris Moller <moller@mollerware.com>
+
+ PR gdb/9067
+ * gdb.cp/pr9067.exp: New
+ * gdb.cp/pr9067.cc: New
+ * gdb.cp/Makefile.in (EXECUTABLES): Add pr9067
+
2010-02-08 Joel Brobecker <brobecker@adacore.com>
* lib/gdb.exp (gdb_test_timeout): New global variable.
diff --git a/gdb/testsuite/gdb.cp/Makefile.in b/gdb/testsuite/gdb.cp/Makefile.in
index c990a64..aa91583 100644
--- a/gdb/testsuite/gdb.cp/Makefile.in
+++ b/gdb/testsuite/gdb.cp/Makefile.in
@@ -4,7 +4,7 @@ srcdir = @srcdir@
EXECUTABLES = ambiguous annota2 anon-union cplusfuncs cttiadd \
derivation inherit local member-ptr method misc \
overload ovldbreak ref-typ ref-typ2 templates userdef virtfunc namespace \
- ref-types ref-params method2 pr9594 gdb2495 virtfunc2
+ ref-types ref-params method2 pr9594 gdb2495 virtfunc2 pr9067
all info install-info dvi install uninstall installcheck check:
@echo "Nothing to be done for $@..."
diff --git a/gdb/testsuite/gdb.cp/pr9067.cc b/gdb/testsuite/gdb.cp/pr9067.cc
new file mode 100644
index 0000000..c30f77d
--- /dev/null
+++ b/gdb/testsuite/gdb.cp/pr9067.cc
@@ -0,0 +1,17 @@
+struct B;
+
+struct A {
+ static B b;
+};
+
+struct B {
+ A a;
+};
+
+B A::b;
+B b;
+
+int main(int,char **)
+{
+ return 0;
+}
diff --git a/gdb/testsuite/gdb.cp/pr9067.exp b/gdb/testsuite/gdb.cp/pr9067.exp
new file mode 100644
index 0000000..0782d3c
--- /dev/null
+++ b/gdb/testsuite/gdb.cp/pr9067.exp
@@ -0,0 +1,46 @@
+# Copyright 2009, 2010 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 <http://www.gnu.org/licenses/>.
+
+set nl "\[\r\n\]+"
+
+if { [skip_cplus_tests] } { continue }
+
+load_lib "cp-support.exp"
+
+set testfile "pr9067"
+set srcfile ${testfile}.cc
+set binfile ${objdir}/${subdir}/${testfile}
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {c++ debug}] != "" } {
+ untested pr9067.exp
+ 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
+}
+
+gdb_test "print b" ".*same as static member.*"
+
+
+gdb_exit
+return 0
+