繁体   English   中英

球拍阅读器宏

[英]Racket reader macros

有没有办法在Racket中制作简单的阅读器宏。 我的意思是像这样的概括:

(define-reader-syntax "'" quote)
; finds expressions that start with "'" and wraps them in `(quote ...)`
'(foo) ; => (quote (foo))
'foo ; => (quote foo)

我使用内置语法来明确我的意思。 我想用它做的一件事就是复制clojure的速记lambda (#(+ 1 %) 5) ; => 6 (#(+ 1 %) 5) ; => 6

看起来很容易定义一个“shorthand-lambda”宏并将“#”前缀映射到它。

以下是如何实现速记lambda:

#lang racket

(define rt (make-readtable #f #\# 'non-terminating-macro
                           (λ (c in . _)
                             (define body (read in))
                             `(lambda (%) ,body))))
(parameterize ([current-readtable rt]
               [current-namespace (make-base-namespace)])
  (eval (read (open-input-string "(#(+ 1 %) 5)")))) ;; => 6

以下是如何实现您简单的例子,使得&相当于'

(define rt2 (make-readtable #f #\& #\' #f))

(parameterize ([current-readtable rt2]
               [current-namespace (make-base-namespace)])
  (eval (read (open-input-string "&(3 4 5)")))) ;; => '(3 4 5)

只看该引导进入readtables读者的扩展来看看如何做到这一点。 参考部分也很有用。 可读扩展比您的示例复杂一点,但它们非常强大。

针对您的具体问题, SRFI-26为Scheme提供了类似的语法,Sam Tobin-Hochstadt编写了一个花哨的应用程序 Racket宏,它实现了Scala对此的看法。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM