LSSTApplications  16.0-10-g0ee56ad,16.0-11-ga33d1f2+2,16.0-12-g3ef5c14+1,16.0-12-g71e5ef5+14,16.0-12-gbdf3636+2,16.0-13-g118c103+2,16.0-13-g8f68b0a,16.0-15-gbf5c1cb,16.0-16-gfd17674+2,16.0-17-g7c01f5c+2,16.0-18-g0a50484,16.0-20-ga20f992+3,16.0-21-g0e05fd4+2,16.0-21-g15e2d33,16.0-22-g62d8060,16.0-22-g847a80f,16.0-24-gfa57b64+1,16.0-28-g3990c221,16.0-3-gf928089+2,16.0-32-g88a4f23,16.0-34-gd7987ad,16.0-36-g6d07a18,16.0-4-g10fc685,16.0-4-g18f3627+24,16.0-4-g5f3a788+25,16.0-5-gaf5c3d7+1,16.0-5-gcc1f4bb,16.0-6-g3b92700,16.0-6-g4412fcd+2,16.0-6-g7235603+1,16.0-68-gb45e8e9d,16.0-7-g0913a87,16.0-7-g56728dd,16.0-8-g14ebd58,16.0-8-g2df868b,16.0-8-g4cec79c+1,16.0-81-g9604f5049,16.0-9-g5400cdc,16.0-9-ge6233d7+1,master-g2880f2d8cf+1,w.2019.05
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.