From d082b6485f371b9eae01789b245a7944535a69d2 Mon Sep 17 00:00:00 2001 From: Mitchell Kember Date: Tue, 22 Mar 2016 21:57:56 -0700 Subject: Fix Bug 1147: Check balance assertions against the amount AFTER --- src/textual.cc | 22 ++++++++++++---------- 1 file changed, 12 insertions(+), 10 deletions(-) (limited to 'src/textual.cc') diff --git a/src/textual.cc b/src/textual.cc index ccd87ca0..4549581b 100644 --- a/src/textual.cc +++ b/src/textual.cc @@ -1671,25 +1671,27 @@ post_t * instance_t::parse_post(char * line, break; } - amount_t tot = amt - diff; - DEBUG("post.assign", "line " << context.linenum << ": " << "diff = " << diff); DEBUG("textual.parse", "line " << context.linenum << ": " << "POST assign: diff = " << diff); - if (! diff.is_zero()) { - if (! post->amount.is_null()) { - diff -= post->amount; - if (! no_assertions && ! diff.is_zero()) - throw_(parse_error, - _f("Balance assertion off by %1% (expected to see %2%)") - % diff % tot); - } else { + if (post->amount.is_null()) { + // balance assignment + if (! diff.is_zero()) { post->amount = diff; DEBUG("textual.parse", "line " << context.linenum << ": " << "Overwrite null posting"); } + } else { + // balance assertion + diff -= post->amount; + if (! no_assertions && ! diff.is_zero()) { + amount_t tot = amt - diff; + throw_(parse_error, + _f("Balance assertion off by %1% (expected to see %2%)") + % diff % tot); + } } if (stream.eof()) -- cgit v1.2.3