diff --git a/tools/node_modules/eslint/README.md b/tools/node_modules/eslint/README.md
index cc969aeadda23e..2a77ed9274695d 100644
--- a/tools/node_modules/eslint/README.md
+++ b/tools/node_modules/eslint/README.md
@@ -250,7 +250,7 @@ The following companies, organizations, and individuals support ESLint's ongoing
Platinum Sponsors
Gold Sponsors
-
Silver Sponsors
+
Silver Sponsors
Bronze Sponsors
diff --git a/tools/node_modules/eslint/bin/eslint.js b/tools/node_modules/eslint/bin/eslint.js
index 75b413148695e5..86291b0f52750a 100755
--- a/tools/node_modules/eslint/bin/eslint.js
+++ b/tools/node_modules/eslint/bin/eslint.js
@@ -14,7 +14,7 @@ require("v8-compile-cache");
// must do this initialization *before* other requires in order to work
if (process.argv.includes("--debug")) {
- require("debug").enable("eslint:*,-eslint:code-path");
+ require("debug").enable("eslint:*,-eslint:code-path,eslintrc:*");
}
//------------------------------------------------------------------------------
diff --git a/tools/node_modules/eslint/lib/rules/index.js b/tools/node_modules/eslint/lib/rules/index.js
index 3cf26e51bc8392..84f3480df2686a 100644
--- a/tools/node_modules/eslint/lib/rules/index.js
+++ b/tools/node_modules/eslint/lib/rules/index.js
@@ -169,6 +169,7 @@ module.exports = new LazyLoadingRuleMap(Object.entries({
"no-new-require": () => require("./no-new-require"),
"no-new-symbol": () => require("./no-new-symbol"),
"no-new-wrappers": () => require("./no-new-wrappers"),
+ "no-nonoctal-decimal-escape": () => require("./no-nonoctal-decimal-escape"),
"no-obj-calls": () => require("./no-obj-calls"),
"no-octal": () => require("./no-octal"),
"no-octal-escape": () => require("./no-octal-escape"),
diff --git a/tools/node_modules/eslint/lib/rules/no-irregular-whitespace.js b/tools/node_modules/eslint/lib/rules/no-irregular-whitespace.js
index 0bf69b128e6bf8..15711c6157a9a4 100644
--- a/tools/node_modules/eslint/lib/rules/no-irregular-whitespace.js
+++ b/tools/node_modules/eslint/lib/rules/no-irregular-whitespace.js
@@ -82,7 +82,7 @@ module.exports = {
const commentNodes = sourceCode.getAllComments();
/**
- * Removes errors that occur inside a string node
+ * Removes errors that occur inside the given node
* @param {ASTNode} node to check for matching errors.
* @returns {void}
* @private
@@ -91,14 +91,12 @@ module.exports = {
const locStart = node.loc.start;
const locEnd = node.loc.end;
- errors = errors.filter(({ loc: { start: errorLoc } }) => {
- if (errorLoc.line >= locStart.line && errorLoc.line <= locEnd.line) {
- if (errorLoc.column >= locStart.column && (errorLoc.column <= locEnd.column || errorLoc.line < locEnd.line)) {
- return false;
- }
- }
- return true;
- });
+ errors = errors.filter(({ loc: { start: errorLocStart } }) => (
+ errorLocStart.line < locStart.line ||
+ errorLocStart.line === locStart.line && errorLocStart.column < locStart.column ||
+ errorLocStart.line === locEnd.line && errorLocStart.column >= locEnd.column ||
+ errorLocStart.line > locEnd.line
+ ));
}
/**
diff --git a/tools/node_modules/eslint/lib/rules/no-nonoctal-decimal-escape.js b/tools/node_modules/eslint/lib/rules/no-nonoctal-decimal-escape.js
new file mode 100644
index 00000000000000..a4b46d9591f5ed
--- /dev/null
+++ b/tools/node_modules/eslint/lib/rules/no-nonoctal-decimal-escape.js
@@ -0,0 +1,147 @@
+/**
+ * @fileoverview Rule to disallow `\8` and `\9` escape sequences in string literals.
+ * @author Milos Djermanovic
+ */
+
+"use strict";
+
+//------------------------------------------------------------------------------
+// Helpers
+//------------------------------------------------------------------------------
+
+const QUICK_TEST_REGEX = /\\[89]/u;
+
+/**
+ * Returns unicode escape sequence that represents the given character.
+ * @param {string} character A single code unit.
+ * @returns {string} "\uXXXX" sequence.
+ */
+function getUnicodeEscape(character) {
+ return `\\u${character.charCodeAt(0).toString(16).padStart(4, "0")}`;
+}
+
+//------------------------------------------------------------------------------
+// Rule Definition
+//------------------------------------------------------------------------------
+
+module.exports = {
+ meta: {
+ type: "suggestion",
+
+ docs: {
+ description: "disallow `\\8` and `\\9` escape sequences in string literals",
+ category: "Best Practices",
+ recommended: false,
+ url: "https://eslint.org/docs/rules/no-nonoctal-decimal-escape",
+ suggestion: true
+ },
+
+ schema: [],
+
+ messages: {
+ decimalEscape: "Don't use '{{decimalEscape}}' escape sequence.",
+
+ // suggestions
+ refactor: "Replace '{{original}}' with '{{replacement}}'. This maintains the current functionality.",
+ escapeBackslash: "Replace '{{original}}' with '{{replacement}}' to include the actual backslash character."
+ }
+ },
+
+ create(context) {
+ const sourceCode = context.getSourceCode();
+
+ /**
+ * Creates a new Suggestion object.
+ * @param {string} messageId "refactor" or "escapeBackslash".
+ * @param {int[]} range The range to replace.
+ * @param {string} replacement New text for the range.
+ * @returns {Object} Suggestion
+ */
+ function createSuggestion(messageId, range, replacement) {
+ return {
+ messageId,
+ data: {
+ original: sourceCode.getText().slice(...range),
+ replacement
+ },
+ fix(fixer) {
+ return fixer.replaceTextRange(range, replacement);
+ }
+ };
+ }
+
+ return {
+ Literal(node) {
+ if (typeof node.value !== "string") {
+ return;
+ }
+
+ if (!QUICK_TEST_REGEX.test(node.raw)) {
+ return;
+ }
+
+ const regex = /(?:[^\\]|(?\\.))*?(?\\[89])/suy;
+ let match;
+
+ while ((match = regex.exec(node.raw))) {
+ const { previousEscape, decimalEscape } = match.groups;
+ const decimalEscapeRangeEnd = node.range[0] + match.index + match[0].length;
+ const decimalEscapeRangeStart = decimalEscapeRangeEnd - decimalEscape.length;
+ const decimalEscapeRange = [decimalEscapeRangeStart, decimalEscapeRangeEnd];
+ const suggest = [];
+
+ // When `regex` is matched, `previousEscape` can only capture characters adjacent to `decimalEscape`
+ if (previousEscape === "\\0") {
+
+ /*
+ * Now we have a NULL escape "\0" immediately followed by a decimal escape, e.g.: "\0\8".
+ * Fixing this to "\08" would turn "\0" into a legacy octal escape. To avoid producing
+ * an octal escape while fixing a decimal escape, we provide different suggestions.
+ */
+ suggest.push(
+ createSuggestion( // "\0\8" -> "\u00008"
+ "refactor",
+ [decimalEscapeRangeStart - previousEscape.length, decimalEscapeRangeEnd],
+ `${getUnicodeEscape("\0")}${decimalEscape[1]}`
+ ),
+ createSuggestion( // "\8" -> "\u0038"
+ "refactor",
+ decimalEscapeRange,
+ getUnicodeEscape(decimalEscape[1])
+ )
+ );
+ } else {
+ suggest.push(
+ createSuggestion( // "\8" -> "8"
+ "refactor",
+ decimalEscapeRange,
+ decimalEscape[1]
+ )
+ );
+ }
+
+ suggest.push(
+ createSuggestion( // "\8" -> "\\8"
+ "escapeBackslash",
+ decimalEscapeRange,
+ `\\${decimalEscape}`
+ )
+ );
+
+ context.report({
+ node,
+ loc: {
+ start: sourceCode.getLocFromIndex(decimalEscapeRangeStart),
+ end: sourceCode.getLocFromIndex(decimalEscapeRangeEnd)
+ },
+ messageId: "decimalEscape",
+ data: {
+ decimalEscape
+ },
+ suggest
+ });
+ }
+ }
+ };
+ }
+};
diff --git a/tools/node_modules/eslint/lib/rules/no-useless-constructor.js b/tools/node_modules/eslint/lib/rules/no-useless-constructor.js
index 4c34aeda715937..baabe7ec80f3a7 100644
--- a/tools/node_modules/eslint/lib/rules/no-useless-constructor.js
+++ b/tools/node_modules/eslint/lib/rules/no-useless-constructor.js
@@ -162,6 +162,14 @@ module.exports = {
return;
}
+ /*
+ * Prevent crashing on parsers which do not require class constructor
+ * to have a body, e.g. typescript and flow
+ */
+ if (!node.value.body) {
+ return;
+ }
+
const body = node.value.body.body;
const ctorParams = node.value.params;
const superClass = node.parent.parent.superClass;
diff --git a/tools/node_modules/eslint/node_modules/debug/package.json b/tools/node_modules/eslint/node_modules/debug/package.json
index 5f2e838cb3d384..2b1dece47b8c9d 100644
--- a/tools/node_modules/eslint/node_modules/debug/package.json
+++ b/tools/node_modules/eslint/node_modules/debug/package.json
@@ -74,5 +74,5 @@
"test:coverage": "cat ./coverage/lcov.info | coveralls",
"test:node": "istanbul cover _mocha -- test.js"
},
- "version": "4.2.0"
+ "version": "4.3.1"
}
\ No newline at end of file
diff --git a/tools/node_modules/eslint/node_modules/debug/src/browser.js b/tools/node_modules/eslint/node_modules/debug/src/browser.js
index ac3f7e1339b985..cd0fc35d1ee11e 100644
--- a/tools/node_modules/eslint/node_modules/debug/src/browser.js
+++ b/tools/node_modules/eslint/node_modules/debug/src/browser.js
@@ -9,6 +9,16 @@ exports.save = save;
exports.load = load;
exports.useColors = useColors;
exports.storage = localstorage();
+exports.destroy = (() => {
+ let warned = false;
+
+ return () => {
+ if (!warned) {
+ warned = true;
+ console.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');
+ }
+ };
+})();
/**
* Colors.
diff --git a/tools/node_modules/eslint/node_modules/debug/src/common.js b/tools/node_modules/eslint/node_modules/debug/src/common.js
index da7eada619f824..392a8e005a063a 100644
--- a/tools/node_modules/eslint/node_modules/debug/src/common.js
+++ b/tools/node_modules/eslint/node_modules/debug/src/common.js
@@ -12,16 +12,12 @@ function setup(env) {
createDebug.enable = enable;
createDebug.enabled = enabled;
createDebug.humanize = require('ms');
+ createDebug.destroy = destroy;
Object.keys(env).forEach(key => {
createDebug[key] = env[key];
});
- /**
- * Active `debug` instances.
- */
- createDebug.instances = [];
-
/**
* The currently active debug mode names, and names to skip.
*/
@@ -63,6 +59,7 @@ function setup(env) {
*/
function createDebug(namespace) {
let prevTime;
+ let enableOverride = null;
function debug(...args) {
// Disabled?
@@ -92,7 +89,7 @@ function setup(env) {
args[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {
// If we encounter an escaped % then don't increase the array index
if (match === '%%') {
- return match;
+ return '%';
}
index++;
const formatter = createDebug.formatters[format];
@@ -115,31 +112,28 @@ function setup(env) {
}
debug.namespace = namespace;
- debug.enabled = createDebug.enabled(namespace);
debug.useColors = createDebug.useColors();
debug.color = createDebug.selectColor(namespace);
- debug.destroy = destroy;
debug.extend = extend;
+ debug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.
+
+ Object.defineProperty(debug, 'enabled', {
+ enumerable: true,
+ configurable: false,
+ get: () => enableOverride === null ? createDebug.enabled(namespace) : enableOverride,
+ set: v => {
+ enableOverride = v;
+ }
+ });
// Env-specific initialization logic for debug instances
if (typeof createDebug.init === 'function') {
createDebug.init(debug);
}
- createDebug.instances.push(debug);
-
return debug;
}
- function destroy() {
- const index = createDebug.instances.indexOf(this);
- if (index !== -1) {
- createDebug.instances.splice(index, 1);
- return true;
- }
- return false;
- }
-
function extend(namespace, delimiter) {
const newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);
newDebug.log = this.log;
@@ -177,11 +171,6 @@ function setup(env) {
createDebug.names.push(new RegExp('^' + namespaces + '$'));
}
}
-
- for (i = 0; i < createDebug.instances.length; i++) {
- const instance = createDebug.instances[i];
- instance.enabled = createDebug.enabled(instance.namespace);
- }
}
/**
@@ -256,6 +245,14 @@ function setup(env) {
return val;
}
+ /**
+ * XXX DO NOT USE. This is a temporary stub function.
+ * XXX It WILL be removed in the next major release.
+ */
+ function destroy() {
+ console.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');
+ }
+
createDebug.enable(createDebug.load());
return createDebug;
diff --git a/tools/node_modules/eslint/node_modules/debug/src/node.js b/tools/node_modules/eslint/node_modules/debug/src/node.js
index 5e1f1541a05593..79bc085cb0230c 100644
--- a/tools/node_modules/eslint/node_modules/debug/src/node.js
+++ b/tools/node_modules/eslint/node_modules/debug/src/node.js
@@ -15,6 +15,10 @@ exports.formatArgs = formatArgs;
exports.save = save;
exports.load = load;
exports.useColors = useColors;
+exports.destroy = util.deprecate(
+ () => {},
+ 'Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.'
+);
/**
* Colors.
@@ -244,7 +248,9 @@ const {formatters} = module.exports;
formatters.o = function (v) {
this.inspectOpts.colors = this.useColors;
return util.inspect(v, this.inspectOpts)
- .replace(/\s*\n\s*/g, ' ');
+ .split('\n')
+ .map(str => str.trim())
+ .join(' ');
};
/**
diff --git a/tools/node_modules/eslint/package.json b/tools/node_modules/eslint/package.json
index b7ff09a778c010..b0e760690be546 100644
--- a/tools/node_modules/eslint/package.json
+++ b/tools/node_modules/eslint/package.json
@@ -155,5 +155,5 @@
"test:cli": "mocha",
"webpack": "node Makefile.js webpack"
},
- "version": "7.13.0"
+ "version": "7.14.0"
}
\ No newline at end of file