diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2011-05-17 00:46:40 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2011-05-17 00:46:40 +0000 |
commit | ceee5e813364a34db3ad99926fd05dce69e4bb44 (patch) | |
tree | 62dd79726a2ab6fed65a13c58f8b316b48620892 | |
parent | 49b35de2a138482593efab097bcffd0b93bd9bf7 (diff) | |
download | bcm5719-llvm-ceee5e813364a34db3ad99926fd05dce69e4bb44.tar.gz bcm5719-llvm-ceee5e813364a34db3ad99926fd05dce69e4bb44.zip |
Inside isEmptyRecord function, for CXXRecordDecl just check the isEmpty bit.
llvm-svn: 131447
-rw-r--r-- | clang/lib/CodeGen/TargetInfo.cpp | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/clang/lib/CodeGen/TargetInfo.cpp b/clang/lib/CodeGen/TargetInfo.cpp index bc2472cebbe..3c18b0b1083 100644 --- a/clang/lib/CodeGen/TargetInfo.cpp +++ b/clang/lib/CodeGen/TargetInfo.cpp @@ -128,12 +128,9 @@ static bool isEmptyRecord(ASTContext &Context, QualType T, bool AllowArrays) { if (RD->hasFlexibleArrayMember()) return false; - // If this is a C++ record, check the bases first. + // If this is a C++ record, check if it is empty. if (const CXXRecordDecl *CXXRD = dyn_cast<CXXRecordDecl>(RD)) - for (CXXRecordDecl::base_class_const_iterator i = CXXRD->bases_begin(), - e = CXXRD->bases_end(); i != e; ++i) - if (!isEmptyRecord(Context, i->getType(), true)) - return false; + return CXXRD->isEmpty(); for (RecordDecl::field_iterator i = RD->field_begin(), e = RD->field_end(); i != e; ++i) |