--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/TFL/utils.sig Fri Oct 18 12:41:04 1996 +0200
@@ -0,0 +1,55 @@
+signature Utils_sig =
+sig
+ (* General error format and reporting mechanism *)
+ exception ERR of {module:string,func:string, mesg:string}
+ val Raise : exn -> 'a
+
+ (* infix 3 ## *)
+ val ## : ('a -> 'b) * ('c -> 'd) -> 'a * 'c -> 'b * 'd
+ val can : ('a -> 'b) -> 'a -> bool
+ val holds : ('a -> bool) -> 'a -> bool
+ val assert: ('a -> bool) -> 'a -> 'a
+ val W : ('a -> 'a -> 'b) -> 'a -> 'b
+ val C : ('a -> 'b -> 'c) -> 'b -> 'a -> 'c
+ val I : 'a -> 'a
+ val curry : ('a * 'b -> 'c) -> 'a -> 'b -> 'c
+ val uncurry : ('a -> 'b -> 'c) -> 'a * 'b -> 'c
+ val fst : 'a * 'b -> 'a
+ val snd : 'a * 'b -> 'b
+
+ (* option type *)
+ datatype 'a option = SOME of 'a | NONE
+
+ (* Set operations *)
+ val mem : ('a -> 'a -> bool) -> 'a -> 'a list -> bool
+ val union : ('a -> 'a -> bool) -> 'a list -> 'a list -> 'a list
+ val Union : ('a -> 'a -> bool) -> 'a list list -> 'a list
+ val intersect : ('a -> 'a -> bool) -> 'a list -> 'a list -> 'a list
+ val set_diff : ('a -> 'b -> bool) -> 'a list -> 'b list -> 'a list
+ val mk_set : ('a -> 'a -> bool) -> 'a list -> 'a list
+ val set_eq : ('a -> 'a -> bool) -> 'a list -> 'a list -> bool
+
+ val map2 : ('a -> 'b -> 'c) -> 'a list -> 'b list -> 'c list
+ val itlist : ('a -> 'b -> 'b) -> 'a list -> 'b -> 'b
+ val rev_itlist : ('a -> 'b -> 'b) -> 'a list -> 'b -> 'b
+ val end_itlist : ('a -> 'a -> 'a) -> 'a list -> 'a
+ val itlist2 :('a -> 'b -> 'c -> 'c) -> 'a list -> 'b list -> 'c -> 'c
+ val filter : ('a -> bool) -> 'a list -> 'a list
+ val mapfilter : ('a -> 'b) -> 'a list -> 'b list
+ val pluck : ('a -> bool) -> 'a list -> 'a * 'a list
+ val assoc1 : ('a*'a->bool) -> 'a -> ('a * 'b) list -> ('a * 'b) option
+ val front_back : 'a list -> 'a list * 'a
+ val all : ('a -> bool) -> 'a list -> bool
+ val exists : ('a -> bool) -> 'a list -> bool
+ val zip : 'a list -> 'b list -> ('a*'b) list
+ val zip3 : 'a list -> 'b list -> 'c list -> ('a*'b*'c) list
+ val unzip : ('a*'b) list -> ('a list * 'b list)
+ val take : ('a -> 'b) -> int * 'a list -> 'b list
+ val sort : ('a -> 'a -> bool) -> 'a list -> 'a list
+
+ val int_to_string : int -> string
+ val concat : string -> string -> string
+ val quote : string -> string
+
+end;
+