X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fcomponents%2Fextlib%2FhExtlib.mli;h=594a80027956644cb721f3007a97c34a678adfa1;hb=794fe0432b14ca29e5dfd2e217cef72e9b0ff61a;hp=815c2052665c6d6a4587612e6ceee38c6da88f0a;hpb=f8de6ff875398b99f8fa193a1160955b46bba57b;p=helm.git diff --git a/helm/software/components/extlib/hExtlib.mli b/helm/software/components/extlib/hExtlib.mli index 815c20526..594a80027 100644 --- a/helm/software/components/extlib/hExtlib.mli +++ b/helm/software/components/extlib/hExtlib.mli @@ -41,11 +41,18 @@ val safe_remove: string -> unit (** removes a file if it exists *) val safe_rmdir: string -> unit (** removes a dir if it exists and is empty *) val is_dir_empty: string -> bool (** checks if the dir is empty *) val rmdir_descend: string -> unit (** rmdir -p *) +val chmod: int -> string -> unit (** chmod *) +val normalize_path: string -> string (** /foo/./bar/..//baz -> /foo/baz *) (** find all _files_ whose name matches test under a filesystem root. * Test is passed the filename path relative to the given filesystem root *) val find: ?test:(string -> bool) -> string -> string list + (** find_in paths name returns the first path^"/"^name such that + * is a regular file and the current user can 'stat' it. + * May raise (Failure "find_in") *) +val find_in: string list -> string -> string + (** {2 File I/O} *) val input_file: string -> string (** read all the contents of file to string *) @@ -83,6 +90,17 @@ val list_concat: ?sep:'a list -> 'a list list -> 'a list (**String.concat-like*) val list_findopt: ('a -> 'b option) -> 'a list -> 'b option val flatten_map: ('a -> 'b list) -> 'a list -> 'b list val list_last: 'a list -> 'a +val list_mapi: ('a -> int -> 'b) -> 'a list -> 'b list +val sharing_map: ('a -> 'a) -> 'a list -> 'a list +(* Iters in parallel on two lists until the first list is empty. + The second one can be shorter and is padded with a default value. + This function cannot fail. *) +val list_iter_default2: ('a -> 'b -> unit) -> 'a list -> 'b -> 'b list -> unit +(* Checks a predicate in parallel on three lists, the first two having the same + length (otherwise it raises Invalid_argument). It stops when the first two + lists are empty. The third one can be shorter and is padded with a default value. *) +val list_forall_default3: ('a -> 'b -> 'c -> bool) -> 'a list -> 'b list -> 'c -> 'c list -> bool + (** split_nth n l * @returns two list, the first contains at least n elements, the second the @@ -90,6 +108,7 @@ val list_last: 'a list -> 'a * @raise Failure when List.length l < n *) val split_nth: int -> 'a list -> 'a list * 'a list +val mk_list: 'a -> int -> 'a list (** {2 Debugging & Profiling} *) type profiler = { profile : 'a 'b. ('a -> 'b) -> 'a -> 'b } @@ -101,15 +120,26 @@ val set_profiling_printings : (string -> bool) -> unit (** {2 Localized exceptions } *) -exception Localized of Token.flocation * exn +exception Localized of Stdpp.location * exn -val loc_of_floc: Token.flocation -> int * int -val floc_of_loc: int * int -> Token.flocation +val loc_of_floc: Stdpp.location -> int * int +val floc_of_loc: int * int -> Stdpp.location -val dummy_floc: Lexing.position * Lexing.position +val dummy_floc: Stdpp.location -val raise_localized_exception: offset:int -> Token.flocation -> exn -> 'a +val raise_localized_exception: offset:int -> Stdpp.location -> exn -> 'a (* size in KB (SLOW) *) val estimate_size: 'a -> int +(* is_prefix_of [prefix] [string], in terms of dirs: + * foo/bar/ is prefix of foo/bar/baz + * foo/bar is prefix of foo/bar/baz + * foo/b isn't of foo/bar/baz + * foo/bar is prefix of foo/bar + *) +val is_prefix_of: string -> string -> bool +val chop_prefix: string -> string -> string +val touch: string -> unit + +val profiling_enabled: bool ref