CMS 3D CMS Logo

Classes | Typedefs | Functions
cand::parser Namespace Reference

Classes

struct  ConjInfo
 
class  ModeSetter
 

Typedefs

typedef rule< ScannerUsed_1Rule_1
 
typedef scanner_policies< skip_parser_iteration_policy< nothing_parser, iteration_policy >, match_policy, action_policy > ScannerPolicy
 
typedef scanner< const char *, ScannerPolicyScannerUsed_1
 

Functions

bool decayParser (const std::string &iValue, std::vector< ConjInfo > &oStrings)
 
bool decayParser (const string &iValue, vector< ConjInfo > &oStrings)
 
std::ostream & operator<< (std::ostream &out, const ConjInfo &info)
 

Typedef Documentation

◆ Rule_1

Definition at line 35 of file decayParser.cc.

◆ ScannerPolicy

typedef scanner_policies<skip_parser_iteration_policy<nothing_parser, iteration_policy>, match_policy, action_policy> cand::parser::ScannerPolicy

Definition at line 33 of file decayParser.cc.

◆ ScannerUsed_1

typedef scanner<const char*, ScannerPolicy> cand::parser::ScannerUsed_1

Definition at line 34 of file decayParser.cc.

Function Documentation

◆ decayParser() [1/2]

bool cand::parser::decayParser ( const std::string &  iValue,
std::vector< ConjInfo > &  oStrings 
)

◆ decayParser() [2/2]

bool cand::parser::decayParser ( const string &  iValue,
vector< ConjInfo > &  oStrings 
)

Definition at line 37 of file decayParser.cc.

37  {
38  using namespace boost::spirit;
39 
40  Rule_1 label = ((+alnum_p) >> *ch_p(':') >> *ch_p('_') >> *alnum_p)[push_back_a(oStrings)];
41  Rule_1 conj = (ch_p('@') >> !((ch_p('b') >> ch_p('a') >> ch_p('r')[ModeSetter(oStrings, ConjInfo::kBar)]) |
42  ch_p('+')[ModeSetter(oStrings, ConjInfo::kPlus)] |
43  ch_p('-')[ModeSetter(oStrings, ConjInfo::kMinus)]));
44 
45  return parse(iValue.c_str(), ((label >> !conj) % blank_p), nothing_p).full;
46  }

References full, reco::ParticleMasses::kPlus, label, and dumpparser::parse().

◆ operator<<()

std::ostream& cand::parser::operator<< ( std::ostream &  out,
const ConjInfo info 
)
inline

Definition at line 43 of file decayParser.h.

43  {
44  return out << info.tag_.encode() << " "
45  << (0 == info.mode_
46  ? "p"
47  : (info.mode_ == ConjInfo::kBar ? "b" : (info.mode_ == ConjInfo::kPlus ? "+" : "-")));
48  }

References info(), cand::parser::ConjInfo::kBar, cand::parser::ConjInfo::kPlus, and MillePedeFileConverter_cfg::out.

reco::ParticleMasses::kPlus
const double kPlus
Definition: ParticleMasses.h:8
info
static const TGPicture * info(bool iBackgroundIsBlack)
Definition: FWCollectionSummaryWidget.cc:152
full
Definition: GenABIO.cc:168
cand::parser::Rule_1
rule< ScannerUsed_1 > Rule_1
Definition: decayParser.cc:35
dumpparser.parse
def parse(path, config)
Definition: dumpparser.py:13
MillePedeFileConverter_cfg.out
out
Definition: MillePedeFileConverter_cfg.py:31
label
const char * label
Definition: PFTauDecayModeTools.cc:11
boost::spirit
Definition: DDPartSelection.cc:9