diff options
author | Florian Dold <florian.dold@gmail.com> | 2018-09-20 02:56:13 +0200 |
---|---|---|
committer | Florian Dold <florian.dold@gmail.com> | 2018-09-20 02:56:13 +0200 |
commit | bbff7403fbf46f9ad92240ac213df8d30ef31b64 (patch) | |
tree | c58400ec5124da1c7d56b01aea83309f80a56c3b /node_modules/enhanced-resolve/lib/concord.js | |
parent | 003fb34971cf63466184351b4db5f7c67df4f444 (diff) |
update packages
Diffstat (limited to 'node_modules/enhanced-resolve/lib/concord.js')
-rw-r--r-- | node_modules/enhanced-resolve/lib/concord.js | 80 |
1 files changed, 43 insertions, 37 deletions
diff --git a/node_modules/enhanced-resolve/lib/concord.js b/node_modules/enhanced-resolve/lib/concord.js index c8db37940..8327095ed 100644 --- a/node_modules/enhanced-resolve/lib/concord.js +++ b/node_modules/enhanced-resolve/lib/concord.js @@ -2,11 +2,13 @@ MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
-var globToRegExp = require("./globToRegExp").globToRegExp;
+"use strict";
+
+const globToRegExp = require("./globToRegExp").globToRegExp;
function parseType(type) {
- var items = type.split("+");
- var t = items.shift();
+ const items = type.split("+");
+ const t = items.shift();
return {
type: t === "*" ? null : t,
features: items
@@ -17,7 +19,7 @@ function isTypeMatched(baseType, testedType) { if(typeof baseType === "string") baseType = parseType(baseType);
if(typeof testedType === "string") testedType = parseType(testedType);
if(testedType.type && testedType.type !== baseType.type) return false;
- return testedType.features.every(function(requiredFeature) {
+ return testedType.features.every(requiredFeature => {
return baseType.features.indexOf(requiredFeature) >= 0;
});
}
@@ -26,7 +28,7 @@ function isResourceTypeMatched(baseType, testedType) { baseType = baseType.split("/");
testedType = testedType.split("/");
if(baseType.length !== testedType.length) return false;
- for(var i = 0; i < baseType.length; i++) {
+ for(let i = 0; i < baseType.length; i++) {
if(!isTypeMatched(baseType[i], testedType[i]))
return false;
}
@@ -34,26 +36,26 @@ function isResourceTypeMatched(baseType, testedType) { }
function isResourceTypeSupported(context, type) {
- return context.supportedResourceTypes && context.supportedResourceTypes.some(function(supportedType) {
+ return context.supportedResourceTypes && context.supportedResourceTypes.some(supportedType => {
return isResourceTypeMatched(supportedType, type);
});
}
function isEnvironment(context, env) {
- return context.environments && context.environments.every(function(environment) {
+ return context.environments && context.environments.every(environment => {
return isTypeMatched(environment, env);
});
}
-var globCache = {};
+const globCache = {};
function getGlobRegExp(glob) {
- var regExp = globCache[glob] || (globCache[glob] = globToRegExp(glob));
+ const regExp = globCache[glob] || (globCache[glob] = globToRegExp(glob));
return regExp;
}
function matchGlob(glob, relativePath) {
- var regExp = getGlobRegExp(glob);
+ const regExp = getGlobRegExp(glob);
return regExp.exec(relativePath);
}
@@ -62,16 +64,16 @@ function isGlobMatched(glob, relativePath) { }
function isConditionMatched(context, condition) {
- var items = condition.split("|");
+ const items = condition.split("|");
return items.some(function testFn(item) {
item = item.trim();
- var inverted = /^!/.test(item);
+ const inverted = /^!/.test(item);
if(inverted) return !testFn(item.substr(1));
if(/^[a-z]+:/.test(item)) {
// match named condition
- var match = /^([a-z]+):\s*/.exec(item);
- var value = item.substr(match[0].length);
- var name = match[1];
+ const match = /^([a-z]+):\s*/.exec(item);
+ const value = item.substr(match[0].length);
+ const name = match[1];
switch(name) {
case "referrer":
return isGlobMatched(value, context.referrer);
@@ -90,10 +92,10 @@ function isConditionMatched(context, condition) { function isKeyMatched(context, key) {
while(true) { //eslint-disable-line
- var match = /^\[([^\]]+)\]\s*/.exec(key);
+ const match = /^\[([^\]]+)\]\s*/.exec(key);
if(!match) return key;
key = key.substr(match[0].length);
- var condition = match[1];
+ const condition = match[1];
if(!isConditionMatched(context, condition)) {
return false;
}
@@ -101,9 +103,9 @@ function isKeyMatched(context, key) { }
function getField(context, configuration, field) {
- var value;
- Object.keys(configuration).forEach(function(key) {
- var pureKey = isKeyMatched(context, key);
+ let value;
+ Object.keys(configuration).forEach(key => {
+ const pureKey = isKeyMatched(context, key);
if(pureKey === field) {
value = configuration[key];
}
@@ -120,23 +122,25 @@ function getExtensions(context, configuration) { }
function matchModule(context, configuration, request) {
- var modulesField = getField(context, configuration, "modules");
+ const modulesField = getField(context, configuration, "modules");
if(!modulesField) return request;
- var newRequest = request;
- var keys = Object.keys(modulesField);
- var iteration = 0;
- for(var i = 0; i < keys.length; i++) {
- var key = keys[i];
- var pureKey = isKeyMatched(context, key);
- var match = matchGlob(pureKey, newRequest);
+ let newRequest = request;
+ const keys = Object.keys(modulesField);
+ let iteration = 0;
+ let match;
+ let index;
+ for(let i = 0; i < keys.length; i++) {
+ const key = keys[i];
+ const pureKey = isKeyMatched(context, key);
+ match = matchGlob(pureKey, newRequest);
if(match) {
- var value = modulesField[key];
+ const value = modulesField[key];
if(typeof value !== "string") {
return value;
} else if(/^\(.+\)$/.test(pureKey)) {
newRequest = newRequest.replace(getGlobRegExp(pureKey), value);
} else {
- var index = 1;
+ index = 1;
newRequest = value.replace(/(\/?\*)?\*/g, replaceMatcher);
}
i = -1;
@@ -150,8 +154,10 @@ function matchModule(context, configuration, request) { function replaceMatcher(find) {
switch(find) {
case "/**":
- var m = match[index++];
- return m ? "/" + m : "";
+ {
+ const m = match[index++];
+ return m ? "/" + m : "";
+ }
case "**":
case "*":
return match[index++];
@@ -160,13 +166,13 @@ function matchModule(context, configuration, request) { }
function matchType(context, configuration, relativePath) {
- var typesField = getField(context, configuration, "types");
+ const typesField = getField(context, configuration, "types");
if(!typesField) return undefined;
- var type;
- Object.keys(typesField).forEach(function(key) {
- var pureKey = isKeyMatched(context, key);
+ let type;
+ Object.keys(typesField).forEach(key => {
+ const pureKey = isKeyMatched(context, key);
if(isGlobMatched(pureKey, relativePath)) {
- var value = typesField[key];
+ const value = typesField[key];
if(!type && /\/\*$/.test(value))
throw new Error("value ('" + value + "') of key '" + key + "' contains '*', but there is no previous value defined");
type = value.replace(/\/\*$/, "/" + type);
|