webpack 4.9.1 → 4.10.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (279) hide show
  1. package/README.md +755 -755
  2. package/SECURITY.md +9 -9
  3. package/buildin/global.js +20 -20
  4. package/buildin/harmony-module.js +24 -24
  5. package/buildin/module.js +22 -22
  6. package/hot/dev-server.js +61 -61
  7. package/hot/log-apply-result.js +44 -44
  8. package/hot/log.js +45 -45
  9. package/hot/only-dev-server.js +105 -105
  10. package/hot/poll.js +37 -37
  11. package/hot/signal.js +62 -62
  12. package/lib/APIPlugin.js +84 -84
  13. package/lib/AmdMainTemplatePlugin.js +87 -75
  14. package/lib/AsyncDependenciesBlock.js +66 -66
  15. package/lib/AsyncDependencyToInitialChunkError.js +31 -21
  16. package/lib/AutomaticPrefetchPlugin.js +50 -50
  17. package/lib/BannerPlugin.js +3 -1
  18. package/lib/BasicEvaluatedExpression.js +211 -208
  19. package/lib/CachePlugin.js +102 -95
  20. package/lib/CaseSensitiveModulesWarning.js +71 -53
  21. package/lib/Chunk.js +750 -722
  22. package/lib/ChunkGroup.js +13 -5
  23. package/lib/ChunkRenderError.js +32 -32
  24. package/lib/CompatibilityPlugin.js +63 -63
  25. package/lib/Compilation.js +1947 -1905
  26. package/lib/Compiler.js +508 -496
  27. package/lib/ConcurrentCompilationError.js +19 -19
  28. package/lib/ConstPlugin.js +258 -242
  29. package/lib/ContextExclusionPlugin.js +17 -17
  30. package/lib/ContextModule.js +749 -710
  31. package/lib/ContextModuleFactory.js +256 -245
  32. package/lib/ContextReplacementPlugin.js +133 -126
  33. package/lib/DefinePlugin.js +206 -197
  34. package/lib/DelegatedModule.js +101 -101
  35. package/lib/DelegatedModuleFactoryPlugin.js +89 -89
  36. package/lib/DelegatedPlugin.js +39 -39
  37. package/lib/DependenciesBlock.js +89 -87
  38. package/lib/DependenciesBlockVariable.js +52 -51
  39. package/lib/Dependency.js +51 -51
  40. package/lib/DllEntryPlugin.js +51 -51
  41. package/lib/DllModule.js +54 -54
  42. package/lib/DllModuleFactory.js +29 -29
  43. package/lib/DllPlugin.js +44 -42
  44. package/lib/DllReferencePlugin.js +84 -84
  45. package/lib/DynamicEntryPlugin.js +73 -71
  46. package/lib/EntryOptionPlugin.js +33 -33
  47. package/lib/EnvironmentPlugin.js +65 -65
  48. package/lib/ErrorHelpers.js +60 -57
  49. package/lib/EvalDevToolModulePlugin.js +27 -27
  50. package/lib/EvalDevToolModuleTemplatePlugin.js +61 -61
  51. package/lib/EvalSourceMapDevToolPlugin.js +41 -40
  52. package/lib/ExportPropertyMainTemplatePlugin.js +53 -40
  53. package/lib/ExtendedAPIPlugin.js +84 -84
  54. package/lib/ExternalModule.js +159 -159
  55. package/lib/ExternalModuleFactoryPlugin.js +110 -110
  56. package/lib/ExternalsPlugin.js +23 -23
  57. package/lib/FlagDependencyExportsPlugin.js +146 -146
  58. package/lib/FlagDependencyUsagePlugin.js +110 -104
  59. package/lib/FlagInitialModulesAsUsedPlugin.js +36 -36
  60. package/lib/FunctionModulePlugin.js +19 -19
  61. package/lib/FunctionModuleTemplatePlugin.js +100 -98
  62. package/lib/GraphHelpers.js +64 -64
  63. package/lib/HarmonyLinkingError.js +18 -18
  64. package/lib/HashedModuleIdsPlugin.js +53 -53
  65. package/lib/HotModuleReplacement.runtime.js +7 -3
  66. package/lib/HotModuleReplacementPlugin.js +413 -406
  67. package/lib/HotUpdateChunk.js +16 -16
  68. package/lib/HotUpdateChunkTemplate.js +78 -78
  69. package/lib/IgnorePlugin.js +71 -71
  70. package/lib/JavascriptGenerator.js +229 -228
  71. package/lib/JavascriptModulesPlugin.js +179 -184
  72. package/lib/JsonGenerator.js +42 -42
  73. package/lib/JsonModulesPlugin.js +30 -30
  74. package/lib/JsonParser.js +27 -26
  75. package/lib/LibManifestPlugin.js +86 -86
  76. package/lib/LibraryTemplatePlugin.js +153 -119
  77. package/lib/LoaderOptionsPlugin.js +53 -52
  78. package/lib/LoaderTargetPlugin.js +24 -24
  79. package/lib/MainTemplate.js +34 -9
  80. package/lib/Module.js +381 -377
  81. package/lib/ModuleBuildError.js +42 -42
  82. package/lib/ModuleDependencyError.js +35 -25
  83. package/lib/ModuleDependencyWarning.js +25 -25
  84. package/lib/ModuleError.js +28 -28
  85. package/lib/ModuleFilenameHelpers.js +178 -166
  86. package/lib/ModuleParseError.js +44 -44
  87. package/lib/ModuleReason.js +40 -40
  88. package/lib/ModuleTemplate.js +84 -84
  89. package/lib/ModuleWarning.js +30 -30
  90. package/lib/MultiCompiler.js +283 -271
  91. package/lib/MultiEntryPlugin.js +58 -58
  92. package/lib/MultiModule.js +81 -78
  93. package/lib/MultiModuleFactory.js +23 -23
  94. package/lib/MultiStats.js +92 -92
  95. package/lib/MultiWatching.js +38 -38
  96. package/lib/NamedChunksPlugin.js +29 -29
  97. package/lib/NamedModulesPlugin.js +57 -57
  98. package/lib/NoEmitOnErrorsPlugin.js +20 -20
  99. package/lib/NoModeWarning.js +23 -23
  100. package/lib/NodeStuffPlugin.js +179 -178
  101. package/lib/NormalModule.js +497 -490
  102. package/lib/NormalModuleFactory.js +501 -483
  103. package/lib/NormalModuleReplacementPlugin.js +51 -51
  104. package/lib/OptionsDefaulter.js +84 -80
  105. package/lib/Parser.js +2164 -2086
  106. package/lib/ParserHelpers.js +103 -100
  107. package/lib/PrefetchPlugin.js +37 -37
  108. package/lib/ProgressPlugin.js +231 -231
  109. package/lib/ProvidePlugin.js +86 -86
  110. package/lib/RawModule.js +56 -54
  111. package/lib/RecordIdsPlugin.js +166 -162
  112. package/lib/RemovedPluginError.js +13 -13
  113. package/lib/RequestShortener.js +81 -74
  114. package/lib/RequireJsStuffPlugin.js +69 -69
  115. package/lib/ResolverFactory.js +64 -64
  116. package/lib/RuleSet.js +555 -534
  117. package/lib/RuntimeTemplate.js +320 -277
  118. package/lib/SetVarMainTemplatePlugin.js +69 -57
  119. package/lib/SingleEntryPlugin.js +44 -44
  120. package/lib/SizeFormatHelpers.js +24 -24
  121. package/lib/SourceMapDevToolModuleOptionsPlugin.js +49 -49
  122. package/lib/SourceMapDevToolPlugin.js +301 -300
  123. package/lib/Stats.js +1408 -1367
  124. package/lib/Template.js +4 -2
  125. package/lib/TemplatedPathPlugin.js +173 -170
  126. package/lib/UmdMainTemplatePlugin.js +304 -264
  127. package/lib/UseStrictPlugin.js +48 -48
  128. package/lib/WarnCaseSensitiveModulesPlugin.js +37 -36
  129. package/lib/WarnNoModeSetPlugin.js +17 -17
  130. package/lib/WatchIgnorePlugin.js +100 -100
  131. package/lib/Watching.js +194 -193
  132. package/lib/WebpackError.js +25 -19
  133. package/lib/WebpackOptionsApply.js +421 -405
  134. package/lib/WebpackOptionsDefaulter.js +347 -344
  135. package/lib/WebpackOptionsValidationError.js +345 -316
  136. package/lib/compareLocations.js +56 -56
  137. package/lib/dependencies/AMDDefineDependency.js +137 -137
  138. package/lib/dependencies/AMDDefineDependencyParserPlugin.js +336 -327
  139. package/lib/dependencies/AMDPlugin.js +250 -250
  140. package/lib/dependencies/AMDRequireArrayDependency.js +49 -49
  141. package/lib/dependencies/AMDRequireContextDependency.js +20 -20
  142. package/lib/dependencies/AMDRequireDependenciesBlock.js +43 -43
  143. package/lib/dependencies/AMDRequireDependenciesBlockParserPlugin.js +273 -270
  144. package/lib/dependencies/AMDRequireDependency.js +135 -135
  145. package/lib/dependencies/CommonJsPlugin.js +161 -161
  146. package/lib/dependencies/CommonJsRequireContextDependency.js +23 -23
  147. package/lib/dependencies/CommonJsRequireDependencyParserPlugin.js +130 -130
  148. package/lib/dependencies/ConstDependency.js +33 -33
  149. package/lib/dependencies/ContextDependency.js +68 -68
  150. package/lib/dependencies/ContextDependencyTemplateAsId.js +42 -42
  151. package/lib/dependencies/ContextDependencyTemplateAsRequireCall.js +38 -38
  152. package/lib/dependencies/ContextElementDependency.js +21 -21
  153. package/lib/dependencies/DelegatedExportsDependency.js +33 -33
  154. package/lib/dependencies/DependencyReference.js +18 -18
  155. package/lib/dependencies/HarmonyAcceptDependency.js +45 -45
  156. package/lib/dependencies/HarmonyAcceptImportDependency.js +23 -23
  157. package/lib/dependencies/HarmonyCompatibilityDependency.js +31 -31
  158. package/lib/dependencies/HarmonyDetectionParserPlugin.js +92 -90
  159. package/lib/dependencies/HarmonyExportDependencyParserPlugin.js +139 -139
  160. package/lib/dependencies/HarmonyExportExpressionDependency.js +53 -53
  161. package/lib/dependencies/HarmonyExportHeaderDependency.js +30 -30
  162. package/lib/dependencies/HarmonyExportImportedSpecifierDependency.js +620 -603
  163. package/lib/dependencies/HarmonyExportSpecifierDependency.js +54 -54
  164. package/lib/dependencies/HarmonyImportDependency.js +104 -94
  165. package/lib/dependencies/HarmonyImportDependencyParserPlugin.js +217 -214
  166. package/lib/dependencies/HarmonyImportSideEffectDependency.js +31 -31
  167. package/lib/dependencies/HarmonyImportSpecifierDependency.js +166 -156
  168. package/lib/dependencies/HarmonyInitDependency.js +60 -60
  169. package/lib/dependencies/HarmonyModulesPlugin.js +146 -146
  170. package/lib/dependencies/HarmonyTopLevelThisParserPlugin.js +26 -26
  171. package/lib/dependencies/ImportContextDependency.js +23 -23
  172. package/lib/dependencies/ImportDependenciesBlock.js +18 -18
  173. package/lib/dependencies/ImportDependency.js +34 -34
  174. package/lib/dependencies/ImportEagerDependency.js +32 -32
  175. package/lib/dependencies/ImportParserPlugin.js +233 -232
  176. package/lib/dependencies/ImportPlugin.js +82 -82
  177. package/lib/dependencies/ImportWeakDependency.js +34 -34
  178. package/lib/dependencies/JsonExportsDependency.js +26 -26
  179. package/lib/dependencies/LoaderPlugin.js +98 -93
  180. package/lib/dependencies/LocalModuleDependency.js +28 -28
  181. package/lib/dependencies/LocalModulesHelpers.js +52 -45
  182. package/lib/dependencies/ModuleDependency.js +20 -20
  183. package/lib/dependencies/ModuleDependencyTemplateAsId.js +17 -17
  184. package/lib/dependencies/ModuleDependencyTemplateAsRequireId.js +17 -17
  185. package/lib/dependencies/MultiEntryDependency.js +20 -20
  186. package/lib/dependencies/NullDependency.js +20 -20
  187. package/lib/dependencies/RequireContextDependency.js +22 -22
  188. package/lib/dependencies/RequireContextDependencyParserPlugin.js +56 -56
  189. package/lib/dependencies/RequireContextPlugin.js +143 -141
  190. package/lib/dependencies/RequireEnsureDependenciesBlock.js +33 -33
  191. package/lib/dependencies/RequireEnsureDependenciesBlockParserPlugin.js +116 -112
  192. package/lib/dependencies/RequireEnsureDependency.js +58 -58
  193. package/lib/dependencies/RequireEnsurePlugin.js +74 -74
  194. package/lib/dependencies/RequireHeaderDependency.js +26 -26
  195. package/lib/dependencies/RequireIncludeDependency.js +39 -39
  196. package/lib/dependencies/RequireIncludeDependencyParserPlugin.js +23 -23
  197. package/lib/dependencies/RequireIncludePlugin.js +61 -61
  198. package/lib/dependencies/RequireResolveContextDependency.js +23 -23
  199. package/lib/dependencies/RequireResolveDependencyParserPlugin.js +85 -85
  200. package/lib/dependencies/RequireResolveHeaderDependency.js +26 -26
  201. package/lib/dependencies/SingleEntryDependency.js +18 -18
  202. package/lib/dependencies/SystemPlugin.js +125 -125
  203. package/lib/dependencies/UnsupportedDependency.js +27 -27
  204. package/lib/dependencies/WebAssemblyImportDependency.js +48 -44
  205. package/lib/dependencies/WebpackMissingModule.js +20 -20
  206. package/lib/dependencies/getFunctionExpression.js +52 -52
  207. package/lib/formatLocation.js +61 -53
  208. package/lib/node/NodeChunkTemplatePlugin.js +31 -31
  209. package/lib/node/NodeEnvironmentPlugin.js +28 -28
  210. package/lib/node/NodeHotUpdateChunkTemplatePlugin.js +36 -36
  211. package/lib/node/NodeMainTemplate.runtime.js +27 -27
  212. package/lib/node/NodeMainTemplateAsync.runtime.js +44 -44
  213. package/lib/node/NodeMainTemplatePlugin.js +323 -320
  214. package/lib/node/NodeSourcePlugin.js +144 -140
  215. package/lib/node/NodeTargetPlugin.js +18 -18
  216. package/lib/node/NodeTemplatePlugin.js +31 -31
  217. package/lib/node/NodeWatchFileSystem.js +99 -82
  218. package/lib/node/ReadFileCompileWasmTemplatePlugin.js +52 -52
  219. package/lib/optimize/AggressiveMergingPlugin.js +87 -87
  220. package/lib/optimize/AggressiveSplittingPlugin.js +287 -281
  221. package/lib/optimize/ChunkModuleIdRangePlugin.js +68 -68
  222. package/lib/optimize/ConcatenatedModule.js +1420 -1413
  223. package/lib/optimize/EnsureChunkConditionsPlugin.js +70 -70
  224. package/lib/optimize/FlagIncludedChunksPlugin.js +99 -99
  225. package/lib/optimize/LimitChunkCountPlugin.js +66 -66
  226. package/lib/optimize/MergeDuplicateChunksPlugin.js +78 -75
  227. package/lib/optimize/MinChunkSizePlugin.js +77 -77
  228. package/lib/optimize/ModuleConcatenationPlugin.js +470 -457
  229. package/lib/optimize/OccurrenceOrderPlugin.js +133 -126
  230. package/lib/optimize/RemoveParentModulesPlugin.js +127 -117
  231. package/lib/optimize/RuntimeChunkPlugin.js +41 -41
  232. package/lib/optimize/SideEffectsFlagPlugin.js +158 -156
  233. package/lib/optimize/SplitChunksPlugin.js +709 -696
  234. package/lib/performance/AssetsOverSizeLimitWarning.js +30 -30
  235. package/lib/performance/EntrypointsOverSizeLimitWarning.js +31 -31
  236. package/lib/performance/NoAsyncChunksWarning.js +21 -21
  237. package/lib/performance/SizeLimitsPlugin.js +105 -105
  238. package/lib/util/Semaphore.js +41 -41
  239. package/lib/util/SortableSet.js +5 -2
  240. package/lib/util/StackedSetMap.js +12 -5
  241. package/lib/util/TrackingSet.js +35 -35
  242. package/lib/util/cachedMerge.js +35 -35
  243. package/lib/util/createHash.js +77 -77
  244. package/lib/util/identifier.js +76 -76
  245. package/lib/validateSchema.js +67 -67
  246. package/lib/wasm/UnsupportedWebAssemblyFeatureError.js +18 -18
  247. package/lib/wasm/WasmMainTemplatePlugin.js +310 -304
  248. package/lib/wasm/WebAssemblyGenerator.js +143 -19
  249. package/lib/wasm/WebAssemblyJavascriptGenerator.js +90 -107
  250. package/lib/wasm/WebAssemblyModulesPlugin.js +80 -80
  251. package/lib/wasm/WebAssemblyParser.js +28 -5
  252. package/lib/wasm/WebAssemblyUtils.js +48 -0
  253. package/lib/web/FetchCompileWasmTemplatePlugin.js +25 -25
  254. package/lib/web/JsonpChunkTemplatePlugin.js +47 -47
  255. package/lib/web/JsonpExportMainTemplatePlugin.js +47 -47
  256. package/lib/web/JsonpHotUpdateChunkTemplatePlugin.js +39 -39
  257. package/lib/web/JsonpMainTemplate.runtime.js +65 -64
  258. package/lib/web/JsonpMainTemplatePlugin.js +576 -574
  259. package/lib/web/JsonpTemplatePlugin.js +23 -23
  260. package/lib/webpack.js +183 -182
  261. package/lib/webpack.web.js +31 -31
  262. package/lib/webworker/WebWorkerChunkTemplatePlugin.js +35 -35
  263. package/lib/webworker/WebWorkerHotUpdateChunkTemplatePlugin.js +40 -40
  264. package/lib/webworker/WebWorkerMainTemplate.runtime.js +65 -64
  265. package/lib/webworker/WebWorkerMainTemplatePlugin.js +179 -179
  266. package/lib/webworker/WebWorkerTemplatePlugin.js +25 -25
  267. package/package.json +9 -8
  268. package/schemas/WebpackOptions.json +1988 -1988
  269. package/schemas/ajv.absolutePath.js +55 -55
  270. package/schemas/plugins/DllPlugin.json +32 -32
  271. package/schemas/plugins/DllReferencePlugin.json +99 -99
  272. package/schemas/plugins/HashedModuleIdsPlugin.json +24 -24
  273. package/schemas/plugins/LoaderOptionsPlugin.json +26 -26
  274. package/schemas/plugins/SourceMapDevToolPlugin.json +187 -187
  275. package/schemas/plugins/WatchIgnorePlugin.json +16 -16
  276. package/schemas/plugins/debug/ProfilingPlugin.json +12 -12
  277. package/schemas/plugins/optimize/AggressiveSplittingPlugin.json +22 -22
  278. package/schemas/plugins/optimize/LimitChunkCountPlugin.json +15 -15
  279. package/schemas/plugins/optimize/MinChunkSizePlugin.json +13 -13
