From 46293f0046335bd7a207ec6b7d3957e1741f0826 Mon Sep 17 00:00:00 2001 From: Dan Goodliffe Date: Mon, 1 Dec 2014 16:35:01 +0000 Subject: Don't cache a pointer to the row state instance, it might move! --- project2/common/variables.cpp | 25 +++++++++---------------- 1 file changed, 9 insertions(+), 16 deletions(-) diff --git a/project2/common/variables.cpp b/project2/common/variables.cpp index 591a03e..d3e7254 100644 --- a/project2/common/variables.cpp +++ b/project2/common/variables.cpp @@ -46,13 +46,16 @@ class VariableParent : public VariableImplDyn { VariableType value(ExecContext * ec) const { try { - if (!getValue) { - if (depth > RowState::Stack().size()) { - throw RowSet::ParentOutOfRange(depth); - } - bind(ec, RowState::Stack()[RowState::Stack().size() - depth]); + if (depth > RowState::Stack().size()) { + throw RowSet::ParentOutOfRange(depth); + } + const auto & row = RowState::Stack()[RowState::Stack().size() - depth]; + if (attr) { + return row->resolveAttr(name)(); + } + else { + return row->getCurrentValue(ec, name); } - return getValue(); } catch (RowSet::ParentOutOfRange) { if (!defaultValue) { @@ -68,19 +71,9 @@ class VariableParent : public VariableImplDyn { } } protected: - void bind(ExecContext * ec, const RowState * row) const - { - if (attr) { - getValue = boost::bind(row->resolveAttr(name)); - } - else { - getValue = boost::bind(&RowState::getCurrentValue, row, ec, name); - } - } const size_t depth; const bool attr; const Glib::ustring name; - mutable boost::function0 getValue; }; DECLARE_COMPONENT_LOADER("parent", VariableParent, VariableLoader); -- cgit v1.2.3