Belt_HashSet
A mutable Hash set which allows customized hash
behavior.
All data are parameterized by not its only type but also a unique identity in the time of initialization, so that two HashSets of ints initialized with different hash functions will have different type.
For example:
RESmodule I0 = unpack(
Belt.Id.hashableU(
~hash=(. a: int) => land(a, 65535),
~eq=(. a, b) => a == b,
)
)
let s0 = Belt.HashSet.make(~id=module(I0), ~hintSize=40)
module I1 = unpack(
Belt.Id.hashableU(
~hash=(. a: int) => land(a, 255),
~eq=(. a, b) => a == b,
)
)
let s1 = Belt.HashSet.make(~id=module(I1), ~hintSize=40)
Belt.HashSet.add(s1, 0)
Belt.HashSet.add(s1, 1)
The invariant must be held: for two elements who are equal, their hashed value should be the same.
Here the compiler would infer s0
and s1
having different type so that it
would not mix.
let s0: Belt.HashSet.t<int, I0.identity>
let s1: Belt.HashSet.t<int, I1.identity>
We can add elements to the collection (see last two lines in the example
above). Since this is an mutable data structure, s1
will contain two pairs.
undefined
Specalized when key type is int
, more efficient
than the generic type
module Int = Belt_HashSetInt
undefined
Specalized when key type is string
, more efficient
than the generic type
module String = Belt_HashSetString
t
type t<'a, 'id>
id
The type of hash tables from type 'a
to type 'b
.
type id<'a, 'id> = Belt_Id.hashable<'a, 'id>
make
let make: (~hintSize: int, ~id: id<'a, 'id>) => t<'a, 'id>
clear
let clear: t<'a, 'id> => unit
isEmpty
let isEmpty: t<'a, 'b> => bool
add
let add: (t<'a, 'id>, 'a) => unit
copy
let copy: t<'a, 'id> => t<'a, 'id>
has
let has: (t<'a, 'id>, 'a) => bool
remove
let remove: (t<'a, 'id>, 'a) => unit
forEachU
let forEachU: (t<'a, 'id>, (. 'a) => unit) => unit
forEach
Order unspecified.
let forEach: (t<'a, 'id>, 'a => unit) => unit
reduceU
let reduceU: (t<'a, 'id>, 'c, (. 'c, 'a) => 'c) => 'c
reduce
Order unspecified.
let reduce: (t<'a, 'id>, 'c, ('c, 'a) => 'c) => 'c
size
let size: t<'a, 'id> => int
logStats
let logStats: t<'a, 'b> => unit
toArray
let toArray: t<'a, 'id> => array<'a>
fromArray
let fromArray: (array<'a>, ~id: id<'a, 'id>) => t<'a, 'id>
mergeMany
let mergeMany: (t<'a, 'id>, array<'a>) => unit
getBucketHistogram
let getBucketHistogram: t<'a, 'b> => array<int>