diff options
author | Chris Lattner <sabre@nondot.org> | 2001-09-07 16:27:05 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2001-09-07 16:27:05 +0000 |
commit | 4c4007b3df52672f6b21594c8448538e1a5c4d90 (patch) | |
tree | b7402a5ecd4cbc02e2d8d397904a84a982c63c5d /lib/Bytecode | |
parent | d5bbe381b9e93113eb6ebe4c7b0519e97a81dfb1 (diff) |
Simplify SlotCalculator. SlotCalculator is now not a ModuleAnalyzer
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@432 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bytecode')
-rw-r--r-- | lib/Bytecode/Writer/SlotCalculator.h | 60 |
1 files changed, 24 insertions, 36 deletions
diff --git a/lib/Bytecode/Writer/SlotCalculator.h b/lib/Bytecode/Writer/SlotCalculator.h index fbdfbe90ad..c7b3149054 100644 --- a/lib/Bytecode/Writer/SlotCalculator.h +++ b/lib/Bytecode/Writer/SlotCalculator.h @@ -9,24 +9,28 @@ #ifndef LLVM_ANALYSIS_SLOTCALCULATOR_H #define LLVM_ANALYSIS_SLOTCALCULATOR_H -#include "llvm/Analysis/ModuleAnalyzer.h" #include "llvm/SymTabValue.h" #include <vector> #include <map> class Value; +class Module; +class Method; +class MethodArgument; +class BasicBlock; +class Instruction; -class SlotCalculator : public ModuleAnalyzer { +class SlotCalculator { const Module *TheModule; bool IgnoreNamedNodes; // Shall we not count named nodes? typedef vector<const Value*> TypePlane; - vector <TypePlane> Table; + vector<TypePlane> Table; map<const Value *, unsigned> NodeMap; // ModuleLevel - Used to keep track of which values belong to the module, // and which values belong to the currently incorporated method. // - vector <unsigned> ModuleLevel; + vector<unsigned> ModuleLevel; public: SlotCalculator(const Module *M, bool IgnoreNamed); @@ -52,46 +56,30 @@ public: void purgeMethod(); protected: - // insertVal - Insert a value into the value table... + // insertVal - Insert a value into the value table... Return the slot that it + // occupies, or -1 if the declaration is to be ignored because of the + // IgnoreNamedNodes flag. // - void insertVal(const Value *D, bool dontIgnore = false); + int insertVal(const Value *D, bool dontIgnore = false); - // visitMethod - This member is called after the constant pool has been - // processed. The default implementation of this is a noop. + // insertValue - Values can be crammed into here at will... if they haven't + // been inserted already, they get inserted, otherwise they are ignored. // - virtual bool visitMethod(const Method *M); + int insertValue(const Value *D); - // processConstant is called once per each constant in the constant pool. It - // traverses the constant pool such that it visits each constant in the - // order of its type. Thus, all 'int' typed constants shall be visited - // sequentially, etc... - // - virtual bool processConstant(const ConstPoolVal *CPV); - - // processType - This callback occurs when an derived type is discovered - // at the class level. This activity occurs when processing a constant pool. - // - virtual bool processType(const Type *Ty); - - // processMethods - The default implementation of this method loops through - // all of the methods in the module and processModule's them. We don't want - // this (we want to explicitly visit them with incorporateMethod), so we - // disable it. - // - virtual bool processMethods(const Module *M) { return false; } - - // processMethodArgument - This member is called for every argument that - // is passed into the method. - // - virtual bool processMethodArgument(const MethodArgument *MA); + // doInsertVal - Small helper function to be called only be insertVal. + int doInsertVal(const Value *D); - // processBasicBlock - This member is called for each basic block in a methd. + // processModule - Process all of the module level method declarations and + // types that are available. // - virtual bool processBasicBlock(const BasicBlock *BB); + void processModule(); - // processInstruction - This member is called for each Instruction in a methd. + // processSymbolTable - Insert all of the values in the specified symbol table + // into the values table... // - virtual bool processInstruction(const Instruction *I); + void processSymbolTable(const SymbolTable *ST); + void processSymbolTableConstants(const SymbolTable *ST); }; #endif |