| | |
| | | |
| | | const { OriginalSource, RawSource } = require("webpack-sources"); |
| | | const Module = require("./Module"); |
| | | const { JS_TYPES } = require("./ModuleSourceTypesConstants"); |
| | | const { |
| | | JAVASCRIPT_TYPE, |
| | | JAVASCRIPT_TYPES |
| | | } = require("./ModuleSourceTypeConstants"); |
| | | const { JAVASCRIPT_MODULE_TYPE_DYNAMIC } = require("./ModuleTypeConstants"); |
| | | const RuntimeGlobals = require("./RuntimeGlobals"); |
| | | const DelegatedSourceDependency = require("./dependencies/DelegatedSourceDependency"); |
| | |
| | | /** @typedef {import("./Module").LibIdent} LibIdent */ |
| | | /** @typedef {import("./Module").NeedBuildCallback} NeedBuildCallback */ |
| | | /** @typedef {import("./Module").NeedBuildContext} NeedBuildContext */ |
| | | /** @typedef {import("./Module").Sources} Sources */ |
| | | /** @typedef {import("./Module").RuntimeRequirements} RuntimeRequirements */ |
| | | /** @typedef {import("./RequestShortener")} RequestShortener */ |
| | | /** @typedef {import("./ResolverFactory").ResolverWithOptions} ResolverWithOptions */ |
| | | /** @typedef {import("./serialization/ObjectMiddleware").ObjectDeserializerContext} ObjectDeserializerContext */ |
| | |
| | | /** @typedef {NonNullable<DllReferencePluginOptions["type"]>} DelegatedModuleType */ |
| | | |
| | | /** |
| | | * Defines the delegated module data type used by this module. |
| | | * @typedef {object} DelegatedModuleData |
| | | * @property {BuildMeta=} buildMeta build meta |
| | | * @property {Exports=} exports exports |
| | |
| | | |
| | | class DelegatedModule extends Module { |
| | | /** |
| | | * Creates an instance of DelegatedModule. |
| | | * @param {DelegatedModuleSourceRequest} sourceRequest source request |
| | | * @param {DelegatedModuleData} data data |
| | | * @param {DelegatedModuleType} type type |
| | |
| | | this.delegateData = data; |
| | | |
| | | // Build info |
| | | /** @type {undefined | DelegatedSourceDependency} */ |
| | | this.delegatedSourceDependency = undefined; |
| | | } |
| | | |
| | | /** |
| | | * Returns the source types this module can generate. |
| | | * @returns {SourceTypes} types available (do not mutate) |
| | | */ |
| | | getSourceTypes() { |
| | | return JS_TYPES; |
| | | return JAVASCRIPT_TYPES; |
| | | } |
| | | |
| | | /** |
| | | * Gets the library identifier. |
| | | * @param {LibIdentOptions} options options |
| | | * @returns {LibIdent | null} an identifier for library inclusion |
| | | */ |
| | |
| | | } |
| | | |
| | | /** |
| | | * Returns the unique identifier used to reference this module. |
| | | * @returns {string} a unique identifier of the module |
| | | */ |
| | | identifier() { |
| | |
| | | } |
| | | |
| | | /** |
| | | * Returns a human-readable identifier for this module. |
| | | * @param {RequestShortener} requestShortener the request shortener |
| | | * @returns {string} a user readable identifier of the module |
| | | */ |
| | |
| | | } |
| | | |
| | | /** |
| | | * Checks whether the module needs to be rebuilt for the current build state. |
| | | * @param {NeedBuildContext} context context info |
| | | * @param {NeedBuildCallback} callback callback function, returns true, if the module needs a rebuild |
| | | * @returns {void} |
| | |
| | | } |
| | | |
| | | /** |
| | | * Builds the module using the provided compilation context. |
| | | * @param {WebpackOptions} options webpack options |
| | | * @param {Compilation} compilation the compilation |
| | | * @param {ResolverWithOptions} resolver the resolver |
| | |
| | | } |
| | | |
| | | /** |
| | | * Generates code and runtime requirements for this module. |
| | | * @param {CodeGenerationContext} context context for code generation |
| | | * @returns {CodeGenerationResult} result |
| | | */ |
| | | codeGeneration({ runtimeTemplate, moduleGraph, chunkGraph }) { |
| | | const dep = /** @type {DelegatedSourceDependency} */ (this.dependencies[0]); |
| | | const sourceModule = moduleGraph.getModule(dep); |
| | | /** @type {string} */ |
| | | let str; |
| | | |
| | | if (!sourceModule) { |
| | |
| | | module: sourceModule, |
| | | chunkGraph, |
| | | request: dep.request, |
| | | /** @type {RuntimeRequirements} */ |
| | | runtimeRequirements: new Set() |
| | | })})`; |
| | | |
| | |
| | | str += ";"; |
| | | } |
| | | |
| | | /** @type {Sources} */ |
| | | const sources = new Map(); |
| | | if (this.useSourceMap || this.useSimpleSourceMap) { |
| | | sources.set("javascript", new OriginalSource(str, this.identifier())); |
| | | sources.set(JAVASCRIPT_TYPE, new OriginalSource(str, this.identifier())); |
| | | } else { |
| | | sources.set("javascript", new RawSource(str)); |
| | | sources.set(JAVASCRIPT_TYPE, new RawSource(str)); |
| | | } |
| | | |
| | | return { |
| | |
| | | } |
| | | |
| | | /** |
| | | * Returns the estimated size for the requested source type. |
| | | * @param {string=} type the source type for which the size should be estimated |
| | | * @returns {number} the estimated size of the module (must be non-zero) |
| | | */ |
| | |
| | | } |
| | | |
| | | /** |
| | | * Updates the hash with the data contributed by this instance. |
| | | * @param {Hash} hash the hash used to track dependencies |
| | | * @param {UpdateHashContext} context context |
| | | * @returns {void} |
| | |
| | | } |
| | | |
| | | /** |
| | | * Serializes this instance into the provided serializer context. |
| | | * @param {ObjectSerializerContext} context context |
| | | */ |
| | | serialize(context) { |
| | |
| | | } |
| | | |
| | | /** |
| | | * Restores this instance from the provided deserializer context. |
| | | * @param {ObjectDeserializerContext} context context\ |
| | | * @returns {DelegatedModule} DelegatedModule |
| | | */ |