summaryrefslogtreecommitdiff
path: root/src/option.h
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2010-06-13 00:42:25 -0400
committerJohn Wiegley <johnw@newartisans.com>2010-06-13 00:42:25 -0400
commit40f553228f5a28034c6635fdcb4c86af28a385ed (patch)
tree2c40305c9f9841a4c3d453a4a5c49ec69056b4b2 /src/option.h
parent556211e623cad88213e5087b5c9c36e754d9aa02 (diff)
parentb1b4e2aadff5983d443d70c09ea86a41b015873f (diff)
downloadfork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.tar.gz
fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.tar.bz2
fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.zip
Merge branch 'next'
Diffstat (limited to 'src/option.h')
-rw-r--r--src/option.h108
1 files changed, 54 insertions, 54 deletions
diff --git a/src/option.h b/src/option.h
index f11497a4..91ff26f9 100644
--- a/src/option.h
+++ b/src/option.h
@@ -52,10 +52,10 @@ template <typename T>
class option_t
{
protected:
- const char * name;
+ const char * name;
string::size_type name_len;
- const char ch;
- bool handled;
+ const char ch;
+ bool handled;
optional<string> source;
option_t& operator=(const option_t&);
@@ -63,7 +63,7 @@ protected:
public:
T * parent;
value_t value;
- bool wants_arg;
+ bool wants_arg;
option_t(const char * _name, const char _ch = '\0')
: name(_name), name_len(std::strlen(name)), ch(_ch),
@@ -93,11 +93,11 @@ public:
out.width(24);
out << std::right << desc();
if (wants_arg) {
- out << " = ";
- value.print(out, 42);
+ out << " = ";
+ value.print(out, 42);
} else {
- out.width(45);
- out << ' ';
+ out.width(45);
+ out << ' ';
}
out << std::left << *source << std::endl;
}
@@ -108,10 +108,10 @@ public:
out << "--";
for (const char * p = name; *p; p++) {
if (*p == '_') {
- if (*(p + 1))
- out << '-';
+ if (*(p + 1))
+ out << '-';
} else {
- out << *p;
+ out << *p;
}
}
if (ch)
@@ -145,7 +145,7 @@ public:
on_with(whence, string_value(str));
}
virtual void on_with(const optional<string>& whence,
- const value_t& val) {
+ const value_t& val) {
handled = true;
value = val;
source = whence;
@@ -162,11 +162,11 @@ public:
virtual void handler(call_scope_t& args) {
if (wants_arg) {
if (args.size() < 2)
- throw_(std::runtime_error, _("No argument provided for %1") << desc());
+ throw_(std::runtime_error, _("No argument provided for %1") << desc());
else if (args.size() > 2)
- throw_(std::runtime_error, _("To many arguments provided for %1") << desc());
+ throw_(std::runtime_error, _("To many arguments provided for %1") << desc());
else if (! args[0].is_string())
- throw_(std::runtime_error, _("Context argument for %1 not a string") << desc());
+ throw_(std::runtime_error, _("Context argument for %1 not a string") << desc());
on_with(args[0].as_string(), args[1]);
}
else if (args.size() < 1) {
@@ -194,9 +194,9 @@ public:
}
else if (wants_arg) {
if (handled)
- return value;
+ return value;
else
- return NULL_VALUE;
+ return NULL_VALUE;
}
else {
return handled;
@@ -204,13 +204,13 @@ public:
}
};
-#define BEGIN(type, name) \
+#define BEGIN(type, name) \
struct name ## option_t : public option_t<type>
-#define CTOR(type, name) \
+#define CTOR(type, name) \
name ## option_t() : option_t<type>(#name)
-#define DECL1(type, name, vartype, var, value) \
- vartype var ; \
+#define DECL1(type, name, vartype, var, value) \
+ vartype var ; \
name ## option_t() : option_t<type>(#name), var(value)
#define DO() virtual void handler_thunk(call_scope_t&)
@@ -220,10 +220,10 @@ public:
#define COPY_OPT(name, other) name ## handler(other.name ## handler)
-#define MAKE_OPT_HANDLER(type, x) \
+#define MAKE_OPT_HANDLER(type, x) \
expr_t::op_t::wrap_functor(bind(&option_t<type>::handler_wrapper, x, _1))
-#define MAKE_OPT_FUNCTOR(type, x) \
+#define MAKE_OPT_FUNCTOR(type, x) \
expr_t::op_t::wrap_functor(bind(&option_t<type>::operator(), x, _1))
inline bool is_eq(const char * p, const char * n) {
@@ -236,57 +236,57 @@ inline bool is_eq(const char * p, const char * n) {
return *p == *n || (! *p && *n == '_' && ! *(n + 1));
}
-#define OPT(name) \
- if (is_eq(p, #name)) \
+#define OPT(name) \
+ if (is_eq(p, #name)) \
return ((name ## handler).parent = this, &(name ## handler))
-#define OPT_ALT(name, alt) \
- if (is_eq(p, #name) || is_eq(p, #alt)) \
+#define OPT_ALT(name, alt) \
+ if (is_eq(p, #name) || is_eq(p, #alt)) \
return ((name ## handler).parent = this, &(name ## handler))
-#define OPT_(name) \
- if (! *(p + 1) || \
- ((name ## handler).wants_arg && \
- *(p + 1) == '_' && ! *(p + 2)) || \
- is_eq(p, #name)) \
+#define OPT_(name) \
+ if (! *(p + 1) || \
+ ((name ## handler).wants_arg && \
+ *(p + 1) == '_' && ! *(p + 2)) || \
+ is_eq(p, #name)) \
return ((name ## handler).parent = this, &(name ## handler))
-#define OPT_CH(name) \
- if (! *(p + 1) || \
- ((name ## handler).wants_arg && \
- *(p + 1) == '_' && ! *(p + 2))) \
+#define OPT_CH(name) \
+ if (! *(p + 1) || \
+ ((name ## handler).wants_arg && \
+ *(p + 1) == '_' && ! *(p + 2))) \
return ((name ## handler).parent = this, &(name ## handler))
#define HANDLER(name) name ## handler
#define HANDLED(name) HANDLER(name)
-#define OPTION(type, name) \
- BEGIN(type, name) \
- { \
- CTOR(type, name) {} \
- } \
+#define OPTION(type, name) \
+ BEGIN(type, name) \
+ { \
+ CTOR(type, name) {} \
+ } \
END(name)
-#define OPTION_(type, name, body) \
- BEGIN(type, name) \
- { \
- CTOR(type, name) {} \
- body \
- } \
+#define OPTION_(type, name, body) \
+ BEGIN(type, name) \
+ { \
+ CTOR(type, name) {} \
+ body \
+ } \
END(name)
-#define OPTION__(type, name, body) \
- BEGIN(type, name) \
- { \
- body \
- } \
+#define OPTION__(type, name, body) \
+ BEGIN(type, name) \
+ { \
+ body \
+ } \
END(name)
bool process_option(const string& whence, const string& name, scope_t& scope,
- const char * arg, const string& varname);
+ const char * arg, const string& varname);
void process_environment(const char ** envp, const string& tag,
- scope_t& scope);
+ scope_t& scope);
strings_list process_arguments(strings_list args, scope_t& scope);