diff options
author | John Wiegley <johnw@newartisans.com> | 2009-02-08 21:17:23 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2009-02-08 21:17:23 -0400 |
commit | e0b108ff3a64ae76d9fa420b35e35f77f30a54e0 (patch) | |
tree | 0e624d7bcb1fab855c8016f43f5c83e9872af352 /python/py_value.cc | |
parent | 623c57a623eae8e2e79af7bfe1680e507e5d333c (diff) | |
download | fork-ledger-e0b108ff3a64ae76d9fa420b35e35f77f30a54e0.tar.gz fork-ledger-e0b108ff3a64ae76d9fa420b35e35f77f30a54e0.tar.bz2 fork-ledger-e0b108ff3a64ae76d9fa420b35e35f77f30a54e0.zip |
Attribute lookup on a Value object which is a Scope now searches the scope.
Diffstat (limited to 'python/py_value.cc')
-rw-r--r-- | python/py_value.cc | 42 |
1 files changed, 28 insertions, 14 deletions
diff --git a/python/py_value.cc b/python/py_value.cc index f4fe11bc..4962f182 100644 --- a/python/py_value.cc +++ b/python/py_value.cc @@ -39,28 +39,40 @@ using namespace boost::python; BOOST_PYTHON_MEMBER_FUNCTION_OVERLOADS(value_overloads, value, 0, 2) -string py_dump(const value_t& value) { - std::ostringstream buf; - value.dump(buf); - return buf.str(); -} +namespace { + expr_t py_value_getattr(value_t& value, const string& name) + { + if (value.is_pointer()) { + if (scope_t * scope = value.as_pointer_lval<scope_t>()) + return expr_t(scope->lookup(name), scope); + } + throw_(value_error, "Cannot lookup attributes in " << value.label()); + return expr_t(); + } -string py_dump_relaxed(const value_t& value) { - std::ostringstream buf; - value.dump(buf, true); - return buf.str(); -} + string py_dump(const value_t& value) { + std::ostringstream buf; + value.dump(buf); + return buf.str(); + } -void py_set_string(value_t& amount, const string& str) { - return amount.set_string(str); -} + string py_dump_relaxed(const value_t& value) { + std::ostringstream buf; + value.dump(buf, true); + return buf.str(); + } + + void py_set_string(value_t& amount, const string& str) { + return amount.set_string(str); + } #define EXC_TRANSLATOR(type) \ void exc_translate_ ## type(const type& err) { \ PyErr_SetString(PyExc_ArithmeticError, err.what()); \ } -EXC_TRANSLATOR(value_error) + EXC_TRANSLATOR(value_error) +} void export_value() { @@ -262,6 +274,8 @@ void export_value() .def("print", &value_t::print) .def("valid", &value_t::valid) + + .def("__getattr__", py_value_getattr) ; enum_< value_t::type_t >("ValueType") |