#include "pyinterp.h" #include "pyutils.h" #include "amount.h" #include #include namespace ledger { using namespace boost::python; void py_parse_1(amount_t& amount, const string& str, unsigned char flags) { amount.parse(str, flags); } void py_parse_2(amount_t& amount, const string& str) { amount.parse(str); } 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 py_value_1(const amount_t& amount, const boost::optional& moment) { return amount.value(moment); } boost::optional py_value_2(const amount_t& amount) { return amount.value(); } #define EXC_TRANSLATOR(type) \ void exc_translate_ ## type(const type& err) { \ PyErr_SetString(PyExc_ArithmeticError, err.what()); \ } EXC_TRANSLATOR(amount_error) void export_amount() { scope().attr("AMOUNT_PARSE_NO_MIGRATE") = AMOUNT_PARSE_NO_MIGRATE; scope().attr("AMOUNT_PARSE_NO_REDUCE") = AMOUNT_PARSE_NO_REDUCE; class_< amount_t > ("amount") #if 0 .def("initialize", &amount_t::initialize) .staticmethod("initialize") .def("shutdown", &amount_t::shutdown) .staticmethod("shutdown") #endif .add_static_property("current_pool", make_getter(&amount_t::current_pool, return_value_policy())) .add_static_property("keep_base", &amount_t::keep_base) .add_static_property("keep_price", &amount_t::keep_price) .add_static_property("keep_date", &amount_t::keep_date) .add_static_property("keep_tag", &amount_t::keep_tag) .add_static_property("stream_fullstrings", &amount_t::stream_fullstrings) .def(init()) .def(init()) .def(init()) .def("exact", &amount_t::exact) .staticmethod("exact") .def(init()) .def("compare", &amount_t::compare) .def(self == self) .def(self == long()) .def(long() == self) .def(self == double()) .def(double() == self) .def(self != self) .def(self != long()) .def(long() != self) .def(self != double()) .def(double() != self) .def(! self) .def(self < self) .def(self < long()) .def(long() < self) .def(self < double()) .def(double() < self) .def(self <= self) .def(self <= long()) .def(long() <= self) .def(self <= double()) .def(double() <= self) .def(self > self) .def(self > long()) .def(long() > self) .def(self > double()) .def(double() > self) .def(self >= self) .def(self >= long()) .def(long() >= self) .def(self >= double()) .def(double() >= self) .def(self += self) .def(self += long()) .def(self += double()) .def(self + self) .def(self + long()) .def(long() + self) .def(self + double()) .def(double() + self) .def(self -= self) .def(self -= long()) .def(self -= double()) .def(self - self) .def(self - long()) .def(long() - self) .def(self - double()) .def(double() - self) .def(self *= self) .def(self *= long()) .def(self *= double()) .def(self * self) .def(self * long()) .def(long() * self) .def(self * double()) .def(double() * self) .def(self /= self) .def(self /= long()) .def(self /= double()) .def(self / self) .def(self / long()) .def(long() / self) .def(self / double()) .def(double() / self) .def("precision", &amount_t::precision) .def("negate", &amount_t::negate) .def("in_place_negate", &amount_t::in_place_negate, return_value_policy()) .def(- self) .def("abs", &amount_t::abs) .def("__abs__", &amount_t::abs) .def("round", py_round_1) .def("round", py_round_2) .def("unround", &amount_t::unround) .def("reduce", &amount_t::reduce) .def("in_place_reduce", &amount_t::in_place_reduce, return_value_policy()) .def("unreduce", &amount_t::unreduce) .def("in_place_unreduce", &amount_t::in_place_unreduce, return_value_policy()) .def("value", py_value_1) .def("value", py_value_2) .def("sign", &amount_t::sign) .def("__nonzero__", &amount_t::is_nonzero) .def("is_nonzero", &amount_t::is_nonzero) .def("is_zero", &amount_t::is_zero) .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_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("quantity_string", &amount_t::quantity_string) .add_property("commodity", make_function(&amount_t::commodity, return_value_policy()), make_function(&amount_t::set_commodity, with_custodian_and_ward<1, 2>())) .def("has_commodity", &amount_t::has_commodity) .def("clear_commodity", &amount_t::clear_commodity) .def("number", &amount_t::number) .def("annotate_commodity", &amount_t::annotate_commodity) .def("commodity_annotated", &amount_t::commodity_annotated) .def("annotation_details", &amount_t::annotation_details) .def("strip_annotations", &amount_t::strip_annotations) .def("parse", py_parse_1) .def("parse", py_parse_2) .def("parse_conversion", &amount_t::parse_conversion) .staticmethod("parse_conversion") .def("valid", &amount_t::valid) ; register_optional_to_python(); implicitly_convertible(); implicitly_convertible(); implicitly_convertible(); #define EXC_TRANSLATE(type) \ register_exception_translator(&exc_translate_ ## type); EXC_TRANSLATE(amount_error); } } // namespace ledger