From 6fa581d64ffe6315e92c277d5ed2c1325345280b Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Sat, 7 Feb 2009 18:42:21 -0400 Subject: Dropped all unnecessary boost header files. --- src/option.cc | 40 ++++++++++++++++++++++++---------------- src/system.hh | 16 +--------------- 2 files changed, 25 insertions(+), 31 deletions(-) (limited to 'src') diff --git a/src/option.cc b/src/option.cc index 366c9c54..b45fc87b 100644 --- a/src/option.cc +++ b/src/option.cc @@ -34,7 +34,7 @@ namespace ledger { namespace { - typedef tuple op_bool_tuple; + typedef std::pair op_bool_tuple; op_bool_tuple find_option(scope_t& scope, const string& name) { @@ -100,8 +100,8 @@ void process_option(const string& name, scope_t& scope, const char * arg, const string& varname) { op_bool_tuple opt(find_option(scope, name)); - if (opt.get<0>()) - process_option(opt.get<0>()->as_function(), scope, arg, varname); + if (opt.first) + process_option(opt.first->as_function(), scope, arg, varname); } void process_environment(const char ** envp, const string& tag, @@ -110,7 +110,7 @@ void process_environment(const char ** envp, const string& tag, const char * tag_p = tag.c_str(); std::size_t tag_len = tag.length(); - for (const char ** p = envp; *p; p++) + for (const char ** p = envp; *p; p++) { if (! tag_p || std::strncmp(*p, tag_p, tag_len) == 0) { char buf[128]; char * r = buf; @@ -135,8 +135,20 @@ void process_environment(const char ** envp, const string& tag, } } } + } } +namespace { + struct op_bool_char_tuple { + expr_t::ptr_op_t op; + bool truth; + char ch; + + op_bool_char_tuple(expr_t::ptr_op_t _op, bool _truth, char _ch) + : op(_op), truth(_truth), ch(_ch) {} + }; +} + strings_list process_arguments(strings_list args, scope_t& scope) { bool anywhere = true; @@ -177,16 +189,16 @@ strings_list process_arguments(strings_list args, scope_t& scope) } op_bool_tuple opt(find_option(scope, opt_name)); - if (! opt.get<0>()) + if (! opt.first) throw_(option_error, "illegal option --" << name); - if (opt.get<1>() && value == NULL) { + if (opt.second && 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); } - process_option(opt.get<0>()->as_function(), scope, value, + process_option(opt.first->as_function(), scope, value, string("--") + name); } else if ((*i)[1] == '\0') { @@ -195,31 +207,27 @@ strings_list process_arguments(strings_list args, scope_t& scope) else { DEBUG("option.args", " single-char option"); - typedef tuple op_bool_char_tuple; - std::list option_queue; int x = 1; for (char c = (*i)[x]; c != '\0'; x++, c = (*i)[x]) { op_bool_tuple opt(find_option(scope, c)); - if (! opt.get<0>()) + if (! opt.first) throw_(option_error, "illegal option -" << c); - option_queue.push_back - (op_bool_char_tuple(opt.get<0>(), opt.get<1>(), c)); + option_queue.push_back(op_bool_char_tuple(opt.first, opt.second, c)); } foreach (op_bool_char_tuple& o, option_queue) { const char * value = NULL; - if (o.get<1>()) { + if (o.truth) { value = (*++i).c_str(); DEBUG("option.args", " read option value from arg: " << value); if (value == NULL) throw_(option_error, - "missing option argument for -" << o.get<2>()); + "missing option argument for -" << o.ch); } - process_option(o.get<0>()->as_function(), scope, value, - string("-") + o.get<2>()); + process_option(o.op->as_function(), scope, value, string("-") + o.ch); } } } diff --git a/src/system.hh b/src/system.hh index 69b8c4e1..d56a1896 100644 --- a/src/system.hh +++ b/src/system.hh @@ -120,21 +120,15 @@ typedef std::ostream::pos_type ostream_pos_type; #endif #include - #ifdef WIN32 #include #else #include #endif - #if defined(HAVE_GETPWUID) || defined(HAVE_GETPWNAM) #include #endif -#if defined(HAVE_NL_LANGINFO) -#include -#endif - #include #include #include "sha1.h" @@ -146,6 +140,7 @@ typedef std::ostream::pos_type ostream_pos_type; #include #include #include +#include #include #include #include @@ -157,19 +152,10 @@ typedef std::ostream::pos_type ostream_pos_type; #include #include #include -#include -#include #include -#include -#include -#include -#include -#include -#include #include #include #include -#include #include #include -- cgit v1.2.3