FreeBSD manual
download PDF document: xo_parse_args.3.pdf
LIBXO(3) FreeBSD Library Functions Manual LIBXO(3)
NAME
xo_parse_args, xo_set_program - detect, parse, and remove arguments for
libxo
LIBRARY
Text, XML, JSON, and HTML Output Emission Library (libxo, -lxo)
SYNOPSIS
#include <libxo/xo.h>
int
xo_parse_args(int argc, char **argv);
int
xo_set_program(const char *name);
DESCRIPTION
The xo_parse_args() function is used to process command-line arguments,
which are described in xo_options(7). libxo specific options are
processed and removed from the argument list so the calling application
does not need to process them. If successful, a new value for argc is
returned. On failure, a message it emitted and -1 is returned.
argc = xo_parse_args(argc, argv);
if (argc < 0)
exit(EXIT_FAILURE);
Following the call to xo_parse_args(), the application can process the
remaining arguments in a normal manner.
The xo_set_program() function sets name of the program as reported by
functions like xo_failure(), xo_warn(), xo_err(), etc. The program name
is initialized by xo_parse_args(), but subsequent calls to
xo_set_program() can override this value.
Note that the value is not copied, so the memory passed to
xo_set_program() (and xo_parse_args()) must be maintained by the caller.
SEE ALSO
xo_emit(3), xo_options(7,) libxo(3)
HISTORY
The libxo library first appeared in FreeBSD 11.0.
AUTHORS
libxo was written by Phil Shafer <phil@freebsd.org>.
FreeBSD 14.2-RELEASE November 17, 2020 FreeBSD 14.2-RELEASE