This commit is contained in:
Jay McCarthy 2014-12-11 09:57:27 -05:00
parent 576bf6ea57
commit c8064354c7
3 changed files with 111 additions and 0 deletions

View File

@ -133,3 +133,5 @@ array.[{1 + 1}].(foo)
[for define things too]
- zos don't appear to users (switch to interp if no write access)
- (define+ (f case) body)

25
remix/exp/cond.rkt Normal file
View File

@ -0,0 +1,25 @@
#lang racket/base
(require (for-syntax racket/base
syntax/parse))
(define-syntax (brackets-cond stx)
(syntax-parse stx
[(_)
(syntax/loc stx
(error 'cond "Reach the end of cond"))]
[(_ ((~literal #%brackets) q . a) . more)
(syntax/loc stx
(if q (let () . a) (brackets-cond . more)))]
[(_ e . more)
(syntax/loc stx
(let () e (brackets-cond . more)))]))
(module+ test
(brackets-cond
(define x 5)
(#%brackets (even? x)
27)
(define y (+ x 6))
(#%brackets (odd? y)
28)
19))

84
remix/exp/template.rkt Normal file
View File

@ -0,0 +1,84 @@
#lang racket/base
(require (for-syntax racket/base
syntax/parse)
racket/stxparam)
(begin-for-syntax
(define-syntax-class template-ell
#:attributes ([x 1])
(pattern ()
#:attr [x 1] null)
(pattern (a:template-ell . d:template-ell)
#:attr [x 1]
(append (attribute a.x) (attribute d.x)))
(pattern ((~literal unquote) [depth:number one:id])
#:attr [x 1]
(if (< (syntax-parameter-value #'template-depth)
(syntax->datum #'depth))
(list #'one)
null))
(pattern _:id
#:attr [x 1] null)))
(define-syntax-parameter template-depth 0)
(define-syntax (template-list stx)
(syntax-parse stx
[(_)
(syntax/loc stx
null)]
[(~and (_ _ (~literal ...) ~! . _)
(_ a:template-ell (~literal ...) . more))
(syntax/loc stx
(append
(for/list ([a.x (in-list a.x)]
...)
(syntax-parameterize
([template-depth (add1 (syntax-parameter-value #'template-depth))])
(template a)))
(template-list . more)))]
[(_ ((~literal unquote-splicing) a) . more)
(syntax/loc stx
(append (template a) (template-list . more)))]
[(_ a . more)
(syntax/loc stx
(cons (template a) (template-list . more)))]))
(define-syntax (template stx)
(syntax-parse stx
;; xxx check depth of this to be equal to template-depth?
[(_ ((~literal unquote) [_ a]))
#'a]
[(_ ((~literal unquote-splicing) . _))
(raise-syntax-error 'template "unquote-splicing not allowed in template" stx)]
[(_ (~and a ((~literal quote) _)))
#'a]
[(_ (op more ...))
(syntax/loc stx
(apply op (template-list more ...)))]
[(_ a)
#'a]))
(module+ test
(require rackunit)
(define a 10)
(define x (list 1 2 3 4))
(define y (list 5 6 7 8))
(check-equal?
(template (+ (* ,[0 a] ,[1 x] ,[1 y]) ...))
(+ (* 10 1 5)
(* 10 2 6)
(* 10 3 7)
(* 10 4 8)))
(check-equal?
(template (list '+ (list '* ,[0 a] ,[1 x] ,[1 y]) ...))
'(+
(* 10 1 5)
(* 10 2 6)
(* 10 3 7)
(* 10 4 8)))
(check-equal?
(template (+ ,[0 a] ,@(map add1 ,[0 x]) ,@,[0 y]))
(+ 10
2 3 4 5
5 6 7 8)))