]> granicus.if.org Git - clang/commitdiff
ir-gen for multi-dimensional array construction. WIP.
authorFariborz Jahanian <fjahanian@apple.com>
Thu, 20 Aug 2009 00:15:15 +0000 (00:15 +0000)
committerFariborz Jahanian <fjahanian@apple.com>
Thu, 20 Aug 2009 00:15:15 +0000 (00:15 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@79497 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGCXX.cpp

index deaac7499f8479551fe01d09ee38e4dc7277315e..b564a0850154d376773b06c33ecbfa709f485532 100644 (file)
@@ -374,18 +374,31 @@ CodeGenFunction::EmitCXXAggrConstructorCall(const CXXConstructorDecl *D,
   EmitBlock(ForBody);
   
   llvm::BasicBlock *ContinueBlock = createBasicBlock("for.inc");
-  
   // Inside the loop body, emit the constructor call on the array element.
-  Counter = Builder.CreateLoad(IndexPtr);
-  llvm::Value *Address = Builder.CreateInBoundsGEP(This, Counter, "arrayidx");
   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
+    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
+  else {
+    Counter = Builder.CreateLoad(IndexPtr);
+    llvm::Value *Address = Builder.CreateInBoundsGEP(This, Counter, "arrayidx");
     EmitCXXConstructorCall(D, Ctor_Complete, Address, 0, 0);
-  
+  }
+    
   EmitBlock(ContinueBlock);
   
   // Emit the increment of the loop counter.
@@ -399,7 +412,6 @@ CodeGenFunction::EmitCXXAggrConstructorCall(const CXXConstructorDecl *D,
   
   // Emit the fall-through block.
   EmitBlock(AfterFor, true);
-  
 }
 
 void