package containers-data

  1. Overview
  2. Docs

Module CCTrie.MakeSource

Parameters

module W : WORD

Signature

Sourcetype char_ = W.char_
Sourcetype key = W.t
Sourcetype 'a t
Sourceval empty : 'a t
Sourceval is_empty : _ t -> bool
Sourceval add : key -> 'a -> 'a t -> 'a t

Add a binding to the trie (possibly erasing the previous one).

Sourceval remove : key -> 'a t -> 'a t

Remove the key, if present.

Sourceval find : key -> 'a t -> 'a option

Find the value associated with the key, if any.

Sourceval find_exn : key -> 'a t -> 'a

Same as find but can fail.

Sourceval longest_prefix : key -> 'a t -> key

longest_prefix k m finds the longest prefix of k that leads to at least one path in m (it does not mean that the prefix is bound to a value.

Example: if m has keys "abc0" and "abcd", then longest_prefix "abc2" m will return "abc".

  • since 0.17
Sourceval update : key -> ('a option -> 'a option) -> 'a t -> 'a t

Update the binding for the given key. The function is given None if the key is absent, or Some v if key is bound to v; if it returns None the key is removed, otherwise it returns Some y and key becomes bound to y.

Sourceval fold : ('b -> key -> 'a -> 'b) -> 'b -> 'a t -> 'b

Fold on key/value bindings. Will use WORD.of_list to rebuild keys.

Sourceval mapi : (key -> 'a -> 'b) -> 'a t -> 'b t

Map values, giving both key and value. Will use WORD.of_list to rebuild keys.

  • since 0.17
Sourceval map : ('a -> 'b) -> 'a t -> 'b t

Map values, giving only the value.

  • since 0.17
Sourceval iter : (key -> 'a -> unit) -> 'a t -> unit

Same as fold, but for effectful functions.

Sourceval fold_values : ('b -> 'a -> 'b) -> 'b -> 'a t -> 'b

More efficient version of fold, that doesn't keep keys.

Sourceval iter_values : ('a -> unit) -> 'a t -> unit
Sourceval merge : ('a -> 'a -> 'a option) -> 'a t -> 'a t -> 'a t

Merge two tries together. The function is used in case of conflicts, when a key belongs to both tries.

Sourceval size : _ t -> int

Number of bindings.

Conversions
Sourceval to_list : 'a t -> (key * 'a) list
Sourceval of_list : (key * 'a) list -> 'a t
Sourceval to_iter : 'a t -> (key * 'a) iter
Sourceval of_iter : (key * 'a) iter -> 'a t
Sourceval to_iter_values : 'a t -> 'a iter
Sourceval to_tree : 'a t -> [ `Char of char_ | `Val of 'a | `Switch ] ktree
Ranges
Sourceval above : key -> 'a t -> (key * 'a) iter

All bindings whose key is bigger or equal to the given key, in ascending order.

Sourceval below : key -> 'a t -> (key * 'a) iter

All bindings whose key is smaller or equal to the given key, in decreasing order.