如何捕获语法异常

ama*_*rov 5 scheme r6rs

我想通过一个测试语法异常的宏来扩展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)) 
Run Code Online (Sandbox Code Playgroud)

有可能吗?如果没有,你会如何编写宏的测试?

test-read-eval-string从srfi-64了解到.它接受一个字符串,将其转换为一个表单并在初始环境中评估该表单.我想要一个宏来评估当前环境中给定的表单并捕获异常.

lep*_*pie 3

执行此操作的唯一可移植方法是通过 eval 调用代码,并将其包装在防护中。

例如:

(define (safe-eval code env)
  (guard [e [(syntax-violation? e) (display e)]]
    (eval code env)))
Run Code Online (Sandbox Code Playgroud)

用法:

> (safe-eval '(let a v) (environment '(rnrs)))
&who: let
&message: "invalid syntax"
&syntax:
  form: (let a v)
  subform: #f
Run Code Online (Sandbox Code Playgroud)

  • 如果您的宏是在库中实现的,我看不到这个问题。 (2认同)