File: Test088.ML

package info (click to toggle)
polyml 5.6-8
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 31,892 kB
  • ctags: 34,453
  • sloc: cpp: 44,983; ansic: 24,520; asm: 14,850; sh: 11,730; makefile: 551; exp: 484; python: 253; awk: 91; sed: 9
file content (43 lines) | stat: -rw-r--r-- 1,089 bytes parent folder | download | duplicates (5)
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
(* Some more cases of polymorphism conversion. *)

(* This changes the polymorphism at some level. *)
structure S: sig type 'a t val x: 'a t val f : 'a t -> int val g: int -> 'a t end =
struct
    type 'a t = int
    val x: 'a t = 1
    fun f (n: int): 'a t = n (* int -> 'a t*)
    fun g (x :'a t): int = x (* 'a t -> int *)
end;

if S.x = 1 then () else raise Fail "Error";

if S.f S.x = 1 then () else raise Fail "Error";


(* Slightly different version that completely hides the relationship with int. *)
structure S:> sig type 'a t val x: 'a t val f : 'a t -> int val g: int -> 'a t end =
struct
    type 'a t = int
    val x: 'a t = 1
    fun f (n: int): 'a t = n (* int -> 'a t*)
    fun g (x :'a t): int = x (* 'a t -> int *)
end;

val x = S.x;
if S.f x = 1 then () else raise Fail "Error";

if S.f S.x = 1 then () else raise Fail "Error";


(* The signature adds polymorphism to a monomorphic function. *)
structure Dispatch:
sig
    type 'a union
    val Char   : word   -> 'a union;
end  =
struct
   type 'a union = word
         
   fun Char   (x:word)   : 'a union = x;

end;