CFGBlock* ContinueTargetBlock;
CFGBlock* BreakTargetBlock;
CFGBlock* SwitchTerminatedBlock;
- unsigned NumBlocks;
// LabelMap records the mapping from Label expressions to their blocks.
typedef llvm::DenseMap<LabelStmt*,CFGBlock*> LabelMapTy;
public:
explicit CFGBuilder() : cfg(NULL), Block(NULL), Succ(NULL),
ContinueTargetBlock(NULL), BreakTargetBlock(NULL),
- SwitchTerminatedBlock(NULL),
- NumBlocks(0) {
+ SwitchTerminatedBlock(NULL) {
// Create an empty CFG.
cfg = new CFG();
}
/// createBlock - Used to lazily create blocks that are connected
/// to the current (global) succcessor.
CFGBlock* CFGBuilder::createBlock(bool add_successor) {
- CFGBlock* B = cfg->createBlock(NumBlocks++);
+ CFGBlock* B = cfg->createBlock();
if (add_successor && Succ) B->addSuccessor(Succ);
return B;
}
/// block has no successors or predecessors. If this is the first block
/// created in the CFG, it is automatically set to be the Entry and Exit
/// of the CFG.
-CFGBlock* CFG::createBlock(unsigned blockID) {
+CFGBlock* CFG::createBlock() {
bool first_block = begin() == end();
// Create the block.
- Blocks.push_front(CFGBlock(blockID));
+ Blocks.push_front(CFGBlock(NumBlockIDs++));
// If this is the first block, set it as the Entry and Exit.
if (first_block) Entry = Exit = &front();
CFGBlock* IndirectGotoBlock; // Special block to contain collective dispatch
// for indirect gotos
CFGBlockListTy Blocks;
+ unsigned NumBlockIDs;
public:
- CFG() : Entry(NULL), Exit(NULL), IndirectGotoBlock(NULL) {};
+ CFG() : Entry(NULL), Exit(NULL), IndirectGotoBlock(NULL), NumBlockIDs(0) {};
~CFG() {};
// Block iterators
// Utility
- CFGBlock* createBlock(unsigned blockID);
+ CFGBlock* createBlock();
+ unsigned getNumBlockIDs() const { return NumBlockIDs; }
+
static CFG* buildCFG(Stmt* AST);
void viewCFG() const;
void print(std::ostream& OS) const;