summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2008-09-16 05:04:21 -0400
committerJohn Wiegley <johnw@newartisans.com>2008-09-16 05:04:21 -0400
commit660c40a6d3f086d0904b755409bf84681f3034d6 (patch)
treeb7b210374860c5cefce152e7d3232745cc2f5af3
parent01aa3800fbee81570efec53ec4406bbba0c68b64 (diff)
downloadfork-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.cc22
1 files changed, 12 insertions, 10 deletions
diff --git a/src/op.cc b/src/op.cc
index 51a26c6e..b19ac730 100644
--- a/src/op.cc
+++ b/src/op.cc
@@ -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) {