From d27df628cc6fa29605fa221a2f0b03b4592caf03 Mon Sep 17 00:00:00 2001 From: Dan Gohman Date: Thu, 5 Jul 2007 20:39:35 +0000 Subject: [PATCH] Make MachineFunctionPass::runOnFunction non-virtual. Subclasses override the virtual function runOnMachineFunction instead. And add access specifiers. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@37924 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/CodeGen/MachineFunctionPass.h | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/include/llvm/CodeGen/MachineFunctionPass.h b/include/llvm/CodeGen/MachineFunctionPass.h index 9a8d29b3c8a..f90c696738f 100644 --- a/include/llvm/CodeGen/MachineFunctionPass.h +++ b/include/llvm/CodeGen/MachineFunctionPass.h @@ -28,17 +28,20 @@ struct MachineFunctionPass : public FunctionPass { explicit MachineFunctionPass(intptr_t ID) : FunctionPass(ID) {} +protected: /// runOnMachineFunction - This method must be overloaded to perform the /// desired machine code transformation or analysis. /// virtual bool runOnMachineFunction(MachineFunction &MF) = 0; +public: // FIXME: This pass should declare that the pass does not invalidate any LLVM // passes. - virtual bool runOnFunction(Function &F) { + bool runOnFunction(Function &F) { return runOnMachineFunction(MachineFunction::get(&F)); } +private: virtual void virtfn(); // out of line virtual fn to give class a home. }; -- 2.34.1