mirror of
https://github.com/jarro2783/cxxopts.git
synced 2026-01-18 01:11:24 +01:00
3656e0b6d45d87595d26685c9d23f8afa7a37efb
== Quick start ==
This is a lightweight C++ option parser library, supporting the standard GNU
style syntax for options.
Options can be given as:
--long
--long=argument
--long argument
-a
-ab
-abc argument
where c takes an argument, but a and b do not.
How to use:
#include <cxxopts.hpp>
Create a cxxopts::Options instance.
cxxopts::Options options;
Then use add_options.
options.add_options()
("d,debug", "Enable debugging")
("f,file", "File name", cxxopts::value<std::string>())
Options can be declared with a short and/or long option. A description must be
provided. The third argument is the value, if omitted it is boolean. Any type
can be given as long as it can be parsed, with operator>>.
To parse the command line do:
options.parse(argc, argv);
To retrieve an option use options.count("option") to get the number of times
it appeared, and
options["opt"].as<type>()
to get its value. If "opt" doesn't exist, or isn't of the right type, then an
exception will be thrown.
== Linking ==
Compile with -lcxxopts.
== Requirements ==
The only build requirement is a C++ compiler that supports C++11 regular
expressions. For example GCC >= 4.9 or clang with libc++.
== TODO list ==
* Allow unrecognised options.
* Option groups.
Languages
C++
96.8%
CMake
2.1%
Meson
0.8%
Python
0.2%
Starlark
0.1%