| 
									
										
										
										
											2018-09-05 20:22:10 +08:00
										 |  |  | /* | 
					
						
							|  |  |  | 	MIT License http://www.opensource.org/licenses/mit-license.php
 | 
					
						
							|  |  |  | 	Author Tobias Koppers @sokra | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | "use strict"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-17 21:30:17 +08:00
										 |  |  | const { compareChunksNatural } = require("../util/comparators"); | 
					
						
							| 
									
										
										
										
											2021-04-16 21:35:18 +08:00
										 |  |  | const createSchemaValidation = require("../util/create-schema-validation"); | 
					
						
							| 
									
										
										
										
											2018-12-07 19:26:35 +08:00
										 |  |  | const { assignAscendingChunkIds } = require("./IdHelpers"); | 
					
						
							| 
									
										
										
										
											2018-09-05 20:22:10 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-25 22:07:42 +08:00
										 |  |  | /** @typedef {import("../../declarations/plugins/ids/OccurrenceChunkIdsPlugin").OccurrenceChunkIdsPluginOptions} OccurrenceChunkIdsPluginOptions */ | 
					
						
							| 
									
										
										
										
											2018-09-05 20:22:10 +08:00
										 |  |  | /** @typedef {import("../Chunk")} Chunk */ | 
					
						
							|  |  |  | /** @typedef {import("../Compiler")} Compiler */ | 
					
						
							|  |  |  | /** @typedef {import("../Module")} Module */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-16 21:35:18 +08:00
										 |  |  | const validate = createSchemaValidation( | 
					
						
							|  |  |  | 	require("../../schemas/plugins/ids/OccurrenceChunkIdsPlugin.check.js"), | 
					
						
							|  |  |  | 	() => require("../../schemas/plugins/ids/OccurrenceChunkIdsPlugin.json"), | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		name: "Occurrence Order Chunk Ids Plugin", | 
					
						
							|  |  |  | 		baseDataPath: "options" | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-05 20:22:10 +08:00
										 |  |  | class OccurrenceChunkIdsPlugin { | 
					
						
							| 
									
										
										
										
											2018-09-25 22:07:42 +08:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * @param {OccurrenceChunkIdsPluginOptions=} options options object | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2018-09-05 20:22:10 +08:00
										 |  |  | 	constructor(options = {}) { | 
					
						
							| 
									
										
										
										
											2021-04-16 21:35:18 +08:00
										 |  |  | 		validate(options); | 
					
						
							| 
									
										
										
										
											2018-09-05 20:22:10 +08:00
										 |  |  | 		this.options = options; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2020-04-23 16:48:36 +08:00
										 |  |  | 	 * Apply the plugin | 
					
						
							|  |  |  | 	 * @param {Compiler} compiler the compiler instance | 
					
						
							| 
									
										
										
										
											2018-09-05 20:22:10 +08:00
										 |  |  | 	 * @returns {void} | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	apply(compiler) { | 
					
						
							|  |  |  | 		const prioritiseInitial = this.options.prioritiseInitial; | 
					
						
							|  |  |  | 		compiler.hooks.compilation.tap("OccurrenceChunkIdsPlugin", compilation => { | 
					
						
							|  |  |  | 			compilation.hooks.chunkIds.tap("OccurrenceChunkIdsPlugin", chunks => { | 
					
						
							|  |  |  | 				const chunkGraph = compilation.chunkGraph; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				/** @type {Map<Chunk, number>} */ | 
					
						
							|  |  |  | 				const occursInInitialChunksMap = new Map(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-17 21:30:17 +08:00
										 |  |  | 				const compareNatural = compareChunksNatural(chunkGraph); | 
					
						
							| 
									
										
										
										
											2018-09-05 20:22:10 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				for (const c of chunks) { | 
					
						
							|  |  |  | 					let occurs = 0; | 
					
						
							|  |  |  | 					for (const chunkGroup of c.groupsIterable) { | 
					
						
							|  |  |  | 						for (const parent of chunkGroup.parentsIterable) { | 
					
						
							|  |  |  | 							if (parent.isInitial()) occurs++; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					occursInInitialChunksMap.set(c, occurs); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				const chunksInOccurrenceOrder = Array.from(chunks).sort((a, b) => { | 
					
						
							|  |  |  | 					if (prioritiseInitial) { | 
					
						
							| 
									
										
										
										
											2023-05-27 01:21:35 +08:00
										 |  |  | 						const aEntryOccurs = | 
					
						
							|  |  |  | 							/** @type {number} */ | 
					
						
							|  |  |  | 							(occursInInitialChunksMap.get(a)); | 
					
						
							|  |  |  | 						const bEntryOccurs = | 
					
						
							|  |  |  | 							/** @type {number} */ | 
					
						
							|  |  |  | 							(occursInInitialChunksMap.get(b)); | 
					
						
							| 
									
										
										
										
											2018-09-05 20:22:10 +08:00
										 |  |  | 						if (aEntryOccurs > bEntryOccurs) return -1; | 
					
						
							|  |  |  | 						if (aEntryOccurs < bEntryOccurs) return 1; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					const aOccurs = a.getNumberOfGroups(); | 
					
						
							|  |  |  | 					const bOccurs = b.getNumberOfGroups(); | 
					
						
							|  |  |  | 					if (aOccurs > bOccurs) return -1; | 
					
						
							|  |  |  | 					if (aOccurs < bOccurs) return 1; | 
					
						
							|  |  |  | 					return compareNatural(a, b); | 
					
						
							|  |  |  | 				}); | 
					
						
							|  |  |  | 				assignAscendingChunkIds(chunksInOccurrenceOrder, compilation); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module.exports = OccurrenceChunkIdsPlugin; |