view tests/type_classMod2.ur @ 2195:18e6fb487880

Reduce: add reduction in some spots previously missed, associated with 'case' return types
author Adam Chlipala <adam@chlipala.net>
date Wed, 25 Nov 2015 18:48:17 -0500
parents 71bafe66dbe1
children
line wrap: on
line source
signature S = sig
        class c
        val default : t :: Type -> c t -> t

        val string_c : c string
        val int_c : c int
end

structure M : S = struct
        class c t = t
        val default = fn t :: Type => fn v : c t => v

        val int_c : c int = 0
        val string_c : c string = "Hi"
end

val hi = M.default [string] _
val zero = M.default [int] _