CMS 3D CMS Logo

EDProducerBase.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: FWCore/Framework
4 // Class : global::EDProducerBase
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(),
46  moduleDescription_(),
47  previousParentages_(),
48  gotBranchIDsFromAcquire_(),
49  previousParentageIds_() {}
50 
52 
54  EventSetupImpl const& c,
55  ActivityRegistry* act,
56  ModuleCallingContext const* mcc) {
57  Event e(ep, moduleDescription_, mcc);
58  e.setConsumer(this);
59  const auto streamIndex = e.streamID().value();
60  e.setProducer(
61  this, &previousParentages_[streamIndex], hasAcquire() ? &gotBranchIDsFromAcquire_[streamIndex] : nullptr);
62  EventSignalsSentry sentry(act, mcc);
63  this->produce(
64  e.streamID(),
65  e,
66  EventSetup{c, static_cast<unsigned int>(Transition::Event), esGetTokenIndices(Transition::Event), false});
67  commit_(e, &previousParentageIds_[streamIndex]);
68  return true;
69  }
70 
72  EventSetupImpl const& ci,
73  ActivityRegistry* act,
74  ModuleCallingContext const* mcc,
76  Event e(ep, moduleDescription_, mcc);
77  e.setConsumer(this);
78  const auto streamIndex = e.streamID().value();
79  e.setProducerForAcquire(this, nullptr, gotBranchIDsFromAcquire_[streamIndex]);
80  EventAcquireSignalsSentry sentry(act, mcc);
81  const EventSetup c{ci, static_cast<unsigned int>(Transition::Event), esGetTokenIndices(Transition::Event), false};
82  this->doAcquire_(e.streamID(), e, c, holder);
83  }
84 
86  auto const nStreams = iPrealloc.numberOfStreams();
87  previousParentages_.reset(new std::vector<BranchID>[nStreams]);
88  if (hasAcquire()) {
89  gotBranchIDsFromAcquire_.reset(new std::vector<BranchID>[nStreams]);
90  }
91  previousParentageIds_.reset(new ParentageID[nStreams]);
92  preallocStreams(nStreams);
95  preallocate(iPrealloc);
96  }
97 
99 
100  void EDProducerBase::doEndJob() { this->endJob(); }
101 
103  Run r(rp, moduleDescription_, mcc, false);
104  r.setConsumer(this);
105  Run const& cnstR = r;
106  const EventSetup c{
107  ci, static_cast<unsigned int>(Transition::BeginRun), esGetTokenIndices(Transition::BeginRun), false};
108  this->doBeginRun_(cnstR, c);
109  this->doBeginRunSummary_(cnstR, c);
110  r.setProducer(this);
111  this->doBeginRunProduce_(r, c);
112  commit_(r);
113  }
114 
116  Run r(rp, moduleDescription_, mcc, true);
117  r.setConsumer(this);
118  r.setProducer(this);
119  Run const& cnstR = r;
120  const EventSetup c{
121  ci, static_cast<unsigned int>(Transition::EndRun), esGetTokenIndices(Transition::EndRun), false};
122  this->doEndRunSummary_(r, c);
123  this->doEndRunProduce_(r, c);
124  this->doEndRun_(cnstR, c);
125  commit_(r);
126  }
127 
129  EventSetupImpl const& ci,
130  ModuleCallingContext const* mcc) {
131  LuminosityBlock lb(lbp, moduleDescription_, mcc, false);
132  lb.setConsumer(this);
133  LuminosityBlock const& cnstLb = lb;
134  const EventSetup c{ci,
135  static_cast<unsigned int>(Transition::BeginLuminosityBlock),
137  false};
138  this->doBeginLuminosityBlock_(cnstLb, c);
139  this->doBeginLuminosityBlockSummary_(cnstLb, c);
140  lb.setProducer(this);
142  commit_(lb);
143  }
144 
146  EventSetupImpl const& ci,
147  ModuleCallingContext const* mcc) {
148  LuminosityBlock lb(lbp, moduleDescription_, mcc, true);
149  lb.setConsumer(this);
150  lb.setProducer(this);
151  LuminosityBlock const& cnstLb = lb;
152  const EventSetup c{ci,
153  static_cast<unsigned int>(Transition::EndLuminosityBlock),
155  false};
156  this->doEndLuminosityBlockSummary_(cnstLb, c);
157  this->doEndLuminosityBlockProduce_(lb, c);
158  this->doEndLuminosityBlock_(cnstLb, c);
159  commit_(lb);
160  }
161 
165  RunPrincipal const& rp,
166  EventSetupImpl const& c,
167  ModuleCallingContext const* mcc) {
168  Run r(rp, moduleDescription_, mcc, false);
169  r.setConsumer(this);
170  this->doStreamBeginRun_(
171  id,
172  r,
173  EventSetup{
174  c, static_cast<unsigned int>(Transition::BeginRun), esGetTokenIndices(Transition::BeginRun), false});
175  }
177  RunPrincipal const& rp,
178  EventSetupImpl const& ci,
179  ModuleCallingContext const* mcc) {
180  Run r(rp, moduleDescription_, mcc, true);
181  r.setConsumer(this);
182  const EventSetup c{
183  ci, static_cast<unsigned int>(Transition::EndRun), esGetTokenIndices(Transition::EndRun), false};
184  this->doStreamEndRun_(id, r, c);
185  this->doStreamEndRunSummary_(id, r, c);
186  }
188  LuminosityBlockPrincipal const& lbp,
189  EventSetupImpl const& c,
190  ModuleCallingContext const* mcc) {
191  LuminosityBlock lb(lbp, moduleDescription_, mcc, false);
192  lb.setConsumer(this);
194  lb,
195  EventSetup{c,
196  static_cast<unsigned int>(Transition::BeginLuminosityBlock),
198  false});
199  }
200 
202  LuminosityBlockPrincipal const& lbp,
203  EventSetupImpl const& ci,
204  ModuleCallingContext const* mcc) {
205  LuminosityBlock lb(lbp, moduleDescription_, mcc, true);
206  lb.setConsumer(this);
207  const EventSetup c{ci,
208  static_cast<unsigned int>(Transition::EndLuminosityBlock),
210  false};
211  this->doStreamEndLuminosityBlock_(id, lb, c);
212  this->doStreamEndLuminosityBlockSummary_(id, lb, c);
213  }
214 
216  //respondToOpenInputFile(fb);
217  }
218 
220  //respondToCloseInputFile(fb);
221  }
222 
223  void EDProducerBase::preallocStreams(unsigned int) {}
224  void EDProducerBase::preallocLumis(unsigned int) {}
230  void EDProducerBase::doStreamEndRun_(StreamID id, Run const& rp, EventSetup const& c) {}
235  LuminosityBlock const& lbp,
236  EventSetup const& c) {}
237 
238  void EDProducerBase::doBeginRun_(Run const& rp, EventSetup const& c) {}
239  void EDProducerBase::doEndRun_(Run const& rp, EventSetup const& c) {}
242 
247 
252 
254 
257  desc.setUnknown();
258  descriptions.addDefault(desc);
259  }
260 
262 
263  static const std::string kBaseType("EDProducer");
264 
266 
267  } // namespace global
268 } // namespace edm
static const std::string kBaseType("EDAnalyzer")
void setProducerForAcquire(ProducerBase const *iProd, std::vector< BranchID > *previousParentage, std::vector< BranchID > &gotBranchIDsFromAcquire)
Definition: Event.cc:90
ModuleDescription moduleDescription_
void setProducer(ProducerBase const *iProducer)
Definition: Run.cc:70
void setConsumer(EDConsumerBase const *iConsumer)
virtual void doEndRunSummary_(Run const &rp, EventSetup const &c)
virtual void doBeginLuminosityBlockProduce_(LuminosityBlock &lbp, EventSetup const &c)
virtual void doEndStream_(StreamID id)
virtual void doStreamBeginRun_(StreamID id, Run const &rp, EventSetup const &c)
void doBeginStream(StreamID id)
virtual void preallocate(PreallocationConfiguration const &)
virtual void doEndRun_(Run const &rp, EventSetup const &c)
std::unique_ptr< ParentageID[]> previousParentageIds_
void doEndLuminosityBlock(LuminosityBlockPrincipal const &lbp, EventSetupImpl const &c, ModuleCallingContext const *)
void doAcquire(EventPrincipal const &, EventSetupImpl const &, ActivityRegistry *, ModuleCallingContext const *, WaitingTaskWithArenaHolder &)
void doPreallocate(PreallocationConfiguration const &)
void setConsumer(EDConsumerBase const *iConsumer)
Definition: Event.cc:35
virtual void doAcquire_(StreamID, Event const &, edm::EventSetup const &, WaitingTaskWithArenaHolder &)
void doStreamEndRun(StreamID id, RunPrincipal const &ep, EventSetupImpl const &c, ModuleCallingContext const *)
virtual void doBeginStream_(StreamID id)
virtual void produce(StreamID, Event &, EventSetup const &) const =0
virtual void doEndLuminosityBlockProduce_(LuminosityBlock &lbp, EventSetup const &c)
virtual bool hasAcquire() const
static void prevalidate(ConfigurationDescriptions &descriptions)
virtual void preallocLumisSummary(unsigned int)
void addDefault(ParameterSetDescription const &psetDescription)
virtual void preallocStreams(unsigned int)
void doRespondToOpenInputFile(FileBlock const &fb)
virtual void doBeginRun_(Run const &rp, EventSetup const &c)
virtual void doStreamEndRun_(StreamID id, Run const &rp, EventSetup const &c)
void edmodule_mightGet_config(ConfigurationDescriptions &iDesc)
void doBeginLuminosityBlock(LuminosityBlockPrincipal const &lbp, EventSetupImpl const &c, ModuleCallingContext const *)
void doStreamBeginRun(StreamID id, RunPrincipal const &ep, EventSetupImpl const &c, ModuleCallingContext const *)
bool doEvent(EventPrincipal const &, EventSetupImpl const &, ActivityRegistry *, ModuleCallingContext const *)
std::unique_ptr< std::vector< BranchID >[]> previousParentages_
virtual void doStreamEndLuminosityBlock_(StreamID id, LuminosityBlock const &lbp, EventSetup const &c)
virtual void doEndLuminosityBlockSummary_(LuminosityBlock const &lb, EventSetup const &c)
virtual void preallocLumis(unsigned int)
static void fillDescriptions(ConfigurationDescriptions &descriptions)
static const std::string & baseType()
std::unique_ptr< std::vector< BranchID >[]> gotBranchIDsFromAcquire_
virtual void doBeginRunProduce_(Run &rp, EventSetup const &c)
unsigned int value() const
Definition: StreamID.h:42
virtual void doStreamEndRunSummary_(StreamID id, Run const &rp, EventSetup const &c)
void doEndRun(RunPrincipal const &rp, EventSetupImpl const &c, ModuleCallingContext const *)
virtual void doStreamBeginLuminosityBlock_(StreamID id, LuminosityBlock const &lbp, EventSetup const &c)
void setProducer(ProducerBase const *iProd, std::vector< BranchID > *previousParentage, std::vector< BranchID > *gotBranchIDsFromAcquire=0)
Definition: Event.cc:64
virtual void doBeginLuminosityBlockSummary_(LuminosityBlock const &rp, EventSetup const &c)
virtual void doEndLuminosityBlock_(LuminosityBlock const &lb, EventSetup const &c)
void setProducer(ProducerBase const *iProducer)
HLT enums.
StreamID streamID() const
Definition: Event.h:96
void doStreamEndLuminosityBlock(StreamID id, LuminosityBlockPrincipal const &ep, EventSetupImpl const &c, ModuleCallingContext const *)
virtual void doStreamEndLuminosityBlockSummary_(StreamID id, LuminosityBlock const &lbp, EventSetup const &c)
virtual void doBeginRunSummary_(Run const &rp, EventSetup const &c)
void commit_(P &iPrincipal)
Definition: ProducerBase.h:115
virtual void doBeginLuminosityBlock_(LuminosityBlock const &lbp, EventSetup const &c)
void doRespondToCloseInputFile(FileBlock const &fb)
void setConsumer(EDConsumerBase const *iConsumer)
Definition: Run.h:51
virtual void doEndRunProduce_(Run &rp, EventSetup const &c)
Definition: Run.h:45
void doBeginRun(RunPrincipal const &rp, EventSetupImpl const &c, ModuleCallingContext const *)
void doEndStream(StreamID id)
void doStreamBeginLuminosityBlock(StreamID id, LuminosityBlockPrincipal const &ep, EventSetupImpl const &c, ModuleCallingContext const *)
ESProxyIndex const * esGetTokenIndices(edm::Transition iTrans) const