From 4a463aca3bece8f2beb68b0fc4d347a713ff07a6 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Mon, 9 Feb 2009 00:02:59 -0400 Subject: [PATCH] If a valexpr identifier is unknown at calc time, re-compile at that point. --- src/op.cc | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/op.cc b/src/op.cc index 902ed647..6a48d528 100644 --- a/src/op.cc +++ b/src/op.cc @@ -105,14 +105,17 @@ value_t expr_t::op_t::calc(scope_t& scope, ptr_op_t * locus) break; case IDENT: { - if (! left()) + ptr_op_t def = left(); + if (! def) + def = compile(scope); + if (! def) throw_(calc_error, "Unknown identifier '" << as_ident() << "'"); // Evaluating an identifier is the same as calling its definition // directly, so we create an empty call_scope_t to reflect the scope for // this implicit call. call_scope_t call_args(scope); - result = left()->calc(call_args, locus); + result = def->calc(call_args, locus); break; }