49 using namespace ::helper;
50 size_t f = selection.find_first_not_of(
' ');
51 size_t n = selection.size();
54 for(; (c = selection[
f]) !=
' ' && f < n; ++
f) {
57 if(command[0] ==
'+') {
59 if(command[0] ==
'+') {
68 if(command[command.size() - 1] ==
'+') {
69 command.erase(command.size() - 1);
70 if(command[command.size()-1] ==
'+') {
71 command.erase(command.size() - 1);
79 if(command ==
"keep") code.
keepOrDrop_ = SelectCode::kKeep;
80 else if(command ==
"drop") code.
keepOrDrop_ = SelectCode::kDrop;
83 <<
"invalid selection command: " << command <<
"\n" << endl;
86 if(selection[f] !=
' ')
break;
88 cut = string(selection, f);
90 cut = string(cut, 0, cut.find_first_of(
' '));
91 code.
all_ = cut ==
"*";
96 src_(cfg.getParameter<
InputTag>(
"src")), keepOrDropAll_(
drop),
97 selection_(cfg.getParameter<vector<string> >(
"select")) {
98 using namespace ::helper;
99 produces<GenParticleCollection>();
142 <<
"selections \"keep *\" and \"drop *\" can be used only as first options. Here used in position # "
145 case ::helper::SelectCode::kDrop :
147 case ::helper::SelectCode::kKeep :
158 using namespace ::helper;
161 const size_t n = src->size();
165 const pair<StringCutObjectSelector<GenParticle>, SelectCode> &
sel =
select_[
j];
166 SelectCode code = sel.second;
168 for(
size_t i = 0;
i <
n; ++
i) {
171 int keepOrDrop =
keep;
172 switch(code.keepOrDrop_) {
173 case SelectCode::kKeep:
174 keepOrDrop =
keep;
break;
175 case SelectCode::kDrop:
179 switch(code.daughtersDepth_) {
180 case SelectCode::kAll :
182 case SelectCode::kFirst :
187 switch(code.mothersDepth_) {
188 case SelectCode::kAll :
190 case SelectCode::kFirst :
200 for(
size_t i = 0;
i <
n; ++
i) {
209 out->reserve(counter);
227 j != daughters.
end(); ++
j) {
244 j != mothers.
end(); ++
j) {
std::vector< std::pair< StringCutObjectSelector< reco::GenParticle >, helper::SelectCode > > select_
void flagDaughters(const reco::GenParticle &, int)
std::vector< GenParticle > GenParticleCollection
collection of GenParticles
void produce(edm::Event &, const edm::EventSetup &)
std::vector< int > flags_
#define DEFINE_FWK_MODULE(type)
void flagMothers(const reco::GenParticle &, int)
std::string replace(const std::string &) const
const daughters & daughterRefVector() const
references to daughtes
GenParticlePruner(const edm::ParameterSet &)
const_iterator end() const
Termination of iteration.
void addDaughterRefs(reco::GenParticle &, reco::GenParticleRefProd, const reco::GenParticleRefVector &) const
const_iterator begin() const
Initialize an iterator over the RefVector.
void addDaughter(const typename daughters::value_type &)
add a daughter via a reference
std::vector< size_t > indices_
const mothers & motherRefVector() const
references to mothers
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
FlagDepth daughtersDepth_
void addMotherRefs(reco::GenParticle &, reco::GenParticleRefProd, const reco::GenParticleRefVector &) const
void recursiveFlagDaughters(size_t, const reco::GenParticleCollection &, int)
void parse(const std::string &selection, helper::SelectCode &code, std::string &cut) const
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
void addMother(const typename mothers::value_type &)
add a daughter via a reference
RefProd< PROD > getRefBeforePut()
key_type key() const
Accessor for product key.
void recursiveFlagMothers(size_t, const reco::GenParticleCollection &, int)
size_type size() const
Size of the RefVector.
std::vector< std::string > selection_