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 | 0ba63ea5be2c90ef62d1350ea4a0a0c415a785f1 (patch) | |
tree | b8f162d43bbdbf6fa7e9907402e826586f2e5923 | |
parent | 7d90199f109290e9d587479a481a2850d390b552 (diff) |
Diagnose ambiguity of operator delete and operator delete[]. Sebastian, please review.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@88747 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Sema/SemaExprCXX.cpp | 7 | ||||
-rw-r--r-- | test/SemaCXX/new-delete.cpp | 17 |
2 files changed, 23 insertions, 1 deletions
diff --git a/lib/Sema/SemaExprCXX.cpp b/lib/Sema/SemaExprCXX.cpp index 964334b20b..0689c6cce9 100644 --- a/lib/Sema/SemaExprCXX.cpp +++ b/lib/Sema/SemaExprCXX.cpp @@ -851,8 +851,13 @@ Sema::ActOnCXXDelete(SourceLocation StartLoc, bool UseGlobal, // Try to find operator delete/operator delete[] in class scope. LookupResult Found; LookupQualifiedName(Found, Record, DeleteName, LookupOrdinaryName); + + if (Found.isAmbiguous()) { + DiagnoseAmbiguousLookup(Found, DeleteName, StartLoc); + return ExprError(); + } + // FIXME: Diagnose ambiguity properly - assert(!Found.isAmbiguous() && "Ambiguous delete/delete[] not handled"); for (LookupResult::iterator F = Found.begin(), FEnd = Found.end(); F != FEnd; ++F) { if (CXXMethodDecl *Delete = dyn_cast<CXXMethodDecl>(*F)) diff --git a/test/SemaCXX/new-delete.cpp b/test/SemaCXX/new-delete.cpp index fec3e2034a..63a716338b 100644 --- a/test/SemaCXX/new-delete.cpp +++ b/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}} +} + |