summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2011-10-11 15:31:00 -0500
committerJohn Wiegley <johnw@newartisans.com>2011-10-11 15:31:00 -0500
commitfc67484a21a32e0ffbf186e33db70e25497ccdf5 (patch)
tree7c3933ad12d3478e0749f9a7c29d40de1694c8e8 /src
parentd353f4fa009f6086f2be705c141ce9dc6fa7ffa7 (diff)
downloadfork-ledger-fc67484a21a32e0ffbf186e33db70e25497ccdf5.tar.gz
fork-ledger-fc67484a21a32e0ffbf186e33db70e25497ccdf5.tar.bz2
fork-ledger-fc67484a21a32e0ffbf186e33db70e25497ccdf5.zip
amount_t::in_place_floor should round toward zero
Diffstat (limited to 'src')
-rw-r--r--src/amount.cc23
1 files changed, 12 insertions, 11 deletions
diff --git a/src/amount.cc b/src/amount.cc
index 808f118d..99e346b7 100644
--- a/src/amount.cc
+++ b/src/amount.cc
@@ -115,6 +115,7 @@ namespace {
mpq_t quant,
amount_t::precision_t precision,
int zeros_prec = -1,
+ mpfr_rnd_t rnd = MPFR_RNDN,
const optional<commodity_t&>& comm = none)
{
char * buf = NULL;
@@ -135,7 +136,7 @@ namespace {
DEBUG("amount.convert", "num prec = " << num_prec);
mpfr_set_prec(tempfnum, num_prec);
- mpfr_set_z(tempfnum, mpq_numref(quant), GMP_RNDN);
+ mpfr_set_z(tempfnum, mpq_numref(quant), rnd);
mp_prec_t den_prec = mpz_sizeinbase(mpq_denref(quant), 2);
den_prec += amount_t::extend_by_digits*64;
@@ -144,10 +145,10 @@ namespace {
DEBUG("amount.convert", "den prec = " << den_prec);
mpfr_set_prec(tempfden, den_prec);
- mpfr_set_z(tempfden, mpq_denref(quant), GMP_RNDN);
+ mpfr_set_z(tempfden, mpq_denref(quant), rnd);
mpfr_set_prec(tempfb, num_prec + den_prec);
- mpfr_div(tempfb, tempfnum, tempfden, GMP_RNDN);
+ mpfr_div(tempfb, tempfnum, tempfden, rnd);
if (mpfr_asprintf(&buf, "%.*RNf", precision, tempfb) < 0)
throw_(amount_error,
@@ -669,7 +670,7 @@ void amount_t::in_place_floor()
_dup();
std::ostringstream out;
- stream_out_mpq(out, MP(quantity), precision_t(0));
+ stream_out_mpq(out, MP(quantity), precision_t(0), -1, MPFR_RNDZ);
mpq_set_str(MP(quantity), out.str().c_str(), 10);
}
@@ -844,8 +845,8 @@ double amount_t::to_double() const
if (! quantity)
throw_(amount_error, _("Cannot convert an uninitialized amount to a double"));
- mpfr_set_q(tempf, MP(quantity), GMP_RNDN);
- return mpfr_get_d(tempf, GMP_RNDN);
+ mpfr_set_q(tempf, MP(quantity), MPFR_RNDN);
+ return mpfr_get_d(tempf, MPFR_RNDN);
}
long amount_t::to_long() const
@@ -853,14 +854,14 @@ long amount_t::to_long() const
if (! quantity)
throw_(amount_error, _("Cannot convert an uninitialized amount to a long"));
- mpfr_set_q(tempf, MP(quantity), GMP_RNDN);
- return mpfr_get_si(tempf, GMP_RNDN);
+ mpfr_set_q(tempf, MP(quantity), MPFR_RNDN);
+ return mpfr_get_si(tempf, MPFR_RNDN);
}
bool amount_t::fits_in_long() const
{
- mpfr_set_q(tempf, MP(quantity), GMP_RNDN);
- return mpfr_fits_slong_p(tempf, GMP_RNDN);
+ mpfr_set_q(tempf, MP(quantity), MPFR_RNDN);
+ return mpfr_fits_slong_p(tempf, MPFR_RNDN);
}
commodity_t& amount_t::commodity() const
@@ -1239,7 +1240,7 @@ void amount_t::print(std::ostream& _out, const uint_least8_t flags) const
}
stream_out_mpq(out, MP(quantity), display_precision(),
- comm ? commodity().precision() : 0, comm);
+ comm ? commodity().precision() : 0, MPFR_RNDN, comm);
if (comm.has_flags(COMMODITY_STYLE_SUFFIXED)) {
if (comm.has_flags(COMMODITY_STYLE_SEPARATED))