git.stg.codes
/
stg.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Ticket12. The StopOnError parameter is comment out.
[stg.git]
/
projects
/
sgconf
/
actions.h
diff --git
a/projects/sgconf/actions.h
b/projects/sgconf/actions.h
index c47f9776090b7adde79252cbb931bb26cde65cc7..08dc177eb9d3eadc575a3427260eec6d4aba376a 100644
(file)
--- a/
projects/sgconf/actions.h
+++ b/
projects/sgconf/actions.h
@@
-30,6
+30,8
@@
#include <string>
#include <string>
+#include <cassert>
+
namespace SGCONF
{
namespace SGCONF
{
@@
-46,7
+48,7
@@
class FUNC0_ACTION : public ACTION
virtual std::string ParamDescription() const { return ""; }
virtual std::string DefaultDescription() const { return ""; }
virtual OPTION_BLOCK & Suboptions() { return m_suboptions; }
virtual std::string ParamDescription() const { return ""; }
virtual std::string DefaultDescription() const { return ""; }
virtual OPTION_BLOCK & Suboptions() { return m_suboptions; }
- virtual PARSER_STATE Parse(int argc, char ** argv)
+ virtual PARSER_STATE Parse(int argc, char ** argv
, void * /*data*/
)
{
m_func();
return PARSER_STATE(true, argc, argv);
{
m_func();
return PARSER_STATE(true, argc, argv);
@@
-76,6
+78,10
@@
class PARAM_ACTION : public ACTION
m_description(paramDescription),
m_hasDefault(true)
{}
m_description(paramDescription),
m_hasDefault(true)
{}
+ PARAM_ACTION(RESETABLE<T> & param)
+ : m_param(param),
+ m_hasDefault(false)
+ {}
PARAM_ACTION(RESETABLE<T> & param,
const std::string & paramDescription)
: m_param(param),
PARAM_ACTION(RESETABLE<T> & param,
const std::string & paramDescription)
: m_param(param),
@@
-88,7
+94,7
@@
class PARAM_ACTION : public ACTION
virtual std::string ParamDescription() const { return m_description; }
virtual std::string DefaultDescription() const;
virtual OPTION_BLOCK & Suboptions() { return m_suboptions; }
virtual std::string ParamDescription() const { return m_description; }
virtual std::string DefaultDescription() const;
virtual OPTION_BLOCK & Suboptions() { return m_suboptions; }
- virtual PARSER_STATE Parse(int argc, char ** argv);
+ virtual PARSER_STATE Parse(int argc, char ** argv
, void * /*data*/
);
virtual void ParseValue(const std::string & value);
private:
virtual void ParseValue(const std::string & value);
private:
@@
-117,7
+123,7
@@
return m_hasDefault ? " (default: '" + m_defaltValue + "')"
template <typename T>
inline
template <typename T>
inline
-PARSER_STATE PARAM_ACTION<T>::Parse(int argc, char ** argv)
+PARSER_STATE PARAM_ACTION<T>::Parse(int argc, char ** argv
, void * /*data*/
)
{
if (argc == 0 ||
argv == NULL ||
{
if (argc == 0 ||
argv == NULL ||
@@
-130,6
+136,14
@@
m_param = value;
return PARSER_STATE(false, --argc, ++argv);
}
return PARSER_STATE(false, --argc, ++argv);
}
+template <>
+inline
+PARSER_STATE PARAM_ACTION<bool>::Parse(int argc, char ** argv, void * /*data*/)
+{
+m_param = true;
+return PARSER_STATE(false, argc, argv);
+}
+
template <typename T>
inline
void PARAM_ACTION<T>::ParseValue(const std::string & stringValue)
template <typename T>
inline
void PARAM_ACTION<T>::ParseValue(const std::string & stringValue)
@@
-151,7
+165,7
@@
m_param = stringValue;
template <>
inline
template <>
inline
-PARSER_STATE PARAM_ACTION<std::string>::Parse(int argc, char ** argv)
+PARSER_STATE PARAM_ACTION<std::string>::Parse(int argc, char ** argv
, void * /*data*/
)
{
if (argc == 0 ||
argv == NULL ||
{
if (argc == 0 ||
argv == NULL ||
@@
-170,6
+184,13
@@
PARAM_ACTION<T> * MakeParamAction(RESETABLE<T> & param,
return new PARAM_ACTION<T>(param, defaultValue, paramDescription);
}
return new PARAM_ACTION<T>(param, defaultValue, paramDescription);
}
+template <typename T>
+inline
+PARAM_ACTION<T> * MakeParamAction(RESETABLE<T> & param)
+{
+return new PARAM_ACTION<T>(param);
+}
+
template <typename T>
inline
PARAM_ACTION<T> * MakeParamAction(RESETABLE<T> & param,
template <typename T>
inline
PARAM_ACTION<T> * MakeParamAction(RESETABLE<T> & param,
@@
-182,10
+203,8
@@
class KV_ACTION : public ACTION
{
public:
KV_ACTION(const std::string & name,
{
public:
KV_ACTION(const std::string & name,
- std::map<std::string, std::string> & kvs,
const std::string & paramDescription)
: m_name(name),
const std::string & paramDescription)
: m_name(name),
- m_kvs(kvs),
m_description(paramDescription)
{}
m_description(paramDescription)
{}
@@
-194,32
+213,32
@@
class KV_ACTION : public ACTION
virtual std::string ParamDescription() const { return m_description; }
virtual std::string DefaultDescription() const { return ""; }
virtual OPTION_BLOCK & Suboptions() { return m_suboptions; }
virtual std::string ParamDescription() const { return m_description; }
virtual std::string DefaultDescription() const { return ""; }
virtual OPTION_BLOCK & Suboptions() { return m_suboptions; }
- virtual PARSER_STATE Parse(int argc, char ** argv);
+ virtual PARSER_STATE Parse(int argc, char ** argv
, void * data
);
private:
std::string m_name;
private:
std::string m_name;
- std::map<std::string, std::string> & m_kvs;
std::string m_description;
OPTION_BLOCK m_suboptions;
};
inline
std::string m_description;
OPTION_BLOCK m_suboptions;
};
inline
-PARSER_STATE KV_ACTION::Parse(int argc, char ** argv)
+PARSER_STATE KV_ACTION::Parse(int argc, char ** argv
, void * data
)
{
if (argc == 0 ||
argv == NULL ||
*argv == NULL)
throw ERROR("Missing argument.");
{
if (argc == 0 ||
argv == NULL ||
*argv == NULL)
throw ERROR("Missing argument.");
-m_kvs[m_name] = *argv;
+assert(data != NULL && "Expecting container pointer.");
+std::map<std::string, std::string> & kvs = *static_cast<std::map<std::string, std::string>*>(data);
+kvs[m_name] = *argv;
return PARSER_STATE(false, --argc, ++argv);
}
inline
KV_ACTION * MakeKVAction(const std::string & name,
return PARSER_STATE(false, --argc, ++argv);
}
inline
KV_ACTION * MakeKVAction(const std::string & name,
- std::map<std::string, std::string> & kvs,
const std::string & paramDescription)
{
const std::string & paramDescription)
{
-return new KV_ACTION(name,
kvs,
paramDescription);
+return new KV_ACTION(name, paramDescription);
}
} // namespace SGCONF
}
} // namespace SGCONF