aboutsummaryrefslogtreecommitdiff
path: root/node_modules/enhanced-resolve/lib/ConditionalPlugin.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/ConditionalPlugin.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/ConditionalPlugin.js')
-rw-r--r--node_modules/enhanced-resolve/lib/ConditionalPlugin.js59
1 files changed, 59 insertions, 0 deletions
diff --git a/node_modules/enhanced-resolve/lib/ConditionalPlugin.js b/node_modules/enhanced-resolve/lib/ConditionalPlugin.js
new file mode 100644
index 0000000..ebcec62
--- /dev/null
+++ b/node_modules/enhanced-resolve/lib/ConditionalPlugin.js
@@ -0,0 +1,59 @@
+/*
+ MIT License http://www.opensource.org/licenses/mit-license.php
+ Author Tobias Koppers @sokra
+*/
+
+"use strict";
+
+/** @typedef {import("./Resolver")} Resolver */
+/** @typedef {import("./Resolver").ResolveRequest} ResolveRequest */
+/** @typedef {import("./Resolver").ResolveStepHook} ResolveStepHook */
+
+module.exports = class ConditionalPlugin {
+ /**
+ * @param {string | ResolveStepHook} source source
+ * @param {Partial<ResolveRequest>} test compare object
+ * @param {string | null} message log message
+ * @param {boolean} allowAlternatives when false, do not continue with the current step when "test" matches
+ * @param {string | ResolveStepHook} target target
+ */
+ constructor(source, test, message, allowAlternatives, target) {
+ this.source = source;
+ this.test = test;
+ this.message = message;
+ this.allowAlternatives = allowAlternatives;
+ this.target = target;
+ }
+
+ /**
+ * @param {Resolver} resolver the resolver
+ * @returns {void}
+ */
+ apply(resolver) {
+ const target = resolver.ensureHook(this.target);
+ const { test, message, allowAlternatives } = this;
+ const keys = Object.keys(test);
+ resolver
+ .getHook(this.source)
+ .tapAsync("ConditionalPlugin", (request, resolveContext, callback) => {
+ for (const prop of keys) {
+ if (request[prop] !== test[prop]) return callback();
+ }
+ resolver.doResolve(
+ target,
+ request,
+ message,
+ resolveContext,
+ allowAlternatives
+ ? callback
+ : (err, result) => {
+ if (err) return callback(err);
+
+ // Don't allow other alternatives
+ if (result === undefined) return callback(null, null);
+ callback(null, result);
+ }
+ );
+ });
+ }
+};