File: Test089.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 (21 lines) | stat: -rw-r--r-- 616 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
(* Test to construct polytype from type abbreviation by opaque matching. *)

structure S:> sig eqtype 'a t val mkT: 'a -> 'a t end =
struct type 'a t = 'a fun mkT x = x end;

PolyML.makestring(S.mkT 1); (* Check the pretty-printer. *)

if S.mkT 1 = S.mkT 1 then () else raise Fail "error";

if S.mkT 1 = S.mkT 2 then raise Fail "error" else ();

(* And from datatype.  *)
structure S:> sig eqtype 'a t val mkT: 'a -> 'a t end =
struct datatype 'a t = X of 'a val mkT = X end;

PolyML.makestring(S.mkT 1);

if S.mkT 1 = S.mkT 1 then () else raise Fail "error";

if S.mkT 1 = S.mkT 2 then raise Fail "error" else ();