File: Test032.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 (52 lines) | stat: -rw-r--r-- 1,404 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
44
45
46
47
48
49
50
51
52
(* Simon Finn pointed out that there might be a bug in this area and there was.
   We can't use the optimised representation for top-level datatypes because
   they may get incorporated into structures.  This didn't apply in ML90 because
   there wasn't any way to get a top-level datatype into a structure. *)

datatype t = X | Y of int * int;

functor F(S: sig type s datatype t = X | Y of s val def: s end) =
struct
open S
fun f (Y d) = d
|   f X = def
end;

structure S = F(struct type s = int * int datatype t = datatype t val def = (0,0) end);

if S.f(Y(1,1)) = (1,1)
then ()
else raise Fail "FAIL";

local
    datatype t = X | Y of int * int;
in
    structure S1 = F(struct type s = int * int datatype t = datatype t val def = (0,0) end);
    val isOk = 
        if S1.f(Y(1,1)) = (1,1) then "OK" else "FAIL";
end;

structure Q =
let
    datatype t = X | Y of int * int;
    structure S1 = F(struct type s = int * int datatype t = datatype t val def = (0,0) end);
in
    struct
        val isOk = S1.f(Y(1,1)) = (1,1);
    end
end;
if Q.isOk then () else raise Fail "wrong";

structure Q =
struct
    structure T =
    let
        datatype t = X | Y of int * int;
        structure S1 = F(struct type s = int * int datatype t = datatype t val def = (0,0) end);
    in
        struct
            val isOk = S1.f(Y(1,1)) = (1,1)
        end
    end
end;
if Q.T.isOk then () else raise Fail "wrong";