From 2b2ffb7787df634aee1681dac7be48e986d34337 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Thu, 29 Oct 2009 00:23:57 -0400 Subject: If isatty is available, no colors/pager for non-ttys --- src/global.cc | 8 +++++++- src/report.h | 17 ++++++++++++++++- 2 files changed, 23 insertions(+), 2 deletions(-) (limited to 'src') diff --git a/src/global.cc b/src/global.cc index 19cab1c8..6c8cc547 100644 --- a/src/global.cc +++ b/src/global.cc @@ -418,8 +418,14 @@ void global_scope_t::normalize_report_options(const string& verb) report_t& rep(report()); - if (! rep.HANDLED(no_color)) +#ifdef HAVE_ISATTY + 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(pager_) && ! isatty(STDOUT_FILENO)) + rep.HANDLER(pager_).off(); +#endif // jww (2009-02-09): These globals are a hack, but hard to avoid. item_t::use_effective_date = (rep.HANDLED(effective) && diff --git a/src/report.h b/src/report.h index 294af19a..22008af6 100644 --- a/src/report.h +++ b/src/report.h @@ -630,10 +630,11 @@ public: OPTION(report_t, output_); // -o +#ifdef HAVE_ISATTY OPTION__ (report_t, pager_, CTOR(report_t, pager_) { - if (! std::getenv("PAGER")) { + if (! std::getenv("PAGER") && isatty(STDOUT_FILENO)) { bool have_less = false; if (exists(path("/opt/local/bin/less")) || exists(path("/usr/local/bin/less")) || @@ -654,6 +655,20 @@ public: else option_t::on_with(whence, text); }); +#else // HAVE_ISATTY + OPTION__ + (report_t, pager_, + CTOR(report_t, pager_) { + } + virtual void on_with(const optional& whence, const value_t& text) { + string cmd(text.to_string()); + if (cmd == "" || cmd == "false" || cmd == "off" || + cmd == "none" || cmd == "no" || cmd == "disable") + option_t::off(); + else + option_t::on_with(whence, text); + }); +#endif // HAVE_ISATTY OPTION(report_t, payee_as_account); -- cgit v1.2.3 From 55f5868380a4917028365256abcfd6d0b5f0a1e4 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Thu, 29 Oct 2009 00:52:51 -0400 Subject: Setting --date-format in ~/.ledgerrc works again --- src/global.cc | 22 +++++++++++++++------- src/option.cc | 7 +++++-- src/option.h | 2 +- src/report.cc | 2 ++ src/report.h | 4 ++++ src/session.cc | 12 +++++++----- src/session.h | 6 ++++-- src/textual.cc | 38 +++++++++++++++++++++++--------------- test/LedgerHarness.py | 6 ++++-- test/baseline/opt-color.test | 2 +- test/baseline/opt-date-format.test | 6 +++--- test/regress/727B2DF8.test | 2 +- 12 files changed, 70 insertions(+), 39 deletions(-) (limited to 'src') diff --git a/src/global.cc b/src/global.cc index 6c8cc547..8204bf69 100644 --- a/src/global.cc +++ b/src/global.cc @@ -111,7 +111,7 @@ void global_scope_t::read_init() ifstream init(init_file); - if (session().read_journal(init_file) > 0 || + if (session().read_journal(init_file, NULL, &report()) > 0 || session().journal->auto_xacts.size() > 0 || session().journal->period_xacts.size() > 0) { throw_(parse_error, _("Transactions found in initialization file '%1'") @@ -419,12 +419,16 @@ void global_scope_t::normalize_report_options(const string& verb) report_t& rep(report()); #ifdef HAVE_ISATTY - 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(pager_) && ! isatty(STDOUT_FILENO)) - rep.HANDLER(pager_).off(); + 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 // jww (2009-02-09): These globals are a hack, but hard to avoid. @@ -536,6 +540,10 @@ void global_scope_t::normalize_report_options(const string& verb) if (cols > 0) { DEBUG("auto.columns", "cols = " << cols); + if (! rep.HANDLER(date_width_).specified) + rep.HANDLER(date_width_) + .on_with(none, 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() : diff --git a/src/option.cc b/src/option.cc index f47410e2..883080e2 100644 --- a/src/option.cc +++ b/src/option.cc @@ -99,12 +99,15 @@ namespace { } } -void process_option(const string& whence, const string& name, scope_t& scope, +bool process_option(const string& whence, const string& name, scope_t& scope, const char * arg, const string& varname) { op_bool_tuple opt(find_option(scope, name)); - if (opt.first) + if (opt.first) { process_option(whence, opt.first->as_function(), scope, arg, varname); + return true; + } + return false; } void process_environment(const char ** envp, const string& tag, diff --git a/src/option.h b/src/option.h index 89f1ad08..83710a1c 100644 --- a/src/option.h +++ b/src/option.h @@ -295,7 +295,7 @@ inline bool is_eq(const char * p, const char * n) { #define WANT_DIR() \ (std::strncmp(p, DIR_PREFIX, DIR_PREFIX_LEN) == 0) -void process_option(const string& whence, const string& name, scope_t& scope, +bool process_option(const string& whence, const string& name, scope_t& scope, const char * arg, const string& varname); void process_environment(const char ** envp, const string& tag, diff --git a/src/report.cc b/src/report.cc index 281057d3..8628cac7 100644 --- a/src/report.cc +++ b/src/report.cc @@ -560,6 +560,8 @@ option_t * report_t::lookup_option(const char * p) OPT(flat); else OPT_ALT(forecast_while_, forecast_); else OPT(format_); + else OPT(force_color); + else OPT(force_pager); else OPT_ALT(head_, first_); break; case 'g': diff --git a/src/report.h b/src/report.h index 22008af6..4d028e33 100644 --- a/src/report.h +++ b/src/report.h @@ -237,6 +237,8 @@ public: HANDLER(exact).report(out); HANDLER(exchange_).report(out); HANDLER(flat).report(out); + HANDLER(force_color).report(out); + HANDLER(force_pager).report(out); HANDLER(forecast_while_).report(out); HANDLER(format_).report(out); HANDLER(gain).report(out); @@ -539,6 +541,8 @@ public: }); OPTION(report_t, flat); + OPTION(report_t, force_color); + OPTION(report_t, force_pager); OPTION(report_t, forecast_while_); OPTION(report_t, format_); // -F diff --git a/src/session.cc b/src/session.cc index 2e728dd6..ea9ae180 100644 --- a/src/session.cc +++ b/src/session.cc @@ -94,13 +94,14 @@ session_t::session_t() std::size_t session_t::read_journal(std::istream& in, const path& pathname, - account_t * master) + account_t * master, + scope_t * scope) { if (! master) master = journal->master; - std::size_t count = journal->parse(in, *this, master, &pathname, - HANDLED(strict)); + std::size_t count = journal->parse(in, scope ? *scope : *this, + master, &pathname, HANDLED(strict)); // remove calculated totals and flags clean_posts(); @@ -110,13 +111,14 @@ std::size_t session_t::read_journal(std::istream& in, } std::size_t session_t::read_journal(const path& pathname, - account_t * master) + account_t * master, + scope_t * scope) { if (! exists(pathname)) throw_(std::logic_error, _("Cannot read file '%1'") << pathname); ifstream stream(pathname); - return read_journal(stream, pathname, master); + return read_journal(stream, pathname, master, scope); } std::size_t session_t::read_data(const string& master_account) diff --git a/src/session.h b/src/session.h index a51cdba6..4955053d 100644 --- a/src/session.h +++ b/src/session.h @@ -84,9 +84,11 @@ public: std::size_t read_journal(std::istream& in, const path& pathname, - account_t * master = NULL); + account_t * master = NULL, + scope_t * scope = NULL); std::size_t read_journal(const path& pathname, - account_t * master = NULL); + account_t * master = NULL, + scope_t * scope = NULL); std::size_t read_data(const string& master_account = ""); diff --git a/src/textual.cc b/src/textual.cc index 4daecc79..f05499df 100644 --- a/src/textual.cc +++ b/src/textual.cc @@ -38,6 +38,7 @@ #include "option.h" #include "pstream.h" #include "pool.h" +#include "session.h" #define TIMELOG_SUPPORT 1 #if defined(TIMELOG_SUPPORT) @@ -60,7 +61,7 @@ namespace { instance_t * parent; std::istream& in; - scope_t& session_scope; + scope_t& scope; journal_t& journal; account_t * master; const path * original_file; @@ -85,7 +86,7 @@ namespace { time_log_t& _timelog, #endif std::istream& _in, - scope_t& _session_scope, + scope_t& _scope, journal_t& _journal, account_t * _master = NULL, const path * _original_file = NULL, @@ -142,7 +143,7 @@ namespace { virtual expr_t::ptr_op_t lookup(const string& name); }; - void parse_amount_expr(scope_t& session_scope, + void parse_amount_expr(scope_t& scope, std::istream& in, amount_t& amount, post_t * post, @@ -162,7 +163,7 @@ namespace { #endif if (expr) { - bind_scope_t bound_scope(session_scope, *post); + bind_scope_t bound_scope(scope, *post); value_t result(expr.calc(bound_scope)); if (result.is_long()) { @@ -184,7 +185,7 @@ instance_t::instance_t(std::list& _account_stack, time_log_t& _timelog, #endif std::istream& _in, - scope_t& _session_scope, + scope_t& _scope, journal_t& _journal, account_t * _master, const path * _original_file, @@ -194,7 +195,7 @@ instance_t::instance_t(std::list& _account_stack, #if defined(TIMELOG_SUPPORT) timelog(_timelog), #endif - parent(_parent), in(_in), session_scope(_session_scope), + parent(_parent), in(_in), scope(_scope), journal(_journal), master(_master), original_file(_original_file), strict(_strict) { @@ -489,7 +490,14 @@ void instance_t::option_directive(char * line) if (p) *p++ = '\0'; } - process_option(pathname.string(), line + 2, session_scope, p, line); + + if (! process_option(pathname.string(), line + 2, scope, p, line) && + ! dynamic_cast(&scope)) { + if (std::strlen(line + 2) == 1) + throw_(option_error, _("Illegal option -%1") << line + 2); + else + throw_(option_error, _("Illegal option --%1") << line + 2); + } } void instance_t::automated_xact_directive(char * line) @@ -624,7 +632,7 @@ void instance_t::include_directive(char * line) #if defined(TIMELOG_SUPPORT) timelog, #endif - stream, session_scope, journal, master, + stream, scope, journal, master, &filename, strict, this); instance.parse(); @@ -689,7 +697,7 @@ void instance_t::pop_directive(char *) void instance_t::define_directive(char * line) { expr_t def(skip_ws(line)); - def.compile(session_scope); // causes definitions to be established + def.compile(scope); // causes definitions to be established } void instance_t::general_directive(char * line) @@ -865,7 +873,7 @@ post_t * instance_t::parse_post(char * line, if (*next != '(') // indicates a value expression post->amount.parse(stream, amount_t::PARSE_NO_REDUCE); else - parse_amount_expr(session_scope, stream, post->amount, post.get(), + parse_amount_expr(scope, stream, post->amount, post.get(), static_cast(expr_t::PARSE_NO_REDUCE) | static_cast(expr_t::PARSE_SINGLE) | static_cast(expr_t::PARSE_NO_ASSIGN)); @@ -913,7 +921,7 @@ post_t * instance_t::parse_post(char * line, if (*p != '(') // indicates a value expression post->cost->parse(cstream, amount_t::PARSE_NO_MIGRATE); else - parse_amount_expr(session_scope, cstream, *post->cost, post.get(), + parse_amount_expr(scope, cstream, *post->cost, post.get(), static_cast(expr_t::PARSE_NO_MIGRATE) | static_cast(expr_t::PARSE_SINGLE) | static_cast(expr_t::PARSE_NO_ASSIGN)); @@ -966,7 +974,7 @@ post_t * instance_t::parse_post(char * line, if (*p != '(') // indicates a value expression post->assigned_amount->parse(stream, amount_t::PARSE_NO_MIGRATE); else - parse_amount_expr(session_scope, stream, *post->assigned_amount, post.get(), + parse_amount_expr(scope, stream, *post->assigned_amount, post.get(), static_cast(expr_t::PARSE_SINGLE) | static_cast(expr_t::PARSE_NO_MIGRATE)); @@ -1233,11 +1241,11 @@ xact_t * instance_t::parse_xact(char * line, expr_t::ptr_op_t instance_t::lookup(const string& name) { - return session_scope.lookup(name); + return scope.lookup(name); } std::size_t journal_t::parse(std::istream& in, - scope_t& session_scope, + scope_t& scope, account_t * master, const path * original_file, bool strict) @@ -1254,7 +1262,7 @@ std::size_t journal_t::parse(std::istream& in, #if defined(TIMELOG_SUPPORT) timelog, #endif - in, session_scope, *this, master, + in, scope, *this, master, original_file, strict); parsing_instance.parse(); diff --git a/test/LedgerHarness.py b/test/LedgerHarness.py index cd8beca8..cf65f590 100755 --- a/test/LedgerHarness.py +++ b/test/LedgerHarness.py @@ -48,8 +48,10 @@ class LedgerHarness: if columns: insert += ' --columns=80' - command = re.sub('\$ledger', '%s%s --args-only --no-color --pager=none' % \ - (self.ledger, insert), command) + command = re.sub('\$ledger', '%s%s %s %s %s %s' % \ + (self.ledger, insert, '--args-only', + '--no-color', '--pager=none', + '--date-format=%y-%b-%d'), command) return Popen(command, shell=True, close_fds=True, env=env, stdin=PIPE, stdout=PIPE, stderr=PIPE) diff --git a/test/baseline/opt-color.test b/test/baseline/opt-color.test index 169c46ae..6520c7dc 100644 --- a/test/baseline/opt-color.test +++ b/test/baseline/opt-color.test @@ -1,4 +1,4 @@ -bal --color +bal --color --force-color <<< 2007/02/02 RD VMMXX Assets:Investments:Vanguard:VMMXX 0.350 VMMXX @ $1.00 diff --git a/test/baseline/opt-date-format.test b/test/baseline/opt-date-format.test index 7a6983cf..b4e1a332 100644 --- a/test/baseline/opt-date-format.test +++ b/test/baseline/opt-date-format.test @@ -4,8 +4,8 @@ reg --date-format='%Y' Assets:Investments:Vanguard:VMMXX 0.350 VMMXX @ $1.00 Income:Dividends:Vanguard:VMMXX $-0.35 >>>1 -2007 RD VMMXX As:In:Vanguard:VMMXX 0.350 VMMXX 0.350 VMMXX - In:Di:Vanguard:VMMXX $-0.35 $-0.35 - 0.350 VMMXX +2007 RD VMMXX As:In:Vanguard:VMMXX 0.350 VMMXX 0.350 VMMXX + In:Di:Vanguard:VMMXX $-0.35 $-0.35 + 0.350 VMMXX >>>2 === 0 diff --git a/test/regress/727B2DF8.test b/test/regress/727B2DF8.test index 599090a1..8c29e1ff 100644 --- a/test/regress/727B2DF8.test +++ b/test/regress/727B2DF8.test @@ -1,4 +1,4 @@ -reg --color +reg --color --force-color <<< N $ -- cgit v1.2.3