我正在尝试使用boost :: program_options解析以下语法:
a)
$ a.out
verbosity: 0
b)
$ a.out -v
verbosity: 1
c)
$ a.out -v -v
verbosity: 2
d)
$ a.out -vv
verbosity: 2
e) (optional)
$ a.out -v3
verbosity: 3
我的计划到目前为止:
#include <iostream>
#include <boost/program_options.hpp>
namespace po = boost::program_options;
int main(int argc, char *argv[])
{
po::options_description desc;
desc.add_options()
("verbose,v", po::value<int>(), "verbose");
po::variables_map vm;
po::store(po::command_line_parser(argc, argv).options(desc).run(), vm);
po::notify(vm);
std::cout << "verbosity: " << vm["verbose"].as<int>() << std::endl;
return 0;
}
这仅适用于e)。如果我将其更改为:
po::value<int>()->default_value(0)
适用于a)和e)。与
po::value<int>()->default_value(0)->implicit_value(1)
适用于a),b)和e)。
如何解析上述所有案例?
我想我需要将一个值向量与zero_tokens()组合在一起,但我似乎无法让它工作。
答案 0 :(得分:1)
获取-v参数的数量使用vm [“verbose”]。count。当然,当与vm [“verbose”]组合时,这将导致一些奇怪的结果。作为&lt;&gt;()方法。
要真正做你想做的事,你可能必须为该选项编写自己的解析方法。该函数看起来像:
std::pair<std::string, std::string> verbosity_count(const std::string& s)
{
if(s.find("-v") || s.find("--verbose"))
{
// process the verbosity count (this will require a static verbosity count var)
return std::make_pair("-v", value as string);
}
else
{
return std::make_pair(std::string(), std::string());
}
return std::make_pair(std::string(), std::string());
}
你可以通过extra_parser()方法将它附加到命令行解析器(有关确切的详细信息,请参阅boost Program Option docs,其冗长和混乱)。
答案 1 :(得分:1)
虽然它并不美观,但这解决了我原来的问题:
#include <iostream>
#include <vector>
#include <string>
#include <boost/lexical_cast.hpp>
#include <boost/foreach.hpp>
#include <boost/program_options.hpp>
namespace po = boost::program_options;
std::pair<std::string, std::string> verbosity(const std::string& s)
{
if(s.find("-v") == 0)
{
size_t value = 1;
try {
value = boost::lexical_cast<size_t>(s.substr(2));
}
catch(...)
{
while(s[1+value] == 'v')
++value;
}
return std::make_pair("verbose", boost::lexical_cast<std::string>(value));
}
return std::make_pair(std::string(), std::string());
}
int main(int argc, char *argv[])
{
po::options_description desc;
desc.add_options()
("verbose,v", po::value<std::vector<std::string> >(), "verbose");
po::variables_map vm;
po::store(po::parse_command_line(argc, argv, desc, 0, verbosity), vm);
po::notify(vm);
size_t verbosity = 0;
if(vm.count("verbose"))
BOOST_FOREACH(const std::string& s, vm["verbose"].as<std::vector<std::string> >())
verbosity += boost::lexical_cast<int>(s);
std::cout << "verbosity: " << verbosity << std::endl;
return 0;
}