From 8bd16b2e8e61f914767e3d0973e83f7326f11cbc Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Thu, 5 Nov 2009 02:27:08 -0500 Subject: Simplified usage of Boost.Python in several cases --- src/py_account.cc | 4 ++-- src/py_balance.cc | 6 ++++++ src/py_commodity.cc | 4 ++-- src/py_journal.cc | 12 ++++++------ src/py_post.cc | 4 ++-- src/py_value.cc | 4 +++- src/py_xact.cc | 4 ++-- src/pyutils.h | 1 - src/system.hh.in | 6 ------ 9 files changed, 23 insertions(+), 22 deletions(-) (limited to 'src') diff --git a/src/py_account.cc b/src/py_account.cc index 3341c948..b0d0a843 100644 --- a/src/py_account.cc +++ b/src/py_account.cc @@ -172,7 +172,7 @@ void export_account() .add_property("parent", make_getter(&account_t::parent, - return_value_policy())) + return_internal_reference<>())) .def_readwrite("name", &account_t::name) .def_readwrite("note", &account_t::note) @@ -197,7 +197,7 @@ void export_account() .def("valid", &account_t::valid) .def("__len__", accounts_len) - .def("__getitem__", accounts_getitem, return_internal_reference<1>()) + .def("__getitem__", accounts_getitem, return_internal_reference<>()) .def("__iter__", range > (&account_t::accounts_begin, &account_t::accounts_end)) diff --git a/src/py_balance.cc b/src/py_balance.cc index effc6937..6d0ad500 100644 --- a/src/py_balance.cc +++ b/src/py_balance.cc @@ -214,6 +214,12 @@ void export_balance() .def("valid", &balance_t::valid) ; + register_optional_to_python(); + + implicitly_convertible(); + implicitly_convertible(); + implicitly_convertible(); + #define EXC_TRANSLATE(type) \ register_exception_translator(&exc_translate_ ## type); diff --git a/src/py_commodity.cc b/src/py_commodity.cc index c0412a45..7cd84f1c 100644 --- a/src/py_commodity.cc +++ b/src/py_commodity.cc @@ -130,12 +130,12 @@ void export_commodity() class_< commodity_pool_t, boost::noncopyable > ("CommodityPool", no_init) .add_property("null_commodity", make_getter(&commodity_pool_t::null_commodity, - return_value_policy()), + return_internal_reference<>()), make_setter(&commodity_pool_t::null_commodity, with_custodian_and_ward<1, 2>())) .add_property("default_commodity", make_getter(&commodity_pool_t::default_commodity, - return_value_policy()), + return_internal_reference<>()), make_setter(&commodity_pool_t::default_commodity, with_custodian_and_ward<1, 2>())) diff --git a/src/py_journal.cc b/src/py_journal.cc index a9789840..9b3e7513 100644 --- a/src/py_journal.cc +++ b/src/py_journal.cc @@ -192,15 +192,15 @@ void export_journal() .def(init()) .add_property("master", make_getter(&journal_t::master, - return_internal_reference<1>())) + return_internal_reference<>())) .add_property("basket", make_getter(&journal_t::basket, - return_internal_reference<1>()), + return_internal_reference<>()), make_setter(&journal_t::basket)) .add_property("was_loaded", make_getter(&journal_t::was_loaded)) .add_property("commodity_pool", make_getter(&journal_t::commodity_pool, - return_internal_reference<1>())) + return_internal_reference<>())) #if 0 .add_property("xact_finalize_hooks", make_getter(&journal_t::xact_finalize_hooks), @@ -210,10 +210,10 @@ void export_journal() .def("add_account", &journal_t::add_account) .def("remove_account", &journal_t::remove_account) - .def("find_account", py_find_account_1, return_internal_reference<1>()) - .def("find_account", py_find_account_2, return_internal_reference<1>()) + .def("find_account", py_find_account_1, return_internal_reference<>()) + .def("find_account", py_find_account_2, return_internal_reference<>()) .def("find_account_re", &journal_t::find_account_re, - return_internal_reference<1>()) + return_internal_reference<>()) .def("add_xact", &journal_t::add_xact) .def("remove_xact", &journal_t::remove_xact) diff --git a/src/py_post.cc b/src/py_post.cc index b4849c3d..9f7476d1 100644 --- a/src/py_post.cc +++ b/src/py_post.cc @@ -131,12 +131,12 @@ void export_post() .add_property("xact", make_getter(&post_t::xact, - return_value_policy()), + return_internal_reference<>()), make_setter(&post_t::xact, with_custodian_and_ward<1, 2>())) .add_property("account", make_getter(&post_t::account, - return_value_policy()), + return_internal_reference<>()), make_setter(&post_t::account, with_custodian_and_ward<1, 2>())) .add_property("amount", diff --git a/src/py_value.cc b/src/py_value.cc index eec3b833..6e4afaf7 100644 --- a/src/py_value.cc +++ b/src/py_value.cc @@ -314,7 +314,9 @@ void export_value() implicitly_convertible(); implicitly_convertible(); - // jww (2009-11-02): Add implicit conversion of mask objects + implicitly_convertible(); + implicitly_convertible(); + implicitly_convertible(); implicitly_convertible(); implicitly_convertible(); diff --git a/src/py_xact.cc b/src/py_xact.cc index 86e2e067..f5453d15 100644 --- a/src/py_xact.cc +++ b/src/py_xact.cc @@ -85,7 +85,7 @@ void export_xact() class_< xact_base_t, bases > ("TransactionBase") .add_property("journal", make_getter(&xact_base_t::journal, - return_value_policy()), + return_internal_reference<>()), make_setter(&xact_base_t::journal, with_custodian_and_ward<1, 2>())) @@ -146,7 +146,7 @@ void export_xact() ("AutomatedTransactionFinalizer") .add_property("journal", make_getter(&auto_xact_finalizer_t::journal, - return_value_policy()), + return_internal_reference<>()), make_setter(&auto_xact_finalizer_t::journal, with_custodian_and_ward<1, 2>())) .def("__call__", &auto_xact_finalizer_t::operator()) diff --git a/src/pyutils.h b/src/pyutils.h index d9b94d50..5709eb35 100644 --- a/src/pyutils.h +++ b/src/pyutils.h @@ -32,7 +32,6 @@ #ifndef _PY_UTILS_H #define _PY_UTILS_H - template struct object_from_python { diff --git a/src/system.hh.in b/src/system.hh.in index 96febb22..b0b8f1eb 100644 --- a/src/system.hh.in +++ b/src/system.hh.in @@ -243,12 +243,6 @@ void serialize(Archive& ar, istream_pos_type& pos, const unsigned int) #include #include -#include -#include -#include -#include -#include -#include #include #endif // HAVE_BOOST_PYTHON -- cgit v1.2.3