main
Last change
on this file since 79a0317 was 79a0317, checked in by stefan toskovski <stefantoska84@…>, 3 days ago |
F4 Finalna Verzija
|
-
Property mode
set to
100644
|
File size:
1.1 KB
|
Line | |
---|
1 | /*
|
---|
2 | MIT License http://www.opensource.org/licenses/mit-license.php
|
---|
3 | Author Tobias Koppers @sokra
|
---|
4 | */
|
---|
5 |
|
---|
6 | "use strict";
|
---|
7 |
|
---|
8 | /**
|
---|
9 | * getOrInsert is a helper function for maps that allows you to get a value
|
---|
10 | * from a map if it exists, or insert a new value if it doesn't. If it value doesn't
|
---|
11 | * exist, it will be computed by the provided function.
|
---|
12 | * @template K
|
---|
13 | * @template V
|
---|
14 | * @param {Map<K, V>} map The map object to check
|
---|
15 | * @param {K} key The key to check
|
---|
16 | * @param {function(): V} computer function which will compute the value if it doesn't exist
|
---|
17 | * @returns {V} The value from the map, or the computed value
|
---|
18 | * @example
|
---|
19 | * ```js
|
---|
20 | * const map = new Map();
|
---|
21 | * const value = getOrInsert(map, "key", () => "value");
|
---|
22 | * console.log(value); // "value"
|
---|
23 | * ```
|
---|
24 | */
|
---|
25 | module.exports.getOrInsert = (map, key, computer) => {
|
---|
26 | // Grab key from map
|
---|
27 | const value = map.get(key);
|
---|
28 | // If the value already exists, return it
|
---|
29 | if (value !== undefined) return value;
|
---|
30 | // Otherwise compute the value, set it in the map, and return it
|
---|
31 | const newValue = computer();
|
---|
32 | map.set(key, newValue);
|
---|
33 | return newValue;
|
---|
34 | };
|
---|
Note:
See
TracBrowser
for help on using the repository browser.