aboutsummaryrefslogtreecommitdiff
path: root/node_modules/enhanced-resolve/lib/AliasFieldPlugin.js
diff options
context:
space:
mode:
authorMinteck <nekostarfan@gmail.com>2021-08-24 14:41:48 +0200
committerMinteck <nekostarfan@gmail.com>2021-08-24 14:41:48 +0200
commitd25e11bee6ca5ca523884da132d18e1400e077b9 (patch)
tree8af39fde19f7ed640a60fb397c7edd647dff1c4c /node_modules/enhanced-resolve/lib/AliasFieldPlugin.js
downloadkartik-iridium-d25e11bee6ca5ca523884da132d18e1400e077b9.tar.gz
kartik-iridium-d25e11bee6ca5ca523884da132d18e1400e077b9.tar.bz2
kartik-iridium-d25e11bee6ca5ca523884da132d18e1400e077b9.zip
Initial commit
Diffstat (limited to 'node_modules/enhanced-resolve/lib/AliasFieldPlugin.js')
-rw-r--r--node_modules/enhanced-resolve/lib/AliasFieldPlugin.js92
1 files changed, 92 insertions, 0 deletions
diff --git a/node_modules/enhanced-resolve/lib/AliasFieldPlugin.js b/node_modules/enhanced-resolve/lib/AliasFieldPlugin.js
new file mode 100644
index 0000000..c387db0
--- /dev/null
+++ b/node_modules/enhanced-resolve/lib/AliasFieldPlugin.js
@@ -0,0 +1,92 @@
+/*
+ MIT License http://www.opensource.org/licenses/mit-license.php
+ Author Tobias Koppers @sokra
+*/
+
+"use strict";
+
+const DescriptionFileUtils = require("./DescriptionFileUtils");
+const getInnerRequest = require("./getInnerRequest");
+
+/** @typedef {import("./Resolver")} Resolver */
+/** @typedef {import("./Resolver").ResolveRequest} ResolveRequest */
+/** @typedef {import("./Resolver").ResolveStepHook} ResolveStepHook */
+
+module.exports = class AliasFieldPlugin {
+ /**
+ * @param {string | ResolveStepHook} source source
+ * @param {string | Array<string>} field field
+ * @param {string | ResolveStepHook} target target
+ */
+ constructor(source, field, target) {
+ this.source = source;
+ this.field = field;
+ this.target = target;
+ }
+
+ /**
+ * @param {Resolver} resolver the resolver
+ * @returns {void}
+ */
+ apply(resolver) {
+ const target = resolver.ensureHook(this.target);
+ resolver
+ .getHook(this.source)
+ .tapAsync("AliasFieldPlugin", (request, resolveContext, callback) => {
+ if (!request.descriptionFileData) return callback();
+ const innerRequest = getInnerRequest(resolver, request);
+ if (!innerRequest) return callback();
+ const fieldData = DescriptionFileUtils.getField(
+ request.descriptionFileData,
+ this.field
+ );
+ if (fieldData === null || typeof fieldData !== "object") {
+ if (resolveContext.log)
+ resolveContext.log(
+ "Field '" +
+ this.field +
+ "' doesn't contain a valid alias configuration"
+ );
+ return callback();
+ }
+ const data1 = fieldData[innerRequest];
+ const data2 = fieldData[innerRequest.replace(/^\.\//, "")];
+ const data = typeof data1 !== "undefined" ? data1 : data2;
+ if (data === innerRequest) return callback();
+ if (data === undefined) return callback();
+ if (data === false) {
+ /** @type {ResolveRequest} */
+ const ignoreObj = {
+ ...request,
+ path: false
+ };
+ return callback(null, ignoreObj);
+ }
+ const obj = {
+ ...request,
+ path: request.descriptionFileRoot,
+ request: data,
+ fullySpecified: false
+ };
+ resolver.doResolve(
+ target,
+ obj,
+ "aliased from description file " +
+ request.descriptionFilePath +
+ " with mapping '" +
+ innerRequest +
+ "' to '" +
+ data +
+ "'",
+ resolveContext,
+ (err, result) => {
+ if (err) return callback(err);
+
+ // Don't allow other aliasing or raw request
+ if (result === undefined) return callback(null, null);
+ callback(null, result);
+ }
+ );
+ });
+ }
+};