我想通过测试语法异常的宏来扩展srfi-78。我想要这样的东西:
#! /usr/bin/env scheme-script
#!r6rs
(import (rnrs) (srfi :78 lightweight-testing))
; the macros I want to test
(define-syntax some-macros
(syntax-rules ()
[(_) 'ok]))
; the extension to srfi-78
(define-syntax check-exception
(syntax-rules ()
; ... some code ...
))
; tests
; prints "correct" or someting like that
(check (some-macros) => 'ok)
; should print "correct" (i. e. the test passed)
(check-exception (some-macros 'arg))
; should print "error"
; (i. e. the exception was not thrown as expected)
(check-exception (some-macros)) 这是完全可能的吗?如果没有,您将如何为宏编写测试?
我从srfi-64上知道了test-read-eval-string。它接受一个字符串,将其转换为一个表单,并在初始环境中计算该表单。我想要一个宏,在当前环境中评估给定的形式,并捕获异常。
发布于 2012-12-05 17:26:55
要做到这一点,唯一可移植的方法是,通过eval调用代码,并将其包装在一个防护中。
例如:
(define (safe-eval code env)
(guard [e [(syntax-violation? e) (display e)]]
(eval code env)))用法:
> (safe-eval '(let a v) (environment '(rnrs)))
&who: let
&message: "invalid syntax"
&syntax:
form: (let a v)
subform: #fhttps://stackoverflow.com/questions/13701605
复制相似问题