eslint-interactive 13.0.0 → 14.0.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 +19 -10
- package/dist/action/convert-error-to-warning-per-file.d.ts +4 -0
- package/dist/action/convert-error-to-warning-per-file.d.ts.map +1 -0
- package/dist/action/convert-error-to-warning-per-file.js +8 -0
- package/dist/action/convert-error-to-warning-per-file.js.map +1 -0
- package/dist/action/disable-per-file.d.ts +4 -0
- package/dist/action/disable-per-file.d.ts.map +1 -0
- package/dist/action/disable-per-file.js +12 -0
- package/dist/action/disable-per-file.js.map +1 -0
- package/dist/action/disable-per-line.d.ts +4 -0
- package/dist/action/disable-per-line.d.ts.map +1 -0
- package/dist/action/disable-per-line.js +12 -0
- package/dist/action/disable-per-line.js.map +1 -0
- package/dist/action/fix.d.ts +4 -0
- package/dist/action/fix.d.ts.map +1 -0
- package/dist/action/fix.js +6 -0
- package/dist/action/fix.js.map +1 -0
- package/dist/action/index.d.ts +6 -0
- package/dist/action/index.d.ts.map +1 -0
- package/dist/action/index.js +6 -0
- package/dist/action/index.js.map +1 -0
- package/dist/action/print-result-details.d.ts +4 -0
- package/dist/action/print-result-details.d.ts.map +1 -0
- package/dist/action/print-result-details.js +36 -0
- package/dist/action/print-result-details.js.map +1 -0
- package/dist/cli/log.d.ts +7 -0
- package/dist/cli/log.d.ts.map +1 -0
- package/dist/cli/log.js +35 -0
- package/dist/cli/log.js.map +1 -0
- package/dist/cli/package.d.ts +2 -0
- package/dist/cli/package.d.ts.map +1 -0
- package/dist/cli/package.js +6 -0
- package/dist/cli/package.js.map +1 -0
- package/dist/cli/pager.d.ts +2 -0
- package/dist/cli/pager.d.ts.map +1 -0
- package/dist/cli/pager.js +34 -0
- package/dist/cli/pager.js.map +1 -0
- package/dist/cli/parse-argv.d.ts +4 -0
- package/dist/cli/parse-argv.d.ts.map +1 -0
- package/dist/cli/parse-argv.js +103 -0
- package/dist/cli/parse-argv.js.map +1 -0
- package/dist/cli/prompt.d.ts +51 -0
- package/dist/cli/prompt.d.ts.map +1 -0
- package/dist/cli/prompt.js +97 -0
- package/dist/cli/prompt.js.map +1 -0
- package/dist/cli/run.d.ts +6 -0
- package/dist/cli/run.d.ts.map +1 -0
- package/dist/cli/run.js +28 -0
- package/dist/cli/run.js.map +1 -0
- package/dist/core.d.ts +82 -0
- package/dist/core.d.ts.map +1 -0
- package/dist/core.js +189 -0
- package/dist/core.js.map +1 -0
- package/dist/eslint/linter.d.ts +18 -0
- package/dist/eslint/linter.d.ts.map +1 -0
- package/dist/eslint/linter.js +71 -0
- package/dist/eslint/linter.js.map +1 -0
- package/dist/eslint/report-translator.d.ts +9 -0
- package/dist/eslint/report-translator.d.ts.map +1 -0
- package/dist/eslint/report-translator.js +75 -0
- package/dist/eslint/report-translator.js.map +1 -0
- package/dist/eslint/rule-fixer.d.ts +80 -0
- package/dist/eslint/rule-fixer.d.ts.map +1 -0
- package/dist/eslint/rule-fixer.js +114 -0
- package/dist/eslint/rule-fixer.js.map +1 -0
- package/dist/eslint/source-code-fixer.d.ts +15 -0
- package/dist/eslint/source-code-fixer.d.ts.map +1 -0
- package/dist/eslint/source-code-fixer.js +131 -0
- package/dist/eslint/source-code-fixer.js.map +1 -0
- package/dist/fix/apply-auto-fixes.d.ts +8 -0
- package/dist/fix/apply-auto-fixes.d.ts.map +1 -0
- package/dist/fix/apply-auto-fixes.js +8 -0
- package/dist/fix/apply-auto-fixes.js.map +1 -0
- package/dist/fix/apply-suggestions.d.ts +11 -0
- package/dist/fix/apply-suggestions.d.ts.map +1 -0
- package/dist/fix/apply-suggestions.js +25 -0
- package/dist/fix/apply-suggestions.js.map +1 -0
- package/dist/fix/convert-error-to-warning-per-file.d.ts +10 -0
- package/dist/fix/convert-error-to-warning-per-file.d.ts.map +1 -0
- package/dist/fix/convert-error-to-warning-per-file.js +28 -0
- package/dist/fix/convert-error-to-warning-per-file.js.map +1 -0
- package/dist/fix/disable-per-file.d.ts +12 -0
- package/dist/fix/disable-per-file.d.ts.map +1 -0
- package/dist/fix/disable-per-file.js +63 -0
- package/dist/fix/disable-per-file.js.map +1 -0
- package/dist/fix/disable-per-line.d.ts +12 -0
- package/dist/fix/disable-per-line.d.ts.map +1 -0
- package/dist/fix/disable-per-line.js +72 -0
- package/dist/fix/disable-per-line.js.map +1 -0
- package/dist/fix/index.d.ts +19 -0
- package/dist/fix/index.d.ts.map +1 -0
- package/dist/fix/index.js +8 -0
- package/dist/fix/index.js.map +1 -0
- package/dist/fix/make-fixable-and-fix.d.ts +11 -0
- package/dist/fix/make-fixable-and-fix.d.ts.map +1 -0
- package/dist/fix/make-fixable-and-fix.js +35 -0
- package/dist/fix/make-fixable-and-fix.js.map +1 -0
- package/dist/formatter/colors.d.ts +4 -0
- package/dist/formatter/colors.d.ts.map +1 -0
- package/dist/formatter/colors.js +5 -0
- package/dist/formatter/colors.js.map +1 -0
- package/dist/formatter/filter-rule-statistics.d.ts +9 -0
- package/dist/formatter/filter-rule-statistics.d.ts.map +1 -0
- package/dist/formatter/filter-rule-statistics.js +22 -0
- package/dist/formatter/filter-rule-statistics.js.map +1 -0
- package/dist/formatter/format-by-files.d.ts +3 -0
- package/dist/formatter/format-by-files.d.ts.map +1 -0
- package/dist/formatter/format-by-files.js +42 -0
- package/dist/formatter/format-by-files.js.map +1 -0
- package/dist/formatter/format-by-rules.d.ts +9 -0
- package/dist/formatter/format-by-rules.d.ts.map +1 -0
- package/dist/formatter/format-by-rules.js +33 -0
- package/dist/formatter/format-by-rules.js.map +1 -0
- package/dist/formatter/format-table.d.ts +4 -0
- package/dist/formatter/format-table.d.ts.map +1 -0
- package/dist/formatter/format-table.js +62 -0
- package/dist/formatter/format-table.js.map +1 -0
- package/dist/formatter/index.d.ts +7 -0
- package/dist/formatter/index.d.ts.map +1 -0
- package/dist/formatter/index.js +9 -0
- package/dist/formatter/index.js.map +1 -0
- package/dist/formatter/sort-rule-statistics.d.ts +5 -0
- package/dist/formatter/sort-rule-statistics.d.ts.map +1 -0
- package/dist/formatter/sort-rule-statistics.js +34 -0
- package/dist/formatter/sort-rule-statistics.js.map +1 -0
- package/dist/formatter/take-rule-statistics.d.ts +18 -0
- package/dist/formatter/take-rule-statistics.d.ts.map +1 -0
- package/dist/formatter/take-rule-statistics.js +51 -0
- package/dist/formatter/take-rule-statistics.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/plugin.d.ts +4 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +87 -0
- package/dist/plugin.js.map +1 -0
- package/dist/scene/check-results.d.ts +21 -0
- package/dist/scene/check-results.d.ts.map +1 -0
- package/dist/scene/check-results.js +19 -0
- package/dist/scene/check-results.js.map +1 -0
- package/dist/scene/index.d.ts +25 -0
- package/dist/scene/index.d.ts.map +1 -0
- package/dist/scene/index.js +6 -0
- package/dist/scene/index.js.map +1 -0
- package/dist/scene/lint.d.ts +7 -0
- package/dist/scene/lint.d.ts.map +1 -0
- package/dist/scene/lint.js +34 -0
- package/dist/scene/lint.js.map +1 -0
- package/dist/scene/select-action.d.ts +19 -0
- package/dist/scene/select-action.d.ts.map +1 -0
- package/dist/scene/select-action.js +44 -0
- package/dist/scene/select-action.js.map +1 -0
- package/dist/scene/select-rule-ids.d.ts +14 -0
- package/dist/scene/select-rule-ids.d.ts.map +1 -0
- package/dist/scene/select-rule-ids.js +10 -0
- package/dist/scene/select-rule-ids.js.map +1 -0
- package/dist/type.d.ts +14 -0
- package/dist/type.d.ts.map +1 -0
- package/dist/type.js +2 -0
- package/dist/type.js.map +1 -0
- package/dist/util/array.d.ts +3 -0
- package/dist/util/array.d.ts.map +1 -0
- package/dist/util/array.js +14 -0
- package/dist/util/array.js.map +1 -0
- package/dist/util/eslint.d.ts +103 -0
- package/dist/util/eslint.d.ts.map +1 -0
- package/dist/util/eslint.js +220 -0
- package/dist/util/eslint.js.map +1 -0
- package/dist/util/terminal-link.d.ts +2 -0
- package/dist/util/terminal-link.d.ts.map +1 -0
- package/dist/util/terminal-link.js +16 -0
- package/dist/util/terminal-link.js.map +1 -0
- package/dist/util/type-check.d.ts +3 -0
- package/dist/util/type-check.d.ts.map +1 -0
- package/dist/util/type-check.js +8 -0
- package/dist/util/type-check.js.map +1 -0
- package/package.json +22 -24
- package/src/action/convert-error-to-warning-per-file.ts +4 -6
- package/src/action/disable-per-file.ts +4 -6
- package/src/action/disable-per-line.ts +4 -6
- package/src/action/fix.ts +4 -10
- package/src/action/print-result-details.ts +5 -9
- package/src/cli/log.ts +25 -0
- package/src/cli/parse-argv.ts +32 -11
- package/src/cli/prompt.ts +56 -92
- package/src/cli/run.ts +3 -29
- package/src/core.ts +13 -6
- package/src/fix/disable-per-file.ts +1 -1
- package/src/fix/disable-per-line.ts +1 -1
- package/src/formatter/filter-rule-statistics.ts +27 -0
- package/src/formatter/format-by-rules.ts +10 -7
- package/src/formatter/index.ts +4 -3
- package/src/index.ts +1 -1
- package/src/scene/check-results.ts +2 -5
- package/src/scene/lint.ts +14 -12
- package/src/scene/select-action.ts +2 -4
- package/src/scene/select-rule-ids.ts +2 -6
- package/src/type.ts +2 -0
- package/src/util/terminal-link.ts +16 -0
- package/src/cli/spinner.ts +0 -22
- package/src/core-worker.ts +0 -55
- package/src/typings/enquirer.d.ts +0 -7
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { mergeFixes } from '../eslint/report-translator.js';
|
|
2
|
+
import { groupBy, unique } from '../util/array.js';
|
|
3
|
+
import { getStartColumnOfTemplateExpression, insertDescriptionCommentStatementBeforeLine, insertDisableCommentStatementBeforeLine, isLineInTemplateLiteral, mergeDescription, mergeRuleIds, parseDisableComment, updateDisableComment, } from '../util/eslint.js';
|
|
4
|
+
import { notEmpty } from '../util/type-check.js';
|
|
5
|
+
function findDisableCommentPerLine(sourceCode, line) {
|
|
6
|
+
const commentsInFile = sourceCode.getAllComments();
|
|
7
|
+
const commentsInPreviousLine = commentsInFile.filter((comment) => comment.loc?.start.line === line - 1);
|
|
8
|
+
return commentsInPreviousLine.map(parseDisableComment).find((comment) => comment?.scope === 'next-line');
|
|
9
|
+
}
|
|
10
|
+
function generateFixesPerLine(context, description, descriptionPosition, line, column, messagesInLine) {
|
|
11
|
+
const { fixer, sourceCode } = context;
|
|
12
|
+
const ruleIdsToDisable = unique(messagesInLine.map((message) => message.ruleId).filter(notEmpty));
|
|
13
|
+
if (ruleIdsToDisable.length === 0)
|
|
14
|
+
return null;
|
|
15
|
+
const disableCommentPerLine = findDisableCommentPerLine(sourceCode, line);
|
|
16
|
+
const fixes = [];
|
|
17
|
+
const isPreviousLine = description !== undefined && descriptionPosition === 'previousLine';
|
|
18
|
+
if (isPreviousLine) {
|
|
19
|
+
fixes.push(insertDescriptionCommentStatementBeforeLine({
|
|
20
|
+
fixer,
|
|
21
|
+
sourceCode,
|
|
22
|
+
line: disableCommentPerLine ? disableCommentPerLine.loc.start.line : line,
|
|
23
|
+
column,
|
|
24
|
+
description,
|
|
25
|
+
}));
|
|
26
|
+
}
|
|
27
|
+
if (disableCommentPerLine) {
|
|
28
|
+
fixes.push(updateDisableComment({
|
|
29
|
+
fixer,
|
|
30
|
+
disableComment: disableCommentPerLine,
|
|
31
|
+
newRules: mergeRuleIds(disableCommentPerLine.ruleIds, ruleIdsToDisable),
|
|
32
|
+
newDescription: isPreviousLine ?
|
|
33
|
+
disableCommentPerLine.description
|
|
34
|
+
: mergeDescription(disableCommentPerLine.description, description),
|
|
35
|
+
}));
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
fixes.push(insertDisableCommentStatementBeforeLine({
|
|
39
|
+
fixer,
|
|
40
|
+
sourceCode,
|
|
41
|
+
line,
|
|
42
|
+
column,
|
|
43
|
+
scope: 'next-line',
|
|
44
|
+
ruleIds: ruleIdsToDisable,
|
|
45
|
+
description: isPreviousLine ? undefined : description,
|
|
46
|
+
}));
|
|
47
|
+
}
|
|
48
|
+
return mergeFixes(fixes, context.sourceCode);
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Create fix to add disable comment per line.
|
|
52
|
+
*/
|
|
53
|
+
export function createFixToDisablePerLine(context, args) {
|
|
54
|
+
const groupedMessages = groupBy(context.messages, (message) => {
|
|
55
|
+
if (isLineInTemplateLiteral(context.sourceCode, message.line)) {
|
|
56
|
+
const column = getStartColumnOfTemplateExpression(context.sourceCode, message);
|
|
57
|
+
return `${message.line}:${column}`;
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
return `${message.line}:0`;
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
const fixes = [];
|
|
64
|
+
for (const [lineAndColumn, messagesInLine] of groupedMessages) {
|
|
65
|
+
const [line, column] = lineAndColumn.split(':').map(Number);
|
|
66
|
+
const fix = generateFixesPerLine(context, args.description, args.descriptionPosition, line, column, messagesInLine);
|
|
67
|
+
if (fix)
|
|
68
|
+
fixes.push(fix);
|
|
69
|
+
}
|
|
70
|
+
return fixes;
|
|
71
|
+
}
|
|
72
|
+
//# sourceMappingURL=disable-per-line.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"disable-per-line.js","sourceRoot":"","sources":["../../src/fix/disable-per-line.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { Linter, Rule, SourceCode } from 'eslint';
|
|
2
|
+
export { verifyAndFix } from '../eslint/linter.js';
|
|
3
|
+
export { type SuggestionFilter, type FixToApplySuggestionsArgs, createFixToApplySuggestions, } from './apply-suggestions.js';
|
|
4
|
+
export { type FixToApplyAutoFixesArgs, createFixToApplyAutoFixes } from './apply-auto-fixes.js';
|
|
5
|
+
export { type FixToDisablePerFileArgs, createFixToDisablePerFile } from './disable-per-file.js';
|
|
6
|
+
export { type FixToDisablePerLineArgs, createFixToDisablePerLine } from './disable-per-line.js';
|
|
7
|
+
export { type FixToConvertErrorToWarningPerFileArgs, createFixToConvertErrorToWarningPerFile, } from './convert-error-to-warning-per-file.js';
|
|
8
|
+
export { type FixableMaker, type FixToMakeFixableAndFixArgs, createFixToMakeFixableAndFix, } from './make-fixable-and-fix.js';
|
|
9
|
+
/**
|
|
10
|
+
* The type representing the additional information for the fix.
|
|
11
|
+
*/
|
|
12
|
+
export type FixContext = {
|
|
13
|
+
filename: string;
|
|
14
|
+
sourceCode: SourceCode;
|
|
15
|
+
messages: Linter.LintMessage[];
|
|
16
|
+
ruleIds: string[];
|
|
17
|
+
fixer: Rule.RuleFixer;
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/fix/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEvD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,OAAO,EACL,KAAK,gBAAgB,EACrB,KAAK,yBAAyB,EAC9B,2BAA2B,GAC5B,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,KAAK,uBAAuB,EAAE,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AAChG,OAAO,EAAE,KAAK,uBAAuB,EAAE,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AAChG,OAAO,EAAE,KAAK,uBAAuB,EAAE,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AAChG,OAAO,EACL,KAAK,qCAAqC,EAC1C,uCAAuC,GACxC,MAAM,wCAAwC,CAAC;AAChD,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,0BAA0B,EAC/B,4BAA4B,GAC7B,MAAM,2BAA2B,CAAC;AAEnC;;GAEG;AACH,MAAM,MAAM,UAAU,GAAG;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,UAAU,CAAC;IACvB,QAAQ,EAAE,MAAM,CAAC,WAAW,EAAE,CAAC;IAC/B,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC;CACvB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { verifyAndFix } from '../eslint/linter.js';
|
|
2
|
+
export { createFixToApplySuggestions, } from './apply-suggestions.js';
|
|
3
|
+
export { createFixToApplyAutoFixes } from './apply-auto-fixes.js';
|
|
4
|
+
export { createFixToDisablePerFile } from './disable-per-file.js';
|
|
5
|
+
export { createFixToDisablePerLine } from './disable-per-line.js';
|
|
6
|
+
export { createFixToConvertErrorToWarningPerFile, } from './convert-error-to-warning-per-file.js';
|
|
7
|
+
export { createFixToMakeFixableAndFix, } from './make-fixable-and-fix.js';
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/fix/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,OAAO,EAGL,2BAA2B,GAC5B,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAgC,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AAChG,OAAO,EAAgC,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AAChG,OAAO,EAAgC,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AAChG,OAAO,EAEL,uCAAuC,GACxC,MAAM,wCAAwC,CAAC;AAChD,OAAO,EAGL,4BAA4B,GAC7B,MAAM,2BAA2B,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { AST, Linter, Rule } from 'eslint';
|
|
2
|
+
import type { FixContext } from './index.js';
|
|
3
|
+
export type FixableMaker = (message: Linter.LintMessage, range: AST.Range, context: FixContext) => Rule.Fix | null | undefined;
|
|
4
|
+
export type FixToMakeFixableAndFixArgs = {
|
|
5
|
+
fixableMaker: FixableMaker;
|
|
6
|
+
};
|
|
7
|
+
/**
|
|
8
|
+
* Create fix to make fixable and fix.
|
|
9
|
+
*/
|
|
10
|
+
export declare function createFixToMakeFixableAndFix(context: FixContext, args: FixToMakeFixableAndFixArgs): Rule.Fix[];
|
|
11
|
+
//# sourceMappingURL=make-fixable-and-fix.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"make-fixable-and-fix.d.ts","sourceRoot":"","sources":["../../src/fix/make-fixable-and-fix.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAc,MAAM,QAAQ,CAAC;AAC5D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAE7C,MAAM,MAAM,YAAY,GAAG,CACzB,OAAO,EAAE,MAAM,CAAC,WAAW,EAC3B,KAAK,EAAE,GAAG,CAAC,KAAK,EAChB,OAAO,EAAE,UAAU,KAChB,IAAI,CAAC,GAAG,GAAG,IAAI,GAAG,SAAS,CAAC;AAEjC,MAAM,MAAM,0BAA0B,GAAG;IACvC,YAAY,EAAE,YAAY,CAAC;CAC5B,CAAC;AA8BF;;GAEG;AACH,wBAAgB,4BAA4B,CAAC,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,0BAA0B,GAAG,IAAI,CAAC,GAAG,EAAE,CAE9G"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
function getMessageRange(sourceCode, message) {
|
|
2
|
+
const index = sourceCode.getIndexFromLoc({
|
|
3
|
+
line: message.line,
|
|
4
|
+
// NOTE: `column` of `ESLint.LintMessage` is 1-based, but `column` of `ESTree.Position` is 0-based.
|
|
5
|
+
column: message.column - 1,
|
|
6
|
+
});
|
|
7
|
+
if (message.endLine && message.endColumn) {
|
|
8
|
+
const endIndex = sourceCode.getIndexFromLoc({
|
|
9
|
+
line: message.endLine,
|
|
10
|
+
// NOTE: `column` of `ESLint.LintMessage` is 1-based, but `column` of `ESTree.Position` is 0-based.
|
|
11
|
+
column: message.endColumn - 1,
|
|
12
|
+
});
|
|
13
|
+
return [index, endIndex];
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
return [index, index];
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
function generateFixes(context, args) {
|
|
20
|
+
const fixes = [];
|
|
21
|
+
for (const message of context.messages) {
|
|
22
|
+
const range = getMessageRange(context.sourceCode, message);
|
|
23
|
+
const fix = args.fixableMaker(message, range, context);
|
|
24
|
+
if (fix)
|
|
25
|
+
fixes.push(fix);
|
|
26
|
+
}
|
|
27
|
+
return fixes;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Create fix to make fixable and fix.
|
|
31
|
+
*/
|
|
32
|
+
export function createFixToMakeFixableAndFix(context, args) {
|
|
33
|
+
return generateFixes(context, args);
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=make-fixable-and-fix.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"make-fixable-and-fix.js","sourceRoot":"","sources":["../../src/fix/make-fixable-and-fix.ts"],"names":[],"mappings":"AAaA,SAAS,eAAe,CAAC,UAAsB,EAAE,OAA2B;IAC1E,MAAM,KAAK,GAAG,UAAU,CAAC,eAAe,CAAC;QACvC,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,mGAAmG;QACnG,MAAM,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC;KAC3B,CAAC,CAAC;IACH,IAAI,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;QACzC,MAAM,QAAQ,GAAG,UAAU,CAAC,eAAe,CAAC;YAC1C,IAAI,EAAE,OAAO,CAAC,OAAO;YACrB,mGAAmG;YACnG,MAAM,EAAE,OAAO,CAAC,SAAS,GAAG,CAAC;SAC9B,CAAC,CAAC;QACH,OAAO,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IAC3B,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACxB,CAAC;AACH,CAAC;AAED,SAAS,aAAa,CAAC,OAAmB,EAAE,IAAgC;IAC1E,MAAM,KAAK,GAAe,EAAE,CAAC;IAC7B,KAAK,MAAM,OAAO,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;QACvC,MAAM,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAC3D,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;QACvD,IAAI,GAAG;YAAE,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC3B,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,4BAA4B,CAAC,OAAmB,EAAE,IAAgC;IAChG,OAAO,aAAa,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AACtC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"colors.d.ts","sourceRoot":"","sources":["../../src/formatter/colors.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,YAAY,EAAG,WAAoB,CAAC;AACjD,eAAO,MAAM,WAAW,EAAG,KAAc,CAAC;AAC1C,eAAO,MAAM,aAAa,EAAG,QAAiB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"colors.js","sourceRoot":"","sources":["../../src/formatter/colors.ts"],"names":[],"mappings":"AAAA,0BAA0B;AAE1B,MAAM,CAAC,MAAM,YAAY,GAAG,WAAoB,CAAC;AACjD,MAAM,CAAC,MAAM,WAAW,GAAG,KAAc,CAAC;AAC1C,MAAM,CAAC,MAAM,aAAa,GAAG,QAAiB,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { FilterCriterion } from '../type.js';
|
|
2
|
+
import type { RuleStatistic } from './take-rule-statistics.js';
|
|
3
|
+
/**
|
|
4
|
+
* Filter rule statistics by the given criteria.
|
|
5
|
+
* Multiple criteria are OR-ed together; a statistic is kept if it matches any of them.
|
|
6
|
+
* When `criteria` is undefined or empty, the input is returned unchanged.
|
|
7
|
+
*/
|
|
8
|
+
export declare function filterRuleStatistics(statistics: RuleStatistic[], criteria: readonly FilterCriterion[] | undefined): RuleStatistic[];
|
|
9
|
+
//# sourceMappingURL=filter-rule-statistics.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"filter-rule-statistics.d.ts","sourceRoot":"","sources":["../../src/formatter/filter-rule-statistics.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAElD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAa/D;;;;GAIG;AACH,wBAAgB,oBAAoB,CAClC,UAAU,EAAE,aAAa,EAAE,EAC3B,QAAQ,EAAE,SAAS,eAAe,EAAE,GAAG,SAAS,GAC/C,aAAa,EAAE,CAGjB"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { unreachable } from '../util/type-check.js';
|
|
2
|
+
function matchesCriterion(statistic, criterion) {
|
|
3
|
+
switch (criterion) {
|
|
4
|
+
case 'fixable':
|
|
5
|
+
return statistic.isFixableCount > 0;
|
|
6
|
+
case 'has-suggestions':
|
|
7
|
+
return statistic.hasSuggestionsCount > 0;
|
|
8
|
+
default:
|
|
9
|
+
return unreachable(`Invalid filter criterion: ${criterion}`);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Filter rule statistics by the given criteria.
|
|
14
|
+
* Multiple criteria are OR-ed together; a statistic is kept if it matches any of them.
|
|
15
|
+
* When `criteria` is undefined or empty, the input is returned unchanged.
|
|
16
|
+
*/
|
|
17
|
+
export function filterRuleStatistics(statistics, criteria) {
|
|
18
|
+
if (!criteria || criteria.length === 0)
|
|
19
|
+
return statistics;
|
|
20
|
+
return statistics.filter((statistic) => criteria.some((criterion) => matchesCriterion(statistic, criterion)));
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=filter-rule-statistics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"filter-rule-statistics.js","sourceRoot":"","sources":["../../src/formatter/filter-rule-statistics.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAGpD,SAAS,gBAAgB,CAAC,SAAwB,EAAE,SAA0B;IAC5E,QAAQ,SAAS,EAAE,CAAC;QAClB,KAAK,SAAS;YACZ,OAAO,SAAS,CAAC,cAAc,GAAG,CAAC,CAAC;QACtC,KAAK,iBAAiB;YACpB,OAAO,SAAS,CAAC,mBAAmB,GAAG,CAAC,CAAC;QAC3C;YACE,OAAO,WAAW,CAAC,6BAA6B,SAAmB,EAAE,CAAC,CAAC;IAC3E,CAAC;AACH,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,oBAAoB,CAClC,UAA2B,EAC3B,QAAgD;IAEhD,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,UAAU,CAAC;IAC1D,OAAO,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,gBAAgB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;AAChH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"format-by-files.d.ts","sourceRoot":"","sources":["../../src/formatter/format-by-files.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAOrC,wBAAgB,aAAa,CAAC,OAAO,EAAE,MAAM,CAAC,UAAU,EAAE,GAAG,MAAM,CAuClE"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
// eslint-disable-next-line n/no-unsupported-features/node-builtins
|
|
2
|
+
import { styleText } from 'node:util';
|
|
3
|
+
import { ERROR_COLOR, FAILED_COLOR, WARNING_COLOR } from './colors.js';
|
|
4
|
+
function pluralize(word, count) {
|
|
5
|
+
return count > 1 ? `${word}s` : word;
|
|
6
|
+
}
|
|
7
|
+
export function formatByFiles(results) {
|
|
8
|
+
let errorCount = 0;
|
|
9
|
+
let failureCount = 0;
|
|
10
|
+
let passCount = 0;
|
|
11
|
+
let warningCount = 0;
|
|
12
|
+
results.forEach((result) => {
|
|
13
|
+
const messages = result.messages;
|
|
14
|
+
if (messages.length === 0) {
|
|
15
|
+
passCount++;
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
failureCount++;
|
|
19
|
+
warningCount += result.warningCount;
|
|
20
|
+
errorCount += result.errorCount;
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
const fileCount = passCount + failureCount;
|
|
24
|
+
const problemCount = errorCount + warningCount;
|
|
25
|
+
let summary = '';
|
|
26
|
+
summary += `- ${fileCount} ${pluralize('file', fileCount)}`;
|
|
27
|
+
summary += ' (';
|
|
28
|
+
summary += `${passCount} ${pluralize('file', passCount)} passed`;
|
|
29
|
+
summary += ', ';
|
|
30
|
+
summary += styleText(FAILED_COLOR, `${failureCount} ${pluralize('file', failureCount)} failed`);
|
|
31
|
+
summary += ') checked.\n';
|
|
32
|
+
if (problemCount > 0) {
|
|
33
|
+
summary += `- ${problemCount} ${pluralize('problem', problemCount)}`;
|
|
34
|
+
summary += ' (';
|
|
35
|
+
summary += styleText(ERROR_COLOR, `${errorCount} ${pluralize('error', errorCount)}`);
|
|
36
|
+
summary += ', ';
|
|
37
|
+
summary += styleText(WARNING_COLOR, `${warningCount} ${pluralize('warning', warningCount)}`);
|
|
38
|
+
summary += ') found.';
|
|
39
|
+
}
|
|
40
|
+
return styleText('bold', summary);
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=format-by-files.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"format-by-files.js","sourceRoot":"","sources":["../../src/formatter/format-by-files.ts"],"names":[],"mappings":"AAAA,mEAAmE;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAEtC,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAEvE,SAAS,SAAS,CAAC,IAAY,EAAE,KAAa;IAC5C,OAAO,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;AACvC,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,OAA4B;IACxD,IAAI,UAAU,GAAG,CAAC,CAAC;IACnB,IAAI,YAAY,GAAG,CAAC,CAAC;IACrB,IAAI,SAAS,GAAG,CAAC,CAAC;IAClB,IAAI,YAAY,GAAG,CAAC,CAAC;IAErB,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;QACzB,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAEjC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC1B,SAAS,EAAE,CAAC;QACd,CAAC;aAAM,CAAC;YACN,YAAY,EAAE,CAAC;YACf,YAAY,IAAI,MAAM,CAAC,YAAY,CAAC;YACpC,UAAU,IAAI,MAAM,CAAC,UAAU,CAAC;QAClC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,MAAM,SAAS,GAAG,SAAS,GAAG,YAAY,CAAC;IAC3C,MAAM,YAAY,GAAG,UAAU,GAAG,YAAY,CAAC;IAE/C,IAAI,OAAO,GAAG,EAAE,CAAC;IACjB,OAAO,IAAI,KAAK,SAAS,IAAI,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC,EAAE,CAAC;IAC5D,OAAO,IAAI,IAAI,CAAC;IAChB,OAAO,IAAI,GAAG,SAAS,IAAI,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC,SAAS,CAAC;IACjE,OAAO,IAAI,IAAI,CAAC;IAChB,OAAO,IAAI,SAAS,CAAC,YAAY,EAAE,GAAG,YAAY,IAAI,SAAS,CAAC,MAAM,EAAE,YAAY,CAAC,SAAS,CAAC,CAAC;IAChG,OAAO,IAAI,cAAc,CAAC;IAE1B,IAAI,YAAY,GAAG,CAAC,EAAE,CAAC;QACrB,OAAO,IAAI,KAAK,YAAY,IAAI,SAAS,CAAC,SAAS,EAAE,YAAY,CAAC,EAAE,CAAC;QACrE,OAAO,IAAI,IAAI,CAAC;QAChB,OAAO,IAAI,SAAS,CAAC,WAAW,EAAE,GAAG,UAAU,IAAI,SAAS,CAAC,OAAO,EAAE,UAAU,CAAC,EAAE,CAAC,CAAC;QACrF,OAAO,IAAI,IAAI,CAAC;QAChB,OAAO,IAAI,SAAS,CAAC,aAAa,EAAE,GAAG,YAAY,IAAI,SAAS,CAAC,SAAS,EAAE,YAAY,CAAC,EAAE,CAAC,CAAC;QAC7F,OAAO,IAAI,UAAU,CAAC;IACxB,CAAC;IAED,OAAO,SAAS,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AACpC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ESLint } from 'eslint';
|
|
2
|
+
import type { FilterCriterion, SortField, SortOrder } from '../type.js';
|
|
3
|
+
export type FormatByRulesOptions = {
|
|
4
|
+
sort?: SortField | undefined;
|
|
5
|
+
sortOrder?: SortOrder | undefined;
|
|
6
|
+
filters?: FilterCriterion[] | undefined;
|
|
7
|
+
};
|
|
8
|
+
export declare function formatByRules(results: ESLint.LintResult[], data?: ESLint.LintResultData, options?: FormatByRulesOptions): string;
|
|
9
|
+
//# sourceMappingURL=format-by-rules.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"format-by-rules.d.ts","sourceRoot":"","sources":["../../src/formatter/format-by-rules.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,KAAK,EAAE,eAAe,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAkBxE,MAAM,MAAM,oBAAoB,GAAG;IACjC,IAAI,CAAC,EAAE,SAAS,GAAG,SAAS,CAAC;IAC7B,SAAS,CAAC,EAAE,SAAS,GAAG,SAAS,CAAC;IAClC,OAAO,CAAC,EAAE,eAAe,EAAE,GAAG,SAAS,CAAC;CACzC,CAAC;AAMF,wBAAgB,aAAa,CAC3B,OAAO,EAAE,MAAM,CAAC,UAAU,EAAE,EAC5B,IAAI,CAAC,EAAE,MAAM,CAAC,cAAc,EAC5B,OAAO,CAAC,EAAE,oBAAoB,GAC7B,MAAM,CAoBR"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
// eslint-disable-next-line n/no-unsupported-features/node-builtins
|
|
2
|
+
import { styleText } from 'node:util';
|
|
3
|
+
import { terminalLink } from '../util/terminal-link.js';
|
|
4
|
+
import { ERROR_COLOR } from './colors.js';
|
|
5
|
+
import { filterRuleStatistics } from './filter-rule-statistics.js';
|
|
6
|
+
import { formatTable } from './format-table.js';
|
|
7
|
+
import { sortRuleStatistics } from './sort-rule-statistics.js';
|
|
8
|
+
import { takeRuleStatistics } from './take-rule-statistics.js';
|
|
9
|
+
const headerRow = ['Rule', 'Error', 'Warning', 'is fixable', 'has suggestions'];
|
|
10
|
+
function numCell(num) {
|
|
11
|
+
return num > 0 ? styleText([ERROR_COLOR, 'bold'], num.toString()) : num.toString();
|
|
12
|
+
}
|
|
13
|
+
export function formatByRules(results, data, options) {
|
|
14
|
+
let ruleStatistics = takeRuleStatistics(results);
|
|
15
|
+
ruleStatistics = filterRuleStatistics(ruleStatistics, options?.filters);
|
|
16
|
+
if (options?.sort) {
|
|
17
|
+
ruleStatistics = sortRuleStatistics(ruleStatistics, options.sort, options.sortOrder);
|
|
18
|
+
}
|
|
19
|
+
const rows = [];
|
|
20
|
+
ruleStatistics.forEach((ruleStatistic) => {
|
|
21
|
+
const { ruleId, errorCount, warningCount, isFixableCount, hasSuggestionsCount } = ruleStatistic;
|
|
22
|
+
const ruleMetaData = data?.rulesMeta[ruleId];
|
|
23
|
+
rows.push([
|
|
24
|
+
ruleMetaData?.docs?.url ? terminalLink(ruleId, ruleMetaData?.docs.url) : ruleId,
|
|
25
|
+
numCell(errorCount),
|
|
26
|
+
numCell(warningCount),
|
|
27
|
+
numCell(isFixableCount),
|
|
28
|
+
numCell(hasSuggestionsCount),
|
|
29
|
+
]);
|
|
30
|
+
});
|
|
31
|
+
return formatTable(headerRow, rows);
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=format-by-rules.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"format-by-rules.js","sourceRoot":"","sources":["../../src/formatter/format-by-rules.ts"],"names":[],"mappings":"AAAA,mEAAmE;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAGtC,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAE/D,MAAM,SAAS,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,iBAAiB,CAAC,CAAC;AAgBhF,SAAS,OAAO,CAAC,GAAW;IAC1B,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,MAAM,CAAC,EAAE,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;AACrF,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,OAA4B,EAC5B,IAA4B,EAC5B,OAA8B;IAE9B,IAAI,cAAc,GAAG,kBAAkB,CAAC,OAAO,CAAC,CAAC;IACjD,cAAc,GAAG,oBAAoB,CAAC,cAAc,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;IACxE,IAAI,OAAO,EAAE,IAAI,EAAE,CAAC;QAClB,cAAc,GAAG,kBAAkB,CAAC,cAAc,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;IACvF,CAAC;IAED,MAAM,IAAI,GAAU,EAAE,CAAC;IACvB,cAAc,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,EAAE;QACvC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,YAAY,EAAE,cAAc,EAAE,mBAAmB,EAAE,GAAG,aAAa,CAAC;QAChG,MAAM,YAAY,GAAG,IAAI,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC;QAC7C,IAAI,CAAC,IAAI,CAAC;YACR,YAAY,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,EAAE,YAAY,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM;YAC/E,OAAO,CAAC,UAAU,CAAC;YACnB,OAAO,CAAC,YAAY,CAAC;YACrB,OAAO,CAAC,cAAc,CAAC;YACvB,OAAO,CAAC,mBAAmB,CAAC;SAC7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IACH,OAAO,WAAW,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACtC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"format-table.d.ts","sourceRoot":"","sources":["../../src/formatter/format-table.ts"],"names":[],"mappings":"AAKA,KAAK,GAAG,GAAG,MAAM,EAAE,CAAC;AAEpB,wBAAgB,WAAW,CAAC,SAAS,EAAE,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,GAAG,MAAM,CA2BnE"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { stripVTControlCharacters } from 'node:util';
|
|
2
|
+
const CELL_PADDING_LEFT = 1;
|
|
3
|
+
const CELL_PADDING_RIGHT = 1;
|
|
4
|
+
export function formatTable(headerRow, bodyRows) {
|
|
5
|
+
if (bodyRows.length === 0) {
|
|
6
|
+
throw new Error('`bodyRows` must not be empty');
|
|
7
|
+
}
|
|
8
|
+
const columnCount = headerRow.length;
|
|
9
|
+
const columnWidths = Array(columnCount).fill(0);
|
|
10
|
+
for (const row of [headerRow, ...bodyRows]) {
|
|
11
|
+
for (let i = 0; i < columnCount; i++) {
|
|
12
|
+
columnWidths[i] = Math.max(columnWidths[i], stripVTControlCharacters(row[i]).length + CELL_PADDING_LEFT + CELL_PADDING_RIGHT);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
let result = '';
|
|
16
|
+
result += formatBorderLine(columnWidths, 'top') + '\n';
|
|
17
|
+
result += formatRow(headerRow, columnWidths) + '\n';
|
|
18
|
+
result += formatBorderLine(columnWidths, 'middle') + '\n';
|
|
19
|
+
for (let i = 0; i < bodyRows.length; i++) {
|
|
20
|
+
result += formatRow(bodyRows[i], columnWidths) + '\n';
|
|
21
|
+
if (i < bodyRows.length - 1) {
|
|
22
|
+
result += formatBorderLine(columnWidths, 'middle') + '\n';
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
result += formatBorderLine(columnWidths, 'bottom') + '\n';
|
|
26
|
+
return result;
|
|
27
|
+
}
|
|
28
|
+
function formatBorderLine(columnWidths, type) {
|
|
29
|
+
let result = '';
|
|
30
|
+
result +=
|
|
31
|
+
type === 'top' ? '╔'
|
|
32
|
+
: type === 'middle' ? '╟'
|
|
33
|
+
: '╚';
|
|
34
|
+
for (let j = 0; j < columnWidths.length; j++) {
|
|
35
|
+
result += (type === 'middle' ? '─' : '═').repeat(columnWidths[j]);
|
|
36
|
+
if (j < columnWidths.length - 1) {
|
|
37
|
+
result +=
|
|
38
|
+
type === 'top' ? '╤'
|
|
39
|
+
: type === 'middle' ? '┼'
|
|
40
|
+
: '╧';
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
result +=
|
|
44
|
+
type === 'top' ? '╗'
|
|
45
|
+
: type === 'middle' ? '╢'
|
|
46
|
+
: '╝';
|
|
47
|
+
return result;
|
|
48
|
+
}
|
|
49
|
+
function formatRow(row, columnWidths) {
|
|
50
|
+
let result = '';
|
|
51
|
+
result += '║';
|
|
52
|
+
for (let j = 0; j < columnWidths.length; j++) {
|
|
53
|
+
const cell = ' '.repeat(CELL_PADDING_LEFT) + row[j] + ' '.repeat(CELL_PADDING_RIGHT);
|
|
54
|
+
result += cell + ' '.repeat(columnWidths[j] - stripVTControlCharacters(cell).length);
|
|
55
|
+
if (j < columnWidths.length - 1) {
|
|
56
|
+
result += '│';
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
result += '║';
|
|
60
|
+
return result;
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=format-table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"format-table.js","sourceRoot":"","sources":["../../src/formatter/format-table.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ESLint } from 'eslint';
|
|
2
|
+
import { type FormatByRulesOptions } from './format-by-rules.js';
|
|
3
|
+
export { takeRuleStatistics, type RuleStatistic } from './take-rule-statistics.js';
|
|
4
|
+
export { sortRuleStatistics } from './sort-rule-statistics.js';
|
|
5
|
+
export { filterRuleStatistics } from './filter-rule-statistics.js';
|
|
6
|
+
export declare function format(results: ESLint.LintResult[], data?: ESLint.LintResultData, options?: FormatByRulesOptions): string;
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/formatter/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAErC,OAAO,EAAiB,KAAK,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAEhF,OAAO,EAAE,kBAAkB,EAAE,KAAK,aAAa,EAAE,MAAM,2BAA2B,CAAC;AACnF,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAEnE,wBAAgB,MAAM,CACpB,OAAO,EAAE,MAAM,CAAC,UAAU,EAAE,EAC5B,IAAI,CAAC,EAAE,MAAM,CAAC,cAAc,EAC5B,OAAO,CAAC,EAAE,oBAAoB,GAC7B,MAAM,CAER"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { formatByFiles } from './format-by-files.js';
|
|
2
|
+
import { formatByRules } from './format-by-rules.js';
|
|
3
|
+
export { takeRuleStatistics } from './take-rule-statistics.js';
|
|
4
|
+
export { sortRuleStatistics } from './sort-rule-statistics.js';
|
|
5
|
+
export { filterRuleStatistics } from './filter-rule-statistics.js';
|
|
6
|
+
export function format(results, data, options) {
|
|
7
|
+
return `${formatByFiles(results)}\n${formatByRules(results, data, options)}`;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/formatter/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,aAAa,EAA6B,MAAM,sBAAsB,CAAC;AAEhF,OAAO,EAAE,kBAAkB,EAAsB,MAAM,2BAA2B,CAAC;AACnF,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAEnE,MAAM,UAAU,MAAM,CACpB,OAA4B,EAC5B,IAA4B,EAC5B,OAA8B;IAE9B,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC,KAAK,aAAa,CAAC,OAAO,EAAE,IAAI,EAAE,OAAO,CAAC,EAAE,CAAC;AAC/E,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { SortField, SortOrder } from '../type.js';
|
|
2
|
+
import type { RuleStatistic } from './take-rule-statistics.js';
|
|
3
|
+
/** Sort rule statistics by the specified field and order */
|
|
4
|
+
export declare function sortRuleStatistics(statistics: RuleStatistic[], field: SortField, order?: SortOrder): RuleStatistic[];
|
|
5
|
+
//# sourceMappingURL=sort-rule-statistics.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sort-rule-statistics.d.ts","sourceRoot":"","sources":["../../src/formatter/sort-rule-statistics.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAEvD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAe/D,4DAA4D;AAC5D,wBAAgB,kBAAkB,CAAC,UAAU,EAAE,aAAa,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,EAAE,SAAS,GAAG,aAAa,EAAE,CAgBpH"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { unreachable } from '../util/type-check.js';
|
|
2
|
+
const SORT_FIELD_TO_KEY = {
|
|
3
|
+
rule: 'ruleId',
|
|
4
|
+
error: 'errorCount',
|
|
5
|
+
warning: 'warningCount',
|
|
6
|
+
fixable: 'isFixableCount',
|
|
7
|
+
suggestions: 'hasSuggestionsCount',
|
|
8
|
+
};
|
|
9
|
+
/** Get the default sort order for a given field */
|
|
10
|
+
function getDefaultSortOrder(field) {
|
|
11
|
+
return field === 'rule' ? 'asc' : 'desc';
|
|
12
|
+
}
|
|
13
|
+
/** Sort rule statistics by the specified field and order */
|
|
14
|
+
export function sortRuleStatistics(statistics, field, order) {
|
|
15
|
+
const resolvedOrder = order ?? getDefaultSortOrder(field);
|
|
16
|
+
const key = SORT_FIELD_TO_KEY[field];
|
|
17
|
+
const sorted = [...statistics].sort((a, b) => {
|
|
18
|
+
const aVal = a[key];
|
|
19
|
+
const bVal = b[key];
|
|
20
|
+
if (typeof aVal === 'string' && typeof bVal === 'string') {
|
|
21
|
+
return aVal.localeCompare(bVal);
|
|
22
|
+
}
|
|
23
|
+
else if (typeof aVal === 'number' && typeof bVal === 'number') {
|
|
24
|
+
return aVal - bVal;
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
return unreachable('Invalid sort key type');
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
if (resolvedOrder === 'desc')
|
|
31
|
+
sorted.reverse();
|
|
32
|
+
return sorted;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=sort-rule-statistics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sort-rule-statistics.js","sourceRoot":"","sources":["../../src/formatter/sort-rule-statistics.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAGpD,MAAM,iBAAiB,GAA2C;IAChE,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,YAAY;IACnB,OAAO,EAAE,cAAc;IACvB,OAAO,EAAE,gBAAgB;IACzB,WAAW,EAAE,qBAAqB;CACnC,CAAC;AAEF,mDAAmD;AACnD,SAAS,mBAAmB,CAAC,KAAgB;IAC3C,OAAO,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC;AAC3C,CAAC;AAED,4DAA4D;AAC5D,MAAM,UAAU,kBAAkB,CAAC,UAA2B,EAAE,KAAgB,EAAE,KAAiB;IACjG,MAAM,aAAa,GAAG,KAAK,IAAI,mBAAmB,CAAC,KAAK,CAAC,CAAC;IAC1D,MAAM,GAAG,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACrC,MAAM,MAAM,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QAC3C,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QACpB,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QACpB,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YACzD,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC;aAAM,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YAChE,OAAO,IAAI,GAAG,IAAI,CAAC;QACrB,CAAC;aAAM,CAAC;YACN,OAAO,WAAW,CAAC,uBAAuB,CAAC,CAAC;QAC9C,CAAC;IACH,CAAC,CAAC,CAAC;IACH,IAAI,aAAa,KAAK,MAAM;QAAE,MAAM,CAAC,OAAO,EAAE,CAAC;IAC/C,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { ESLint } from 'eslint';
|
|
2
|
+
/**
|
|
3
|
+
* The type representing the lint results of a rule unit.
|
|
4
|
+
*/
|
|
5
|
+
export type RuleStatistic = {
|
|
6
|
+
ruleId: string;
|
|
7
|
+
errorCount: number;
|
|
8
|
+
warningCount: number;
|
|
9
|
+
isFixableCount: number;
|
|
10
|
+
isFixableErrorCount: number;
|
|
11
|
+
isFixableWarningCount: number;
|
|
12
|
+
hasSuggestionsCount: number;
|
|
13
|
+
hasSuggestionsErrorCount: number;
|
|
14
|
+
hasSuggestionsWarningCount: number;
|
|
15
|
+
};
|
|
16
|
+
/** ルールごとのエラー/警告の件数などの統計を取る */
|
|
17
|
+
export declare function takeRuleStatistics(results: ESLint.LintResult[]): RuleStatistic[];
|
|
18
|
+
//# sourceMappingURL=take-rule-statistics.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"take-rule-statistics.d.ts","sourceRoot":"","sources":["../../src/formatter/take-rule-statistics.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAU,MAAM,QAAQ,CAAC;AAG7C;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,cAAc,EAAE,MAAM,CAAC;IACvB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,qBAAqB,EAAE,MAAM,CAAC;IAC9B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,wBAAwB,EAAE,MAAM,CAAC;IACjC,0BAA0B,EAAE,MAAM,CAAC;CACpC,CAAC;AAoCF,8BAA8B;AAC9B,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,CAAC,UAAU,EAAE,GAAG,aAAa,EAAE,CAYhF"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { groupBy } from '../util/array.js';
|
|
2
|
+
/** 指定されたルールのエラー/警告の件数などの統計を取る */
|
|
3
|
+
function takeRuleStatistic(ruleId, messages) {
|
|
4
|
+
let errorCount = 0;
|
|
5
|
+
let warningCount = 0;
|
|
6
|
+
let isFixableErrorCount = 0;
|
|
7
|
+
let isFixableWarningCount = 0;
|
|
8
|
+
let hasSuggestionsErrorCount = 0;
|
|
9
|
+
let hasSuggestionsWarningCount = 0;
|
|
10
|
+
for (const message of messages) {
|
|
11
|
+
if (message.severity === 2) {
|
|
12
|
+
errorCount++;
|
|
13
|
+
if (message.fix)
|
|
14
|
+
isFixableErrorCount++;
|
|
15
|
+
if (message.suggestions && message.suggestions.length > 0)
|
|
16
|
+
hasSuggestionsErrorCount++;
|
|
17
|
+
}
|
|
18
|
+
else if (message.severity === 1) {
|
|
19
|
+
warningCount++;
|
|
20
|
+
if (message.fix)
|
|
21
|
+
isFixableWarningCount++;
|
|
22
|
+
if (message.suggestions && message.suggestions.length > 0)
|
|
23
|
+
hasSuggestionsWarningCount++;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
return {
|
|
27
|
+
ruleId,
|
|
28
|
+
errorCount,
|
|
29
|
+
warningCount,
|
|
30
|
+
isFixableCount: isFixableErrorCount + isFixableWarningCount,
|
|
31
|
+
isFixableErrorCount,
|
|
32
|
+
isFixableWarningCount,
|
|
33
|
+
hasSuggestionsCount: hasSuggestionsErrorCount + hasSuggestionsWarningCount,
|
|
34
|
+
hasSuggestionsErrorCount,
|
|
35
|
+
hasSuggestionsWarningCount,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
/** ルールごとのエラー/警告の件数などの統計を取る */
|
|
39
|
+
export function takeRuleStatistics(results) {
|
|
40
|
+
const messages = results.flatMap((result) => result.messages).filter((message) => message.ruleId !== null);
|
|
41
|
+
const ruleIdToMessages = groupBy(messages, (message) => message.ruleId);
|
|
42
|
+
const ruleStatistics = [];
|
|
43
|
+
for (const [ruleId, messages] of ruleIdToMessages) {
|
|
44
|
+
// NOTE: Exclude problems with a null `ruleId`.
|
|
45
|
+
// ref: ref: https://github.com/eslint/eslint/blob/f1b7499a5162d3be918328ce496eb80692353a5a/docs/developer-guide/nodejs-api.md?plain=1#L372
|
|
46
|
+
if (ruleId !== null)
|
|
47
|
+
ruleStatistics.push(takeRuleStatistic(ruleId, messages));
|
|
48
|
+
}
|
|
49
|
+
return ruleStatistics;
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=take-rule-statistics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"take-rule-statistics.js","sourceRoot":"","sources":["../../src/formatter/take-rule-statistics.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAiB3C,iCAAiC;AACjC,SAAS,iBAAiB,CAAC,MAAc,EAAE,QAA8B;IACvE,IAAI,UAAU,GAAG,CAAC,CAAC;IACnB,IAAI,YAAY,GAAG,CAAC,CAAC;IACrB,IAAI,mBAAmB,GAAG,CAAC,CAAC;IAC5B,IAAI,qBAAqB,GAAG,CAAC,CAAC;IAC9B,IAAI,wBAAwB,GAAG,CAAC,CAAC;IACjC,IAAI,0BAA0B,GAAG,CAAC,CAAC;IAEnC,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,IAAI,OAAO,CAAC,QAAQ,KAAK,CAAC,EAAE,CAAC;YAC3B,UAAU,EAAE,CAAC;YACb,IAAI,OAAO,CAAC,GAAG;gBAAE,mBAAmB,EAAE,CAAC;YACvC,IAAI,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC;gBAAE,wBAAwB,EAAE,CAAC;QACxF,CAAC;aAAM,IAAI,OAAO,CAAC,QAAQ,KAAK,CAAC,EAAE,CAAC;YAClC,YAAY,EAAE,CAAC;YACf,IAAI,OAAO,CAAC,GAAG;gBAAE,qBAAqB,EAAE,CAAC;YACzC,IAAI,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC;gBAAE,0BAA0B,EAAE,CAAC;QAC1F,CAAC;IACH,CAAC;IAED,OAAO;QACL,MAAM;QACN,UAAU;QACV,YAAY;QACZ,cAAc,EAAE,mBAAmB,GAAG,qBAAqB;QAC3D,mBAAmB;QACnB,qBAAqB;QACrB,mBAAmB,EAAE,wBAAwB,GAAG,0BAA0B;QAC1E,wBAAwB;QACxB,0BAA0B;KAC3B,CAAC;AACJ,CAAC;AAED,8BAA8B;AAC9B,MAAM,UAAU,kBAAkB,CAAC,OAA4B;IAC7D,MAAM,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,KAAK,IAAI,CAAC,CAAC;IAE3G,MAAM,gBAAgB,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAExE,MAAM,cAAc,GAAoB,EAAE,CAAC;IAC3C,KAAK,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,IAAI,gBAAgB,EAAE,CAAC;QAClD,+CAA+C;QAC/C,2IAA2I;QAC3I,IAAI,MAAM,KAAK,IAAI;YAAE,cAAc,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;IAChF,CAAC;IACD,OAAO,cAAc,CAAC;AACxB,CAAC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { run, type Options } from './cli/run.js';
|
|
2
|
+
export { Core } from './core.js';
|
|
3
|
+
export { type SortField, type SortOrder, type FilterCriterion, type Config } from './type.js';
|
|
4
|
+
export { takeRuleStatistics, type RuleStatistic, sortRuleStatistics } from './formatter/index.js';
|
|
5
|
+
export { type FixableMaker, type SuggestionFilter, type FixContext } from './fix/index.js';
|
|
6
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,KAAK,OAAO,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,SAAS,EAAE,KAAK,eAAe,EAAE,KAAK,MAAM,EAAE,MAAM,WAAW,CAAC;AAC9F,OAAO,EAAE,kBAAkB,EAAE,KAAK,aAAa,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAClG,OAAO,EAAE,KAAK,YAAY,EAAE,KAAK,gBAAgB,EAAE,KAAK,UAAU,EAAE,MAAM,gBAAgB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAgB,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAqE,MAAM,WAAW,CAAC;AAC9F,OAAO,EAAE,kBAAkB,EAAsB,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAClG,OAAO,EAA6D,MAAM,gBAAgB,CAAC"}
|