Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2024-05-11 03:34:11

0001 #ifndef FWCore_Framework_one_EDFilter_h
0002 #define FWCore_Framework_one_EDFilter_h
0003 // -*- C++ -*-
0004 //
0005 // Package:     FWCore/Framework
0006 // Class  :     edm::one::EDFilter
0007 //
0008 /**\class edm::one::EDFilter EDFilter.h "FWCore/Framework/interface/one/EDFilter.h"
0009 
0010  Description: [one line class summary]
0011 
0012  Usage:
0013     <usage>
0014 
0015 */
0016 //
0017 // Original Author:  Chris Jones
0018 //         Created:  Thu, 09 May 2013 19:53:55 GMT
0019 //
0020 
0021 // system include files
0022 
0023 // user include files
0024 #include "FWCore/Framework/interface/one/filterAbilityToImplementor.h"
0025 
0026 // forward declarations
0027 namespace edm {
0028   namespace one {
0029     template <typename... T>
0030     class EDFilter : public filter::AbilityToImplementor<T>::Type..., public virtual EDFilterBase {
0031     public:
0032       static_assert(not(CheckAbility<module::Abilities::kRunCache, T...>::kHasIt and
0033                         CheckAbility<module::Abilities::kOneWatchRuns, T...>::kHasIt),
0034                     "Cannot use both WatchRuns and RunCache");
0035       static_assert(not(CheckAbility<module::Abilities::kLuminosityBlockCache, T...>::kHasIt and
0036                         CheckAbility<module::Abilities::kOneWatchLuminosityBlocks, T...>::kHasIt),
0037                     "Cannot use both WatchLuminosityBlocks and LuminosityBLockCache");
0038       EDFilter() = default;
0039       EDFilter(const EDFilter&) = delete;
0040       const EDFilter& operator=(const EDFilter&) = delete;
0041 
0042       //virtual ~EDFilter();
0043 
0044       // ---------- const member functions ---------------------
0045       bool wantsProcessBlocks() const noexcept final { return WantsProcessBlockTransitions<T...>::value; }
0046       bool wantsInputProcessBlocks() const noexcept final { return WantsInputProcessBlockTransitions<T...>::value; }
0047       bool wantsGlobalRuns() const noexcept final { return WantsGlobalRunTransitions<T...>::value; }
0048       bool wantsGlobalLuminosityBlocks() const noexcept final {
0049         return WantsGlobalLuminosityBlockTransitions<T...>::value;
0050       }
0051 
0052       bool hasAbilityToProduceInBeginProcessBlocks() const final {
0053         return HasAbilityToProduceInBeginProcessBlocks<T...>::value;
0054       }
0055       bool hasAbilityToProduceInEndProcessBlocks() const final {
0056         return HasAbilityToProduceInEndProcessBlocks<T...>::value;
0057       }
0058 
0059       bool hasAbilityToProduceInBeginRuns() const final { return HasAbilityToProduceInBeginRuns<T...>::value; }
0060       bool hasAbilityToProduceInEndRuns() const final { return HasAbilityToProduceInEndRuns<T...>::value; }
0061 
0062       bool hasAbilityToProduceInBeginLumis() const final { return HasAbilityToProduceInBeginLumis<T...>::value; }
0063       bool hasAbilityToProduceInEndLumis() const final { return HasAbilityToProduceInEndLumis<T...>::value; }
0064 
0065       // ---------- static member functions --------------------
0066 
0067       // ---------- member functions ---------------------------
0068       SerialTaskQueue* globalRunsQueue() final { return globalRunsQueue_.queue(); }
0069       SerialTaskQueue* globalLuminosityBlocksQueue() final { return globalLuminosityBlocksQueue_.queue(); }
0070 
0071     private:
0072       // ---------- member data --------------------------------
0073       impl::OptionalSerialTaskQueueHolder<WantsSerialGlobalRunTransitions<T...>::value> globalRunsQueue_;
0074       impl::OptionalSerialTaskQueueHolder<WantsSerialGlobalLuminosityBlockTransitions<T...>::value>
0075           globalLuminosityBlocksQueue_;
0076     };
0077 
0078   }  // namespace one
0079 }  // namespace edm
0080 
0081 #endif