CMS 3D CMS Logo

ModifiedObjectProducer.h
Go to the documentation of this file.
1 #ifndef __PhysicsTools_PatAlgos_ModifiedObjectProducer_h__
2 #define __PhysicsTools_PatAlgos_ModifiedObjectProducer_h__
3 
5 
11 
12 #include <memory>
13 
14 namespace pat {
15 
16  template <class T>
18  public:
19  typedef std::vector<T> Collection;
21 
23  //set our input source
24  src_ = consumes<edm::View<T> >(conf.getParameter<edm::InputTag>("src"));
25  //setup modifier
26  const edm::ParameterSet& mod_config = conf.getParameter<edm::ParameterSet>("modifierConfig");
27  modifier_ = std::make_unique<Modifier>(mod_config, consumesCollector());
28  //declare products
29  produces<Collection>();
30  }
32 
34  modifier_->setEventContent(evs);
35  }
36 
37  void produce(edm::Event& evt, const edm::EventSetup& evs) final {
39  auto output = std::make_unique<Collection>();
40 
41  evt.getByToken(src_, input);
42  output->reserve(input->size());
43 
44  modifier_->setEvent(evt);
45 
46  for (auto itr = input->begin(); itr != input->end(); ++itr) {
47  output->push_back(*itr);
48  T& obj = output->back();
49  modifier_->modify(obj);
50  }
51 
52  evt.put(std::move(output));
53  }
54 
55  private:
57  std::unique_ptr<Modifier> modifier_;
58  };
59 } // namespace pat
60 
61 #endif
T getParameter(std::string const &) const
std::unique_ptr< Modifier > modifier_
void beginLuminosityBlock(const edm::LuminosityBlock &, const edm::EventSetup &evs) final
ModifiedObjectProducer(const edm::ParameterSet &conf)
static std::string const input
Definition: EdmProvDump.cc:48
Definition: HeavyIon.h:7
edm::EDGetTokenT< edm::View< T > > src_
void produce(edm::Event &evt, const edm::EventSetup &evs) final
pat::ObjectModifier< T > Modifier
long double T
def move(src, dest)
Definition: eostools.py:511