From 6bac888419048aa8fe06b49bf94f64893228bb00 Mon Sep 17 00:00:00 2001 From: gareuselesinge Date: Thu, 8 Aug 2013 18:50:39 +0000 Subject: Searchable stack data structure It is like Stack but one can search without popping git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@16670 85f007b7-540e-0410-9357-904b9bb8a0f7 --- lib/searchstack.ml | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) create mode 100644 lib/searchstack.ml (limited to 'lib/searchstack.ml') diff --git a/lib/searchstack.ml b/lib/searchstack.ml new file mode 100644 index 0000000000..8d160e5723 --- /dev/null +++ b/lib/searchstack.ml @@ -0,0 +1,25 @@ +(************************************************************************) +(* v * The Coq Proof Assistant / The Coq Development Team *) +(* raise Stack.Empty | x::xs -> l := xs; x +let top l = match !l with [] -> raise Stack.Empty | x::_ -> x +let find f i l = + let rec aux i = function + | [] -> raise Not_found + | x::xs -> match f i x with `Stop x -> x | `Cont i -> aux i xs in + aux i !l +let is_empty l = match !l with [] -> true | _ -> false +let iter f l = List.iter f !l +let clear l = l := [] +let length l = List.length !l +let to_list l = !l -- cgit v1.2.3