File indexing completed on 2024-04-06 12:01:02
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019 #include "FWCore/Framework/interface/global/EDProducer.h"
0020 #include "FWCore/Utilities/interface/InputTag.h"
0021 #include "DataFormats/Candidate/interface/Candidate.h"
0022
0023 class CandReducer : public edm::global::EDProducer<> {
0024 public:
0025
0026 explicit CandReducer(const edm::ParameterSet&);
0027
0028 ~CandReducer() override = default;
0029
0030 private:
0031
0032 void produce(edm::StreamID, edm::Event& e, edm::EventSetup const& c) const override;
0033
0034 const edm::EDGetTokenT<reco::CandidateView> srcToken_;
0035 };
0036
0037 #include "FWCore/Framework/interface/Event.h"
0038 #include "FWCore/ParameterSet/interface/ParameterSet.h"
0039 #include "DataFormats/Candidate/interface/LeafCandidate.h"
0040 #include "FWCore/Utilities/interface/EDMException.h"
0041
0042 using namespace reco;
0043 using namespace edm;
0044
0045 CandReducer::CandReducer(const edm::ParameterSet& cfg)
0046 : srcToken_(consumes<reco::CandidateView>(cfg.getParameter<edm::InputTag>("src"))) {
0047 produces<CandidateCollection>();
0048 }
0049
0050 void CandReducer::produce(edm::StreamID, edm::Event& evt, edm::EventSetup const&) const {
0051 const Handle<reco::CandidateView> cands = evt.getHandle(srcToken_);
0052 std::unique_ptr<CandidateCollection> comp(new CandidateCollection);
0053 for (reco::CandidateView::const_iterator c = cands->begin(); c != cands->end(); ++c) {
0054 std::unique_ptr<Candidate> cand(new LeafCandidate(*c));
0055 comp->push_back(cand.release());
0056 }
0057 evt.put(std::move(comp));
0058 }
0059
0060 #include "FWCore/Framework/interface/MakerMacros.h"
0061 DEFINE_FWK_MODULE(CandReducer);