add some support for blockaddress. This isn't really enough to be useful,
authorChris Lattner <sabre@nondot.org>
Mon, 21 Jun 2010 23:19:36 +0000 (23:19 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 21 Jun 2010 23:19:36 +0000 (23:19 +0000)
but it will cover uses of blockaddress that are actually in a function.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@106502 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/CppBackend/CPPBackend.cpp

index 00f3cafb707a18dd6ce1c63621b63108814b578e..da63b1e75a06a5e2f055f6e45073f870f838b1b8 100644 (file)
@@ -936,6 +936,9 @@ void CppWriter::printConstant(const Constant *CV) {
         Out << ", " << getCppName(CE->getOperand(i));
       Out << ");";
     }
+  } else if (const BlockAddress *BA = dyn_cast<BlockAddress>(CV)) {
+    Out << "Constant* " << constName << " = ";
+    Out << "BlockAddress::get(" << getOpName(BA->getBasicBlock()) << ");";
   } else {
     error("Bad Constant");
     Out << "Constant* " << constName << " = 0; ";
@@ -1088,9 +1091,8 @@ void CppWriter::printInstruction(const Instruction *I,
   // forward references. So, we get the names of all the operands in advance
   const unsigned Ops(I->getNumOperands());
   std::string* opNames = new std::string[Ops];
-  for (unsigned i = 0; i < Ops; i++) {
+  for (unsigned i = 0; i < Ops; i++)
     opNames[i] = getOpName(I->getOperand(i));
-  }
 
   switch (I->getOpcode()) {
   default:
@@ -1106,7 +1108,7 @@ void CppWriter::printInstruction(const Instruction *I,
   case Instruction::Br: {
     const BranchInst* br = cast<BranchInst>(I);
     Out << "BranchInst::Create(" ;
-    if (br->getNumOperands() == 3 ) {
+    if (br->getNumOperands() == 3) {
       Out << opNames[2] << ", "
           << opNames[1] << ", "
           << opNames[0] << ", ";