mirror of
https://github.com/cuberite/TCLAP.git
synced 2025-09-13 06:07:07 -04:00
minor formatting
This commit is contained in:
parent
5b198cd996
commit
ad7f3fdab3
@ -50,15 +50,14 @@ class Arg
|
|||||||
*/
|
*/
|
||||||
static bool& ignoreRestRef() { static bool ign = false; return ign; }
|
static bool& ignoreRestRef() { static bool ign = false; return ign; }
|
||||||
|
|
||||||
|
|
||||||
protected:
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The delimiter that separates an argument flag/name from the
|
* The delimiter that separates an argument flag/name from the
|
||||||
* value.
|
* value.
|
||||||
*/
|
*/
|
||||||
static char& delimiterRef() { static char delim = ' '; return delim; }
|
static char& delimiterRef() { static char delim = ' '; return delim; }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The single char flag used to identify the argument.
|
* The single char flag used to identify the argument.
|
||||||
* This value (preceded by a dash {-}), can be used to identify
|
* This value (preceded by a dash {-}), can be used to identify
|
||||||
@ -446,7 +445,8 @@ inline bool Arg::operator==(const Arg& a)
|
|||||||
// should be overridden
|
// should be overridden
|
||||||
inline bool Arg::processArg(int* i, std::vector<std::string>& args)
|
inline bool Arg::processArg(int* i, std::vector<std::string>& args)
|
||||||
{
|
{
|
||||||
std::cerr << "WARNING: Ignoring unknown argument: " << args[*i] << std::endl;
|
std::cerr << "WARNING: Ignoring unknown argument: "
|
||||||
|
<< args[*i] << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,8 +37,6 @@
|
|||||||
#include <list>
|
#include <list>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <ostream>
|
#include <ostream>
|
||||||
#include <cstdio>
|
|
||||||
#include <cstdarg>
|
|
||||||
#include <iomanip>
|
#include <iomanip>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
@ -231,7 +229,9 @@ class CmdLine : public CmdLineInterface
|
|||||||
//Begin CmdLine.cpp
|
//Begin CmdLine.cpp
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
inline CmdLine::CmdLine(const std::string& n, const std::string& m, const std::string& v )
|
inline CmdLine::CmdLine(const std::string& n,
|
||||||
|
const std::string& m,
|
||||||
|
const std::string& v )
|
||||||
: _progName(n),
|
: _progName(n),
|
||||||
_message(m),
|
_message(m),
|
||||||
_version(v),
|
_version(v),
|
||||||
@ -241,7 +241,9 @@ inline CmdLine::CmdLine(const std::string& n, const std::string& m, const std::s
|
|||||||
_constructor();
|
_constructor();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline CmdLine::CmdLine(const std::string& m, char delim, const std::string& v )
|
inline CmdLine::CmdLine(const std::string& m,
|
||||||
|
char delim,
|
||||||
|
const std::string& v )
|
||||||
: _progName("not_set_yet"),
|
: _progName("not_set_yet"),
|
||||||
_message(m),
|
_message(m),
|
||||||
_version(v),
|
_version(v),
|
||||||
@ -339,7 +341,8 @@ inline void CmdLine::add( Arg* a )
|
|||||||
|
|
||||||
inline void CmdLine::version(int exitVal)
|
inline void CmdLine::version(int exitVal)
|
||||||
{
|
{
|
||||||
std::cout << std::endl << _progName << " version: " << _version << std::endl << std::endl;
|
std::cout << std::endl << _progName << " version: "
|
||||||
|
<< _version << std::endl << std::endl;
|
||||||
exit( exitVal );
|
exit( exitVal );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -436,7 +439,8 @@ inline void CmdLine::parse(int argc, char** argv)
|
|||||||
_shortUsage( std::cerr );
|
_shortUsage( std::cerr );
|
||||||
|
|
||||||
std::cerr << std::endl << "For complete USAGE and HELP type: "
|
std::cerr << std::endl << "For complete USAGE and HELP type: "
|
||||||
<< std::endl << " " << _progName << " --help" << std::endl << std::endl;
|
<< std::endl << " " << _progName << " --help"
|
||||||
|
<< std::endl << std::endl;
|
||||||
|
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
@ -36,15 +36,19 @@
|
|||||||
|
|
||||||
namespace TCLAP {
|
namespace TCLAP {
|
||||||
|
|
||||||
class Arg;
|
class Arg;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The base class that manages the command line definition and passes
|
* The base class that manages the command line definition and passes
|
||||||
* along the parsing to the appropriate Arg classes.
|
* along the parsing to the appropriate Arg classes.
|
||||||
*/
|
*/
|
||||||
class CmdLineInterface
|
class CmdLineInterface
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
virtual ~CmdLineInterface() {}
|
virtual ~CmdLineInterface() {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -93,7 +97,7 @@ namespace TCLAP {
|
|||||||
* \param argv - Array of arguments.
|
* \param argv - Array of arguments.
|
||||||
*/
|
*/
|
||||||
virtual void parse(int argc, char** argv)=0;
|
virtual void parse(int argc, char** argv)=0;
|
||||||
};
|
};
|
||||||
|
|
||||||
} //namespace
|
} //namespace
|
||||||
|
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
/* -*- Mode: CC; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
*
|
*
|
||||||
* file: MultiArg.h
|
* file: MultiArg.h
|
||||||
@ -33,38 +31,53 @@
|
|||||||
|
|
||||||
namespace TCLAP {
|
namespace TCLAP {
|
||||||
|
|
||||||
template<class T> class MultiArg;
|
template<class T> class MultiArg;
|
||||||
|
|
||||||
namespace MULTI_ARG_HELPER {
|
namespace MULTI_ARG_HELPER {
|
||||||
|
|
||||||
enum Error_e {
|
enum Error_e { EFAIL = 1000, EMANY };
|
||||||
EFAIL = 1000,
|
|
||||||
EMANY
|
|
||||||
};
|
|
||||||
|
|
||||||
//This class is used to extract a value from an argument.
|
/**
|
||||||
//It is used because we need a special implementation to
|
* This class is used to extract a value from an argument.
|
||||||
//deal with std::string and making a specialiced function
|
* It is used because we need a special implementation to
|
||||||
//puts it in the T segment, thus generating link errors.
|
* deal with std::string and making a specialiced function
|
||||||
//Having a specialiced class makes the symbols weak.
|
* puts it in the T segment, thus generating link errors.
|
||||||
//This is not pretty but I don't know how to make it
|
* Having a specialiced class makes the symbols weak.
|
||||||
//work any other way.
|
* This is not pretty but I don't know how to make it
|
||||||
template<class T>
|
* work any other way.
|
||||||
class ValueExtractor
|
*/
|
||||||
{
|
template<class T>
|
||||||
|
class ValueExtractor
|
||||||
|
{
|
||||||
friend class MultiArg<T>;
|
friend class MultiArg<T>;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reference to the vector of values where the result of the
|
||||||
|
* extraction will be put.
|
||||||
|
*/
|
||||||
std::vector<T> &_values;
|
std::vector<T> &_values;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
* \param values - Where the values extracted will be put.
|
||||||
|
*/
|
||||||
ValueExtractor(std::vector<T> &values) : _values(values) {}
|
ValueExtractor(std::vector<T> &values) : _values(values) {}
|
||||||
|
|
||||||
int extractValue( const std::string& val ) {
|
/**
|
||||||
|
* Method that will attempt to parse the input stream for values
|
||||||
|
* of type T.
|
||||||
|
* \param val - Where the values parsed will be put.
|
||||||
|
*/
|
||||||
|
int extractValue( const std::string& val )
|
||||||
|
{
|
||||||
T temp;
|
T temp;
|
||||||
std::istringstream is(val);
|
std::istringstream is(val);
|
||||||
int valuesRead = 0;
|
int valuesRead = 0;
|
||||||
|
|
||||||
while ( is.good() ) {
|
while ( is.good() )
|
||||||
|
{
|
||||||
if ( is.peek() != EOF )
|
if ( is.peek() != EOF )
|
||||||
is >> temp;
|
is >> temp;
|
||||||
else
|
else
|
||||||
@ -83,37 +96,54 @@ namespace MULTI_ARG_HELPER {
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Specialization for string. This is necessary because istringstream
|
* Specialization for string. This is necessary because istringstream
|
||||||
* operator>> is not able to ignore spaces... meaning -x "X Y" will only
|
* operator>> is not able to ignore spaces... meaning -x "X Y" will only
|
||||||
* read 'X'... and thus the specialization.
|
* read 'X'... and thus the specialization.
|
||||||
*/
|
*/
|
||||||
template<>
|
template<>
|
||||||
class ValueExtractor<std::string> {
|
class ValueExtractor<std::string>
|
||||||
|
{
|
||||||
friend class MultiArg<std::string>;
|
friend class MultiArg<std::string>;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reference to the vector of strings where the result of the
|
||||||
|
* extraction will be put.
|
||||||
|
*/
|
||||||
std::vector<std::string> &_values;
|
std::vector<std::string> &_values;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
* \param values - Where the strings extracted will be put.
|
||||||
|
*/
|
||||||
ValueExtractor(std::vector<std::string> &values) : _values(values) {}
|
ValueExtractor(std::vector<std::string> &values) : _values(values) {}
|
||||||
|
|
||||||
int extractValue( const std::string& val ) {
|
/**
|
||||||
|
* Method that will attempt to parse the input stream for values
|
||||||
|
* of type std::string.
|
||||||
|
* \param val - Where the values parsed will be put.
|
||||||
|
*/
|
||||||
|
int extractValue( const std::string& val )
|
||||||
|
{
|
||||||
_values.push_back( val );
|
_values.push_back( val );
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} //namespace MULTI_ARG_HELPER
|
} //namespace MULTI_ARG_HELPER
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An argument that allows multiple values of type T to be specified. Very
|
* An argument that allows multiple values of type T to be specified. Very
|
||||||
* similar to a ValueArg, except a vector of values will be returned
|
* similar to a ValueArg, except a vector of values will be returned
|
||||||
* instead of just one.
|
* instead of just one.
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
class MultiArg : public Arg
|
class MultiArg : public Arg
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -140,21 +170,7 @@ namespace MULTI_ARG_HELPER {
|
|||||||
* is thrown.
|
* is thrown.
|
||||||
* \param val - The string to be read.
|
* \param val - The string to be read.
|
||||||
*/
|
*/
|
||||||
void _extractValue( const std::string& val ) {
|
void _extractValue( const std::string& val );
|
||||||
MULTI_ARG_HELPER::ValueExtractor<T> ve(_values);
|
|
||||||
|
|
||||||
int err = ve.extractValue(val);
|
|
||||||
if(err == MULTI_ARG_HELPER::EFAIL)
|
|
||||||
throw( ArgException("Couldn't read argument value "
|
|
||||||
"from string '" +
|
|
||||||
val + "'", toString() ) );
|
|
||||||
if(err == MULTI_ARG_HELPER::EMANY)
|
|
||||||
throw( ArgException("More than one valid value "
|
|
||||||
"parsed from string '" +
|
|
||||||
val + "'", toString() ) );
|
|
||||||
_checkAllowed( val );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks to see if parsed value is in allowed list.
|
* Checks to see if parsed value is in allowed list.
|
||||||
@ -213,6 +229,7 @@ namespace MULTI_ARG_HELPER {
|
|||||||
const std::string& typeDesc,
|
const std::string& typeDesc,
|
||||||
CmdLineInterface& parser,
|
CmdLineInterface& parser,
|
||||||
Visitor* v = NULL );
|
Visitor* v = NULL );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor.
|
* Constructor.
|
||||||
* \param flag - The one character flag that identifies this
|
* \param flag - The one character flag that identifies this
|
||||||
@ -299,14 +316,14 @@ namespace MULTI_ARG_HELPER {
|
|||||||
* Common initialization code for constructors with allowed vectors.
|
* Common initialization code for constructors with allowed vectors.
|
||||||
*/
|
*/
|
||||||
void allowedInit();
|
void allowedInit();
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
void MultiArg<T>::allowedInit()
|
void MultiArg<T>::allowedInit()
|
||||||
{
|
{
|
||||||
for ( unsigned int i = 0; i < _allowed.size(); i++ )
|
for ( unsigned int i = 0; i < _allowed.size(); i++ )
|
||||||
{
|
{
|
||||||
std::ostringstream os;
|
std::ostringstream os;
|
||||||
@ -316,81 +333,82 @@ namespace MULTI_ARG_HELPER {
|
|||||||
|
|
||||||
if ( i > 0 )
|
if ( i > 0 )
|
||||||
_typeDesc += "|";
|
_typeDesc += "|";
|
||||||
|
|
||||||
_typeDesc += temp;
|
_typeDesc += temp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
MultiArg<T>::MultiArg(const std::string& flag,
|
MultiArg<T>::MultiArg(const std::string& flag,
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::string& desc,
|
const std::string& desc,
|
||||||
bool req,
|
bool req,
|
||||||
const std::string& typeDesc,
|
const std::string& typeDesc,
|
||||||
Visitor* v)
|
Visitor* v)
|
||||||
: Arg( flag, name, desc, req, true, v ),
|
: Arg( flag, name, desc, req, true, v ),
|
||||||
_typeDesc( typeDesc )
|
_typeDesc( typeDesc )
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
template<class T>
|
template<class T>
|
||||||
MultiArg<T>::MultiArg(const std::string& flag,
|
MultiArg<T>::MultiArg(const std::string& flag,
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::string& desc,
|
const std::string& desc,
|
||||||
bool req,
|
bool req,
|
||||||
const std::string& typeDesc,
|
const std::string& typeDesc,
|
||||||
CmdLineInterface& parser,
|
CmdLineInterface& parser,
|
||||||
Visitor* v)
|
Visitor* v)
|
||||||
: Arg( flag, name, desc, req, true, v ),
|
: Arg( flag, name, desc, req, true, v ),
|
||||||
_typeDesc( typeDesc )
|
_typeDesc( typeDesc )
|
||||||
{
|
{
|
||||||
parser.add( this );
|
parser.add( this );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
MultiArg<T>::MultiArg(const std::string& flag,
|
MultiArg<T>::MultiArg(const std::string& flag,
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::string& desc,
|
const std::string& desc,
|
||||||
bool req,
|
bool req,
|
||||||
const std::vector<T>& allowed,
|
const std::vector<T>& allowed,
|
||||||
Visitor* v)
|
Visitor* v)
|
||||||
: Arg( flag, name, desc, req, true, v ),
|
: Arg( flag, name, desc, req, true, v ),
|
||||||
_allowed( allowed )
|
_allowed( allowed )
|
||||||
{
|
{
|
||||||
allowedInit();
|
allowedInit();
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class T>
|
template<class T>
|
||||||
MultiArg<T>::MultiArg(const std::string& flag,
|
MultiArg<T>::MultiArg(const std::string& flag,
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::string& desc,
|
const std::string& desc,
|
||||||
bool req,
|
bool req,
|
||||||
const std::vector<T>& allowed,
|
const std::vector<T>& allowed,
|
||||||
CmdLineInterface& parser,
|
CmdLineInterface& parser,
|
||||||
Visitor* v)
|
Visitor* v)
|
||||||
: Arg( flag, name, desc, req, true, v ),
|
: Arg( flag, name, desc, req, true, v ),
|
||||||
_allowed( allowed )
|
_allowed( allowed )
|
||||||
{
|
{
|
||||||
allowedInit();
|
allowedInit();
|
||||||
parser.add( this );
|
parser.add( this );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
const std::vector<T>& MultiArg<T>::getValue() { return _values; }
|
const std::vector<T>& MultiArg<T>::getValue() { return _values; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
bool MultiArg<T>::processArg(int *i, std::vector<std::string>& args)
|
bool MultiArg<T>::processArg(int *i, std::vector<std::string>& args)
|
||||||
{
|
{
|
||||||
if ( _ignoreable && Arg::ignoreRest() )
|
if ( _ignoreable && Arg::ignoreRest() )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -421,100 +439,55 @@ namespace MULTI_ARG_HELPER {
|
|||||||
_extractValue( value );
|
_extractValue( value );
|
||||||
|
|
||||||
_checkWithVisitor();
|
_checkWithVisitor();
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/**
|
||||||
template<class T>
|
|
||||||
void MultiArg<T>::_extractValue( const std::string& val )
|
|
||||||
{
|
|
||||||
T temp;
|
|
||||||
std::istringstream is(val);
|
|
||||||
|
|
||||||
int valuesRead = 0;
|
|
||||||
while ( is.good() )
|
|
||||||
{
|
|
||||||
if ( is.peek() != EOF )
|
|
||||||
is >> temp;
|
|
||||||
else
|
|
||||||
break;
|
|
||||||
|
|
||||||
valuesRead++;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( is.fail() )
|
|
||||||
throw( ArgException("Couldn't read argument value from string '" +
|
|
||||||
val + "'", toString() ) );
|
|
||||||
|
|
||||||
if ( valuesRead > 1 )
|
|
||||||
throw( ArgException("More than one valid value parsed from string '" +
|
|
||||||
val + "'", toString() ) );
|
|
||||||
|
|
||||||
|
|
||||||
_values.push_back(temp);
|
|
||||||
|
|
||||||
_checkAllowed( val );
|
|
||||||
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Specialization to handle strings with spaces in them. This is needed
|
|
||||||
* because there is no way to tell operator>> to ignore spaces.
|
|
||||||
*
|
|
||||||
template<>
|
|
||||||
void MultiArg<std::string>::_extractValue( const std::string& val )
|
|
||||||
{
|
|
||||||
_values.push_back( val );
|
|
||||||
|
|
||||||
_checkAllowed( val );
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* Checks to see if the value parsed is in the allowed list.
|
* Checks to see if the value parsed is in the allowed list.
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
void MultiArg<T>::_checkAllowed( const std::string& val )
|
void MultiArg<T>::_checkAllowed( const std::string& val )
|
||||||
{
|
{
|
||||||
if ( _allowed.size() > 0 )
|
if ( _allowed.size() > 0 )
|
||||||
if ( find(_allowed.begin(),_allowed.end(),_values.back())
|
if ( find(_allowed.begin(),_allowed.end(),_values.back())
|
||||||
== _allowed.end() )
|
== _allowed.end() )
|
||||||
throw( ArgException( "Couldn't find '" + val +
|
throw( ArgException( "Couldn't find '" + val +
|
||||||
"' in allowed list.", toString() ) );
|
"' in allowed list.", toString() ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
std::string MultiArg<T>::shortID(const std::string& val) const
|
std::string MultiArg<T>::shortID(const std::string& val) const
|
||||||
{
|
{
|
||||||
std::string id = Arg::shortID(_typeDesc) + " ... ";
|
std::string id = Arg::shortID(_typeDesc) + " ... ";
|
||||||
|
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
std::string MultiArg<T>::longID(const std::string& val) const
|
std::string MultiArg<T>::longID(const std::string& val) const
|
||||||
{
|
{
|
||||||
std::string id = Arg::longID(_typeDesc) + " (accepted multiple times)";
|
std::string id = Arg::longID(_typeDesc) + " (accepted multiple times)";
|
||||||
|
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Once we've matched the first value, then the arg is no longer
|
* Once we've matched the first value, then the arg is no longer
|
||||||
* required.
|
* required.
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
bool MultiArg<T>::isRequired() const
|
bool MultiArg<T>::isRequired() const
|
||||||
{
|
{
|
||||||
if ( _required )
|
if ( _required )
|
||||||
{
|
{
|
||||||
if ( _values.size() > 1 )
|
if ( _values.size() > 1 )
|
||||||
@ -525,8 +498,26 @@ namespace MULTI_ARG_HELPER {
|
|||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template<class T>
|
||||||
|
void MultiArg<T>::_extractValue( const std::string& val )
|
||||||
|
{
|
||||||
|
MULTI_ARG_HELPER::ValueExtractor<T> ve(_values);
|
||||||
|
|
||||||
|
int err = ve.extractValue(val);
|
||||||
|
|
||||||
|
if ( err == MULTI_ARG_HELPER::EFAIL )
|
||||||
|
throw( ArgException("Couldn't read argument value "
|
||||||
|
"from string '" + val + "'", toString() ) );
|
||||||
|
|
||||||
|
if(err == MULTI_ARG_HELPER::EMANY)
|
||||||
|
throw( ArgException("More than one valid value "
|
||||||
|
"parsed from string '" + val + "'", toString() ) );
|
||||||
|
_checkAllowed( val );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} // namespace TCLAP
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -39,7 +39,7 @@ namespace TCLAP {
|
|||||||
* \param secondLineOffset - The number of spaces to indent the second
|
* \param secondLineOffset - The number of spaces to indent the second
|
||||||
* and all subsequent lines in addition to indentSpaces.
|
* and all subsequent lines in addition to indentSpaces.
|
||||||
*/
|
*/
|
||||||
inline void spacePrint( std::ostream& os,
|
inline void spacePrint( std::ostream& os,
|
||||||
const std::string& s,
|
const std::string& s,
|
||||||
int maxWidth,
|
int maxWidth,
|
||||||
int indentSpaces=0,
|
int indentSpaces=0,
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
/* -*- Mode: CC; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
*
|
*
|
||||||
* file: ValueArg.h
|
* file: ValueArg.h
|
||||||
@ -33,35 +31,54 @@
|
|||||||
|
|
||||||
namespace TCLAP {
|
namespace TCLAP {
|
||||||
|
|
||||||
template<class T> class ValueArg;
|
template<class T> class ValueArg;
|
||||||
|
|
||||||
namespace VALUE_ARG_HELPER {
|
namespace VALUE_ARG_HELPER {
|
||||||
|
|
||||||
enum Error_e {
|
enum Error_e { EFAIL = 1000, EMANY };
|
||||||
EFAIL = 1000,
|
|
||||||
EMANY
|
|
||||||
};
|
|
||||||
|
|
||||||
//This class is used to extract a value from an argument.
|
|
||||||
//It is used because we need a special implementation to
|
|
||||||
//deal with std::string and making a specialiced function
|
|
||||||
//puts it in the T segment, thus generating link errors.
|
|
||||||
//Having a specialiced class makes the symbols weak.
|
|
||||||
//This is not pretty but I don't know how to make it
|
|
||||||
//work any other way.
|
|
||||||
template<class T> class ValueExtractor {
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class is used to extract a value from an argument.
|
||||||
|
* It is used because we need a special implementation to
|
||||||
|
* deal with std::string and making a specialiced function
|
||||||
|
* puts it in the T segment, thus generating link errors.
|
||||||
|
* Having a specialiced class makes the symbols weak.
|
||||||
|
* This is not pretty but I don't know how to make it
|
||||||
|
* work any other way.
|
||||||
|
*/
|
||||||
|
template<class T> class ValueExtractor
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
friend class ValueArg<T>;
|
friend class ValueArg<T>;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reference to the value where the result of the extraction will
|
||||||
|
* be put.
|
||||||
|
*/
|
||||||
T &_value;
|
T &_value;
|
||||||
|
|
||||||
ValueExtractor(T &value) : _value(value) {}
|
/**
|
||||||
|
* Constructor.
|
||||||
|
* \param value - Where the value extracted will be put.
|
||||||
|
*/
|
||||||
|
ValueExtractor(T &value) : _value(value) { }
|
||||||
|
|
||||||
int extractValue( const std::string& val ) {
|
/**
|
||||||
|
* Method that will attempt to parse the input stream for a value
|
||||||
|
* of type T.
|
||||||
|
* \param val - Where the value parsed will be put.
|
||||||
|
*/
|
||||||
|
int extractValue( const std::string& val )
|
||||||
|
{
|
||||||
std::istringstream is(val);
|
std::istringstream is(val);
|
||||||
|
|
||||||
int valuesRead = 0;
|
int valuesRead = 0;
|
||||||
while ( is.good() ) {
|
while ( is.good() )
|
||||||
|
{
|
||||||
if ( is.peek() != EOF )
|
if ( is.peek() != EOF )
|
||||||
is >> _value;
|
is >> _value;
|
||||||
else
|
else
|
||||||
@ -78,30 +95,49 @@ namespace VALUE_ARG_HELPER {
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Specialization for string. This is necessary because istringstream
|
* Specialization for string. This is necessary because istringstream
|
||||||
* operator>> is not able to ignore spaces... meaning -x "X Y" will only
|
* operator>> is not able to ignore spaces... meaning -x "X Y" will only
|
||||||
* read 'X'... and thus the specialization.
|
* read 'X'... and thus the specialization.
|
||||||
*/
|
*/
|
||||||
template<> class ValueExtractor<std::string> {
|
template<> class ValueExtractor<std::string>
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
friend class ValueArg<std::string>;
|
friend class ValueArg<std::string>;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reference to the value where the result of the extraction will
|
||||||
|
* be put.
|
||||||
|
*/
|
||||||
std::string &_value;
|
std::string &_value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
* \param value - Where the value extracted will be put.
|
||||||
|
*/
|
||||||
ValueExtractor(std::string &value) : _value(value) {}
|
ValueExtractor(std::string &value) : _value(value) {}
|
||||||
|
|
||||||
int extractValue( const std::string& val ) {
|
/**
|
||||||
|
* Method that will attempt to parse the input stream for a value
|
||||||
|
* of type std::string.
|
||||||
|
* \param val - Where the string parsed will be put.
|
||||||
|
*/
|
||||||
|
int extractValue( const std::string& val )
|
||||||
|
{
|
||||||
_value = val;
|
_value = val;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} //namespace VALUE_ARG_HELPER
|
} //namespace VALUE_ARG_HELPER
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The basic labeled argument that parses a value.
|
* The basic labeled argument that parses a value.
|
||||||
* This is a template class, which means the type T defines the type
|
* This is a template class, which means the type T defines the type
|
||||||
* that a given object will attempt to parse when the flag/name is matched
|
* that a given object will attempt to parse when the flag/name is matched
|
||||||
@ -109,9 +145,9 @@ namespace VALUE_ARG_HELPER {
|
|||||||
* an unflagged ValueArg, it is unwise and would cause significant problems.
|
* an unflagged ValueArg, it is unwise and would cause significant problems.
|
||||||
* Instead use an UnlabeledValueArg.
|
* Instead use an UnlabeledValueArg.
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
class ValueArg : public Arg
|
class ValueArg : public Arg
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -144,19 +180,7 @@ namespace VALUE_ARG_HELPER {
|
|||||||
* is thrown.
|
* is thrown.
|
||||||
* \param val - value to be parsed.
|
* \param val - value to be parsed.
|
||||||
*/
|
*/
|
||||||
void _extractValue( const std::string& val ) {
|
void _extractValue( const std::string& val );
|
||||||
VALUE_ARG_HELPER::ValueExtractor<T> ve(_value);
|
|
||||||
|
|
||||||
int err = ve.extractValue(val);
|
|
||||||
if(err == VALUE_ARG_HELPER::EFAIL)
|
|
||||||
throw( ArgException("Couldn't read argument value from string '" +
|
|
||||||
val + "'", toString() ) );
|
|
||||||
if(err == VALUE_ARG_HELPER::EMANY)
|
|
||||||
throw( ArgException("More than one valid value parsed from string '" +
|
|
||||||
val + "'", toString() ) );
|
|
||||||
|
|
||||||
_checkAllowed( val );
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks to see if parsed value is in allowed list.
|
* Checks to see if parsed value is in allowed list.
|
||||||
@ -326,12 +350,12 @@ namespace VALUE_ARG_HELPER {
|
|||||||
*/
|
*/
|
||||||
void allowedInit();
|
void allowedInit();
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
template<class T>
|
template<class T>
|
||||||
void ValueArg<T>::allowedInit()
|
void ValueArg<T>::allowedInit()
|
||||||
{
|
{
|
||||||
for ( unsigned int i = 0; i < _allowed.size(); i++ )
|
for ( unsigned int i = 0; i < _allowed.size(); i++ )
|
||||||
{
|
{
|
||||||
std::ostringstream os;
|
std::ostringstream os;
|
||||||
@ -343,26 +367,26 @@ namespace VALUE_ARG_HELPER {
|
|||||||
_typeDesc += "|";
|
_typeDesc += "|";
|
||||||
_typeDesc += temp;
|
_typeDesc += temp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor implementation.
|
* Constructor implementation.
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
ValueArg<T>::ValueArg(const std::string& flag,
|
ValueArg<T>::ValueArg(const std::string& flag,
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::string& desc,
|
const std::string& desc,
|
||||||
bool req,
|
bool req,
|
||||||
T val,
|
T val,
|
||||||
const std::string& typeDesc,
|
const std::string& typeDesc,
|
||||||
Visitor* v)
|
Visitor* v)
|
||||||
: Arg(flag, name, desc, req, true, v),
|
: Arg(flag, name, desc, req, true, v),
|
||||||
_value( val ),
|
_value( val ),
|
||||||
_typeDesc( typeDesc )
|
_typeDesc( typeDesc )
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
template<class T>
|
template<class T>
|
||||||
ValueArg<T>::ValueArg(const std::string& flag,
|
ValueArg<T>::ValueArg(const std::string& flag,
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::string& desc,
|
const std::string& desc,
|
||||||
bool req,
|
bool req,
|
||||||
@ -370,33 +394,33 @@ namespace VALUE_ARG_HELPER {
|
|||||||
const std::string& typeDesc,
|
const std::string& typeDesc,
|
||||||
CmdLineInterface& parser,
|
CmdLineInterface& parser,
|
||||||
Visitor* v)
|
Visitor* v)
|
||||||
: Arg(flag, name, desc, req, true, v),
|
: Arg(flag, name, desc, req, true, v),
|
||||||
_value( val ),
|
_value( val ),
|
||||||
_typeDesc( typeDesc )
|
_typeDesc( typeDesc )
|
||||||
{
|
{
|
||||||
parser.add( this );
|
parser.add( this );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor with allowed list.
|
* Constructor with allowed list.
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
ValueArg<T>::ValueArg(const std::string& flag,
|
ValueArg<T>::ValueArg(const std::string& flag,
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::string& desc,
|
const std::string& desc,
|
||||||
bool req,
|
bool req,
|
||||||
T val,
|
T val,
|
||||||
const std::vector<T>& allowed,
|
const std::vector<T>& allowed,
|
||||||
Visitor* v)
|
Visitor* v)
|
||||||
: Arg(flag, name, desc, req, true, v),
|
: Arg(flag, name, desc, req, true, v),
|
||||||
_value( val ),
|
_value( val ),
|
||||||
_allowed( allowed )
|
_allowed( allowed )
|
||||||
{
|
{
|
||||||
allowedInit();
|
allowedInit();
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class T>
|
template<class T>
|
||||||
ValueArg<T>::ValueArg(const std::string& flag,
|
ValueArg<T>::ValueArg(const std::string& flag,
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::string& desc,
|
const std::string& desc,
|
||||||
bool req,
|
bool req,
|
||||||
@ -404,27 +428,27 @@ namespace VALUE_ARG_HELPER {
|
|||||||
const std::vector<T>& allowed,
|
const std::vector<T>& allowed,
|
||||||
CmdLineInterface& parser,
|
CmdLineInterface& parser,
|
||||||
Visitor* v)
|
Visitor* v)
|
||||||
: Arg(flag, name, desc, req, true, v),
|
: Arg(flag, name, desc, req, true, v),
|
||||||
_value( val ),
|
_value( val ),
|
||||||
_allowed( allowed )
|
_allowed( allowed )
|
||||||
{
|
{
|
||||||
allowedInit();
|
allowedInit();
|
||||||
parser.add( this );
|
parser.add( this );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implementation of getValue().
|
* Implementation of getValue().
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
T& ValueArg<T>::getValue() { return _value; }
|
T& ValueArg<T>::getValue() { return _value; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implementation of processArg().
|
* Implementation of processArg().
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
bool ValueArg<T>::processArg(int *i, std::vector<std::string>& args)
|
bool ValueArg<T>::processArg(int *i, std::vector<std::string>& args)
|
||||||
{
|
{
|
||||||
if ( _ignoreable && Arg::ignoreRest() )
|
if ( _ignoreable && Arg::ignoreRest() )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -463,37 +487,56 @@ namespace VALUE_ARG_HELPER {
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks to see if the value parsed is in the allowed list.
|
* Checks to see if the value parsed is in the allowed list.
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
void ValueArg<T>::_checkAllowed( const std::string& val )
|
void ValueArg<T>::_checkAllowed( const std::string& val )
|
||||||
{
|
{
|
||||||
if ( _allowed.size() > 0 )
|
if ( _allowed.size() > 0 )
|
||||||
if ( find(_allowed.begin(),_allowed.end(),_value) == _allowed.end() )
|
if ( find(_allowed.begin(),_allowed.end(),_value) == _allowed.end() )
|
||||||
throw( ArgException( "Couldn't find '" + val +
|
throw( ArgException( "Couldn't find '" + val +
|
||||||
"' in allowed list.", toString() ) );
|
"' in allowed list.", toString() ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implementation of shortID.
|
* Implementation of shortID.
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
std::string ValueArg<T>::shortID(const std::string& val) const
|
std::string ValueArg<T>::shortID(const std::string& val) const
|
||||||
{
|
{
|
||||||
return Arg::shortID( _typeDesc );
|
return Arg::shortID( _typeDesc );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implementation of longID.
|
* Implementation of longID.
|
||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
std::string ValueArg<T>::longID(const std::string& val) const
|
std::string ValueArg<T>::longID(const std::string& val) const
|
||||||
{
|
{
|
||||||
return Arg::longID( _typeDesc );
|
return Arg::longID( _typeDesc );
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template<class T>
|
||||||
|
void ValueArg<T>::_extractValue( const std::string& val )
|
||||||
|
{
|
||||||
|
VALUE_ARG_HELPER::ValueExtractor<T> ve(_value);
|
||||||
|
|
||||||
|
int err = ve.extractValue(val);
|
||||||
|
|
||||||
|
if ( err == VALUE_ARG_HELPER::EFAIL )
|
||||||
|
throw( ArgException("Couldn't read argument value from string '" +
|
||||||
|
val + "'", toString() ) );
|
||||||
|
|
||||||
|
if ( err == VALUE_ARG_HELPER::EMANY )
|
||||||
|
throw( ArgException("More than one valid value parsed from string '" +
|
||||||
|
val + "'", toString() ) );
|
||||||
|
|
||||||
|
_checkAllowed( val );
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace TCLAP
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user