diff --git a/module/language/cps/types.scm b/module/language/cps/types.scm index 55cde2744..fc23e1691 100644 --- a/module/language/cps/types.scm +++ b/module/language/cps/types.scm @@ -117,6 +117,9 @@ ;; Union types. &number &real + ;; Untagged types. + &f64 + infer-types lookup-pre-type lookup-post-type @@ -164,7 +167,9 @@ &bytevector &bitvector &array - &hash-table) + &hash-table + + &f64) (define-syntax &no-type (identifier-syntax 0)) @@ -670,6 +675,24 @@ minimum, and maximum." ((logior &number &false) -inf.0 +inf.0)) + + +;;; +;;; Unboxed double-precision floating-point numbers. +;;; + +(define-type-checker (scm->f64 scm) + (check-type scm &real -inf.0 +inf.0)) +(define-type-inferrer (scm->f64 scm result) + (restrict! scm &real -inf.0 +inf.0) + (define! result &f64 (&min scm) (&max scm))) + +(define-type-checker (f64->scm f64) + #t) +(define-type-inferrer (f64->scm f64 result) + (define! result &flonum (&min f64) (&max f64))) + + ;;;