You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
	
	
		
			62 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
		
		
			
		
	
	
			62 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
| 
											9 months ago
										 | /* | ||
|  | 	MIT License http://www.opensource.org/licenses/mit-license.php
 | ||
|  | 	Author Tobias Koppers @sokra | ||
|  | */ | ||
|  | 
 | ||
|  | "use strict"; | ||
|  | 
 | ||
|  | const Generator = require("../Generator"); | ||
|  | 
 | ||
|  | /** @typedef {import("webpack-sources").Source} Source */ | ||
|  | /** @typedef {import("../Generator").GenerateContext} GenerateContext */ | ||
|  | /** @typedef {import("../NormalModule")} NormalModule */ | ||
|  | 
 | ||
|  | const TYPES = new Set(["webassembly"]); | ||
|  | 
 | ||
|  | /** | ||
|  |  * @typedef {Object} AsyncWebAssemblyGeneratorOptions | ||
|  |  * @property {boolean} [mangleImports] mangle imports | ||
|  |  */ | ||
|  | 
 | ||
|  | class AsyncWebAssemblyGenerator extends Generator { | ||
|  | 	/** | ||
|  | 	 * @param {AsyncWebAssemblyGeneratorOptions} options options | ||
|  | 	 */ | ||
|  | 	constructor(options) { | ||
|  | 		super(); | ||
|  | 		this.options = options; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * @param {NormalModule} module fresh module | ||
|  | 	 * @returns {Set<string>} available types (do not mutate) | ||
|  | 	 */ | ||
|  | 	getTypes(module) { | ||
|  | 		return TYPES; | ||
|  | 	} | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * @param {NormalModule} module the module | ||
|  | 	 * @param {string=} type source type | ||
|  | 	 * @returns {number} estimate size of the module | ||
|  | 	 */ | ||
|  | 	getSize(module, type) { | ||
|  | 		const originalSource = module.originalSource(); | ||
|  | 		if (!originalSource) { | ||
|  | 			return 0; | ||
|  | 		} | ||
|  | 		return originalSource.size(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	/** | ||
|  | 	 * @param {NormalModule} module module for which the code should be generated | ||
|  | 	 * @param {GenerateContext} generateContext context for generate | ||
|  | 	 * @returns {Source} generated code | ||
|  | 	 */ | ||
|  | 	generate(module, generateContext) { | ||
|  | 		return /** @type {Source} */ (module.originalSource()); | ||
|  | 	} | ||
|  | } | ||
|  | 
 | ||
|  | module.exports = AsyncWebAssemblyGenerator; |