-
-
Notifications
You must be signed in to change notification settings - Fork 48
/
Copy pathrender-rules.ts
105 lines (89 loc) · 3.35 KB
/
render-rules.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
97
98
99
100
101
102
103
104
105
import type { RuleModule } from "../src/types"
import { rules } from "../src/utils/rules"
const categories = [
"Possible Errors",
"Security Vulnerability",
"Best Practices",
"Stylistic Issues",
"Extension Rules",
"System",
] as const
const descriptions: Record<typeof categories[number], string> = {
"Possible Errors":
"These rules relate to possible syntax or logic errors in Svelte code:",
"Security Vulnerability":
"These rules relate to security vulnerabilities in Svelte code:",
"Best Practices":
"These rules relate to better ways of doing things to help you avoid problems:",
"Stylistic Issues":
"These rules relate to style guidelines, and are therefore quite subjective:",
"Extension Rules":
"These rules extend the rules provided by ESLint itself to work well in Svelte:",
System: "These rules relate to this plugin works:",
}
const activeRules = rules.filter((rule) => !rule.meta.deprecated)
const svelteRules = activeRules
const deprecatedRules = rules.filter((rule) => rule.meta.deprecated)
activeRules.forEach((rule) => {
if (!categories.includes(rule.meta.docs.category)) {
throw new Error(`missing categories:${rule.meta.docs.category}`)
}
})
const categoryRules = categories.map((cat) => {
return {
title: cat,
rules: svelteRules.filter((rule) => rule.meta.docs.category === cat),
}
})
//eslint-disable-next-line require-jsdoc -- ignore
export default function renderRulesTableContent(
buildRulePath = (ruleName: string) => `./rules/${ruleName}.md`,
): string {
// -----------------------------------------------------------------------------
//eslint-disable-next-line require-jsdoc -- ignore
function toRuleRow(rule: RuleModule) {
const mark = `${rule.meta.docs.recommended ? ":star:" : ""}${
rule.meta.fixable ? ":wrench:" : ""
}${rule.meta.deprecated ? ":warning:" : ""}`
const link = `[${rule.meta.docs.ruleId}](${buildRulePath(
rule.meta.docs.ruleName || "",
)})`
const description = rule.meta.docs.description || "(no description)"
return `| ${link} | ${description} | ${mark} |`
}
//eslint-disable-next-line require-jsdoc -- ignore
function toDeprecatedRuleRow(rule: RuleModule) {
const link = `[${rule.meta.docs.ruleId}](${buildRulePath(
rule.meta.docs.ruleName || "",
)})`
const replacedRules = rule.meta.replacedBy || []
const replacedBy = replacedRules
.map((name) => `[svelte/${name}](${buildRulePath(name)})`)
.join(", ")
return `| ${link} | ${replacedBy || "(no replacement)"} |`
}
// -----------------------------------------------------------------------------
let rulesTableContent = categoryRules
.map((cat) => {
return `
## ${cat.title}
${descriptions[cat.title]}
| Rule ID | Description | |
|:--------|:------------|:---|
${cat.rules.map(toRuleRow).join("\n")}
`
})
.join("")
// -----------------------------------------------------------------------------
if (deprecatedRules.length >= 1) {
rulesTableContent += `
## Deprecated
- :warning: We're going to remove deprecated rules in the next major release. Please migrate to successor/new rules.
- :innocent: We don't fix bugs which are in deprecated rules since we don't have enough resources.
| Rule ID | Replaced by |
|:--------|:------------|
${deprecatedRules.map(toDeprecatedRuleRow).join("\n")}
`
}
return rulesTableContent
}