X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Feval.impure.lisp;h=5989e51e5979f30c0dc2641d69184b65fae707a9;hb=cfc1753e593943c7d0eb8d0621158948917f8304;hp=da75fb08ad6a947ceb49ed4ecba15a1d7fce0ed8;hpb=0ca182b2e0fd9a7fc8005bef9d21000b326208fc;p=sbcl.git diff --git a/tests/eval.impure.lisp b/tests/eval.impure.lisp index da75fb0..5989e51 100644 --- a/tests/eval.impure.lisp +++ b/tests/eval.impure.lisp @@ -188,4 +188,13 @@ (with-output-to-string (*standard-output*) (eval '(progn (princ ".") (let ((x 42)) t) (princ ".")))))) +;;; IF +(defun true () t) +(defun false () nil) +(defmacro oops () (throw :oops (list))) +(defun test-eval (ok form) (assert (eq ok (catch :oops (eval form))))) +(test-eval t '(if (false) (oops) t)) +(test-eval t '(if (true) t (oops))) +(test-eval nil '(if (not (if (false) t)) (oops))) + ;;; success