/
new-rule.js
108 lines (92 loc) · 2.18 KB
/
new-rule.js
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
106
107
108
/**
* @author Toru Nagashima <https://github.com/mysticatea>
* See LICENSE file in root directory for full license.
*/
"use strict"
const cp = require("child_process")
const fs = require("fs")
const path = require("path")
const logger = console
// main
;(ruleId => {
if (ruleId == null) {
logger.error("Usage: npm run new <RuleID>")
process.exitCode = 1
return
}
if (!/^[\w-]+$/u.test(ruleId)) {
logger.error("Invalid RuleID '%s'.", ruleId)
process.exitCode = 1
return
}
const ruleFile = path.resolve(__dirname, `../lib/rules/${ruleId}.js`)
const testFile = path.resolve(__dirname, `../tests/lib/rules/${ruleId}.js`)
const docFile = path.resolve(__dirname, `../docs/rules/${ruleId}.md`)
fs.writeFileSync(
ruleFile,
`/**
* @author Toru Nagashima <https://github.com/mysticatea>
* See LICENSE file in root directory for full license.
*/
"use strict"
module.exports = {
meta: {
docs: {
description: "",
category: "",
recommended: false,
url: "",
},
fixable: null,
messages: {
},
schema: [],
type: "problem",
},
create(context) {
return {}
},
}
`
)
fs.writeFileSync(
testFile,
`/**
* @author Toru Nagashima <https://github.com/mysticatea>
* See LICENSE file in root directory for full license.
*/
"use strict"
const { RuleTester } = require("eslint")
const rule = require("../../../lib/rules/${ruleId}.js")
new RuleTester().run("${ruleId}", rule, {
valid: [],
invalid: [],
})
`
)
fs.writeFileSync(
docFile,
`# (es/${ruleId})
(TODO: Why this rule is useful.)
## 📖 Rule Details
(TODO: How this rule will report code.)
👍 Examples of **correct** code for this rule:
\`\`\`js
/*eslint node/${ruleId}: error */
\`\`\`
👎 Examples of **incorrect** code for this rule:
\`\`\`js
/*eslint node/${ruleId}: error */
\`\`\`
## ⚙ Options
\`\`\`json
{
"node/${ruleId}": ["error", ...]
}
\`\`\`
`
)
cp.execSync(`code "${ruleFile}"`)
cp.execSync(`code "${testFile}"`)
cp.execSync(`code "${docFile}"`)
})(process.argv[2])