diff options
author | John Wiegley <johnw@newartisans.com> | 2009-02-07 05:47:21 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2009-02-07 05:47:21 -0400 |
commit | ea9330adaeedbdb5a03b4f37910b30f0ddb23e29 (patch) | |
tree | 6919e137cc645b2d3be307e1d9e4129fdf971e2e /src/global.cc | |
parent | 66d007db9d4f7b793d53e08acc852b2bda335e32 (diff) | |
download | fork-ledger-ea9330adaeedbdb5a03b4f37910b30f0ddb23e29.tar.gz fork-ledger-ea9330adaeedbdb5a03b4f37910b30f0ddb23e29.tar.bz2 fork-ledger-ea9330adaeedbdb5a03b4f37910b30f0ddb23e29.zip |
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.
Diffstat (limited to 'src/global.cc')
-rw-r--r-- | src/global.cc | 46 |
1 files changed, 27 insertions, 19 deletions
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> * 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<global_scope_t> * handler = lookup_option(p)) + return MAKE_OPT_HANDLER(global_scope_t, handler); } + break; case 'p': if (WANT_PRECMD()) { p += PRECMD_PREFIX_LEN; |