11

试图理解 free-identifier=? 和绑定标识符=?。谁能给我使用 free-identifier= 的等效代码示例?将返回 true 并使用 bound-identifier=? 将返回错误。

谢谢

4

1 回答 1

6

这是一个例子:

(define-syntax (compare-with-x stx)
  (syntax-case stx ()
    [(_ x-in)
     (with-syntax ([free=? (free-identifier=? #'x-in #'x)]
                   [bound=? (bound-identifier=? #'x-in #'x)])
       #'(list free=? bound=?))]))

(define-syntax go
  (syntax-rules ()
    [(go) (compare-with-x x)]))

(go) ;; => '(#t #f)

x引入的 by在其go上具有扩展步骤的标记,但xincompare-with-x没有,因此bound-identifier=?认为它们不同。

这是另一个例子:

(define-syntax (compare-xs stx)
  (syntax-case stx ()
    [(_ x1 x2)
     (with-syntax ([free=? (free-identifier=? #'x1 #'x2)]
                   [bound=? (bound-identifier=? #'x1 #'x2)])
       #'(list free=? bound=?))]))

(define-syntax go2
  (syntax-rules ()
    [(go2 x-in) (compare-xs x-in x)]))

(go2 x) ;; => '(#t #f)

这里go2还引入了x带标记的 an,而作为参数的xgiven togo2没有标记。相同的故事。

于 2011-07-27T23:29:17.567 回答