Fixed compatibility with Racket 6.7

This commit is contained in:
Georges Dupéron 2017-01-12 19:51:20 +01:00
parent 85e4f1412a
commit ee8e7dd7cc
2 changed files with 16 additions and 12 deletions

View File

@ -21,8 +21,9 @@
(Syntaxof Any)
(Syntaxof A)))]
;; Backported from 6.8 so that it works on 6.7
[[vector->list vectortop->list]
( VectorTop (Listof Any))])
[vector->list
( (A) (case→ ( (Vectorof A) (Listof A))
( VectorTop (Listof Any))))])
(define-syntax-rule (unsafe-cast v t)
((inst unsafe-cast-function t) v))
@ -94,8 +95,7 @@
[else
(values (cons car* cdr*) 'modified)]))]
[(vector? e) (match-let ([(cons vs* status)
(try-listof-any->isexp* (vectortop->list e)
non-sexp)])
(try-listof-any->isexp* (vector->list e) non-sexp)])
(case status
[(unmodified)
(if (immutable? e)

View File

@ -4,14 +4,6 @@
typed/racket/unsafe
"typed-prefab-declarations.rkt")
(unsafe-require/typed racket/base
[[datum->syntax datum->syntax*]
( (A) ( (Syntaxof Any)
A
(Syntaxof Any)
(Syntaxof Any)
(Syntaxof A)))])
(provide ISyntaxOf
ISyntaxOf-E
ISyntax
@ -27,6 +19,18 @@
isyntax?
isyntax-e?)
(unsafe-require/typed racket/base
[[datum->syntax datum->syntax*]
( (A) ( (Syntaxof Any)
A
(Syntaxof Any)
(Syntaxof Any)
(Syntaxof A)))]
;; Backported from 6.8 so that it works on 6.7
[vector->list
( (A) (case→ ( (Vectorof A) (Listof A))
( VectorTop (Listof Any))))])
(unsafe-require/typed racket/function
[[identity unsafe-cast-function] ( (A) ( Any A))])
(define-syntax-rule (unsafe-cast v t)