LSSTApplications  19.0.0-14-gb0260a2+d60062ef16,20.0.0+1540ce6389,20.0.0+7c6b12c2f9,20.0.0+ae956f52c5,20.0.0+be870186d9,20.0.0+e2e26847c2,20.0.0-1-g10df615+7683e4f082,20.0.0-1-g253301a+7c6b12c2f9,20.0.0-1-g2b7511a+46a6078777,20.0.0-1-g3dda6ea+606b36f8c0,20.0.0-1-g4d801e7+901ee84527,20.0.0-1-g5b95a8c+a5fa15ec54,20.0.0-1-gb058bd0+46a6078777,20.0.0-1-gb88604f+acecce4127,20.0.0-1-gc96f8cb+61a4a056b1,20.0.0-1-gedffbd8+4f0e391d5e,20.0.0-10-g0891cd99+aadc987f3e,20.0.0-10-g9a20bd332+576ca7b471,20.0.0-17-gcdbda88+ed0d4927ab,20.0.0-2-g4dae9ad+61a4a056b1,20.0.0-2-g61b8584+85c46248f3,20.0.0-2-gb780d76+f45b7d88f4,20.0.0-2-gf072044+7c6b12c2f9,20.0.0-21-g9bbb7f7+61a4a056b1,20.0.0-22-gc512666+9eba1c4719,20.0.0-23-g8900aa8+68630f7098,20.0.0-3-g1653f94+85c46248f3,20.0.0-3-g4cc78c6+63636aeed8,20.0.0-3-g750bffe+e05f822de9,20.0.0-3-gbd60e8c+ff10c6d78d,20.0.0-32-g15a0e07c+ff1c9f120b,20.0.0-4-g97dc21a+68630f7098,20.0.0-4-gfea843c+f45b7d88f4,20.0.0-5-g357b56b+f45b7d88f4,20.0.0-6-g9a5b7a1+2c4171520d,20.0.0-61-g4de25fb+e4dd172200,20.0.0-7-gcda7bf1+85e953d7e4,w.2020.43
LSSTDataManagementBasePackage
PAFParserFactory.cc
Go to the documentation of this file.
1 /*
2  * LSST Data Management System
3  * Copyright 2008, 2009, 2010 LSST Corporation.
4  *
5  * This product includes software developed by the
6  * LSST Project (http://www.lsst.org/).
7  *
8  * This program is free software: you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation, either version 3 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the LSST License Statement and
19  * the GNU General Public License along with this program. If not,
20  * see <http://www.lsstcorp.org/LegalNotices/>.
21  */
22 
31 
32 namespace lsst {
33 namespace pex {
34 namespace policy {
35 namespace paf {
36 
37 //@cond
38 
39 using boost::regex_search;
40 using boost::regex;
41 using std::string;
44 
45 /*
46  * a name for the format
47  */
48 const string PAFParserFactory::FORMAT_NAME("PAF");
49 
50 const regex PAFParserFactory::LEADER_PATTERN("^\\s*\\w");
51 const regex
52  PAFParserFactory::CONTENTID("^\\s*#\\s*<\\?cfg\\s+PAF(\\s+\\w+)*\\s*\\?>",
53  regex::icase);
54 
55 /*
56  * create a new PolicyParser class and return a pointer to it. The
57  * caller is responsible for destroying the pointer.
58  * @param policy the Policy object that data should be loaded into.
59  */
60 PolicyParser* PAFParserFactory::createParser(Policy& policy,
61  bool strict) const
62 {
63  return new PAFParser(policy, strict);
64 }
65 
66 /*
67  * return the name for the format supported by the parser
68  */
69 const string& PAFParserFactory::getFormatName() { return FORMAT_NAME; }
70 
71 /*
72  * analyze the given string assuming contains the leading characters
73  * from the data stream and return true if it is recognized as being in
74  * the format supported by this parser. If it is, return the name of
75  * the this format;
76  */
77 bool PAFParserFactory::isRecognized(const string& leaders) const {
78  return (regex_search(leaders, contentid) ||
79  regex_search(leaders, LEADER_PATTERN));
80 }
81 
82 
83 //@endcond
84 
85 }}}} // end lsst::pex::policy::paf
lsst.pex::policy::paf::PAFParserFactory::createParser
virtual PolicyParser * createParser(Policy &policy, bool strict=true) const
create a new PolicyParser class and return a pointer to it.
lsst.pex::policy::PolicyParser
an abstract class for parsing serialized Policy data and loading it into a Policy object.
Definition: PolicyParser.h:46
std::string
STL class.
lsst.pex::policy::Policy
a container for holding hierarchical configuration data in memory.
Definition: Policy.h:167
PAFParserFactory.h
definition of the PAFParserFactory class
lsst.pex::policy::paf::PAFParserFactory::isRecognized
virtual bool isRecognized(const std::string &leaders) const
analyze the given string assuming contains the leading characters from the data stream and return tru...
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
std::regex_search
T regex_search(T... args)
lsst.pex::policy::paf::PAFParserFactory::getFormatName
virtual const std::string & getFormatName()
return the name for the format supported by the parser
PAFParser.h
definition of the PAFParser class
lsst.pex::policy::paf::PAFParserFactory::FORMAT_NAME
static const std::string FORMAT_NAME
a name for the format
Definition: PAFParserFactory.h:96
lsst.pex::policy::paf::PAFParserFactory::CONTENTID
static const boost::regex CONTENTID
a default pattern for the content identifier.
Definition: PAFParserFactory.h:108
lsst.pex::policy::paf::PAFParserFactory::LEADER_PATTERN
static const boost::regex LEADER_PATTERN
a pattern for the leading data characters for this format
Definition: PAFParserFactory.h:101