diff options
-rw-r--r-- | src/textual.cc | 28 |
1 files changed, 14 insertions, 14 deletions
diff --git a/src/textual.cc b/src/textual.cc index 99635696..018806f7 100644 --- a/src/textual.cc +++ b/src/textual.cc @@ -117,9 +117,9 @@ namespace { if (expr) { value_t result(expr.calc(*xact)); - // jww (2009-02-01): What about storing time-dependent expressions? if (! result.is_amount()) throw_(parse_error, "Transactions may only specify simple amounts"); + amount = result.as_amount(); DEBUG("textual.parse", "The transaction amount is " << amount); return expr; @@ -766,12 +766,6 @@ xact_t * textual_parser_t::instance_t::parse_xact(char * line, static_cast<uint_least8_t>(expr_t::PARSE_NO_REDUCE) | static_cast<uint_least8_t>(expr_t::PARSE_NO_ASSIGN)); - if (! xact->amount.is_null()) { - xact->amount.reduce(); - DEBUG("textual.parse", "line " << linenum << ": " << - "Reduced amount is " << xact->amount); - } - // We don't need to store the actual expression that resulted in the // amount if it's constant if (xact->amount_expr) { @@ -782,6 +776,12 @@ xact_t * textual_parser_t::instance_t::parse_xact(char * line, xact->amount_expr->set_text(string(line, long(beg), long(end - beg))); } } + + if (! xact->amount.is_null()) { + xact->amount.reduce(); + DEBUG("textual.parse", "line " << linenum << ": " << + "Reduced amount is " << xact->amount); + } } // Parse the optional cost (@ PER-UNIT-COST, @@ TOTAL-COST) @@ -871,13 +871,6 @@ xact_t * textual_parser_t::instance_t::parse_xact(char * line, parse_amount_expr(in, *xact->assigned_amount, xact.get(), static_cast<uint_least8_t>(expr_t::PARSE_NO_MIGRATE)); - if (xact->assigned_amount->is_null()) - throw parse_error - ("An assigned balance must evaluate to a constant value"); - - DEBUG("textual.parse", "line " << linenum << ": " << - "XACT assign: parsed amt = " << *xact->assigned_amount); - if (xact->assigned_amount_expr) { end = in.tellg(); xact->assigned_amount_expr->set_text @@ -885,6 +878,13 @@ xact_t * textual_parser_t::instance_t::parse_xact(char * line, } } + if (xact->assigned_amount->is_null()) + throw parse_error + ("An assigned balance must evaluate to a constant value"); + + DEBUG("textual.parse", "line " << linenum << ": " << + "XACT assign: parsed amt = " << *xact->assigned_amount); + account_t::xdata_t& xdata(xact->account->xdata()); amount_t& amt(*xact->assigned_amount); |