Mnemonix v0.2.0 Mnemonix
Easy access to Mnemonix.Store servers with a Map-like interface.
Rather than a map, you can use the GenServer.server/0 reference returned
by Mnemonix.Store.start_link/2 to perform operations on Mnemonix stores.
The new/0, new/1, and new/3 functions start links to a
Mnemonix.Map.Store (mimicing to Map.new) to make it easy to play with the
Mnemonix interface:
iex> store = Mnemonix.new(fizz: 1)
iex> Mnemonix.get(store, :foo)
nil
iex> Mnemonix.get(store, :fizz)
1
iex> Mnemonix.put_new(store, :foo, "bar")
iex> Mnemonix.get(store, :foo)
"bar"
iex> Mnemonix.put_new(store, :foo, "baz")
iex> Mnemonix.get(store, :foo)
"bar"
iex> Mnemonix.put(store, :foo, "baz")
iex> Mnemonix.get(store, :foo)
"baz"
iex> Mnemonix.get(store, :fizz)
1
iex> Mnemonix.get_and_update(store, :fizz, &({&1, &1 * 2}))
iex> Mnemonix.get_and_update(store, :fizz, &({&1, &1 * 2}))
iex> Mnemonix.get(store, :fizz)
4
These functions behave exactly like their Map counterparts. However, Mnemonix
doesn’t supply analogs for functions that assume a store can be exhaustively
iterated or fit into a specific shape:
equal?(Map.t, Map.t) :: booleanfrom_struct(Struct.t) :: Map.tkeys(Map.t) :: [keys]merge(Map.t, Map.t) :: Map.tmerge(Map.t, Map.t, callback) :: Map.tsplit(Map.t, keys) :: Map.ttake(Map.t, keys) :: Map.tto_list(Map.t) :: Map.tvalues(Map.t) :: [values]
Summary
Functions
Removes the entry under key in store
Retrievs the value of the entry under key in store
Fetches the value for specific key
Gets the value for a specific key
Gets the value for a specific key with default
Gets the value from key and updates it, all in one pass
Gets the value from key and updates it. Raises if there is no key
Gets the value for a specific key
Returns whether a given key exists in the given store
Starts a new Mnemonix.Map.Store server with an empty map
Starts a new Mnemonix.Map.Store server from the enumerable
Starts a new Mnemonix.Map.Store server from the enumerable via
the transformation function
Returns and removes the value associated with key in store
Returns and removes the value associated with key in store with default
Lazily returns and removes the value associated with key in store
Creates a new entry for value under key in store
Puts the given value under key unless the entry key
already exists
Evaluates fun and puts the result under key
in store unless key is already present
Updates the key in store with the given function
Updates the key with the given function
Functions
Removes the entry under key in store.
If the key does not exist, the contents of store will be unaffected.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> Mnemonix.get(store, :a)
1
iex> Mnemonix.delete(store, :a)
iex> Mnemonix.get(store, :a)
nil
Retrievs the value of the entry under key in store.
If the key does not exist, returns :error, otherwise returns
{:ok, value}.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> Mnemonix.fetch(store, :a)
{:ok, 1}
iex> Mnemonix.fetch(store, :b)
:error
Fetches the value for specific key.
If key does not exist, a KeyError is raised.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> Mnemonix.fetch!(store, :a)
1
iex> Mnemonix.fetch!(store, :b)
** (KeyError) key :b not found in: Mnemonix.Map.Store
Gets the value for a specific key.
If key does not exist, returns nil.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> Mnemonix.get(store, :a)
1
iex> Mnemonix.get(store, :b)
nil
Gets the value for a specific key with default.
If key does not exist, returns default.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> Mnemonix.get(store, :a, 2)
1
iex> Mnemonix.get(store, :b, 2)
2
get_and_update(store, key, (value -> {get, value} | :pop)) ::
{get, store} |
no_return when get: term
Gets the value from key and updates it, all in one pass.
This fun argument receives the value of key (or nil if key
is not present) and must return a two-element tuple: the “get” value
(the retrieved value, which can be operated on before being returned)
and the new value to be stored under key. The fun may also
return :pop, implying the current value shall be removed
from store and returned.
The returned value is a tuple with the “get” value returned by
fun and a reference to the store with the updated value under key.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> {value, ^store} = Mnemonix.get_and_update(store, :a, fn current ->
...> {current, "new value!"}
...> end)
iex> value
1
iex> Mnemonix.get(store, :a)
"new value!"
iex> store = Mnemonix.new(%{a: 1})
iex> {value, ^store} = Mnemonix.get_and_update(store, :b, fn current ->
...> {current, "new value!"}
...> end)
iex> value
nil
iex> Mnemonix.get(store, :b)
"new value!"
iex> store = Mnemonix.new(%{a: 1})
iex> {value, ^store} = Mnemonix.get_and_update(store, :a, fn _ -> :pop end)
iex> value
1
iex> Mnemonix.get(store, :a)
nil
iex> store = Mnemonix.new(%{a: 1})
iex> {value, ^store} = Mnemonix.get_and_update(store, :b, fn _ -> :pop end)
iex> value
nil
iex> Mnemonix.get(store, :b)
nil
get_and_update!(store, key, (value -> {get, value})) ::
{get, store} |
no_return when get: term
Gets the value from key and updates it. Raises if there is no key.
This fun argument receives the value of key and must return a
two-element tuple: the “get” value (the retrieved value, which can be
operated on before being returned) and the new value to be stored under
key.
The returned value is a tuple with the “get” value returned by fun and a
a reference to the store with the updated value under key.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> {value, ^store} = Mnemonix.get_and_update!(store, :a, fn current ->
...> {current, "new value!"}
...> end)
iex> value
1
iex> Mnemonix.get(store, :a)
"new value!"
iex> store = Mnemonix.new(%{a: 1})
iex> {_value, ^store} = Mnemonix.get_and_update!(store, :b, fn current ->
...> {current, "new value!"}
...> end)
** (KeyError) key :b not found in: Mnemonix.Map.Store
iex> store = Mnemonix.new(%{a: 1})
iex> {value, ^store} = Mnemonix.get_and_update!(store, :a, fn _ -> :pop end)
iex> value
1
iex> Mnemonix.get(store, :a)
nil
iex> store = Mnemonix.new(%{a: 1})
iex> {_value, ^store} = Mnemonix.get_and_update!(store, :b, fn _ -> :pop end)
** (KeyError) key :b not found in: Mnemonix.Map.Store
Gets the value for a specific key.
If key does not exist, lazily evaluates fun and returns its result.
This is useful if the default value is very expensive to calculate or generally difficult to setup and teardown again.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> fun = fn ->
...> # some expensive operation here
...> 13
...> end
iex> Mnemonix.get_lazy(store, :a, fun)
1
iex> Mnemonix.get_lazy(store, :b, fun)
13
Returns whether a given key exists in the given store.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> Mnemonix.has_key?(store, :a)
true
iex> Mnemonix.has_key?(store, :b)
false
Starts a new Mnemonix.Map.Store server with an empty map.
Examples
iex> store = Mnemonix.new
iex> Mnemonix.get(store, :a)
nil
iex> Mnemonix.get(store, :b)
nil
Starts a new Mnemonix.Map.Store server from the enumerable.
Duplicated keys are removed; the latest one prevails.
Examples
iex> store = Mnemonix.new(a: 1)
iex> Mnemonix.get(store, :a)
1
iex> Mnemonix.get(store, :b)
nil
Starts a new Mnemonix.Map.Store server from the enumerable via
the transformation function.
Duplicated keys are removed; the latest one prevails.
Examples
iex> store = Mnemonix.new(%{"A" => 0}, fn {key, value} ->
...> { String.downcase(key), value + 1 }
...> end )
iex> Mnemonix.get(store, "a")
1
iex> Mnemonix.get(store, "A")
nil
Returns and removes the value associated with key in store.
If no value is associated with the key, nil is returned.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> {value, ^store} = Mnemonix.pop(store, :a)
iex> value
1
iex> Mnemonix.get(store, :a)
nil
iex> {value, ^store} = Mnemonix.pop(store, :b)
iex> value
nil
Returns and removes the value associated with key in store with default.
If no value is associated with the key but default is given,
that will be returned instead without touching the store.
Examples
iex> store = Mnemonix.new()
iex> {value, ^store} = Mnemonix.pop(store, :a)
iex> value
nil
iex> {value, ^store} = Mnemonix.pop(store, :b, 2)
iex> value
2
Lazily returns and removes the value associated with key in store.
This is useful if the default value is very expensive to calculate or generally difficult to setup and teardown again.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> fun = fn ->
...> # some expensive operation here
...> 13
...> end
iex> {value, ^store} = Mnemonix.pop_lazy(store, :a, fun)
iex> value
1
iex> {value, ^store} = Mnemonix.pop_lazy(store, :b, fun)
iex> value
13
Creates a new entry for value under key in store.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> Mnemonix.get(store, :b)
nil
iex> Mnemonix.put(store, :b, 2)
iex> Mnemonix.get(store, :b)
2
Puts the given value under key unless the entry key
already exists.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> Mnemonix.put_new(store, :b, 2)
iex> Mnemonix.get(store, :b)
2
iex> Mnemonix.put_new(store, :b, 3)
iex> Mnemonix.get(store, :b)
2
Evaluates fun and puts the result under key
in store unless key is already present.
This is useful if the value is very expensive to calculate or generally difficult to setup and teardown again.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> fun = fn ->
...> # some expensive operation here
...> 13
...> end
iex> Mnemonix.put_new_lazy(store, :b, fun)
iex> Mnemonix.get(store, :b)
13
iex> Mnemonix.put_new_lazy(store, :a, fun)
iex> Mnemonix.get(store, :a)
1
Updates the key in store with the given function.
If the key does not exist, inserts the given initial value.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> Mnemonix.update(store, :a, 13, &(&1 * 2))
iex> Mnemonix.get(store, :a)
2
iex> Mnemonix.update(store, :b, 13, &(&1 * 2))
iex> Mnemonix.get(store, :b)
13
Updates the key with the given function.
If the key does not exist, raises KeyError.
Examples
iex> store = Mnemonix.new(%{a: 1})
iex> Mnemonix.update!(store, :a, &(&1 * 2))
iex> Mnemonix.get(store, :a)
2
iex> Mnemonix.update!(store, :b, &(&1 * 2))
** (KeyError) key :b not found in: Mnemonix.Map.Store