auto-syntax-e/scribblings/auto-syntax-e.scrbl
Georges Dupéron a9c8f48832 Initial commit
2016-10-20 00:53:37 +02:00

50 lines
2.0 KiB
Racket

#lang scribble/manual
@require[scribble/example
@for-label[auto-syntax-e
racket/base
syntax/parse]]
@title{auto-syntax-e}
@author{georges}
@defmodule[auto-syntax-e]
This package allows using syntax pattern variables outside of syntax
templates: when @racket[_x] is bound as a syntax pattern variable, writing
@racket[_x] then becomes roughly equivalent to
@racket[(syntax->datum #'_x-ddd)], where @racket[_x-ddd] is @racket[x] wrapped
under the appropriate number of ellipses. If the pattern variable is bound by
@racket[syntax-parse] and contains non-syntax parts (e.g. it was bound within
an @racket[~optional] clause, or using @racket[#:attr]), they are left
unchanged.
@defform[(auto-with-syntax ([patᵢ eᵢ] ...) body ...)]{
Like @racket[(with-syntax ([patᵢ eᵢ] ...) body ...)], but the syntax pattern
variables bound by the @racket[patᵢ ...] can be used outside of syntax patterns
(they are implicitly transformed using @racket[syntax->datum]):
@examples[#:eval ((make-eval-factory '(auto-syntax-e)))
(auto-with-syntax ([x #'123])
(list (add1 x) #'x))]}
@defform[(auto-syntax (pvarᵢ ...) body ...)]{
Re-binds the syntax pattern variables @racket[pvarᵢ ...], so that can be used
outside of syntax patterns like in @racket[auto-with-syntax]:
@examples[#:eval ((make-eval-factory '(auto-syntax-e syntax/parse)))
(syntax-parse #'(1 2 3)
[(x:nat y:nat ...)
(auto-syntax (x y)
(list (map add1 (cons x y)) #'(x y ...)))])
(syntax-parse #'(1 2 3)
[({~seq x:nat {~optional y:nat}} ...)
(auto-syntax (x y)
(list (map cons x y)
(attribute x)
(attribute y)))])]
When one of the @racket[pvarᵢ ...] is not a syntax pattern variable, it is
ignored and the existing binding, if any, is left untouched.
Note that it is not necessary to specify the ellipsis-depth of each
@racket[pvarᵢ].}