diff options
author | Anders Carlsson <andersca@mac.com> | 2009-11-14 03:17:38 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-11-14 03:17:38 +0000 |
commit | 654e5c7cf802af8b04106bcf6852654fc80144eb (patch) | |
tree | 494d470b96ef84f4a28fa51c3baee8b4241133f5 /clang/test/SemaCXX/new-delete.cpp | |
parent | 6ad7da96fefb4364aaa8dfb8c695511bdaaac85d (diff) | |
download | bcm5719-llvm-654e5c7cf802af8b04106bcf6852654fc80144eb.tar.gz bcm5719-llvm-654e5c7cf802af8b04106bcf6852654fc80144eb.zip |
Diagnose ambiguity of operator delete and operator delete[]. Sebastian, please review.
llvm-svn: 88747
Diffstat (limited to 'clang/test/SemaCXX/new-delete.cpp')
-rw-r--r-- | clang/test/SemaCXX/new-delete.cpp | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/new-delete.cpp b/clang/test/SemaCXX/new-delete.cpp index fec3e2034af..63a716338ba 100644 --- a/clang/test/SemaCXX/new-delete.cpp +++ b/clang/test/SemaCXX/new-delete.cpp @@ -165,3 +165,20 @@ template <class T> struct TBase { TBase<int> t1; // expected-note {{in instantiation of template class 'struct TBase<int>' requested here}} +class X6 { +public: + static void operator delete(void*, int); // expected-note {{member found by ambiguous name lookup}} +}; + +class X7 { +public: + static void operator delete(void*, int); // expected-note {{member found by ambiguous name lookup}} +}; + +class X8 : public X6, public X7 { +}; + +void f(X8* x8) { + delete x8; // expected-error {{member 'operator delete' found in multiple base classes of different types}} +} + |