[llvm-commits] CVS: llvm/lib/CWriter/Writer.cpp
Chris Lattner
lattner at cs.uiuc.edu
Tue Apr 22 15:21:00 PDT 2003
Changes in directory llvm/lib/CWriter:
Writer.cpp updated: 1.77 -> 1.78
---
Log message:
Add support for the switch instruction to the CWriter
---
Diffs of the changes:
Index: llvm/lib/CWriter/Writer.cpp
diff -u llvm/lib/CWriter/Writer.cpp:1.77 llvm/lib/CWriter/Writer.cpp:1.78
--- llvm/lib/CWriter/Writer.cpp:1.77 Wed Feb 12 14:45:00 2003
+++ llvm/lib/CWriter/Writer.cpp Tue Apr 22 15:19:52 2003
@@ -7,11 +7,7 @@
#include "llvm/Constants.h"
#include "llvm/DerivedTypes.h"
#include "llvm/Module.h"
-#include "llvm/iMemory.h"
-#include "llvm/iTerminators.h"
-#include "llvm/iPHINode.h"
-#include "llvm/iOther.h"
-#include "llvm/iOperators.h"
+#include "llvm/Instructions.h"
#include "llvm/Pass.h"
#include "llvm/SymbolTable.h"
#include "llvm/SlotCalculator.h"
@@ -108,6 +104,7 @@
void visitReturnInst(ReturnInst &I);
void visitBranchInst(BranchInst &I);
+ void visitSwitchInst(SwitchInst &I);
void visitPHINode(PHINode &I) {}
void visitBinaryOperator(Instruction &I);
@@ -156,8 +153,8 @@
string CWriter::getValueName(const Value *V) {
if (V->hasName()) { // Print out the label if it exists...
if (isa<GlobalValue>(V) && // Do not mangle globals...
- cast<GlobalValue>(V)->hasExternalLinkage())// && // Unless it's internal or
- //!MangledGlobals.count(V)) // Unless the name would collide if we don't
+ cast<GlobalValue>(V)->hasExternalLinkage()) // Unless it's internal or
+ //!MangledGlobals.count(V)) // Unless the name would collide if we don't
return makeNameProper(V->getName());
return "l" + utostr(V->getType()->getUniqueID()) + "_" +
@@ -866,6 +863,25 @@
}
Out << ";\n";
}
+
+void CWriter::visitSwitchInst(SwitchInst &SI) {
+ Out << " switch (";
+ writeOperand(SI.getOperand(0));
+ Out << ") {\n default: goto ";
+ writeOperand(SI.getDefaultDest());
+ Out << ";\n";
+ for (unsigned i = 2, e = SI.getNumOperands(); i != e; i += 2) {
+ Out << " case ";
+ writeOperand(SI.getOperand(i));
+ Out << ":\n";
+ BasicBlock *Succ = cast<BasicBlock>(SI.getOperand(i+1));
+ printBranchToBlock(SI.getParent(), Succ, 2);
+ if (Succ == SI.getParent()->getNext())
+ Out << " break;\n";
+ }
+ Out << " }\n";
+}
+
static bool isGotoCodeNeccessary(BasicBlock *From, BasicBlock *To) {
// If PHI nodes need copies, we need the copy code...
More information about the llvm-commits
mailing list