This manual is for Arg_parser (version 1.19, 11 January 2025).
Copyright © 2006-2025 Antonio Diaz Diaz.
This manual is free documentation: you have unlimited permission to copy, distribute, and modify it.
Arg_parser is an argument parser that follows POSIX and GNU conventions for command-line arguments. There exist C++ and C versions of Arg_parser. The C++ version is implemented as a C++ class, while the C version is implemented as a single struct plus associated functions. Both are simpler, easier to use, and safer than 'getopt_long'.
For maximum stability, Arg_parser is self-contained. It extracts all the information it needs from its arguments to avoid refering to them later. This avoids index-out-of-bounds errors.
Arg_parser does not modify its arguments, nor uses any global variables. So you may create more than one parser in your program if you need or want to.
The C++ version of Arg_parser can also parse options from configuration files.
Arg_parser was developed as the argument parser for GNU moe, because moe's argument parsing is rather complex. Then I used it in my other projects, including GNU ddrescue, GNU ed, lzip, GNU ocrad, tarlz, and zutils, with excellent results.
POSIX recommends these conventions for command-line arguments. Arg_parser makes it easy to implement them.
Arg_parser normally makes it appear as if all the option arguments were specified before all the non-option arguments for the purposes of parsing, even if the user of your program intermixed option and non-option arguments. If you want the arguments in the exact order the user typed them, call 'Arg_parser' with in_order = true.
GNU adds long options to these conventions:
The syntax of options with an optional argument is -<short_option><argument> (without whitespace), or --<long_option>=<argument>.
The syntax of options with an empty argument is -<short_option> "", --<long_option> "", or --<long_option>="".
To use Arg_parser in your own programs first copy the files arg_parser.h and arg_parser.cc in your source tree. See the file main.cc for an example of use.
The class 'Arg_parser' has two constructors; one to parse command-line arguments from argv, and the other to parse a single token from a configuration file or other source.
This structure describes a single option for the sake of 'Arg_parser'. The argument options must be an array of these structures, one for each option. Terminate the array with an element containing a code which is zero.
'struct Option' has the following members:
int code
- This member is the code that identifies the option, normally the short-option character. Must be different from 0. A code value outside the unsigned char range means a long-only option.
const char * long_name
- This member is the long option name. It is a zero-terminated string. A null or empty long_name means a short-only option.
enum Has_arg has_arg
- This member says whether the option takes an argument. It has four valid values: 'no', 'yes', 'maybe', and 'yme', meaning respectively 'no argument', 'non-empty argument required', 'optional argument', and 'argument required, but it may be the empty string'. 'yme' is not recommended.
If an empty argument is passed to an option specified as 'yme', it must be in a separate command-line argument or specified as a long option with the empty string after the '=' character. It can't be specified as the empty string after the short option.
Constructor. Reads the arguments in argv and parses all options, option arguments, and non-option arguments contained in them. In case of error, 'error().size()' returns nonzero.
Restricted constructor. Parses a single token (plus an optional second token in case an argument is needed for an option parsed). Can be used to parse options from a configuration file one at a time. Be warned that a single token may produce an undefined number of short options. In case of error, 'error().size()' returns nonzero.
Use this funtion to check that the arguments have been correctly parsed by the constructor. If there was an error parsing the arguments, 'error' returns an error message explaining the cause.
After a successful call to the constructor, which must be checked by calling 'error', the options and arguments parsed can be accessed by means of the following functions:
This function returns the number of options and non-option arguments parsed. This number is usually different from argc.
This function returns the code of the option at position i. Valid values for i range from 0 to 'arguments() - 1'. If the code returned is nonzero, 'argument(i)' is the option's argument (or is empty if the option does not have an argument). If the code returned is zero, 'argument(i)' is a non-option argument.
This function returns the full name of the option parsed (short or long) at position i. It may be useful to produce more accurate diagnostic messages. For non-option arguments it returns the empty string.
This function returns the argument at position i. It may be the argument of an option or a non-option argument, depending on the value returned by 'code(i)'. Valid values for i range from 0 to 'arguments() - 1'. If the argument does not exist, the empty string is returned.
To use the C version of Arg_parser in your own programs first copy the files carg_parser.h and carg_parser.c in your source tree. See the file cmain.c for an example of use.
Then you need to declare a variable of type 'Arg_parser', pass its address to 'ap_init' to initialize it, and check that 'ap_error' returns 0.
'struct ap_Option' is identical to 'struct Option', except that 'Has_arg' becomes 'ap_Has_arg', and the names of its four values are also prefixed with 'ap_'. See struct Option, for details about the members.
Reads the arguments in argv and parses all options, option arguments, and non-option arguments contained in them. Returns 0 if there is not enough memory, else 1. In case of error, 'ap_error' returns a non-null pointer.
Frees all dynamically allocated data structures.
Use this funtion to check that the arguments have been correctly parsed by 'ap_init'. If there was an error parsing the arguments, 'ap_error' returns a pointer to an error message explaining the cause, else it returns a null pointer.
After a successful call to 'ap_init', which must be checked by calling 'ap_error', the options and arguments parsed can be accessed by means of the following functions:
This function returns the number of options and non-option arguments parsed. This number is usually different from argc.
This function returns the code of the option at position i. Valid values for i range from 0 to 'ap_arguments() - 1'. If the code returned is nonzero, 'ap_argument(i)' is the option's argument (or is empty if the option does not have an argument). If the code returned is zero, 'ap_argument(i)' is a non-option argument.
This function returns the full name of the option parsed (short or long) at position i. It may be useful to produce more accurate diagnostic messages. For non-option arguments it returns the empty string.
This function returns the argument at position i. It may be the argument of an option or a non-option argument, depending on the value returned by 'ap_code(i)'. Valid values for i range from 0 to 'ap_arguments() - 1'. If the argument does not exist, the empty string is returned.
When you are finished, you should free all dynamically allocated data structures by calling 'ap_free'.
There are probably bugs in Arg_parser. There are certainly errors and omissions in this manual. If you report them, they will get fixed. If you don't, no one will ever know about them and they will remain unfixed for all eternity, if not longer.
If you find a bug in Arg_parser, please send electronic mail to arg-parser-bug@nongnu.org. Include the version number, which you can find by running 'arg_parser --version'.