mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
Added some more modification documentation
This commit is contained in:
parent
baba35c998
commit
8e8e63011f
67
dependencies/include/getoptPlusPlus/getoptpp.h
vendored
67
dependencies/include/getoptPlusPlus/getoptpp.h
vendored
@ -19,7 +19,8 @@
|
|||||||
*
|
*
|
||||||
* - Removed using namespace std from header
|
* - Removed using namespace std from header
|
||||||
* - Changed Parameter container type from std::set to std::list to presume order
|
* - Changed Parameter container type from std::set to std::list to presume order
|
||||||
*
|
* - Changed arguments of Parameters to be a seperated arguments on the command line
|
||||||
|
* - Make the choice of receiving arguments or not in subclasses of CommonParameter
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <list>
|
#include <list>
|
||||||
@ -50,7 +51,7 @@ public:
|
|||||||
Parameter& operator[](char c) const;
|
Parameter& operator[](char c) const;
|
||||||
|
|
||||||
/** Find a parameter by long option form. */
|
/** Find a parameter by long option form. */
|
||||||
Parameter& operator[](const std::string &s) const;
|
Parameter& operator[](const std::string &s) const;
|
||||||
|
|
||||||
/** Factory method that adds a new parameter of
|
/** Factory method that adds a new parameter of
|
||||||
* type T to the set.
|
* type T to the set.
|
||||||
@ -72,7 +73,7 @@ public:
|
|||||||
~ParameterSet();
|
~ParameterSet();
|
||||||
protected:
|
protected:
|
||||||
friend class OptionsParser;
|
friend class OptionsParser;
|
||||||
std::list<Parameter*> parameters;
|
std::list<Parameter*> parameters;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ParameterSet(const ParameterSet& ps);
|
ParameterSet(const ParameterSet& ps);
|
||||||
@ -94,7 +95,7 @@ public:
|
|||||||
ParameterSet& getParameters();
|
ParameterSet& getParameters();
|
||||||
|
|
||||||
/** Parse command line arguments */
|
/** Parse command line arguments */
|
||||||
void parse(int argc, const char* argv[]) throw(std::runtime_error);
|
void parse(int argc, const char* argv[]) throw(std::runtime_error);
|
||||||
|
|
||||||
/** Generate a usage screen */
|
/** Generate a usage screen */
|
||||||
void usage() const;
|
void usage() const;
|
||||||
@ -102,16 +103,16 @@ public:
|
|||||||
/** Return the name of the program, as
|
/** Return the name of the program, as
|
||||||
* given by argv[0]
|
* given by argv[0]
|
||||||
*/
|
*/
|
||||||
const std::string& programName() const;
|
const std::string& programName() const;
|
||||||
|
|
||||||
/** Return a vector of each non-parameter */
|
/** Return a vector of each non-parameter */
|
||||||
const std::vector<std::string>& getFiles() const;
|
const std::vector<std::string>& getFiles() const;
|
||||||
protected:
|
protected:
|
||||||
std::string argv0;
|
std::string argv0;
|
||||||
std::string fprogramDesc;
|
std::string fprogramDesc;
|
||||||
|
|
||||||
ParameterSet parameters;
|
ParameterSet parameters;
|
||||||
std::vector<std::string> files;
|
std::vector<std::string> files;
|
||||||
|
|
||||||
friend class ParserState;
|
friend class ParserState;
|
||||||
};
|
};
|
||||||
@ -123,18 +124,18 @@ protected:
|
|||||||
|
|
||||||
class ParserState {
|
class ParserState {
|
||||||
public:
|
public:
|
||||||
const std::string peek() const;
|
const std::string peek() const;
|
||||||
const std::string get() const;
|
const std::string get() const;
|
||||||
void advance();
|
void advance();
|
||||||
bool end() const;
|
bool end() const;
|
||||||
protected:
|
protected:
|
||||||
ParserState(OptionsParser &opts, std::vector<std::string>& args);
|
ParserState(OptionsParser &opts, std::vector<std::string>& args);
|
||||||
private:
|
private:
|
||||||
friend class OptionsParser;
|
friend class OptionsParser;
|
||||||
|
|
||||||
OptionsParser &opts;
|
OptionsParser &opts;
|
||||||
const std::vector<std::string> &arguments;
|
const std::vector<std::string> &arguments;
|
||||||
std::vector<std::string>::const_iterator iterator;
|
std::vector<std::string>::const_iterator iterator;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -148,27 +149,27 @@ public:
|
|||||||
|
|
||||||
/** Generic exception thrown when a parameter is malformed
|
/** Generic exception thrown when a parameter is malformed
|
||||||
*/
|
*/
|
||||||
class ParameterRejected : public std::runtime_error {
|
class ParameterRejected : public std::runtime_error {
|
||||||
public:
|
public:
|
||||||
ParameterRejected(const std::string& s) : std::runtime_error(s) {}
|
ParameterRejected(const std::string& s) : std::runtime_error(s) {}
|
||||||
ParameterRejected() : runtime_error("") {}
|
ParameterRejected() : runtime_error("") {}
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Exception thrown when a parameter did not expect an argument */
|
/** Exception thrown when a parameter did not expect an argument */
|
||||||
class UnexpectedArgument : public ParameterRejected {
|
class UnexpectedArgument : public ParameterRejected {
|
||||||
public:
|
public:
|
||||||
UnexpectedArgument(const std::string &s) : ParameterRejected(s) {}
|
UnexpectedArgument(const std::string &s) : ParameterRejected(s) {}
|
||||||
UnexpectedArgument() {}
|
UnexpectedArgument() {}
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Exception thrown when a parameter expected an argument */
|
/** Exception thrown when a parameter expected an argument */
|
||||||
class ExpectedArgument : public ParameterRejected {
|
class ExpectedArgument : public ParameterRejected {
|
||||||
public:
|
public:
|
||||||
ExpectedArgument(const std::string &s) : ParameterRejected(s) {}
|
ExpectedArgument(const std::string &s) : ParameterRejected(s) {}
|
||||||
ExpectedArgument() {}
|
ExpectedArgument() {}
|
||||||
};
|
};
|
||||||
|
|
||||||
Parameter(char shortOption, const std::string & longOption, const std::string & description);
|
Parameter(char shortOption, const std::string & longOption, const std::string & description);
|
||||||
|
|
||||||
virtual ~Parameter();
|
virtual ~Parameter();
|
||||||
|
|
||||||
@ -176,16 +177,16 @@ public:
|
|||||||
virtual bool isSet() const = 0;
|
virtual bool isSet() const = 0;
|
||||||
|
|
||||||
/** This parameter's line in OptionsParser::usage() */
|
/** This parameter's line in OptionsParser::usage() */
|
||||||
virtual std::string usageLine() const = 0;
|
virtual std::string usageLine() const = 0;
|
||||||
|
|
||||||
/** Description of the parameter (rightmost field in OptionsParser::usage()) */
|
/** Description of the parameter (rightmost field in OptionsParser::usage()) */
|
||||||
const std::string& description() const;
|
const std::string& description() const;
|
||||||
|
|
||||||
/** The long name of this parameter (e.g. "--option"), without the dash. */
|
/** The long name of this parameter (e.g. "--option"), without the dash. */
|
||||||
const std::string& longOption() const;
|
const std::string& longOption() const;
|
||||||
|
|
||||||
/** Check if this parameters has a short option */
|
/** Check if this parameters has a short option */
|
||||||
bool hasShortOption() const;
|
bool hasShortOption() const;
|
||||||
|
|
||||||
/** The short name of this parameter (e.g. "-o"), without the dash. */
|
/** The short name of this parameter (e.g. "-o"), without the dash. */
|
||||||
char shortOption() const;
|
char shortOption() const;
|
||||||
@ -203,13 +204,13 @@ protected:
|
|||||||
* iterator that technically allows for more complex grammar than what is
|
* iterator that technically allows for more complex grammar than what is
|
||||||
* presently used.
|
* presently used.
|
||||||
*/
|
*/
|
||||||
virtual int receive(ParserState& state) throw(ParameterRejected) = 0;
|
virtual int receive(ParserState& state) throw(ParameterRejected) = 0;
|
||||||
|
|
||||||
friend class OptionsParser;
|
friend class OptionsParser;
|
||||||
|
|
||||||
char fshortOption;
|
char fshortOption;
|
||||||
const std::string flongOption;
|
const std::string flongOption;
|
||||||
const std::string fdescription;
|
const std::string fdescription;
|
||||||
private:
|
private:
|
||||||
|
|
||||||
};
|
};
|
||||||
@ -243,16 +244,16 @@ public:
|
|||||||
const char* description);
|
const char* description);
|
||||||
virtual ~CommonParameter();
|
virtual ~CommonParameter();
|
||||||
|
|
||||||
virtual std::string usageLine() const;
|
virtual std::string usageLine() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
/** Parse the argument given by state, and dispatch either
|
/** Parse the argument given by state, and dispatch either
|
||||||
* receiveSwitch() or receiveArgument() accordingly.
|
* receiveSwitch() or receiveArgument() accordingly.
|
||||||
*
|
*
|
||||||
* @param state The current argument being parsed.
|
* @param state The current argument being parsed.
|
||||||
* @return The number of parameters taken from the input
|
* @return The number of parameters taken from the input
|
||||||
*/
|
*/
|
||||||
virtual int receive(ParserState& state) throw(ParameterRejected) = 0;
|
virtual int receive(ParserState& state) throw(ParameterRejected) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
/** This class (used as a mixin) defines how a parameter
|
/** This class (used as a mixin) defines how a parameter
|
||||||
@ -341,7 +342,7 @@ public:
|
|||||||
virtual ~SwitchParameter();
|
virtual ~SwitchParameter();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual int receive(ParserState& state) throw(Parameter::ParameterRejected);
|
virtual int receive(ParserState& state) throw(Parameter::ParameterRejected);
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Plain-Old-Data parameter. Performs input validation.
|
/** Plain-Old-Data parameter. Performs input validation.
|
||||||
@ -372,14 +373,14 @@ public:
|
|||||||
|
|
||||||
std::string usageLine() const;
|
std::string usageLine() const;
|
||||||
protected:
|
protected:
|
||||||
virtual int receive(ParserState& state) throw(Parameter::ParameterRejected);
|
virtual int receive(ParserState& state) throw(Parameter::ParameterRejected);
|
||||||
|
|
||||||
/** Validation function for the data type.
|
/** Validation function for the data type.
|
||||||
*
|
*
|
||||||
* @throw ParameterRejected if the argument does not conform to this data type.
|
* @throw ParameterRejected if the argument does not conform to this data type.
|
||||||
* @return the value corresponding to the argument.
|
* @return the value corresponding to the argument.
|
||||||
*/
|
*/
|
||||||
virtual T validate(const std::string& s) throw (Parameter::ParameterRejected);
|
virtual T validate(const std::string& s) throw (Parameter::ParameterRejected);
|
||||||
|
|
||||||
T value;
|
T value;
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user