From: Chandler Carruth Date: Sun, 8 Aug 2010 07:04:00 +0000 (+0000) Subject: Fix a crash on template delete operators. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=09556fd1fb576144e2beda023bf3386f2292243b;p=clang Fix a crash on template delete operators. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@110542 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaExprCXX.cpp b/lib/Sema/SemaExprCXX.cpp index b1d6015514..7bebce16e1 100644 --- a/lib/Sema/SemaExprCXX.cpp +++ b/lib/Sema/SemaExprCXX.cpp @@ -1301,8 +1301,14 @@ bool Sema::FindDeallocationFunction(SourceLocation StartLoc, CXXRecordDecl *RD, llvm::SmallVector Matches; for (LookupResult::iterator F = Found.begin(), FEnd = Found.end(); F != FEnd; ++F) { - CXXMethodDecl *Delete = cast((*F)->getUnderlyingDecl()); - if (Delete->isUsualDeallocationFunction()) + NamedDecl *ND = (*F)->getUnderlyingDecl(); + + // Ignore template operator delete members from the check for a usual + // deallocation function. + if (isa(ND)) + continue; + + if (cast(ND)->isUsualDeallocationFunction()) Matches.push_back(F.getPair()); } diff --git a/test/SemaCXX/new-delete.cpp b/test/SemaCXX/new-delete.cpp index 816b808346..b127e667c5 100644 --- a/test/SemaCXX/new-delete.cpp +++ b/test/SemaCXX/new-delete.cpp @@ -332,3 +332,15 @@ namespace PR7810 { static void operator delete(void *volatile); }; } + +// Don't crash on template delete operators +namespace TemplateDestructors { + struct S { + virtual ~S() {} + + void* operator new(const size_t size); + template void* operator new(const size_t, const int, T*); + void operator delete(void*, const size_t); + template void operator delete(void*, const size_t, const int, T*); + }; +}