PNG  IHDR;IDATxܻn0K )(pA 7LeG{ §㻢|ذaÆ 6lذaÆ 6lذaÆ 6lom$^yذag5bÆ 6lذaÆ 6lذa{ 6lذaÆ `}HFkm,mӪôô! x|'ܢ˟;E:9&ᶒ}{v]n&6 h_tڠ͵-ҫZ;Z$.Pkž)!o>}leQfJTu іچ\X=8Rن4`Vwl>nG^is"ms$ui?wbs[m6K4O.4%/bC%t Mז -lG6mrz2s%9s@-k9=)kB5\+͂Zsٲ Rn~GRC wIcIn7jJhۛNCS|j08yiHKֶۛkɈ+;SzL/F*\Ԕ#"5m2[S=gnaPeғL lذaÆ 6l^ḵaÆ 6lذaÆ 6lذa; _ذaÆ 6lذaÆ 6lذaÆ RIENDB` 'use strict'; const { compare, filterOutStabilizedProposals, has, intersection } = require('./helpers'); const data = require('./data'); const entries = require('./entries'); const getModulesListForTargetVersion = require('./get-modules-list-for-target-version'); const allModules = require('./modules'); const targetsParser = require('./targets-parser'); function throwInvalidFilter(filter) { throw TypeError(`Specified invalid module name or pattern: ${ filter }`); } function atLeastSomeModules(modules, filter) { if (!modules.length) throwInvalidFilter(filter); return modules; } function getModules(filter) { if (typeof filter == 'string') { if (has(entries, filter)) return entries[filter]; return atLeastSomeModules(allModules.filter(it => it.startsWith(filter)), filter); } else if (filter instanceof RegExp) return atLeastSomeModules(allModules.filter(it => filter.test(it)), filter); throwInvalidFilter(filter); } function normalizeModules(option) { // TODO: use `.flatMap` in core-js@4 return new Set(Array.isArray(option) ? [].concat.apply([], option.map(getModules)) : getModules(option)); } function checkModule(name, targets) { const result = { required: !targets, targets: {}, }; if (!targets) return result; const requirements = data[name]; for (const [engine, version] of targets) { if (!has(requirements, engine) || compare(version, '<', requirements[engine])) { result.required = true; result.targets[engine] = version; } } return result; } module.exports = function ({ filter = null, // TODO: Obsolete, remove from `core-js@4` modules = null, exclude = [], targets = null, version = null, inverse = false, } = {}) { if (modules == null) modules = filter; inverse = !!inverse; const parsedTargets = targets ? targetsParser(targets) : null; const result = { list: [], targets: {}, }; exclude = normalizeModules(exclude); modules = modules ? [...normalizeModules(modules)] : allModules; if (exclude.size) modules = modules.filter(it => !exclude.has(it)); modules = intersection(modules, version ? getModulesListForTargetVersion(version) : allModules); if (!inverse) modules = filterOutStabilizedProposals(modules); for (const key of modules) { const check = checkModule(key, parsedTargets); if (check.required ^ inverse) { result.list.push(key); result.targets[key] = check.targets; } } return result; };