RSC  0.17.1
Configuration.h
Go to the documentation of this file.
1 /* ============================================================
2  *
3  * This file is part of the RSC project
4  *
5  * Copyright (C) 2012, 2013, 2016 Jan Moringen <jmoringe@techfak.uni-bielefeld.de>
6  *
7  * This file may be licensed under the terms of the
8  * GNU Lesser General Public License Version 3 (the ``LGPL''),
9  * or (at your option) any later version.
10  *
11  * Software distributed under the License is distributed
12  * on an ``AS IS'' basis, WITHOUT WARRANTY OF ANY KIND, either
13  * express or implied. See the LGPL for the specific language
14  * governing rights and limitations.
15  *
16  * You should have received a copy of the LGPL along with this
17  * program. If not, go to http://www.gnu.org/licenses/lgpl.html
18  * or write to the Free Software Foundation, Inc.,
19  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
20  *
21  * The development of this software was supported by:
22  * CoR-Lab, Research Institute for Cognition and Robotics
23  * Bielefeld University
24  *
25  * ============================================================ */
26 
27 #include <string>
28 
29 #include <boost/filesystem.hpp>
30 
31 #include "OptionHandler.h"
32 
33 #include <rsc/rscexports.h>
34 
35 namespace rsc {
36 namespace config {
37 
38 RSC_EXPORT extern const std::string DEFAULT_DEBUG_VARIABLE_NAME;
39 
40 RSC_EXPORT extern const std::string DEFAULT_FILE_VARIABLE_NAME;
41 
42 RSC_EXPORT extern const std::string CONFIG_FILE_KEY_PREFIX;
43 RSC_EXPORT extern const std::string CONFIG_FILE_KEY_USER;
44 RSC_EXPORT extern const std::string CONFIG_FILE_KEY_PWD;
45 
46 std::vector<std::string> RSC_EXPORT
47 defaultConfigurationFiles(const std::string& fileVariableName
48  = DEFAULT_FILE_VARIABLE_NAME);
49 
50 
62 std::pair<boost::filesystem::path, std::string> RSC_EXPORT
63 resolveConfigurationFile(const std::string& spec,
64  const boost::filesystem::path& prefix,
65  const std::string& configFileName);
66 
116 void RSC_EXPORT configure(OptionHandler& handler,
117  const std::string& configFileName,
118  const std::string& environmentVariablePrefix,
119  int argc = 0,
120  const char** argv = 0,
121  bool stripEnvironmentVariablePrefix = true,
122  const boost::filesystem::path& prefix = "/",
123  const std::string& debugVariableName = DEFAULT_DEBUG_VARIABLE_NAME,
124  const std::vector<std::string>& configurationFiles = defaultConfigurationFiles());
125 
126 }
127 }
const std::string CONFIG_FILE_KEY_PWD
const std::string DEFAULT_DEBUG_VARIABLE_NAME
std::pair< boost::filesystem::path, std::string > resolveConfigurationFile(const std::string &spec, const boost::filesystem::path &prefix, const std::string &configFileName)
Return a pair of configuration file path and description derived from spec.
std::vector< std::string > defaultConfigurationFiles(const std::string &fileVariableName)
const std::string DEFAULT_FILE_VARIABLE_NAME
const std::string CONFIG_FILE_KEY_PREFIX
const std::string CONFIG_FILE_KEY_USER
void handler(int signal)
void configure(OptionHandler &handler, const string &configFileName, const string &environmentVariablePrefix, int argc, const char **argv, bool stripEnvironmentVariablePrefix, const boost::filesystem::path &prefix, const std::string &debugVariableName, const std::vector< std::string > &configurationFiles)
Pass configuration options in from configuration files derived from configFileName and environment va...