summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2010-08-08 07:04:00 +0000
committerChandler Carruth <chandlerc@gmail.com>2010-08-08 07:04:00 +0000
commit9b41823177c8454e03bf1524260bcf55dded9f45 (patch)
treef74c2b2a9c0061519e71b8bf3959e0db687d8a36 /clang
parent7f36ac54d7af0baf9794457ead65458200969a60 (diff)
downloadbcm5719-llvm-9b41823177c8454e03bf1524260bcf55dded9f45.tar.gz
bcm5719-llvm-9b41823177c8454e03bf1524260bcf55dded9f45.zip
Fix a crash on template delete operators.
llvm-svn: 110542
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Sema/SemaExprCXX.cpp10
-rw-r--r--clang/test/SemaCXX/new-delete.cpp12
2 files changed, 20 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaExprCXX.cpp b/clang/lib/Sema/SemaExprCXX.cpp
index b1d60155141..7bebce16e1f 100644
--- a/clang/lib/Sema/SemaExprCXX.cpp
+++ b/clang/lib/Sema/SemaExprCXX.cpp
@@ -1301,8 +1301,14 @@ bool Sema::FindDeallocationFunction(SourceLocation StartLoc, CXXRecordDecl *RD,
llvm::SmallVector<DeclAccessPair,4> Matches;
for (LookupResult::iterator F = Found.begin(), FEnd = Found.end();
F != FEnd; ++F) {
- CXXMethodDecl *Delete = cast<CXXMethodDecl>((*F)->getUnderlyingDecl());
- if (Delete->isUsualDeallocationFunction())
+ NamedDecl *ND = (*F)->getUnderlyingDecl();
+
+ // Ignore template operator delete members from the check for a usual
+ // deallocation function.
+ if (isa<FunctionTemplateDecl>(ND))
+ continue;
+
+ if (cast<CXXMethodDecl>(ND)->isUsualDeallocationFunction())
Matches.push_back(F.getPair());
}
diff --git a/clang/test/SemaCXX/new-delete.cpp b/clang/test/SemaCXX/new-delete.cpp
index 816b808346a..b127e667c53 100644
--- a/clang/test/SemaCXX/new-delete.cpp
+++ b/clang/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<class T> void* operator new(const size_t, const int, T*);
+ void operator delete(void*, const size_t);
+ template<class T> void operator delete(void*, const size_t, const int, T*);
+ };
+}
OpenPOWER on IntegriCloud