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.
Files changed (156) hide show
  1. package/README.md +31 -28
  2. package/bin/eslint.js +4 -3
  3. package/conf/ecma-version.js +16 -0
  4. package/conf/globals.js +1 -0
  5. package/conf/rule-type-list.json +3 -1
  6. package/lib/api.js +7 -11
  7. package/lib/cli-engine/cli-engine.js +14 -3
  8. package/lib/cli-engine/formatters/formatters-meta.json +1 -29
  9. package/lib/cli-engine/lint-result-cache.js +2 -2
  10. package/lib/cli.js +115 -36
  11. package/lib/config/default-config.js +3 -0
  12. package/lib/config/flat-config-array.js +110 -24
  13. package/lib/config/flat-config-helpers.js +41 -20
  14. package/lib/config/flat-config-schema.js +1 -7
  15. package/lib/config/rule-validator.js +42 -6
  16. package/lib/eslint/eslint-helpers.js +116 -58
  17. package/lib/eslint/eslint.js +892 -377
  18. package/lib/eslint/index.js +2 -2
  19. package/lib/eslint/legacy-eslint.js +728 -0
  20. package/lib/linter/apply-disable-directives.js +59 -31
  21. package/lib/linter/code-path-analysis/code-path-analyzer.js +0 -1
  22. package/lib/linter/code-path-analysis/code-path.js +32 -30
  23. package/lib/linter/code-path-analysis/fork-context.js +1 -1
  24. package/lib/linter/config-comment-parser.js +8 -11
  25. package/lib/linter/index.js +1 -3
  26. package/lib/linter/interpolate.js +24 -2
  27. package/lib/linter/linter.js +428 -207
  28. package/lib/linter/report-translator.js +3 -3
  29. package/lib/linter/rules.js +6 -15
  30. package/lib/linter/source-code-fixer.js +1 -1
  31. package/lib/linter/timing.js +16 -8
  32. package/lib/options.js +35 -3
  33. package/lib/rule-tester/index.js +3 -1
  34. package/lib/rule-tester/rule-tester.js +424 -347
  35. package/lib/rules/array-bracket-newline.js +1 -1
  36. package/lib/rules/array-bracket-spacing.js +1 -1
  37. package/lib/rules/block-scoped-var.js +1 -1
  38. package/lib/rules/callback-return.js +2 -2
  39. package/lib/rules/camelcase.js +3 -5
  40. package/lib/rules/capitalized-comments.js +10 -7
  41. package/lib/rules/comma-dangle.js +1 -1
  42. package/lib/rules/comma-style.js +2 -2
  43. package/lib/rules/complexity.js +14 -1
  44. package/lib/rules/constructor-super.js +99 -100
  45. package/lib/rules/default-case.js +1 -1
  46. package/lib/rules/eol-last.js +2 -2
  47. package/lib/rules/function-paren-newline.js +2 -2
  48. package/lib/rules/indent-legacy.js +5 -5
  49. package/lib/rules/indent.js +5 -5
  50. package/lib/rules/index.js +1 -2
  51. package/lib/rules/key-spacing.js +2 -2
  52. package/lib/rules/line-comment-position.js +1 -1
  53. package/lib/rules/lines-around-directive.js +2 -2
  54. package/lib/rules/max-depth.js +1 -1
  55. package/lib/rules/max-len.js +3 -3
  56. package/lib/rules/max-lines.js +3 -3
  57. package/lib/rules/max-nested-callbacks.js +1 -1
  58. package/lib/rules/max-params.js +1 -1
  59. package/lib/rules/max-statements.js +1 -1
  60. package/lib/rules/multiline-comment-style.js +7 -7
  61. package/lib/rules/new-cap.js +1 -1
  62. package/lib/rules/newline-after-var.js +1 -1
  63. package/lib/rules/newline-before-return.js +1 -1
  64. package/lib/rules/no-case-declarations.js +13 -1
  65. package/lib/rules/no-constant-binary-expression.js +7 -8
  66. package/lib/rules/no-constant-condition.js +18 -7
  67. package/lib/rules/no-constructor-return.js +2 -2
  68. package/lib/rules/no-dupe-class-members.js +2 -2
  69. package/lib/rules/no-else-return.js +1 -1
  70. package/lib/rules/no-empty-function.js +2 -2
  71. package/lib/rules/no-empty-static-block.js +1 -1
  72. package/lib/rules/no-extend-native.js +1 -2
  73. package/lib/rules/no-extra-semi.js +1 -1
  74. package/lib/rules/no-fallthrough.js +41 -16
  75. package/lib/rules/no-implicit-coercion.js +66 -24
  76. package/lib/rules/no-inner-declarations.js +23 -2
  77. package/lib/rules/no-invalid-regexp.js +1 -1
  78. package/lib/rules/no-invalid-this.js +1 -1
  79. package/lib/rules/no-lone-blocks.js +3 -3
  80. package/lib/rules/no-loss-of-precision.js +1 -1
  81. package/lib/rules/no-misleading-character-class.js +225 -69
  82. package/lib/rules/no-mixed-spaces-and-tabs.js +1 -1
  83. package/lib/rules/no-multiple-empty-lines.js +1 -1
  84. package/lib/rules/no-new-native-nonconstructor.js +1 -1
  85. package/lib/rules/no-new-symbol.js +8 -1
  86. package/lib/rules/no-restricted-globals.js +1 -1
  87. package/lib/rules/no-restricted-imports.js +186 -40
  88. package/lib/rules/no-restricted-modules.js +2 -2
  89. package/lib/rules/no-return-await.js +1 -1
  90. package/lib/rules/no-sequences.js +1 -0
  91. package/lib/rules/no-this-before-super.js +45 -13
  92. package/lib/rules/no-trailing-spaces.js +2 -3
  93. package/lib/rules/no-unneeded-ternary.js +1 -1
  94. package/lib/rules/no-unsafe-optional-chaining.js +1 -1
  95. package/lib/rules/no-unused-private-class-members.js +1 -1
  96. package/lib/rules/no-unused-vars.js +197 -36
  97. package/lib/rules/no-useless-assignment.js +566 -0
  98. package/lib/rules/no-useless-backreference.js +1 -1
  99. package/lib/rules/no-useless-computed-key.js +2 -2
  100. package/lib/rules/no-useless-return.js +7 -2
  101. package/lib/rules/object-curly-spacing.js +3 -3
  102. package/lib/rules/object-property-newline.js +1 -1
  103. package/lib/rules/one-var.js +5 -5
  104. package/lib/rules/padded-blocks.js +7 -7
  105. package/lib/rules/prefer-arrow-callback.js +3 -3
  106. package/lib/rules/prefer-reflect.js +1 -1
  107. package/lib/rules/prefer-regex-literals.js +1 -1
  108. package/lib/rules/prefer-template.js +1 -1
  109. package/lib/rules/radix.js +2 -2
  110. package/lib/rules/semi-style.js +1 -1
  111. package/lib/rules/sort-imports.js +1 -1
  112. package/lib/rules/sort-keys.js +1 -1
  113. package/lib/rules/sort-vars.js +1 -1
  114. package/lib/rules/space-unary-ops.js +1 -1
  115. package/lib/rules/strict.js +1 -1
  116. package/lib/rules/use-isnan.js +101 -7
  117. package/lib/rules/utils/ast-utils.js +16 -7
  118. package/lib/rules/utils/char-source.js +240 -0
  119. package/lib/rules/utils/lazy-loading-rule-map.js +1 -1
  120. package/lib/rules/utils/unicode/index.js +9 -4
  121. package/lib/rules/yield-star-spacing.js +1 -1
  122. package/lib/shared/runtime-info.js +1 -0
  123. package/lib/shared/serialization.js +55 -0
  124. package/lib/shared/stats.js +30 -0
  125. package/lib/shared/string-utils.js +9 -11
  126. package/lib/shared/types.js +35 -1
  127. package/lib/source-code/index.js +3 -1
  128. package/lib/source-code/source-code.js +299 -85
  129. package/lib/source-code/token-store/backward-token-cursor.js +3 -3
  130. package/lib/source-code/token-store/cursors.js +4 -2
  131. package/lib/source-code/token-store/forward-token-comment-cursor.js +3 -3
  132. package/lib/source-code/token-store/forward-token-cursor.js +3 -3
  133. package/lib/source-code/token-store/index.js +2 -2
  134. package/lib/unsupported-api.js +3 -5
  135. package/messages/no-config-found.js +1 -1
  136. package/messages/plugin-conflict.js +1 -1
  137. package/messages/plugin-invalid.js +1 -1
  138. package/messages/plugin-missing.js +1 -1
  139. package/package.json +32 -29
  140. package/conf/config-schema.js +0 -93
  141. package/lib/cli-engine/formatters/checkstyle.js +0 -60
  142. package/lib/cli-engine/formatters/compact.js +0 -60
  143. package/lib/cli-engine/formatters/jslint-xml.js +0 -41
  144. package/lib/cli-engine/formatters/junit.js +0 -82
  145. package/lib/cli-engine/formatters/tap.js +0 -95
  146. package/lib/cli-engine/formatters/unix.js +0 -58
  147. package/lib/cli-engine/formatters/visualstudio.js +0 -63
  148. package/lib/cli-engine/xml-escape.js +0 -34
  149. package/lib/eslint/flat-eslint.js +0 -1155
  150. package/lib/rule-tester/flat-rule-tester.js +0 -1131
  151. package/lib/rules/require-jsdoc.js +0 -122
  152. package/lib/rules/utils/patterns/letters.js +0 -36
  153. package/lib/rules/valid-jsdoc.js +0 -516
  154. package/lib/shared/config-validator.js +0 -347
  155. package/lib/shared/deprecation-warnings.js +0 -58
  156. 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 };
@@ -6,7 +6,7 @@
6
6
 
7
7
  const debug = require("debug")("eslint:rules");
8
8
 
9
- /** @typedef {import("./types").Rule} Rule */
9
+ /** @typedef {import("../../shared/types").Rule} Rule */
10
10
 
11
11
  /**
12
12
  * The `Map` object that loads each rule when it's accessed.
@@ -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: require("./is-combining-character"),
8
- isEmojiModifier: require("./is-emoji-modifier"),
9
- isRegionalIndicatorSymbol: require("./is-regional-indicator-symbol"),
10
- isSurrogatePair: require("./is-surrogate-pair")
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 {Graphemer | undefined} */
22
- let splitter;
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
- if (!splitter) {
51
- splitter = new Graphemer();
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 splitter.countGraphemes(value);
52
+ return graphemeCount;
55
53
  }
56
54
 
57
55
  module.exports = {
@@ -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, Function | Rule>} [rules] The definition of plugin rules.
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
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
 
3
+ const SourceCode = require("./source-code");
4
+
3
5
  module.exports = {
4
- SourceCode: require("./source-code")
6
+ SourceCode
5
7
  };