diff options
author | Will Newton <willnewton@sourceware.org> | 2013-06-07 08:47:09 +0000 |
---|---|---|
committer | Will Newton <willnewton@sourceware.org> | 2013-06-07 08:47:09 +0000 |
commit | f4059ef3dea24d7ced46bcceddccff7b01af3ba9 (patch) | |
tree | 1561e1c837c5910ff8d861120f9de7edd1670705 | |
parent | fe8400b4383bda9333b559255b63c2c659e9ad5f (diff) | |
download | gdb-f4059ef3dea24d7ced46bcceddccff7b01af3ba9.zip gdb-f4059ef3dea24d7ced46bcceddccff7b01af3ba9.tar.gz gdb-f4059ef3dea24d7ced46bcceddccff7b01af3ba9.tar.bz2 |
gdb/testsuite/gdb.cp: Fix tests for ARM C++ ABI.
The ARM C++ ABI defines constructors and destructors to return
pointers to this. The C++ tests that check the types of constructors
and destructors expect a return type of void. Conditionalize these
tests so they pass on ARM.
gdb/testsuite/ChangeLog:
2013-06-07 Will Newton <will.newton@linaro.org>
* gdb.cp/anon-struct.exp: Conditionalize constructor and
destructor prototypes for ARM ABI.
* gdb.cp/m-static.exp: Likewise.
-rw-r--r-- | gdb/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gdb/testsuite/gdb.cp/anon-struct.exp | 25 | ||||
-rw-r--r-- | gdb/testsuite/gdb.cp/m-static.exp | 75 |
3 files changed, 75 insertions, 31 deletions
diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index 81c6648..67e9bf3 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2013-06-07 Will Newton <will.newton@linaro.org> + + * gdb.cp/anon-struct.exp: Conditionalize constructor and + destructor prototypes for ARM ABI. + * gdb.cp/m-static.exp: Likewise. + 2013-06-07 Yao Qi <yao@codesourcery.com> * gdb.trace/mi-trace-unavailable.exp: New. diff --git a/gdb/testsuite/gdb.cp/anon-struct.exp b/gdb/testsuite/gdb.cp/anon-struct.exp index edab092..3446eb7 100644 --- a/gdb/testsuite/gdb.cp/anon-struct.exp +++ b/gdb/testsuite/gdb.cp/anon-struct.exp @@ -20,14 +20,25 @@ if { [prepare_for_testing ${testfile}.exp ${testfile} ${srcfile} {debug c++}] } return -1 } -gdb_test "ptype t::t" "type = void \\(t \\* const\\)" \ - "print type of t::t" +if { [istarget arm*-*-*] } { + gdb_test "ptype t::t" "type = struct t {\r\n C m;\r\n} \\*\\(t \\* const\\)" \ + "print type of t::t" +} else { + gdb_test "ptype t::t" "type = void \\(t \\* const\\)" \ + "print type of t::t" +} gdb_test "ptype X::t2" "type = struct X::t2 {\[\r\n \]*X::C2 m;\[\r\n \]*}" \ "print type of X::t2" -gdb_test "ptype X::t2::t2" "type = void \\(X::t2 \\* const\\)" \ - "print type of X::t2::t2" - -gdb_test "ptype t3::~t3" "type = void \\(t3 \\* const\\)" \ - "print type of t3::~t3" +if { [istarget arm*-*-*] } { + gdb_test "ptype X::t2::t2" "type = struct X::t2 {\r\n X::C2 m;\r\n} \\*\\(X::t2 \\* const\\)" \ + "print type of X::t2::t2" + gdb_test "ptype t3::~t3" "type = void \\*\\(t3 \\* const\\)" \ + "print type of t3::~t3" +} else { + gdb_test "ptype X::t2::t2" "type = void \\(X::t2 \\* const\\)" \ + "print type of X::t2::t2" + gdb_test "ptype t3::~t3" "type = void \\(t3 \\* const\\)" \ + "print type of t3::~t3" +} diff --git a/gdb/testsuite/gdb.cp/m-static.exp b/gdb/testsuite/gdb.cp/m-static.exp index 65ec6a0..9b0e642 100644 --- a/gdb/testsuite/gdb.cp/m-static.exp +++ b/gdb/testsuite/gdb.cp/m-static.exp @@ -69,30 +69,57 @@ 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" -gdb_test "print test5.single_constructor" \ - { = {void \(single_constructor \* const\)} 0x[0-9a-f]+ <single_constructor::single_constructor\(\)>} \ - "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]+ <gnu_obj_1::~gnu_obj_1\(\)>} \ - "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]+ <gnu_obj_1::~gnu_obj_1\(\)>} \ - "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" +if { [istarget arm*-*-*] } { + gdb_test "print test5.single_constructor" \ + { = {single_constructor \*\(single_constructor \* const\)} 0x[0-9a-f]+ <single_constructor::single_constructor\(\)>} \ + "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\(int\);\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\(int\);\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]+ <gnu_obj_1::~gnu_obj_1\(\)>} \ + "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]+ <gnu_obj_1::~gnu_obj_1\(\)>} \ + "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]+ <single_constructor::single_constructor\(\)>} \ + "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]+ <gnu_obj_1::~gnu_obj_1\(\)>} \ + "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]+ <gnu_obj_1::~gnu_obj_1\(\)>} \ + "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. |