This is an updated fork of mysticatea/eslint-plugin-dprint. Some things are still being adjusted.
The plugin that runs dprint to format code in ESLint.
Use npm or a compatible tool.
$ npm install -D eslint @ben_12/eslint-plugin-dprint
Then install dprint plugin for the language to format.
$ npm install -D @dprint/dockerfile
$ npm install -D @dprint/json
$ npm install -D @dprint/markdown
$ npm install -D @dprint/toml
$ npm install -D @dprint/typescript
$ npm install -D dprint-plugin-malva
$ npm install -D dprint-plugin-markup
Write your ESLint configuration. For example with typescript code:
From eslint v9 (flat configuration)
import tsPlugin from "@typescript-eslint/eslint-plugin";
import tsParser from "@typescript-eslint/parser";
import dprint from "@ben_12/eslint-plugin-dprint";
module.exports = {
files: ["**/*.ts", "**/*.js"],
languageOptions: {
parser: tsParser
},
plugins: {
"@typescript-eslint": tsPlugin,
"@ben_12/dprint": dprint,
},
rules: {
...tsPlugin.configs["eslint-recommended"].rules,
...tsPlugin.configs["recommended"].rules,
...tsPlugin.configs["strict"].rules,
...dprint.configs["typescript-recommended"].rules
"@ben_12/dprint/typescript": [
"error",
{
// Use dprint JSON configuration file (default: "dprint.json")
// It may be created using `dprint init` command
// See also https://dprint.dev/config/
configFile: "dprint.json",
config: {
// The TypeScript configuration of dprint
// See also https://dprint.dev/plugins/typescript/config/
},
},
],
},
};
For old eslint (eslintrc configuration)
module.exports = {
extends: ["eslint:recommended", "plugin:@typescript-eslint/recommended", "plugin:@ben_12/dprint/typescript-recommended"],
rules: {
"@ben_12/dprint/typescript": [
"error",
{
// Use dprint JSON configuration file (default: "dprint.json")
// It may be created using `dprint init` command
// See also https://dprint.dev/config/
configFile: "dprint.json",
config: {
// The TypeScript configuration of dprint
// See also https://dprint.dev/plugins/typescript/config/
},
},
],
},
};
Then run ESLint with --fix
!
Rule | Description |
---|---|
@ben_12/dprint/dockerfile | Format dockerfile code with @dprint/dockerfile. |
@ben_12/dprint/json | Format json code with @dprint/json. |
@ben_12/dprint/markdown | Format markdown code with @dprint/markdown. |
@ben_12/dprint/toml | Format toml code with @dprint/toml. |
@ben_12/dprint/typescript | Format typescript code with @dprint/typescript. |
@ben_12/dprint/malva | Format css/scss/less/sass code with malva. |
@ben_12/dprint/markup | Format HTML/Vue/Svelte/... code with markup_fmt. |
Config | Description |
---|---|
plugin:@ben_12/dprint/disable-typescript-conflict-rules | Disable rules where are conflicted with the @ben_12/dprint/typescript rule. |
plugin:@ben_12/dprint/dockerfile-recommended | Enable the @ben_12/dprint/dockerfile rule. |
plugin:@ben_12/dprint/json-recommended | Enable the @ben_12/dprint/json rule. |
plugin:@ben_12/dprint/markdown-recommended | Enable the @ben_12/dprint/markdown rule. |
plugin:@ben_12/dprint/toml-recommended | Enable the @ben_12/dprint/toml rule. |
plugin:@ben_12/dprint/typescript-recommended | Enable the @ben_12/dprint/typescript rule along with the plugin:@ben_12/dprint/disable-typescript-conflict-rules preset. |
plugin:@ben_12/dprint/malva-recommended | Enable the @ben_12/dprint/malva rule. |
plugin:@ben_12/dprint/markup-recommended | Enable the @ben_12/dprint/markup rule. |
- Put the [plugin:@ben_12/dprint/recommended] or [plugin:@ben_12/dprint/disable-conflict-rules] config into the last of your
extends
list in order to ensure disabling conflict rules where came from other base configurations.
See GitHub Releases.
Welcome contributing!
Please use GitHub's Issues/PRs.
npm test
... Run tests. It generates code coverage intocoverage
directory.npm run watch
... Run tests when files are edited.npm version <patch|minor|major>
... Bump a new version.