EDAnalyzerBase

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
#ifndef FWCore_Framework_stream_EDAnalyzerBase_h
#define FWCore_Framework_stream_EDAnalyzerBase_h
// -*- C++ -*-
//
// Package:     FWCore/Framework
// Class  :     EDAnalyzerBase
//
/**\class edm::stream::EDAnalyzerBase EDAnalyzerBase.h "FWCore/Framework/interface/stream/EDAnalyzerBase.h"

 Description: [one line class summary]

 Usage:
    <usage>

*/
//
// Original Author:  Chris Jones
//         Created:  Fri, 02 Aug 2013 00:11:27 GMT
//

// system include files

// user include files
#include "FWCore/Framework/interface/EDConsumerBase.h"
#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/stream/EDAnalyzerAdaptor.h"
#include "DataFormats/Provenance/interface/ModuleDescription.h"
#include "FWCore/ParameterSet/interface/ParameterSetfwd.h"

// forward declarations
namespace edm {
  namespace stream {
    class EDAnalyzerAdaptorBase;

    class EDAnalyzerBase : public edm::EDConsumerBase {
      //This needs access to the parentage cache info
      friend class EDAnalyzerAdaptorBase;

    public:
      typedef EDAnalyzerAdaptorBase ModuleType;

      EDAnalyzerBase();
      EDAnalyzerBase(const EDAnalyzerBase&) = delete;                   // stop default
      const EDAnalyzerBase& operator=(const EDAnalyzerBase&) = delete;  // stop default
      ~EDAnalyzerBase() override;

      static void fillDescriptions(ConfigurationDescriptions& descriptions);
      static void prevalidate(ConfigurationDescriptions& descriptions);
      static const std::string& baseType();

      // Warning: the returned moduleDescription will be invalid during construction
      ModuleDescription const& moduleDescription() const { return *moduleDescriptionPtr_; }

      void callWhenNewProductsRegistered(std::function<void(ProductDescription const&)> const& func);

    private:
      void registerProductsAndCallbacks(EDAnalyzerBase const*, SignallingProductRegistryFiller* reg);

      virtual void beginStream(StreamID) {}
      virtual void beginRun(edm::Run const&, edm::EventSetup const&) {}
      virtual void beginLuminosityBlock(edm::LuminosityBlock const&, edm::EventSetup const&) {}
      virtual void analyze(Event const&, EventSetup const&) = 0;
      virtual void endLuminosityBlock(edm::LuminosityBlock const&, edm::EventSetup const&) {}
      virtual void endRun(edm::Run const&, edm::EventSetup const&) {}
      virtual void endStream() {}

      void setModuleDescriptionPtr(ModuleDescription const* iDesc) { moduleDescriptionPtr_ = iDesc; }
      // ---------- member data --------------------------------
      std::function<void(ProductDescription const&)> callWhenNewProductsRegistered_;
      ModuleDescription const* moduleDescriptionPtr_;
    };

  }  // namespace stream
}  // namespace edm

#endif