2018-07-30 16:33:33 +08:00
|
|
|
/*
|
|
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
|
|
Author Tobias Koppers @sokra
|
|
|
|
*/
|
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
const InitFragment = require("../InitFragment");
|
|
|
|
const ModuleDependency = require("./ModuleDependency");
|
|
|
|
|
|
|
|
/** @typedef {import("webpack-sources").ReplaceSource} ReplaceSource */
|
|
|
|
/** @typedef {import("../Dependency")} Dependency */
|
2018-07-31 03:39:17 +08:00
|
|
|
/** @typedef {import("../DependencyTemplate").TemplateContext} TemplateContext */
|
2018-07-30 16:33:33 +08:00
|
|
|
/** @typedef {import("../DependencyTemplates")} DependencyTemplates */
|
2018-07-17 22:42:05 +08:00
|
|
|
/** @typedef {import("../ModuleGraph")} ModuleGraph */
|
2018-07-30 16:33:33 +08:00
|
|
|
/** @typedef {import("../RuntimeTemplate")} RuntimeTemplate */
|
2018-07-30 19:23:59 +08:00
|
|
|
/** @typedef {import("../util/createHash").Hash} Hash */
|
2018-07-30 16:33:33 +08:00
|
|
|
|
|
|
|
class ModuleDecoratorDependency extends ModuleDependency {
|
2018-07-30 18:02:46 +08:00
|
|
|
constructor(request, originModule) {
|
2018-07-30 16:33:33 +08:00
|
|
|
super(request);
|
|
|
|
this.originModule = originModule;
|
|
|
|
}
|
2018-07-30 19:23:59 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the hash
|
|
|
|
* @param {Hash} hash hash to be updated
|
2018-07-17 22:42:05 +08:00
|
|
|
* @param {ModuleGraph} moduleGraph module graph
|
2018-07-30 19:23:59 +08:00
|
|
|
* @returns {void}
|
|
|
|
*/
|
2018-07-17 22:42:05 +08:00
|
|
|
updateHash(hash, moduleGraph) {
|
|
|
|
super.updateHash(hash, moduleGraph);
|
2018-07-30 19:23:59 +08:00
|
|
|
hash.update("module decorator");
|
|
|
|
}
|
2018-07-30 16:33:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
ModuleDecoratorDependency.Template = class ModuleDecoratorDependencyTemplate 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 {RuntimeTemplate} runtimeTemplate the runtime template
|
|
|
|
* @param {DependencyTemplates} dependencyTemplates the dependency templates
|
|
|
|
* @returns {void}
|
|
|
|
*/
|
|
|
|
apply(dependency, source, runtimeTemplate, dependencyTemplates) {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {Dependency} dependency the dependency for which the template should be applied
|
2018-07-31 03:39:17 +08:00
|
|
|
* @param {TemplateContext} templateContext the template context
|
2018-07-30 16:33:33 +08:00
|
|
|
* @returns {InitFragment[]|null} the init fragments
|
|
|
|
*/
|
2018-07-31 03:39:17 +08:00
|
|
|
getInitFragments(dependency, { runtimeTemplate, dependencyTemplates }) {
|
2018-07-30 16:33:33 +08:00
|
|
|
const dep = /** @type {ModuleDecoratorDependency} */ (dependency);
|
|
|
|
return [
|
|
|
|
new InitFragment(
|
|
|
|
`/* module decorator */ ${
|
|
|
|
dep.originModule.moduleArgument
|
|
|
|
} = ${runtimeTemplate.moduleExports({
|
|
|
|
module: dep.module,
|
|
|
|
request: dep.request
|
|
|
|
})}(${dep.originModule.moduleArgument});\n`,
|
|
|
|
InitFragment.STAGE_PROVIDES,
|
|
|
|
0,
|
|
|
|
`module decorator ${dep.originModule.id}`
|
|
|
|
)
|
|
|
|
];
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = ModuleDecoratorDependency;
|