wxcmdlineparserwxcmdlineparser is a class for parsing the command line. it has the following features:
to use it you should follow these steps:
in the documentation below the following terminology is used:
derived from no base class include files <wx/cmdline.h> constants the structure wxcmdlineentrydesc is used to describe the one command line switch, option or parameter. an array of such structures should be passed to setdesc(). also, the meanings of parameters of the addxxx() functions are the same as of the corresponding fields in this structure:
struct wxcmdlineentrydesc { wxcmdlineentrytype kind; const wxchar *shortname; const wxchar *longname; const wxchar *description; wxcmdlineparamtype type; int flags; };the type of a command line entity is in the kind field and may be one of the following constants:
the field shortname is the usual, short, name of the switch or the option. longname is the corresponding long name or null if the option has no long name. both of these fields are unused for the parameters. both the short and long option names can contain only letters, digits and the underscores. description is used by the usage() method to construct a help message explaining the syntax of the program. the possible values of type which specifies the type of the value accepted by an option or parameter are:
finally, the flags field is a combination of the following bit masks:
notice that by default (i.e. if flags are just 0), options are optional (sic) and each call to addparam() allows one more parameter - this may be changed by giving non-default flags to it, i.e. use wxcmd_line_option_mandatory to require that the option is given and wxcmd_line_param_optional to make a parameter optional. also, wxcmd_line_param_multiple may be specified if the programs accepts a variable number of parameters - but it only can be given for the last parameter in the command line description. if you use this flag, you will probably need to use getparamcount to retrieve the number of parameters effectively specified after calling parse. the last flag wxcmd_line_needs_separator can be specified to require a separator (either a colon, an equal sign or white space) between the option name and its value. by default, no separator is required. see also
wxapp::argc and wxapp::argv function groups
construction
constructionbefore parse can be called, the command line parser object must have the command line to parse and also the rules saying which switches, options and parameters are valid - this is called command line description in what follows. you have complete freedom of choice as to when specify the required information, the only restriction is that it must be done before calling parse. to specify the command line to parse you may use either one of constructors accepting it (wxcmdlineparser(argc, argv) or wxcmdlineparser usually) or, if you use the default constructor, you can do it later by calling setcmdline. the same holds for command line description: it can be specified either in the constructor (without command line or together with it) or constructed later using either setdesc or combination of addswitch, addoption and addparam methods. using constructors or setdesc uses a (usually const static) table containing the command line description. if you want to decide which options to accept during the run-time, using one of the addxxx() functions above might be preferable.
customizationwxcmdlineparser has several global options which may be changed by the application. all of the functions described in this section should be called before parse. first global option is the support for long (also known as gnu-style) options. the long options are the ones which start with two dashes ("--") and look like this: --verbose, i.e. they generally are complete words and not some abbreviations of them. as long options are used by more and more applications, they are enabled by default, but may be disabled with disablelongoptions. another global option is the set of characters which may be used to start an option (otherwise, the word on the command line is assumed to be a parameter). under unix, '-' is always used, but windows has at least two common choices for this: '-' and '/'. some programs also use '+'. the default is to use what suits most the current platform, but may be changed with setswitchchars method. finally, setlogo can be used to show some application-specific text before the explanation given by usage function.
parsing command lineafter the command line description was constructed and the desired options were set, you can finally call parse method. it returns 0 if the command line was correct and was parsed, -1 if the help option was specified (this is a separate case as, normally, the program will terminate after this) or a positive number if there was an error during the command line parsing. in the latter case, the appropriate error message and usage information are logged by wxcmdlineparser itself using the standard wxwidgets logging functions.
getting resultsafter calling parse (and if it returned 0), you may access the results of parsing using one of overloaded found() methods. for a simple switch, you will simply call found to determine if the switch was given or not, for an option or a parameter, you will call a version of found() which also returns the associated value in the provided variable. all found() functions return true if the switch or option were found in the command line or false if they were not specified.
wxcmdlineparser::wxcmdlineparserwxcmdlineparser() default constructor. you must use setcmdline later.
wxcmdlineparser::wxcmdlineparserwxcmdlineparser(int argc, char** argv) wxcmdlineparser(int argc, wchar_t** argv) constructor specifies the command line to parse. this is the traditional (unix) command line format. the parameters argc and argv have the same meaning as for main() function. the second overloaded constructor is only available in unicode build. the first one is available in both ansi and unicode modes because under some platforms the command line arguments are passed as ascii strings even to unicode programs.
wxcmdlineparser::wxcmdlineparserwxcmdlineparser(const wxstring& cmdline) constructor specifies the command line to parse in windows format. the parameter cmdline has the same meaning as the corresponding parameter of winmain().
wxcmdlineparser::wxcmdlineparserwxcmdlineparser(const wxcmdlineentrydesc* desc) same as wxcmdlineparser, but also specifies the command line description.
wxcmdlineparser::wxcmdlineparserwxcmdlineparser(const wxcmdlineentrydesc* desc, int argc, char** argv) same as wxcmdlineparser, but also specifies the command line description.
wxcmdlineparser::wxcmdlineparserwxcmdlineparser(const wxcmdlineentrydesc* desc, const wxstring& cmdline) same as wxcmdlineparser, but also specifies the command line description.
wxcmdlineparser::convertstringtoargsstatic wxarraystring convertstringtoargs(const wxchar *cmdline) breaks down the string containing the full command line in words. the words are separated by whitespace. the quotes can be used in the input string to quote the white space and the back slashes can be used to quote the quotes.
wxcmdlineparser::setcmdlinevoid setcmdline(int argc, char** argv) void setcmdline(int argc, wchar_t** argv) set command line to parse after using one of the constructors which don't do it. the second overload of this function is only available in unicode build. see also
wxcmdlineparser::setcmdlinevoid setcmdline(const wxstring& cmdline) set command line to parse after using one of the constructors which don't do it. see also
wxcmdlineparser::~wxcmdlineparser~wxcmdlineparser() frees resources allocated by the object. nb: destructor is not virtual, don't use this class polymorphically.
wxcmdlineparser::setswitchcharsvoid setswitchchars(const wxstring& switchchars) switchchars contains all characters with which an option or switch may start. default is "-" for unix, "-/" for windows.
wxcmdlineparser::enablelongoptionsvoid enablelongoptions(bool enable = true) enable or disable support for the long options. as long options are not (yet) posix-compliant, this option allows to disable them. see also customization and arelongoptionsenabled
wxcmdlineparser::disablelongoptionsvoid disablelongoptions() identical to enablelongoptions(false).
wxcmdlineparser::arelongoptionsenabledbool arelongoptionsenabled() returns true if long options are enabled, otherwise false. see also
wxcmdlineparser::setlogovoid setlogo(const wxstring& logo) logo is some extra text which will be shown by usage method.
wxcmdlineparser::setdescvoid setdesc(const wxcmdlineentrydesc* desc) construct the command line description take the command line description from the wxcmd_line_none terminated table. example of usage:
static const wxcmdlineentrydesc cmdlinedesc[] = { { wxcmd_line_switch, "v", "verbose", "be verbose" }, { wxcmd_line_switch, "q", "quiet", "be quiet" }, { wxcmd_line_option, "o", "output", "output file" }, { wxcmd_line_option, "i", "input", "input dir" }, { wxcmd_line_option, "s", "size", "output block size", wxcmd_line_val_number }, { wxcmd_line_option, "d", "date", "output file date", wxcmd_line_val_date }, { wxcmd_line_param, null, null, "input file", wxcmd_line_val_string, wxcmd_line_param_multiple }, { wxcmd_line_none } }; wxcmdlineparser parser; parser.setdesc(cmdlinedesc); wxcmdlineparser::addswitchvoid addswitch(const wxstring& name, const wxstring& lng = wxemptystring, const wxstring& desc = wxemptystring, int flags = 0) add a switch name with an optional long name lng (no long name if it is empty, which is default), description desc and flags flags to the command line description.
wxcmdlineparser::addoptionvoid addoption(const wxstring& name, const wxstring& lng = wxemptystring, const wxstring& desc = wxemptystring, wxcmdlineparamtype type = wxcmd_line_val_string, int flags = 0) add an option name with an optional long name lng (no long name if it is empty, which is default) taking a value of the given type (string by default) to the command line description.
wxcmdlineparser::addparamvoid addparam(const wxstring& desc = wxemptystring, wxcmdlineparamtype type = wxcmd_line_val_string, int flags = 0) add a parameter of the given type to the command line description.
wxcmdlineparser::parseint parse(bool giveusage = true) parse the command line, return 0 if ok, -1 if "-h" or "--help" option was encountered and the help message was given or a positive value if a syntax error occurred. parameters giveusage
wxcmdlineparser::usagevoid usage() give the standard usage message describing all program options. it will use the options and parameters descriptions specified earlier, so the resulting message will not be helpful to the user unless the descriptions were indeed specified. see also
wxcmdlineparser::foundbool found(const wxstring& name) const returns true if the given switch was found, false otherwise.
wxcmdlineparser::foundbool found(const wxstring& name, wxstring* value) const returns true if an option taking a string value was found and stores the value in the provided pointer (which should not be null).
wxcmdlineparser::foundbool found(const wxstring& name, long* value) const returns true if an option taking an integer value was found and stores the value in the provided pointer (which should not be null).
wxcmdlineparser::foundbool found(const wxstring& name, wxdatetime* value) const returns true if an option taking a date value was found and stores the value in the provided pointer (which should not be null).
wxcmdlineparser::getparamcountsize_t getparamcount() const returns the number of parameters found. this function makes sense mostly if you had used wxcmd_line_param_multiple flag.
wxcmdlineparser::getparamwxstring getparam(size_t n = 0u) const returns the value of nth parameter (as string only for now). see also
|