Eval
The form eval
takes an LFE data structure and evaluates it as an expression and then returns the value:
lfe> (eval 15)
15
lfe> (eval '(+ 1 2 3 4))
10
lfe> (eval '(list 'a 'b 'c))
(a b c)
Using eval
is one way way to merge lists and code. However, it is not a very good way:
-
It is inefficient as the input expression is evaluated by the LFE interpreter,
lfe_eval
. This is much slower than running compiled code. -
The expression is evaluated without a lexical context. So calling
eval
inside alet
does not allow the evaluated expression to refer to variables bound by thelet
:
lfe> (set expr '(* x y)) ; Expression to evaluate
(* x y)
lfe> (let ((x 17) (y 42)) (eval expr))
exception error: #(unbound_symb x)
Well, this is not quite true. If we "reverse" the code and build a let
expression which imports and binds the variables and then call eval
on it we can access the variables:
lfe> (eval (list 'let (list (list 'x 17) (list 'y 42)) expr))
714