WXL
3 天以前 9bce51f651aad297ef9eb6df832bfdaf1de05d84
node_modules/webpack/lib/sharing/ConsumeSharedModule.js
@@ -8,7 +8,10 @@
const { RawSource } = require("webpack-sources");
const AsyncDependenciesBlock = require("../AsyncDependenciesBlock");
const Module = require("../Module");
const { CONSUME_SHARED_TYPES } = require("../ModuleSourceTypesConstants");
const {
   CONSUME_SHARED_TYPES,
   JAVASCRIPT_TYPES
} = require("../ModuleSourceTypeConstants");
const {
   WEBPACK_MODULE_TYPE_CONSUME_SHARED_MODULE
} = require("../ModuleTypeConstants");
@@ -16,6 +19,9 @@
const makeSerializable = require("../util/makeSerializable");
const { rangeToString, stringifyHoley } = require("../util/semver");
const ConsumeSharedFallbackDependency = require("./ConsumeSharedFallbackDependency");
/** @type {WeakMap<ModuleGraph, WeakMap<ConsumeSharedModule, Module | null>>} */
const fallbackModuleCache = new WeakMap();
/** @typedef {import("../config/defaults").WebpackOptionsNormalizedWithDefaults} WebpackOptions */
/** @typedef {import("../Compilation")} Compilation */
@@ -27,7 +33,10 @@
/** @typedef {import("../Module").LibIdent} LibIdent */
/** @typedef {import("../Module").NeedBuildCallback} NeedBuildCallback */
/** @typedef {import("../Module").NeedBuildContext} NeedBuildContext */
/** @typedef {import("../Module").Sources} Sources */
/** @typedef {import("../Module").SourceTypes} SourceTypes */
/** @typedef {import("../ModuleGraph")} ModuleGraph */
/** @typedef {import("../Module").ExportsType} ExportsType */
/** @typedef {import("../RequestShortener")} RequestShortener */
/** @typedef {import("../ResolverFactory").ResolverWithOptions} ResolverWithOptions */
/** @typedef {import("../serialization/ObjectMiddleware").ObjectDeserializerContext} ObjectDeserializerContext */
@@ -35,8 +44,10 @@
/** @typedef {import("../util/Hash")} Hash */
/** @typedef {import("../util/fs").InputFileSystem} InputFileSystem */
/** @typedef {import("../util/semver").SemVerRange} SemVerRange */
/** @typedef {import("../Module").BasicSourceTypes} BasicSourceTypes */
/**
 * Represents the consume shared module runtime component.
 * @typedef {object} ConsumeOptions
 * @property {string=} import fallback request
 * @property {string=} importResolved resolved fallback request
@@ -51,6 +62,7 @@
class ConsumeSharedModule extends Module {
   /**
    * Creates an instance of ConsumeSharedModule.
    * @param {string} context context
    * @param {ConsumeOptions} options consume options
    */
@@ -60,6 +72,7 @@
   }
   /**
    * Returns the unique identifier used to reference this module.
    * @returns {string} a unique identifier of the module
    */
   identifier() {
@@ -78,6 +91,7 @@
   }
   /**
    * Returns a human-readable identifier for this module.
    * @param {RequestShortener} requestShortener the request shortener
    * @returns {string} a user readable identifier of the module
    */
@@ -101,6 +115,7 @@
   }
   /**
    * Gets the library identifier.
    * @param {LibIdentOptions} options options
    * @returns {LibIdent | null} an identifier for library inclusion
    */
