phc-toolkit/light-no-check.rkt
2017-04-27 23:38:55 +02:00

46 lines
1.7 KiB
Racket

#lang racket/base
(provide (except-out (all-from-out racket/base)
define)
(rename-out [new-: :]
[new-define-type define-type]
[new-define define]
[new-require/typed require/typed]))
(require (for-syntax racket/base))
(begin-for-syntax
(define (process-arg stx)
(syntax-case stx (new-:)
[id/kw (or (identifier? #'id/kw) (keyword? (syntax-e #'id/kw))) #'id/kw]
[[_ _] stx] ;; [arg default]
[[arg new-: _] #'arg]
[[arg new-: _ default] #'[arg default]]))
(define (process-curried stx)
(syntax-case stx ()
[id (identifier? #'id) #'id]
[(recur arg ...)
(with-syntax ([recur.no-types (process-curried #'recur)]
[(arg.no-types ...)
(map process-arg (syntax->list #'(arg ...)))])
#'(recur.no-types arg.no-types ...))])))
(define-syntax (new-: stx) #'(begin))
(define-syntax (new-define-type stx) #'(begin))
(define-syntax (new-define stx)
(syntax-case stx (new-:)
[(_ #:∀ _ curried new-: _ e ...)
(with-syntax ([curried.no-types (process-curried #'curried)])
#'(define curried.no-types e ...))]
[(_ #:∀ _ curried e ...)
(with-syntax ([curried.no-types (process-curried #'curried)])
#'(define curried.no-types e ...))]
[(_ curried new-: _ e ...)
(with-syntax ([curried.no-types (process-curried #'curried)])
#'(define curried.no-types e ...))]
[(_ curried e ...)
(with-syntax ([curried.no-types (process-curried #'curried)])
#'(define curried.no-types e ...))]))
(define-syntax-rule (new-require/typed mod [id τ] ...)
(require (only-in mod id ...)))