Added a few abstractions to core

* Added abstraction for manipulating Γ and Σ to core
This commit is contained in:
William J. Bowman 2015-10-02 17:41:48 -04:00
parent 04405758ff
commit c892519a93
No known key found for this signature in database
GPG Key ID: DDD48D26958F0D1A
2 changed files with 18 additions and 12 deletions

View File

@ -42,7 +42,7 @@
(i ::= natural)
(U ::= (Unv i))
(x ::= variable-not-otherwise-mentioned)
(t e ::= (Π (x : t) t) (λ (x : t) t) (elim t t) x U (t t))
(t e ::= (Π (x : t) t) (λ (x : t) t) (elim x U) x U (t t))
;; Σ (signature). (inductive-name : type ((constructor : type) ...))
;; NB: Σ is a map from a name x to a pair of it's type and a map of constructor names to their types
(Σ ::= (Σ (x : t ((x : t) ...)))))
@ -222,6 +222,10 @@
[(Σ-ref-type (Σ (x_0 : t_0 ((x_1 : t_1) ... (x : t) (x_2 : t_2) ...))) x) t]
[(Σ-ref-type (Σ (x_0 : t_0 any)) x) (Σ-ref-type Σ x)])
(define-metafunction ttL
Σ-set : Σ x t ((x : t) ...) -> Σ
[(Σ-set Σ x t any) (Σ (x : t any))])
(define-metafunction ttL
Σ-union : Σ Σ -> Σ
[(Σ-union Σ ) Σ]
@ -737,6 +741,10 @@
[(Γ-union Γ_2 (Γ_1 x : t))
((Γ-union Γ_2 Γ_1) x : t)])
(define-metafunction tt-typingL
Γ-set : Γ x t -> Γ
[(Γ-set Γ x t) (Γ x : t)])
;; NB: Depends on clause order
(define-metafunction tt-typingL
Γ-ref : Γ x -> t or #f

View File

@ -88,7 +88,7 @@
;; These should be provided by core, so details of envs can be hidden.
(define (extend-Γ/term env x t)
(term (,(env) ,x : ,t)))
(term (Γ-set ,(env) ,x ,t)))
(define (extend-Γ/term! env x t) (env (extend-Γ/term env x t)))
@ -98,7 +98,7 @@
(define (extend-Γ/syn! env x t) (env (extend-Γ/syn env x t)))
(define (extend-Σ/term env x t c*)
(term (,(env) (,x : ,t (,@c*)))))
(term (Σ-set ,(env) ,x ,t (,@c*))))
(define (extend-Σ/term! env x t c*)
(env (extend-Σ/term env x t c*)))
@ -121,8 +121,6 @@
[exprs (second (bind-subst))])
(bind-subst (list (cons x vars) (cons t exprs)))))
;; TODO: Still absurdly slow. Probably doing n^2 checks of sigma and
;; gamma. And lookup on sigma, gamma are linear, so probably n^2 lookup time.
(define (type-infer/term t)
(let ([t (judgment-holds (type-infer ,(sigma) ,(gamma) ,t t_0) t_0)])
(and (pair? t) (car t))))
@ -144,15 +142,15 @@
;; Only type-check at the top-level, to prevent exponential
;; type-checking. Redex is expensive enough.
;; TODO: This results in less good error messages. Add an
;; algorithm to find the smallest ill-typed term.
(define inner-expand? (make-parameter #f))
;; Reifiy cur syntax into curnel datum
(define (cur->datum syn)
;; Main loop; avoid type
(define reified-term
(parameterize ([inner-expand? #t])
;; TODO: This results in less good error messages. Add an
;; algorithm to find the smallest ill-typed term.
(parameterize ([inner-expand? #f])
(let cur->datum ([syn syn])
(syntax-parse (core-expand syn)
#:literals (term reduce #%app subst-all)
@ -177,7 +175,7 @@
(term (elim ,t1 ,t2)))]
[(#%app e1 e2)
(term (,(cur->datum #'e1) ,(cur->datum #'e2)))]))))
(unless (and inner-expand? (type-infer/term reified-term))
(unless (or inner-expand? (type-infer/term reified-term))
;; TODO: is this really a syntax error?
(raise-syntax-error 'cur "term is ill-typed:"
(begin (printf "Sigma: ~s~nGamma: ~s~n" (sigma) (gamma))
@ -380,8 +378,7 @@
(syntax-case syn ()
[(_ e ...) (filter-cur-imports #'(e ...))]))))
;; TODO: rename in will need to rename variables in gamma and
;; sigma.
;; TODO: rename in will need to rename variables in gamma and sigma.
(define-syntax (import-envs syn)
(syntax-case syn ()
[(_) #`(begin-for-syntax #,@out-gammas #,@out-sigmas
@ -436,7 +433,6 @@
(define-syntax (dep-inductive syn)
(syntax-case syn (:)
[(_ i : ti (x1 : t1) ...)
;; TODO: Probably should occur only in definition context? and also, should not really produce void
(begin
(extend-Σ/syn! sigma #'i #'ti #'((x1 : t1) ...))
#'(void))]))
@ -484,6 +480,8 @@
[(_ id:id e)
(let ([e (cur->datum #'e)]
[id (syntax->datum #'id)])
;; NB: Have to roll our own namespace rather than use built-in define so id is resolved at
;; compile time in redex, and at runtime in racket.
(extend-Γ/term! gamma id (type-infer/term e))
(add-binding/term! id e)
#'(void))]))