Map

GitHub   Edit on GitHub

A Map holds key-value pairs. Any value may be used as a key or value. Operations on a Map mutate the internal state, so it never needs to be re-assigned.

Added in 0.2.0 No other changes yet.
1
import Map from "map"

Types

Type declarations included in the Map module.

Map.Map

1
type Map<k, v>

Values

Functions for working with Maps.

Map.makeSized

Added in 0.2.0 No other changes yet.
1
makeSized : Number -> Map<a, b>

Creates a new empty map with an initial storage of the given size. As values are added or removed, the internal storage may grow or shrink. Generally, you won’t need to care about the storage size of your map and can use Map.make() instead.

Parameters:

param type description
size Number The initial storage size of the map

Returns:

type description
Map<a, b> An empty map with the given initial storage size

Map.make

Added in 0.2.0 No other changes yet.
1
make : () -> Map<a, b>

Creates a new, empty map.

Returns:

type description
Map<a, b> An empty map

Map.set

Added in 0.2.0 No other changes yet.
1
set : (a, b, Map<a, b>) -> Void

Adds a new key-value pair to the map. If the key already exists in the map, the value is replaced.

Parameters:

param type description
key a The unique key in the map
value b The value to store
map Map<a, b> The map to modify

Map.get

Added in 0.2.0 No other changes yet.
1
get : (a, Map<a, b>) -> Option<b>

Retrieves the value for the given key.

Parameters:

param type description
key a The key to access
map Map<a, b> The map to access

Returns:

type description
Option<b> Some(value) if the key exists in the map or None otherwise

Map.contains

Added in 0.2.0 No other changes yet.
1
contains : (a, Map<a, b>) -> Bool

Determines if the map contains the given key. In such a case, it will always contain a value for the given key.

Parameters:

param type description
key a The key to search for
map Map<a, b> The map to search

Returns:

type description
Bool true if the map contains the given key or false otherwise

Map.remove

Added in 0.2.0 No other changes yet.
1
remove : (a, Map<a, b>) -> Void

Removes the given key from the map, which also removes the value. If the key pair doesn’t exist, nothing happens.

Parameters:

param type description
key a The key to remove
map Map<a, b> The map to update

Map.update

Added in 0.3.0 No other changes yet.
1
update : (a, (Option<b> -> Option<b>), Map<a, b>) -> Void

Updates a value in the map by calling an updater function that receives the previously stored value as an Option and returns the new value to be stored as an Option. If the key didn’t exist previously, the value will be None. If None is returned from the updater function, the key-value pair is removed.

Parameters:

param type description
key a The unique key in the map
fn Option<b> -> Option<b> The updater function
map Map<a, b> The map to modify

Map.size

Added in 0.2.0 No other changes yet.
1
size : Map<a, b> -> Number

Provides the count of key-value pairs stored within the map.

Parameters:

param type description
map Map<a, b> The map to inspect

Returns:

type description
Number The count of key-value pairs in the map

Map.isEmpty

Added in 0.2.0 No other changes yet.
1
isEmpty : Map<a, b> -> Bool

Determines if the map contains no key-value pairs.

Parameters:

param type description
map Map<a, b> The map to inspect

Returns:

type description
Bool true if the given map is empty or false otherwise

Map.clear

Added in 0.2.0 No other changes yet.
1
clear : Map<a, b> -> Void

Resets the map by removing all key-value pairs.

Parameters:

param type description
map Map<a, b> The map to reset

Map.forEach

Added in 0.2.0
versionchanges
0.5.0Ensured the iterator function return type is always `Void`
1
forEach : (((a, b) -> Void), Map<a, b>) -> Void

Iterates the map, calling an iterator function with each key and value.

Parameters:

param type description
fn (a, b) -> Void The iterator function to call with each key and value
map Map<a, b> The map to iterate

Map.reduce

Added in 0.2.0 No other changes yet.
1
reduce : (((a, b, c) -> a), a, Map<b, c>) -> a

Combines all key-value pairs of a map using a reducer function.

Parameters:

param type description
fn (a, b, c) -> a The reducer function to call on each key and value, where the value returned will be the next accumulator value
init a The initial value to use for the accumulator on the first iteration
map Map<b, c> The map to iterate

Returns:

type description
a The final accumulator returned from fn

Map.keys

Added in 0.2.0 No other changes yet.
1
keys : Map<a, b> -> List<a>

Enumerates all keys in the given map.

Parameters:

param type description
map Map<a, b> The map to enumerate

Returns:

type description
List<a> A list containing all keys from the given map

Map.values

Added in 0.2.0 No other changes yet.
1
values : Map<a, b> -> List<b>

Enumerates all values in the given map.

Parameters:

param type description
map Map<a, b> The map to enumerate

Returns:

type description
List<b> A list containing all values from the given map

Map.toList

Added in 0.2.0 No other changes yet.
1
toList : Map<a, b> -> List<(a, b)>

Enumerates all key-value pairs in the given map.

Parameters:

param type description
map Map<a, b> The map to enumerate

Returns:

type description
List<(a, b)> A list containing all key-value pairs from the given map

Map.fromList

Added in 0.2.0 No other changes yet.
1
fromList : List<(a, b)> -> Map<a, b>

Creates a map from a list.

Parameters:

param type description
list List<(a, b)> The list to convert

Returns:

type description
Map<a, b> A map containing all key-value pairs from the list

Map.toArray

Added in 0.2.0 No other changes yet.
1
toArray : Map<a, b> -> Array<(a, b)>

Converts a map into an array of its key-value pairs.

Parameters:

param type description
map Map<a, b> The map to convert

Returns:

type description
Array<(a, b)> An array containing all key-value pairs from the given map

Map.fromArray

Added in 0.2.0 No other changes yet.
1
fromArray : Array<(a, b)> -> Map<a, b>

Creates a map from an array.

Parameters:

param type description
array Array<(a, b)> The array to convert

Returns:

type description
Map<a, b> A map containing all key-value pairs from the array

Map.filter

Added in 0.2.0 No other changes yet.
1
filter : (((a, b) -> Bool), Map<a, b>) -> Void

Removes key-value pairs from a map where a predicate function returns false.

Parameters:

param type description
fn (a, b) -> Bool The predicate function to indicate which key-value pairs to remove from the map, where returning false indicates the key-value pair should be removed
map Map<a, b> The map to iterate

Map.reject

Added in 0.2.0 No other changes yet.
1
reject : (((a, b) -> Bool), Map<a, b>) -> Void

Removes key-value pairs from a map where a predicate function returns true.

Parameters:

param type description
fn (a, b) -> Bool The predicate function to indicate which key-value pairs to remove from the map, where returning true indicates the key-value pair should be removed
map Map<a, b> The map to iterate

Map.getInternalStats

Added in 0.2.0 No other changes yet.
1
getInternalStats : Map<a, b> -> (Number, Number)

Provides data representing the internal state state of the map.

Parameters:

param type description
map Map<a, b> The map to inspect

Returns:

type description
(Number, Number) The internal state of the map
This is a notification!