diff options
author | John Wiegley <johnw@newartisans.com> | 2008-09-16 05:04:21 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2008-09-16 05:04:21 -0400 |
commit | 660c40a6d3f086d0904b755409bf84681f3034d6 (patch) | |
tree | b7b210374860c5cefce152e7d3232745cc2f5af3 | |
parent | 01aa3800fbee81570efec53ec4406bbba0c68b64 (diff) | |
download | fork-ledger-660c40a6d3f086d0904b755409bf84681f3034d6.tar.gz fork-ledger-660c40a6d3f086d0904b755409bf84681f3034d6.tar.bz2 fork-ledger-660c40a6d3f086d0904b755409bf84681f3034d6.zip |
Corrected several assertions which could occur when using unary operators and
unresolved identifiers.
-rw-r--r-- | src/op.cc | 22 |
1 files changed, 12 insertions, 10 deletions
@@ -141,11 +141,9 @@ value_t expr_t::op_t::calc(scope_t& scope) return left()->calc(scope) / right()->calc(scope); case O_NEG: - assert(! right()); return left()->calc(scope).negate(); case O_NOT: - assert(! right()); return ! left()->calc(scope); case O_AND: @@ -443,9 +441,10 @@ void expr_t::op_t::dump(std::ostream& out, const int depth) const if (kind > TERMINALS || kind == IDENT) { if (left()) { left()->dump(out, depth + 1); - if (right()) + if (kind > UNARY_OPERATORS && right()) right()->dump(out, depth + 1); - } else { + } + else if (kind > UNARY_OPERATORS) { assert(! right()); } } @@ -459,7 +458,7 @@ void expr_t::op_t::read(const char *& data) set_left(new expr_t::op_t()); left()->read(data); - if (binary::read_bool(data)) { + if (kind > UNARY_OPERATORS && binary::read_bool(data)) { set_right(new expr_t::op_t()); right()->read(data); } @@ -503,11 +502,14 @@ void expr_t::op_t::write(std::ostream& out) const if (kind > TERMINALS) { left()->write(out); - if (right()) { - binary::write_bool(out, true); - right()->write(out); - } else { - binary::write_bool(out, false); + + if (kind > UNARY_OPERATORS) { + if (right()) { + binary::write_bool(out, true); + right()->write(out); + } else { + binary::write_bool(out, false); + } } } else { switch (kind) { |