File: kitdangle.sml

package info (click to toggle)
mlton 20130715-3
  • links: PTS
  • area: main
  • in suites: stretch
  • size: 60,900 kB
  • ctags: 69,386
  • sloc: xml: 34,418; ansic: 17,399; lisp: 2,879; makefile: 1,605; sh: 1,254; pascal: 256; python: 143; asm: 97
file content (19 lines) | stat: -rw-r--r-- 403 bytes parent folder | download | duplicates (11)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
(*kitdangle.sml*)

infix - + :: =
(*fun op = (x: ''a, y: ''a): bool =           prim ("=", "=", (x, y)) *)

exception Hd
fun hd (x::l) = x
  | hd [] = raise Hd

fun mklist 0 = []
  | mklist n = n :: mklist(n-1)

fun cycle(p as (m,f)) = 
  if m=0 then p
  else cycle(m-1, let val x = [(m, mklist 2000)]
                  in fn () => #1(hd x) + f()
                  end)

val r = cycle(1000, fn() => 0);