nav tabs on admin dashboard
This commit is contained in:
161
node_modules/webpack/lib/FlagDependencyUsagePlugin.js
generated
vendored
161
node_modules/webpack/lib/FlagDependencyUsagePlugin.js
generated
vendored
@@ -4,77 +4,112 @@
|
||||
*/
|
||||
"use strict";
|
||||
|
||||
/** @typedef {import("./Module")} Module */
|
||||
/** @typedef {import("./DependenciesBlock")} DependenciesBlock */
|
||||
|
||||
/** @typedef {false | true | string[]} UsedExports */
|
||||
|
||||
const addToSet = (a, b) => {
|
||||
for (const item of b) {
|
||||
if (!a.includes(item)) a.push(item);
|
||||
}
|
||||
return a;
|
||||
};
|
||||
|
||||
const isSubset = (biggerSet, subset) => {
|
||||
if (biggerSet === true) return true;
|
||||
if (subset === true) return false;
|
||||
return subset.every(item => biggerSet.indexOf(item) >= 0);
|
||||
};
|
||||
|
||||
class FlagDependencyUsagePlugin {
|
||||
apply(compiler) {
|
||||
compiler.plugin("compilation", compilation => {
|
||||
compilation.plugin("optimize-modules-advanced", modules => {
|
||||
|
||||
modules.forEach(module => module.used = false);
|
||||
|
||||
const queue = [];
|
||||
compilation.chunks.forEach(chunk => {
|
||||
if(chunk.entryModule) {
|
||||
processModule(chunk.entryModule, true);
|
||||
}
|
||||
});
|
||||
|
||||
while(queue.length) {
|
||||
const queueItem = queue.pop();
|
||||
processDependenciesBlock(queueItem[0], queueItem[1]);
|
||||
}
|
||||
|
||||
function processModule(module, usedExports) {
|
||||
module.used = true;
|
||||
if(module.usedExports === true)
|
||||
return;
|
||||
else if(usedExports === true)
|
||||
module.usedExports = true;
|
||||
else if(Array.isArray(usedExports)) {
|
||||
const old = module.usedExports ? module.usedExports.length : -1;
|
||||
module.usedExports = addToSet(module.usedExports || [], usedExports);
|
||||
if(module.usedExports.length === old)
|
||||
compiler.hooks.compilation.tap("FlagDependencyUsagePlugin", compilation => {
|
||||
compilation.hooks.optimizeDependencies.tap(
|
||||
"FlagDependencyUsagePlugin",
|
||||
modules => {
|
||||
const processModule = (module, usedExports) => {
|
||||
module.used = true;
|
||||
if (module.usedExports === true) return;
|
||||
if (usedExports === true) {
|
||||
module.usedExports = true;
|
||||
} else if (Array.isArray(usedExports)) {
|
||||
const old = module.usedExports ? module.usedExports.length : -1;
|
||||
module.usedExports = addToSet(
|
||||
module.usedExports || [],
|
||||
usedExports
|
||||
);
|
||||
if (module.usedExports.length === old) {
|
||||
return;
|
||||
}
|
||||
} else if (Array.isArray(module.usedExports)) {
|
||||
return;
|
||||
} else if(Array.isArray(module.usedExports))
|
||||
return;
|
||||
else
|
||||
module.usedExports = false;
|
||||
} else {
|
||||
module.usedExports = false;
|
||||
}
|
||||
|
||||
queue.push([module, module.usedExports]);
|
||||
}
|
||||
// for a module without side effects we stop tracking usage here when no export is used
|
||||
// This module won't be evaluated in this case
|
||||
if (module.factoryMeta.sideEffectFree) {
|
||||
if (module.usedExports === false) return;
|
||||
if (
|
||||
Array.isArray(module.usedExports) &&
|
||||
module.usedExports.length === 0
|
||||
)
|
||||
return;
|
||||
}
|
||||
|
||||
function processDependenciesBlock(depBlock, usedExports) {
|
||||
depBlock.dependencies.forEach(dep => processDependency(dep));
|
||||
depBlock.variables.forEach(variable => variable.dependencies.forEach(dep => processDependency(dep)));
|
||||
depBlock.blocks.forEach(block => queue.push([block, usedExports]));
|
||||
}
|
||||
queue.push([module, module, module.usedExports]);
|
||||
};
|
||||
|
||||
function processDependency(dep) {
|
||||
const reference = dep.getReference && dep.getReference();
|
||||
if(!reference) return;
|
||||
const module = reference.module;
|
||||
const importedNames = reference.importedNames;
|
||||
const oldUsed = module.used;
|
||||
const oldUsedExports = module.usedExports;
|
||||
if(!oldUsed || (importedNames && (!oldUsedExports || !isSubset(oldUsedExports, importedNames)))) {
|
||||
processModule(module, importedNames);
|
||||
const processDependenciesBlock = (module, depBlock, usedExports) => {
|
||||
for (const dep of depBlock.dependencies) {
|
||||
processDependency(module, dep);
|
||||
}
|
||||
for (const variable of depBlock.variables) {
|
||||
for (const dep of variable.dependencies) {
|
||||
processDependency(module, dep);
|
||||
}
|
||||
}
|
||||
for (const block of depBlock.blocks) {
|
||||
queue.push([module, block, usedExports]);
|
||||
}
|
||||
};
|
||||
|
||||
const processDependency = (module, dep) => {
|
||||
const reference = compilation.getDependencyReference(module, dep);
|
||||
if (!reference) return;
|
||||
const referenceModule = reference.module;
|
||||
const importedNames = reference.importedNames;
|
||||
const oldUsed = referenceModule.used;
|
||||
const oldUsedExports = referenceModule.usedExports;
|
||||
if (
|
||||
!oldUsed ||
|
||||
(importedNames &&
|
||||
(!oldUsedExports || !isSubset(oldUsedExports, importedNames)))
|
||||
) {
|
||||
processModule(referenceModule, importedNames);
|
||||
}
|
||||
};
|
||||
|
||||
for (const module of modules) {
|
||||
module.used = false;
|
||||
}
|
||||
|
||||
/** @type {[Module, DependenciesBlock, UsedExports][]} */
|
||||
const queue = [];
|
||||
for (const preparedEntrypoint of compilation._preparedEntrypoints) {
|
||||
if (preparedEntrypoint.module) {
|
||||
processModule(preparedEntrypoint.module, true);
|
||||
}
|
||||
}
|
||||
|
||||
while (queue.length) {
|
||||
const queueItem = queue.pop();
|
||||
processDependenciesBlock(queueItem[0], queueItem[1], queueItem[2]);
|
||||
}
|
||||
}
|
||||
|
||||
});
|
||||
|
||||
function addToSet(a, b) {
|
||||
b.forEach(item => {
|
||||
if(a.indexOf(item) < 0)
|
||||
a.push(item);
|
||||
});
|
||||
return a;
|
||||
}
|
||||
|
||||
function isSubset(biggerSet, subset) {
|
||||
if(biggerSet === true) return true;
|
||||
if(subset === true) return false;
|
||||
return subset.every(item => biggerSet.indexOf(item) >= 0);
|
||||
}
|
||||
);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user