summaryrefslogtreecommitdiffstats
path: root/clang/test/CXX/special/class.dtor/p9.cpp
diff options
context:
space:
mode:
authorHans Wennborg <hans@hanshq.net>2014-02-24 15:58:24 +0000
committerHans Wennborg <hans@hanshq.net>2014-02-24 15:58:24 +0000
commit3d79154aecd98a5ff59e11bd30e94c8d2206393e (patch)
tree47d4cbdd00fd7065ca7b56b3bc9cd37fe47b7174 /clang/test/CXX/special/class.dtor/p9.cpp
parentdc59a36caa73a7de021423ff9769525ce9cdb969 (diff)
downloadbcm5719-llvm-3d79154aecd98a5ff59e11bd30e94c8d2206393e.tar.gz
bcm5719-llvm-3d79154aecd98a5ff59e11bd30e94c8d2206393e.zip
[Win32 ABI] Defer operator delete checks until vtable is marked used
We were previously checking at every destructor declaration, but that was a bit excessive. Since the deleting destructor is emitted with the vtable, do the check when the vtable is marked used. Differential Revision: http://llvm-reviews.chandlerc.com/D2851 llvm-svn: 202046
Diffstat (limited to 'clang/test/CXX/special/class.dtor/p9.cpp')
-rw-r--r--clang/test/CXX/special/class.dtor/p9.cpp19
1 files changed, 0 insertions, 19 deletions
diff --git a/clang/test/CXX/special/class.dtor/p9.cpp b/clang/test/CXX/special/class.dtor/p9.cpp
index 1c70fd48615..a03fcdb2495 100644
--- a/clang/test/CXX/special/class.dtor/p9.cpp
+++ b/clang/test/CXX/special/class.dtor/p9.cpp
@@ -29,18 +29,12 @@ namespace test0 {
namespace test1 {
class A {
public:
-#ifdef MSABI
- // expected-note@+2 {{declared here}}
-#endif
static void operator delete(void *p) {}; // expected-note {{member 'operator delete' declared here}}
virtual ~A();
};
class B : protected A {
public:
-#ifdef MSABI
- // expected-note@+2 {{declared here}}
-#endif
static void operator delete(void *, size_t) {}; // expected-note {{member 'operator delete' declared here}}
~B();
};
@@ -50,9 +44,6 @@ namespace test1 {
using A::operator delete;
using B::operator delete;
-#ifdef MSABI
- // expected-error@+2 {{multiple suitable 'operator delete' functions in 'C'}}
-#endif
~C();
};
@@ -62,22 +53,12 @@ namespace test1 {
// ...at the point of definition of a virtual destructor...
namespace test2 {
struct A {
-#ifdef MSABI
- // expected-error@+3 {{no suitable member 'operator delete' in 'A'}}
- // expected-note@+3 {{declared here}}
-#endif
virtual ~A();
static void operator delete(void*, const int &);
};
struct B {
-#ifdef MSABI
- // expected-error@+2 {{no suitable member 'operator delete' in 'B'}}
-#endif
virtual ~B();
-#ifdef MSABI
- // expected-note@+2 {{declared here}}
-#endif
static void operator delete(void*, const int &); // expected-note {{declared here}}
};
B::~B() {} // expected-error {{no suitable member 'operator delete' in 'B'}}
OpenPOWER on IntegriCloud