X-Git-Url: https://oss.titaniummirror.com/gitweb?a=blobdiff_plain;f=gcc%2Ftestsuite%2Fg%2B%2B.old-deja%2Fg%2B%2B.mike%2Fdyncast5.C;fp=gcc%2Ftestsuite%2Fg%2B%2B.old-deja%2Fg%2B%2B.mike%2Fdyncast5.C;h=0000000000000000000000000000000000000000;hb=6fed43773c9b0ce596dca5686f37ac3fc0fa11c0;hp=f46d81e49357e18c4f229896601bdaf883499265;hpb=27b11d56b743098deb193d510b337ba22dc52e5c;p=msp430-gcc.git diff --git a/gcc/testsuite/g++.old-deja/g++.mike/dyncast5.C b/gcc/testsuite/g++.old-deja/g++.mike/dyncast5.C deleted file mode 100644 index f46d81e4..00000000 --- a/gcc/testsuite/g++.old-deja/g++.mike/dyncast5.C +++ /dev/null @@ -1,71 +0,0 @@ -#include - -void *p; -int fail; - -class HeapTracked { -public: - virtual ~HeapTracked() = 0; - void *operator new(size_t size); - void operator delete(void *ptr); - static bool isObjectAllocation(const HeapTracked *ptr); -}; - -HeapTracked::~HeapTracked(){} -void * HeapTracked::operator new(size_t size) -{ - void * memPtr = ::operator new(size); - p = memPtr; - return memPtr; -} - -void HeapTracked::operator delete(void *ptr) -{ - if (p != ptr) - fail = 1; - ::operator delete(ptr); -} - -bool HeapTracked::isObjectAllocation(const HeapTracked *ptr) -{ - if (p != const_cast(dynamic_cast(ptr))) - fail = 1; - return false; -} - -class Mumble1: public virtual HeapTracked { - double d; -public: - virtual ~Mumble1(){} -}; - -class Mumble2: public virtual HeapTracked { - double d; -public: - virtual ~Mumble2(){} -}; - -class Foo: virtual public HeapTracked, - virtual public Mumble1, - virtual public Mumble2 { -public: - ~Foo(){} -}; - -int main() -{ - Foo *pf = new Foo; - pf->isObjectAllocation(pf); - - Mumble1 *pm1 = pf; - pm1->isObjectAllocation(pm1); - - Mumble2 *pm2 = pf; - pm2->isObjectAllocation(pm2); - - // delete pf; - // delete pm1; - delete pm2; - - return fail; -}