-
Notifications
You must be signed in to change notification settings - Fork 57
/
Copy pathutils.ts
96 lines (80 loc) · 2.46 KB
/
utils.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
import type { PluginContext } from 'rollup'
import { existsSync } from 'node:fs'
import type { Options, ESLint, OutputFixes } from './types'
export function parseRequest(id: string) {
return id.split('?', 2)[0]
}
export function isVirtualModule(file: string) {
return !existsSync(file)
}
export function pickESLintOptions(options: Options): ESLint.Options {
const {
// eslint-disable-next-line @typescript-eslint/no-unused-vars
eslintPath,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
lintOnStart,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
include,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
exclude,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
formatter,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
emitWarning,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
emitError,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
failOnWarning,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
failOnError,
...eslintOptions
} = options
return eslintOptions
}
export async function to<R, E = Error>(promise: Promise<R>) {
return promise
.then<[null, R]>((data) => [null, data])
.catch<[E, undefined]>((error: E) => [error, undefined])
}
export async function checkModule(
ctx: PluginContext,
eslint: ESLint,
files: string | string[],
options: Options,
formatter: ESLint.Formatter['format'],
outputFixes: OutputFixes
) {
const [error, report] = await to(eslint.lintFiles(files))
if (error) {
return Promise.reject(error)
}
const hasWarning = report.some((item) => item.warningCount > 0)
const hasError = report.some((item) => item.errorCount > 0)
const result = formatter(report)
// Auto fix error
if (options.fix && report) {
const [error] = await to(outputFixes(report))
if (error) {
return Promise.reject(error)
}
}
// Throw warning message
if (hasWarning && options.emitWarning) {
const warning = typeof result === 'string' ? result : await result
if (options.failOnWarning) {
ctx.error(warning)
} else {
ctx.warn(warning)
}
}
// Throw error message
if (hasError && options.emitError) {
const error = typeof result === 'string' ? result : await result
if (options.failOnError) {
ctx.error(error)
} else {
console.log(error)
}
}
return Promise.resolve()
}