X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fcomponents%2Fextlib%2FhExtlib.ml;h=8451eb6b86c69eb435adf561a7290497cc353ff3;hb=8bc5bc0e8375a85736f6a5df317d129d5efa8de4;hp=b2092c5b35be4b91db19529f1449f818f7555868;hpb=1b70a1f66be53f76e475383e86d63c2b5c1fbcaa;p=helm.git diff --git a/helm/software/components/extlib/hExtlib.ml b/helm/software/components/extlib/hExtlib.ml index b2092c5b3..8451eb6b8 100644 --- a/helm/software/components/extlib/hExtlib.ml +++ b/helm/software/components/extlib/hExtlib.ml @@ -217,6 +217,18 @@ let rec filter_map f = | None -> filter_map f tl | Some v -> v :: filter_map f tl) +let filter_map_acc f acc l = + let acc, res = + List.fold_left + (fun (acc, res) t -> + match f acc t with + | None -> acc, res + | Some (acc, x) -> acc, x::res) + (acc,[]) l + in + acc, List.rev res +;; + let list_rev_map_filter f l = let rec aux a = function | [] -> a