@@ -114,6 +129,7 @@
   }
   /**
    * 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}
@@ -123,6 +139,7 @@
   }
   /**
    * Builds the module using the provided compilation context.
    * @param {WebpackOptions} options webpack options
    * @param {Compilation} compilation the compilation
    * @param {ResolverWithOptions} resolver the resolver
@@ -147,6 +164,7 @@
   }
   /**
    * Returns the source types this module can generate.
    * @returns {SourceTypes} types available (do not mutate)
    */
   getSourceTypes() {
@@ -154,6 +172,73 @@
   }
   /**
    * Basic source types are high-level categories like javascript, css, webassembly, etc.
    * We only have built-in knowledge about the javascript basic type here; other basic types may be
    * added or changed over time by generators and do not need to be handled or detected here.
    *
    * Some modules, e.g. RemoteModule, may return non-basic source types like "remote" and "share-init"
    * from getSourceTypes(), but their generated output is still JavaScript, i.e. their basic type is JS.
    * @returns {BasicSourceTypes} types available (do not mutate)
    */
   getSourceBasicTypes() {
      return JAVASCRIPT_TYPES;
   }
   /**
    * Get fallback module.
    * @param {ModuleGraph} moduleGraph the module graph
    * @returns {Module | null} fallback module
    */
   _getFallbackModule(moduleGraph) {
      let moduleCache = fallbackModuleCache.get(moduleGraph);
      if (!moduleCache) {
         moduleCache = new WeakMap();
         fallbackModuleCache.set(moduleGraph, moduleCache);
      }
      const cached = moduleCache.get(this);
      if (cached !== undefined) {
         return cached;
      }
      /** @type {undefined | null | Module} */
      let fallbackModule = null;
      if (this.options.import) {
         if (this.options.eager) {
            const dep = this.dependencies[0];
            if (dep) {
               fallbackModule = moduleGraph.getModule(dep);
            }
         } else {
            const block = this.blocks[0];
            if (block && block.dependencies.length > 0) {
               fallbackModule = moduleGraph.getModule(block.dependencies[0]);
            }
         }
      }
      moduleCache.set(this, fallbackModule);
      return fallbackModule;
   }
   /**
    * Returns export type.
    * @param {ModuleGraph} moduleGraph the module graph
    * @param {boolean | undefined} strict the importing module is strict
    * @returns {ExportsType} export type
    * "namespace": Exports is already a namespace object. namespace = exports.
    * "dynamic": Check at runtime if __esModule is set. When set: namespace = { ...exports, default: exports }. When not set: namespace = { default: exports }.
    * "default-only": Provide a namespace object with only default export. namespace = { default: exports }
    * "default-with-named": Provide a namespace object with named and default export. namespace = { ...exports, default: exports }
    */
   getExportsType(moduleGraph, strict) {
      const fallbackModule = this._getFallbackModule(moduleGraph);
      if (!fallbackModule) return "dynamic";
      return fallbackModule.getExportsType(moduleGraph, strict);
   }
   /**
    * 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)
    */
@@ -162,6 +247,7 @@
   }
   /**
    * 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}
@@ -172,6 +258,7 @@
   }
   /**
    * Generates code and runtime requirements for this module.
    * @param {CodeGenerationContext} context context for code generation
    * @returns {CodeGenerationResult} result
    */
@@ -186,6 +273,7 @@
         singleton,
         eager
      } = this.options;
      /** @type {undefined | string} */
      let fallbackCode;
      if (request) {
         if (eager) {
@@ -219,6 +307,7 @@
         args.push(fallbackCode);
      }
      /** @type {string} */
      let fn;
      if (requiredVersion) {
@@ -232,6 +321,7 @@
      }
      const code = runtimeTemplate.returningFunction(`${fn}(${args.join(", ")})`);
      /** @type {Sources} */
      const sources = new Map();
      sources.set("consume-shared", new RawSource(code));
      return {
@@ -241,6 +331,7 @@
   }
   /**
    * Serializes this instance into the provided serializer context.
    * @param {ObjectSerializerContext} context context
    */
   serialize(context) {
@@ -250,6 +341,7 @@
   }
   /**
    * Restores this instance from the provided deserializer context.
    * @param {ObjectDeserializerContext} context context
    */
   deserialize(context) {