diff options
author | John Wiegley <johnw@newartisans.com> | 2007-05-07 10:27:21 +0000 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2008-04-13 03:38:39 -0400 |
commit | d8498372037a4d0c272547ae48046b2182bcd4b1 (patch) | |
tree | ea3f228c5b6b20d71456e47a418e383669925d5f /src/balance.cc | |
parent | a71d48881e538630aa1d147d58365da84e6db91f (diff) | |
download | fork-ledger-d8498372037a4d0c272547ae48046b2182bcd4b1.tar.gz fork-ledger-d8498372037a4d0c272547ae48046b2182bcd4b1.tar.bz2 fork-ledger-d8498372037a4d0c272547ae48046b2182bcd4b1.zip |
Major restructuring of the value_t class.
Diffstat (limited to 'src/balance.cc')
-rw-r--r-- | src/balance.cc | 58 |
1 files changed, 0 insertions, 58 deletions
diff --git a/src/balance.cc b/src/balance.cc index 9d5e57f4..6952b123 100644 --- a/src/balance.cc +++ b/src/balance.cc @@ -33,39 +33,6 @@ namespace ledger { -balance_t& balance_t::operator*=(const balance_t& bal) -{ - if (is_realzero()) { - return *this; - } - else if (bal.is_realzero()) { - return *this = bal; - } - else if (bal.amounts.size() == 1) { - return *this *= (*bal.amounts.begin()).second; - } - else if (amounts.size() == 1) { - return *this = bal * *this; - } - else { - // Since we would fail with an error at this point otherwise, try - // stripping annotations to see if we can come up with a - // reasonable result. The user will not notice any annotations - // missing (since they are viewing a stripped report anyway), only - // that some of their value expression may not see any pricing or - // date data because of this operation. - - balance_t temp(bal.strip_annotations()); - if (temp.amounts.size() == 1) - return *this *= temp; - temp = strip_annotations(); - if (temp.amounts.size() == 1) - return *this = bal * temp; - - throw_(amount_error, "Cannot multiply two balances: " << temp << " * " << bal); - } -} - balance_t& balance_t::operator*=(const amount_t& amt) { if (is_realzero()) { @@ -107,31 +74,6 @@ balance_t& balance_t::operator*=(const amount_t& amt) return *this; } -balance_t& balance_t::operator/=(const balance_t& bal) -{ - if (bal.is_realzero()) { - throw_(amount_error, "Divide by zero: " << *this << " / " << bal); - } - else if (is_realzero()) { - return *this; - } - else if (bal.amounts.size() == 1) { - return *this /= (*bal.amounts.begin()).second; - } - else if (*this == bal) { - return *this = amount_t(1L); - } - else { - // Try stripping annotations before giving an error. - balance_t temp(bal.strip_annotations()); - if (temp.amounts.size() == 1) - return *this /= temp; - - throw_(amount_error, - "Cannot divide two balances: " << temp << " / " << bal); - } -} - balance_t& balance_t::operator/=(const amount_t& amt) { if (amt.is_realzero()) { |