diff options
| author | Douglas Gregor <dgregor@apple.com> | 2011-07-26 15:11:03 +0000 |
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2011-07-26 15:11:03 +0000 |
| commit | 72912fb9a42ec1095c53c82cbac575d19a4b6c92 (patch) | |
| tree | 5475b5557b086e424bffc5a57383533b015b9042 /clang/lib/Sema/TreeTransform.h | |
| parent | 3ac1836540641ec69f739d8660b6d8540c521953 (diff) | |
| download | bcm5719-llvm-72912fb9a42ec1095c53c82cbac575d19a4b6c92.tar.gz bcm5719-llvm-72912fb9a42ec1095c53c82cbac575d19a4b6c92.zip | |
When we decide not to rebuild an instantiated C++ 'new' expression
that allocates an array of objects with a non-trivial destructor, be
sure to mark the destructor is "used". Fixes PR10480 /
<rdar://problem/9834317>.
llvm-svn: 136081
Diffstat (limited to 'clang/lib/Sema/TreeTransform.h')
| -rw-r--r-- | clang/lib/Sema/TreeTransform.h | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/clang/lib/Sema/TreeTransform.h b/clang/lib/Sema/TreeTransform.h index c75665bfc01..2221fc0c211 100644 --- a/clang/lib/Sema/TreeTransform.h +++ b/clang/lib/Sema/TreeTransform.h @@ -6902,6 +6902,19 @@ TreeTransform<Derived>::TransformCXXNewExpr(CXXNewExpr *E) { SemaRef.MarkDeclarationReferenced(E->getLocStart(), OperatorNew); if (OperatorDelete) SemaRef.MarkDeclarationReferenced(E->getLocStart(), OperatorDelete); + + if (E->isArray() && Constructor && + !E->getAllocatedType()->isDependentType()) { + QualType ElementType + = SemaRef.Context.getBaseElementType(E->getAllocatedType()); + if (const RecordType *RecordT = ElementType->getAs<RecordType>()) { + CXXRecordDecl *Record = cast<CXXRecordDecl>(RecordT->getDecl()); + if (CXXDestructorDecl *Destructor = SemaRef.LookupDestructor(Record)) { + SemaRef.MarkDeclarationReferenced(E->getLocStart(), Destructor); + } + } + } + return SemaRef.Owned(E); } |

