From 4028f0bcb455ce4ea23c355b6a43dc6122447a78 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Fri, 7 May 2010 23:16:45 -0400 Subject: print command correctly prints amount expressions --- src/expr.cc | 15 +++++++++++++-- src/print.cc | 12 +++++++++--- 2 files changed, 22 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/expr.cc b/src/expr.cc index 79fb3611..8fed2b14 100644 --- a/src/expr.cc +++ b/src/expr.cc @@ -39,10 +39,21 @@ namespace ledger { void expr_t::parse(std::istream& in, const parse_flags_t& flags, const optional& original_string) { - base_type::parse(in, flags, original_string); - parser_t parser; + istream_pos_type start_pos = in.tellg(); ptr = parser.parse(in, flags, original_string); + istream_pos_type end_pos = in.tellg(); + + if (original_string) { + set_text(*original_string); + } else { + in.clear(); + in.seekg(start_pos, std::ios::beg); + scoped_array buf + (new char[static_cast(end_pos - start_pos) + 1]); + in.read(buf.get(), end_pos - start_pos); + set_text(buf.get()); + } } void expr_t::compile(scope_t& scope) diff --git a/src/print.cc b/src/print.cc index eb102a87..34f5af51 100644 --- a/src/print.cc +++ b/src/print.cc @@ -140,9 +140,15 @@ namespace { if (slip > 0) out << string(slip, ' '); - std::ostringstream amt_str; - report.scrub(post->amount).print(amt_str, 12, -1, true); - string amt = amt_str.str(); + string amt; + if (post->amount_expr) { + amt = post->amount_expr->text(); + } else { + std::ostringstream amt_str; + report.scrub(post->amount).print(amt_str, 12, -1, true); + amt = amt_str.str(); + } + string trimmed_amt(amt); trim_left(trimmed_amt); int amt_slip = (static_cast(amt.length()) - -- cgit v1.2.3