| 
									
										
										
										
											2014-06-03 14:45:26 +08:00
										 |  |  | /* | 
					
						
							|  |  |  | 	MIT License http://www.opensource.org/licenses/mit-license.php
 | 
					
						
							|  |  |  | 	Author Tobias Koppers @sokra | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2018-07-30 23:08:51 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-29 15:10:25 +08:00
										 |  |  | "use strict"; | 
					
						
							| 
									
										
										
										
											2014-06-03 14:45:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | const util = require("util"); | 
					
						
							| 
									
										
										
										
											2020-12-27 05:32:57 +08:00
										 |  |  | const memoize = require("./util/memoize"); | 
					
						
							| 
									
										
										
										
											2014-06-03 14:45:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | /** @typedef {import("tapable").Tap} Tap */ | 
					
						
							| 
									
										
										
										
											2018-06-20 18:04:47 +08:00
										 |  |  | /** @typedef {import("webpack-sources").Source} Source */ | 
					
						
							| 
									
										
										
										
											2018-07-24 23:35:36 +08:00
										 |  |  | /** @typedef {import("./Chunk")} Chunk */ | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | /** @typedef {import("./Compilation")} Compilation */ | 
					
						
							| 
									
										
										
										
											2018-07-24 23:35:36 +08:00
										 |  |  | /** @typedef {import("./DependencyTemplates")} DependencyTemplates */ | 
					
						
							| 
									
										
										
										
											2018-06-20 18:04:47 +08:00
										 |  |  | /** @typedef {import("./Module")} Module */ | 
					
						
							| 
									
										
										
										
											2018-07-24 23:35:36 +08:00
										 |  |  | /** @typedef {import("./RuntimeTemplate")} RuntimeTemplate */ | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | /** @typedef {import("./javascript/JavascriptModulesPlugin").ChunkRenderContext} ChunkRenderContext */ | 
					
						
							| 
									
										
										
										
											2025-08-04 23:50:05 +08:00
										 |  |  | /** @typedef {import("./javascript/JavascriptModulesPlugin").ModuleRenderContext}  ModuleRenderContext */ | 
					
						
							| 
									
										
										
										
											2019-07-17 22:02:33 +08:00
										 |  |  | /** @typedef {import("./util/Hash")} Hash */ | 
					
						
							| 
									
										
										
										
											2018-07-24 23:35:36 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @template T | 
					
						
							|  |  |  |  * @typedef {import("tapable").IfSet<T>} IfSet | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-27 05:32:57 +08:00
										 |  |  | const getJavascriptModulesPlugin = memoize(() => | 
					
						
							| 
									
										
										
										
											2019-10-11 21:46:57 +08:00
										 |  |  | 	require("./javascript/JavascriptModulesPlugin") | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // TODO webpack 6: remove this class
 | 
					
						
							| 
									
										
										
										
											2019-10-09 19:32:20 +08:00
										 |  |  | class ModuleTemplate { | 
					
						
							| 
									
										
										
										
											2018-11-07 21:03:25 +08:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * @param {RuntimeTemplate} runtimeTemplate the runtime template | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 	 * @param {Compilation} compilation the compilation | 
					
						
							| 
									
										
										
										
											2018-11-07 21:03:25 +08:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 	constructor(runtimeTemplate, compilation) { | 
					
						
							| 
									
										
										
										
											2019-10-09 19:32:20 +08:00
										 |  |  | 		this._runtimeTemplate = runtimeTemplate; | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 		this.type = "javascript"; | 
					
						
							| 
									
										
										
										
											2018-07-30 20:25:40 +08:00
										 |  |  | 		this.hooks = Object.freeze({ | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 			content: { | 
					
						
							|  |  |  | 				tap: util.deprecate( | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 					/** | 
					
						
							|  |  |  | 					 * @template AdditionalOptions | 
					
						
							|  |  |  | 					 * @param {string | Tap & IfSet<AdditionalOptions>} options options | 
					
						
							| 
									
										
										
										
											2025-08-04 23:50:05 +08:00
										 |  |  | 					 * @param {(source: Source, module: Module, moduleRenderContext: ModuleRenderContext, dependencyTemplates: DependencyTemplates) => Source} fn fn | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 					 */ | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 					(options, fn) => { | 
					
						
							|  |  |  | 						getJavascriptModulesPlugin() | 
					
						
							|  |  |  | 							.getCompilationHooks(compilation) | 
					
						
							| 
									
										
										
										
											2019-10-09 19:32:20 +08:00
										 |  |  | 							.renderModuleContent.tap( | 
					
						
							|  |  |  | 								options, | 
					
						
							|  |  |  | 								(source, module, renderContext) => | 
					
						
							|  |  |  | 									fn( | 
					
						
							|  |  |  | 										source, | 
					
						
							|  |  |  | 										module, | 
					
						
							|  |  |  | 										renderContext, | 
					
						
							|  |  |  | 										renderContext.dependencyTemplates | 
					
						
							|  |  |  | 									) | 
					
						
							|  |  |  | 							); | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 					}, | 
					
						
							|  |  |  | 					"ModuleTemplate.hooks.content is deprecated (use JavascriptModulesPlugin.getCompilationHooks().renderModuleContent instead)", | 
					
						
							|  |  |  | 					"DEP_MODULE_TEMPLATE_CONTENT" | 
					
						
							|  |  |  | 				) | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			module: { | 
					
						
							|  |  |  | 				tap: util.deprecate( | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 					/** | 
					
						
							|  |  |  | 					 * @template AdditionalOptions | 
					
						
							|  |  |  | 					 * @param {string | Tap & IfSet<AdditionalOptions>} options options | 
					
						
							| 
									
										
										
										
											2025-08-04 23:50:05 +08:00
										 |  |  | 					 * @param {(source: Source, module: Module, moduleRenderContext: ModuleRenderContext, dependencyTemplates: DependencyTemplates) => Source} fn fn | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 					 */ | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 					(options, fn) => { | 
					
						
							|  |  |  | 						getJavascriptModulesPlugin() | 
					
						
							|  |  |  | 							.getCompilationHooks(compilation) | 
					
						
							| 
									
										
										
										
											2019-10-09 19:32:20 +08:00
										 |  |  | 							.renderModuleContent.tap( | 
					
						
							|  |  |  | 								options, | 
					
						
							|  |  |  | 								(source, module, renderContext) => | 
					
						
							|  |  |  | 									fn( | 
					
						
							|  |  |  | 										source, | 
					
						
							|  |  |  | 										module, | 
					
						
							|  |  |  | 										renderContext, | 
					
						
							|  |  |  | 										renderContext.dependencyTemplates | 
					
						
							|  |  |  | 									) | 
					
						
							|  |  |  | 							); | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 					}, | 
					
						
							|  |  |  | 					"ModuleTemplate.hooks.module is deprecated (use JavascriptModulesPlugin.getCompilationHooks().renderModuleContent instead)", | 
					
						
							|  |  |  | 					"DEP_MODULE_TEMPLATE_MODULE" | 
					
						
							|  |  |  | 				) | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			render: { | 
					
						
							|  |  |  | 				tap: util.deprecate( | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 					/** | 
					
						
							|  |  |  | 					 * @template AdditionalOptions | 
					
						
							|  |  |  | 					 * @param {string | Tap & IfSet<AdditionalOptions>} options options | 
					
						
							| 
									
										
										
										
											2025-03-12 09:56:14 +08:00
										 |  |  | 					 * @param {(source: Source, module: Module, chunkRenderContext: ChunkRenderContext, dependencyTemplates: DependencyTemplates) => Source} fn fn | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 					 */ | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 					(options, fn) => { | 
					
						
							|  |  |  | 						getJavascriptModulesPlugin() | 
					
						
							|  |  |  | 							.getCompilationHooks(compilation) | 
					
						
							| 
									
										
										
										
											2019-10-09 19:32:20 +08:00
										 |  |  | 							.renderModuleContainer.tap( | 
					
						
							|  |  |  | 								options, | 
					
						
							|  |  |  | 								(source, module, renderContext) => | 
					
						
							|  |  |  | 									fn( | 
					
						
							|  |  |  | 										source, | 
					
						
							|  |  |  | 										module, | 
					
						
							|  |  |  | 										renderContext, | 
					
						
							|  |  |  | 										renderContext.dependencyTemplates | 
					
						
							|  |  |  | 									) | 
					
						
							|  |  |  | 							); | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 					}, | 
					
						
							|  |  |  | 					"ModuleTemplate.hooks.render is deprecated (use JavascriptModulesPlugin.getCompilationHooks().renderModuleContainer instead)", | 
					
						
							|  |  |  | 					"DEP_MODULE_TEMPLATE_RENDER" | 
					
						
							|  |  |  | 				) | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			package: { | 
					
						
							|  |  |  | 				tap: util.deprecate( | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 					/** | 
					
						
							|  |  |  | 					 * @template AdditionalOptions | 
					
						
							|  |  |  | 					 * @param {string | Tap & IfSet<AdditionalOptions>} options options | 
					
						
							| 
									
										
										
										
											2025-03-12 09:56:14 +08:00
										 |  |  | 					 * @param {(source: Source, module: Module, chunkRenderContext: ChunkRenderContext, dependencyTemplates: DependencyTemplates) => Source} fn fn | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 					 */ | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 					(options, fn) => { | 
					
						
							|  |  |  | 						getJavascriptModulesPlugin() | 
					
						
							|  |  |  | 							.getCompilationHooks(compilation) | 
					
						
							| 
									
										
										
										
											2019-10-09 19:32:20 +08:00
										 |  |  | 							.renderModulePackage.tap( | 
					
						
							|  |  |  | 								options, | 
					
						
							|  |  |  | 								(source, module, renderContext) => | 
					
						
							|  |  |  | 									fn( | 
					
						
							|  |  |  | 										source, | 
					
						
							|  |  |  | 										module, | 
					
						
							|  |  |  | 										renderContext, | 
					
						
							|  |  |  | 										renderContext.dependencyTemplates | 
					
						
							|  |  |  | 									) | 
					
						
							|  |  |  | 							); | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 					}, | 
					
						
							|  |  |  | 					"ModuleTemplate.hooks.package is deprecated (use JavascriptModulesPlugin.getCompilationHooks().renderModulePackage instead)", | 
					
						
							|  |  |  | 					"DEP_MODULE_TEMPLATE_PACKAGE" | 
					
						
							|  |  |  | 				) | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			hash: { | 
					
						
							|  |  |  | 				tap: util.deprecate( | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 					/** | 
					
						
							|  |  |  | 					 * @template AdditionalOptions | 
					
						
							|  |  |  | 					 * @param {string | Tap & IfSet<AdditionalOptions>} options options | 
					
						
							| 
									
										
										
										
											2025-03-12 09:56:14 +08:00
										 |  |  | 					 * @param {(hash: Hash) => void} fn fn | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 					 */ | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 					(options, fn) => { | 
					
						
							|  |  |  | 						compilation.hooks.fullHash.tap(options, fn); | 
					
						
							|  |  |  | 					}, | 
					
						
							| 
									
										
										
										
											2020-10-12 20:39:43 +08:00
										 |  |  | 					"ModuleTemplate.hooks.hash is deprecated (use Compilation.hooks.fullHash instead)", | 
					
						
							| 
									
										
										
										
											2019-10-02 14:54:21 +08:00
										 |  |  | 					"DEP_MODULE_TEMPLATE_HASH" | 
					
						
							|  |  |  | 				) | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2018-07-30 20:25:40 +08:00
										 |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2016-12-29 15:10:25 +08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-10-09 19:32:20 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Object.defineProperty(ModuleTemplate.prototype, "runtimeTemplate", { | 
					
						
							|  |  |  | 	get: util.deprecate( | 
					
						
							|  |  |  | 		/** | 
					
						
							|  |  |  | 		 * @this {ModuleTemplate} | 
					
						
							| 
									
										
										
										
											2024-08-15 02:38:08 +08:00
										 |  |  | 		 * @returns {RuntimeTemplate} output options | 
					
						
							| 
									
										
										
										
											2019-10-09 19:32:20 +08:00
										 |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2025-07-03 17:06:45 +08:00
										 |  |  | 		function runtimeTemplate() { | 
					
						
							| 
									
										
										
										
											2019-10-09 19:32:20 +08:00
										 |  |  | 			return this._runtimeTemplate; | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		"ModuleTemplate.runtimeTemplate is deprecated (use Compilation.runtimeTemplate instead)", | 
					
						
							|  |  |  | 		"DEP_WEBPACK_CHUNK_TEMPLATE_OUTPUT_OPTIONS" | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module.exports = ModuleTemplate; |