如何序列化/反序列化boost :: program_options :: variables_map?我找不到已经实现的序列化函数,我不知道我可以使用variables_map中的哪些函数来提取和重新组合映射.
使用boost:program_options进行命令行解析时遇到问题.解释它的最快方法是显示代码:
const std::vector<tstring> args;
if (ac > 0 && NULL!=av) //ac is a ULONG
{
for (int i = 0; i < ac; i++)
{
args.push_back(av[i]); //av is an LPTSTR pointer (pointer to TCHAR*)
}
}
po::command_line_parser parser(args);
Run Code Online (Sandbox Code Playgroud)
解析器ctor应该采用const std :: vector <charT>
typedef basic_command_line_parser<char> command_line_parser;
typedef basic_command_line_parser<wchar_t> wcommand_line_parser;
/** Creates instance of 'command_line_parser', passes parameters to it,
and returns the result of calling the 'run' method.
*/
template<class charT>
class basic_command_line_parser : private detail::cmdline {
public:
/** Creates a …Run Code Online (Sandbox Code Playgroud) 我正在使用boost :: program_options来实现具有以下语法的命令行实用程序:
myutil command [--in file_name] [---out file_name]
Run Code Online (Sandbox Code Playgroud)
其中'command'是必需的,并且是以下之一:
read | write | find | version | help
Run Code Online (Sandbox Code Playgroud)
问题是"命令"不应该要求--或者-我还没有找到如何使用boost :: program_options来做到这一点.
我有以下示例代码:
#include <iostream>
#include <boost/program_options.hpp>
int main ( int ac, char *av[] ) {
// Declare the supported options.
boost::program_options::options_description desc("Allowed options");
desc.add_options()("help", "produce help message");
boost::program_options::variables_map vm;
boost::program_options::store(boost::program_options::parse_command_line(ac, av, desc), vm);
return 0;
}
Run Code Online (Sandbox Code Playgroud)
它使用例如编译好g++ test.cpp -lboost_program_options.但是,如果我尝试使用该调用激活GCC边界检查g++ test.cpp -lboost_program_options -D_GLIBCXX_DEBUG,则会抛出以下链接器错误:
/tmp/ccZLdZ1g.o: In function `boost::program_options::basic_command_line_parser<char>::basic_command_line_parser(int, char const* const*)':
test.cpp:(.text._ZN5boost15program_options25basic_command_line_parserIcEC2EiPKPKc[_ZN5boost15program_options25basic_command_line_parserIcEC5EiPKPKc]+0x97): undefined reference to `boost::program_options::detail::cmdline::cmdline(std::__debug::vector<std::string, std::allocator<std::string> > const&)'
collect2: error: ld returned 1 exit status
Run Code Online (Sandbox Code Playgroud)
据我所知,链接器找不到该函数boost::program_options::detail::cmdline::cmdline(std::__debug::vector<std::string, std::allocator<std::string> > const&),因为它的参数被调试向量代替而不是正常std::vector.但为什么会这样呢?有没有人知道一个解决方法,使Boost程序选项适用GLIBCXX_DEBUG?
我使用以下系统:
我有一张代表配置的地图.这是地图std::string和boost::any.
此映射在开始时初始化,我希望用户能够在命令行上覆盖这些选项.
我喜欢做的是使用该options_description::add_option()方法从此地图构建程序选项.但是,它需要一个模板参数,po::value<>而我只有boost::any.
到目前为止,我只是拥有代码的shell. m_Config代表我的配置类,并getTuples()返回一个std::map<std::string, Tuple>. TuplePair是一个typedef std::pair<std::string, Tuple>和Tuple包含boost::any我感兴趣的.
po::options_description desc;
std::for_each(m_Config.getTuples().begin(),
m_Config.getTuples().end(),
[&desc](const TuplePair& _pair)
{
// what goes here? :)
// desc.add_options() ( _pair.first, po::value<???>, "");
});
Run Code Online (Sandbox Code Playgroud)
有没有办法以这种方式构建它,还是我需要自己去做?
提前致谢!
在下面的代码中,我使用程序选项从命令行或文件中读取参数.此外,可以通过ConfigProxy :: setConfig在运行时以编程方式设置选项
po::options_description desc("Allowed options");
desc.add_options()
...
("compression", po::value<int>(), "set compression level");
po::variables_map vm;
class ConfigProxy
{
template< typename T>
void setConfig( const std::string key, const T value ){
... // check if the key exists in variable map "vm"
// key exists, set the value
runtimeConfig[key] = po::variable_value( boost::any(value), false);
}
po::variable_value& operator[] (const std::string key) const{
...
// if exists in runtimeConfig return the value in runtimeConfig
// of type program_options::variable_value
...
// else return …Run Code Online (Sandbox Code Playgroud) 鉴于以下简单使用Boost.Program_Options:
boost::program_options::options_description options("Options");
options.add_options()
("my_bool_flag,b", boost::program_options::value<bool>(), "Sample boolean switch)")
;
Run Code Online (Sandbox Code Playgroud)
...什么命令行参数将评估false,以及什么true?
(即,假设程序名为"foo",并在命令行上执行:
foo -b ?
...带有问号的占位符,用于其他一些文本:所有可能正确评估的文本选项是false什么,以及什么true? )
c++ boost boolean command-line-arguments boost-program-options
我正在尝试用boost 1.58.0解析命令行.我的代码非常简单,可以从教程中复制\粘贴.它看起来像这样:
try {
po::options_description desc;
desc.add_options()
("version,v", "Display version of application.");
po::positional_options_description p;
p.add("input-file", -1);
try
{
po::store(po::command_line_parser(argc, argv).
options(desc).positional(p).run(), vm);
if ( vm.count("version") )
{
std::cout << "Program version: " << SHUF_T_VERSION << std::endl << "Boost library version: " << BOOST_LIB_VERSION << std::endl;
return false;
}
po::notify(vm); // throws on error, so do after help in case
// there are any problems
}
catch(po::error& e)
{
std::cerr << "ERROR: " << e.what() << std::endl << std::endl;
std::cerr << …Run Code Online (Sandbox Code Playgroud) 是否有任何方法可以使程序选项依赖于其他选项使用boost::program_options?
例如,我的程序可以接受以下示例参数:
wifi --scan --interface=en0
wifi --scan --interface=en0 --ssid=network
wifi --do_something_else
Run Code Online (Sandbox Code Playgroud)
在此示例中,interface和ssid参数仅在伴随时才有效scan.他们依赖于这个scan论点.
有没有办法自动执行此操作boost::program_options?它当然可以手动实现,但似乎必须有更好的方法.
我想让程序有两个选项,起始地址和结束地址,以便程序选项如下:
--start_address 0xc0000000 --end_address 0xffffffff
Run Code Online (Sandbox Code Playgroud)
是否可以options_description采用这种十六进制输入?我是否必须将输入视为字符串并将其转换为十六进制值.我现在有这个:
po::options_description desc("Allowed options");
desc.add_options()
("help,h", "display this help message")
("path,p", po::value<std::string>(), "Executable file path")
("start_address,s", po::value<std::string>(), "Start address")
("end_address,e", po::value<std::string>(), "End address")
;
Run Code Online (Sandbox Code Playgroud)
可以boost::lexical_cast做这样的转换吗?