.
This commit is contained in:
		
							
								
								
									
										68
									
								
								qwen/nodejs/node_modules/side-channel-map/index.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								qwen/nodejs/node_modules/side-channel-map/index.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,68 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
var GetIntrinsic = require('get-intrinsic');
 | 
			
		||||
var callBound = require('call-bound');
 | 
			
		||||
var inspect = require('object-inspect');
 | 
			
		||||
 | 
			
		||||
var $TypeError = require('es-errors/type');
 | 
			
		||||
var $Map = GetIntrinsic('%Map%', true);
 | 
			
		||||
 | 
			
		||||
/** @type {<K, V>(thisArg: Map<K, V>, key: K) => V} */
 | 
			
		||||
var $mapGet = callBound('Map.prototype.get', true);
 | 
			
		||||
/** @type {<K, V>(thisArg: Map<K, V>, key: K, value: V) => void} */
 | 
			
		||||
var $mapSet = callBound('Map.prototype.set', true);
 | 
			
		||||
/** @type {<K, V>(thisArg: Map<K, V>, key: K) => boolean} */
 | 
			
		||||
var $mapHas = callBound('Map.prototype.has', true);
 | 
			
		||||
/** @type {<K, V>(thisArg: Map<K, V>, key: K) => boolean} */
 | 
			
		||||
var $mapDelete = callBound('Map.prototype.delete', true);
 | 
			
		||||
/** @type {<K, V>(thisArg: Map<K, V>) => number} */
 | 
			
		||||
var $mapSize = callBound('Map.prototype.size', true);
 | 
			
		||||
 | 
			
		||||
/** @type {import('.')} */
 | 
			
		||||
module.exports = !!$Map && /** @type {Exclude<import('.'), false>} */ function getSideChannelMap() {
 | 
			
		||||
	/** @typedef {ReturnType<typeof getSideChannelMap>} Channel */
 | 
			
		||||
	/** @typedef {Parameters<Channel['get']>[0]} K */
 | 
			
		||||
	/** @typedef {Parameters<Channel['set']>[1]} V */
 | 
			
		||||
 | 
			
		||||
	/** @type {Map<K, V> | undefined} */ var $m;
 | 
			
		||||
 | 
			
		||||
	/** @type {Channel} */
 | 
			
		||||
	var channel = {
 | 
			
		||||
		assert: function (key) {
 | 
			
		||||
			if (!channel.has(key)) {
 | 
			
		||||
				throw new $TypeError('Side channel does not contain ' + inspect(key));
 | 
			
		||||
			}
 | 
			
		||||
		},
 | 
			
		||||
		'delete': function (key) {
 | 
			
		||||
			if ($m) {
 | 
			
		||||
				var result = $mapDelete($m, key);
 | 
			
		||||
				if ($mapSize($m) === 0) {
 | 
			
		||||
					$m = void undefined;
 | 
			
		||||
				}
 | 
			
		||||
				return result;
 | 
			
		||||
			}
 | 
			
		||||
			return false;
 | 
			
		||||
		},
 | 
			
		||||
		get: function (key) { // eslint-disable-line consistent-return
 | 
			
		||||
			if ($m) {
 | 
			
		||||
				return $mapGet($m, key);
 | 
			
		||||
			}
 | 
			
		||||
		},
 | 
			
		||||
		has: function (key) {
 | 
			
		||||
			if ($m) {
 | 
			
		||||
				return $mapHas($m, key);
 | 
			
		||||
			}
 | 
			
		||||
			return false;
 | 
			
		||||
		},
 | 
			
		||||
		set: function (key, value) {
 | 
			
		||||
			if (!$m) {
 | 
			
		||||
				// @ts-expect-error TS can't handle narrowing a variable inside a closure
 | 
			
		||||
				$m = new $Map();
 | 
			
		||||
			}
 | 
			
		||||
			$mapSet($m, key, value);
 | 
			
		||||
		}
 | 
			
		||||
	};
 | 
			
		||||
 | 
			
		||||
	// @ts-expect-error TODO: figure out why TS is erroring here
 | 
			
		||||
	return channel;
 | 
			
		||||
};
 | 
			
		||||
		Reference in New Issue
	
	Block a user