From 6b52a1684f6f828b1d0ba5f212523b0086c4eb31 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Sun, 19 May 2013 04:16:12 -0500 Subject: Fixed parsing of the "fixed" directive --- src/textual.cc | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) (limited to 'src/textual.cc') diff --git a/src/textual.cc b/src/textual.cc index 932bde84..9e19ee37 100644 --- a/src/textual.cc +++ b/src/textual.cc @@ -848,7 +848,8 @@ void instance_t::apply_tag_directive(char * line) void instance_t::apply_rate_directive(char * line) { if (optional > price_point = - commodity_pool_t::current_pool->parse_price_directive(trim_ws(line), true)) { + commodity_pool_t::current_pool->parse_price_directive + (trim_ws(line), true, true)) { apply_stack.push_front (application_t("fixed", fixed_rate_t(price_point->first, price_point->second.price))); @@ -1445,6 +1446,9 @@ post_t * instance_t::parse_post(char * line, PARSE_NO_REDUCE | PARSE_SINGLE | PARSE_NO_ASSIGN, defer_expr, &post->amount_expr); + DEBUG("textual.parse", "line " << context.linenum << ": " + << "post amount = " << post->amount); + if (! post->amount.is_null() && post->amount.has_commodity()) { context.journal->register_commodity(post->amount.commodity(), post.get()); @@ -1456,15 +1460,14 @@ post_t * instance_t::parse_post(char * line, annotation_t details(rate.second); details.add_flags(ANNOTATION_PRICE_FIXATED); post->amount.annotate(details); + DEBUG("textual.parse", "line " << context.linenum << ": " + << "applied rate = " << post->amount); break; } } } } - DEBUG("textual.parse", "line " << context.linenum << ": " - << "post amount = " << post->amount); - if (stream.eof()) { next = NULL; } else { -- cgit v1.2.3