From be5966ee63d361f884891ba192c9cac8582b81ab Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Sat, 11 Jan 2025 20:23:54 -0400 Subject: reverse: unique option --- src/reverse.js | 32 +++++++++++++++++++++++++++++--- 1 file changed, 29 insertions(+), 3 deletions(-) (limited to 'src/reverse.js') diff --git a/src/reverse.js b/src/reverse.js index 22746d24..9ad5c8a7 100644 --- a/src/reverse.js +++ b/src/reverse.js @@ -3,16 +3,36 @@ import * as fr from './find-reverse.js'; import {sortByDate} from '#sort'; import {stitchArrays} from '#sugar'; +function checkUnique(value) { + if (value.length === 0) { + return null; + } else if (value.length === 1) { + return value[0]; + } else { + throw new Error( + `Requested unique referencing thing, ` + + `but ${value.length} reference this`); + } +} + function reverseHelper(spec) { const cache = new WeakMap(); - return (thing, data) => { + return (thing, data, { + unique = false, + } = {}) => { // Check for an existing cache record which corresponds to this data. // If it exists, query it for the requested thing, and return that; // if it doesn't, create it and put it where it needs to be. if (cache.has(data)) { - return cache.get(data).get(thing) ?? []; + const value = cache.get(data).get(thing) ?? []; + + if (unique) { + return checkUnique(value); + } else { + return value; + } } const cacheRecord = new WeakMap(); @@ -70,7 +90,13 @@ function reverseHelper(spec) { // Then just pluck out the requested thing from the now-filled // cache record! - return cacheRecord.get(thing) ?? []; + const value = cacheRecord.get(thing) ?? []; + + if (unique) { + return checkUnique(value); + } else { + return value; + } }; } -- cgit 1.3.0-6-gf8a5