#ifndef ARGPARSE_HPP #define ARGPARSE_HPP #include #include #include #include /** @brief Aim to achieve the functionality of Python argparse * * http://docs.python.org/library/argparse.html#module-argparse */ class ArgParse { public: enum ValueType { NONE, STRING, INT, DOUBLE, BOOL }; enum ValueRequired { OPTIONAL, REQUIRED }; /** @param description Exmplanation, before the usage lines. * @param epilog Lines after the usage and options. Usually contact e-mail. * @param addHelp Add a "-h,--help" option. */ ArgParse(const std::string description, const std::string epilog = std::string(""), const bool addHelp = true); /** @brief Adds an argument which the object will accept. * * @param name short and/or long form: "-f,--foo" * @param help Description of the argument, printed when --help is given. * @param type Type of the paramterer, required by the argument. * @param valueRequired Parameter requiered/optional after the argument. * @param valueName Default is the type. But some short text can be better. * @param choices Comma separeted list of strings: "yes,no,maybe" * or a range accepted numbers: NUM..NUM */ void addArgument(const std::string name, const std::string help, const enum ValueType type = NONE, const enum ValueRequired valueRequired = REQUIRED, const std::string valueName = std::string(""), const std::string choices = std::string("")); /** @brief Parse command line arguments according to the accepted arguments. * * Wrapper around the other version of parseArgs. * * @param argc Argumetn counter of the main function. * @param argv Argument vector of the main function. * @throw std::runtime_error When the command line args are bad. * Shall be cought be the client code! * @throw std::logic_error If the addArgument was bad. * @todo addArgument shall handle this! */ void parseArgs(const int argc, const char* argv[]); void parseArgs(const std::list argList); // is this arg in the map of understood arguments? bool isArg(const std::string arg) const; // is this argument passed as a command line parameter? bool foundArg(const std::string arg) const; // argument is passed as a command line parameter, but has a value? bool argHasValue(const std::string arg) const; // return true is arg exists and the arg in &value // arg need to be the same string as in addArgument ( "-h,--help" ) bool argAsString(const std::string arg, std::string &value) const; bool argAsInt(const std::string arg, int &value) const; bool argAsDouble(const std::string arg, double &value) const; bool argAsBool(const std::string arg, bool &value) const; std::string usage() const; private: struct Argument { const std::string m_help; const enum ValueType m_type; const enum ValueRequired m_valueRequired; const std::string m_valueName; const std::string m_choices; std::string m_value; bool m_found; bool m_valueHasBeenSet; Argument (const std::string help, const enum ValueType type = NONE, const enum ValueRequired valueRequired = REQUIRED, const std::string valueName = std::string(""), const std::string choices = std::string(""), const std::string value = std::string("")); }; class argCompare { public: // short and long arg shall be compared with same amount of dashes bool operator()(const std::string a,const std::string b) const; }; typedef std::map ArgMap; // arg is just the shor or long form: "-h" or "--help" ArgMap::iterator findElement(const std::string param); std::set parseCommaSepStringToSet(const std::string s) const; std::string typeToString(const ValueType type, const std::string valueName) const; std::string m_description; std::string m_epilog; std::string m_programName; ArgMap m_params; }; // class ArgParse #endif // ARGPARSE_HPP