Fix variable scoping.

Refs #5846
This commit is contained in:
Gunnar Beutner 2014-03-24 09:10:37 +01:00
parent 1aca29afd2
commit 7086b44d3a
1 changed files with 14 additions and 4 deletions

View File

@ -152,10 +152,16 @@ Value AExpression::OpLiteral(const AExpression *expr, const Dictionary::Ptr& loc
Value AExpression::OpVariable(const AExpression *expr, const Dictionary::Ptr& locals) Value AExpression::OpVariable(const AExpression *expr, const Dictionary::Ptr& locals)
{ {
if (locals && locals->Contains(expr->m_Operand1)) Dictionary::Ptr scope = locals;
return locals->Get(expr->m_Operand1);
else while (scope) {
return ScriptVariable::Get(expr->m_Operand1); if (scope->Contains(expr->m_Operand1))
return scope->Get(expr->m_Operand1);
scope = scope->Get("__parent");
}
return ScriptVariable::Get(expr->m_Operand1);
} }
Value AExpression::OpNegate(const AExpression *expr, const Dictionary::Ptr& locals) Value AExpression::OpNegate(const AExpression *expr, const Dictionary::Ptr& locals)
@ -306,12 +312,16 @@ Value AExpression::OpDict(const AExpression *expr, const Dictionary::Ptr& locals
bool in_place = expr->m_Operand2; bool in_place = expr->m_Operand2;
Dictionary::Ptr result = make_shared<Dictionary>(); Dictionary::Ptr result = make_shared<Dictionary>();
result->Set("__parent", locals);
if (arr) { if (arr) {
BOOST_FOREACH(const AExpression::Ptr& aexpr, arr) { BOOST_FOREACH(const AExpression::Ptr& aexpr, arr) {
aexpr->Evaluate(in_place ? locals : result); aexpr->Evaluate(in_place ? locals : result);
} }
} }
result->Remove("__parent");
return result; return result;
} }