CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
EDProducerBase.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: FWCore/Framework
4 // Class : one::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
27 
30 
31 //
32 // constants, enums and typedefs
33 //
34 namespace edm {
35 
36  namespace one {
37  //
38  // static data member definitions
39  //
40 
41  //
42  // constructors and destructor
43  //
45  : ProducerBase(), moduleDescription_(), previousParentage_(), previousParentageId_() {}
46 
48 
50  ActivityRegistry* act,
51  ModuleCallingContext const* mcc) {
52  Event e(info, moduleDescription_, mcc);
53  e.setConsumer(this);
56  EventSignalsSentry sentry(act, mcc);
57  ESParentContext parentC(mcc);
58  const EventSetup c{
59  info, static_cast<unsigned int>(Transition::Event), esGetTokenIndices(Transition::Event), parentC, false};
60  this->produce(e, c);
62  return true;
63  }
64 
67  std::vector<std::shared_ptr<SerialTaskQueue>>(1, std::make_shared<SerialTaskQueue>())};
68  }
69 
72 
75 
76  this->beginJob();
77  }
78 
79  void EDProducerBase::doEndJob() { this->endJob(); }
80 
82  auto const nThreads = iPrealloc.numberOfThreads();
83  preallocThreads(nThreads);
85  }
86 
87  void EDProducerBase::preallocLumis(unsigned int){};
88 
90  ProcessBlock processBlock(pbp, moduleDescription_, mcc, false);
91  processBlock.setConsumer(this);
92  ProcessBlock const& constProcessBlock = processBlock;
93  this->doBeginProcessBlock_(constProcessBlock);
94  processBlock.setProducer(this);
95  this->doBeginProcessBlockProduce_(processBlock);
96  commit_(processBlock);
97  }
98 
100  ProcessBlock processBlock(pbp, moduleDescription_, mcc, false);
101  processBlock.setConsumer(this);
102  ProcessBlock const& constProcessBlock = processBlock;
103  this->doAccessInputProcessBlock_(constProcessBlock);
104  }
105 
107  ProcessBlock processBlock(pbp, moduleDescription_, mcc, true);
108  processBlock.setConsumer(this);
109  ProcessBlock const& constProcessBlock = processBlock;
110  this->doEndProcessBlock_(constProcessBlock);
111  processBlock.setProducer(this);
112  this->doEndProcessBlockProduce_(processBlock);
113  commit_(processBlock);
114  }
115 
117  Run r(info, moduleDescription_, mcc, false);
118  r.setConsumer(this);
119  Run const& cnstR = r;
120  ESParentContext parentC(mcc);
121  const EventSetup c{info,
122  static_cast<unsigned int>(Transition::BeginRun),
124  parentC,
125  false};
126  this->doBeginRun_(cnstR, c);
127  r.setProducer(this);
128  this->doBeginRunProduce_(r, c);
129  commit_(r);
130  }
131 
133  Run r(info, moduleDescription_, mcc, true);
134  r.setConsumer(this);
135  Run const& cnstR = r;
136  r.setProducer(this);
137  ESParentContext parentC(mcc);
138  const EventSetup c{
139  info, static_cast<unsigned int>(Transition::EndRun), esGetTokenIndices(Transition::EndRun), parentC, false};
140  this->doEndRunProduce_(r, c);
141  this->doEndRun_(cnstR, c);
142  commit_(r);
143  }
144 
146  LuminosityBlock lb(info, moduleDescription_, mcc, false);
147  lb.setConsumer(this);
148  LuminosityBlock const& cnstLb = lb;
149  ESParentContext parentC(mcc);
150  const EventSetup c{info,
151  static_cast<unsigned int>(Transition::BeginLuminosityBlock),
153  parentC,
154  false};
155  this->doBeginLuminosityBlock_(cnstLb, c);
156  lb.setProducer(this);
158  commit_(lb);
159  }
160 
162  LuminosityBlock lb(info, moduleDescription_, mcc, true);
163  lb.setConsumer(this);
164  lb.setProducer(this);
165  ESParentContext parentC(mcc);
166  const EventSetup c{info,
167  static_cast<unsigned int>(Transition::EndLuminosityBlock),
169  parentC,
170  false};
171  this->doEndLuminosityBlockProduce_(lb, c);
172  LuminosityBlock const& cnstLb = lb;
173  this->doEndLuminosityBlock_(cnstLb, c);
174  commit_(lb);
175  }
176 
180  void EDProducerBase::doBeginRun_(Run const& rp, EventSetup const& c) {}
181  void EDProducerBase::doEndRun_(Run const& rp, EventSetup const& c) {}
184 
191 
193 
196  desc.setUnknown();
197  descriptions.addDefault(desc);
198  }
199 
201 
202  static const std::string kBaseType("EDProducer");
203 
205 
206  } // namespace one
207 } // namespace edm
virtual SerialTaskQueue * globalLuminosityBlocksQueue()
static const std::string kBaseType("EDAnalyzer")
virtual void preallocLumis(unsigned int)
void setProducer(ProducerBase const *iProducer)
Definition: Run.cc:77
void doEndLuminosityBlock(LumiTransitionInfo const &, ModuleCallingContext const *)
static void fillDescriptions(ConfigurationDescriptions &descriptions)
static const TGPicture * info(bool iBackgroundIsBlack)
void setConsumer(EDConsumerBase const *iConsumer)
const edm::EventSetup & c
static const std::string & baseType()
virtual void doEndLuminosityBlock_(LuminosityBlock const &lbp, EventSetup const &c)
virtual void doBeginRunProduce_(Run &rp, EventSetup const &c)
virtual void doEndRunProduce_(Run &rp, EventSetup const &c)
void doAccessInputProcessBlock(ProcessBlockPrincipal const &, ModuleCallingContext const *)
virtual SerialTaskQueue * globalRunsQueue()
void setConsumer(EDConsumerBase const *iConsumer)
Definition: Event.cc:39
virtual void doBeginProcessBlockProduce_(ProcessBlock &)
virtual void doEndProcessBlockProduce_(ProcessBlock &)
ParentageID previousParentageId_
void setProducer(ProducerBase const *iProd, std::vector< BranchID > *previousParentage, std::vector< BranchID > *gotBranchIDsFromAcquire=nullptr)
Definition: Event.cc:68
void doEndRun(RunTransitionInfo const &, ModuleCallingContext const *)
void addDefault(ParameterSetDescription const &psetDescription)
void doBeginRun(RunTransitionInfo const &, ModuleCallingContext const *)
virtual void doEndLuminosityBlockProduce_(LuminosityBlock &lbp, EventSetup const &c)
bool doEvent(EventTransitionInfo const &, ActivityRegistry *, ModuleCallingContext const *)
void setConsumer(EDConsumerBase const *iConsumer)
Definition: ProcessBlock.h:53
virtual void clearInputProcessBlockCaches()
virtual void doEndRun_(Run const &rp, EventSetup const &c)
void edmodule_mightGet_config(ConfigurationDescriptions &iDesc)
virtual void doAccessInputProcessBlock_(ProcessBlock const &)
virtual void doBeginLuminosityBlock_(LuminosityBlock const &lbp, EventSetup const &c)
virtual void doBeginLuminosityBlockProduce_(LuminosityBlock &lbp, EventSetup const &c)
void doBeginProcessBlock(ProcessBlockPrincipal const &, ModuleCallingContext const *)
virtual void doEndProcessBlock_(ProcessBlock const &)
void doEndProcessBlock(ProcessBlockPrincipal const &, ModuleCallingContext const *)
SharedResourcesAcquirer resourcesAcquirer_
void setProducer(ProducerBase const *iProducer)
Definition: ProcessBlock.cc:13
void doPreallocate(PreallocationConfiguration const &)
void setProducer(ProducerBase const *iProducer)
virtual void preallocThreads(unsigned int)
void setSharedResourcesAcquirer(SharedResourcesAcquirer *iResourceAcquirer)
Definition: Event.cc:47
void doBeginLuminosityBlock(LumiTransitionInfo const &, ModuleCallingContext const *)
static void prevalidate(ConfigurationDescriptions &descriptions)
void commit_(P &iPrincipal)
Definition: ProducerBase.h:121
virtual void doBeginRun_(Run const &rp, EventSetup const &c)
virtual SharedResourcesAcquirer createAcquirer()
void setConsumer(EDConsumerBase const *iConsumer)
Definition: Run.h:52
virtual void doBeginProcessBlock_(ProcessBlock const &)
std::vector< BranchID > previousParentage_
ModuleDescription moduleDescription_
virtual void produce(Event &, EventSetup const &)=0
Definition: Run.h:45
ESProxyIndex const * esGetTokenIndices(edm::Transition iTrans) const