diff options
author | John Wiegley <johnw@newartisans.com> | 2006-03-08 18:24:56 +0000 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2008-04-13 02:41:29 -0400 |
commit | e32d9e64a768f276e04fe79c14f1b28d88bd4185 (patch) | |
tree | 198f0b5a65a2eeb6f1f0a61dc59bf5111e7ae50d /balance.cc | |
parent | b737cd8e6dd185beeae902caa4eee6c4cee8bc36 (diff) | |
download | fork-ledger-e32d9e64a768f276e04fe79c14f1b28d88bd4185.tar.gz fork-ledger-e32d9e64a768f276e04fe79c14f1b28d88bd4185.tar.bz2 fork-ledger-e32d9e64a768f276e04fe79c14f1b28d88bd4185.zip |
Added much better error location.
Diffstat (limited to 'balance.cc')
-rw-r--r-- | balance.cc | 18 |
1 files changed, 8 insertions, 10 deletions
@@ -22,7 +22,7 @@ amount_t balance_t::amount(const commodity_t& commodity) const std::ostringstream errmsg; errmsg << "Requested amount of a balance with multiple commodities: " << *this; - throw amount_error(errmsg.str()); + throw new amount_error(errmsg.str()); } } else if (amounts.size() > 0) { @@ -214,7 +214,7 @@ balance_t& balance_t::operator*=(const balance_t& bal) std::ostringstream errmsg; errmsg << "Cannot multiply two balances: " << *this << " * " << bal; - throw amount_error(errmsg.str()); + throw new amount_error(errmsg.str()); } } @@ -255,7 +255,7 @@ balance_t& balance_t::operator*=(const amount_t& amt) errmsg << "Attempt to multiply balance by a commodity" << " not found in that balance: " << *this << " * " << amt; - throw amount_error(errmsg.str()); + throw new amount_error(errmsg.str()); } } return *this; @@ -266,7 +266,7 @@ balance_t& balance_t::operator/=(const balance_t& bal) if (bal.realzero()) { std::ostringstream errmsg; errmsg << "Attempt to divide by zero: " << *this << " / " << bal; - throw amount_error(errmsg.str()); + throw new amount_error(errmsg.str()); } else if (realzero()) { return *this = 0L; @@ -285,7 +285,7 @@ balance_t& balance_t::operator/=(const balance_t& bal) std::ostringstream errmsg; errmsg << "Cannot divide between two balances: " << *this << " / " << bal; - throw amount_error(errmsg.str()); + throw new amount_error(errmsg.str()); } } @@ -294,7 +294,7 @@ balance_t& balance_t::operator/=(const amount_t& amt) if (amt.realzero()) { std::ostringstream errmsg; errmsg << "Attempt to divide by zero: " << *this << " / " << amt; - throw amount_error(errmsg.str()); + throw new amount_error(errmsg.str()); } else if (realzero()) { return *this = 0L; @@ -326,7 +326,7 @@ balance_t& balance_t::operator/=(const amount_t& amt) errmsg << "Attempt to divide balance by a commodity" << " not found in that balance: " << *this << " * " << amt; - throw amount_error(errmsg.str()); + throw new amount_error(errmsg.str()); } } return *this; @@ -349,7 +349,7 @@ balance_t::operator amount_t() const std::ostringstream errmsg; errmsg << "Cannot convert a balance with " << "multiple commodities to an amount: " << *this; - throw amount_error(errmsg.str()); + throw new amount_error(errmsg.str()); } } @@ -464,7 +464,6 @@ void export_balance() .def("date", &balance_t::date) .def("strip_annotations", &balance_t::strip_annotations) .def("write", &balance_t::write) - .def("abs", &balance_t::abs) .def("round", &balance_t::round) .def("negate", &balance_t::negate) .def("negated", &balance_t::negated) @@ -553,7 +552,6 @@ void export_balance() .def("date", &balance_pair_t::date) .def("strip_annotations", &balance_pair_t::strip_annotations) .def("write", &balance_pair_t::write) - .def("abs", &balance_pair_t::abs) .def("round", &balance_pair_t::round) .def("negate", &balance_pair_t::negate) .def("negated", &balance_pair_t::negated) |