From 291433e057263e10ad988ad062b8530e1be30bcc Mon Sep 17 00:00:00 2001 From: =?utf8?q?David=20V=C3=A1zquez?= Date: Wed, 24 Apr 2013 19:40:15 +0100 Subject: [PATCH] translate-variable checks if the symbol is unbound --- ecmalisp.lisp | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/ecmalisp.lisp b/ecmalisp.lisp index 9fd5cba..a7f9f5c 100644 --- a/ecmalisp.lisp +++ b/ecmalisp.lisp @@ -931,6 +931,10 @@ (aset v i x) (incf i)))) +(defmacro awhen (condition &body body) + `(let ((it ,condition)) + (when it ,@body))) + #+ecmalisp (progn (defun values-list (list) @@ -1358,6 +1362,9 @@ (incf index))))) ',name))) + +;;; Environment + (def!struct binding name type @@ -1399,7 +1406,8 @@ (code "v" (incf *variable-counter*))) (defun translate-variable (symbol) - (binding-value (lookup-in-lexenv symbol *environment* 'variable))) + (awhen (lookup-in-lexenv symbol *environment* 'variable) + (binding-value it))) (defun extend-local-env (args) (let ((new (copy-lexenv *environment*))) -- 1.7.10.4