aboutsummaryrefslogtreecommitdiff
path: root/node_modules/enhanced-resolve/lib/JoinRequestPartPlugin.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/JoinRequestPartPlugin.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/JoinRequestPartPlugin.js')
-rw-r--r--node_modules/enhanced-resolve/lib/JoinRequestPartPlugin.js64
1 files changed, 64 insertions, 0 deletions
diff --git a/node_modules/enhanced-resolve/lib/JoinRequestPartPlugin.js b/node_modules/enhanced-resolve/lib/JoinRequestPartPlugin.js
new file mode 100644
index 0000000..356af1d
--- /dev/null
+++ b/node_modules/enhanced-resolve/lib/JoinRequestPartPlugin.js
@@ -0,0 +1,64 @@
+/*
+ MIT License http://www.opensource.org/licenses/mit-license.php
+ Author Tobias Koppers @sokra
+*/
+
+"use strict";
+
+/** @typedef {import("./Resolver")} Resolver */
+/** @typedef {import("./Resolver").ResolveStepHook} ResolveStepHook */
+
+const namespaceStartCharCode = "@".charCodeAt(0);
+
+module.exports = class JoinRequestPartPlugin {
+ /**
+ * @param {string | ResolveStepHook} source source
+ * @param {string | ResolveStepHook} target target
+ */
+ constructor(source, target) {
+ this.source = source;
+ this.target = target;
+ }
+
+ /**
+ * @param {Resolver} resolver the resolver
+ * @returns {void}
+ */
+ apply(resolver) {
+ const target = resolver.ensureHook(this.target);
+ resolver
+ .getHook(this.source)
+ .tapAsync(
+ "JoinRequestPartPlugin",
+ (request, resolveContext, callback) => {
+ const req = request.request || "";
+ let i = req.indexOf("/", 3);
+
+ if (i >= 0 && req.charCodeAt(2) === namespaceStartCharCode) {
+ i = req.indexOf("/", i + 1);
+ }
+
+ let moduleName, remainingRequest, fullySpecified;
+ if (i < 0) {
+ moduleName = req;
+ remainingRequest = ".";
+ fullySpecified = false;
+ } else {
+ moduleName = req.slice(0, i);
+ remainingRequest = "." + req.slice(i);
+ fullySpecified = request.fullySpecified;
+ }
+ const obj = {
+ ...request,
+ path: resolver.join(request.path, moduleName),
+ relativePath:
+ request.relativePath &&
+ resolver.join(request.relativePath, moduleName),
+ request: remainingRequest,
+ fullySpecified
+ };
+ resolver.doResolve(target, obj, null, resolveContext, callback);
+ }
+ );
+ }
+};