CMS 3D CMS Logo

EDFilterBase.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: FWCore/Framework
4 // Class : one::EDFilterBase
5 //
6 // Implementation:
7 // [Notes on implementation]
8 //
9 // Original Author: Chris Jones
10 // Created: Thu, 02 May 2013 21:56:04 GMT
11 //
12 
13 // system include files
14 
15 // user include files
24 
27 
28 //
29 // constants, enums and typedefs
30 //
31 namespace edm {
32  class ModuleCallingContext;
33 
34  namespace one {
35  //
36  // static data member definitions
37  //
38 
39  //
40  // constructors and destructor
41  //
42  EDFilterBase::EDFilterBase() : ProducerBase(), moduleDescription_(), previousParentage_(), previousParentageId_() {}
43 
45 
47  EventSetupImpl const& ci,
48  ActivityRegistry* act,
49  ModuleCallingContext const* mcc) {
50  Event e(ep, moduleDescription_, mcc);
51  e.setConsumer(this);
53  bool returnValue = true;
55  EventSignalsSentry sentry(act, mcc);
56  const EventSetup c{ci, static_cast<unsigned int>(Transition::Event), esGetTokenIndices(Transition::Event)};
57  returnValue = this->filter(e, c);
59  return returnValue;
60  }
61 
64  std::vector<std::shared_ptr<SerialTaskQueue>>(1, std::make_shared<SerialTaskQueue>())};
65  }
66 
69 
72 
73  this->beginJob();
74  }
75 
76  void EDFilterBase::doEndJob() { this->endJob(); }
77 
79  auto const nThreads = iPrealloc.numberOfThreads();
82  }
83  void EDFilterBase::preallocLumis(unsigned int){};
84 
86  Run r(rp, moduleDescription_, mcc, false);
87  r.setConsumer(this);
88  Run const& cnstR = r;
89  const EventSetup c{ci, static_cast<unsigned int>(Transition::BeginRun), esGetTokenIndices(Transition::BeginRun)};
90  this->doBeginRun_(cnstR, c);
91  r.setProducer(this);
92  this->doBeginRunProduce_(r, c);
93  commit_(r);
94  }
95 
97  Run r(rp, moduleDescription_, mcc, true);
98  r.setConsumer(this);
99  Run const& cnstR = r;
100  const EventSetup c{ci, static_cast<unsigned int>(Transition::EndRun), esGetTokenIndices(Transition::EndRun)};
101  this->doEndRun_(cnstR, c);
102  r.setProducer(this);
103  this->doEndRunProduce_(r, c);
104  commit_(r);
105  }
106 
108  EventSetupImpl const& ci,
109  ModuleCallingContext const* mcc) {
110  LuminosityBlock lb(lbp, moduleDescription_, mcc, false);
111  lb.setConsumer(this);
112  LuminosityBlock const& cnstLb = lb;
113  const EventSetup c{ci,
114  static_cast<unsigned int>(Transition::BeginLuminosityBlock),
116  this->doBeginLuminosityBlock_(cnstLb, c);
117  lb.setProducer(this);
119  commit_(lb);
120  }
121 
123  EventSetupImpl const& ci,
124  ModuleCallingContext const* mcc) {
125  LuminosityBlock lb(lbp, moduleDescription_, mcc, true);
126  lb.setConsumer(this);
127  LuminosityBlock const& cnstLb = lb;
128  const EventSetup c{ci,
129  static_cast<unsigned int>(Transition::EndLuminosityBlock),
131  this->doEndLuminosityBlock_(cnstLb, c);
132  lb.setProducer(this);
133  this->doEndLuminosityBlockProduce_(lb, c);
134  commit_(lb);
135  }
136 
138  //respondToOpenInputFile(fb);
139  }
140 
142  //respondToCloseInputFile(fb);
143  }
144 
145  void EDFilterBase::doBeginRun_(Run const& rp, EventSetup const& c) {}
146  void EDFilterBase::doEndRun_(Run const& rp, EventSetup const& c) {}
149 
154 
157  desc.setUnknown();
158  descriptions.addDefault(desc);
159  }
160 
162 
163  static const std::string kBaseType("EDFilter");
164 
166 
167  } // namespace one
168 } // namespace edm
virtual void beginJob()
Definition: EDFilterBase.h:108
static const std::string kBaseType("EDAnalyzer")
void setProducer(ProducerBase const *iProducer)
Definition: Run.cc:70
void setConsumer(EDConsumerBase const *iConsumer)
SharedResourcesAcquirer resourcesAcquirer_
Definition: EDFilterBase.h:133
virtual void doEndRunProduce_(Run &rp, EventSetup const &c)
virtual SharedResourcesAcquirer createAcquirer()
Definition: EDFilterBase.cc:62
virtual void doBeginRun_(Run const &rp, EventSetup const &c)
virtual void doEndLuminosityBlockProduce_(LuminosityBlock &lbp, EventSetup const &c)
static void fillDescriptions(ConfigurationDescriptions &descriptions)
virtual void preallocLumis(unsigned int)
Definition: EDFilterBase.cc:83
virtual void doEndLuminosityBlock_(LuminosityBlock const &lbp, EventSetup const &c)
void setConsumer(EDConsumerBase const *iConsumer)
Definition: Event.cc:37
void doEndLuminosityBlock(LuminosityBlockPrincipal const &lbp, EventSetupImpl const &c, ModuleCallingContext const *)
virtual SerialTaskQueue * globalLuminosityBlocksQueue()
Definition: EDFilterBase.cc:68
void addDefault(ParameterSetDescription const &psetDescription)
std::vector< BranchID > previousParentage_
Definition: EDFilterBase.h:130
void doRespondToOpenInputFile(FileBlock const &fb)
void doBeginLuminosityBlock(LuminosityBlockPrincipal const &lbp, EventSetupImpl const &c, ModuleCallingContext const *)
void edmodule_mightGet_config(ConfigurationDescriptions &iDesc)
virtual void endJob()
Definition: EDFilterBase.h:109
static void prevalidate(ConfigurationDescriptions &descriptions)
virtual void preallocThreads(unsigned int)
Definition: EDFilterBase.h:111
void doBeginRun(RunPrincipal const &rp, EventSetupImpl const &c, ModuleCallingContext const *)
Definition: EDFilterBase.cc:85
void doEndRun(RunPrincipal const &rp, EventSetupImpl const &c, ModuleCallingContext const *)
Definition: EDFilterBase.cc:96
virtual void doBeginLuminosityBlock_(LuminosityBlock const &lbp, EventSetup const &c)
virtual SerialTaskQueue * globalRunsQueue()
Definition: EDFilterBase.cc:67
virtual void doBeginRunProduce_(Run &rp, EventSetup const &c)
void doRespondToCloseInputFile(FileBlock const &fb)
void setProducer(ProducerBase const *iProd, std::vector< BranchID > *previousParentage, std::vector< BranchID > *gotBranchIDsFromAcquire=0)
Definition: Event.cc:55
virtual void doEndRun_(Run const &rp, EventSetup const &c)
bool doEvent(EventPrincipal const &ep, EventSetupImpl const &c, ActivityRegistry *, ModuleCallingContext const *)
Definition: EDFilterBase.cc:46
virtual void doBeginLuminosityBlockProduce_(LuminosityBlock &lbp, EventSetup const &c)
void setProducer(ProducerBase const *iProducer)
ParentageID previousParentageId_
Definition: EDFilterBase.h:131
static const std::string & baseType()
void setSharedResourcesAcquirer(SharedResourcesAcquirer *iResourceAcquirer)
Definition: Event.cc:43
HLT enums.
ModuleDescription moduleDescription_
Definition: EDFilterBase.h:129
void commit_(P &iPrincipal)
Definition: ProducerBase.h:111
void setConsumer(EDConsumerBase const *iConsumer)
Definition: Run.h:51
virtual bool filter(Event &, EventSetup const &)=0
void doPreallocate(PreallocationConfiguration const &)
Definition: EDFilterBase.cc:78
Definition: Run.h:45
ESProxyIndex const * esGetTokenIndices(edm::Transition iTrans) const