X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/9f83044fb8785568e186bee64db4f98b7a9ac9c6..8d7ddd02649628327f8169cf2f4f9ee7b52f39c7:/include/wx/cmdline.h diff --git a/include/wx/cmdline.h b/include/wx/cmdline.h index 0b7576b8cf..a3a685ce3f 100644 --- a/include/wx/cmdline.h +++ b/include/wx/cmdline.h @@ -17,6 +17,10 @@ #pragma interface "cmdline.h" #endif +#include "wx/defs.h" + +#if wxUSE_CMDLINE_PARSER + #include "wx/string.h" class WXDLLEXPORT wxDateTime; @@ -32,7 +36,8 @@ enum wxCMD_LINE_OPTION_MANDATORY = 0x01, // this option must be given wxCMD_LINE_PARAM_OPTIONAL = 0x02, // the parameter may be omitted wxCMD_LINE_PARAM_MULTIPLE = 0x04, // the parameter may be repeated - wxCMD_LINE_OPTION_HELP = 0x08 // this option is a help request + wxCMD_LINE_OPTION_HELP = 0x08, // this option is a help request + wxCMD_LINE_NEEDS_SEPARATOR = 0x10 // must have sep before the value }; // an option value or parameter may be a string (the most common case), a @@ -95,20 +100,20 @@ public: // default ctor or ctor giving the cmd line in either Unix or Win form wxCmdLineParser() { Init(); } - wxCmdLineParser(int argc, char **argv) { Init(); SetCmdLine(argc, argv); } + wxCmdLineParser(int argc, wxChar **argv) { Init(); SetCmdLine(argc, argv); } wxCmdLineParser(const wxString& cmdline) { Init(); SetCmdLine(cmdline); } // the same as above, but also gives the cmd line description - otherwise, // use AddXXX() later wxCmdLineParser(const wxCmdLineEntryDesc *desc) { Init(); SetDesc(desc); } - wxCmdLineParser(const wxCmdLineEntryDesc *desc, int argc, char **argv) + wxCmdLineParser(const wxCmdLineEntryDesc *desc, int argc, wxChar **argv) { Init(); SetCmdLine(argc, argv); SetDesc(desc); } wxCmdLineParser(const wxCmdLineEntryDesc *desc, const wxString& cmdline) { Init(); SetCmdLine(cmdline); SetDesc(desc); } // set cmd line to parse after using one of the ctors which don't do it - void SetCmdLine(int argc, char **argv); + void SetCmdLine(int argc, wxChar **argv); void SetCmdLine(const wxString& cmdline); // not virtual, don't use this class polymorphically @@ -126,6 +131,9 @@ public: void EnableLongOptions(bool enable = TRUE); void DisableLongOptions() { EnableLongOptions(FALSE); } + // extra text may be shown by Usage() method if set by this function + void SetLogo(const wxString& logo); + // construct the cmd line description // ---------------------------------- @@ -181,7 +189,10 @@ public: size_t GetParamCount() const; // gets the value of Nth parameter (as string only for now) - wxString GetParam(size_t n) const; + wxString GetParam(size_t n = 0u) const; + + // Resets switches and options + void Reset(); private: // common part of all ctors @@ -190,4 +201,6 @@ private: struct wxCmdLineParserData *m_data; }; +#endif // wxUSE_CMDLINE_PARSER + #endif // _WX_CMDLINE_H_