adamc@448: fun add x =
adamc@448: let
adamc@448: fun add' y = x + y
adamc@448: in
adamc@448: add' 1 + add' 2
adamc@448: end
adamc@448:
adamc@448: fun f (x : int) =
adamc@448: let
adamc@448: fun page () = return
adamc@448: {[x]}
adamc@448:
adamc@448: in
adamc@448: page
adamc@448: end
adamc@448:
adamc@448: fun f (x : int) =
adamc@448: let
adamc@448: fun page1 () = return
adamc@448: {[x]}
adamc@448:
adamc@448:
adamc@448: and page2 () =
adamc@448: case Some True of
adamc@448: Some r => return {[r]}
adamc@448: | _ => return Error
adamc@448: in
adamc@450: page2
adamc@450: end
adamc@450:
adamc@450: fun f (x : int) =
adamc@450: let
adamc@450: fun page1 () = return
adamc@450: {[x]}
adamc@450:
adamc@450:
adamc@450: and page2 () =
adamc@450: case Some True of
adamc@450: Some r => return {[r]}
adamc@450: | _ => return !!
adamc@450:
adamc@450: and page3 () = return !!
adamc@450: !
adamc@450: in
adamc@450: page3
adamc@448: end
adamc@448:
adamc@448: datatype list t = Nil | Cons of t * list t
adamc@448:
adamc@448: fun length (t ::: Type) (ls : list t) =
adamc@448: let
adamc@448: fun length' ls acc =
adamc@448: case ls of
adamc@448: Nil => acc
adamc@448: | Cons (_, ls') => length' ls' (acc + 1)
adamc@448: in
adamc@448: length' ls 0
adamc@448: end
adamc@450: