diff options
-rw-r--r-- | src/option.cc | 8 | ||||
-rw-r--r-- | src/option.h | 20 |
2 files changed, 19 insertions, 9 deletions
diff --git a/src/option.cc b/src/option.cc index 1a68d2a8..f8e6a713 100644 --- a/src/option.cc +++ b/src/option.cc @@ -194,8 +194,8 @@ strings_list process_arguments(strings_list args, scope_t& scope) if (! opt.first) throw_(option_error, "illegal option --" << name); - if (opt.second && value == NULL) { - value = (*++i).c_str(); + if (opt.second && ++i != args.end() && value == NULL) { + value = (*i).c_str(); DEBUG("option.args", " read option value from arg: " << value); if (value == NULL) throw_(option_error, "missing option argument for --" << name); @@ -222,8 +222,8 @@ strings_list process_arguments(strings_list args, scope_t& scope) foreach (op_bool_char_tuple& o, option_queue) { const char * value = NULL; - if (o.truth) { - value = (*++i).c_str(); + if (o.truth && ++i != args.end()) { + value = (*i).c_str(); DEBUG("option.args", " read option value from arg: " << value); if (value == NULL) throw_(option_error, diff --git a/src/option.h b/src/option.h index 7deb5f58..b201cb72 100644 --- a/src/option.h +++ b/src/option.h @@ -90,10 +90,17 @@ public: string desc() const { std::ostringstream out; + out << "--"; + for (const char * p = name; *p; p++) { + if (*p == '_') { + if (*(p + 1)) + out << '-'; + } else { + out << *p; + } + } if (ch) - out << "--" << name << " (-" << ch << ")"; - else - out << "--" << name; + out << " (-" << ch << ")"; return out.str(); } @@ -136,10 +143,13 @@ public: virtual void handler_thunk(call_scope_t&) {} virtual void handler(call_scope_t& args) { - if (wants_arg) + if (wants_arg) { + if (args.empty()) + throw_(std::runtime_error, "No argument provided for " << desc()); on(args[0]); - else + } else { on(); + } handler_thunk(args); } |