webpack/lib/Dependency.js

119 lines
2.5 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
*/
"use strict";
2018-04-04 15:17:10 +08:00
const DependencyReference = require("./dependencies/DependencyReference");
/** @typedef {import("./Module")} Module */
2018-05-15 18:20:17 +08:00
/** @typedef {import("webpack-sources").Source} Source */
/** @typedef {import("./RuntimeTemplate")} RuntimeTemplate */
2018-07-11 19:05:13 +08:00
/** @typedef {import("./DependencyTemplates")} DependencyTemplates */
2018-07-25 15:33:48 +08:00
/** @typedef {import("./util/createHash").Hash} Hash */
/** @typedef {import("./WebpackError")} WebpackError */
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 */
2018-07-25 15:33:48 +08:00
/**
* @typedef {Object} ExportsSpec
* @property {string[] | true | null} exports exported names, true for unknown exports or null for no exports
* @property {Module[]=} dependencies module on which the result depends on
*/
class Dependency {
constructor() {
/** @type {Module|null} */
this.module = null;
2018-06-08 19:21:06 +08:00
// TODO remove in webpack 5
/** @type {boolean} */
2017-08-08 15:28:34 +08:00
this.weak = false;
/** @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
/**
* Returns the referenced module and export
* @returns {DependencyReference} reference
*/
getReference() {
2018-02-25 09:00:20 +08:00
if (!this.module) return null;
2018-07-23 03:01:05 +08:00
return new DependencyReference(() => this.module, true, this.weak);
}
2018-07-25 15:33:48 +08:00
/**
* Returns the exported names
* @returns {ExportsSpec | undefined} export names
*/
getExports() {
return null;
}
2018-07-25 15:33:48 +08:00
/**
* Returns warnings
* @returns {WebpackError[]} warnings
*/
getWarnings() {
return null;
}
2018-07-25 15:33:48 +08:00
/**
* Returns errors
* @returns {WebpackError[]} errors
*/
getErrors() {
return null;
}
2018-07-25 15:33:48 +08:00
/**
* Update the hash
* @param {Hash} hash hash to be updated
* @returns {void}
*/
updateHash(hash) {
hash.update((this.module && this.module.id) + "");
}
2013-01-31 01:49:25 +08:00
2018-07-25 15:33:48 +08:00
/**
* Disconnect the dependency from the graph
* @returns {void}
*/
disconnect() {
this.module = null;
}
}
2018-07-09 14:48:34 +08:00
module.exports = Dependency;