Go to the documentation of this file. 1 #ifndef FWCore_Framework_stream_ProducingModuleAdaptor_h
2 #define FWCore_Framework_stream_ProducingModuleAdaptor_h
38 template <
typename T,
typename M,
typename B>
46 typename T::GlobalCache
const*
dummy =
nullptr;
60 T::HasAbility::kBeginLuminosityBlockProducer
or T::HasAbility::kEndLuminosityBlockProducer;
79 this->createStreamModules([
this]() -> M* {
113 Run r(rp, this->moduleDescription(), mcc,
false);
116 Run const& cnstR =
r;
133 Run r(rp, this->moduleDescription(), mcc,
true);
156 T::HasAbility::kBeginLuminosityBlockProducer) {
162 RunIndex ri = lbp.runPrincipal().index();
172 if constexpr (T::HasAbility::kBeginLuminosityBlockProducer) {
182 T::HasAbility::kEndLuminosityBlockProducer) {
188 RunIndex ri = lbp.runPrincipal().index();
195 if constexpr (T::HasAbility::kEndLuminosityBlockProducer) {
static void endJob(typename T::GlobalCache *iCache)
static void produce(edm::Run &, edm::EventSetup const &, typename T::RunContext const *, typename T::RunSummaryCache const *)
bool hasAccumulator() const final
static void fillDescriptions(ConfigurationDescriptions &descriptions)
impl::choose_shared_vec< typename T::LuminosityBlockCache const >::type m_lumis
void doEndLuminosityBlock(LuminosityBlockPrincipal const &lbp, EventSetupImpl const &ci, ModuleCallingContext const *mcc) final
CallBeginLuminosityBlockProduce< T > MyBeginLuminosityBlockProduce
ProducingModuleAdaptor(edm::ParameterSet const &iPSet)
void setProducer(ProducerBase const *iProducer)
~ProducingModuleAdaptor() override
static void streamEndRunSummary(B *iProd, edm::Run const &iRun, edm::EventSetup const &iES, typename T::RunSummaryCache *iCache)
impl::choose_shared_vec< typename T::RunSummaryCache >::type m_runSummaries
static void beginLuminosityBlock(edm::LuminosityBlock const &Lumi, edm::EventSetup const &iES, typename T::RunContext const *iRC, std::shared_ptr< typename T::LuminosityBlockCache const > &oCache)
std::vector< std::shared_ptr< T > > type
CallEndRunProduce< T > MyEndRunProduce
static void set(B *iProd, typename T::GlobalCache const *iCache)
static void set(B *iProd, typename T::RunCache const *iCache)
static void produce(edm::LuminosityBlock &, edm::EventSetup const &, typename T::LuminosityBlockContext const *, typename T::LuminosityBlockSummaryCache const *)
void doEndRun(RunPrincipal const &rp, EventSetupImpl const &ci, ModuleCallingContext const *mcc) final
static void endLuminosityBlock(edm::LuminosityBlock const &Lumi, edm::EventSetup const &iES, typename T::LuminosityBlockContext const *iContext)
bool wantsGlobalLuminosityBlocks() const final
static void produce(edm::LuminosityBlock &Lumi, edm::EventSetup const &iES, typename T::LuminosityBlockContext const *iRC)
void doBeginRun(RunPrincipal const &rp, EventSetupImpl const &ci, ModuleCallingContext const *mcc) final
static void endRun(edm::Run const &iRun, edm::EventSetup const &iES, typename T::RunContext const *iContext)
static void beginJob(typename T::GlobalCache *iCache)
static void produce(edm::Run &iRun, edm::EventSetup const &iES, typename T::RunContext const *iRC)
CallGlobalRun< T > MyGlobalRun
CallEndLuminosityBlockProduce< T > MyEndLuminosityBlockProduce
static void globalEndLuminosityBlock(edm::LuminosityBlock const &Lumi, edm::EventSetup const &iES, typename T::LuminosityBlockContext const *iContext, typename T::LuminosityBlockSummaryCache *iCache)
void streamEndLuminosityBlockSummary(M *iProd, edm::LuminosityBlock const &iLumi, edm::EventSetup const &iES) final
CallGlobalLuminosityBlock< T > MyGlobalLuminosityBlock
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
impl::choose_shared_vec< typename T::RunCache const >::type m_runs
impl::choose_unique_ptr< typename T::GlobalCache >::type m_global
CallGlobalLuminosityBlockSummary< T > MyGlobalLuminosityBlockSummary
CallGlobalRunSummary< T > MyGlobalRunSummary
bool wantsGlobalRuns() const final
static void prevalidate(ConfigurationDescriptions &descriptions)
void streamEndRunSummary(M *iProd, edm::Run const &iRun, edm::EventSetup const &iES) final
static void beginRun(edm::Run const &iRun, edm::EventSetup const &iES, typename T::RunContext const *iRC, std::shared_ptr< typename T::RunSummaryCache > &oCache)
void setConsumer(EDConsumerBase const *iConsumer)
CallBeginRunProduce< T > MyBeginRunProduce
T const & get(Event const &event, InputTag const &tag) noexcept(false)
const ProducingModuleAdaptor & operator=(const ProducingModuleAdaptor &)=delete
static void globalEndRun(edm::Run const &iRun, edm::EventSetup const &iES, typename T::RunContext const *iContext, typename T::RunSummaryCache *iCache)
void setupStreamModules() final
std::unique_ptr< T > type
void setProducer(ProducerBase const *iProducer)
impl::choose_mutex< typename T::RunSummaryCache >::type m_runSummaryLock
static const std::string B
static void set(B *iProd, typename T::LuminosityBlockCache const *iCache)
ParameterSet const * m_pset
static void beginRun(edm::Run const &iRun, edm::EventSetup const &iES, typename T::GlobalCache const *iGC, std::shared_ptr< typename T::RunCache const > &oCache)
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e< void, edm::EventID const &, edm::Timestamp const & > We also list in braces which AR_WATCH_USING_METHOD_ is used for those or
void doBeginLuminosityBlock(LuminosityBlockPrincipal const &lbp, EventSetupImpl const &ci, ModuleCallingContext const *mcc) final
static void streamEndLuminosityBlockSummary(B *iProd, edm::LuminosityBlock const &iLumi, edm::EventSetup const &iES, typename T::LuminosityBlockSummaryCache *iCache)
static void beginLuminosityBlock(edm::LuminosityBlock const &Lumi, edm::EventSetup const &iES, typename T::LuminosityBlockContext const *iRC, std::shared_ptr< typename T::LuminosityBlockSummaryCache > &oCache)
impl::choose_shared_vec< typename T::LuminosityBlockSummaryCache >::type m_lumiSummaries
void setupLuminosityBlock(M *iProd, LuminosityBlockIndex iIndex) final
void setupRun(M *iProd, RunIndex iIndex) final
bool hasAcquire() const final
void preallocLumis(unsigned int iNLumis) final
impl::choose_mutex< typename T::LuminosityBlockSummaryCache >::type m_lumiSummaryLock