diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2009-08-20 01:01:06 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-08-20 01:01:06 +0000 |
commit | 995d2818a11395b15995694a30f842a0e4fdee4f (patch) | |
tree | 1333784bb3e57033a48e127efdbaf405c7e12296 /lib/CodeGen/CGCXX.cpp | |
parent | c484381467789938b06872bb1b270db1b6ec164c (diff) |
Test case for my last patch plus a minor clean up.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@79500 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGCXX.cpp')
-rw-r--r-- | lib/CodeGen/CGCXX.cpp | 6 |
1 files changed, 2 insertions, 4 deletions
diff --git a/lib/CodeGen/CGCXX.cpp b/lib/CodeGen/CGCXX.cpp index b564a08501..d3dad897a8 100644 --- a/lib/CodeGen/CGCXX.cpp +++ b/lib/CodeGen/CGCXX.cpp @@ -375,26 +375,24 @@ CodeGenFunction::EmitCXXAggrConstructorCall(const CXXConstructorDecl *D, llvm::BasicBlock *ContinueBlock = createBasicBlock("for.inc"); // Inside the loop body, emit the constructor call on the array element. + Counter = Builder.CreateLoad(IndexPtr); if (const ConstantArrayType *CAT = dyn_cast<ConstantArrayType>(Array->getElementType())) { - // Need to call this routine again. uint32_t delta = 1; const ConstantArrayType *CAW = CAT; do { delta *= CAW->getSize().getZExtValue(); CAW = dyn_cast<ConstantArrayType>(CAW->getElementType()); } while (CAW); - // Address = This + delta*Counter + // Address = This + delta*Counter for current loop iteration. llvm::Value *DeltaPtr = llvm::ConstantInt::get(llvm::Type::getInt32Ty(VMContext), delta); - Counter = Builder.CreateLoad(IndexPtr); DeltaPtr = Builder.CreateMul(Counter, DeltaPtr, "mul"); llvm::Value *Address = Builder.CreateInBoundsGEP(This, DeltaPtr, "arrayidx"); EmitCXXAggrConstructorCall(D, CAT, Address); } else { - Counter = Builder.CreateLoad(IndexPtr); llvm::Value *Address = Builder.CreateInBoundsGEP(This, Counter, "arrayidx"); EmitCXXConstructorCall(D, Ctor_Complete, Address, 0, 0); } |