package coq
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=b1501d686c21836302191ae30f610cca57fb309214c126518ca009363ad2cd3c
doc/coq-core.kernel/Univ/LMap/index.html
Module Univ.LMap
Source
Polymorphic maps from universe levels to 'a
include CMap.ExtS with type key = Level.t and module Set := LSet
The underlying Map library
Apply the given function to the binding of the given key.
bind f s
transform the set x1; ...; xn
into x1 := f x1; ...; xn := f xn
.
Alias for fold
, to easily track where we depend on fold order.
val height : 'a t -> int
An indication of the logarithmic size of a map
find_range in_range m
Given a comparison function in_range x
, that tests if x
is below, above, or inside a given range filter_range
returns the submap of m
whose keys are in range. Note that in_range
has to define a continouous range.
update x f m
returns a map containing the same bindings as m
, except for the binding of x
. Depending on the value of y
where y
is f (find_opt x m)
, the binding of x
is added, removed or updated. If y
is None
, the binding is removed if it exists; otherwise, if y
is Some z
then x
is associated to z
in the resulting map. If x
was already bound in m
to a value that is physically equal to z
, m
is returned unchanged (the result of the function is then physically equal to m
).
module Smart : sig ... end
module Unsafe : sig ... end
module Monad (M : CMap.MonadS) : sig ... end
Fold operators parameterized by any monad.
diff x y
removes bindings from x that appear in y (whatever the value).
subst_union x y
favors the bindings of the first map that are Some
, otherwise takes y's bindings.