summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2009-07-01 23:35:25 +0000
committerFariborz Jahanian <fjahanian@apple.com>2009-07-01 23:35:25 +0000
commit5c6af0a9989f068d8021e7453d5cda65844fdbb6 (patch)
tree2140dc992f97446c3d0da51028e3a1642b5df128 /clang/lib
parent873db258791b2c16ede203276737b3d46d5798bd (diff)
downloadbcm5719-llvm-5c6af0a9989f068d8021e7453d5cda65844fdbb6.tar.gz
bcm5719-llvm-5c6af0a9989f068d8021e7453d5cda65844fdbb6.zip
Use Destroy for member initializer list clean up.
Per Doug's comments. Doug please review. llvm-svn: 74666
Diffstat (limited to 'clang/lib')
-rw-r--r--clang/lib/AST/DeclCXX.cpp10
-rw-r--r--clang/lib/Sema/SemaDeclCXX.cpp7
2 files changed, 15 insertions, 2 deletions
diff --git a/clang/lib/AST/DeclCXX.cpp b/clang/lib/AST/DeclCXX.cpp
index f653943f1dd..9bdf07b29e5 100644
--- a/clang/lib/AST/DeclCXX.cpp
+++ b/clang/lib/AST/DeclCXX.cpp
@@ -409,17 +409,25 @@ CXXDestructorDecl::Create(ASTContext &C, CXXRecordDecl *RD,
void
CXXConstructorDecl::setBaseOrMemberInitializers(
+ ASTContext &C,
CXXBaseOrMemberInitializer **Initializers,
unsigned NumInitializers) {
if (NumInitializers > 0) {
NumBaseOrMemberInitializers = NumInitializers;
BaseOrMemberInitializers =
- new CXXBaseOrMemberInitializer*[NumInitializers];
+ new (C, 8) CXXBaseOrMemberInitializer*[NumInitializers];
for (unsigned Idx = 0; Idx < NumInitializers; ++Idx)
BaseOrMemberInitializers[Idx] = Initializers[Idx];
}
}
+void
+CXXConstructorDecl::Destroy(ASTContext& C) {
+ C.Deallocate(BaseOrMemberInitializers);
+ this->~CXXMethodDecl();
+ C.Deallocate((void *)this);
+}
+
CXXConversionDecl *
CXXConversionDecl::Create(ASTContext &C, CXXRecordDecl *RD,
SourceLocation L, DeclarationName N,
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp
index bbb173a02ad..bef63a16d6c 100644
--- a/clang/lib/Sema/SemaDeclCXX.cpp
+++ b/clang/lib/Sema/SemaDeclCXX.cpp
@@ -782,7 +782,7 @@ void Sema::ActOnMemInitializers(DeclPtrTy ConstructorDecl,
return;
}
llvm::DenseMap<void*, CXXBaseOrMemberInitializer *>Members;
-
+ bool err = false;
for (unsigned i = 0; i < NumMemInits; i++) {
CXXBaseOrMemberInitializer *Member =
static_cast<CXXBaseOrMemberInitializer*>(MemInits[i]);
@@ -811,7 +811,12 @@ void Sema::ActOnMemInitializers(DeclPtrTy ConstructorDecl,
}
Diag(PrevMember->getSourceLocation(), diag::note_previous_initializer)
<< 0;
+ err = true;
}
+ if (!err)
+ Constructor->setBaseOrMemberInitializers(Context,
+ reinterpret_cast<CXXBaseOrMemberInitializer **>(MemInits),
+ NumMemInits);
}
namespace {
OpenPOWER on IntegriCloud