LSSTApplications  11.0-22-g33de520,12.1+25,13.0+26,13.0+31,13.0-1-g41367f3+4,13.0-1-g47a359c+4,13.0-1-g52a7baa+3,13.0-1-g976b40b+3,13.0-11-gf01aa92,13.0-12-gad3af2c,13.0-12-gfeff4b0,13.0-13-gdd29b46+6,13.0-16-gca4cc00,13.0-2-g15de9a1+3,13.0-2-g167564e,13.0-2-ga4f5e85+7,13.0-2-gf5c5ced+7,13.0-2-gf9e84ea+6,13.0-25-ga3789c2,13.0-3-g7fa07e0+5,13.0-39-g3deb52d,13.0-4-g0bde1de,13.0-6-g7b63e3f+7,13.0-8-g3fb36f0,13.0-8-gba0f85f+1,13.0-8-gce69b36,master-g43362ee2f3,master-gd1207e8857
LSSTDataManagementBasePackage
Utils.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 
23 #include "lsst/utils/Utils.h"
24 
25 #include <iostream>
26 #include <sstream>
27 #include <string>
28 #include "boost/regex.hpp"
29 #include "lsst/pex/exceptions.h"
30 
31 namespace lsst {
32 namespace utils {
33 
34 std::string getPackageDir(std::string const& packageName) {
35  std::string envVar = packageName; // package's environment variable
36 
37  transform(envVar.begin(), envVar.end(), envVar.begin(), (int (*)(int)) toupper);
38  envVar += "_DIR";
39 
40  char const *dir = getenv(envVar.c_str());
41  if (!dir) {
42  throw LSST_EXCEPT(lsst::pex::exceptions::NotFoundError, "Package " + packageName + " not found");
43  }
44 
45  return dir;
46 }
47 
48 }} // namespace lsst::utils
std::string getPackageDir(std::string const &packageName)
return the root directory of a setup package
Definition: Utils.cc:34
#define LSST_EXCEPT(type,...)
Create an exception with a given type and message and optionally other arguments (dependent on the ty...
Definition: Exception.h:46
Include files required for standard LSST Exception handling.