(* * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. *) open! NS0 module type S = sig type key type compare_key type +'a t [@@deriving compare, equal, sexp_of] include Comparer.S1 with type 'a t := 'a t module Provide_of_sexp (_ : sig type t = key [@@deriving of_sexp] end) : sig type 'a t [@@deriving of_sexp] end with type 'a t := 'a t (** {1 Construct} *) val empty : 'a t val singleton : key -> 'a -> 'a t val add_exn : key:key -> data:'a -> 'a t -> 'a t val add : key:key -> data:'a -> 'a t -> 'a t val add_multi : key:key -> data:'a -> 'a list t -> 'a list t val remove : key -> 'a t -> 'a t val merge : 'a t -> 'b t -> f: ( key -> [`Left of 'a | `Both of 'a * 'b | `Right of 'b] -> 'c option) -> 'c t val merge_endo : 'a t -> 'b t -> f: ( key -> [`Left of 'a | `Both of 'a * 'b | `Right of 'b] -> 'a option) -> 'a t (** Like merge, but specialized to require [f] to preserve the type of the left argument, which enables preserving [==] if [f] preserves [==] of every value. *) val union : 'a t -> 'a t -> f:(key -> 'a -> 'a -> 'a option) -> 'a t val union_absent : 'a t -> 'a t -> 'a t (** [union_absent m1 m2] contains all the bindings of [m1] as well as those of [m2] for keys not contained by [m1]. [union_absent m1 m2 == m1] if no bindings from [m2] are added. *) val partition : 'a t -> f:(key -> 'a -> bool) -> 'a t * 'a t val partition_map : 'a t -> f:(key -> 'a -> ('b, 'c) Either.t) -> 'b t * 'c t (** {1 Query} *) val is_empty : 'a t -> bool val is_singleton : 'a t -> bool val length : 'a t -> int val only_binding : 'a t -> (key * 'a) option val classify : 'a t -> (key, 'a) zero_one_many2 val choose : 'a t -> (key * 'a) option (** Find an unspecified binding. Different bindings may be chosen for equivalent maps. [O(1)]. *) val choose_exn : 'a t -> key * 'a (** Find an unspecified binding. Different bindings may be chosen for equivalent maps. [O(1)]. *) val min_binding : 'a t -> (key * 'a) option val max_binding : 'a t -> (key * 'a) option val max_binding_exn : 'a t -> key * 'a val mem : key -> 'a t -> bool val find : key -> 'a t -> 'a option val find_exn : key -> 'a t -> 'a val find_multi : key -> 'a list t -> 'a list val find_update : key -> 'a t -> f:('a option -> 'a option) -> 'a option * 'a t (** [find_update k f m] is [(found, m')] where [found] is [find k m] and [find k m'] is [f found] and [find h m'] is [find h m] for all other [h]. *) val find_and_remove : key -> 'a t -> 'a option * 'a t (** Find and remove the binding for a key. *) val find_or_add : key -> 'a -> 'a t -> 'a option * 'a t (** Find the value bound to the given key if there is one, or otherwise add a binding for the given key and value. *) val pop_min_binding : 'a t -> (key * 'a * 'a t) option (** Find and remove binding with minimum key. [O(log n)]. *) (** {1 Transform} *) val update : key -> 'a t -> f:('a option -> 'a option) -> 'a t val map : 'a t -> f:('a -> 'b) -> 'b t val mapi : 'a t -> f:(key:key -> data:'a -> 'b) -> 'b t val map_endo : 'a t -> f:('a -> 'a) -> 'a t (** Like map, but specialized to require [f] to be an endofunction, which enables preserving [==] if [f] preserves [==] of every value. *) val filter_mapi : 'a t -> f:(key:key -> data:'a -> 'b option) -> 'b t (** {1 Traverse} *) val iter : 'a t -> f:('a -> unit) -> unit val iteri : 'a t -> f:(key:key -> data:'a -> unit) -> unit val existsi : 'a t -> f:(key:key -> data:'a -> bool) -> bool val for_alli : 'a t -> f:(key:key -> data:'a -> bool) -> bool val fold : 'a t -> 's -> f:(key:key -> data:'a -> 's -> 's) -> 's val fold_until : 'a t -> 's -> f:(key:key -> data:'a -> 's -> [`Continue of 's | `Stop of 'b]) -> finish:('s -> 'b) -> 'b (** {1 Convert} *) val keys : 'a t -> key iter val values : 'a t -> 'a iter val to_iter : 'a t -> (key * 'a) iter val to_list : 'a t -> (key * 'a) list val of_iter : (key * 'a) iter -> 'a t val of_list : (key * 'a) list -> 'a t val symmetric_diff : 'a t -> 'b t -> eq:('a -> 'b -> bool) -> (key * [> `Left of 'a | `Unequal of 'a * 'b | `Right of 'b]) iter (** {1 Pretty-print} *) val pp : key pp -> 'a pp -> 'a t pp val pp_diff : ?pre:(unit, unit) fmt -> ?suf:(unit, unit) fmt -> ?sep:(unit, unit) fmt -> key pp -> 'a pp -> ('a * 'a) pp -> eq:('a -> 'a -> bool) -> ('a t * 'a t) pp end