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/py_amount.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/py_amount.cc')
-rw-r--r-- | src/py_amount.cc | 49 |
1 files changed, 34 insertions, 15 deletions
diff --git a/src/py_amount.cc b/src/py_amount.cc index c9b4e8d3..7fc667e7 100644 --- a/src/py_amount.cc +++ b/src/py_amount.cc @@ -40,27 +40,41 @@ namespace ledger { using namespace boost::python; -void py_parse_1(amount_t& amount, const string& str, unsigned char flags) { - amount.parse(str, flags); +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); } -void py_parse_2(amount_t& amount, const string& str) { + +void py_parse_1(amount_t& amount, const string& str) { amount.parse(str); } +void py_parse_2(amount_t& amount, const string& str, unsigned char flags) { + amount.parse(str, flags); +} +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); } -amount_t py_round_2(const amount_t& amount) { - return amount.round(); -} +boost::optional<amount_t> py_value_0(const amount_t& amount) { + return amount.value(); +} boost::optional<amount_t> py_value_1(const amount_t& amount, const boost::optional<moment_t>& moment) { return amount.value(moment); } -boost::optional<amount_t> py_value_2(const amount_t& amount) { - return amount.value(); -} #define EXC_TRANSLATOR(type) \ void exc_translate_ ## type(const type& err) { \ @@ -193,8 +207,8 @@ void export_amount() .def("abs", &amount_t::abs) .def("__abs__", &amount_t::abs) + .def("round", py_round_0) .def("round", py_round_1) - .def("round", py_round_2) .def("unround", &amount_t::unround) .def("reduce", &amount_t::reduce) @@ -205,8 +219,8 @@ void export_amount() .def("in_place_unreduce", &amount_t::in_place_unreduce, return_value_policy<reference_existing_object>()) + .def("value", py_value_0) .def("value", py_value_1) - .def("value", py_value_2) .def("sign", &amount_t::sign) .def("__nonzero__", &amount_t::is_nonzero) @@ -215,15 +229,20 @@ void export_amount() .def("is_realzero", &amount_t::is_realzero) .def("is_null", &amount_t::is_null) - .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_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_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) .add_property("commodity", |