boost
Расширенные возможности программы
Поиск…
Основное использование
Расширенные параметры программы обеспечивают простой и безопасный способ анализа и обработки аргументов командной строки.
#include <boost/program_options.hpp>
#include <string>
#include <iostream>
int main(int argc, char** argv) {
namespace po = boost::program_options;
po::variables_map vm;
po::options_description desc("Allowed Options");
// declare arguments
desc.add_options()
("name", po::value<std::string>()->required(), "Type your name to be greeted!");
// parse arguments and save them in the variable map (vm)
po::store(po::parse_command_line(argc, argv, desc), vm);
std::cout << "Hello " << vm["name"].as<std::string>() << std::endl;
return 0;
}
Скомпилируйте и запустите:
$ g++ main.cpp -lboost_program_options && ./a.out --name Batman
Hello Batman
Вы можете вывести объект boost::program_options::options_description для печати ожидаемого формата аргумента:
std::cout << desc << std::endl;
будет производить:
Allowed Options:
--name arg Type your name to be greeted!
Обработка ошибок
boost::program_options::notify может использоваться для сообщения любых ошибок при передаче параметров
#include <boost/program_options.hpp>
#include <string>
#include <iostream>
int main(int argc, char** argv) {
namespace po = boost::program_options;
po::variables_map vm;
po::options_description desc("Allowed Options");
// declare options
desc.add_options()
("name", po::value<std::string>()->required(), "Type your name to be greeted!");
// parse arguments
po::store(po::parse_command_line(argc, argv, desc), vm);
// check arguments
try {
po::notify(vm);
} catch (std::exception& e) {
std::cout << "Error: " << e.what() << std::endl;
std::cout << desc << std::endl;
return 1;
}
// program logic
std::cout << "Hello " << vm["name"].as<std::string>() << std::endl;
return 0;
}
Передача незаконных аргументов приводит к сообщениям об ошибках
$ ./a.out
Error: the option '--name' is required but missing
Allowed Options:
--name arg Type your name to be greeted!
Значения по умолчанию
Аргумент командной строки по умолчанию может быть легко задан:
// declare options
desc.add_options()
("name", po::value<std::string>()->required(), "Type your name to be greeted!")
("rank", po::value<std::string>()->default_value("Dark Knight"), "Your rank");
Его значение также добавляется к карте переменных:
std::cout << "Hello " << vm["name"].as<std::string>() << " " << vm["rank"].as<std::string>() << std::endl;
Значение по умолчанию показано в описании ...
$ ./a.out
Error: the option '--name' is required but missing
Allowed Options:
--name arg Type your name to be greeted!
--rank arg (=Dark Knight) Your rank
... и используется, если не указано ...
$ ./a.out --name Batman
Hello Batman Dark Knight
... но может быть перезаписана в командной строке:
$ ./a.out --name Batman --rank FlyingSquirrel
Hello Batman FlyingSquirrel
Выключатели
Коммутатор - это аргумент командной строки, который не принимает значения. Его можно указать с помощью:
desc.add_options()
("hidden", po::bool_switch()->default_value(false), "Hide your name");
И используется с:
if (vm["hidden"].as<bool>())
std::cout << "Hello *****" << std::endl;
из командной строки:
$ ./a.out --name Batman --hidden
Hello *****
и в описании это показано как:
Allowed Options:
--name arg Type your name to be greeted!
--rank arg (=Dark Knight) Your rank
--hidden Hide your name