| 
									
										
										
										
											2018-10-12 22:53:14 +08:00
										 |  |  | /* | 
					
						
							|  |  |  | 	MIT License http://www.opensource.org/licenses/mit-license.php
 | 
					
						
							|  |  |  | 	Author Florent Cailhol @ooflorent | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | "use strict"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const WebpackError = require("./WebpackError"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-03 04:05:46 +08:00
										 |  |  | /** @typedef {import("./Compiler")} Compiler */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-12 22:53:14 +08:00
										 |  |  | class WarnDeprecatedOptionPlugin { | 
					
						
							| 
									
										
										
										
											2018-11-03 04:05:46 +08:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Create an instance of the plugin | 
					
						
							|  |  |  | 	 * @param {string} option the target option | 
					
						
							|  |  |  | 	 * @param {string | number} value the deprecated option value | 
					
						
							|  |  |  | 	 * @param {string} suggestion the suggestion replacement | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2018-10-12 22:53:14 +08:00
										 |  |  | 	constructor(option, value, suggestion) { | 
					
						
							|  |  |  | 		this.option = option; | 
					
						
							|  |  |  | 		this.value = value; | 
					
						
							|  |  |  | 		this.suggestion = suggestion; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-03 04:05:46 +08:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Apply the plugin | 
					
						
							|  |  |  | 	 * @param {Compiler} compiler the compiler instance | 
					
						
							|  |  |  | 	 * @returns {void} | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2018-10-12 22:53:14 +08:00
										 |  |  | 	apply(compiler) { | 
					
						
							|  |  |  | 		compiler.hooks.thisCompilation.tap( | 
					
						
							|  |  |  | 			"WarnDeprecatedOptionPlugin", | 
					
						
							|  |  |  | 			compilation => { | 
					
						
							|  |  |  | 				compilation.warnings.push( | 
					
						
							|  |  |  | 					new DeprecatedOptionWarning(this.option, this.value, this.suggestion) | 
					
						
							|  |  |  | 				); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class DeprecatedOptionWarning extends WebpackError { | 
					
						
							| 
									
										
										
										
											2023-05-25 06:41:32 +08:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Create an instance deprecated option warning | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param {string} option the target option | 
					
						
							|  |  |  | 	 * @param {string | number} value the deprecated option value | 
					
						
							|  |  |  | 	 * @param {string} suggestion the suggestion replacement | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2018-10-12 22:53:14 +08:00
										 |  |  | 	constructor(option, value, suggestion) { | 
					
						
							|  |  |  | 		super(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		this.name = "DeprecatedOptionWarning"; | 
					
						
							|  |  |  | 		this.message = | 
					
						
							|  |  |  | 			"configuration\n" + | 
					
						
							|  |  |  | 			`The value '${value}' for option '${option}' is deprecated. ` + | 
					
						
							|  |  |  | 			`Use '${suggestion}' instead.`; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module.exports = WarnDeprecatedOptionPlugin; |