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` /* MIT License http://www.opensource.org/licenses/mit-license.php Author Florent Cailhol @ooflorent */ "use strict"; const { compareModulesByPreOrderIndexOrIdentifier } = require("../util/comparators"); const { getUsedModuleIdsAndModules, getFullModuleName, assignDeterministicIds } = require("./IdHelpers"); /** @typedef {import("../Compiler")} Compiler */ /** @typedef {import("../Module")} Module */ class DeterministicModuleIdsPlugin { /** * @param {Object} options options * @param {string=} options.context context relative to which module identifiers are computed * @param {function(Module): boolean=} options.test selector function for modules * @param {number=} options.maxLength maximum id length in digits (used as starting point) * @param {number=} options.salt hash salt for ids * @param {boolean=} options.fixedLength do not increase the maxLength to find an optimal id space size * @param {boolean=} options.failOnConflict throw an error when id conflicts occur (instead of rehashing) */ constructor(options = {}) { this.options = options; } /** * Apply the plugin * @param {Compiler} compiler the compiler instance * @returns {void} */ apply(compiler) { compiler.hooks.compilation.tap( "DeterministicModuleIdsPlugin", compilation => { compilation.hooks.moduleIds.tap("DeterministicModuleIdsPlugin", () => { const chunkGraph = compilation.chunkGraph; const context = this.options.context ? this.options.context : compiler.context; const maxLength = this.options.maxLength || 3; const failOnConflict = this.options.failOnConflict || false; const fixedLength = this.options.fixedLength || false; const salt = this.options.salt || 0; let conflicts = 0; const [usedIds, modules] = getUsedModuleIdsAndModules( compilation, this.options.test ); assignDeterministicIds( modules, module => getFullModuleName(module, context, compiler.root), failOnConflict ? () => 0 : compareModulesByPreOrderIndexOrIdentifier( compilation.moduleGraph ), (module, id) => { const size = usedIds.size; usedIds.add(`${id}`); if (size === usedIds.size) { conflicts++; return false; } chunkGraph.setModuleId(module, id); return true; }, [Math.pow(10, maxLength)], fixedLength ? 0 : 10, usedIds.size, salt ); if (failOnConflict && conflicts) throw new Error( `Assigning deterministic module ids has lead to ${conflicts} conflict${ conflicts > 1 ? "s" : "" }.\nIncrease the 'maxLength' to increase the id space and make conflicts less likely (recommended when there are many conflicts or application is expected to grow), or add an 'salt' number to try another hash starting value in the same id space (recommended when there is only a single conflict).` ); }); } ); } } module.exports = DeterministicModuleIdsPlugin;