oxc/tasks/lint_rules
Yuji Sugiura 17635973b6
fix(tasks/lint_rules): Refactor syncing typescript-eslint and eslint status (#4654)
Closes #4085 

This issue seemed to have been addressed in #3779 , but partially
reverted in #3813 ? 🤔

Since I wasn't aware of these changes, I've just checked the current
implementation through the review requests in #4611 and refactored as
the original author.
2024-08-05 13:21:52 +08:00
..
src fix(tasks/lint_rules): Refactor syncing typescript-eslint and eslint status (#4654) 2024-08-05 13:21:52 +08:00
.gitignore chore(lint_rules): deprecated eslint no-dupe-args / no-octal / no-with 2024-02-02 17:33:54 +08:00
jsconfig.json feat(tasks): Enable tasks/lint_rules(JS ver) (#2177) 2024-01-26 15:45:05 +08:00
package.json feat(tasks): Enable tasks/lint_rules(JS ver) (#2177) 2024-01-26 15:45:05 +08:00
README.md feat(tasks): Enable tasks/lint_rules(JS ver) (#2177) 2024-01-26 15:45:05 +08:00

tasks/lint_rules

Task to update implementation progress for each linter plugin.

Usage:
  $ cmd [--target=<pluginName>]... [--update] [--help]

Options:
  --target, -t: Which plugin to target, multiple allowed
  --update: Update the issue instead of printing to stdout
  --help, -h: Print this help message

Environment variables GITHUB_TOKEN is required when --update is specified.

Design

  • Always install eslint-plugin-XXX@latest from npm
  • Load them through ESLint Node.js API
  • List all their plugin rules(name, deprecated, recommended, docs, etc...)
  • List all our implemented rules(name)
  • Combine these lists and render as markdown
  • Update GitHub issue body

FAQ

  • Why is this task written in Node.js? Why not Rust?
  • Why .cjs?
    • To keep dependencies as simple as possible
    • Some plugins only provide their module as CommonJS
    • So, CommonJS is the only way to go without bundling