(cons '#(syntax-object syntax-case ((top)) (hygiene guile))
(cons '#(syntax-object x ((top)) (hygiene guile))
(cons k
- (map (lambda (tmp-1 tmp)
- (list (cons '#(syntax-object dummy ((top)) (hygiene guile)) tmp)
+ (map (lambda (tmp-2 tmp-1 tmp)
+ (list (cons tmp tmp-1)
(list '#(syntax-object syntax ((top)) (hygiene guile))
- tmp-1)))
+ tmp-2)))
template
- pattern))))))
+ pattern
+ keyword))))))
tmp)
(let ((tmp ($sc-dispatch tmp-1 '(_ each-any any . #(each ((any . any) any))))))
(if (if tmp
(cons '#(syntax-object syntax-case ((top)) (hygiene guile))
(cons '#(syntax-object x ((top)) (hygiene guile))
(cons k
- (map (lambda (tmp-1 tmp)
- (list (cons '#(syntax-object dummy ((top)) (hygiene guile)) tmp)
+ (map (lambda (tmp-2 tmp-1 tmp)
+ (list (cons tmp tmp-1)
(list '#(syntax-object syntax ((top)) (hygiene guile))
- tmp-1)))
+ tmp-2)))
template
- pattern))))))
+ pattern
+ keyword))))))
tmp)
(syntax-violation
#f
name
(list '#(syntax-object syntax-rules ((top)) (hygiene guile))
'()
- (list (cons '#(syntax-object _ ((top)) (hygiene guile)) pattern)
- template))))
+ (list (cons name pattern) template))))
tmp)
(let ((tmp ($sc-dispatch tmp-1 '(_ (any . any) any any))))
(if (if tmp
(list '#(syntax-object syntax-rules ((top)) (hygiene guile))
'()
docstring
- (list (cons '#(syntax-object _ ((top)) (hygiene guile)) pattern)
- template))))
+ (list (cons name pattern) template))))
tmp)
(syntax-violation
#f
#((macro-type . syntax-rules)
(patterns pattern ...))
(syntax-case x (k ...)
- ((dummy . pattern) #'template)
+ ((keyword . pattern) #'template)
...)))
((_ (k ...) docstring ((keyword . pattern) template) ...)
(string? (syntax->datum #'docstring))
#((macro-type . syntax-rules)
(patterns pattern ...))
(syntax-case x (k ...)
- ((dummy . pattern) #'template)
+ ((keyword . pattern) #'template)
...))))))
(define-syntax define-syntax-rule
((_ (name . pattern) template)
#'(define-syntax name
(syntax-rules ()
- ((_ . pattern) template))))
+ ((name . pattern) template))))
((_ (name . pattern) docstring template)
(string? (syntax->datum #'docstring))
#'(define-syntax name
(syntax-rules ()
docstring
- ((_ . pattern) template)))))))
+ ((name . pattern) template)))))))
(define-syntax let*
(lambda (x)