CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
EDAnalyzerBase.h
Go to the documentation of this file.
1 #ifndef FWCore_Framework_one_EDAnalyzerBase_h
2 #define FWCore_Framework_one_EDAnalyzerBase_h
3 // -*- C++ -*-
4 //
5 // Package: FWCore/Framework
6 // Class : one::EDAnalyzerBase
7 //
16 //
17 // Original Author: Chris Jones
18 // Created: Thu, 01 Aug 2013 21:21:21 GMT
19 //
20 
21 // system include files
22 
23 // user include files
29 
30 // forward declarations
31 namespace edm {
32 
33  class ModuleCallingContext;
34  class PreallocationConfiguration;
35  class ActivityRegistry;
36  class ProductRegistry;
37  class ThinnedAssociationsHelper;
38 
39  namespace maker {
40  template<typename T> class ModuleHolderT;
41  }
42 
43  namespace one {
44 
46  {
47 
48  public:
49  template <typename T> friend class edm::WorkerT;
50  template <typename T> friend class edm::maker::ModuleHolderT;
51 
53 
54 
56  virtual ~EDAnalyzerBase();
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 
66 
67  private:
68  bool doEvent(EventPrincipal const& ep, EventSetup const& c,
70  ModuleCallingContext const*);
72  void doBeginJob();
73  void doEndJob();
74 
75  void doBeginRun(RunPrincipal const& rp, EventSetup const& c,
76  ModuleCallingContext const*);
77  void doEndRun(RunPrincipal const& rp, EventSetup const& c,
78  ModuleCallingContext const*);
80  ModuleCallingContext const*);
82  ModuleCallingContext const*);
83 
85  void doPostForkReacquireResources(unsigned int iChildIndex, unsigned int iNumberOfChildren);
86 
87  //For now, the following are just dummy implemenations with no ability for users to override
92 
94  std::string workerType() const {return "WorkerT<EDAnalyzer>";}
95 
97  return resourcesAcquirer_;
98  }
99 
100  virtual void analyze(Event const&, EventSetup const&) = 0;
101  virtual void beginJob() {}
102  virtual void endJob(){}
103 
104  virtual void preForkReleaseResources() {}
105  virtual void postForkReacquireResources(unsigned int /*iChildIndex*/, unsigned int /*iNumberOfChildren*/) {}
106 
107 
108  virtual void doBeginRun_(Run const& rp, EventSetup const& c);
109  virtual void doEndRun_(Run const& rp, EventSetup const& c);
110  virtual void doBeginLuminosityBlock_(LuminosityBlock const& lbp, EventSetup const& c);
111  virtual void doEndLuminosityBlock_(LuminosityBlock const& lbp, EventSetup const& c);
112 
114 
116  moduleDescription_ = md;
117  }
119  std::function<void(BranchDescription const&)> callWhenNewProductsRegistered_;
120 
122  };
123  }
124 }
125 #endif
void doRespondToCloseInputFile(FileBlock const &fb)
void doEndRun(RunPrincipal const &rp, EventSetup const &c, ModuleCallingContext const *)
bool doEvent(EventPrincipal const &ep, EventSetup const &c, ActivityRegistry *, ModuleCallingContext const *)
static const std::string & baseType()
ModuleDescription const & moduleDescription() const
static void prevalidate(ConfigurationDescriptions &descriptions)
SharedResourcesAcquirer & sharedResourcesAcquirer()
static void fillDescriptions(ConfigurationDescriptions &descriptions)
virtual void postForkReacquireResources(unsigned int, unsigned int)
virtual void doEndRun_(Run const &rp, EventSetup const &c)
virtual void doEndLuminosityBlock_(LuminosityBlock const &lbp, EventSetup const &c)
virtual SharedResourcesAcquirer createAcquirer()
virtual void analyze(Event const &, EventSetup const &)=0
void registerProductsAndCallbacks(EDAnalyzerBase const *module, ProductRegistry *reg)
void doPreallocate(PreallocationConfiguration const &)
std::function< void(BranchDescription const &)> callWhenNewProductsRegistered_
helper::RootFunctionHelper< F, args >::root_function function(F &f)
Definition: rootFunction.h:14
void callWhenNewProductsRegistered(std::function< void(BranchDescription const &)> const &func)
void doBeginRun(RunPrincipal const &rp, EventSetup const &c, ModuleCallingContext const *)
EDAnalyzerBase ModuleType
SharedResourcesAcquirer resourcesAcquirer_
void doBeginLuminosityBlock(LuminosityBlockPrincipal const &lbp, EventSetup const &c, ModuleCallingContext const *)
std::string workerType() const
ModuleDescription moduleDescription_
void doRespondToOpenInputFile(FileBlock const &fb)
virtual void doBeginLuminosityBlock_(LuminosityBlock const &lbp, EventSetup const &c)
void doEndLuminosityBlock(LuminosityBlockPrincipal const &lbp, EventSetup const &c, ModuleCallingContext const *)
void setModuleDescription(ModuleDescription const &md)
virtual void preForkReleaseResources()
void doRegisterThinnedAssociations(ProductRegistry const &, ThinnedAssociationsHelper &)
Definition: vlib.h:208
void doPostForkReacquireResources(unsigned int iChildIndex, unsigned int iNumberOfChildren)
virtual void doBeginRun_(Run const &rp, EventSetup const &c)
Definition: Run.h:42