File: Test087.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 (31 lines) | stat: -rw-r--r-- 403 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
(* Tests for handling of complex polymorphic declarations. *)

let
    fun f x = x
    val c = (f, f)
    val (a, b) = c
in
    a(b 1)
end; 

let
    val c = (nil, nil)
    
    fun f(a::_, b::_) = a+b | f _ = 0
in
    f c
end;


let
    val a = { x=NONE, y=NONE }
    fun f {x=SOME (x: int), y=SOME(y: int) } = x + y | f _ = 0
in
    f a
end;

let
    val SOME f = SOME (fn x => x)
in
    f (f 1)
end;