12.6 Local Binding with Splicing Body
(require racket/splicing) | package: base |
语法
语法
语法
语法
语法
语法
语法
语法
语法
语法
语法
> (splicing-let-syntax ([one (lambda (stx) #'1)]) (define o one)) > o 1
> one one: undefined;
cannot reference an identifier before its definition
in module: top-level
internal name: one
When a splicing binding form occurs in a top-level context or module context, its local bindings are treated similarly to definitions. In particular, syntax bindings are evaluated every time the module is visited, instead of only once during compilation as in let-syntax, etc.
> (splicing-letrec ([x bad] [bad 1]) x) bad.1: undefined;
cannot reference an identifier before its definition
in module: top-level
internal name: bad.1
If a definition within a splicing form is intended to be local to the splicing body, then the identifier should have a true value for the 'definition-intended-as-local syntax property. For example, splicing-let itself adds the property to locally-bound identifiers as it expands to a sequence of definitions, so that nesting splicing-let within a splicing form works as expected (without any ambiguous bindings).
修改于package base的6.12.0.2版本:Added splicing-parameterize.
Note that require transformers and provide transformers are not affected by syntax parameterization. While all uses of require and provide will be spliced into the enclosing context, derived import or export specifications will expand as if they had not been inside of the splicing-syntax-parameterize.
Additionally, submodules defined with module* that specify #f in place of a module path are affected by syntax parameterization, but other submodules (those defined with module or module* with a module path) are not.
> (define-syntax-parameter place (lambda (stx) #'"Kansas")) > (define-syntax-rule (where) `(at ,(place))) > (where) '(at "Kansas")
> (splicing-syntax-parameterize ([place (lambda (stx) #'"Oz")]) (define here (where))) > here '(at "Oz")
修改于package base的6.11.0.1版本:Modified to syntax parameterize module* submodules that specify #f in place of a module path.