From ea9330adaeedbdb5a03b4f37910b30f0ddb23e29 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Sat, 7 Feb 2009 05:47:21 -0400 Subject: Allow value expressions to gain access to option settings. For example, "ledger eval options.limit" prints 0 (for false), but: "ledger -l hello eval options.limit" print "hello"s, since the value of options.limit, once set to a value, is that string. For flag options, such as -Y, eval prints 0 if unset, and 1 if set. This feature allows value expressions to be conditionalized based on the presence of user options. --- src/global.cc | 46 +++++++++++++++++++++++++++------------------- 1 file changed, 27 insertions(+), 19 deletions(-) (limited to 'src/global.cc') diff --git a/src/global.cc b/src/global.cc index 497dc397..8915d763 100644 --- a/src/global.cc +++ b/src/global.cc @@ -238,32 +238,40 @@ int global_scope_t::execute_command_wrapper(strings_list args, bool at_repl) return status; } +option_t * global_scope_t::lookup_option(const char * p) +{ + switch (*p) { + case 'd': + OPT(debug_); + break; + case 'i': + OPT(init_file_); + break; + case 's': + OPT(script_); + break; + case 't': + OPT(trace_); + break; + case 'v': + OPT_(verbose); + else OPT(verify); + else OPT(version); + break; + } + return NULL; +} + expr_t::ptr_op_t global_scope_t::lookup(const string& name) { const char * p = name.c_str(); switch (*p) { case 'o': if (WANT_OPT()) { p += OPT_PREFIX_LEN; - switch (*p) { - case 'd': - OPT(debug_); - break; - case 'i': - OPT(init_file_); - break; - case 's': - OPT(script_); - break; - case 't': - OPT(trace_); - break; - case 'v': - OPT_(verbose); - else OPT(verify); - else OPT(version); - break; - } + if (option_t * handler = lookup_option(p)) + return MAKE_OPT_HANDLER(global_scope_t, handler); } + break; case 'p': if (WANT_PRECMD()) { p += PRECMD_PREFIX_LEN; -- cgit v1.2.3