diff options
author | John Wiegley <johnw@newartisans.com> | 2010-06-10 08:16:59 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2010-06-10 08:16:59 -0400 |
commit | 77c5df4053855addcf0ed58e0e45b0226bd0d31c (patch) | |
tree | de5641a591a3669ebbe686151b9c40b2910b8e38 | |
parent | 7be17fd779db1ee2a20064bdf3b4a8f5da3eb968 (diff) | |
download | fork-ledger-77c5df4053855addcf0ed58e0e45b0226bd0d31c.tar.gz fork-ledger-77c5df4053855addcf0ed58e0e45b0226bd0d31c.tar.bz2 fork-ledger-77c5df4053855addcf0ed58e0e45b0226bd0d31c.zip |
Errors involving value objects provide more context
-rw-r--r-- | src/expr.cc | 5 | ||||
-rw-r--r-- | src/value.cc | 49 |
2 files changed, 45 insertions, 9 deletions
diff --git a/src/expr.cc b/src/expr.cc index f3a30de6..62058e0b 100644 --- a/src/expr.cc +++ b/src/expr.cc @@ -78,6 +78,8 @@ value_t expr_t::real_calc(scope_t& scope) } catch (const std::exception& err) { if (locus) { + string current_context = error_context(); + add_error_context(_("While evaluating value expression:")); add_error_context(op_context(ptr, locus)); @@ -103,6 +105,9 @@ value_t expr_t::real_calc(scope_t& scope) } add_error_context(out.str()); } + + if (! current_context.empty()) + add_error_context(current_context); } throw; } diff --git a/src/value.cc b/src/value.cc index 64193db6..33461c5a 100644 --- a/src/value.cc +++ b/src/value.cc @@ -122,7 +122,9 @@ value_t::operator bool() const break; } + add_error_context(_("While taking boolean value of %1:") << *this); throw_(value_error, _("Cannot determine truth of %1") << label()); + return false; } @@ -313,7 +315,9 @@ value_t value_t::number() const break; } + add_error_context(_("While calling number() on %1:") << *this); throw_(value_error, _("Cannot determine numeric value of %1") << label()); + return false; } @@ -335,6 +339,7 @@ value_t& value_t::operator+=(const value_t& val) for (; i != end(); i++, j++) *i += *j; } else { + add_error_context(_("While adding %1 to %2:") << *this << val); throw_(value_error, _("Cannot add sequences of different lengths")); } } else { @@ -447,7 +452,9 @@ value_t& value_t::operator+=(const value_t& val) break; } + add_error_context(_("While adding %1 to %2:") << *this << val); throw_(value_error, _("Cannot add %1 to %2") << val.label() << label()); + return *this; } @@ -464,6 +471,7 @@ value_t& value_t::operator-=(const value_t& val) for (; i != end(); i++, j++) *i -= *j; } else { + add_error_context(_("While subtracting %1 to %2:") << *this << val); throw_(value_error, _("Cannot subtract sequences of different lengths")); } } else { @@ -586,6 +594,7 @@ value_t& value_t::operator-=(const value_t& val) break; } + add_error_context(_("While subtracting %1 from %2:") << *this << val); throw_(value_error, _("Cannot subtract %1 from %2") << val.label() << label()); return *this; @@ -667,9 +676,7 @@ value_t& value_t::operator*=(const value_t& val) break; } - DEBUG("value.multiply.error", "Left: " << *this); - DEBUG("value.multiply.error", "Right: " << val); - + add_error_context(_("While multiplying %1 with %2:") << *this << val); throw_(value_error, _("Cannot multiply %1 with %2") << label() << val.label()); return *this; @@ -747,6 +754,7 @@ value_t& value_t::operator/=(const value_t& val) break; } + add_error_context(_("While dividing %1 by %2:") << *this << val); throw_(value_error, _("Cannot divide %1 by %2") << label() << val.label()); return *this; @@ -832,6 +840,7 @@ bool value_t::is_equal_to(const value_t& val) const break; } + add_error_context(_("While comparing equality of %1 to %2:") << *this << val); throw_(value_error, _("Cannot compare %1 to %2") << label() << val.label()); return *this; @@ -958,6 +967,8 @@ bool value_t::is_less_than(const value_t& val) const break; } + add_error_context(_("While comparing if %1 is less than %2:") + << *this << val); throw_(value_error, _("Cannot compare %1 to %2") << label() << val.label()); return *this; @@ -1078,6 +1089,8 @@ bool value_t::is_greater_than(const value_t& val) const break; } + add_error_context(_("While comparing if %1 is greater than %2:") + << *this << val); throw_(value_error, _("Cannot compare %1 to %2") << label() << val.label()); return *this; @@ -1219,6 +1232,7 @@ void value_t::in_place_cast(type_t cast_type) return; } else { + add_error_context(_("While converting %1 to an amount:") << *this); throw_(value_error, _("Cannot convert %1 with multiple commodities to %2") << label() << label(cast_type)); } @@ -1266,6 +1280,7 @@ void value_t::in_place_cast(type_t cast_type) break; } + add_error_context(_("While converting %1:") << *this); throw_(value_error, _("Cannot convert %1 to %2") << label() << label(cast_type)); } @@ -1300,6 +1315,7 @@ void value_t::in_place_negate() break; } + add_error_context(_("While negating %1:") << *this); throw_(value_error, _("Cannot negate %1") << label()); } @@ -1336,6 +1352,7 @@ void value_t::in_place_not() break; } + add_error_context(_("While applying not to %1:") << *this); throw_(value_error, _("Cannot 'not' %1") << label()); } @@ -1365,6 +1382,7 @@ bool value_t::is_realzero() const return ! as_expr(); default: + add_error_context(_("While applying is_realzero to %1:") << *this); throw_(value_error, _("Cannot determine if %1 is really zero") << label()); } return false; @@ -1396,6 +1414,7 @@ bool value_t::is_zero() const return ! as_expr(); default: + add_error_context(_("While applying is_zero to %1:") << *this); throw_(value_error, _("Cannot determine if %1 is zero") << label()); } return false; @@ -1424,6 +1443,7 @@ value_t value_t::value(const optional<datetime_t>& moment, break; } + add_error_context(_("While finding valuation of %1:") << *this); throw_(value_error, _("Cannot find the value of %1") << label()); return NULL_VALUE; } @@ -1511,6 +1531,7 @@ value_t value_t::abs() const break; } + add_error_context(_("While taking abs of %1:") << *this); throw_(value_error, _("Cannot abs %1") << label()); return NULL_VALUE; } @@ -1537,6 +1558,7 @@ void value_t::in_place_round() break; } + add_error_context(_("While rounding %1:") << *this); throw_(value_error, _("Cannot set rounding for %1") << label()); } @@ -1562,6 +1584,7 @@ void value_t::in_place_truncate() break; } + add_error_context(_("While truncating %1:") << *this); throw_(value_error, _("Cannot truncate %1") << label()); } @@ -1587,6 +1610,7 @@ void value_t::in_place_floor() break; } + add_error_context(_("While flooring %1:") << *this); throw_(value_error, _("Cannot floor %1") << label()); } @@ -1612,32 +1636,38 @@ void value_t::in_place_unround() break; } + add_error_context(_("While unrounding %1:") << *this); throw_(value_error, _("Cannot unround %1") << label()); } void value_t::annotate(const annotation_t& details) { - if (is_amount()) + if (is_amount()) { as_amount_lval().annotate(details); - else + } else { + add_error_context(_("While attempting to annotate %1:") << *this); throw_(value_error, _("Cannot annotate %1") << label()); + } } bool value_t::has_annotation() const { - if (is_amount()) + if (is_amount()) { return as_amount().has_annotation(); - else + } else { + add_error_context(_("While checking if %1 has annotations:") << *this); throw_(value_error, _("Cannot determine whether %1 is annotated") << label()); + } return false; } annotation_t& value_t::annotation() { - if (is_amount()) + if (is_amount()) { return as_amount_lval().annotation(); - else { + } else { + add_error_context(_("While requesting the annotations of %1:") << *this); throw_(value_error, _("Cannot request annotation of %1") << label()); return as_amount_lval().annotation(); // quiet g++ warning } @@ -1776,6 +1806,7 @@ void value_t::print(std::ostream& out, break; default: + add_error_context(_("While printing %1:") << *this); throw_(value_error, _("Cannot print %1") << label()); } } |