webpack/lib/dependencies/HarmonyImportDependency.js

163 lines
4.8 KiB
JavaScript
Raw Normal View History

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-11 17:51:58 +08:00
"use strict";
2018-04-04 15:17:10 +08:00
const InitFragment = require("../InitFragment");
2018-07-30 23:08:51 +08:00
const Template = require("../Template");
2018-04-04 15:17:10 +08:00
const DependencyReference = require("./DependencyReference");
const ModuleDependency = require("./ModuleDependency");
2015-01-13 00:45:30 +08:00
/** @typedef {import("webpack-sources").ReplaceSource} ReplaceSource */
/** @typedef {import("webpack-sources").Source} Source */
/** @typedef {import("../ChunkGraph")} ChunkGraph */
2018-07-30 23:08:51 +08:00
/** @typedef {import("../Dependency")} Dependency */
/** @typedef {import("../DependencyTemplate").DependencyTemplateContext} DependencyTemplateContext */
/** @typedef {import("../Module")} Module */
2018-07-17 22:42:05 +08:00
/** @typedef {import("../ModuleGraph")} ModuleGraph */
/** @typedef {import("../RuntimeTemplate")} RuntimeTemplate */
2018-07-25 15:33:48 +08:00
/** @typedef {import("../util/createHash").Hash} Hash */
class HarmonyImportDependency extends ModuleDependency {
/**
*
* @param {string} request request string
* @param {number} sourceOrder source order
*/
constructor(request, sourceOrder) {
super(request);
this.sourceOrder = sourceOrder;
}
2018-07-25 15:33:48 +08:00
/**
* Returns the referenced module and export
* @param {ModuleGraph} moduleGraph module graph
2018-07-25 15:33:48 +08:00
* @returns {DependencyReference} reference
*/
getReference(moduleGraph) {
if (!moduleGraph.getModule(this)) return null;
return new DependencyReference(
() => moduleGraph.getModule(this),
false,
this.weak,
this.sourceOrder
);
}
/**
* @param {ModuleGraph} moduleGraph the module graph
* @returns {string} name of the variable for the import
*/
getImportVar(moduleGraph) {
const module = moduleGraph.getParentModule(this);
const meta = moduleGraph.getMeta(module);
let importVarMap = meta.importVarMap;
if (!importVarMap) meta.importVarMap = importVarMap = new Map();
let importVar = importVarMap.get(moduleGraph.getModule(this));
2018-02-25 09:00:20 +08:00
if (importVar) return importVar;
importVar = `${Template.toIdentifier(
`${this.userRequest}`
)}__WEBPACK_IMPORTED_MODULE_${importVarMap.size}__`;
importVarMap.set(moduleGraph.getModule(this), importVar);
return importVar;
}
/**
* @param {boolean} update create new variables or update existing one
* @param {DependencyTemplateContext} templateContext the template context
* @returns {string} name of the variable for the import
*/
getImportStatement(
update,
{ runtimeTemplate, module, moduleGraph, chunkGraph }
) {
return runtimeTemplate.importStatement({
update,
module: moduleGraph.getModule(this),
chunkGraph,
importVar: this.getImportVar(moduleGraph),
request: this.request,
originModule: module
});
}
2018-07-25 15:33:48 +08:00
/**
* Update the hash
* @param {Hash} hash hash to be updated
* @param {ChunkGraph} chunkGraph chunk graph
2018-07-25 15:33:48 +08:00
* @returns {void}
*/
updateHash(hash, chunkGraph) {
super.updateHash(hash, chunkGraph);
const importedModule = chunkGraph.moduleGraph.getModule(this);
2018-02-25 09:00:20 +08:00
hash.update(
(importedModule &&
(!importedModule.buildMeta || importedModule.buildMeta.exportsType)) +
""
);
}
}
module.exports = HarmonyImportDependency;
const importEmittedMap = new WeakMap();
HarmonyImportDependency.Template = class HarmonyImportDependencyTemplate extends ModuleDependency.Template {
/**
* @param {Dependency} dependency the dependency for which the template should be applied
* @param {ReplaceSource} source the current replace source which can be modified
* @param {DependencyTemplateContext} templateContext the context object
* @returns {void}
*/
apply(dependency, source, templateContext) {
2018-04-04 17:02:11 +08:00
// no-op
}
/**
*
* @param {Dependency} dep the dependency
* @param {Module} module the module
* @returns {boolean} true, when for this dependency and module a import init fragment was created
*/
static isImportEmitted(dep, module) {
const emittedModules = importEmittedMap.get(dep);
return emittedModules !== undefined && emittedModules.has(module);
}
2018-07-27 17:45:12 +08:00
/**
* @param {Dependency} dependency the dependency for which the template should be applied
* @param {DependencyTemplateContext} templateContext the template context
2018-07-27 17:45:12 +08:00
* @returns {InitFragment[]|null} the init fragments
*/
getInitFragments(dependency, templateContext) {
2018-07-27 17:45:12 +08:00
const dep = /** @type {HarmonyImportDependency} */ (dependency);
const { module, moduleGraph } = templateContext;
2018-07-27 17:45:12 +08:00
const referencedModule = moduleGraph.getModule(dep);
const moduleKey = referencedModule
? referencedModule.identifier()
: dep.request;
const key = `harmony import ${moduleKey}`;
if (module) {
let emittedModules = importEmittedMap.get(dep);
if (emittedModules === undefined) {
emittedModules = new WeakSet();
importEmittedMap.set(dep, emittedModules);
}
emittedModules.add(module);
}
return [
new InitFragment(
dep.getImportStatement(false, templateContext),
2018-07-30 16:15:18 +08:00
InitFragment.STAGE_HARMONY_IMPORTS,
dep.sourceOrder,
key
)
];
2015-01-13 00:45:30 +08:00
}
};