RSC  0.16.0
ConfigSource.cpp
Go to the documentation of this file.
1 /* ============================================================
2  *
3  * This file is a part of the RSC project.
4  *
5  * Copyright (C) 2011 by Johannes Wienke <jwienke at techfak dot uni-bielefeld dot 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 "ConfigSource.h"
28 
29 #include <stdexcept>
30 
31 #include <boost/tokenizer.hpp>
32 
33 namespace rsc {
34 namespace config {
35 
36 using namespace std;
37 
39 }
40 
41 void ConfigSource::splitKeyAtDots(const string& input, vector<string>& output) {
42  typedef boost::escaped_list_separator<char> SeparatorType;
43  typedef boost::tokenizer<SeparatorType> TokenizerType;
44 
45  SeparatorType sep('\\', '.');
46  TokenizerType tok(input, sep);
47  copy(tok.begin(), tok.end(), back_inserter(output));
48 
49  for (vector<string>::const_iterator outputIt = output.begin();
50  outputIt != output.end(); ++outputIt) {
51  if (outputIt->empty()) {
52  throw invalid_argument("Empty component in key '" + input + "'");
53  }
54  }
55 
56  if (output.empty()) {
57  throw invalid_argument("Option key is empty");
58  }
59 
60 }
61 
62 }
63 }
void splitKeyAtDots(const std::string &input, std::vector< std::string > &output)
Creates a key vector structure used in the options backend from a dot-separated string.
STL namespace.