1.0.2 โ€ข Published 4 years ago

umap v1.0.2

Weekly downloads
2,152
License
ISC
Repository
github
Last release
4 years ago

ยตmap ๐Ÿ—บ

Build Status Coverage Status

The smallest, yet handy, Map and WeakMap utility ever.

import umap from 'umap';
// const umap = require('umap');

const map = umap(new Map);
console.assert(
  (map.get(1) || map.set(1, Math.random())) ===
  (map.get(1) || map.set(1, Math.random())),
  'a very common pattern I have with Map instances'
);

const weakMap = umap(new WeakMap);
console.assert(
  (weakMap.get(map) || weakMap.set(map, Math.random())) ===
  (weakMap.get(map) || weakMap.set(map, Math.random())),
  'which I use even more with WeakMap instances'
);

๐Ÿค” Reason

I am super tired of creating workarounds for the fact map.set(key, value) doesn't return value but the map itself, and so does the WeakMap.

This module will help, at least me, dropping all one-off helpers, here and there, to always do the same thing:

// before ๐Ÿ˜ข
const cache = new WeakMap;
const setThing = (key, value) => {
  cache.set(key, value);
  return value;
};
const thing = cache.get(key) || setThing(key, value);

// with umap ๐ŸŽ‰
const cache = umap(new WeakMap);
const thing = cache.get(key) || cache.set(key, value);

๐ŸŒˆ It's Done!

This module is meant to solve one pattern only, and it does exactly that, so that if you store falsy values in Maps or WeakMaps, it is not a concern of this module.