'use strict'; /** * Create a collection of Maps that serve to contextualize a given node. * This is useful to ensure that you only compare nodes that share a certain * context. * * All nodes are initially contextualized by their input source. * From there, you can contextualize them however you want. * * For a usage example, see `selector-no-descending-specificity`. */ module.exports = function () { const contextMap = new Map(); return { /** * @param {import('postcss').Node} node */ getContext(node, /** @type {any[]} */ ...subContexts) { // TODO TYPES node.source possible undefined const nodeSource = /** @type {import('postcss').NodeSource} */ (node.source).input.from; const baseContext = creativeGetMap(contextMap, nodeSource); return subContexts.reduce((result, context) => { return creativeGetMap(result, context); }, baseContext); }, }; }; /** * TODO TYPES * @param {Map} someMap * @param {any} someThing */ function creativeGetMap(someMap, someThing) { if (!someMap.has(someThing)) { someMap.set(someThing, new Map()); } return someMap.get(someThing); }