summaryrefslogtreecommitdiff
path: root/tests/type_class.ur
blob: a41ccdc8764f3b7b0831891cdd755a72a9450b9a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
datatype pair a b = Pair of a * b

structure M : sig
    class default
    val get : t ::: Type -> default t -> t

    val string_default : default string
    val int_default : default int

    val option_default : t ::: Type -> default t -> default (option t)
    val pair_default : a ::: Type -> b ::: Type -> default a -> default b -> default (pair a b)

    class awesome
    val awesome_default : t ::: Type -> awesome t -> default t

    val float_awesome : awesome float
end = struct
    class default t = t
    fun get (t ::: Type) (x : t) = x

    val string_default = "Hi"
    val int_default = 0

    fun option_default (t ::: Type) (x : t) = Some x
    fun pair_default (a ::: Type) (b ::: Type) (x : a) (y : b) = Pair (x, y)

    class awesome t = t
    fun awesome_default (t ::: Type) (x : t) = x

    val float_awesome = 1.23
end

open M

fun default (t ::: Type) (_ : default t) : t = get
val hi : string = default
val zero : int = default
val some_zero : option int = default
val hi_zero : pair string int = default
val ott : float = default

fun frob (t ::: Type) (_ : default t) : t = default
val hi_again : string = frob
val zero_again : int = frob

fun show_option (t ::: Type) (_ : show t) : show (option t) =
    mkShow (fn x =>
               case x of
                   None => "None"
                 | Some y => show y)

fun show_pair (a ::: Type) (b ::: Type) (_ : show a) (_ : show b) : show (pair a b) =
    mkShow (fn x =>
               case x of
                   Pair (y, z) => "(" ^ show y ^ "," ^ show z ^ ")")

fun main () : transaction page = return <xml><body>
  {[hi_again]}, {[zero_again]}, {[some_zero]}, {[hi_zero]}, {[ott]}
</body></xml>