CMS 3D CMS Logo

EDProducerBase.h
Go to the documentation of this file.
1 #ifndef FWCore_Framework_limited_EDProducerBase_h
2 #define FWCore_Framework_limited_EDProducerBase_h
3 // -*- C++ -*-
4 //
5 // Package: FWCore/Framework
6 // Class : EDProducerBase
7 //
16 //
17 // Original Author: Chris Jones
18 // Created: Thu, 18 Jul 2013 11:51:14 GMT
19 //
20 
21 // system include files
22 #include <memory>
23 
24 // user include files
31 
32 // forward declarations
33 
34 namespace edm {
35  class ModuleCallingContext;
36  class PreallocationConfiguration;
37  class StreamID;
38  class GlobalSchedule;
39  class ActivityRegistry;
40  class ProductRegistry;
41  class ThinnedAssociationsHelper;
42  class WaitingTask;
43 
44  namespace maker {
45  template<typename T> class ModuleHolderT;
46  }
47 
48  namespace limited {
49 
51  {
52 
53  public:
54  template <typename T> friend class edm::maker::ModuleHolderT;
55  template <typename T> friend class edm::WorkerT;
57 
58  friend class edm::GlobalSchedule;
59 
61  ~EDProducerBase() override;
62 
63  static void fillDescriptions(ConfigurationDescriptions& descriptions);
64  static void prevalidate(ConfigurationDescriptions& descriptions);
65  static const std::string& baseType();
66 
67  // Warning: the returned moduleDescription will be invalid during construction
68  ModuleDescription const& moduleDescription() const { return moduleDescription_; }
69 
70  virtual bool wantsGlobalRuns() const =0;
71  virtual bool wantsGlobalLuminosityBlocks() const =0;
72  virtual bool wantsStreamRuns() const =0;
73  virtual bool wantsStreamLuminosityBlocks() const =0;
74 
75  unsigned int concurrencyLimit() const { return queue_.concurrencyLimit(); }
76 
78  return queue_;
79  }
80  private:
81  bool doEvent(EventPrincipal const& ep, EventSetup const& c,
83  ModuleCallingContext const*);
84  void doPreallocate(PreallocationConfiguration const&);
85  void doBeginJob();
86  void doEndJob();
87 
88  void doBeginStream(StreamID id);
89  void doEndStream(StreamID id);
90  void doStreamBeginRun(StreamID id,
91  RunPrincipal const& ep,
92  EventSetup const& c,
93  ModuleCallingContext const*);
94  void doStreamEndRun(StreamID id,
95  RunPrincipal const& ep,
96  EventSetup const& c,
97  ModuleCallingContext const*);
98  void doStreamBeginLuminosityBlock(StreamID id,
99  LuminosityBlockPrincipal const& ep,
100  EventSetup const& c,
101  ModuleCallingContext const*);
102  void doStreamEndLuminosityBlock(StreamID id,
103  LuminosityBlockPrincipal const& ep,
104  EventSetup const& c,
105  ModuleCallingContext const*);
106 
107 
108  void doBeginRun(RunPrincipal const& rp, EventSetup const& c,
109  ModuleCallingContext const*);
110  void doEndRun(RunPrincipal const& rp, EventSetup const& c,
111  ModuleCallingContext const*);
112  void doBeginLuminosityBlock(LuminosityBlockPrincipal const& lbp, EventSetup const& c,
113  ModuleCallingContext const*);
114  void doEndLuminosityBlock(LuminosityBlockPrincipal const& lbp, EventSetup const& c,
115  ModuleCallingContext const*);
116 
117  //For now, the following are just dummy implemenations with no ability for users to override
118  void doRespondToOpenInputFile(FileBlock const& fb);
119  void doRespondToCloseInputFile(FileBlock const& fb);
122 
124  registerProducts(module, reg, moduleDescription_);
125  }
126  std::string workerType() const {return "WorkerT<EDProducer>";}
127 
128  virtual void produce(StreamID, Event&, EventSetup const&) const= 0;
129  //For now this is a placeholder
130  /*virtual*/ void preActionBeforeRunEventAsync(WaitingTask* iTask, ModuleCallingContext const& iModuleCallingContext, Principal const& iPrincipal) const {}
131 
132  virtual void beginJob() {}
133  virtual void endJob(){}
134 
135  virtual void preallocStreams(unsigned int);
136  virtual void preallocLumis(unsigned int);
137  virtual void preallocate(PreallocationConfiguration const&);
138  virtual void doBeginStream_(StreamID id);
139  virtual void doEndStream_(StreamID id);
140  virtual void doStreamBeginRun_(StreamID id, Run const& rp, EventSetup const& c);
141  virtual void doStreamEndRun_(StreamID id, Run const& rp, EventSetup const& c);
142  virtual void doStreamEndRunSummary_(StreamID id, Run const& rp, EventSetup const& c);
143  virtual void doStreamBeginLuminosityBlock_(StreamID id, LuminosityBlock const& lbp, EventSetup const& c);
144  virtual void doStreamEndLuminosityBlock_(StreamID id, LuminosityBlock const& lbp, EventSetup const& c);
145  virtual void doStreamEndLuminosityBlockSummary_(StreamID id, LuminosityBlock const& lbp, EventSetup const& c);
146 
147  virtual void doBeginRun_(Run const& rp, EventSetup const& c);
148  virtual void doBeginRunSummary_(Run const& rp, EventSetup const& c);
149  virtual void doEndRunSummary_(Run const& rp, EventSetup const& c);
150  virtual void doEndRun_(Run const& rp, EventSetup const& c);
151  virtual void doBeginLuminosityBlock_(LuminosityBlock const& lbp, EventSetup const& c);
152  virtual void doBeginLuminosityBlockSummary_(LuminosityBlock const& rp, EventSetup const& c);
153  virtual void doEndLuminosityBlockSummary_(LuminosityBlock const& lb, EventSetup const& c);
154  virtual void doEndLuminosityBlock_(LuminosityBlock const& lb, EventSetup const& c);
155 
156  virtual void doBeginRunProduce_(Run& rp, EventSetup const& c);
157  virtual void doEndRunProduce_(Run& rp, EventSetup const& c);
158  virtual void doBeginLuminosityBlockProduce_(LuminosityBlock& lbp, EventSetup const& c);
159  virtual void doEndLuminosityBlockProduce_(LuminosityBlock& lbp, EventSetup const& c);
160 
161  virtual bool hasAccumulator() const { return false; }
162 
163  bool hasAcquire() const { return false; }
164 
166  moduleDescription_ = md;
167  }
169  std::unique_ptr<std::vector<BranchID>[]> previousParentages_;
170  std::unique_ptr<ParentageID[]> previousParentageIds_;
172  };
173 
174  }
175 }
176 
177 #endif
void registerProductsAndCallbacks(EDProducerBase *module, ProductRegistry *reg)
void preActionBeforeRunEventAsync(WaitingTask *iTask, ModuleCallingContext const &iModuleCallingContext, Principal const &iPrincipal) const
ModuleDescription const & moduleDescription() const
void setModuleDescription(ModuleDescription const &md)
unsigned int concurrencyLimit() const
ModuleDescription moduleDescription_
std::string workerType() const
std::unique_ptr< ParentageID[]> previousParentageIds_
virtual bool hasAccumulator() const
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
HLT enums.
LimitedTaskQueue & queue()
void doRegisterThinnedAssociations(ProductRegistry const &, ThinnedAssociationsHelper &)
std::unique_ptr< std::vector< BranchID >[]> previousParentages_
Definition: vlib.h:208
Definition: Run.h:44