@@ -1,70 +1,70 @@
1
- /*
2
- MIT License http://www.opensource.org/licenses/mit-license.php
3
- Author Tobias Koppers @sokra
4
- */
5
- "use strict";
6
-
7
- const GraphHelpers = require("../GraphHelpers");
8
-
9
- class EnsureChunkConditionsPlugin {
10
- apply(compiler) {
11
- compiler.hooks.compilation.tap(
12
- "EnsureChunkConditionsPlugin",
13
- compilation => {
14
- const handler = chunks => {
15
- let changed = false;
16
- for (const module of compilation.modules) {
17
- if (!module.chunkCondition) continue;
18
- const sourceChunks = new Set();
19
- const chunkGroups = new Set();
20
- for (const chunk of module.chunksIterable) {
21
- if (!module.chunkCondition(chunk)) {
22
- sourceChunks.add(chunk);
23
- for (const group of chunk.groupsIterable) {
24
- chunkGroups.add(group);
25
- }
26
- }
27
- }
28
- if (sourceChunks.size === 0) continue;
29
- const targetChunks = new Set();
30
- chunkGroupLoop: for (const chunkGroup of chunkGroups) {
31
- // Can module be placed in a chunk of this group?
32
- for (const chunk of chunkGroup.chunks) {
33
- if (module.chunkCondition(chunk)) {
34
- targetChunks.add(chunk);
35
- continue chunkGroupLoop;
36
- }
37
- }
38
- // We reached the entrypoint: fail
39
- if (chunkGroup.isInitial()) {
40
- throw new Error(
41
- "Cannot fullfil chunk condition of " + module.identifier()
42
- );
43
- }
44
- // Try placing in all parents
45
- for (const group of chunkGroup.parentsIterable) {
46
- chunkGroups.add(group);
47
- }
48
- }
49
- for (const sourceChunk of sourceChunks) {
50
- GraphHelpers.disconnectChunkAndModule(sourceChunk, module);
51
- }
52
- for (const targetChunk of targetChunks) {
53
- GraphHelpers.connectChunkAndModule(targetChunk, module);
54
- }
55
- }
56
- if (changed) return true;
57
- };
58
- compilation.hooks.optimizeChunksBasic.tap(
59
- "EnsureChunkConditionsPlugin",
60
- handler
61
- );
62
- compilation.hooks.optimizeExtractedChunksBasic.tap(
63
- "EnsureChunkConditionsPlugin",
64
- handler
65
- );
66
- }
67
- );
68
- }
69
- }
70
- module.exports = EnsureChunkConditionsPlugin;
1
+ /*
2
+ MIT License http://www.opensource.org/licenses/mit-license.php
3
+ Author Tobias Koppers @sokra
4
+ */
5
+ "use strict";
6
+
7
+ const GraphHelpers = require("../GraphHelpers");
8
+
9
+ class EnsureChunkConditionsPlugin {
10
+ apply(compiler) {
11
+ compiler.hooks.compilation.tap(
12
+ "EnsureChunkConditionsPlugin",
13
+ compilation => {
14
+ const handler = chunks => {
15
+ let changed = false;
16
+ for (const module of compilation.modules) {
17
+ if (!module.chunkCondition) continue;
18
+ const sourceChunks = new Set();
19
+ const chunkGroups = new Set();
20
+ for (const chunk of module.chunksIterable) {
21
+ if (!module.chunkCondition(chunk)) {
22
+ sourceChunks.add(chunk);
23
+ for (const group of chunk.groupsIterable) {
24
+ chunkGroups.add(group);
25
+ }
26
+ }
27
+ }
28
+ if (sourceChunks.size === 0) continue;
29
+ const targetChunks = new Set();
30
+ chunkGroupLoop: for (const chunkGroup of chunkGroups) {
31
+ // Can module be placed in a chunk of this group?
32
+ for (const chunk of chunkGroup.chunks) {
33
+ if (module.chunkCondition(chunk)) {
34
+ targetChunks.add(chunk);
35
+ continue chunkGroupLoop;
36
+ }
37
+ }
38
+ // We reached the entrypoint: fail
39
+ if (chunkGroup.isInitial()) {
40
+ throw new Error(
41
+ "Cannot fullfil chunk condition of " + module.identifier()
42
+ );
43
+ }
44
+ // Try placing in all parents
45
+ for (const group of chunkGroup.parentsIterable) {
46
+ chunkGroups.add(group);
47
+ }
48
+ }
49
+ for (const sourceChunk of sourceChunks) {
50
+ GraphHelpers.disconnectChunkAndModule(sourceChunk, module);
51
+ }
52
+ for (const targetChunk of targetChunks) {
53
+ GraphHelpers.connectChunkAndModule(targetChunk, module);
54
+ }
55
+ }
56
+ if (changed) return true;
57
+ };
58
+ compilation.hooks.optimizeChunksBasic.tap(
59
+ "EnsureChunkConditionsPlugin",
60
+ handler
61
+ );
62
+ compilation.hooks.optimizeExtractedChunksBasic.tap(
63
+ "EnsureChunkConditionsPlugin",
64
+ handler
65
+ );
66
+ }
67
+ );
68
+ }
69
+ }
70
+ module.exports = EnsureChunkConditionsPlugin;
@@ -1,99 +1,99 @@
1
- /*
2
- MIT License http://www.opensource.org/licenses/mit-license.php
3
- Author Tobias Koppers @sokra
4
- */
5
- "use strict";
6
-
7
- class FlagIncludedChunksPlugin {
8
- apply(compiler) {
9
- compiler.hooks.compilation.tap("FlagIncludedChunksPlugin", compilation => {
10
- compilation.hooks.optimizeChunkIds.tap(
11
- "FlagIncludedChunksPlugin",
12
- chunks => {
13
- // prepare two bit integers for each module
14
- // 2^31 is the max number represented as SMI in v8
15
- // we want the bits distributed this way:
16
- // the bit 2^31 is pretty rar and only one module should get it
17
- // so it has a probability of 1 / modulesCount
18
- // the first bit (2^0) is the easiest and every module could get it
19
- // if it doesn't get a better bit
20
- // from bit 2^n to 2^(n+1) there is a probability of p
21
- // so 1 / modulesCount == p^31
22
- // <=> p = sqrt31(1 / modulesCount)
23
- // so we use a modulo of 1 / sqrt31(1 / modulesCount)
24
- const moduleBits = new WeakMap();
25
- const modulesCount = compilation.modules.length;
26
-
27
- // precalculate the modulo values for each bit
28
- const modulo = 1 / Math.pow(1 / modulesCount, 1 / 31);
29
- const modulos = Array.from(
30
- { length: 31 },
31
- (x, i) => Math.pow(modulo, i) | 0
32
- );
33
-
34
- // iterate all modules to generate bit values
35
- let i = 0;
36
- for (const module of compilation.modules) {
37
- let bit = 30;
38
- while (i % modulos[bit] !== 0) {
39
- bit--;
40
- }
41
- moduleBits.set(module, 1 << bit);
42
- i++;
43
- }
44
-
45
- // interate all chunks to generate bitmaps
46
- const chunkModulesHash = new WeakMap();
47
- for (const chunk of chunks) {
48
- let hash = 0;
49
- for (const module of chunk.modulesIterable) {
50
- hash |= moduleBits.get(module);
51
- }
52
- chunkModulesHash.set(chunk, hash);
53
- }
54
-
55
- for (const chunkA of chunks) {
56
- const chunkAHash = chunkModulesHash.get(chunkA);
57
- const chunkAModulesCount = chunkA.getNumberOfModules();
58
- if (chunkAModulesCount === 0) continue;
59
- let bestModule = undefined;
60
- for (const module of chunkA.modulesIterable) {
61
- if (
62
- bestModule === undefined ||
63
- bestModule.getNumberOfChunks() > module.getNumberOfChunks()
64
- )
65
- bestModule = module;
66
- }
67
- loopB: for (const chunkB of bestModule.chunksIterable) {
68
- // as we iterate the same iterables twice
69
- // skip if we find ourselves
70
- if (chunkA === chunkB) continue;
71
-
72
- const chunkBModulesCount = chunkB.getNumberOfModules();
73
-
74
- // ids for empty chunks are not included
75
- if (chunkBModulesCount === 0) continue;
76
-
77
- // instead of swapping A and B just bail
78
- // as we loop twice the current A will be B and B then A
79
- if (chunkAModulesCount > chunkBModulesCount) continue;
80
-
81
- // is chunkA in chunkB?
82
-
83
- // we do a cheap check for the hash value
84
- const chunkBHash = chunkModulesHash.get(chunkB);
85
- if ((chunkBHash & chunkAHash) !== chunkAHash) continue;
86
-
87
- // compare all modules
88
- for (const m of chunkA.modulesIterable) {
89
- if (!chunkB.containsModule(m)) continue loopB;
90
- }
91
- chunkB.ids.push(chunkA.id);
92
- }
93
- }
94
- }
95
- );
96
- });
97
- }
98
- }
99
- module.exports = FlagIncludedChunksPlugin;
1
+ /*
2
+ MIT License http://www.opensource.org/licenses/mit-license.php
3
+ Author Tobias Koppers @sokra
4
+ */
5
+ "use strict";
6
+
7
+ class FlagIncludedChunksPlugin {
8
+ apply(compiler) {
9
+ compiler.hooks.compilation.tap("FlagIncludedChunksPlugin", compilation => {
10
+ compilation.hooks.optimizeChunkIds.tap(
11
+ "FlagIncludedChunksPlugin",
12
+ chunks => {
13
+ // prepare two bit integers for each module
14
+ // 2^31 is the max number represented as SMI in v8
15
+ // we want the bits distributed this way:
16
+ // the bit 2^31 is pretty rar and only one module should get it
17
+ // so it has a probability of 1 / modulesCount
18
+ // the first bit (2^0) is the easiest and every module could get it
19
+ // if it doesn't get a better bit
20
+ // from bit 2^n to 2^(n+1) there is a probability of p
21
+ // so 1 / modulesCount == p^31
22
+ // <=> p = sqrt31(1 / modulesCount)
23
+ // so we use a modulo of 1 / sqrt31(1 / modulesCount)
24
+ const moduleBits = new WeakMap();
25
+ const modulesCount = compilation.modules.length;
26
+
27
+ // precalculate the modulo values for each bit
28
+ const modulo = 1 / Math.pow(1 / modulesCount, 1 / 31);
29
+ const modulos = Array.from(
30
+ { length: 31 },
31
+ (x, i) => Math.pow(modulo, i) | 0
32
+ );
33
+
34
+ // iterate all modules to generate bit values
35
+ let i = 0;
36
+ for (const module of compilation.modules) {
37
+ let bit = 30;
38
+ while (i % modulos[bit] !== 0) {
39
+ bit--;
40
+ }
41
+ moduleBits.set(module, 1 << bit);
42
+ i++;
43
+ }
44
+
45
+ // interate all chunks to generate bitmaps
46
+ const chunkModulesHash = new WeakMap();
47
+ for (const chunk of chunks) {
48
+ let hash = 0;
49
+ for (const module of chunk.modulesIterable) {
50
+ hash |= moduleBits.get(module);
51
+ }
52
+ chunkModulesHash.set(chunk, hash);
53
+ }
54
+
55
+ for (const chunkA of chunks) {
56
+ const chunkAHash = chunkModulesHash.get(chunkA);
57
+ const chunkAModulesCount = chunkA.getNumberOfModules();
58
+ if (chunkAModulesCount === 0) continue;
59
+ let bestModule = undefined;
60
+ for (const module of chunkA.modulesIterable) {
61
+ if (
62
+ bestModule === undefined ||
63
+ bestModule.getNumberOfChunks() > module.getNumberOfChunks()
64
+ )
65
+ bestModule = module;
66
+ }
67
+ loopB: for (const chunkB of bestModule.chunksIterable) {
68
+ // as we iterate the same iterables twice
69
+ // skip if we find ourselves
70
+ if (chunkA === chunkB) continue;
71
+
72
+ const chunkBModulesCount = chunkB.getNumberOfModules();
73
+
74
+ // ids for empty chunks are not included
75
+ if (chunkBModulesCount === 0) continue;
76
+
77
+ // instead of swapping A and B just bail
78
+ // as we loop twice the current A will be B and B then A
79
+ if (chunkAModulesCount > chunkBModulesCount) continue;
80
+
81
+ // is chunkA in chunkB?
82
+
83
+ // we do a cheap check for the hash value
84
+ const chunkBHash = chunkModulesHash.get(chunkB);
85
+ if ((chunkBHash & chunkAHash) !== chunkAHash) continue;
86
+
87
+ // compare all modules
88
+ for (const m of chunkA.modulesIterable) {
89
+ if (!chunkB.containsModule(m)) continue loopB;
90
+ }
91
+ chunkB.ids.push(chunkA.id);
92
+ }
93
+ }
94
+ }
95
+ );
96
+ });
97
+ }
98
+ }
99
+ module.exports = FlagIncludedChunksPlugin;
@@ -1,66 +1,66 @@
1
- /*
2
- MIT License http://www.opensource.org/licenses/mit-license.php
3
- Author Tobias Koppers @sokra
4
- */
5
- "use strict";
6
-
7
- const validateOptions = require("schema-utils");
8
- const schema = require("../../schemas/plugins/optimize/LimitChunkCountPlugin.json");
9
-
10
- class LimitChunkCountPlugin {
11
- constructor(options) {
12
- validateOptions(schema, options || {}, "Limit Chunk Count Plugin");
13
- this.options = options || {};
14
- }
15
- apply(compiler) {
16
- const options = this.options;
17
- compiler.hooks.compilation.tap("LimitChunkCountPlugin", compilation => {
18
- compilation.hooks.optimizeChunksAdvanced.tap(
19
- "LimitChunkCountPlugin",
20
- chunks => {
21
- const maxChunks = options.maxChunks;
22
- if (!maxChunks) return;
23
- if (maxChunks < 1) return;
24
- if (chunks.length <= maxChunks) return;
25
-
26
- const sortedExtendedPairCombinations = chunks
27
- .reduce((combinations, a, idx) => {
28
- // create combination pairs
29
- for (let i = 0; i < idx; i++) {
30
- const b = chunks[i];
31
- combinations.push([b, a]);
32
- }
33
- return combinations;
34
- }, [])
35
- .map(pair => {
36
- // extend combination pairs with size and integrated size
37
- const a = pair[0].size(options);
38
- const b = pair[1].size(options);
39
- const ab = pair[0].integratedSize(pair[1], options);
40
- return [a + b - ab, ab, pair[0], pair[1], a, b];
41
- })
42
- .filter(extendedPair => {
43
- // filter pairs that do not have an integratedSize
44
- // meaning they can NOT be integrated!
45
- return extendedPair[1] !== false;
46
- })
47
- .sort((a, b) => {
48
- // sadly javascript does an inplace sort here
49
- // sort them by size
50
- const diff = b[0] - a[0];
51
- if (diff !== 0) return diff;
52
- return a[1] - b[1];
53
- });
54
-
55
- const pair = sortedExtendedPairCombinations[0];
56
-
57
- if (pair && pair[2].integrate(pair[3], "limit")) {
58
- chunks.splice(chunks.indexOf(pair[3]), 1);
59
- return true;
60
- }
61
- }
62
- );
63
- });
64
- }
65
- }
66
- module.exports = LimitChunkCountPlugin;
1
+ /*
2
+ MIT License http://www.opensource.org/licenses/mit-license.php
3
+ Author Tobias Koppers @sokra
4
+ */
5
+ "use strict";
6
+
7
+ const validateOptions = require("schema-utils");
8
+ const schema = require("../../schemas/plugins/optimize/LimitChunkCountPlugin.json");
9
+
10
+ class LimitChunkCountPlugin {
11
+ constructor(options) {
12
+ validateOptions(schema, options || {}, "Limit Chunk Count Plugin");
13
+ this.options = options || {};
14
+ }
15
+ apply(compiler) {
16
+ const options = this.options;
17
+ compiler.hooks.compilation.tap("LimitChunkCountPlugin", compilation => {
18
+ compilation.hooks.optimizeChunksAdvanced.tap(
19
+ "LimitChunkCountPlugin",
20
+ chunks => {
21
+ const maxChunks = options.maxChunks;
22
+ if (!maxChunks) return;
23
+ if (maxChunks < 1) return;
24
+ if (chunks.length <= maxChunks) return;
25
+
26
+ const sortedExtendedPairCombinations = chunks
27
+ .reduce((combinations, a, idx) => {
28
+ // create combination pairs
29
+ for (let i = 0; i < idx; i++) {
30
+ const b = chunks[i];
31
+ combinations.push([b, a]);
32
+ }
33
+ return combinations;
34
+ }, [])
35
+ .map(pair => {
36
+ // extend combination pairs with size and integrated size
37
+ const a = pair[0].size(options);
38
+ const b = pair[1].size(options);
39
+ const ab = pair[0].integratedSize(pair[1], options);
40
+ return [a + b - ab, ab, pair[0], pair[1], a, b];
41
+ })
42
+ .filter(extendedPair => {
43
+ // filter pairs that do not have an integratedSize
44
+ // meaning they can NOT be integrated!
45
+ return extendedPair[1] !== false;
46
+ })
47
+ .sort((a, b) => {
48
+ // sadly javascript does an inplace sort here
49
+ // sort them by size
50
+ const diff = b[0] - a[0];
51
+ if (diff !== 0) return diff;
52
+ return a[1] - b[1];
53
+ });
54
+
55
+ const pair = sortedExtendedPairCombinations[0];
56
+
57
+ if (pair && pair[2].integrate(pair[3], "limit")) {
58
+ chunks.splice(chunks.indexOf(pair[3]), 1);
59
+ return true;
60
+ }
61
+ }
62
+ );
63
+ });
64
+ }
65
+ }
66
+ module.exports = LimitChunkCountPlugin;
@@ -1,75 +1,78 @@
1
- /*
2
- MIT License http://www.opensource.org/licenses/mit-license.php
3
- Author Tobias Koppers @sokra
4
- */
5
- "use strict";
6
-
7
- class MergeDuplicateChunksPlugin {
8
- apply(compiler) {
9
- compiler.hooks.compilation.tap(
10
- "MergeDuplicateChunksPlugin",
11
- compilation => {
12
- compilation.hooks.optimizeChunksBasic.tap(
13
- "MergeDuplicateChunksPlugin",
14
- chunks => {
15
- // remember already tested chunks for performance
16
- const notDuplicates = new Set();
17
-
18
- // for each chunk
19
- for (const chunk of chunks) {
20
- // track a Set of all chunk that could be duplicates
21
- let possibleDuplicates;
22
- for (const module of chunk.modulesIterable) {
23
- if (possibleDuplicates === undefined) {
24
- // when possibleDuplicates is not yet set,
25
- // create a new Set from chunks of the current module
26
- // including only chunks with the same number of modules
27
- for (const dup of module.chunksIterable) {
28
- if (
29
- dup !== chunk &&
30
- chunk.getNumberOfModules() === dup.getNumberOfModules() &&
31
- !notDuplicates.has(dup)
32
- ) {
33
- // delay allocating the new Set until here, reduce memory pressure
34
- if (possibleDuplicates === undefined)
35
- possibleDuplicates = new Set();
36
- possibleDuplicates.add(dup);
37
- }
38
- }
39
- // when no chunk is possible we can break here
40
- if (possibleDuplicates === undefined) break;
41
- } else {
42
- // validate existing possible duplicates
43
- for (const dup of possibleDuplicates) {
44
- // remove possible duplicate when module is not contained
45
- if (!dup.containsModule(module))
46
- possibleDuplicates.delete(dup);
47
- }
48
- // when all chunks has been removed we can break here
49
- if (possibleDuplicates.size === 0) break;
50
- }
51
- }
52
-
53
- // when we found duplicates
54
- if (
55
- possibleDuplicates !== undefined &&
56
- possibleDuplicates.size > 0
57
- ) {
58
- for (const otherChunk of possibleDuplicates) {
59
- if (otherChunk.hasRuntime() !== chunk.hasRuntime()) continue;
60
- // merge them
61
- if (chunk.integrate(otherChunk, "duplicate"))
62
- chunks.splice(chunks.indexOf(otherChunk), 1);
63
- }
64
- }
65
-
66
- // don't check already processed chunks twice
67
- notDuplicates.add(chunk);
68
- }
69
- }
70
- );
71
- }
72
- );
73
- }
74
- }
75
- module.exports = MergeDuplicateChunksPlugin;
1
+ /*
2
+ MIT License http://www.opensource.org/licenses/mit-license.php
3
+ Author Tobias Koppers @sokra
4
+ */
5
+ "use strict";
6
+
7
+ class MergeDuplicateChunksPlugin {
8
+ apply(compiler) {
9
+ compiler.hooks.compilation.tap(
10
+ "MergeDuplicateChunksPlugin",
11
+ compilation => {
12
+ compilation.hooks.optimizeChunksBasic.tap(
13
+ "MergeDuplicateChunksPlugin",
14
+ chunks => {
15
+ // remember already tested chunks for performance
16
+ const notDuplicates = new Set();
17
+
18
+ // for each chunk
19
+ for (const chunk of chunks) {
20
+ // track a Set of all chunk that could be duplicates
21
+ let possibleDuplicates;
22
+ for (const module of chunk.modulesIterable) {
23
+ if (possibleDuplicates === undefined) {
24
+ // when possibleDuplicates is not yet set,
25
+ // create a new Set from chunks of the current module
26
+ // including only chunks with the same number of modules
27
+ for (const dup of module.chunksIterable) {
28
+ if (
29
+ dup !== chunk &&
30
+ chunk.getNumberOfModules() === dup.getNumberOfModules() &&
31
+ !notDuplicates.has(dup)
32
+ ) {
33
+ // delay allocating the new Set until here, reduce memory pressure
34
+ if (possibleDuplicates === undefined) {
35
+ possibleDuplicates = new Set();
36
+ }
37
+ possibleDuplicates.add(dup);
38
+ }
39
+ }
40
+ // when no chunk is possible we can break here
41
+ if (possibleDuplicates === undefined) break;
42
+ } else {
43
+ // validate existing possible duplicates
44
+ for (const dup of possibleDuplicates) {
45
+ // remove possible duplicate when module is not contained
46
+ if (!dup.containsModule(module)) {
47
+ possibleDuplicates.delete(dup);
48
+ }
49
+ }
50
+ // when all chunks has been removed we can break here
51
+ if (possibleDuplicates.size === 0) break;
52
+ }
53
+ }
54
+
55
+ // when we found duplicates
56
+ if (
57
+ possibleDuplicates !== undefined &&
58
+ possibleDuplicates.size > 0
59
+ ) {
60
+ for (const otherChunk of possibleDuplicates) {
61
+ if (otherChunk.hasRuntime() !== chunk.hasRuntime()) continue;
62
+ // merge them
63
+ if (chunk.integrate(otherChunk, "duplicate")) {
64
+ chunks.splice(chunks.indexOf(otherChunk), 1);
65
+ }
66
+ }
67
+ }
68
+
69
+ // don't check already processed chunks twice
70
+ notDuplicates.add(chunk);
71
+ }
72
+ }
73
+ );
74
+ }
75
+ );
76
+ }
77
+ }
78
+ module.exports = MergeDuplicateChunksPlugin;