CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
EDFilterBase.h
Go to the documentation of this file.
1 #ifndef FWCore_Framework_global_EDFilterBase_h
2 #define FWCore_Framework_global_EDFilterBase_h
3 // -*- C++ -*-
4 //
5 // Package: FWCore/Framework
6 // Class : EDFilterBase
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
30 
31 // forward declarations
32 
33 namespace edm {
34  class ModuleCallingContext;
35  class PreallocationConfiguration;
36  class StreamID;
37  class ActivityRegistry;
38  class ProductRegistry;
39  class ThinnedAssociationsHelper;
40 
41  namespace maker {
42  template<typename T> class ModuleHolderT;
43  }
44 
45  namespace global {
46 
47  class EDFilterBase : public ProducerBase, public EDConsumerBase
48  {
49 
50  public:
51  template <typename T> friend class edm::maker::ModuleHolderT;
52  template <typename T> friend class edm::WorkerT;
54 
55  EDFilterBase();
56  virtual ~EDFilterBase();
57 
58  static void fillDescriptions(ConfigurationDescriptions& descriptions);
59  static void prevalidate(ConfigurationDescriptions& descriptions);
60  static const std::string& baseType();
61 
62  // Warning: the returned moduleDescription will be invalid during construction
64 
65  private:
66  bool doEvent(EventPrincipal& ep, EventSetup const& c,
68  ModuleCallingContext const*);
70  void doBeginJob();
71  void doEndJob();
72 
73  void doBeginStream(StreamID id);
74  void doEndStream(StreamID id);
75  void doStreamBeginRun(StreamID id,
76  RunPrincipal& ep,
77  EventSetup const& c,
78  ModuleCallingContext const*);
79  void doStreamEndRun(StreamID id,
80  RunPrincipal& ep,
81  EventSetup const& c,
82  ModuleCallingContext const*);
85  EventSetup const& c,
86  ModuleCallingContext const*);
89  EventSetup const& c,
90  ModuleCallingContext const*);
91 
92 
93  void doBeginRun(RunPrincipal& rp, EventSetup const& c,
94  ModuleCallingContext const*);
95  void doEndRun(RunPrincipal& rp, EventSetup const& c,
96  ModuleCallingContext const*);
98  ModuleCallingContext const*);
100  ModuleCallingContext const*);
101 
103  void doPostForkReacquireResources(unsigned int iChildIndex, unsigned int iNumberOfChildren);
104 
105  //For now, the following are just dummy implemenations with no ability for users to override
110 
112  registerProducts(module, reg, moduleDescription_);
113  }
114  std::string workerType() const {return "WorkerT<EDProducer>";}
115 
116  virtual bool filter(StreamID, Event&, EventSetup const&) const= 0;
117  virtual void beginJob() {}
118  virtual void endJob(){}
119 
120  virtual void preForkReleaseResources() {}
121  virtual void postForkReacquireResources(unsigned int /*iChildIndex*/, unsigned int /*iNumberOfChildren*/) {}
122 
123  virtual void preallocStreams(unsigned int);
124  virtual void doBeginStream_(StreamID id);
125  virtual void doEndStream_(StreamID id);
126  virtual void doStreamBeginRun_(StreamID id, Run const& rp, EventSetup const& c);
127  virtual void doStreamEndRun_(StreamID id, Run const& rp, EventSetup const& c);
128  virtual void doStreamEndRunSummary_(StreamID id, Run const& rp, EventSetup const& c);
129  virtual void doStreamBeginLuminosityBlock_(StreamID id, LuminosityBlock const& lbp, EventSetup const& c);
130  virtual void doStreamEndLuminosityBlock_(StreamID id, LuminosityBlock const& lbp, EventSetup const& c);
131  virtual void doStreamEndLuminosityBlockSummary_(StreamID id, LuminosityBlock const& lbp, EventSetup const& c);
132 
133  virtual void doBeginRun_(Run const& rp, EventSetup const& c);
134  virtual void doBeginRunSummary_(Run const& rp, EventSetup const& c);
135  virtual void doEndRunSummary_(Run const& rp, EventSetup const& c);
136  virtual void doEndRun_(Run const& rp, EventSetup const& c);
137  virtual void doBeginLuminosityBlock_(LuminosityBlock const& lbp, EventSetup const& c);
138  virtual void doBeginLuminosityBlockSummary_(LuminosityBlock const& rp, EventSetup const& c);
139  virtual void doEndLuminosityBlockSummary_(LuminosityBlock const& lb, EventSetup const& c);
140  virtual void doEndLuminosityBlock_(LuminosityBlock const& lb, EventSetup const& c);
141 
142  virtual void doBeginRunProduce_(Run& rp, EventSetup const& c);
143  virtual void doEndRunProduce_(Run& rp, EventSetup const& c);
144  virtual void doBeginLuminosityBlockProduce_(LuminosityBlock& lbp, EventSetup const& c);
145  virtual void doEndLuminosityBlockProduce_(LuminosityBlock& lbp, EventSetup const& c);
146 
147 
150  }
152  std::unique_ptr<std::vector<BranchID>[]> previousParentages_; //Per stream in the future?
153  std::unique_ptr<ParentageID[]> previousParentageIds_;
154  };
155 
156  }
157 }
158 
159 #endif
void doPreallocate(PreallocationConfiguration const &)
Definition: EDFilterBase.cc:64
virtual void doStreamBeginRun_(StreamID id, Run const &rp, EventSetup const &c)
virtual void doStreamEndLuminosityBlock_(StreamID id, LuminosityBlock const &lbp, EventSetup const &c)
void registerProductsAndCallbacks(EDFilterBase *module, ProductRegistry *reg)
Definition: EDFilterBase.h:111
virtual bool filter(StreamID, Event &, EventSetup const &) const =0
virtual void doEndRunProduce_(Run &rp, EventSetup const &c)
void doRegisterThinnedAssociations(ProductRegistry const &, ThinnedAssociationsHelper &)
Definition: EDFilterBase.h:108
void doRespondToCloseInputFile(FileBlock const &fb)
virtual void doStreamEndRun_(StreamID id, Run const &rp, EventSetup const &c)
void doPostForkReacquireResources(unsigned int iChildIndex, unsigned int iNumberOfChildren)
bool doEvent(EventPrincipal &ep, EventSetup const &c, ActivityRegistry *, ModuleCallingContext const *)
Definition: EDFilterBase.cc:51
void doStreamEndLuminosityBlock(StreamID id, LuminosityBlockPrincipal &ep, EventSetup const &c, ModuleCallingContext const *)
void registerProducts(ProducerBase *, ProductRegistry *, ModuleDescription const &)
Definition: ProducerBase.cc:60
static void fillDescriptions(ConfigurationDescriptions &descriptions)
virtual void doStreamBeginLuminosityBlock_(StreamID id, LuminosityBlock const &lbp, EventSetup const &c)
virtual void doStreamEndLuminosityBlockSummary_(StreamID id, LuminosityBlock const &lbp, EventSetup const &c)
void doEndLuminosityBlock(LuminosityBlockPrincipal &lbp, EventSetup const &c, ModuleCallingContext const *)
virtual void preForkReleaseResources()
Definition: EDFilterBase.h:120
virtual void doBeginLuminosityBlockSummary_(LuminosityBlock const &rp, EventSetup const &c)
void doBeginLuminosityBlock(LuminosityBlockPrincipal &lbp, EventSetup const &c, ModuleCallingContext const *)
ModuleDescription moduleDescription_
Definition: EDFilterBase.h:151
virtual void doBeginLuminosityBlockProduce_(LuminosityBlock &lbp, EventSetup const &c)
void setModuleDescription(ModuleDescription const &md)
Definition: EDFilterBase.h:148
virtual void doEndLuminosityBlock_(LuminosityBlock const &lb, EventSetup const &c)
static const std::string & baseType()
ModuleDescription const & moduleDescription() const
Definition: EDFilterBase.h:63
std::unique_ptr< std::vector< BranchID >[]> previousParentages_
Definition: EDFilterBase.h:152
void doStreamBeginRun(StreamID id, RunPrincipal &ep, EventSetup const &c, ModuleCallingContext const *)
void doEndRun(RunPrincipal &rp, EventSetup const &c, ModuleCallingContext const *)
Definition: EDFilterBase.cc:94
virtual void doBeginLuminosityBlock_(LuminosityBlock const &lbp, EventSetup const &c)
virtual void doStreamEndRunSummary_(StreamID id, Run const &rp, EventSetup const &c)
void doStreamEndRun(StreamID id, RunPrincipal &ep, EventSetup const &c, ModuleCallingContext const *)
virtual void doBeginRunProduce_(Run &rp, EventSetup const &c)
std::unique_ptr< ParentageID[]> previousParentageIds_
Definition: EDFilterBase.h:153
void doStreamBeginLuminosityBlock(StreamID id, LuminosityBlockPrincipal &ep, EventSetup const &c, ModuleCallingContext const *)
virtual void doEndRunSummary_(Run const &rp, EventSetup const &c)
void doEndStream(StreamID id)
void doBeginRun(RunPrincipal &rp, EventSetup const &c, ModuleCallingContext const *)
Definition: EDFilterBase.cc:82
void doRespondToOpenInputFile(FileBlock const &fb)
std::string workerType() const
Definition: EDFilterBase.h:114
virtual void doEndLuminosityBlockSummary_(LuminosityBlock const &lb, EventSetup const &c)
static void prevalidate(ConfigurationDescriptions &descriptions)
virtual void postForkReacquireResources(unsigned int, unsigned int)
Definition: EDFilterBase.h:121
virtual void doEndRun_(Run const &rp, EventSetup const &c)
virtual void doBeginRunSummary_(Run const &rp, EventSetup const &c)
virtual void doBeginRun_(Run const &rp, EventSetup const &c)
virtual void doEndLuminosityBlockProduce_(LuminosityBlock &lbp, EventSetup const &c)
virtual void preallocStreams(unsigned int)
virtual void doBeginStream_(StreamID id)
void doBeginStream(StreamID id)
Definition: vlib.h:208
Definition: Run.h:43
virtual void doEndStream_(StreamID id)