| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 | 'use strict';exports.__esModule = true;const log = require('debug')('eslint-module-utils:ModuleCache');/** @type {import('./ModuleCache').ModuleCache} */class ModuleCache {  /** @param {typeof import('./ModuleCache').ModuleCache.prototype.map} map */  constructor(map) {    this.map = map || /** @type {{typeof import('./ModuleCache').ModuleCache.prototype.map} */ new Map();  }  /** @type {typeof import('./ModuleCache').ModuleCache.prototype.set} */  set(cacheKey, result) {    this.map.set(cacheKey, { result, lastSeen: process.hrtime() });    log('setting entry for', cacheKey);    return result;  }  /** @type {typeof import('./ModuleCache').ModuleCache.prototype.get} */  get(cacheKey, settings) {    if (this.map.has(cacheKey)) {      const f = this.map.get(cacheKey);      // check freshness      // @ts-expect-error TS can't narrow properly from `has` and `get`      if (process.hrtime(f.lastSeen)[0] < settings.lifetime) { return f.result; }    } else {      log('cache miss for', cacheKey);    }    // cache miss    return undefined;  }  /** @type {typeof import('./ModuleCache').ModuleCache.getSettings} */  static getSettings(settings) {    /** @type {ReturnType<typeof ModuleCache.getSettings>} */    const cacheSettings = Object.assign({      lifetime: 30,  // seconds    }, settings['import/cache']);    // parse infinity    // @ts-expect-error the lack of type overlap is because we're abusing `cacheSettings` as a temporary object    if (cacheSettings.lifetime === '∞' || cacheSettings.lifetime === 'Infinity') {      cacheSettings.lifetime = Infinity;    }    return cacheSettings;  }}exports.default = ModuleCache;
 |