diff options
-rw-r--r-- | src/global.cc | 174 | ||||
-rw-r--r-- | src/global.h | 1 | ||||
-rw-r--r-- | src/report.cc | 171 | ||||
-rw-r--r-- | src/report.h | 2 |
4 files changed, 174 insertions, 174 deletions
diff --git a/src/global.cc b/src/global.cc index 0c8cedd8..e120e5d5 100644 --- a/src/global.cc +++ b/src/global.cc @@ -194,7 +194,7 @@ void global_scope_t::execute_command(strings_list args, bool at_repl) if (! at_repl) session().read_journal_files(); - normalize_report_options(verb); + report().normalize_options(verb); if (! bool(command = look_for_command(bound_scope, verb))) throw_(std::logic_error, _("Unrecognized command '%1'") << verb); @@ -416,178 +416,6 @@ expr_t::func_t global_scope_t::look_for_command(scope_t& scope, return expr_t::func_t(); } -void global_scope_t::normalize_report_options(const string& verb) -{ - // Patch up some of the reporting options based on what kind of - // command it was. - - report_t& rep(report()); - -#ifdef HAVE_ISATTY - if (! rep.HANDLED(force_color)) { - if (! rep.HANDLED(no_color) && isatty(STDOUT_FILENO)) - rep.HANDLER(color).on_only(string("?normalize")); - if (rep.HANDLED(color) && ! isatty(STDOUT_FILENO)) - rep.HANDLER(color).off(); - } - if (! rep.HANDLED(force_pager)) { - if (rep.HANDLED(pager_) && ! isatty(STDOUT_FILENO)) - rep.HANDLER(pager_).off(); - } -#endif - - item_t::use_effective_date = (rep.HANDLED(effective) && - ! rep.HANDLED(actual_dates)); - - rep.session.journal->commodity_pool->keep_base = rep.HANDLED(base); - rep.session.journal->commodity_pool->get_quotes = rep.session.HANDLED(download); - - if (rep.session.HANDLED(price_exp_)) - rep.session.journal->commodity_pool->quote_leeway = - rep.session.HANDLER(price_exp_).value.as_long(); - - if (rep.session.HANDLED(price_db_)) - rep.session.journal->commodity_pool->price_db = - rep.session.HANDLER(price_db_).str(); - else - rep.session.journal->commodity_pool->price_db = none; - - if (rep.HANDLED(date_format_)) - set_date_format(rep.HANDLER(date_format_).str().c_str()); - if (rep.HANDLED(datetime_format_)) - set_datetime_format(rep.HANDLER(datetime_format_).str().c_str()); - if (rep.HANDLED(start_of_week_)) { - if (optional<date_time::weekdays> weekday = - string_to_day_of_week(rep.HANDLER(start_of_week_).str())) - start_of_week = *weekday; - } - - if (verb == "print" || verb == "xact" || verb == "dump") { - rep.HANDLER(related).on_only(string("?normalize")); - rep.HANDLER(related_all).on_only(string("?normalize")); - } - else if (verb == "equity") { - rep.HANDLER(equity).on_only(string("?normalize")); - } - - if (verb == "print") - rep.HANDLER(limit_).on(string("?normalize"), "actual"); - - if (! rep.HANDLED(empty)) - rep.HANDLER(display_).on(string("?normalize"), "amount|(!post&total)"); - - if (verb[0] != 'b' && verb[0] != 'r') - rep.HANDLER(base).on_only(string("?normalize")); - - // If a time period was specified with -p, check whether it also gave a - // begin and/or end to the report period (though these can be overridden - // using -b or -e). Then, if no _duration_ was specified (such as monthly), - // then ignore the period since the begin/end are the only interesting - // details. - if (rep.HANDLED(period_)) { - if (! rep.HANDLED(sort_all_)) - rep.HANDLER(sort_xacts_).on_only(string("?normalize")); - - date_interval_t interval(rep.HANDLER(period_).str()); - - if (! rep.HANDLED(begin_) && interval.start) { - string predicate = - "date>=[" + to_iso_extended_string(*interval.start) + "]"; - rep.HANDLER(limit_).on(string("?normalize"), predicate); - } - if (! rep.HANDLED(end_) && interval.end) { - string predicate = - "date<[" + to_iso_extended_string(*interval.end) + "]"; - rep.HANDLER(limit_).on(string("?normalize"), predicate); - } - - if (! interval.duration) - rep.HANDLER(period_).off(); - } - - // If -j or -J were specified, set the appropriate format string now so as - // to avoid option ordering issues were we to have done it during the - // initial parsing of the options. - if (rep.HANDLED(amount_data)) { - rep.HANDLER(format_) - .on_with(string("?normalize"), rep.HANDLER(plot_amount_format_).value); - } - else if (rep.HANDLED(total_data)) { - rep.HANDLER(format_) - .on_with(string("?normalize"), rep.HANDLER(plot_total_format_).value); - } - - // If the --exchange (-X) option was used, parse out any final price - // settings that may be there. - if (rep.HANDLED(exchange_) && - rep.HANDLER(exchange_).str().find('=') != string::npos) { - value_t(0L).exchange_commodities(rep.HANDLER(exchange_).str(), true, - rep.terminus); - } - - long cols = 0; - if (rep.HANDLED(columns_)) - cols = rep.HANDLER(columns_).value.to_long(); - else if (const char * columns = std::getenv("COLUMNS")) - cols = lexical_cast<long>(columns); - else - cols = 80L; - - if (cols > 0) { - DEBUG("auto.columns", "cols = " << cols); - - if (! rep.HANDLER(date_width_).specified) - rep.HANDLER(date_width_) - .on_with(none, static_cast<long>(format_date(CURRENT_DATE(), - FMT_PRINTED).length())); - - long date_width = rep.HANDLER(date_width_).value.to_long(); - long payee_width = (rep.HANDLER(payee_width_).specified ? - rep.HANDLER(payee_width_).value.to_long() : - int(double(cols) * 0.263157)); - long account_width = (rep.HANDLER(account_width_).specified ? - rep.HANDLER(account_width_).value.to_long() : - int(double(cols) * 0.302631)); - long amount_width = (rep.HANDLER(amount_width_).specified ? - rep.HANDLER(amount_width_).value.to_long() : - int(double(cols) * 0.157894)); - long total_width = (rep.HANDLER(total_width_).specified ? - rep.HANDLER(total_width_).value.to_long() : - amount_width); - - DEBUG("auto.columns", "date_width = " << date_width); - DEBUG("auto.columns", "payee_width = " << payee_width); - DEBUG("auto.columns", "account_width = " << account_width); - DEBUG("auto.columns", "amount_width = " << amount_width); - DEBUG("auto.columns", "total_width = " << total_width); - - if (! rep.HANDLER(date_width_).specified && - ! rep.HANDLER(payee_width_).specified && - ! rep.HANDLER(account_width_).specified && - ! rep.HANDLER(amount_width_).specified && - ! rep.HANDLER(total_width_).specified) { - long total = (4 /* the spaces between */ + date_width + payee_width + - account_width + amount_width + total_width); - if (total > cols) { - DEBUG("auto.columns", "adjusting account down"); - account_width -= total - cols; - DEBUG("auto.columns", "account_width now = " << account_width); - } - } - - if (! rep.HANDLER(date_width_).specified) - rep.HANDLER(date_width_).on_with(string("?normalize"), date_width); - if (! rep.HANDLER(payee_width_).specified) - rep.HANDLER(payee_width_).on_with(string("?normalize"), payee_width); - if (! rep.HANDLER(account_width_).specified) - rep.HANDLER(account_width_).on_with(string("?normalize"), account_width); - if (! rep.HANDLER(amount_width_).specified) - rep.HANDLER(amount_width_).on_with(string("?normalize"), amount_width); - if (! rep.HANDLER(total_width_).specified) - rep.HANDLER(total_width_).on_with(string("?normalize"), total_width); - } -} - void global_scope_t::visit_man_page() const { int pid = fork(); diff --git a/src/global.h b/src/global.h index f7b87973..ab3afed4 100644 --- a/src/global.h +++ b/src/global.h @@ -62,7 +62,6 @@ public: void normalize_session_options(); expr_t::func_t look_for_precommand(scope_t& scope, const string& verb); expr_t::func_t look_for_command(scope_t& scope, const string& verb); - void normalize_report_options(const string& verb); char * prompt_string(); diff --git a/src/report.cc b/src/report.cc index ff7223a8..a911a9d3 100644 --- a/src/report.cc +++ b/src/report.cc @@ -33,6 +33,7 @@ #include "report.h" #include "session.h" +#include "pool.h" #include "format.h" #include "query.h" #include "output.h" @@ -47,6 +48,176 @@ namespace ledger { +void report_t::normalize_options(const string& verb) +{ + // Patch up some of the reporting options based on what kind of + // command it was. + +#ifdef HAVE_ISATTY + if (! HANDLED(force_color)) { + if (! HANDLED(no_color) && isatty(STDOUT_FILENO)) + HANDLER(color).on_only(string("?normalize")); + if (HANDLED(color) && ! isatty(STDOUT_FILENO)) + HANDLER(color).off(); + } + if (! HANDLED(force_pager)) { + if (HANDLED(pager_) && ! isatty(STDOUT_FILENO)) + HANDLER(pager_).off(); + } +#endif + + item_t::use_effective_date = (HANDLED(effective) && + ! HANDLED(actual_dates)); + + session.journal->commodity_pool->keep_base = HANDLED(base); + session.journal->commodity_pool->get_quotes = session.HANDLED(download); + + if (session.HANDLED(price_exp_)) + session.journal->commodity_pool->quote_leeway = + session.HANDLER(price_exp_).value.as_long(); + + if (session.HANDLED(price_db_)) + session.journal->commodity_pool->price_db = + session.HANDLER(price_db_).str(); + else + session.journal->commodity_pool->price_db = none; + + if (HANDLED(date_format_)) + set_date_format(HANDLER(date_format_).str().c_str()); + if (HANDLED(datetime_format_)) + set_datetime_format(HANDLER(datetime_format_).str().c_str()); + if (HANDLED(start_of_week_)) { + if (optional<date_time::weekdays> weekday = + string_to_day_of_week(HANDLER(start_of_week_).str())) + start_of_week = *weekday; + } + + if (verb == "print" || verb == "xact" || verb == "dump") { + HANDLER(related).on_only(string("?normalize")); + HANDLER(related_all).on_only(string("?normalize")); + } + else if (verb == "equity") { + HANDLER(equity).on_only(string("?normalize")); + } + + if (verb == "print") + HANDLER(limit_).on(string("?normalize"), "actual"); + + if (! HANDLED(empty)) + HANDLER(display_).on(string("?normalize"), "amount|(!post&total)"); + + if (verb[0] != 'b' && verb[0] != 'r') + HANDLER(base).on_only(string("?normalize")); + + // If a time period was specified with -p, check whether it also gave a + // begin and/or end to the report period (though these can be overridden + // using -b or -e). Then, if no _duration_ was specified (such as monthly), + // then ignore the period since the begin/end are the only interesting + // details. + if (HANDLED(period_)) { + if (! HANDLED(sort_all_)) + HANDLER(sort_xacts_).on_only(string("?normalize")); + + date_interval_t interval(HANDLER(period_).str()); + + if (! HANDLED(begin_) && interval.start) { + string predicate = + "date>=[" + to_iso_extended_string(*interval.start) + "]"; + HANDLER(limit_).on(string("?normalize"), predicate); + } + if (! HANDLED(end_) && interval.end) { + string predicate = + "date<[" + to_iso_extended_string(*interval.end) + "]"; + HANDLER(limit_).on(string("?normalize"), predicate); + } + + if (! interval.duration) + HANDLER(period_).off(); + } + + // If -j or -J were specified, set the appropriate format string now so as + // to avoid option ordering issues were we to have done it during the + // initial parsing of the options. + if (HANDLED(amount_data)) { + HANDLER(format_) + .on_with(string("?normalize"), HANDLER(plot_amount_format_).value); + } + else if (HANDLED(total_data)) { + HANDLER(format_) + .on_with(string("?normalize"), HANDLER(plot_total_format_).value); + } + + // If the --exchange (-X) option was used, parse out any final price + // settings that may be there. + if (HANDLED(exchange_) && + HANDLER(exchange_).str().find('=') != string::npos) { + value_t(0L).exchange_commodities(HANDLER(exchange_).str(), true, + terminus); + } + + long cols = 0; + if (HANDLED(columns_)) + cols = HANDLER(columns_).value.to_long(); + else if (const char * columns = std::getenv("COLUMNS")) + cols = lexical_cast<long>(columns); + else + cols = 80L; + + if (cols > 0) { + DEBUG("auto.columns", "cols = " << cols); + + if (! HANDLER(date_width_).specified) + HANDLER(date_width_) + .on_with(none, static_cast<long>(format_date(CURRENT_DATE(), + FMT_PRINTED).length())); + + long date_width = HANDLER(date_width_).value.to_long(); + long payee_width = (HANDLER(payee_width_).specified ? + HANDLER(payee_width_).value.to_long() : + int(double(cols) * 0.263157)); + long account_width = (HANDLER(account_width_).specified ? + HANDLER(account_width_).value.to_long() : + int(double(cols) * 0.302631)); + long amount_width = (HANDLER(amount_width_).specified ? + HANDLER(amount_width_).value.to_long() : + int(double(cols) * 0.157894)); + long total_width = (HANDLER(total_width_).specified ? + HANDLER(total_width_).value.to_long() : + amount_width); + + DEBUG("auto.columns", "date_width = " << date_width); + DEBUG("auto.columns", "payee_width = " << payee_width); + DEBUG("auto.columns", "account_width = " << account_width); + DEBUG("auto.columns", "amount_width = " << amount_width); + DEBUG("auto.columns", "total_width = " << total_width); + + if (! HANDLER(date_width_).specified && + ! HANDLER(payee_width_).specified && + ! HANDLER(account_width_).specified && + ! HANDLER(amount_width_).specified && + ! HANDLER(total_width_).specified) { + long total = (4 /* the spaces between */ + date_width + payee_width + + account_width + amount_width + total_width); + if (total > cols) { + DEBUG("auto.columns", "adjusting account down"); + account_width -= total - cols; + DEBUG("auto.columns", "account_width now = " << account_width); + } + } + + if (! HANDLER(date_width_).specified) + HANDLER(date_width_).on_with(string("?normalize"), date_width); + if (! HANDLER(payee_width_).specified) + HANDLER(payee_width_).on_with(string("?normalize"), payee_width); + if (! HANDLER(account_width_).specified) + HANDLER(account_width_).on_with(string("?normalize"), account_width); + if (! HANDLER(amount_width_).specified) + HANDLER(amount_width_).on_with(string("?normalize"), amount_width); + if (! HANDLER(total_width_).specified) + HANDLER(total_width_).on_with(string("?normalize"), total_width); + } +} + void report_t::posts_report(post_handler_ptr handler) { journal_posts_iterator walker(*session.journal.get()); diff --git a/src/report.h b/src/report.h index 5d4ee6fa..c31ffc32 100644 --- a/src/report.h +++ b/src/report.h @@ -124,6 +124,8 @@ public: output_stream.close(); } + void normalize_options(const string& verb); + void posts_report(post_handler_ptr handler); void generate_report(post_handler_ptr handler); void xact_report(post_handler_ptr handler, xact_t& xact); |