summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2011-02-13 00:46:43 +0000
committerJohn McCall <rjmccall@apple.com>2011-02-13 00:46:43 +0000
commit2b3c5538fa26f5301d4498b8d6c8949d68aa20c2 (patch)
treed4cb41556fb0188c5b05c0da837ff3024fee394f /clang/lib/CodeGen
parent2406b7d179a38907023ffecce0ed2ddb28f8c2b6 (diff)
downloadbcm5719-llvm-2b3c5538fa26f5301d4498b8d6c8949d68aa20c2.tar.gz
bcm5719-llvm-2b3c5538fa26f5301d4498b8d6c8949d68aa20c2.zip
Look through array types when deciding whether a field requires non-trivial
destruction in the destructor-aliases logic. Fixes PR 9197. llvm-svn: 125447
Diffstat (limited to 'clang/lib/CodeGen')
-rw-r--r--clang/lib/CodeGen/CGCXX.cpp9
1 files changed, 4 insertions, 5 deletions
diff --git a/clang/lib/CodeGen/CGCXX.cpp b/clang/lib/CodeGen/CGCXX.cpp
index d4bd9cbc9ab..7ffc6e73255 100644
--- a/clang/lib/CodeGen/CGCXX.cpp
+++ b/clang/lib/CodeGen/CGCXX.cpp
@@ -60,13 +60,12 @@ bool CodeGenModule::TryEmitBaseDestructorAsAlias(const CXXDestructorDecl *D) {
return true;
}
- // If any fields have a non-trivial destructor, we have to emit it
- // separately.
+ // If any field has a non-trivial destructor, we have to emit the
+ // destructor separately.
for (CXXRecordDecl::field_iterator I = Class->field_begin(),
E = Class->field_end(); I != E; ++I)
- if (const RecordType *RT = (*I)->getType()->getAs<RecordType>())
- if (!cast<CXXRecordDecl>(RT->getDecl())->hasTrivialDestructor())
- return true;
+ if ((*I)->getType().isDestructedType())
+ return true;
// Try to find a unique base class with a non-trivial destructor.
const CXXRecordDecl *UniqueBase = 0;
OpenPOWER on IntegriCloud