diff options
author | upstream source tree <ports@midipix.org> | 2015-03-15 20:14:05 -0400 |
---|---|---|
committer | upstream source tree <ports@midipix.org> | 2015-03-15 20:14:05 -0400 |
commit | 554fd8c5195424bdbcabf5de30fdc183aba391bd (patch) | |
tree | 976dc5ab7fddf506dadce60ae936f43f58787092 /gcc/testsuite/g++.old-deja/g++.other/rttid2.C | |
download | cbb-gcc-4.6.4-upstream.tar.bz2 cbb-gcc-4.6.4-upstream.tar.xz |
obtained gcc-4.6.4.tar.bz2 from upstream website;upstream
verified gcc-4.6.4.tar.bz2.sig;
imported gcc-4.6.4 source tree from verified upstream tarball.
downloading a git-generated archive based on the 'upstream' tag
should provide you with a source tree that is binary identical
to the one extracted from the above tarball.
if you have obtained the source via the command 'git clone',
however, do note that line-endings of files in your working
directory might differ from line-endings of the respective
files in the upstream repository.
Diffstat (limited to 'gcc/testsuite/g++.old-deja/g++.other/rttid2.C')
-rw-r--r-- | gcc/testsuite/g++.old-deja/g++.other/rttid2.C | 101 |
1 files changed, 101 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.other/rttid2.C b/gcc/testsuite/g++.old-deja/g++.other/rttid2.C new file mode 100644 index 000000000..06746506f --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.other/rttid2.C @@ -0,0 +1,101 @@ +// { dg-do run } +// { dg-options "-frtti" } +// test of rtti of single inheritance and multiple inheritance classes +// dynamic casting + +#include <typeinfo> + +extern "C" { + int printf(const char *, ...); + void exit(int); +} + +class X { + public: + int xi; +}; + +class Y : public X { + short ys; +}; + +class Z : public Y { + int zi; +}; + +Z z; +Y y; +Y *yp = &z; +X *xp = &z; +Z *zp = &z; + +class A { + public: + int Ai; +}; + +class B { + public: + int Bi; +}; + +class D : public A, public B { + int Di; +}; + +/* +class E : public D, public B { + int Ei; +}; +*/ +class E { + int Ei; +}; + +class F : public E, public D { + int Fi; +}; + +D d; +A *ap = &d; +B *bp = &d; +F f; +F *fp = &f; +A *aap = &f; +D *dp = &f; +B *bbp = dp; + +void *vp = zp; + +/* +void error (int i) +{ + printf("FAIL\n"); + exit(i); +} +*/ + +void error (int i) +{ + exit(i); +} + +int main () +{ + + vp = (void *)0; + + vp = dynamic_cast<Y *> (&z); + if (vp == 0) error(11); + + vp = dynamic_cast<X *> (yp); + if (vp == 0) error(12); + + vp = dynamic_cast<D *> (dp); + if (vp != (void *)dp) error(21); + + vp = dynamic_cast<B *> (fp); + if (vp != (void *)bbp) error(22); + +} + |