LSSTApplications  17.0+11,17.0+34,17.0+56,17.0+57,17.0+59,17.0+7,17.0-1-g377950a+33,17.0.1-1-g114240f+2,17.0.1-1-g4d4fbc4+28,17.0.1-1-g55520dc+49,17.0.1-1-g5f4ed7e+52,17.0.1-1-g6dd7d69+17,17.0.1-1-g8de6c91+11,17.0.1-1-gb9095d2+7,17.0.1-1-ge9fec5e+5,17.0.1-1-gf4e0155+55,17.0.1-1-gfc65f5f+50,17.0.1-1-gfc6fb1f+20,17.0.1-10-g87f9f3f+1,17.0.1-11-ge9de802+16,17.0.1-16-ga14f7d5c+4,17.0.1-17-gc79d625+1,17.0.1-17-gdae4c4a+8,17.0.1-2-g26618f5+29,17.0.1-2-g54f2ebc+9,17.0.1-2-gf403422+1,17.0.1-20-g2ca2f74+6,17.0.1-23-gf3eadeb7+1,17.0.1-3-g7e86b59+39,17.0.1-3-gb5ca14a,17.0.1-3-gd08d533+40,17.0.1-30-g596af8797,17.0.1-4-g59d126d+4,17.0.1-4-gc69c472+5,17.0.1-6-g5afd9b9+4,17.0.1-7-g35889ee+1,17.0.1-7-gc7c8782+18,17.0.1-9-gc4bbfb2+3,w.2019.22
LSSTDataManagementBasePackage
UrnPolicyFile.h
Go to the documentation of this file.
1 // -*- lsst-c++ -*-
2 
3 /*
4  * LSST Data Management System
5  * Copyright 2008, 2009, 2010 LSST Corporation.
6  *
7  * This product includes software developed by the
8  * LSST Project (http://www.lsst.org/).
9  *
10  * This program is free software: you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation, either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the LSST License Statement and
21  * the GNU General Public License along with this program. If not,
22  * see <http://www.lsstcorp.org/LegalNotices/>.
23  */
24 
35 #ifndef LSST_PEX_POLICY_URNPOLICYFILE_H
36 #define LSST_PEX_POLICY_URNPOLICYFILE_H
37 
39 
40 namespace lsst {
41 namespace pex {
42 namespace policy {
43 
69 public:
70 
85  explicit UrnPolicyFile(const std::string& urn,
86  bool strictUrn=false, bool strictLoads=true)
87  // TODO: oops, this is a segfault waiting to happen -- pass a string instead?
88  : DefaultPolicyFile(productNameFromUrn(urn, strictUrn).c_str(),
89  filePathFromUrn(urn, strictUrn),
90  reposFromUrn(urn, strictUrn),
91  strictLoads),
92  _urn(urn) {}
93 
100  static std::string productNameFromUrn(const std::string& urn,
101  bool strictUrn=false);
102 
109  static std::string filePathFromUrn(const std::string& urn,
110  bool strictUrn=false);
111 
118  static std::string reposFromUrn(const std::string& urn,
119  bool strictUrn=false);
120 
122 
125  static const std::string URN_PREFIX; // "urn:eupspkg:";
126  static const std::string URN_PREFIX_ABBREV; // "@";
128 
129 
137  static bool looksLikeUrn(const std::string& s, bool strict=false);
138 
139 private:
140  const std::string _urn;
141 };
142 
143 }}} // end namespace lsst::pex::policy
144 
145 #endif // LSST_PEX_POLICY_URNPOLICYFILE_H
static std::string reposFromUrn(const std::string &urn, bool strictUrn=false)
Extract the repository name from a URN, or "" if none.
UrnPolicyFile(const std::string &urn, bool strictUrn=false, bool strictLoads=true)
Construct a new policy file reference from a URN.
Definition: UrnPolicyFile.h:85
static const std::string URN_PREFIX_ABBREV
The prefix that a Policy URN starts with.
A Policy file in the installation directory of an LSST product, referred to using a URN...
Definition: UrnPolicyFile.h:68
the definition of the DefaultPolicyFile class
a representation of a default Policy file that is stored as a file in the installation directory of a...
static std::string filePathFromUrn(const std::string &urn, bool strictUrn=false)
Extract the local file path from a URN.
STL class.
A base class for image defects.
static const std::string URN_PREFIX
The prefix that a Policy URN starts with.
static bool looksLikeUrn(const std::string &s, bool strict=false)
Does s look like a URN? That is, does it start with URN_PREFIX or URN_PREFIX_ABBREV?
solver_t * s
static std::string productNameFromUrn(const std::string &urn, bool strictUrn=false)
Extract the product name from a URN.