From: Chris Lattner Date: Tue, 22 Jan 2002 00:17:48 +0000 (+0000) Subject: Ooops, forgot to implement void PassManager::add(BasicBlockPass *BBP) X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=35f07eb2ebf7d3a9e1a95470770b29e1b45b2cb1;p=oota-llvm.git Ooops, forgot to implement void PassManager::add(BasicBlockPass *BBP) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1523 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/VMCore/Pass.cpp b/lib/VMCore/Pass.cpp index 2f2fd0e2116..a3d03f13b3d 100644 --- a/lib/VMCore/Pass.cpp +++ b/lib/VMCore/Pass.cpp @@ -60,13 +60,17 @@ public: for_each(SubPasses.begin(), SubPasses.end(), deleter); } + void add(BasicBlockPass *BBP) { + if (BBPBatcher == 0) { + BBPBatcher = new BasicBlockPassBatcher(); + SubPasses.push_back(BBPBatcher); + } + BBPBatcher->add(BBP); + } + void add(MethodPass *P) { if (BasicBlockPass *BBP = dynamic_cast(P)) { - if (BBPBatcher == 0) { - BBPBatcher = new BasicBlockPassBatcher(); - SubPasses.push_back(BBPBatcher); - } - BBPBatcher->add(BBP); + add(BBP); } else { BBPBatcher = 0; // Ensure that passes don't get accidentally reordered SubPasses.push_back(P); @@ -92,7 +96,15 @@ public: } }; - +// add(BasicBlockPass*) - If we know it's a BasicBlockPass, we don't have to do +// any checking... +// +void PassManager::add(BasicBlockPass *BBP) { + if (Batcher == 0) // If we don't have a batcher yet, make one now. + add((MethodPass*)BBP); + else + Batcher->add(BBP); +} // add(MethodPass*) - MethodPass's must be batched together... make sure this