webpack/lib/Dependency.js

200 lines
4.9 KiB
JavaScript
Raw Normal View History

2013-01-31 01:49:25 +08:00
/*
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
2018-07-30 23:08:51 +08:00
"use strict";
2018-04-04 15:17:10 +08:00
2018-05-15 18:20:17 +08:00
/** @typedef {import("webpack-sources").Source} Source */
/** @typedef {import("./ChunkGraph")} ChunkGraph */
2018-07-11 19:05:13 +08:00
/** @typedef {import("./DependencyTemplates")} DependencyTemplates */
2018-07-30 23:08:51 +08:00
/** @typedef {import("./Module")} Module */
2018-07-17 22:42:05 +08:00
/** @typedef {import("./ModuleGraph")} ModuleGraph */
2018-07-30 23:08:51 +08:00
/** @typedef {import("./RuntimeTemplate")} RuntimeTemplate */
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 */
2018-05-15 18:20:17 +08:00
/** @typedef {Object} SourcePosition
2018-06-22 02:58:54 +08:00
* @property {number} line
* @property {number=} column
2018-06-22 02:58:54 +08:00
*/
/** @typedef {Object} RealDependencyLocation
* @property {SourcePosition} start
* @property {SourcePosition=} end
* @property {number=} index
*/
/** @typedef {Object} SynteticDependencyLocation
* @property {string} name
* @property {number=} index
2018-05-15 18:20:17 +08:00
*/
/** @typedef {SynteticDependencyLocation|RealDependencyLocation} DependencyLocation */
/**
* @typedef {Object} ExportSpec
* @property {string} name the name of the export
2019-06-12 20:00:34 +08:00
* @property {boolean=} canMangle can the export be renamed (defaults to true)
* @property {Module=} from when reexported: from which module
* @property {string[] | null=} export when reexported: from which export
*/
2018-07-25 15:33:48 +08:00
/**
* @typedef {Object} ExportsSpec
* @property {(string | ExportSpec)[] | true | null} exports exported names, true for unknown exports or null for no exports
2018-07-25 15:33:48 +08:00
* @property {Module[]=} dependencies module on which the result depends on
*/
class Dependency {
constructor() {
// TODO check if this can be moved into ModuleDependency
/** @type {boolean} */
2017-08-08 15:28:34 +08:00
this.weak = false;
// TODO check if this can be moved into ModuleDependency
/** @type {boolean} */
this.optional = false;
/** @type {DependencyLocation} */
2018-03-28 13:27:05 +08:00
this.loc = undefined;
}
2013-01-31 01:49:25 +08:00
2018-07-25 15:33:48 +08:00
/**
* @returns {string} a display name for the type of dependency
*/
get type() {
return "unknown";
}
/**
* @returns {string | null} an identifier to merge equal requests
*/
getResourceIdentifier() {
return null;
}
2013-01-31 01:49:25 +08:00
2018-07-25 15:33:48 +08:00
/**
* @deprecated
2018-07-25 15:33:48 +08:00
* Returns the referenced module and export
* @param {ModuleGraph} moduleGraph module graph
* @returns {never} throws error
2018-07-25 15:33:48 +08:00
*/
getReference(moduleGraph) {
throw new Error(
"Dependency.getReference was removed in favor of Dependency.getReferencedExports, ModuleGraph.getModule and ModuleGraph.getConnection().active"
);
}
/**
* Returns list of exports referenced by this dependency
* @param {ModuleGraph} moduleGraph module graph
* @returns {string[][]} referenced exports
*/
getReferencedExports(moduleGraph) {
2019-10-30 14:57:55 +08:00
return Dependency.NS_OBJECT_REFERENCED;
}
/**
* @param {ModuleGraph} moduleGraph module graph
* @returns {function(): boolean} function to determine if the connection is active
*/
getCondition(moduleGraph) {
return null;
}
2018-07-25 15:33:48 +08:00
/**
* Returns the exported names
2018-07-17 22:34:36 +08:00
* @param {ModuleGraph} moduleGraph module graph
2018-07-25 15:33:48 +08:00
* @returns {ExportsSpec | undefined} export names
*/
2018-07-17 22:34:36 +08:00
getExports(moduleGraph) {
return undefined;
}
2018-07-25 15:33:48 +08:00
/**
* Returns warnings
* @param {ModuleGraph} moduleGraph module graph
2018-07-25 15:33:48 +08:00
* @returns {WebpackError[]} warnings
*/
getWarnings(moduleGraph) {
return null;
}
2018-07-25 15:33:48 +08:00
/**
* Returns errors
* @param {ModuleGraph} moduleGraph module graph
2018-07-25 15:33:48 +08:00
* @returns {WebpackError[]} errors
*/
getErrors(moduleGraph) {
return null;
}
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) {
const module = chunkGraph.moduleGraph.getModule(this);
if (module) {
hash.update(chunkGraph.getModuleId(module) + "");
}
}
2013-01-31 01:49:25 +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
*/
getNumberOfIdOccurrences() {
return 1;
}
2018-10-09 20:30:59 +08:00
serialize({ write }) {
write(this.weak);
write(this.optional);
write(this.loc);
}
deserialize({ read }) {
this.weak = read();
this.optional = read();
this.loc = read();
}
}
2019-10-30 14:57:55 +08:00
Dependency.NO_EXPORTS_REFERENCED = [];
Dependency.NS_OBJECT_REFERENCED = [[]];
Dependency.DEFAULT_EXPORT_REFERENCED = [["default"]];
Object.defineProperty(Dependency.prototype, "module", {
2018-07-25 15:33:48 +08:00
/**
* @deprecated
* @returns {never} throws
*/
get() {
throw new Error(
"module property was removed from Dependency (use compilation.moduleGraph.getModule(dependency) instead)"
);
},
/**
* @deprecated
* @returns {never} throws
2018-07-25 15:33:48 +08:00
*/
set() {
throw new Error(
"module property was removed from Dependency (use compilation.moduleGraph.updateModule(dependency, module) instead)"
);
}
});
Object.defineProperty(Dependency.prototype, "disconnect", {
get() {
throw new Error(
"disconnect was removed from Dependency (Dependency no longer carries graph specific information)"
);
}
});
2018-07-09 14:48:34 +08:00
module.exports = Dependency;