diff options
author | Aaron Marks <nymacro@gmail.com> | 2020-01-03 23:29:15 +1000 |
---|---|---|
committer | Aaron Marks <nymacro@gmail.com> | 2020-01-03 23:29:15 +1000 |
commit | 645e4775420c59bb10ef0693ed2631a8df8c0e29 (patch) | |
tree | 3dc334bf2ce20ab242f8b003333c51c1342c79d2 /scheme/chez/geiser/test.ss | |
parent | 6ec47dc1b57c1475ace9869efc1d23332da89e9b (diff) | |
download | geiser-guile-645e4775420c59bb10ef0693ed2631a8df8c0e29.tar.gz geiser-guile-645e4775420c59bb10ef0693ed2631a8df8c0e29.tar.bz2 |
Add rudimentary Chez support for macro expansion
Diffstat (limited to 'scheme/chez/geiser/test.ss')
-rw-r--r-- | scheme/chez/geiser/test.ss | 33 |
1 files changed, 32 insertions, 1 deletions
diff --git a/scheme/chez/geiser/test.ss b/scheme/chez/geiser/test.ss index ac5503b..21f3396 100644 --- a/scheme/chez/geiser/test.ss +++ b/scheme/chez/geiser/test.ss @@ -1,13 +1,21 @@ (import (geiser) (chezscheme)) +(define-syntax assert-equal + (syntax-rules () + ((_ a b) + (if (equal? a b) + #t + (begin + (display (format "failed assertion `~a' == `~a'" a b)) + (assert (equal? a b))))))) (define-syntax get-result (syntax-rules () ((_ form) (with-output-to-string (lambda () - (geiser:eval #f form)))))) + (geiser:eval #f form)))))) (define-syntax do-test (syntax-rules () @@ -17,6 +25,29 @@ (get-result form) result))))) +(define-syntax do-test-macroexpand + (syntax-rules () + ((_ form result) + (assert + (equal? (geiser:macroexpand form) + result))))) + +(define-syntax test-or + (syntax-rules () + ((_ x) x) + ((_ x xs ...) + (if x + x + (test-or xs ...))))) + +(do-test-macroexpand + '(test-or 1) + '1) + +(do-test-macroexpand + '(test-or 1 2) + '(if 1 1 2)) + ;; (something-doesnot-exist) ;;=> Error: Exception: variable something-doesnot-exist is not bound (do-test |