diff options
author | Michael Chastain <mec@google.com> | 2004-08-09 22:47:50 +0000 |
---|---|---|
committer | Michael Chastain <mec@google.com> | 2004-08-09 22:47:50 +0000 |
commit | 78c9050252787db32fd6c8aa0a68d8fe594a3694 (patch) | |
tree | c6124c94696687c8cdc504abfe7bb8522f91c95d /gdb/testsuite/gdb.cp/derivation.exp | |
parent | 88e5ea782b40ef390d55c3d285c6631bc0091efc (diff) | |
download | gdb-78c9050252787db32fd6c8aa0a68d8fe594a3694.zip gdb-78c9050252787db32fd6c8aa0a68d8fe594a3694.tar.gz gdb-78c9050252787db32fd6c8aa0a68d8fe594a3694.tar.bz2 |
2004-08-09 Michael Chastain <mec.gnu@mindspring.com>
* lib/cp-support.exp: New file.
* lib/cp-support.exp (cp_test_type_class): New function.
* gdb.cp/derivation.exp: Use cp_test_ptype_class.
* gdb.cp/virtfunc.exp (test_one_ptype): Removed.
* gdb.cp/virtfunc.exp (test_ptype_of_classes): Use
cp_test_ptype_class.
Diffstat (limited to 'gdb/testsuite/gdb.cp/derivation.exp')
-rw-r--r-- | gdb/testsuite/gdb.cp/derivation.exp | 133 |
1 files changed, 51 insertions, 82 deletions
diff --git a/gdb/testsuite/gdb.cp/derivation.exp b/gdb/testsuite/gdb.cp/derivation.exp index d82ab1f..6c98d3c 100644 --- a/gdb/testsuite/gdb.cp/derivation.exp +++ b/gdb/testsuite/gdb.cp/derivation.exp @@ -38,6 +38,8 @@ set bug_id 0 if { [skip_cplus_tests] } { continue } +load_lib "cp-support.exp" + set testfile "derivation" set srcfile ${testfile}.cc set binfile ${objdir}/${subdir}/${testfile} @@ -61,124 +63,91 @@ if ![runto 'marker1'] then { gdb_test "up" ".*main.*" "up from marker1" # Print class types and values. -# See virtfunc.exp for a discussion of ptype. # class A -set re_class "((struct|class) A \{${ws}public:|struct A \{)" -set re_fields "int a;${ws}int aa;" -set re_methods "A\\((void|)\\);${ws}int afoo\\((void|)\\);${ws}int foo\\((void|)\\);" -set re_synth_gcc_23 "A & operator=\\(A const ?&\\);${ws}A\\(A const ?&\\);" -set re_all_methods "($re_methods|$re_methods${ws}$re_synth_gcc_23|$re_synth_gcc_23${ws}$re_methods)" - gdb_test "print a_instance" "\\$\[0-9\]+ = \{a = 1, aa = 2\}" "print value of a_instance" -gdb_test_multiple "ptype a_instance" "ptype a_instance" { - -re "type = $re_class${ws}$re_fields${ws}$re_methods$nl\}$nl$gdb_prompt $" { - pass "ptype a_instance (no synth ops)" - } - -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23${ws}$re_methods${ws}$nl\}$nl$gdb_prompt $" { - pass "ptype a_instance (with synth ops)" +cp_test_ptype_class \ + "ptype a_instance" "" "class" "A" \ + { + { field public "int a;" } + { field public "int aa;" } + { method public "A();" } + { method public "int afoo();" } + { method public "int foo();" } } - -re "type = $re_class${ws}$re_fields${ws}$re_methods${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" { - pass "ptype a_instance (with synth ops)" - } -} # class D -set re_class "class D : private A, public B, protected C \{${ws}public:" -set XX_class "class D : private A, public B, private C \{${ws}public:" -set re_fields "int d;${ws}int dd;" -set re_methods "D\\((void|)\\);${ws}int dfoo\\((void|)\\);${ws}int foo\\((void|)\\);" -set re_synth_gcc_23 "D & operator=\\(D const ?&\\);${ws}D\\(D const ?&\\);" -set re_all_methods "($re_methods|$re_methods${ws}$re_synth_gcc_23|$re_synth_gcc_23${ws}$re_methods)" - gdb_test_multiple "print d_instance" "print value of d_instance" { -re "\\$\[0-9\]+ = \{<(class A|A)> = \{a = 1, aa = 2\}, <(class B|B)> = \{b = 3, bb = 4\}, <(class C|C)> = \{c = 5, cc = 6\}, d = 7, dd = 8\}$nl$gdb_prompt $" { pass "print value of d_instance" } } -gdb_test_multiple "ptype d_instance" "ptype d_instance" { - -re "type = $re_class${ws}$re_fields${ws}$re_methods${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" { - pass "ptype d_instance" - } - -re "type = $re_class${ws}$re_fields${ws}$re_all_methods$nl\}$nl$gdb_prompt $" { - pass "ptype d_instance" - } - -re "type = $XX_class${ws}$re_fields${ws}$re_methods${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" { - # This is a gcc bug, gcc/13539, gdb/1498. - # Fixed in gcc HEAD 2004-01-13 - setup_xfail "*-*-*" "gcc/13539" - fail "ptype d_instance" - } - -re "type = $XX_class${ws}$re_fields${ws}$re_all_methods$nl\}$nl$gdb_prompt $" { - # This is a gcc bug, gcc/13539, gdb/1498. - # Fixed in gcc HEAD 2004-01-13 - setup_xfail "*-*-*" "gcc/13539" - fail "ptype d_instance" +cp_test_ptype_class \ + "ptype d_instance" "" "class" "D" \ + { + { base "private A" } + { base "public B" } + { base "protected C" } + { field public "int d;" } + { field public "int dd;" } + { method public "D();" } + { method public "int dfoo();" } + { method public "int foo();" } + } \ + "" \ + { + { "protected C" "private C" { setup_xfail "*-*-*" "gcc/13539" } } } -} # class E -set re_class "class E : public A, private B, protected C \{${ws}public:" -set XX_class "class E : public A, private B, private C \{${ws}public:" -set re_fields "int e;${ws}int ee;" -set re_methods "E\\((void|)\\);${ws}int efoo\\((void|)\\);${ws}int foo\\((void|)\\);" -set re_synth_gcc_23 "E & operator=\\(E const ?&\\);${ws}E\\(E const ?&\\);" -set re_all_methods "($re_methods|$re_methods${ws}$re_synth_gcc_23|$re_synth_gcc_23${ws}$re_methods)" - gdb_test_multiple "print e_instance" "print value of e_instance" { -re "\\$\[0-9\]+ = \{<(class A|A)> = \{a = 1, aa = 2\}, <(class B|B)> = \{b = 3, bb = 4\}, <(class C|C)> = \{c = 5, cc = 6\}, e = 9, ee = 10\}$nl$gdb_prompt $" { pass "print value of e_instance" } } -gdb_test_multiple "ptype e_instance" "ptype e_instance" { - -re "type = $re_class${ws}$re_fields${ws}$re_methods${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" { - pass "ptype e_instance" - } - -re "type = $re_class${ws}$re_fields${ws}$re_all_methods$nl\}$nl$gdb_prompt $" { - pass "ptype e_instance" - } - -re "type = $XX_class${ws}$re_fields${ws}$re_methods${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" { - # This is a gcc bug, gcc/13539, gdb/1498. - # Fixed in gcc HEAD 2004-01-13 - setup_xfail "*-*-*" "gcc/13539" - fail "ptype e_instance" - } - -re "type = $XX_class${ws}$re_fields${ws}$re_all_methods$nl\}$nl$gdb_prompt $" { - # This is a gcc bug, gcc/13539, gdb/1498. - # Fixed in gcc HEAD 2004-01-13 - setup_xfail "*-*-*" "gcc/13539" - fail "ptype e_instance" +cp_test_ptype_class \ + "ptype e_instance" "" "class" "E" \ + { + { base "public A" } + { base "private B" } + { base "protected C" } + { field public "int e;" } + { field public "int ee;" } + { method public "E();" } + { method public "int efoo();" } + { method public "int foo();" } + } \ + "" \ + { + { "protected C" "private C" { setup_xfail "*-*-*" "gcc/13539" } } } -} # class F -set re_class "class F : private A, public B, private C \{${ws}public:" -set re_fields "int f;${ws}int ff;" -set re_methods "F\\((void|)\\);${ws}int ffoo\\((void|)\\);${ws}int foo\\((void|)\\);" -set re_synth_gcc_23 "F & operator=\\(F const ?&\\);${ws}F\\(F const ?&\\);" -set re_all_methods "($re_methods|$re_methods${ws}$re_synth_gcc_23|$re_synth_gcc_23${ws}$re_methods)" - gdb_test_multiple "print f_instance" "print value of f_instance" { -re "\\$\[0-9\]+ = \{<(class A|A)> = \{a = 1, aa = 2\}, <(class B|B)> = \{b = 3, bb = 4\}, <(class C|C)> = \{c = 5, cc = 6\}, f = 11, ff = 12\}$nl$gdb_prompt $" { pass "print value of f_instance" } } -gdb_test_multiple "ptype f_instance" "ptype f_instance" { - -re "type = $re_class${ws}$re_fields${ws}$re_methods${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" { - pass "ptype f_instance" +cp_test_ptype_class \ + "ptype f_instance" "" "class" "F" \ + { + { base "private A" } + { base "public B" } + { base "private C" } + { field public "int f;" } + { field public "int ff;" } + { method public "F();" } + { method public "int ffoo();" } + { method public "int foo();" } } - -re "type = $re_class${ws}$re_fields${ws}$re_all_methods$nl\}$nl$gdb_prompt $" { - pass "ptype f_instance" - } -} # Print individual fields. |