eslint 8.57.0 → 9.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +31 -28
- package/bin/eslint.js +4 -3
- package/conf/ecma-version.js +16 -0
- package/conf/globals.js +1 -0
- package/conf/rule-type-list.json +3 -1
- package/lib/api.js +7 -11
- package/lib/cli-engine/cli-engine.js +14 -3
- package/lib/cli-engine/formatters/formatters-meta.json +1 -29
- package/lib/cli-engine/lint-result-cache.js +2 -2
- package/lib/cli.js +115 -36
- package/lib/config/default-config.js +3 -0
- package/lib/config/flat-config-array.js +110 -24
- package/lib/config/flat-config-helpers.js +41 -20
- package/lib/config/flat-config-schema.js +1 -7
- package/lib/config/rule-validator.js +42 -6
- package/lib/eslint/eslint-helpers.js +116 -58
- package/lib/eslint/eslint.js +892 -377
- package/lib/eslint/index.js +2 -2
- package/lib/eslint/legacy-eslint.js +728 -0
- package/lib/linter/apply-disable-directives.js +59 -31
- package/lib/linter/code-path-analysis/code-path-analyzer.js +0 -1
- package/lib/linter/code-path-analysis/code-path.js +32 -30
- package/lib/linter/code-path-analysis/fork-context.js +1 -1
- package/lib/linter/config-comment-parser.js +8 -11
- package/lib/linter/index.js +1 -3
- package/lib/linter/interpolate.js +24 -2
- package/lib/linter/linter.js +428 -207
- package/lib/linter/report-translator.js +3 -3
- package/lib/linter/rules.js +6 -15
- package/lib/linter/source-code-fixer.js +1 -1
- package/lib/linter/timing.js +16 -8
- package/lib/options.js +35 -3
- package/lib/rule-tester/index.js +3 -1
- package/lib/rule-tester/rule-tester.js +424 -347
- package/lib/rules/array-bracket-newline.js +1 -1
- package/lib/rules/array-bracket-spacing.js +1 -1
- package/lib/rules/block-scoped-var.js +1 -1
- package/lib/rules/callback-return.js +2 -2
- package/lib/rules/camelcase.js +3 -5
- package/lib/rules/capitalized-comments.js +10 -7
- package/lib/rules/comma-dangle.js +1 -1
- package/lib/rules/comma-style.js +2 -2
- package/lib/rules/complexity.js +14 -1
- package/lib/rules/constructor-super.js +99 -100
- package/lib/rules/default-case.js +1 -1
- package/lib/rules/eol-last.js +2 -2
- package/lib/rules/function-paren-newline.js +2 -2
- package/lib/rules/indent-legacy.js +5 -5
- package/lib/rules/indent.js +5 -5
- package/lib/rules/index.js +1 -2
- package/lib/rules/key-spacing.js +2 -2
- package/lib/rules/line-comment-position.js +1 -1
- package/lib/rules/lines-around-directive.js +2 -2
- package/lib/rules/max-depth.js +1 -1
- package/lib/rules/max-len.js +3 -3
- package/lib/rules/max-lines.js +3 -3
- package/lib/rules/max-nested-callbacks.js +1 -1
- package/lib/rules/max-params.js +1 -1
- package/lib/rules/max-statements.js +1 -1
- package/lib/rules/multiline-comment-style.js +7 -7
- package/lib/rules/new-cap.js +1 -1
- package/lib/rules/newline-after-var.js +1 -1
- package/lib/rules/newline-before-return.js +1 -1
- package/lib/rules/no-case-declarations.js +13 -1
- package/lib/rules/no-constant-binary-expression.js +7 -8
- package/lib/rules/no-constant-condition.js +18 -7
- package/lib/rules/no-constructor-return.js +2 -2
- package/lib/rules/no-dupe-class-members.js +2 -2
- package/lib/rules/no-else-return.js +1 -1
- package/lib/rules/no-empty-function.js +2 -2
- package/lib/rules/no-empty-static-block.js +1 -1
- package/lib/rules/no-extend-native.js +1 -2
- package/lib/rules/no-extra-semi.js +1 -1
- package/lib/rules/no-fallthrough.js +41 -16
- package/lib/rules/no-implicit-coercion.js +66 -24
- package/lib/rules/no-inner-declarations.js +23 -2
- package/lib/rules/no-invalid-regexp.js +1 -1
- package/lib/rules/no-invalid-this.js +1 -1
- package/lib/rules/no-lone-blocks.js +3 -3
- package/lib/rules/no-loss-of-precision.js +1 -1
- package/lib/rules/no-misleading-character-class.js +225 -69
- package/lib/rules/no-mixed-spaces-and-tabs.js +1 -1
- package/lib/rules/no-multiple-empty-lines.js +1 -1
- package/lib/rules/no-new-native-nonconstructor.js +1 -1
- package/lib/rules/no-new-symbol.js +8 -1
- package/lib/rules/no-restricted-globals.js +1 -1
- package/lib/rules/no-restricted-imports.js +186 -40
- package/lib/rules/no-restricted-modules.js +2 -2
- package/lib/rules/no-return-await.js +1 -1
- package/lib/rules/no-sequences.js +1 -0
- package/lib/rules/no-this-before-super.js +45 -13
- package/lib/rules/no-trailing-spaces.js +2 -3
- package/lib/rules/no-unneeded-ternary.js +1 -1
- package/lib/rules/no-unsafe-optional-chaining.js +1 -1
- package/lib/rules/no-unused-private-class-members.js +1 -1
- package/lib/rules/no-unused-vars.js +197 -36
- package/lib/rules/no-useless-assignment.js +566 -0
- package/lib/rules/no-useless-backreference.js +1 -1
- package/lib/rules/no-useless-computed-key.js +2 -2
- package/lib/rules/no-useless-return.js +7 -2
- package/lib/rules/object-curly-spacing.js +3 -3
- package/lib/rules/object-property-newline.js +1 -1
- package/lib/rules/one-var.js +5 -5
- package/lib/rules/padded-blocks.js +7 -7
- package/lib/rules/prefer-arrow-callback.js +3 -3
- package/lib/rules/prefer-reflect.js +1 -1
- package/lib/rules/prefer-regex-literals.js +1 -1
- package/lib/rules/prefer-template.js +1 -1
- package/lib/rules/radix.js +2 -2
- package/lib/rules/semi-style.js +1 -1
- package/lib/rules/sort-imports.js +1 -1
- package/lib/rules/sort-keys.js +1 -1
- package/lib/rules/sort-vars.js +1 -1
- package/lib/rules/space-unary-ops.js +1 -1
- package/lib/rules/strict.js +1 -1
- package/lib/rules/use-isnan.js +101 -7
- package/lib/rules/utils/ast-utils.js +16 -7
- package/lib/rules/utils/char-source.js +240 -0
- package/lib/rules/utils/lazy-loading-rule-map.js +1 -1
- package/lib/rules/utils/unicode/index.js +9 -4
- package/lib/rules/yield-star-spacing.js +1 -1
- package/lib/shared/runtime-info.js +1 -0
- package/lib/shared/serialization.js +55 -0
- package/lib/shared/stats.js +30 -0
- package/lib/shared/string-utils.js +9 -11
- package/lib/shared/types.js +35 -1
- package/lib/source-code/index.js +3 -1
- package/lib/source-code/source-code.js +299 -85
- package/lib/source-code/token-store/backward-token-cursor.js +3 -3
- package/lib/source-code/token-store/cursors.js +4 -2
- package/lib/source-code/token-store/forward-token-comment-cursor.js +3 -3
- package/lib/source-code/token-store/forward-token-cursor.js +3 -3
- package/lib/source-code/token-store/index.js +2 -2
- package/lib/unsupported-api.js +3 -5
- package/messages/no-config-found.js +1 -1
- package/messages/plugin-conflict.js +1 -1
- package/messages/plugin-invalid.js +1 -1
- package/messages/plugin-missing.js +1 -1
- package/package.json +32 -29
- package/conf/config-schema.js +0 -93
- package/lib/cli-engine/formatters/checkstyle.js +0 -60
- package/lib/cli-engine/formatters/compact.js +0 -60
- package/lib/cli-engine/formatters/jslint-xml.js +0 -41
- package/lib/cli-engine/formatters/junit.js +0 -82
- package/lib/cli-engine/formatters/tap.js +0 -95
- package/lib/cli-engine/formatters/unix.js +0 -58
- package/lib/cli-engine/formatters/visualstudio.js +0 -63
- package/lib/cli-engine/xml-escape.js +0 -34
- package/lib/eslint/flat-eslint.js +0 -1155
- package/lib/rule-tester/flat-rule-tester.js +0 -1131
- package/lib/rules/require-jsdoc.js +0 -122
- package/lib/rules/utils/patterns/letters.js +0 -36
- package/lib/rules/valid-jsdoc.js +0 -516
- package/lib/shared/config-validator.js +0 -347
- package/lib/shared/deprecation-warnings.js +0 -58
- package/lib/shared/relative-module-resolver.js +0 -50
@@ -0,0 +1,240 @@
|
|
1
|
+
/**
|
2
|
+
* @fileoverview Utility functions to locate the source text of each code unit in the value of a string literal or template token.
|
3
|
+
* @author Francesco Trotta
|
4
|
+
*/
|
5
|
+
|
6
|
+
"use strict";
|
7
|
+
|
8
|
+
/**
|
9
|
+
* Represents a code unit produced by the evaluation of a JavaScript common token like a string
|
10
|
+
* literal or template token.
|
11
|
+
*/
|
12
|
+
class CodeUnit {
|
13
|
+
constructor(start, source) {
|
14
|
+
this.start = start;
|
15
|
+
this.source = source;
|
16
|
+
}
|
17
|
+
|
18
|
+
get end() {
|
19
|
+
return this.start + this.length;
|
20
|
+
}
|
21
|
+
|
22
|
+
get length() {
|
23
|
+
return this.source.length;
|
24
|
+
}
|
25
|
+
}
|
26
|
+
|
27
|
+
/**
|
28
|
+
* An object used to keep track of the position in a source text where the next characters will be read.
|
29
|
+
*/
|
30
|
+
class TextReader {
|
31
|
+
constructor(source) {
|
32
|
+
this.source = source;
|
33
|
+
this.pos = 0;
|
34
|
+
}
|
35
|
+
|
36
|
+
/**
|
37
|
+
* Advances the reading position of the specified number of characters.
|
38
|
+
* @param {number} length Number of characters to advance.
|
39
|
+
* @returns {void}
|
40
|
+
*/
|
41
|
+
advance(length) {
|
42
|
+
this.pos += length;
|
43
|
+
}
|
44
|
+
|
45
|
+
/**
|
46
|
+
* Reads characters from the source.
|
47
|
+
* @param {number} [offset=0] The offset where reading starts, relative to the current position.
|
48
|
+
* @param {number} [length=1] Number of characters to read.
|
49
|
+
* @returns {string} A substring of source characters.
|
50
|
+
*/
|
51
|
+
read(offset = 0, length = 1) {
|
52
|
+
const start = offset + this.pos;
|
53
|
+
|
54
|
+
return this.source.slice(start, start + length);
|
55
|
+
}
|
56
|
+
}
|
57
|
+
|
58
|
+
const SIMPLE_ESCAPE_SEQUENCES =
|
59
|
+
{ __proto__: null, b: "\b", f: "\f", n: "\n", r: "\r", t: "\t", v: "\v" };
|
60
|
+
|
61
|
+
/**
|
62
|
+
* Reads a hex escape sequence.
|
63
|
+
* @param {TextReader} reader The reader should be positioned on the first hexadecimal digit.
|
64
|
+
* @param {number} length The number of hexadecimal digits.
|
65
|
+
* @returns {string} A code unit.
|
66
|
+
*/
|
67
|
+
function readHexSequence(reader, length) {
|
68
|
+
const str = reader.read(0, length);
|
69
|
+
const charCode = parseInt(str, 16);
|
70
|
+
|
71
|
+
reader.advance(length);
|
72
|
+
return String.fromCharCode(charCode);
|
73
|
+
}
|
74
|
+
|
75
|
+
/**
|
76
|
+
* Reads a Unicode escape sequence.
|
77
|
+
* @param {TextReader} reader The reader should be positioned after the "u".
|
78
|
+
* @returns {string} A code unit.
|
79
|
+
*/
|
80
|
+
function readUnicodeSequence(reader) {
|
81
|
+
const regExp = /\{(?<hexDigits>[\dA-Fa-f]+)\}/uy;
|
82
|
+
|
83
|
+
regExp.lastIndex = reader.pos;
|
84
|
+
const match = regExp.exec(reader.source);
|
85
|
+
|
86
|
+
if (match) {
|
87
|
+
const codePoint = parseInt(match.groups.hexDigits, 16);
|
88
|
+
|
89
|
+
reader.pos = regExp.lastIndex;
|
90
|
+
return String.fromCodePoint(codePoint);
|
91
|
+
}
|
92
|
+
return readHexSequence(reader, 4);
|
93
|
+
}
|
94
|
+
|
95
|
+
/**
|
96
|
+
* Reads an octal escape sequence.
|
97
|
+
* @param {TextReader} reader The reader should be positioned after the first octal digit.
|
98
|
+
* @param {number} maxLength The maximum number of octal digits.
|
99
|
+
* @returns {string} A code unit.
|
100
|
+
*/
|
101
|
+
function readOctalSequence(reader, maxLength) {
|
102
|
+
const [octalStr] = reader.read(-1, maxLength).match(/^[0-7]+/u);
|
103
|
+
|
104
|
+
reader.advance(octalStr.length - 1);
|
105
|
+
const octal = parseInt(octalStr, 8);
|
106
|
+
|
107
|
+
return String.fromCharCode(octal);
|
108
|
+
}
|
109
|
+
|
110
|
+
/**
|
111
|
+
* Reads an escape sequence or line continuation.
|
112
|
+
* @param {TextReader} reader The reader should be positioned on the backslash.
|
113
|
+
* @returns {string} A string of zero, one or two code units.
|
114
|
+
*/
|
115
|
+
function readEscapeSequenceOrLineContinuation(reader) {
|
116
|
+
const char = reader.read(1);
|
117
|
+
|
118
|
+
reader.advance(2);
|
119
|
+
const unitChar = SIMPLE_ESCAPE_SEQUENCES[char];
|
120
|
+
|
121
|
+
if (unitChar) {
|
122
|
+
return unitChar;
|
123
|
+
}
|
124
|
+
switch (char) {
|
125
|
+
case "x":
|
126
|
+
return readHexSequence(reader, 2);
|
127
|
+
case "u":
|
128
|
+
return readUnicodeSequence(reader);
|
129
|
+
case "\r":
|
130
|
+
if (reader.read() === "\n") {
|
131
|
+
reader.advance(1);
|
132
|
+
}
|
133
|
+
|
134
|
+
// fallthrough
|
135
|
+
case "\n":
|
136
|
+
case "\u2028":
|
137
|
+
case "\u2029":
|
138
|
+
return "";
|
139
|
+
case "0":
|
140
|
+
case "1":
|
141
|
+
case "2":
|
142
|
+
case "3":
|
143
|
+
return readOctalSequence(reader, 3);
|
144
|
+
case "4":
|
145
|
+
case "5":
|
146
|
+
case "6":
|
147
|
+
case "7":
|
148
|
+
return readOctalSequence(reader, 2);
|
149
|
+
default:
|
150
|
+
return char;
|
151
|
+
}
|
152
|
+
}
|
153
|
+
|
154
|
+
/**
|
155
|
+
* Reads an escape sequence or line continuation and generates the respective `CodeUnit` elements.
|
156
|
+
* @param {TextReader} reader The reader should be positioned on the backslash.
|
157
|
+
* @returns {Generator<CodeUnit>} Zero, one or two `CodeUnit` elements.
|
158
|
+
*/
|
159
|
+
function *mapEscapeSequenceOrLineContinuation(reader) {
|
160
|
+
const start = reader.pos;
|
161
|
+
const str = readEscapeSequenceOrLineContinuation(reader);
|
162
|
+
const end = reader.pos;
|
163
|
+
const source = reader.source.slice(start, end);
|
164
|
+
|
165
|
+
switch (str.length) {
|
166
|
+
case 0:
|
167
|
+
break;
|
168
|
+
case 1:
|
169
|
+
yield new CodeUnit(start, source);
|
170
|
+
break;
|
171
|
+
default:
|
172
|
+
yield new CodeUnit(start, source);
|
173
|
+
yield new CodeUnit(start, source);
|
174
|
+
break;
|
175
|
+
}
|
176
|
+
}
|
177
|
+
|
178
|
+
/**
|
179
|
+
* Parses a string literal.
|
180
|
+
* @param {string} source The string literal to parse, including the delimiting quotes.
|
181
|
+
* @returns {CodeUnit[]} A list of code units produced by the string literal.
|
182
|
+
*/
|
183
|
+
function parseStringLiteral(source) {
|
184
|
+
const reader = new TextReader(source);
|
185
|
+
const quote = reader.read();
|
186
|
+
|
187
|
+
reader.advance(1);
|
188
|
+
const codeUnits = [];
|
189
|
+
|
190
|
+
for (;;) {
|
191
|
+
const char = reader.read();
|
192
|
+
|
193
|
+
if (char === quote) {
|
194
|
+
break;
|
195
|
+
}
|
196
|
+
if (char === "\\") {
|
197
|
+
codeUnits.push(...mapEscapeSequenceOrLineContinuation(reader));
|
198
|
+
} else {
|
199
|
+
codeUnits.push(new CodeUnit(reader.pos, char));
|
200
|
+
reader.advance(1);
|
201
|
+
}
|
202
|
+
}
|
203
|
+
return codeUnits;
|
204
|
+
}
|
205
|
+
|
206
|
+
/**
|
207
|
+
* Parses a template token.
|
208
|
+
* @param {string} source The template token to parse, including the delimiting sequences `` ` ``, `${` and `}`.
|
209
|
+
* @returns {CodeUnit[]} A list of code units produced by the template token.
|
210
|
+
*/
|
211
|
+
function parseTemplateToken(source) {
|
212
|
+
const reader = new TextReader(source);
|
213
|
+
|
214
|
+
reader.advance(1);
|
215
|
+
const codeUnits = [];
|
216
|
+
|
217
|
+
for (;;) {
|
218
|
+
const char = reader.read();
|
219
|
+
|
220
|
+
if (char === "`" || char === "$" && reader.read(1) === "{") {
|
221
|
+
break;
|
222
|
+
}
|
223
|
+
if (char === "\\") {
|
224
|
+
codeUnits.push(...mapEscapeSequenceOrLineContinuation(reader));
|
225
|
+
} else {
|
226
|
+
let unitSource;
|
227
|
+
|
228
|
+
if (char === "\r" && reader.read(1) === "\n") {
|
229
|
+
unitSource = "\r\n";
|
230
|
+
} else {
|
231
|
+
unitSource = char;
|
232
|
+
}
|
233
|
+
codeUnits.push(new CodeUnit(reader.pos, unitSource));
|
234
|
+
reader.advance(unitSource.length);
|
235
|
+
}
|
236
|
+
}
|
237
|
+
return codeUnits;
|
238
|
+
}
|
239
|
+
|
240
|
+
module.exports = { parseStringLiteral, parseTemplateToken };
|
@@ -3,9 +3,14 @@
|
|
3
3
|
*/
|
4
4
|
"use strict";
|
5
5
|
|
6
|
+
const isCombiningCharacter = require("./is-combining-character");
|
7
|
+
const isEmojiModifier = require("./is-emoji-modifier");
|
8
|
+
const isRegionalIndicatorSymbol = require("./is-regional-indicator-symbol");
|
9
|
+
const isSurrogatePair = require("./is-surrogate-pair");
|
10
|
+
|
6
11
|
module.exports = {
|
7
|
-
isCombiningCharacter
|
8
|
-
isEmojiModifier
|
9
|
-
isRegionalIndicatorSymbol
|
10
|
-
isSurrogatePair
|
12
|
+
isCombiningCharacter,
|
13
|
+
isEmojiModifier,
|
14
|
+
isRegionalIndicatorSymbol,
|
15
|
+
isSurrogatePair
|
11
16
|
};
|
@@ -79,7 +79,7 @@ module.exports = {
|
|
79
79
|
const after = leftToken.value === "*";
|
80
80
|
const spaceRequired = mode[side];
|
81
81
|
const node = after ? leftToken : rightToken;
|
82
|
-
let messageId
|
82
|
+
let messageId;
|
83
83
|
|
84
84
|
if (spaceRequired) {
|
85
85
|
messageId = side === "before" ? "missingBefore" : "missingAfter";
|
@@ -162,6 +162,7 @@ function version() {
|
|
162
162
|
//------------------------------------------------------------------------------
|
163
163
|
|
164
164
|
module.exports = {
|
165
|
+
__esModule: true, // Indicate intent for imports, remove ambiguity for Knip (see: https://github.com/eslint/eslint/pull/18005#discussion_r1484422616)
|
165
166
|
environment,
|
166
167
|
version
|
167
168
|
};
|
@@ -0,0 +1,55 @@
|
|
1
|
+
/**
|
2
|
+
* @fileoverview Serialization utils.
|
3
|
+
* @author Bryan Mishkin
|
4
|
+
*/
|
5
|
+
|
6
|
+
"use strict";
|
7
|
+
|
8
|
+
/**
|
9
|
+
* Check if a value is a primitive or plain object created by the Object constructor.
|
10
|
+
* @param {any} val the value to check
|
11
|
+
* @returns {boolean} true if so
|
12
|
+
* @private
|
13
|
+
*/
|
14
|
+
function isSerializablePrimitiveOrPlainObject(val) {
|
15
|
+
return (
|
16
|
+
val === null ||
|
17
|
+
typeof val === "string" ||
|
18
|
+
typeof val === "boolean" ||
|
19
|
+
typeof val === "number" ||
|
20
|
+
(typeof val === "object" && val.constructor === Object) ||
|
21
|
+
Array.isArray(val)
|
22
|
+
);
|
23
|
+
}
|
24
|
+
|
25
|
+
/**
|
26
|
+
* Check if a value is serializable.
|
27
|
+
* Functions or objects like RegExp cannot be serialized by JSON.stringify().
|
28
|
+
* Inspired by: https://stackoverflow.com/questions/30579940/reliable-way-to-check-if-objects-is-serializable-in-javascript
|
29
|
+
* @param {any} val the value
|
30
|
+
* @returns {boolean} true if the value is serializable
|
31
|
+
*/
|
32
|
+
function isSerializable(val) {
|
33
|
+
if (!isSerializablePrimitiveOrPlainObject(val)) {
|
34
|
+
return false;
|
35
|
+
}
|
36
|
+
if (typeof val === "object") {
|
37
|
+
for (const property in val) {
|
38
|
+
if (Object.hasOwn(val, property)) {
|
39
|
+
if (!isSerializablePrimitiveOrPlainObject(val[property])) {
|
40
|
+
return false;
|
41
|
+
}
|
42
|
+
if (typeof val[property] === "object") {
|
43
|
+
if (!isSerializable(val[property])) {
|
44
|
+
return false;
|
45
|
+
}
|
46
|
+
}
|
47
|
+
}
|
48
|
+
}
|
49
|
+
}
|
50
|
+
return true;
|
51
|
+
}
|
52
|
+
|
53
|
+
module.exports = {
|
54
|
+
isSerializable
|
55
|
+
};
|
@@ -0,0 +1,30 @@
|
|
1
|
+
/**
|
2
|
+
* @fileoverview Provides helper functions to start/stop the time measurements
|
3
|
+
* that are provided by the ESLint 'stats' option.
|
4
|
+
* @author Mara Kiefer <http://github.com/mnkiefer>
|
5
|
+
*/
|
6
|
+
"use strict";
|
7
|
+
|
8
|
+
/**
|
9
|
+
* Start time measurement
|
10
|
+
* @returns {[number, number]} t variable for tracking time
|
11
|
+
*/
|
12
|
+
function startTime() {
|
13
|
+
return process.hrtime();
|
14
|
+
}
|
15
|
+
|
16
|
+
/**
|
17
|
+
* End time measurement
|
18
|
+
* @param {[number, number]} t Variable for tracking time
|
19
|
+
* @returns {number} The measured time in milliseconds
|
20
|
+
*/
|
21
|
+
function endTime(t) {
|
22
|
+
const time = process.hrtime(t);
|
23
|
+
|
24
|
+
return time[0] * 1e3 + time[1] / 1e6;
|
25
|
+
}
|
26
|
+
|
27
|
+
module.exports = {
|
28
|
+
startTime,
|
29
|
+
endTime
|
30
|
+
};
|
@@ -5,12 +5,6 @@
|
|
5
5
|
|
6
6
|
"use strict";
|
7
7
|
|
8
|
-
//------------------------------------------------------------------------------
|
9
|
-
// Requirements
|
10
|
-
//------------------------------------------------------------------------------
|
11
|
-
|
12
|
-
const Graphemer = require("graphemer").default;
|
13
|
-
|
14
8
|
//------------------------------------------------------------------------------
|
15
9
|
// Helpers
|
16
10
|
//------------------------------------------------------------------------------
|
@@ -18,8 +12,8 @@ const Graphemer = require("graphemer").default;
|
|
18
12
|
// eslint-disable-next-line no-control-regex -- intentionally including control characters
|
19
13
|
const ASCII_REGEX = /^[\u0000-\u007f]*$/u;
|
20
14
|
|
21
|
-
/** @type {
|
22
|
-
let
|
15
|
+
/** @type {Intl.Segmenter | undefined} */
|
16
|
+
let segmenter;
|
23
17
|
|
24
18
|
//------------------------------------------------------------------------------
|
25
19
|
// Public Interface
|
@@ -47,11 +41,15 @@ function getGraphemeCount(value) {
|
|
47
41
|
return value.length;
|
48
42
|
}
|
49
43
|
|
50
|
-
|
51
|
-
|
44
|
+
segmenter ??= new Intl.Segmenter("en-US"); // en-US locale should be supported everywhere
|
45
|
+
let graphemeCount = 0;
|
46
|
+
|
47
|
+
// eslint-disable-next-line no-unused-vars -- for-of needs a variable
|
48
|
+
for (const unused of segmenter.segment(value)) {
|
49
|
+
graphemeCount++;
|
52
50
|
}
|
53
51
|
|
54
|
-
return
|
52
|
+
return graphemeCount;
|
55
53
|
}
|
56
54
|
|
57
55
|
module.exports = {
|
package/lib/shared/types.js
CHANGED
@@ -168,7 +168,7 @@ module.exports = {};
|
|
168
168
|
* @property {Record<string, ConfigData>} [configs] The definition of plugin configs.
|
169
169
|
* @property {Record<string, Environment>} [environments] The definition of plugin environments.
|
170
170
|
* @property {Record<string, Processor>} [processors] The definition of plugin processors.
|
171
|
-
* @property {Record<string,
|
171
|
+
* @property {Record<string, Rule>} [rules] The definition of plugin rules.
|
172
172
|
*/
|
173
173
|
|
174
174
|
/**
|
@@ -189,11 +189,45 @@ module.exports = {};
|
|
189
189
|
* @property {number} warningCount Number of warnings for the result.
|
190
190
|
* @property {number} fixableErrorCount Number of fixable errors for the result.
|
191
191
|
* @property {number} fixableWarningCount Number of fixable warnings for the result.
|
192
|
+
* @property {Stats} [stats] The performance statistics collected with the `stats` flag.
|
192
193
|
* @property {string} [source] The source code of the file that was linted.
|
193
194
|
* @property {string} [output] The source code of the file that was linted, with as many fixes applied as possible.
|
194
195
|
* @property {DeprecatedRuleInfo[]} usedDeprecatedRules The list of used deprecated rules.
|
195
196
|
*/
|
196
197
|
|
198
|
+
/**
|
199
|
+
* Performance statistics
|
200
|
+
* @typedef {Object} Stats
|
201
|
+
* @property {number} fixPasses The number of times ESLint has applied at least one fix after linting.
|
202
|
+
* @property {Times} times The times spent on (parsing, fixing, linting) a file.
|
203
|
+
*/
|
204
|
+
|
205
|
+
/**
|
206
|
+
* Performance Times for each ESLint pass
|
207
|
+
* @typedef {Object} Times
|
208
|
+
* @property {TimePass[]} passes Time passes
|
209
|
+
*/
|
210
|
+
|
211
|
+
/**
|
212
|
+
* @typedef {Object} TimePass
|
213
|
+
* @property {ParseTime} parse The parse object containing all parse time information.
|
214
|
+
* @property {Record<string, RuleTime>} [rules] The rules object containing all lint time information for each rule.
|
215
|
+
* @property {FixTime} fix The parse object containing all fix time information.
|
216
|
+
* @property {number} total The total time that is spent on (parsing, fixing, linting) a file.
|
217
|
+
*/
|
218
|
+
/**
|
219
|
+
* @typedef {Object} ParseTime
|
220
|
+
* @property {number} total The total time that is spent when parsing a file.
|
221
|
+
*/
|
222
|
+
/**
|
223
|
+
* @typedef {Object} RuleTime
|
224
|
+
* @property {number} total The total time that is spent on a rule.
|
225
|
+
*/
|
226
|
+
/**
|
227
|
+
* @typedef {Object} FixTime
|
228
|
+
* @property {number} total The total time that is spent on applying fixes to the code.
|
229
|
+
*/
|
230
|
+
|
197
231
|
/**
|
198
232
|
* Information provided when the maximum warning threshold is exceeded.
|
199
233
|
* @typedef {Object} MaxWarningsExceeded
|