Give PassManager and FunctionPassManager a common base class, with

add(Pass *) as a pure virtual member function. This will allow all
the various addPassesTo* functions in LLVM to avoid hard-coding what
type of PassManager is used. 

llvm-svn: 48226
This commit is contained in:
Dan Gohman 2008-03-11 16:41:42 +00:00
parent dfdf2c0633
commit d3a20c9e1e
2 changed files with 17 additions and 3 deletions

View File

@ -29,8 +29,22 @@ class ModuleProvider;
class PassManagerImpl;
class FunctionPassManagerImpl;
/// PassManagerBase - An abstract interface to allow code to add passes to
/// a pass manager without having to hard-code what kind of pass manager
/// it is.
class PassManagerBase {
public:
virtual ~PassManagerBase();
/// add - Add a pass to the queue of passes to run. This passes ownership of
/// the Pass to the PassManager. When the PassManager is destroyed, the pass
/// will be destroyed as well, so there is no need to delete the pass. This
/// implies that all passes MUST be allocated with 'new'.
virtual void add(Pass *P) = 0;
};
/// PassManager manages ModulePassManagers
class PassManager {
class PassManager : public PassManagerBase {
public:
PassManager();
@ -54,7 +68,7 @@ private:
};
/// FunctionPassManager manages FunctionPasses and BasicBlockPassManagers.
class FunctionPassManager {
class FunctionPassManager : public PassManagerBase {
public:
/// FunctionPassManager ctor - This initializes the pass manager. It needs,
/// but does not take ownership of, the specified module provider.

View File

@ -1531,4 +1531,4 @@ void BasicBlockPass::assignPassManager(PMStack &PMS,
BBP->add(this);
}
PassManagerBase::~PassManagerBase() {}