26 #ifndef TCLAP_SWITCH_ARG_H 27 #define TCLAP_SWITCH_ARG_H 71 const std::string& name,
72 const std::string& desc,
91 const std::string& name,
92 const std::string& desc,
106 virtual bool processArg(
int* i, std::vector<std::string>& args);
126 virtual void reset();
133 bool lastCombined(std::string& combined);
138 void commonProcessing();
145 const std::string& name,
146 const std::string& desc,
149 :
Arg(flag, name, desc, false, false, v),
155 const std::string& name,
156 const std::string& desc,
160 :
Arg(flag, name, desc, false, false, v),
167 inline bool SwitchArg::lastCombined(std::string& combinedSwitches )
169 for (
unsigned int i = 1; i < combinedSwitches.length(); i++ )
179 if ( combinedSwitches.length() > 0 &&
189 if ( combinedSwitches.find_first_of(
Arg::delimiter()) != std::string::npos)
194 for (
unsigned int i = 1; i < combinedSwitches.length(); i++ )
195 if (
_flag.length() > 0 &&
196 combinedSwitches[i] ==
_flag[0] &&
211 inline void SwitchArg::commonProcessing()
215 "Mutually exclusive argument already set!",
toString()));
256 return lastCombined( args[*i] );
bool getValue() const
Returns bool, whether or not the switch has been set.
virtual bool argMatches(const std::string &s) const
A method that tests whether a string matches this argument.
bool _alreadySet
Indicates whether the argument has been set.
bool combinedSwitchesMatch(std::string &combined)
Checks a string to see if any of the chars in the string match the flag for this Switch.
A virtual base class that defines the essential data for all arguments.
Thrown from CmdLine when the arguments on the command line are not properly specified, e.g.
A simple switch argument.
virtual void reset()
Clears the Arg object and allows it to be reused by new command lines.
bool _xorSet
Indicates that the arg was set as part of an XOR and not on the command line.
static char delimiter()
The delimiter that separates an argument flag/name from the value.
virtual bool processArg(int *i, std::vector< std::string > &args)
Handles the processing of the argument.
bool _value
The value of the switch.
bool _default
Used to support the reset() method so that ValueArg can be reset to their constructed value...
void _checkWithVisitor() const
Performs the special handling described by the Visitor.
static const std::string nameStartString()
A base class that defines the interface for visitors.
The base class that manages the command line definition and passes along the parsing to the appropria...
virtual std::string toString() const
Returns a simple string representation of the argument.
virtual void add(Arg &a)=0
Adds an argument to the list of arguments to be parsed.
bool _ignoreable
Whether this argument can be ignored, if desired.
static bool ignoreRest()
Whether to ignore the rest.
virtual void reset()
Clears the Arg object and allows it to be reused by new command lines.
static char blankChar()
The char used as a place holder when SwitchArgs are combined.
SwitchArg(const std::string &flag, const std::string &name, const std::string &desc, bool def=false, Visitor *v=NULL)
SwitchArg constructor.
std::string _flag
The single char flag used to identify the argument.
static const std::string flagStartString()