summaryrefslogtreecommitdiff
path: root/python/py_amount.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2009-01-31 04:25:05 -0400
committerJohn Wiegley <johnw@newartisans.com>2009-01-31 04:25:05 -0400
commite9ff5caa13e2d60681010dbedcf56459ee7521a4 (patch)
tree056a124c232daccb3dcc616a32fb3b2a9c217d86 /python/py_amount.cc
parentc96ab6cb0fb289cd50fb239ba44c01aba131fc18 (diff)
downloadfork-ledger-e9ff5caa13e2d60681010dbedcf56459ee7521a4.tar.gz
fork-ledger-e9ff5caa13e2d60681010dbedcf56459ee7521a4.tar.bz2
fork-ledger-e9ff5caa13e2d60681010dbedcf56459ee7521a4.zip
Rationals based math is now passing the unit tests.
Diffstat (limited to 'python/py_amount.cc')
-rw-r--r--python/py_amount.cc73
1 files changed, 38 insertions, 35 deletions
diff --git a/python/py_amount.cc b/python/py_amount.cc
index b57687f2..2528f779 100644
--- a/python/py_amount.cc
+++ b/python/py_amount.cc
@@ -41,29 +41,6 @@ namespace ledger {
using namespace boost::python;
-#ifdef INTEGER_MATH
-amount_t py_round_0(const amount_t& amount) {
- return amount.round();
-}
-amount_t py_round_1(const amount_t& amount, amount_t::precision_t prec) {
- return amount.round(prec);
-}
-#endif
-
-double py_to_double_0(amount_t& amount) {
- return amount.to_double();
-}
-double py_to_double_1(amount_t& amount, bool no_check) {
- return amount.to_double(no_check);
-}
-
-long py_to_long_0(amount_t& amount) {
- return amount.to_long();
-}
-long py_to_long_1(amount_t& amount, bool no_check) {
- return amount.to_long(no_check);
-}
-
boost::optional<amount_t> py_value_0(const amount_t& amount) {
return amount.value();
}
@@ -169,7 +146,9 @@ void export_amount()
make_getter(&amount_t::stream_fullstrings),
make_setter(&amount_t::stream_fullstrings))
+#if 0
.def(init<double>())
+#endif
.def(init<long>())
.def(init<std::string>())
@@ -185,80 +164,108 @@ internal precision.")
.def(self == self)
.def(self == long())
.def(long() == self)
+#if 0
.def(self == double())
.def(double() == self)
+#endif
.def(self != self)
.def(self != long())
.def(long() != self)
+#if 0
.def(self != double())
.def(double() != self)
+#endif
.def(! self)
.def(self < self)
.def(self < long())
.def(long() < self)
+#if 0
.def(self < double())
.def(double() < self)
+#endif
.def(self <= self)
.def(self <= long())
.def(long() <= self)
+#if 0
.def(self <= double())
.def(double() <= self)
+#endif
.def(self > self)
.def(self > long())
.def(long() > self)
+#if 0
.def(self > double())
.def(double() > self)
+#endif
.def(self >= self)
.def(self >= long())
.def(long() >= self)
+#if 0
.def(self >= double())
.def(double() >= self)
+#endif
.def(self += self)
.def(self += long())
+#if 0
.def(self += double())
+#endif
.def(self + self)
.def(self + long())
.def(long() + self)
+#if 0
.def(self + double())
.def(double() + self)
+#endif
.def(self -= self)
.def(self -= long())
+#if 0
.def(self -= double())
+#endif
.def(self - self)
.def(self - long())
.def(long() - self)
+#if 0
.def(self - double())
.def(double() - self)
+#endif
.def(self *= self)
.def(self *= long())
+#if 0
.def(self *= double())
+#endif
.def(self * self)
.def(self * long())
.def(long() * self)
+#if 0
.def(self * double())
.def(double() * self)
+#endif
.def(self /= self)
.def(self /= long())
+#if 0
.def(self /= double())
+#endif
.def(self / self)
.def(self / long())
.def(long() / self)
+#if 0
.def(self / double())
.def(double() / self)
+#endif
.def("precision", &amount_t::precision)
@@ -270,11 +277,8 @@ internal precision.")
.def("abs", &amount_t::abs)
.def("__abs__", &amount_t::abs)
-#ifdef INTEGER_MATH
- .def("round", py_round_0)
- .def("round", py_round_1)
-#endif
- .def("unround", &amount_t::unround)
+ .def("rounded", &amount_t::rounded)
+ .def("unrounded", &amount_t::unrounded)
.def("reduce", &amount_t::reduce)
.def("in_place_reduce", &amount_t::in_place_reduce,
@@ -295,18 +299,15 @@ internal precision.")
.def("is_realzero", &amount_t::is_realzero)
.def("is_null", &amount_t::is_null)
- .def("to_double", py_to_double_0)
- .def("to_double", py_to_double_1)
- .def("__float__", py_to_double_0)
- .def("to_long", py_to_long_0)
- .def("to_long", py_to_long_1)
- .def("__int__", py_to_long_0)
+ .def("to_double", &amount_t::to_double)
+ .def("__float__", &amount_t::to_double)
+ .def("to_long", &amount_t::to_long)
+ .def("__int__", &amount_t::to_long)
.def("to_string", &amount_t::to_string)
.def("__str__", &amount_t::to_string)
.def("to_fullstring", &amount_t::to_fullstring)
.def("__repr__", &amount_t::to_fullstring)
- .def("fits_in_double", &amount_t::fits_in_double)
.def("fits_in_long", &amount_t::fits_in_long)
.def("quantity_string", &amount_t::quantity_string)
@@ -359,7 +360,9 @@ internal precision.")
register_optional_to_python<amount_t>();
+#if 0
implicitly_convertible<double, amount_t>();
+#endif
implicitly_convertible<long, amount_t>();
implicitly_convertible<string, amount_t>();