2015-01-13 00:45:30 +08:00
|
|
|
/*
|
|
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
|
|
Author Tobias Koppers @sokra
|
|
|
|
*/
|
2018-07-30 23:08:51 +08:00
|
|
|
|
2017-01-05 02:50:35 +08:00
|
|
|
"use strict";
|
2018-04-04 15:17:10 +08:00
|
|
|
|
2020-04-23 02:31:26 +08:00
|
|
|
const Dependency = require("../Dependency");
|
2021-01-19 20:31:55 +08:00
|
|
|
const { isDependencyUsedByExports } = require("../optimize/InnerGraph");
|
2018-10-09 20:30:59 +08:00
|
|
|
const makeSerializable = require("../util/makeSerializable");
|
2020-09-11 15:41:54 +08:00
|
|
|
const propertyAccess = require("../util/propertyAccess");
|
2017-08-08 15:32:43 +08:00
|
|
|
const HarmonyImportDependency = require("./HarmonyImportDependency");
|
2015-01-13 00:45:30 +08:00
|
|
|
|
2018-07-23 23:33:29 +08:00
|
|
|
/** @typedef {import("webpack-sources").ReplaceSource} ReplaceSource */
|
2018-08-28 17:50:33 +08:00
|
|
|
/** @typedef {import("../ChunkGraph")} ChunkGraph */
|
2018-07-30 23:08:51 +08:00
|
|
|
/** @typedef {import("../Dependency").ExportsSpec} ExportsSpec */
|
2020-05-28 02:34:55 +08:00
|
|
|
/** @typedef {import("../Dependency").ReferencedExport} ReferencedExport */
|
2020-07-28 00:09:48 +08:00
|
|
|
/** @typedef {import("../Dependency").UpdateHashContext} UpdateHashContext */
|
2018-07-18 01:38:42 +08:00
|
|
|
/** @typedef {import("../DependencyTemplate").DependencyTemplateContext} DependencyTemplateContext */
|
2018-07-17 22:42:05 +08:00
|
|
|
/** @typedef {import("../ModuleGraph")} ModuleGraph */
|
2020-07-28 00:09:48 +08:00
|
|
|
/** @typedef {import("../ModuleGraphConnection")} ModuleGraphConnection */
|
2020-10-05 22:57:31 +08:00
|
|
|
/** @typedef {import("../ModuleGraphConnection").ConnectionState} ConnectionState */
|
2018-07-25 15:33:48 +08:00
|
|
|
/** @typedef {import("../WebpackError")} WebpackError */
|
2019-07-17 22:02:33 +08:00
|
|
|
/** @typedef {import("../util/Hash")} Hash */
|
2020-07-28 00:09:48 +08:00
|
|
|
/** @typedef {import("../util/runtime").RuntimeSpec} RuntimeSpec */
|
2018-07-23 23:33:29 +08:00
|
|
|
|
2019-03-14 19:06:59 +08:00
|
|
|
const idsSymbol = Symbol("HarmonyImportSpecifierDependency.ids");
|
2018-08-16 20:07:34 +08:00
|
|
|
|
2017-08-08 15:32:43 +08:00
|
|
|
class HarmonyImportSpecifierDependency extends HarmonyImportDependency {
|
2019-03-14 19:06:59 +08:00
|
|
|
constructor(request, sourceOrder, ids, name, range, strictExportPresence) {
|
2018-09-27 19:40:58 +08:00
|
|
|
super(request, sourceOrder);
|
2019-03-14 19:06:59 +08:00
|
|
|
this.ids = ids;
|
2017-01-05 02:50:35 +08:00
|
|
|
this.name = name;
|
|
|
|
this.range = range;
|
2017-02-23 05:31:46 +08:00
|
|
|
this.strictExportPresence = strictExportPresence;
|
2017-05-21 15:13:33 +08:00
|
|
|
this.namespaceObjectAsContext = false;
|
|
|
|
this.call = undefined;
|
|
|
|
this.directImport = undefined;
|
2018-03-30 08:33:19 +08:00
|
|
|
this.shorthand = undefined;
|
2020-08-29 22:00:03 +08:00
|
|
|
this.asiSafe = undefined;
|
2019-09-03 20:11:50 +08:00
|
|
|
/** @type {Set<string> | boolean} */
|
|
|
|
this.usedByExports = undefined;
|
2017-01-05 02:50:35 +08:00
|
|
|
}
|
|
|
|
|
2019-03-14 19:06:59 +08:00
|
|
|
// TODO webpack 6 remove
|
|
|
|
get id() {
|
|
|
|
throw new Error("id was renamed to ids and type changed to string[]");
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO webpack 6 remove
|
|
|
|
getId() {
|
|
|
|
throw new Error("id was renamed to ids and type changed to string[]");
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO webpack 6 remove
|
|
|
|
setId() {
|
|
|
|
throw new Error("id was renamed to ids and type changed to string[]");
|
|
|
|
}
|
|
|
|
|
2017-01-05 02:50:35 +08:00
|
|
|
get type() {
|
|
|
|
return "harmony import specifier";
|
|
|
|
}
|
|
|
|
|
2018-07-24 23:35:36 +08:00
|
|
|
/**
|
|
|
|
* @param {ModuleGraph} moduleGraph the module graph
|
2019-03-14 19:06:59 +08:00
|
|
|
* @returns {string[]} the imported ids
|
2018-07-24 23:35:36 +08:00
|
|
|
*/
|
2019-03-14 19:06:59 +08:00
|
|
|
getIds(moduleGraph) {
|
|
|
|
return moduleGraph.getMeta(this)[idsSymbol] || this.ids;
|
2018-08-16 20:07:34 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {ModuleGraph} moduleGraph the module graph
|
2019-03-14 19:06:59 +08:00
|
|
|
* @param {string[]} ids the imported ids
|
2018-08-16 20:07:34 +08:00
|
|
|
* @returns {void}
|
|
|
|
*/
|
2019-03-14 19:06:59 +08:00
|
|
|
setIds(moduleGraph, ids) {
|
|
|
|
moduleGraph.getMeta(this)[idsSymbol] = ids;
|
2018-05-27 05:07:02 +08:00
|
|
|
}
|
|
|
|
|
2019-10-30 04:37:59 +08:00
|
|
|
/**
|
|
|
|
* @param {ModuleGraph} moduleGraph module graph
|
2020-10-05 22:57:31 +08:00
|
|
|
* @returns {function(ModuleGraphConnection, RuntimeSpec): ConnectionState} function to determine if the connection is active
|
2019-10-30 04:37:59 +08:00
|
|
|
*/
|
|
|
|
getCondition(moduleGraph) {
|
2020-07-28 00:09:48 +08:00
|
|
|
return (connection, runtime) =>
|
2021-01-19 20:31:55 +08:00
|
|
|
isDependencyUsedByExports(this, this.usedByExports, moduleGraph, runtime);
|
2019-10-30 04:37:59 +08:00
|
|
|
}
|
|
|
|
|
2020-11-29 00:30:32 +08:00
|
|
|
/**
|
|
|
|
* @param {ModuleGraph} moduleGraph the module graph
|
|
|
|
* @returns {ConnectionState} how this dependency connects the module to referencing modules
|
|
|
|
*/
|
|
|
|
getModuleEvaluationSideEffectsState(moduleGraph) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2019-09-06 20:49:05 +08:00
|
|
|
/**
|
2019-10-30 05:28:42 +08:00
|
|
|
* Returns list of exports referenced by this dependency
|
2019-09-06 20:49:05 +08:00
|
|
|
* @param {ModuleGraph} moduleGraph module graph
|
2020-07-28 00:09:48 +08:00
|
|
|
* @param {RuntimeSpec} runtime the runtime for which the module is analysed
|
2020-05-28 02:34:55 +08:00
|
|
|
* @returns {(string[] | ReferencedExport)[]} referenced exports
|
2019-09-06 20:49:05 +08:00
|
|
|
*/
|
2020-07-28 00:09:48 +08:00
|
|
|
getReferencedExports(moduleGraph, runtime) {
|
2020-04-23 02:31:26 +08:00
|
|
|
let ids = this.getIds(moduleGraph);
|
|
|
|
if (ids.length > 0 && ids[0] === "default") {
|
|
|
|
const selfModule = moduleGraph.getParentModule(this);
|
|
|
|
const importedModule = moduleGraph.getModule(this);
|
|
|
|
switch (
|
2020-08-18 03:32:47 +08:00
|
|
|
importedModule.getExportsType(
|
|
|
|
moduleGraph,
|
|
|
|
selfModule.buildMeta.strictHarmonyModule
|
|
|
|
)
|
2020-04-23 02:31:26 +08:00
|
|
|
) {
|
|
|
|
case "default-only":
|
|
|
|
case "default-with-named":
|
|
|
|
if (ids.length === 1) return Dependency.EXPORTS_OBJECT_REFERENCED;
|
|
|
|
ids = ids.slice(1);
|
|
|
|
break;
|
|
|
|
case "dynamic":
|
|
|
|
return Dependency.EXPORTS_OBJECT_REFERENCED;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this.namespaceObjectAsContext) {
|
|
|
|
if (ids.length === 1) return Dependency.EXPORTS_OBJECT_REFERENCED;
|
|
|
|
ids = ids.slice(0, -1);
|
|
|
|
}
|
|
|
|
|
|
|
|
return [ids];
|
2017-01-05 02:50:35 +08:00
|
|
|
}
|
|
|
|
|
2018-07-25 15:33:48 +08:00
|
|
|
/**
|
|
|
|
* Returns warnings
|
2018-07-24 23:35:36 +08:00
|
|
|
* @param {ModuleGraph} moduleGraph module graph
|
2018-07-25 15:33:48 +08:00
|
|
|
* @returns {WebpackError[]} warnings
|
|
|
|
*/
|
2018-07-24 23:35:36 +08:00
|
|
|
getWarnings(moduleGraph) {
|
2018-02-25 09:00:20 +08:00
|
|
|
if (
|
|
|
|
this.strictExportPresence ||
|
2018-08-07 20:20:53 +08:00
|
|
|
moduleGraph.getParentModule(this).buildMeta.strictHarmonyModule
|
2018-02-25 09:00:20 +08:00
|
|
|
) {
|
2019-08-07 18:00:50 +08:00
|
|
|
return null;
|
2017-02-23 05:31:46 +08:00
|
|
|
}
|
2018-07-24 23:35:36 +08:00
|
|
|
return this._getErrors(moduleGraph);
|
2017-02-23 05:31:46 +08:00
|
|
|
}
|
|
|
|
|
2018-07-25 15:33:48 +08:00
|
|
|
/**
|
|
|
|
* Returns errors
|
2018-07-24 23:35:36 +08:00
|
|
|
* @param {ModuleGraph} moduleGraph module graph
|
2018-07-25 15:33:48 +08:00
|
|
|
* @returns {WebpackError[]} errors
|
|
|
|
*/
|
2018-07-24 23:35:36 +08:00
|
|
|
getErrors(moduleGraph) {
|
2018-02-25 09:00:20 +08:00
|
|
|
if (
|
|
|
|
this.strictExportPresence ||
|
2018-08-07 20:20:53 +08:00
|
|
|
moduleGraph.getParentModule(this).buildMeta.strictHarmonyModule
|
2018-02-25 09:00:20 +08:00
|
|
|
) {
|
2018-07-24 23:35:36 +08:00
|
|
|
return this._getErrors(moduleGraph);
|
2017-02-23 05:31:46 +08:00
|
|
|
}
|
2019-08-07 18:00:50 +08:00
|
|
|
return null;
|
2017-02-23 05:31:46 +08:00
|
|
|
}
|
|
|
|
|
2018-12-30 16:03:42 +08:00
|
|
|
/**
|
|
|
|
* @param {ModuleGraph} moduleGraph module graph
|
|
|
|
* @returns {WebpackError[] | undefined} errors
|
|
|
|
*/
|
2018-07-24 23:35:36 +08:00
|
|
|
_getErrors(moduleGraph) {
|
2019-03-14 19:06:59 +08:00
|
|
|
const ids = this.getIds(moduleGraph);
|
2019-06-12 20:31:36 +08:00
|
|
|
return this.getLinkingErrors(
|
|
|
|
moduleGraph,
|
|
|
|
ids,
|
|
|
|
`(imported as '${this.name}')`
|
|
|
|
);
|
2017-01-05 02:50:35 +08:00
|
|
|
}
|
|
|
|
|
2018-07-20 22:13:22 +08:00
|
|
|
/**
|
|
|
|
* implement this method to allow the occurrence order plugin to count correctly
|
|
|
|
* @returns {number} count how often the id is used in this dependency
|
|
|
|
*/
|
2017-08-08 15:32:43 +08:00
|
|
|
getNumberOfIdOccurrences() {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-10-09 20:30:59 +08:00
|
|
|
serialize(context) {
|
|
|
|
const { write } = context;
|
2019-03-14 19:06:59 +08:00
|
|
|
write(this.ids);
|
2018-10-09 20:30:59 +08:00
|
|
|
write(this.name);
|
|
|
|
write(this.range);
|
|
|
|
write(this.strictExportPresence);
|
|
|
|
write(this.namespaceObjectAsContext);
|
|
|
|
write(this.call);
|
|
|
|
write(this.directImport);
|
|
|
|
write(this.shorthand);
|
2019-08-23 05:03:38 +08:00
|
|
|
write(this.asiSafe);
|
2019-09-03 20:11:50 +08:00
|
|
|
write(this.usedByExports);
|
2018-10-09 20:30:59 +08:00
|
|
|
super.serialize(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
deserialize(context) {
|
|
|
|
const { read } = context;
|
2019-03-14 19:06:59 +08:00
|
|
|
this.ids = read();
|
2018-10-09 20:30:59 +08:00
|
|
|
this.name = read();
|
|
|
|
this.range = read();
|
|
|
|
this.strictExportPresence = read();
|
|
|
|
this.namespaceObjectAsContext = read();
|
|
|
|
this.call = read();
|
|
|
|
this.directImport = read();
|
|
|
|
this.shorthand = read();
|
2019-08-23 05:03:38 +08:00
|
|
|
this.asiSafe = read();
|
2019-09-03 20:11:50 +08:00
|
|
|
this.usedByExports = read();
|
2018-10-09 20:30:59 +08:00
|
|
|
super.deserialize(context);
|
|
|
|
}
|
2017-01-05 02:50:35 +08:00
|
|
|
}
|
|
|
|
|
2018-10-09 20:30:59 +08:00
|
|
|
makeSerializable(
|
|
|
|
HarmonyImportSpecifierDependency,
|
|
|
|
"webpack/lib/dependencies/HarmonyImportSpecifierDependency"
|
|
|
|
);
|
|
|
|
|
2020-11-26 17:52:55 +08:00
|
|
|
HarmonyImportSpecifierDependency.Template = class HarmonyImportSpecifierDependencyTemplate extends (
|
|
|
|
HarmonyImportDependency.Template
|
|
|
|
) {
|
2018-07-23 23:33:29 +08:00
|
|
|
/**
|
|
|
|
* @param {Dependency} dependency the dependency for which the template should be applied
|
|
|
|
* @param {ReplaceSource} source the current replace source which can be modified
|
2018-07-18 01:38:42 +08:00
|
|
|
* @param {DependencyTemplateContext} templateContext the context object
|
2018-07-23 23:33:29 +08:00
|
|
|
* @returns {void}
|
|
|
|
*/
|
2018-07-18 01:38:42 +08:00
|
|
|
apply(dependency, source, templateContext) {
|
2018-07-23 23:33:29 +08:00
|
|
|
const dep = /** @type {HarmonyImportSpecifierDependency} */ (dependency);
|
2020-09-11 15:41:54 +08:00
|
|
|
const {
|
|
|
|
moduleGraph,
|
|
|
|
module,
|
|
|
|
runtime,
|
|
|
|
concatenationScope
|
|
|
|
} = templateContext;
|
2019-10-30 04:37:59 +08:00
|
|
|
const connection = moduleGraph.getConnection(dep);
|
2019-09-06 20:49:05 +08:00
|
|
|
// Skip rendering depending when dependency is conditional
|
2020-10-07 15:10:29 +08:00
|
|
|
if (connection && !connection.isTargetActive(runtime)) return;
|
2019-09-06 20:49:05 +08:00
|
|
|
|
2020-09-11 15:41:54 +08:00
|
|
|
const ids = dep.getIds(moduleGraph);
|
2019-10-30 04:37:59 +08:00
|
|
|
|
2020-09-11 15:41:54 +08:00
|
|
|
let exportExpr;
|
|
|
|
if (
|
2020-09-22 22:46:49 +08:00
|
|
|
connection &&
|
2020-09-11 15:41:54 +08:00
|
|
|
concatenationScope &&
|
|
|
|
concatenationScope.isModuleInScope(connection.module)
|
|
|
|
) {
|
|
|
|
if (ids.length === 0) {
|
|
|
|
exportExpr = concatenationScope.createModuleReference(
|
|
|
|
connection.module,
|
|
|
|
{
|
|
|
|
asiSafe: dep.asiSafe
|
|
|
|
}
|
|
|
|
);
|
|
|
|
} else if (dep.namespaceObjectAsContext && ids.length === 1) {
|
|
|
|
exportExpr =
|
|
|
|
concatenationScope.createModuleReference(connection.module, {
|
|
|
|
asiSafe: dep.asiSafe
|
|
|
|
}) + propertyAccess(ids);
|
|
|
|
} else {
|
|
|
|
exportExpr = concatenationScope.createModuleReference(
|
|
|
|
connection.module,
|
|
|
|
{
|
|
|
|
ids,
|
|
|
|
call: dep.call,
|
|
|
|
directImport: dep.directImport,
|
|
|
|
asiSafe: dep.asiSafe
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
super.apply(dependency, source, templateContext);
|
2019-11-05 04:05:17 +08:00
|
|
|
|
2020-09-11 15:41:54 +08:00
|
|
|
const {
|
|
|
|
runtimeTemplate,
|
|
|
|
initFragments,
|
|
|
|
runtimeRequirements
|
|
|
|
} = templateContext;
|
|
|
|
|
|
|
|
exportExpr = runtimeTemplate.exportFromImport({
|
|
|
|
moduleGraph,
|
|
|
|
module: moduleGraph.getModule(dep),
|
|
|
|
request: dep.request,
|
|
|
|
exportName: ids,
|
|
|
|
originModule: module,
|
|
|
|
asiSafe: dep.shorthand ? true : dep.asiSafe,
|
|
|
|
isCall: dep.call,
|
|
|
|
callContext: !dep.directImport,
|
|
|
|
defaultInterop: true,
|
|
|
|
importVar: dep.getImportVar(moduleGraph),
|
|
|
|
initFragments,
|
|
|
|
runtime,
|
|
|
|
runtimeRequirements
|
|
|
|
});
|
|
|
|
}
|
2019-08-29 21:28:19 +08:00
|
|
|
if (dep.shorthand) {
|
|
|
|
source.insert(dep.range[1], `: ${exportExpr}`);
|
|
|
|
} else {
|
|
|
|
source.replace(dep.range[0], dep.range[1] - 1, exportExpr);
|
|
|
|
}
|
2016-06-04 21:22:47 +08:00
|
|
|
}
|
2017-01-11 17:51:58 +08:00
|
|
|
};
|
2017-01-05 02:50:35 +08:00
|
|
|
|
|
|
|
module.exports = HarmonyImportSpecifierDependency;
|