diff options
| author | Pierre-Marie Pédrot | 2014-01-29 20:29:35 +0100 |
|---|---|---|
| committer | Pierre-Marie Pédrot | 2014-01-29 20:29:35 +0100 |
| commit | 5a430f21ecbba4cce096efac44a69589d1d7382b (patch) | |
| tree | 3668309c21bdbcfc98e1f5ac09ae4833d8b87162 /lib | |
| parent | a438546db97261451882286f82114191247ad275 (diff) | |
Adding a smartmap[i] operator to maps.
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/cMap.ml | 22 | ||||
| -rw-r--r-- | lib/cMap.mli | 6 |
2 files changed, 28 insertions, 0 deletions
diff --git a/lib/cMap.ml b/lib/cMap.ml index 6bf3b2f068..42a4111b1a 100644 --- a/lib/cMap.ml +++ b/lib/cMap.ml @@ -24,6 +24,8 @@ sig val bind : (key -> 'a) -> Set.t -> 'a t val fold_left : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b val fold_right : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b + val smartmap : ('a -> 'a) -> 'a t -> 'a t + val smartmapi : (key -> 'a -> 'a) -> 'a t -> 'a t module Unsafe : sig val map : (key -> 'a -> key * 'b) -> 'a t -> 'b t @@ -39,6 +41,8 @@ sig val bind : (M.t -> 'a) -> Set.Make(M).t -> 'a map val fold_left : (M.t -> 'a -> 'b -> 'b) -> 'a map -> 'b -> 'b val fold_right : (M.t -> 'a -> 'b -> 'b) -> 'a map -> 'b -> 'b + val smartmap : ('a -> 'a) -> 'a map -> 'a map + val smartmapi : (M.t -> 'a -> 'a) -> 'a map -> 'a map module Unsafe : sig val map : (M.t -> 'a -> M.t * 'b) -> 'a map -> 'b map @@ -115,6 +119,24 @@ struct let accu = f k v (fold_right f r accu) in fold_right f l accu + let rec smartmap f (s : 'a map) = match map_prj s with + | MEmpty -> map_inj MEmpty + | MNode (l, k, v, r, h) -> + let l' = smartmap f l in + let r' = smartmap f r in + let v' = f v in + if l == l' && r == r' && v == v' then s + else map_inj (MNode (l', k, v', r', h)) + + let rec smartmapi f (s : 'a map) = match map_prj s with + | MEmpty -> map_inj MEmpty + | MNode (l, k, v, r, h) -> + let l' = smartmapi f l in + let r' = smartmapi f r in + let v' = f k v in + if l == l' && r == r' && v == v' then s + else map_inj (MNode (l', k, v', r', h)) + module Unsafe = struct diff --git a/lib/cMap.mli b/lib/cMap.mli index 7091e844e3..9fe3355515 100644 --- a/lib/cMap.mli +++ b/lib/cMap.mli @@ -45,6 +45,12 @@ sig val fold_right : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b (** Folding keys in decreasing order. *) + val smartmap : ('a -> 'a) -> 'a t -> 'a t + (** As [map] but tries to preserve sharing. *) + + val smartmapi : (key -> 'a -> 'a) -> 'a t -> 'a t + (** As [mapi] but tries to preserve sharing. *) + module Unsafe : sig val map : (key -> 'a -> key * 'b) -> 'a t -> 'b t |
