python-lsp-ruff
is a plugin for python-lsp-server
that adds linting, code action and formatting capabilities that are provided by ruff,
an extremely fast Python linter and formatter written in Rust.
In the same virtualenv
as python-lsp-server
:
pip install python-lsp-ruff
There also exists an AUR package.
Ruff version 0.1.0
introduced API changes that are fixed in Python LSP Ruff v1.6.0
. To continue with ruff<0.1.0
please use v1.5.3
, e.g. using pip
:
pip install "ruff<0.1.0" "python-lsp-ruff==1.5.3"
This plugin will disable pycodestyle
, pyflakes
, mccabe
, autopep8
, and yapf
by default, unless they are explicitly enabled in the client configuration.
When python-lsp-ruff
is enabled, all linting diagnostics and formatting capabilities will be provided by ruff
.
Any codes given in the format
option will only be marked as fixable
for ruff during the formatting operation, the user has to make sure that these codes are also in the list of codes that ruff checks!
Configuration options can be passed to the python-language-server. If a pyproject.toml
file is present in the project, python-lsp-ruff
will ignore specific options (see below).
The plugin follows python-lsp-server's configuration.
This example configuration using for neovim
shows the possible options:
Lua
pylsp = {
plugins = {
ruff = {
enabled = true, -- Enable the plugin
formatEnabled = true, -- Enable formatting using ruffs formatter
executable = "<path-to-ruff-bin>", -- Custom path to ruff
config = "<path_to_custom_ruff_toml>", -- Custom config for ruff to use
extendSelect = { "I" }, -- Rules that are additionally used by ruff
extendIgnore = { "C90" }, -- Rules that are additionally ignored by ruff
format = { "I" }, -- Rules that are marked as fixable by ruff that should be fixed when running textDocument/formatting
severities = { ["D212"] = "I" }, -- Optional table of rules where a custom severity is desired
unsafeFixes = false, -- Whether or not to offer unsafe fixes as code actions. Ignored with the "Fix All" action
-- Rules that are ignored when a pyproject.toml or ruff.toml is present:
lineLength = 88, -- Line length to pass to ruff checking and formatting
exclude = { "__about__.py" }, -- Files to be excluded by ruff checking
select = { "F" }, -- Rules to be enabled by ruff
ignore = { "D210" }, -- Rules to be ignored by ruff
perFileIgnores = { ["__init__.py"] = "CPY001" }, -- Rules that should be ignored for specific files
preview = false, -- Whether to enable the preview style linting and formatting.
targetVersion = "py310", -- The minimum python version to target (applies for both linting and formatting).
},
}
}
JSON
{
"pylsp": {
"plugins": {
"ruff": {
"enabled": true,
"formatEnabled": true,
"executable": "<path-to-ruff-bin>",
"config": "<path_to_custom_ruff_toml>",
"extendSelect": [ "I" ],
"extendIgnore": [ "C90"],
"format": [ "I" ],
"severities": {
"D212": "I"
},
"unsafeFixes": false,
"lineLength": 88,
"exclude": ["__about__.py"],
"select": ["F"],
"ignore": ["D210"],
"perFileIgnores": {
"__init__.py": "CPY001"
},
"preview": false,
"targetVersion": "py310"
}
}
}
}
For more information on the configuration visit Ruff's homepage.
By default, all diagnostics are marked as warning, except for "E999"
and all error codes starting with "F"
, which are displayed as errors.
This default can be changed through the pylsp.plugins.ruff.severities
option, which takes the error code as a key and any of
"E"
, "W"
, "I"
and "H"
to be displayed as errors, warnings, information and hints, respectively.
For more information on the diagnostic severities please refer to
the official LSP reference.
With v2.0.0
it is also possible to use patterns to match codes. Rules match if the error code starts with the given pattern. If multiple patterns match the error code, python-lsp-ruff
chooses the one with the most amount of matching characters.
With python-lsp-ruff>1.6.0
formatting is done using ruffs own formatter by default.
Formatting using ruff can be explicitly disabled by setting formatEnabled = false
in the LSP settings.
Additional rules that should be fixed during the textDocument/formatting
request can be added with the format
option.
Coming from previous versions the only change is that isort
rules are not applied by default.
To enable sorting of imports using ruff's isort functionality, add "I"
to the list of format
rules.
python-lsp-ruff
supports code actions as given by possible fixes by ruff
. python-lsp-ruff
also supports unsafe fixes.
Fixes considered unsafe by ruff
are marked (unsafe)
in the code action.
The Fix all
code action only consideres safe fixes.
The log level can be set via the cmd
option of pylsp
:
lspconfig.pylsp.setup {
cmd = {"pylsp", "-vvv", "--log-file", "/tmp/lsp.log"},
settings = {
pylsp = {
plugins = {
ruff = {
enabled = true,
},
}
}
}
}