X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fcomponents%2Fextlib%2FhExtlib.ml;h=361587b7d33402f4d3989ffde01d72538a88deb6;hb=6a16a37b5b4cbea5f5216247182d5bb99a0d8d65;hp=6af86f9cd4d4ac0b620d004976ea6a83fc951a6e;hpb=abc5b4352a4ad787ede7122e2239ee44132886dd;p=helm.git diff --git a/helm/software/components/extlib/hExtlib.ml b/helm/software/components/extlib/hExtlib.ml index 6af86f9cd..361587b7d 100644 --- a/helm/software/components/extlib/hExtlib.ml +++ b/helm/software/components/extlib/hExtlib.ml @@ -164,6 +164,23 @@ let rec list_forall_default3 f l1 l2 def l3 = | a::ta, b::tb, [] -> f a b def && list_forall_default3 f ta tb def [] ;; +exception FailureAt of int;; + +let list_forall_default3_var f l1 l2 def l3 = + let rec aux f l1 l2 def l3 i = + match l1,l2,l3 with + | [], [], _ -> true + | [], _, _ + | _, [], _ -> raise (Invalid_argument "list_forall_default3") + | a::ta, b::tb, c::tc -> + if f a b c then aux f ta tb def tc (i+1) + else raise (FailureAt i) + | a::ta, b::tb, [] -> + if f a b def then aux f ta tb def [] (i+1) + else raise (FailureAt i) + in aux f l1 l2 def l3 0 +;; + let sharing_map f l = let unchanged = ref true in let rec aux b = function @@ -522,6 +539,7 @@ let rec mk_list x = function ;; let list_seq start stop = + if start > stop then [] else let rec aux pos = if pos = stop then [] else pos :: (aux (pos+1))