Cleaned up tests. make clean && make works.

This commit is contained in:
Georges Dupéron 2015-11-12 12:47:43 +01:00
parent fbc2411603
commit efd556eb66
4 changed files with 68 additions and 61 deletions

View File

@ -2,8 +2,10 @@
(require "cond-abort.rkt")
(require "variant.lp2.rkt")
(require typed/rackunit)
(match-abort '(1 (a b) 3)
(check-equal?
(match-abort '(1 (a b) 3)
[(list x y z)
(let-abort ([new-x x]
[new-y (match-abort y
@ -11,11 +13,14 @@
[(list q r s) (list 'B q r s)])]
[new-z z])
(list new-x new-y new-z))])
'(1 (A a b) 3))
(λ ([x : (U (Vector Number) (Vector String String))])
(let ()
(λ ([x : (U (Vector Number) (Vector String String))])
(if (= (vector-length x) 1)
x
x ;; Occurrence typing didn't narrow the type of x to (Vector Number).
x))
(void))
#|
@ -48,8 +53,8 @@
(foldl
(check-equal?
(foldl
(λ (x acc)
(if (null? x)
acc;(reverse acc)
@ -58,6 +63,7 @@
(cons x acc))))
'()
'(a b c))
'(c b a))
(begin

View File

@ -4,7 +4,8 @@
#;(λ ([x : (U (Vector Number) (Vector String String))])
(ann (vector-ref x 0) (U Number String)))
(ann (λ ([x : (U (Vector Number) (Vector String String) Symbol)])
(let ()
(ann (λ ([x : (U (Vector Number) (Vector String String) Symbol)])
(if (vector? x)
x
#f))
@ -12,5 +13,6 @@
(U False (Vector Number) (Vector String String))))
(λ ([x : (U ( Number Number Number) ( Number Number))])
(λ ([x : (U ( Number Number Number) ( Number Number))])
(procedure-arity x))
(void))

View File

@ -1,19 +1,18 @@
#lang typed/racket
(require "low.rkt")
(provide (all-from-out "low.rkt"))
(require "eval-get-values.rkt")
(provide (all-from-out "low.rkt")
(all-from-out "eval-get-values.rkt"))
;; Types
(provide AnyImmutable)
;; Functions
(provide eval-get-values)
(provide (rename-out [ compose]))
;; Macros
(provide mapp comment)
(require "eval-get-values.rkt")
(define compose)
(require (for-syntax syntax/parse
racket/syntax))

View File

@ -84,7 +84,7 @@
(syntax->datum #'n))
#'n)
;; Just for testing:
#''error]))
#''test]))
(define-type C Boolean)
@ -116,18 +116,18 @@
(define-type TA A)
(define-type TAI (incomplete A))
(displayln (ann '(A . 1) TAI))
(ann '(A . 1) TAI)
(define-type TC C)
(define-type TCI (incomplete C))
(displayln (ann #t TC))
(displayln (ann '(C . #t) TCI))
(ann #t TC)
(ann '(C . #t) TCI)
(let ()
(define-type A Boolean)
(define-type TA A)
(define-type TAI (incomplete A))
(displayln (ann 'error TAI))
(ann 'test TAI)
(void))))
(require (prefix-in tr: typed/racket))