0
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-02-15 01:57:09 -05:00
denoland-deno/cli/js
Bartek Iwańczuk f08ca6414b
feat(lint): add JavaScript plugin support (#27203)
This commit adds an unstable lint plugin API.

Plugins are specified in the `deno.json` file under
`lint.plugins` option like so:

```
{
  "lint": {
    "plugins": [
      "./plugins/my-plugin.ts",
      "jsr:@deno/lint-plugin1",
      "npm:@deno/lint-plugin2"
    ]
  }
}
```

The API is considered unstable and might be subject
to changes in the future.

Plugin API was modelled after ESLint API for the 
most part, but there are no guarantees for compatibility.
The AST format exposed to plugins is closely modelled
after the AST that `typescript-eslint` uses.

Lint plugins use the visitor pattern and can add
diagnostics like so:

```
export default {
  name: "lint-plugin",
  rules: {
    "plugin-rule": {
      create(context) {
        return {
          Identifier(node) {
            if (node.name === "a") {
              context.report({
                node,
                message: "should be b",
                fix(fixer) {
                  return fixer.replaceText(node, "_b");
                },
              });
            }
          },
        };
      },
    },
  },
} satisfies Deno.lint.Plugin;
```

Besides reporting errors (diagnostics) plugins can provide
automatic fixes that use text replacement to apply changes.

---------

Co-authored-by: Marvin Hagemeister <marvin@deno.com>
Co-authored-by: David Sherret <dsherret@gmail.com>
2025-02-05 16:59:24 +01:00
..
40_bench.js refactor: add 'deno_os' crate (#27655) 2025-01-14 17:29:36 +01:00
40_jupyter.js chore: Happy New Year 2025 (#27509) 2024-12-31 19:12:39 +00:00
40_lint.js feat(lint): add JavaScript plugin support (#27203) 2025-02-05 16:59:24 +01:00
40_lint_selector.js feat(unstable): refactor js lint plugin AST (#27615) 2025-01-14 13:31:02 +01:00
40_lint_types.d.ts feat(lint): add JavaScript plugin support (#27203) 2025-02-05 16:59:24 +01:00
40_test.js refactor: add 'deno_os' crate (#27655) 2025-01-14 17:29:36 +01:00
40_test_common.js chore: Happy New Year 2025 (#27509) 2024-12-31 19:12:39 +00:00