factor/unmaintained/lisp/lisp-tests.factor

95 lines
2.0 KiB
Factor
Raw Normal View History

2008-04-27 23:12:52 -04:00
! Copyright (C) 2008 James Cash
! See http://factorcode.org/license.txt for BSD license.
2008-06-11 01:25:11 -04:00
USING: lisp lisp.parser tools.test sequences math kernel parser arrays lists
quotations ;
2008-04-27 23:12:52 -04:00
2008-04-29 23:10:47 -04:00
IN: lisp.test
2008-07-10 00:28:44 -04:00
[
define-lisp-builtins
2008-05-22 18:38:51 -04:00
{ 5 } [
"(+ 2 3)" lisp-eval
2008-05-22 18:38:51 -04:00
] unit-test
{ 8.3 } [
"(- 10.4 2.1)" lisp-eval
2008-05-22 18:38:51 -04:00
] unit-test
{ 3 } [
"((lambda (x y) (+ x y)) 1 2)" lisp-eval
2008-05-22 18:38:51 -04:00
] unit-test
2008-06-18 12:13:19 -04:00
{ 42 } [
"((lambda (x y z) (+ x (- y z))) 40 3 1)" lisp-eval
2008-06-18 12:13:19 -04:00
] unit-test
2008-05-22 18:38:51 -04:00
2008-06-11 01:25:11 -04:00
{ "b" } [
"(cond (#f \"a\") (#t \"b\"))" lisp-eval
2008-06-08 09:01:31 -04:00
] unit-test
2008-06-07 22:32:54 -04:00
2008-06-18 15:08:42 -04:00
{ "b" } [
"(cond ((< 1 2) \"b\") (#t \"a\"))" lisp-eval
2008-06-18 15:08:42 -04:00
] unit-test
{ +nil+ } [
"(list)" lisp-eval
2008-06-05 16:28:24 -04:00
] unit-test
2008-06-11 01:25:11 -04:00
{ { 1 2 3 4 5 } } [
"(list 1 2 3 4 5)" lisp-eval list>seq
2008-06-05 18:14:43 -04:00
] unit-test
2008-06-11 01:25:11 -04:00
{ { 1 2 { 3 { 4 } 5 } } } [
"(list 1 2 (list 3 (list 4) 5))" lisp-eval cons>seq
2008-06-08 09:01:31 -04:00
] unit-test
{ 5 } [
"(begin (+ 1 4))" lisp-eval
] unit-test
2008-05-22 18:38:51 -04:00
2008-07-10 00:28:44 -04:00
{ 5 } [
"(begin (+ 5 6) (+ 1 4))" lisp-eval
] unit-test
2008-06-11 01:25:11 -04:00
{ t } [
T{ lisp-symbol f "if" } lisp-macro?
2008-05-22 18:38:51 -04:00
] unit-test
2008-06-18 12:13:19 -04:00
{ 1 } [
"(if #t 1 2)" lisp-eval
2008-06-18 12:13:19 -04:00
] unit-test
2008-06-11 01:25:11 -04:00
2008-08-23 23:18:42 -04:00
{ 3 } [
"((lambda (x) (if x (+ 1 2) (- 3 5))) #t)" lisp-eval
] unit-test
2008-05-26 15:48:22 -04:00
2008-09-08 23:28:16 -04:00
{ { 5 4 3 } } [
"((lambda (x &rest xs) (cons x xs)) 5 4 3)" lisp-eval cons>seq
] unit-test
{ { 5 } } [
"((lambda (x &rest xs) (cons x xs)) 5)" lisp-eval cons>seq
] unit-test
{ { 1 2 3 4 } } [
"((lambda (&rest xs) xs) 1 2 3 4)" lisp-eval cons>seq
] unit-test
2008-09-08 23:37:55 -04:00
{ 10 } [
<LISP (begin (+ 1 2) (+ 9 1)) LISP>
] unit-test
2008-09-08 23:28:16 -04:00
2008-09-08 23:37:55 -04:00
{ 4 } [
<LISP ((lambda (x y) (if x (+ 1 y) (+ 2 y))) #t 3) LISP>
] unit-test
2008-09-08 23:28:16 -04:00
2008-09-16 19:40:30 -04:00
{ { 3 3 4 } } [
2008-09-14 21:28:36 -04:00
<LISP (defun foo (x y &rest z)
(cons (+ x y) z))
2008-09-14 20:24:06 -04:00
(foo 1 2 3 4)
LISP> cons>seq
] unit-test
2008-05-26 17:02:23 -04:00
] with-interactive-vocabs