Mercurial > urweb
view tests/termination.ur @ 1360:02fc16faecf3
[De]serialization of times in JavaScript; proper integer division in JavaScript; Basis.crypt; Top.mkRead'; more aggressive Mono-level inlining, for values of function-y types
author | Adam Chlipala <adam@chlipala.net> |
---|---|
date | Thu, 23 Dec 2010 17:46:40 -0500 |
parents | e0ed0d4dabc9 |
children |
line wrap: on
line source
datatype list a = Nil | Cons of a * list a fun isNil (t ::: Type) (ls : list t) : bool = case ls of Nil => True | Cons _ => False fun append (t ::: Type) (ls1 : list t) (ls2 : list t) : list t = case ls1 of Nil => ls2 | Cons (x, ls1') => Cons (x, append ls1' ls2) fun appendR (t ::: Type) (ls2 : list t) (ls1 : list t) : list t = case ls1 of Nil => ls2 | Cons (x, ls1') => Cons (x, appendR ls2 ls1') (*fun naughty (t ::: Type) (ls : list t) : list t = naughty ls*) fun append1 (t ::: Type) (ls1 : list t) (ls2 : list t) : list t = case ls1 of Nil => ls2 | Cons (x, ls1') => Cons (x, append2 ls2 ls1') and append2 (t ::: Type) (ls2 : list t) (ls1 : list t) : list t = case ls1 of Nil => ls2 | Cons (x, ls1') => Cons (x, append1 ls1' ls2)