CMS 3D CMS Logo

EDFilterBase.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: FWCore/Framework
4 // Class : global::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
25 
28 
29 //
30 // constants, enums and typedefs
31 //
32 namespace edm {
33 
34  class WaitingTaskWithArenaHolder;
35 
36  namespace global {
37  //
38  // static data member definitions
39  //
40 
41  //
42  // constructors and destructor
43  //
45  : ProducerBase(), moduleDescription_(), previousParentages_(), previousParentageIds_() {}
46 
48 
50  EventSetupImpl const& ci,
51  ActivityRegistry* act,
52  ModuleCallingContext const* mcc) {
53  Event e(ep, moduleDescription_, mcc);
54  e.setConsumer(this);
55  const auto streamIndex = e.streamID().value();
56  e.setProducer(
57  this, &previousParentages_[streamIndex], hasAcquire() ? &gotBranchIDsFromAcquire_[streamIndex] : nullptr);
58  EventSignalsSentry sentry(act, mcc);
59  const EventSetup c{ci, static_cast<unsigned int>(Transition::Event), esGetTokenIndices(Transition::Event)};
60  bool returnValue = this->filter(e.streamID(), e, c);
61  commit_(e, &previousParentageIds_[streamIndex]);
62  return returnValue;
63  }
64 
66  EventSetupImpl const& ci,
67  ActivityRegistry* act,
68  ModuleCallingContext const* mcc,
70  Event e(ep, moduleDescription_, mcc);
71  e.setConsumer(this);
72  const auto streamIndex = e.streamID().value();
73  e.setProducerForAcquire(this, nullptr, gotBranchIDsFromAcquire_[streamIndex]);
74  EventAcquireSignalsSentry sentry(act, mcc);
75  const EventSetup c{ci, static_cast<unsigned int>(Transition::Event), esGetTokenIndices(Transition::Event)};
76  this->doAcquire_(e.streamID(), e, c, holder);
77  }
78 
80  const auto nStreams = iPrealloc.numberOfStreams();
81  previousParentages_.reset(new std::vector<BranchID>[nStreams]);
82  if (hasAcquire()) {
83  gotBranchIDsFromAcquire_.reset(new std::vector<BranchID>[nStreams]);
84  }
85  previousParentageIds_.reset(new ParentageID[nStreams]);
86  preallocStreams(nStreams);
88  preallocate(iPrealloc);
89  }
90 
91  void EDFilterBase::doBeginJob() { this->beginJob(); }
92 
93  void EDFilterBase::doEndJob() { this->endJob(); }
94 
96  Run r(rp, moduleDescription_, mcc, false);
97  r.setConsumer(this);
98  Run const& cnstR = r;
99  const EventSetup c{ci, static_cast<unsigned int>(Transition::BeginRun), esGetTokenIndices(Transition::BeginRun)};
100  this->doBeginRun_(cnstR, c);
101  this->doBeginRunSummary_(cnstR, c);
102  r.setProducer(this);
103  this->doBeginRunProduce_(r, c);
104  commit_(r);
105  }
106 
108  Run r(rp, moduleDescription_, mcc, true);
109  r.setConsumer(this);
110  r.setProducer(this);
111  Run const& cnstR = r;
112  const EventSetup c{ci, static_cast<unsigned int>(Transition::EndRun), esGetTokenIndices(Transition::EndRun)};
113  this->doEndRunProduce_(r, c);
114  this->doEndRunSummary_(r, c);
115  this->doEndRun_(cnstR, c);
116  commit_(r);
117  }
118 
120  EventSetupImpl const& ci,
121  ModuleCallingContext const* mcc) {
122  LuminosityBlock lb(lbp, moduleDescription_, mcc, false);
123  lb.setConsumer(this);
124  LuminosityBlock const& cnstLb = lb;
125  const EventSetup c{ci,
126  static_cast<unsigned int>(Transition::BeginLuminosityBlock),
128  this->doBeginLuminosityBlock_(cnstLb, c);
129  this->doBeginLuminosityBlockSummary_(cnstLb, c);
130  lb.setProducer(this);
132  commit_(lb);
133  }
134 
136  EventSetupImpl const& ci,
137  ModuleCallingContext const* mcc) {
138  LuminosityBlock lb(lbp, moduleDescription_, mcc, true);
139  lb.setConsumer(this);
140  lb.setProducer(this);
141  LuminosityBlock const& cnstLb = lb;
142  const EventSetup c{ci,
143  static_cast<unsigned int>(Transition::EndLuminosityBlock),
145  this->doEndLuminosityBlockProduce_(lb, c);
146  this->doEndLuminosityBlockSummary_(cnstLb, c);
147  this->doEndLuminosityBlock_(cnstLb, c);
148  commit_(lb);
149  }
150 
154  RunPrincipal const& rp,
155  EventSetupImpl const& ci,
156  ModuleCallingContext const* mcc) {
157  Run r(rp, moduleDescription_, mcc, false);
158  r.setConsumer(this);
159  const EventSetup c{ci, static_cast<unsigned int>(Transition::BeginRun), esGetTokenIndices(Transition::BeginRun)};
160  this->doStreamBeginRun_(id, r, c);
161  }
163  RunPrincipal const& rp,
164  EventSetupImpl const& ci,
165  ModuleCallingContext const* mcc) {
166  Run r(rp, moduleDescription_, mcc, true);
167  r.setConsumer(this);
168  const EventSetup c{ci, static_cast<unsigned int>(Transition::EndRun), esGetTokenIndices(Transition::EndRun)};
169  this->doStreamEndRun_(id, r, c);
170  this->doStreamEndRunSummary_(id, r, c);
171  }
173  LuminosityBlockPrincipal const& lbp,
174  EventSetupImpl const& ci,
175  ModuleCallingContext const* mcc) {
176  LuminosityBlock lb(lbp, moduleDescription_, mcc, false);
177  lb.setConsumer(this);
178  const EventSetup c{ci,
179  static_cast<unsigned int>(Transition::BeginLuminosityBlock),
181  this->doStreamBeginLuminosityBlock_(id, lb, c);
182  }
183 
185  LuminosityBlockPrincipal const& lbp,
186  EventSetupImpl const& ci,
187  ModuleCallingContext const* mcc) {
188  LuminosityBlock lb(lbp, moduleDescription_, mcc, true);
189  lb.setConsumer(this);
190  const EventSetup c{ci,
191  static_cast<unsigned int>(Transition::EndLuminosityBlock),
193  this->doStreamEndLuminosityBlock_(id, lb, c);
194  this->doStreamEndLuminosityBlockSummary_(id, lb, c);
195  }
196 
198  //respondToOpenInputFile(fb);
199  }
200 
202  //respondToCloseInputFile(fb);
203  }
204 
205  void EDFilterBase::preallocStreams(unsigned int) {}
206  void EDFilterBase::preallocLumis(unsigned int) {}
210  void EDFilterBase::doStreamBeginRun_(StreamID id, Run const& rp, EventSetup const& c) {}
211  void EDFilterBase::doStreamEndRun_(StreamID id, Run const& rp, EventSetup const& c) {}
216  LuminosityBlock const& lbp,
217  EventSetup const& c) {}
218 
219  void EDFilterBase::doBeginRun_(Run const& rp, EventSetup const& c) {}
220  void EDFilterBase::doEndRun_(Run const& rp, EventSetup const& c) {}
222  void EDFilterBase::doEndRunSummary_(Run const& rp, EventSetup const& c) {}
223 
228 
233 
235 
238  desc.setUnknown();
239  descriptions.addDefault(desc);
240  }
241 
243 
244  static const std::string kBaseType("EDFilter");
245 
247 
248  } // namespace global
249 } // namespace edm
static const std::string kBaseType("EDAnalyzer")
void setProducerForAcquire(ProducerBase const *iProd, std::vector< BranchID > *previousParentage, std::vector< BranchID > &gotBranchIDsFromAcquire)
Definition: Event.cc:81
void doPreallocate(PreallocationConfiguration const &)
Definition: EDFilterBase.cc:79
virtual void doStreamBeginRun_(StreamID id, Run const &rp, EventSetup const &c)
virtual void doStreamEndLuminosityBlock_(StreamID id, LuminosityBlock const &lbp, EventSetup const &c)
void setProducer(ProducerBase const *iProducer)
Definition: Run.cc:70
void setConsumer(EDConsumerBase const *iConsumer)
bool doEvent(EventPrincipal const &, EventSetupImpl const &, ActivityRegistry *, ModuleCallingContext const *)
Definition: EDFilterBase.cc:49
virtual void doEndRunProduce_(Run &rp, EventSetup const &c)
void doRespondToCloseInputFile(FileBlock const &fb)
virtual void doStreamEndRun_(StreamID id, Run const &rp, EventSetup const &c)
void doStreamEndRun(StreamID id, RunPrincipal const &ep, EventSetupImpl const &c, ModuleCallingContext const *)
static void fillDescriptions(ConfigurationDescriptions &descriptions)
virtual void preallocate(PreallocationConfiguration const &)
void doBeginRun(RunPrincipal const &rp, EventSetupImpl const &c, ModuleCallingContext const *)
Definition: EDFilterBase.cc:95
virtual bool filter(StreamID, Event &, EventSetup const &) const =0
virtual void doStreamBeginLuminosityBlock_(StreamID id, LuminosityBlock const &lbp, EventSetup const &c)
virtual void doStreamEndLuminosityBlockSummary_(StreamID id, LuminosityBlock const &lbp, EventSetup const &c)
void setConsumer(EDConsumerBase const *iConsumer)
Definition: Event.cc:37
void doStreamBeginLuminosityBlock(StreamID id, LuminosityBlockPrincipal const &ep, EventSetupImpl const &c, ModuleCallingContext const *)
virtual void doBeginLuminosityBlockSummary_(LuminosityBlock const &rp, EventSetup const &c)
void addDefault(ParameterSetDescription const &psetDescription)
ModuleDescription moduleDescription_
Definition: EDFilterBase.h:157
void edmodule_mightGet_config(ConfigurationDescriptions &iDesc)
virtual void doBeginLuminosityBlockProduce_(LuminosityBlock &lbp, EventSetup const &c)
virtual void doEndLuminosityBlock_(LuminosityBlock const &lb, EventSetup const &c)
virtual bool hasAcquire() const
Definition: EDFilterBase.h:151
static const std::string & baseType()
std::unique_ptr< std::vector< BranchID >[]> previousParentages_
Definition: EDFilterBase.h:158
virtual void doAcquire_(StreamID, Event const &, edm::EventSetup const &, WaitingTaskWithArenaHolder &)
void doEndRun(RunPrincipal const &rp, EventSetupImpl const &c, ModuleCallingContext const *)
virtual void doBeginLuminosityBlock_(LuminosityBlock const &lbp, EventSetup const &c)
virtual void doStreamEndRunSummary_(StreamID id, Run const &rp, EventSetup const &c)
virtual void doBeginRunProduce_(Run &rp, EventSetup const &c)
std::unique_ptr< ParentageID[]> previousParentageIds_
Definition: EDFilterBase.h:160
unsigned int value() const
Definition: StreamID.h:42
std::unique_ptr< std::vector< BranchID >[]> gotBranchIDsFromAcquire_
Definition: EDFilterBase.h:159
virtual void doEndRunSummary_(Run const &rp, EventSetup const &c)
void doEndStream(StreamID id)
void setProducer(ProducerBase const *iProd, std::vector< BranchID > *previousParentage, std::vector< BranchID > *gotBranchIDsFromAcquire=0)
Definition: Event.cc:55
void doRespondToOpenInputFile(FileBlock const &fb)
virtual void doEndLuminosityBlockSummary_(LuminosityBlock const &lb, EventSetup const &c)
static void prevalidate(ConfigurationDescriptions &descriptions)
void setProducer(ProducerBase const *iProducer)
virtual void doEndRun_(Run const &rp, EventSetup const &c)
virtual void preallocLumis(unsigned int)
HLT enums.
StreamID streamID() const
Definition: Event.h:95
virtual void doBeginRunSummary_(Run const &rp, EventSetup const &c)
void doEndLuminosityBlock(LuminosityBlockPrincipal const &lbp, EventSetupImpl const &c, ModuleCallingContext const *)
virtual void doBeginRun_(Run const &rp, EventSetup const &c)
void doBeginLuminosityBlock(LuminosityBlockPrincipal const &lbp, EventSetupImpl const &c, ModuleCallingContext const *)
virtual void doEndLuminosityBlockProduce_(LuminosityBlock &lbp, EventSetup const &c)
virtual void preallocStreams(unsigned int)
void commit_(P &iPrincipal)
Definition: ProducerBase.h:111
virtual void doBeginStream_(StreamID id)
void doAcquire(EventPrincipal const &, EventSetupImpl const &, ActivityRegistry *, ModuleCallingContext const *, WaitingTaskWithArenaHolder &)
Definition: EDFilterBase.cc:65
void doBeginStream(StreamID id)
void setConsumer(EDConsumerBase const *iConsumer)
Definition: Run.h:51
void doStreamBeginRun(StreamID id, RunPrincipal const &ep, EventSetupImpl const &c, ModuleCallingContext const *)
void doStreamEndLuminosityBlock(StreamID id, LuminosityBlockPrincipal const &ep, EventSetupImpl const &c, ModuleCallingContext const *)
Definition: Run.h:45
virtual void doEndStream_(StreamID id)
ESProxyIndex const * esGetTokenIndices(edm::Transition iTrans) const