summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-03-09 05:35:16 +0000
committerChris Lattner <sabre@nondot.org>2005-03-09 05:35:16 +0000
commit4dc39d447dc9b7ff89888ee7b2eb086cc035e79c (patch)
treeb0b836aa02f481b5320e546e95cbef6531848678
parentadb043c2d8045ea3350cb52386f65845f096e4bb (diff)
downloadbcm5719-llvm-4dc39d447dc9b7ff89888ee7b2eb086cc035e79c.tar.gz
bcm5719-llvm-4dc39d447dc9b7ff89888ee7b2eb086cc035e79c.zip
Use static_cast and #include Instructions.h
llvm-svn: 20528
-rw-r--r--llvm/include/llvm/Support/InstVisitor.h16
1 files changed, 10 insertions, 6 deletions
diff --git a/llvm/include/llvm/Support/InstVisitor.h b/llvm/include/llvm/Support/InstVisitor.h
index 6eef0f9a106..49b5ee109c0 100644
--- a/llvm/include/llvm/Support/InstVisitor.h
+++ b/llvm/include/llvm/Support/InstVisitor.h
@@ -51,6 +51,7 @@
#define LLVM_SUPPORT_INSTVISITOR_H
#include "llvm/Function.h"
+#include "llvm/Instructions.h"
#include "llvm/Module.h"
namespace llvm {
@@ -66,7 +67,8 @@ class TerminatorInst; class BinaryOperator;
class AllocationInst;
#define DELEGATE(CLASS_TO_VISIT) \
- return ((SubClass*)this)->visit##CLASS_TO_VISIT((CLASS_TO_VISIT&)I)
+ return static_cast<SubClass*>(this)-> \
+ visit##CLASS_TO_VISIT(static_cast<CLASS_TO_VISIT&>(I))
template<typename SubClass, typename RetTy=void>
@@ -81,21 +83,21 @@ public:
template<class Iterator>
void visit(Iterator Start, Iterator End) {
while (Start != End)
- ((SubClass*)this)->visit(*Start++);
+ static_cast<SubClass*>(this)->visit(*Start++);
}
// Define visitors for functions and basic blocks...
//
void visit(Module &M) {
- ((SubClass*)this)->visitModule(M);
+ static_cast<SubClass*>(this)->visitModule(M);
visit(M.begin(), M.end());
}
void visit(Function &F) {
- ((SubClass*)this)->visitFunction(F);
+ static_cast<SubClass*>(this)->visitFunction(F);
visit(F.begin(), F.end());
}
void visit(BasicBlock &BB) {
- ((SubClass*)this)->visitBasicBlock(BB);
+ static_cast<SubClass*>(this)->visitBasicBlock(BB);
visit(BB.begin(), BB.end());
}
@@ -113,7 +115,9 @@ public:
abort();
// Build the switch statement using the Instruction.def file...
#define HANDLE_INST(NUM, OPCODE, CLASS) \
- case Instruction::OPCODE:return ((SubClass*)this)->visit##OPCODE((CLASS&)I);
+ case Instruction::OPCODE: return \
+ static_cast<SubClass*>(this)-> \
+ visit##OPCODE(static_cast<CLASS&>(I));
#include "llvm/Instruction.def"
}
}
OpenPOWER on IntegriCloud