BRL-CAD
|
Generalized option handling. More...
Modules | |
Pre-Defined Option Parsers | |
Files | |
file | opt.h |
Data Structures | |
struct | bu_opt_desc |
"Option description" structure. More... | |
struct | bu_opt_desc_opts |
Macros | |
#define | BU_OPT_CHECK_ARGV0(_msg, _argc, _argv, _opt_name) |
#define | BU_OPT_DESC_NULL {NULL, NULL, NULL, NULL, NULL, NULL} |
#define | BU_OPT(_desc, _so, _lo, _ahelp, _aprocess, _var, _help) |
#define | BU_OPT_NULL(_desc) |
#define | BU_OPT_DESC_OPTS_INIT_ZERO { BU_OPT_ASCII, 2, 28, 50, NULL, NULL, NULL, 1, NULL, NULL } |
Typedefs | |
typedef int(* | bu_opt_arg_process_t) (struct bu_vls *msg, size_t argc, const char **argv, void *set_var) |
Enumerations | |
enum | bu_opt_format_t { BU_OPT_ASCII , BU_OPT_DOCBOOK } |
Functions | |
int | bu_opt_parse (struct bu_vls *msgs, size_t ac, const char **argv, const struct bu_opt_desc *ds) |
char * | bu_opt_describe (const struct bu_opt_desc *ds, struct bu_opt_desc_opts *settings) |
Generalized option handling.
This module implements a callback and assignment based mechanism for generalized handling of option handling. Functionally it is intended to provide capabilities similar to getopt_long, Qt's QCommandLineParser, and the tclap library. Results are returned by way of variable assignment, and function callbacks are used to convert and validate argument strings.
The bu_opt option parsing system does not make any use of global values, unless a user defines an option definition array that passes in pointers to global variables for setting.
To set up a bu_opt parsing system, an array of bu_opt_desc (option description) structures is defined and terminated with a BU_OPT_DESC_NULL entry. This array is then used by bu_opt_parse to process an argv array.
When defining a bu_opt_desc entry, the type of the set_var assignment variable needed is determined by the arg_process callback. If no callback is present, set_var is expected to be an integer that will be set to 1 if the option is present in the argv string.
There are two styles in which a bu_opt_desc array may be initialized. The first is very compact but in C89 based code requires static variables as set_var entries, as seen in the following example:
This style of initialization is suitable for application programs, but in libraries such static variables will preclude thread and reentrant safety. For libraries, the BU_OPT and BU_OPT_NULL macros are used to construct a bu_opt_desc array that does not require static variables:
Given the option description array and argc/argv data, bu_opt_parse will do the rest. The design of bu_opt_parse is to fail early when an invalid option situation is encountered, so code using this system needs to be ready to handle such cases.
For generating descriptive help strings from a bu_opt_desc array use the bu_opt_describe function, which supports multiple output styles and formats.
#define BU_OPT_CHECK_ARGV0 | ( | _msg, | |
_argc, | |||
_argv, | |||
_opt_name | |||
) |
A common task when writing bu_opt_arg_process_t validators is to check the first argument of the argv array. This macro encapsulates that into a standard check.
#define BU_OPT_DESC_NULL {NULL, NULL, NULL, NULL, NULL, NULL} |
Convenience initializer for NULL bu_opt_desc array terminator
#define BU_OPT | ( | _desc, | |
_so, | |||
_lo, | |||
_ahelp, | |||
_aprocess, | |||
_var, | |||
_help | |||
) |
Macro for assigning values to bu_opt_desc array entries.
#define BU_OPT_NULL | ( | _desc | ) |
Convenience macro for setting a bu_opt_desc struct to BU_OPT_DESC_NULL
#define BU_OPT_DESC_OPTS_INIT_ZERO { BU_OPT_ASCII, 2, 28, 50, NULL, NULL, NULL, 1, NULL, NULL } |
initialize an bu_opt_desc_opts struct.
Out of the box, assume an overall column width of 80 characters. Given that width, we do a default partitioning. The first three numbers tell the option printer what column breakout to use for various components of the lines:
offset = 2 is the default column offsetting from the left edge option_columns = The next 28 columns are for printing the option and its aliases description_columns = The remaining 50 columns are for human readable explanations of the option
These values were chosen after some casual experimentation/observation to see what "looked right" for Linux command line option printing - if better values (perhaps based on some OS convention or standard) are available, it would be better to use those and document their source.
typedef int(* bu_opt_arg_process_t) (struct bu_vls *msg, size_t argc, const char **argv, void *set_var) |
Callback function signature for bu_opt_desc argument processing functions. Any user defined argument processing function should match this signature and return values as documented below.
[out] | msg | If not NULL, callback messages (usually error descriptions) may be appended here. |
[in] | argc | Number of arguments in argv. |
[in] | argv | All arguments that follow the option flag. |
[in,out] | set_var | The value specified in the associated bu_opt_desc. |
Val | Interpretation |
---|---|
-1 | Invalid argument encountered, or argument expected but not found. |
0 | No argument processed (not an error.) |
>0 | Number of argv elements used in valid argument processing. |
An example user-defined argument processing function:
enum bu_opt_format_t |
int bu_opt_parse | ( | struct bu_vls * | msgs, |
size_t | ac, | ||
const char ** | argv, | ||
const struct bu_opt_desc * | ds | ||
) |
Parse argv
array using option descriptions.
The bu_opt_desc array ds
must be terminated with BU_OPT_DESC_NULL.
Val | Interpretation |
---|---|
-1 | Fatal error in parsing. Program must decide to recover or exit. |
0 | All argv options handled. |
>0 | Number of unused argv entries returned at the beginning of the argv array. |
[out] | msgs | will collect any informational messages generated by the parser (typically used for error reporting) |
[in] | ac | number of input arguments in argv |
[in,out] | argv | a return value >0 indicates that argv has been reordered to move the indicated number of unused args to the beginning of the array |
[in] | ds | option structure |
char* bu_opt_describe | ( | const struct bu_opt_desc * | ds, |
struct bu_opt_desc_opts * | settings | ||
) |
Using the example definition:
bu_opt_describe would generate the following help string by default:
-h, --help Print help string and exit. -n #, --num # Read int -f #, --fastf_t # Read float
When multiple options use the same set_var to capture their effect, they are considered aliases for documentation purposes. For example, if we add multiple aliases to the help option and make it more elaborate:
the generated help string reflects this:
-h [type], -H [type], -? [type], --help [type], --HELP [type] Print help and exit. If a type is specified to --help, print help specific to that type -n #, --num # Read int -f #, --fastf_t # Read float