나는 program_options의 multiple_sources.cpp 예제 파일에 표시된
과 같이 표준 파일에서 구문 분석을 위해 program_options를 부스트합니다.parse_config_file을 늘리십시오, 빈 키 값
ifstream ini_file("config.ini");
po::store(po::parse_config_file(ini_file, desc, true), vm);
po::notify(vm);
config.ini 파일은 = 같은 값 쌍 빈 키 그러나했습니다
key1=value1
key2=value2
key3=
key4=
key5=value5
는 부스트 오류가이 파일 결과 읽으려고 :
boost::program_options::invalid_option_value
가 어떤인가 boost :: program_options의 메커니즘은 빈 entire와 같은 설정 파일을 읽을 수 있습니까?
도움을 주시면 감사하겠습니다.
이 문제는 아직 해결되지 않았으므로 편집 중입니다. 나는 Boost (1.53)의 예제를 인용 할 것이다.
이 전체 multiple_sources.cpp 파일입니다
#include <boost/program_options.hpp>
namespace po = boost::program_options;
#include <iostream>
#include <fstream>
#include <iterator>
using namespace std;
// A helper function to simplify the main part.
template<class T>
ostream& operator<<(ostream& os, const vector<T>& v)
{
copy(v.begin(), v.end(), ostream_iterator<T>(os, " "));
return os;
}
int main(int ac, char* av[])
{
try {
int opt;
string config_file;
// Declare a group of options that will be
// allowed only on command line
po::options_description generic("Generic options");
generic.add_options()
("version,v", "print version string")
("help", "produce help message")
//("optimization","optimization level")
("config,c", po::value<string>(&config_file)->default_value("multiple_sources.cfg"),
"name of a file of a configuration.")
;
// Declare a group of options that will be
// allowed both on command line and in
// config file
po::options_description config("Configuration");
config.add_options()
("optimization", po::value<int>(&opt)->default_value(10),
"optimization level")
("include-path,I", po::value< vector<string> >()->composing(),
"include path")
;
// Hidden options, will be allowed both on command line and
// in config file, but will not be shown to the user.
po::options_description hidden("Hidden options");
hidden.add_options()
("input-file", po::value< vector<string> >(), "input file")
;
po::options_description cmdline_options;
cmdline_options.add(generic).add(config).add(hidden);
po::options_description config_file_options;
config_file_options.add(config).add(hidden);
po::options_description visible("Allowed options");
visible.add(generic).add(config);
po::positional_options_description p;
p.add("input-file", -1);
po::variables_map vm;
store(po::command_line_parser(ac, av).
options(cmdline_options).positional(p).run(), vm);
notify(vm);
ifstream ifs(config_file.c_str());
if (!ifs)
{
cout << "can not open config file: " << config_file << "\n";
return 0;
}
else
{
store(parse_config_file(ifs, config_file_options), vm);
notify(vm);
}
if (vm.count("help")) {
cout << visible << "\n";
return 0;
}
if (vm.count("version")) {
cout << "Multiple sources example, version 1.0\n";
return 0;
}
if (vm.count("include-path"))
{
cout << "Include paths are: "
<< vm["include-path"].as< vector<string> >() << "\n";
}
if (vm.count("input-file"))
{
cout << "Input files are: "
<< vm["input-file"].as< vector<string> >() << "\n";
}
cout << "Optimization level is " << opt << "\n";
}
catch(exception& e)
{
cout << e.what() << "\n";
return 1;
}
return 0;
}
및 해당 구성 파일 (multiple_sources.cfg)입니다 :
:이 파일이 지금에 수정#
# Comment out this line to use hard-coded default value of 10
#
optimization = 1
include-path = /opt
경우
#
# Comment out this line to use hard-coded default value of 10
#
optimization =
include-path = /opt
다음과 같은 오류 메시지가 표시됩니다.
등 과부하 유효성 검사개the argument for option 'optimization' is invalid
제안 된 솔루션은 하나의 '\ n'을 다른 공백을 인식의 가능성을 포함, 각 데이터 유형에 대한 유효성 검사 함수를 작성해야 할 수도 있습니다, 특히 이후 불필요하게 복잡하게 보인다.
제안 사항? 시간을내어 주셔서 감사합니다.
("optimization", po::value<int>(&opt)->zero_tokens(),
"optimization level")
과 :
("optimization", po::value<int>(&opt)->implicit_value(10),
"optimization level")
을 그들 중 어느 것도 빈 읽은 다음에
("optimization", po::value<int>(&opt)->default_value(10),
"optimization level")
: 아 딧야의 제안에 따라
는나는 다음 줄을 교체 한 옵션. 예를 들어 다음과 같이 프로그램을 부스트 "parser_test.cpp"는 벡터에 키 - 값 쌍을 읽어 zero_tokens() 또는 implicit_value()의 사용을 우회 :
void test_config_file(const char* config_file)
{
options_description desc;
desc.add_options()
("gv1", new untyped_value)
("gv2", new untyped_value)
("empty_value", new untyped_value)
("plug*", new untyped_value)
("m1.v1", new untyped_value)
("m1.v2", new untyped_value)
("b", bool_switch())
;
const char content1[] =
" gv1 = 0#asd\n"
"empty_value = \n"
"plug3 = 7\n"
"b = true\n"
"[m1]\n"
"v1 = 1\n"
"\n"
"v2 = 2\n"
;
vector<option> a2 = parse_config_file<char>(config_file, desc).options;
BOOST_REQUIRE(a2.size() == 6);
check_value(a2[0], "gv1", "0");
check_value(a2[1], "empty_value", "");
check_value(a2[2], "plug3", "7");
check_value(a2[3], "b", "true");
check_value(a2[4], "m1.v1", "1");
check_value(a2[5], "m1.v2", "2");
}
다음을보십시오 : http://stackoverflow.com/questions/4459650/skipping-unknown-options-without-throwing-with-boost-program-options – ypnos
링크 ypnos 주셔서 감사합니다, 그러나 이미 살펴 보았습니다. 해당 솔루션에서 parse_config_file 인수의 세 번째 매개 변수로 "true"를 추가했습니다. 그래도 문제가 해결되지는 않습니다. 이 문제가 발생하여 제안 된 해결 방법으로 문제를 해결 했습니까? –
죄송합니다, 그럼 당신을 위해 도움이되지 않습니다. :/ 설정 파일에 key3 = 1, key4 = 1이 있으면 제대로 작동합니까? – ypnos