12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- "use strict";
- const { STAGE_BASIC } = require("../OptimizationStages");
- class EnsureChunkConditionsPlugin {
-
- apply(compiler) {
- compiler.hooks.compilation.tap(
- "EnsureChunkConditionsPlugin",
- compilation => {
-
- const handler = chunks => {
- const chunkGraph = compilation.chunkGraph;
-
-
-
- const sourceChunks = new Set();
-
- const chunkGroups = new Set();
- for (const module of compilation.modules) {
- if (!module.hasChunkCondition()) continue;
- for (const chunk of chunkGraph.getModuleChunksIterable(module)) {
- if (!module.chunkCondition(chunk, compilation)) {
- sourceChunks.add(chunk);
- for (const group of chunk.groupsIterable) {
- chunkGroups.add(group);
- }
- }
- }
- if (sourceChunks.size === 0) continue;
-
- const targetChunks = new Set();
- chunkGroupLoop: for (const chunkGroup of chunkGroups) {
-
- for (const chunk of chunkGroup.chunks) {
- if (module.chunkCondition(chunk, compilation)) {
- targetChunks.add(chunk);
- continue chunkGroupLoop;
- }
- }
-
- if (chunkGroup.isInitial()) {
- throw new Error(
- "Cannot fulfil chunk condition of " + module.identifier()
- );
- }
-
- for (const group of chunkGroup.parentsIterable) {
- chunkGroups.add(group);
- }
- }
- for (const sourceChunk of sourceChunks) {
- chunkGraph.disconnectChunkAndModule(sourceChunk, module);
- }
- for (const targetChunk of targetChunks) {
- chunkGraph.connectChunkAndModule(targetChunk, module);
- }
- sourceChunks.clear();
- chunkGroups.clear();
- }
- };
- compilation.hooks.optimizeChunks.tap(
- {
- name: "EnsureChunkConditionsPlugin",
- stage: STAGE_BASIC
- },
- handler
- );
- }
- );
- }
- }
- module.exports = EnsureChunkConditionsPlugin;
|