From 648cca199bbf0d2b4b04414404bca866fe5b52c9 Mon Sep 17 00:00:00 2001 From: Dhruv Manilawala Date: Thu, 18 Jul 2024 17:41:43 +0530 Subject: [PATCH] Add docs for Ruff language server (#12344) ## Summary This PR adds documentation for the Ruff language server. It mainly does the following: 1. Combines various READMEs containing instructions for different editor setup in their respective section on the online docs 2. Provide an enumerated list of server settings. Additionally, it also provides a section for VS Code specific options. 3. Adds a "Features" section which enumerates all the current capabilities of the native server For (2), the settings documentation is done manually but a future improvement (easier after `ruff-lsp` is deprecated) is to move the docs in to Rust struct and generate the documentation from the code itself. And, the VS Code extension specific options can be generated by diffing against the `package.json` in `ruff-vscode` repository. ### Structure 1. Setup: This section contains the configuration for setting up the language server for different editors 2. Features: This section contains a list of capabilities provided by the server along with short GIF to showcase it 3. Settings: This section contains an enumerated list of settings in a similar format to the one for the linter / formatter 4. Migrating from `ruff-lsp` > [!NOTE] > > The settings page is manually written but could possibly be auto-generated via a macro similar to `OptionsMetadata` on the `ClientSettings` struct resolves: #11217 ## Test Plan Generate and open the documentation locally using: 1. `python scripts/generate_mkdocs.py` 2. `mkdocs serve -f mkdocs.insiders.yml` --- crates/ruff_server/README.md | 72 +-- crates/ruff_server/docs/MIGRATION.md | 84 +-- crates/ruff_server/docs/setup/HELIX.md | 100 +-- crates/ruff_server/docs/setup/KATE.md | 24 +- crates/ruff_server/docs/setup/NEOVIM.md | 93 +-- crates/ruff_server/docs/setup/VIM.md | 40 +- .../setup/assets/SuccessfulHelixSetup.png | Bin 199760 -> 0 bytes docs/.gitignore | 10 +- docs/editors/features.md | 105 ++++ docs/editors/index.md | 27 + docs/editors/migration.md | 81 +++ docs/editors/settings.md | 571 ++++++++++++++++++ docs/editors/setup.md | 363 +++++++++++ docs/integrations.md | 383 ++---------- scripts/generate_mkdocs.py | 32 +- 15 files changed, 1254 insertions(+), 731 deletions(-) delete mode 100644 crates/ruff_server/docs/setup/assets/SuccessfulHelixSetup.png create mode 100644 docs/editors/features.md create mode 100644 docs/editors/index.md create mode 100644 docs/editors/migration.md create mode 100644 docs/editors/settings.md create mode 100644 docs/editors/setup.md diff --git a/crates/ruff_server/README.md b/crates/ruff_server/README.md index dc4700f43fc5b..de9254d0d0264 100644 --- a/crates/ruff_server/README.md +++ b/crates/ruff_server/README.md @@ -1,6 +1,4 @@ -## The Ruff Language Server - -Welcome! +# The Ruff Language Server `ruff server` is a language server that powers Ruff's editor integrations. @@ -9,68 +7,12 @@ and call into Ruff's linter and formatter crates to construct real-time diagnost sent back to the client. It also tracks configuration files in your editor's workspace, and will refresh its in-memory configuration whenever those files are modified. -### Setup - -We have specific setup instructions depending on your editor. If you don't see your editor on this list and would like a -setup guide, please open an issue. - -If you're transferring your configuration from [`ruff-lsp`](https://github.com/astral-sh/ruff-lsp), regardless of -editor, there are several settings which have changed or are no longer available. See the [migration guide](docs/MIGRATION.md) for -more. - -#### VS Code - -Install the Ruff extension from the [VS Code Marketplace](https://marketplace.visualstudio.com/items?itemName=charliermarsh.ruff). - -As this server is still in Beta, you will need to enable the "Native Server" extension setting, either in the settings -UI: - -![A screenshot showing an enabled "Native Server" extension setting in the VS Code settings view](assets/nativeServer.png) - -Or in your `settings.json`: - -```json -{ - "ruff.nativeServer": true -} -``` - -From there, you can configure Ruff to format Python code on-save with: - -```json -{ - "[python]": { - "editor.formatOnSave": true, - "editor.defaultFormatter": "charliermarsh.ruff" - } -} -``` - -For more, see [_Configuring VS Code_](https://github.com/astral-sh/ruff-vscode?tab=readme-ov-file#configuring-vs-code) -in the Ruff extension documentation. - -By default, the extension will run against the `ruff` binary that it discovers in your environment. If you don't have -`ruff` installed, the extension will fall back to a bundled version of the binary. - -#### Neovim - -See the [Neovim setup guide](docs/setup/NEOVIM.md). - -#### Helix - -See the [Helix setup guide](docs/setup//HELIX.md). - -#### Vim - -See the [Vim setup guide](docs/setup/VIM.md). - -#### Kate - -See the [Kate setup guide](docs/setup/KATE.md). +Refer to the [documentation](https://docs.astral.sh/ruff/editors/) for more information on +how to set up the language server with your editor and configure it to your liking. -### Contributing +## Contributing -If you're interested in contributing to `ruff server` - well, first of all, thank you! Second of all, you might find the -[**contribution guide**](CONTRIBUTING.md) to be a useful resource. +Contributions are welcome and highly appreciated. To get started, check out the +[**contributing guidelines**](https://docs.astral.sh/ruff/contributing/). -Finally, don't hesitate to reach out on [**Discord**](https://discord.com/invite/astral-sh) if you have questions. +You can also join us on [**Discord**](https://discord.com/invite/astral-sh). diff --git a/crates/ruff_server/docs/MIGRATION.md b/crates/ruff_server/docs/MIGRATION.md index 9b42ca0ee6616..18ee2ecd49fb0 100644 --- a/crates/ruff_server/docs/MIGRATION.md +++ b/crates/ruff_server/docs/MIGRATION.md @@ -1,85 +1,3 @@ ## Migrating From `ruff-lsp` -While `ruff server` supports the same feature set as [`ruff-lsp`](https://github.com/astral-sh/ruff-lsp), migrating to -`ruff server` may require changes to your Ruff or language server configuration. - -> \[!NOTE\] -> -> The [VS Code extension](https://github.com/astral-sh/ruff-vscode) settings include documentation to indicate which -> settings are supported by `ruff server`. As such, this migration guide is primarily targeted at editors that lack -> explicit documentation for `ruff server` settings, such as Helix or Neovim. - -### Unsupported Settings - -Several `ruff-lsp` settings are not supported by `ruff server`. These are, as follows: - -- `format.args` -- `ignoreStandardLibrary` -- `interpreter` -- `lint.args` -- `lint.run` -- `logLevel` -- `path` - -Note that some of these settings, like `interpreter` and `path`, are still accepted by the VS Code extension. `path`, -in particular, can be used to specify a dedicated binary to use when initializing `ruff server`. But the language server -itself will no longer accept such settings. - -### New Settings - -`ruff server` introduces several new settings that `ruff-lsp` does not have. These are, as follows: - -- `configuration`: A path to a `ruff.toml` or `pyproject.toml` file to use for configuration. By default, Ruff will discover configuration for each project from the filesystem, mirroring the behavior of the Ruff CLI. -- `configurationPreference`: Used to specify how you want to resolve server settings with local file configuration. The following values are available: - - `"editorFirst"`: The default strategy - configuration set in the server settings takes priority over configuration set in `.toml` files. - - `"filesystemFirst"`: An alternative strategy - configuration set in `.toml` files takes priority over configuration set in the server settings. - - `"editorOnly"`: An alternative strategy - configuration set in `.toml` files is ignored entirely. -- `exclude`: Paths for the linter and formatter to ignore. See [the documentation](https://docs.astral.sh/ruff/settings/#exclude) for more details. -- `format.preview`: Enables [preview mode](https://docs.astral.sh/ruff/settings/#format_preview) for the formatter; enables unstable formatting. -- `lineLength`: The [line length](https://docs.astral.sh/ruff/settings/#line-length) used by the formatter and linter. -- `lint.select`: The rule codes to enable. Use `ALL` to enable all rules. See [the documentation](https://docs.astral.sh/ruff/settings/#lint_select) for more details. -- `lint.extendSelect`: Enables additional rule codes on top of existing configuration, instead of overriding it. Use `ALL` to enable all rules. -- `lint.ignore`: Sets rule codes to disable. See [the documentation](https://docs.astral.sh/ruff/settings/#lint_ignore) for more details. -- `lint.preview`: Enables [preview mode](https://docs.astral.sh/ruff/settings/#lint_preview) for the linter; enables unstable rules and fixes. - -Several of these new settings are replacements for the now-unsupported `format.args` and `lint.args`. For example, if -you've been passing `--select=` to `lint.args`, you can migrate to the new server by using `lint.select` with a -value of `[""]`. - -### Examples - -Let's say you have these settings in VS Code: - -```json -{ - "ruff.lint.args": "--select=E,F --line-length 80 --config ~/.config/custom_ruff_config.toml" -} -``` - -After enabling the native server, you can migrate your settings like so: - -```json -{ - "ruff.configuration": "~/.config/custom_ruff_config.toml", - "ruff.lineLength": 80, - "ruff.lint.select": ["E", "F"] -} -``` - -Similarly, let's say you have these settings in Helix: - -```toml -[language-server.ruff.config.lint] -args = "--select=E,F --line-length 80 --config ~/.config/custom_ruff_config.toml" -``` - -These can be migrated like so: - -```toml -[language-server.ruff.config] -configuration = "~/.config/custom_ruff_config.toml" -lineLength = 80 - -[language-server.ruff.config.lint] -select = ["E", "F"] -``` +This document has been moved to . diff --git a/crates/ruff_server/docs/setup/HELIX.md b/crates/ruff_server/docs/setup/HELIX.md index e41fb2b8bd275..b8e75fec75206 100644 --- a/crates/ruff_server/docs/setup/HELIX.md +++ b/crates/ruff_server/docs/setup/HELIX.md @@ -1,101 +1,3 @@ ## Helix Setup Guide for `ruff server` -First, open the language configuration file for Helix. On Linux and macOS, this will be at `~/.config/helix/languages.toml`, -and on Windows this will be at `%AppData%\helix\languages.toml`. - -Add the language server by adding: - -```toml -[language-server.ruff] -command = "ruff" -args = ["server", "--preview"] -``` - -Then, you'll register the language server as the one to use with Python. -If you don't already have a language server registered to use with Python, add this to `languages.toml`: - -```toml -[[language]] -name = "python" -language-servers = ["ruff"] -``` - -Otherwise, if you already have `language-servers` defined, you can simply add `"ruff"` to the list. For example, -if you already have `pylsp` as a language server, you can modify the language entry as follows: - -```toml -[[language]] -name = "python" -language-servers = ["ruff", "pylsp"] -``` - -> \[!NOTE\] -> Multiple language servers for a single language are only supported in Helix version [`23.10`](https://github.com/helix-editor/helix/blob/master/CHANGELOG.md#2310-2023-10-24) and later. - -Once you've set up the server, you should see diagnostics in your Python files. Code actions and other LSP features should also be available. - -![A screenshot showing an open Python file in Helix with highlighted diagnostics and a code action dropdown menu open](assets/SuccessfulHelixSetup.png) -*This screenshot is using `select=["ALL]"` for demonstration purposes.* - -If you want to, as an example, turn on auto-formatting, add `auto-format = true`: - -```toml -[[language]] -name = "python" -language-servers = ["ruff", "pylsp"] -auto-format = true -``` - -See the [Helix documentation](https://docs.helix-editor.com/languages.html) for more settings you can use here. - -You can pass settings into `ruff server` using `[language-server.ruff.config.settings]`. For example: - -```toml -[language-server.ruff.config.settings] -lineLength = 80 -[language-server.ruff.config.settings.lint] -select = ["E4", "E7"] -preview = false -[language-server.ruff.config.settings.format] -preview = true -``` - -By default, Ruff does not log anything to Helix. To enable logging, set the `RUFF_TRACE` environment variable -to either `messages` or `verbose`. - -```toml -[language-server.ruff] -command = "ruff" -args = ["server", "--preview"] -environment = { "RUFF_TRACE" = "messages" } -``` - -> \[!NOTE\] -> `RUFF_TRACE=verbose` does not enable Helix's verbose mode by itself. You'll need to run Helix with `-v` for verbose logging. - -To change the log level for Ruff (which is `info` by default), use the `logLevel` setting: - -```toml -[language-server.ruff] -command = "ruff" -args = ["server", "--preview"] -environment = { "RUFF_TRACE" = "messages" } - -[language-server.ruff.config.settings] -logLevel = "debug" -``` - -You can also divert Ruff's logs to a separate file with the `logFile` setting: - -```toml -[language-server.ruff] -command = "ruff" -args = ["server", "--preview"] -environment = { "RUFF_TRACE" = "messages" } - -[language-server.ruff.config.settings] -logLevel = "debug" -logFile = "~/.cache/helix/ruff.log" -``` - -The `logFile` path supports tildes and environment variables. +This document has been moved to . diff --git a/crates/ruff_server/docs/setup/KATE.md b/crates/ruff_server/docs/setup/KATE.md index 7b828121fc739..b0e87637e8d43 100644 --- a/crates/ruff_server/docs/setup/KATE.md +++ b/crates/ruff_server/docs/setup/KATE.md @@ -1,25 +1,3 @@ ## Kate Setup Guide for `ruff server` -1. Activate the [LSP Client plugin](https://docs.kde.org/stable5/en/kate/kate/plugins.html#kate-application-plugins). -1. Setup LSP Client [as desired](https://docs.kde.org/stable5/en/kate/kate/kate-application-plugin-lspclient.html). -1. Finally, add this to `Settings` -> `Configure Kate` -> `LSP Client` -> `User Server Settings`: - -```json -{ - "servers": { - "python": { - "command": ["ruff", "server", "--preview"], - "url": "https://github.com/astral-sh/ruff", - "highlightingModeRegex": "^Python$", - "settings": {} - } - } -} -``` - -See [LSP Client documentation](https://docs.kde.org/stable5/en/kate/kate/kate-application-plugin-lspclient.html) for more details -on how to configure the server from there. - -> \[!IMPORTANT\] -> -> Kate's LSP Client plugin does not support multiple servers for the same language. +This document has been moved to . diff --git a/crates/ruff_server/docs/setup/NEOVIM.md b/crates/ruff_server/docs/setup/NEOVIM.md index d055c58e1a1da..e47810686f042 100644 --- a/crates/ruff_server/docs/setup/NEOVIM.md +++ b/crates/ruff_server/docs/setup/NEOVIM.md @@ -1,94 +1,3 @@ ## Neovim Setup Guide for `ruff server` -### Using `nvim-lspconfig` - -1. Install [`nvim-lspconfig`](https://github.com/neovim/nvim-lspconfig). -1. Setup `nvim-lspconfig` with the [suggested configuration](https://github.com/neovim/nvim-lspconfig/tree/master#suggested-configuration). -1. Finally, add this to your `init.lua`: - -```lua -require('lspconfig').ruff.setup {} -``` - -See [`nvim-lspconfig`'s server configuration guide](https://github.com/neovim/nvim-lspconfig/blob/master/doc/server_configurations.md#ruff) for more details -on how to configure the server from there. - -> \[!IMPORTANT\] -> -> If you have the older language server (`ruff-lsp`) configured in Neovim, make sure to disable it to prevent any conflicts. - -#### Tips - -If you're using Ruff alongside another LSP (like Pyright), you may want to defer to that LSP for certain capabilities, -like `textDocument/hover`: - -```lua -local on_attach = function(client, bufnr) - if client.name == 'ruff' then - -- Disable hover in favor of Pyright - client.server_capabilities.hoverProvider = false - end -end - -require('lspconfig').ruff.setup { - on_attach = on_attach, -} -``` - -If you'd like to use Ruff exclusively for linting, formatting, and import organization, you can disable those -capabilities for Pyright: - -```lua -require('lspconfig').pyright.setup { - settings = { - pyright = { - -- Using Ruff's import organizer - disableOrganizeImports = true, - }, - python = { - analysis = { - -- Ignore all files for analysis to exclusively use Ruff for linting - ignore = { '*' }, - }, - }, - }, -} -``` - -By default, Ruff will not show any logs. To enable logging in Neovim, you'll need to set the `RUFF_TRACE` environment variable -to either `messages` or `verbose`: - -```lua -require('lspconfig').ruff.setup { - cmd_env = { RUFF_TRACE = "messages" } -} -``` - -You can set the log level in `settings`: - -```lua -require('lspconfig').ruff.setup { - cmd_env = { RUFF_TRACE = "messages" }, - init_options = { - settings = { - logLevel = "debug", - } - } -} -``` - -It's also possible to divert Ruff's logs to a separate file with the `logFile` setting: - -```lua -require('lspconfig').ruff.setup { - cmd_env = { RUFF_TRACE = "messages" }, - init_options = { - settings = { - logLevel = "debug", - logFile = "~/.local/state/nvim/ruff.log" - } - } -} -``` - -The `logFile` path supports tildes and environment variables. +This document has been moved to . diff --git a/crates/ruff_server/docs/setup/VIM.md b/crates/ruff_server/docs/setup/VIM.md index 5723243f2b2d2..0e583d3f07169 100644 --- a/crates/ruff_server/docs/setup/VIM.md +++ b/crates/ruff_server/docs/setup/VIM.md @@ -1,41 +1,3 @@ ## Vim Setup Guide for `ruff server` -### Using `vim-lsp` - -1. Install [`vim-lsp`](https://github.com/prabirshrestha/vim-lsp). -1. Setup `vim-lsp` [as desired](https://github.com/prabirshrestha/vim-lsp?tab=readme-ov-file#registering-servers). -1. Finally, add this to your `.vimrc`: - -```vim -if executable('ruff') - au User lsp_setup call lsp#register_server({ - \ 'name': 'ruff', - \ 'cmd': {server_info->['ruff', 'server', '--preview']}, - \ 'allowlist': ['python'], - \ 'workspace_config': {}, - \ }) -endif -``` - -See the `vim-lsp` [documentation](https://github.com/prabirshrestha/vim-lsp/blob/master/doc/vim-lsp.txt) for more -details on how to configure the language server. - -> \[!IMPORTANT\] -> -> If Ruff's legacy language server (`ruff-lsp`) is configured in Vim, be sure to disable it to prevent any conflicts. - -#### Tips - -If you're using Ruff alongside another LSP (like Pyright), you may want to defer to that LSP for certain capabilities, -like `textDocument/hover` by adding the following to the function `s:on_lsp_buffer_enabled()`: - -```vim -function! s:on_lsp_buffer_enabled() abort - " add your keybindings here (see https://github.com/prabirshrestha/vim-lsp?tab=readme-ov-file#registering-servers) - - let l:capabilities = lsp#get_server_capabilities('ruff') - if !empty(l:capabilities) - let l:capabilities.hoverProvider = v:false - endif -endfunction -``` +This document has been moved to . diff --git a/crates/ruff_server/docs/setup/assets/SuccessfulHelixSetup.png b/crates/ruff_server/docs/setup/assets/SuccessfulHelixSetup.png deleted file mode 100644 index ff21894cbfc3b1e851b941f8475848e57ddf3bb7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 199760 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 diff --git a/docs/.gitignore b/docs/.gitignore index 9df24a132a260..ec6ed14e2bb3f 100644 --- a/docs/.gitignore +++ b/docs/.gitignore @@ -1,5 +1,5 @@ -contributing.md -index.md -rules.md -rules/ -settings.md +/contributing.md +/index.md +/rules.md +/rules/ +/settings.md diff --git a/docs/editors/features.md b/docs/editors/features.md new file mode 100644 index 0000000000000..3ce5ff4d7ff92 --- /dev/null +++ b/docs/editors/features.md @@ -0,0 +1,105 @@ +# Features + +This section provides a detailed overview of the features provided by the Ruff Language Server. + +## Diagnostic Highlighting + +Provide diagnostics for your Python code in real-time. + + + +## Dynamic Configuration + +The server dynamically refreshes the diagnostics when a configuration file is changed in the +workspace, whether it's a `pyproject.toml`, `ruff.toml`, or `.ruff.toml` file. + +The server relies on the file watching capabilities of the editor to detect changes to these files. +If an editor does not support file watching, the server will not be able to detect +changes to the configuration file and thus will not refresh the diagnostics. + + + +## Formatting + +Provide code formatting for your Python code. The server can format an entire document or a specific +range of lines. + +The VS Code extension provides the `Ruff: Format Document` command to format an entire document. +In VS Code, the range formatting can be triggered by selecting a range of lines, right-clicking, and +selecting `Format Selection` from the context menu. + + + +## Code Actions + +Code actions are context-sensitive suggestions that can help you fix issues in your code. They are +usually triggered by a shortcut or by clicking a light bulb icon in the editor. The Ruff Language +Server provides the following code actions: + +- Apply a quick fix for a diagnostic that has a fix available (e.g., removing an unused import). +- Ignore a diagnostic with a `# noqa` comment. +- Apply all quick fixes available in the document. +- Organize imports in the document. + + + +You can even run these actions on-save. For example, to fix all issues and organize imports on save +in VS Code, add the following to your `settings.json`: + +```json +{ + "[python]": { + "editor.codeActionsOnSave": { + "source.fixAll.ruff": "explicit", + "source.organizeImports.ruff": "explicit" + } + } +} +``` + +### Fix Safety + +Ruff's automatic fixes are labeled as "safe" and "unsafe". By default, the "Fix all" action will not +apply unsafe fixes. However, unsafe fixes can be applied manually with the "Quick fix" action. +Application of unsafe fixes when using "Fix all" can be enabled by setting `unsafe-fixes = true` in +your Ruff configuration file. + +See the [Ruff fix documentation](https://docs.astral.sh/ruff/linter/#fix-safety) for more details on +how fix safety works. + +## Hover + +The server can provide the rule documentation when focusing over a NoQA code in the comment. +Focusing is usually hovering with a mouse, but can also be triggered with a shortcut. + + + +## Jupyter Notebook + +Similar to Ruff's CLI, the Ruff Language Server fully supports Jupyter Notebook files with all the +capabilities available to Python files. + + + + diff --git a/docs/editors/index.md b/docs/editors/index.md new file mode 100644 index 0000000000000..f0f193be21d7b --- /dev/null +++ b/docs/editors/index.md @@ -0,0 +1,27 @@ +# Editor Integrations + +Ruff can be integrated with various editors and IDEs to provide a seamless development experience. +This section provides instructions on [how to set up Ruff with your editor](./setup.md) and [configure it to your +liking](./settings.md). + +## Language Server Protocol + +The editor integration is mainly powered by the Ruff Language Server which implements the +[Language Server Protocol](https://microsoft.github.io/language-server-protocol/). The server is +written in Rust and is available as part of the `ruff` CLI via `ruff server`. It is a single, common +backend built directly into Ruff, and a direct replacement for [`ruff-lsp`](https://github.com/astral-sh/ruff-lsp), +our previous language server. You can read more about `ruff server` in the +[`v0.4.5` blog post](https://astral.sh/blog/ruff-v0.4.5). + +The server supports surfacing Ruff diagnostics, providing Code Actions to fix them, and +formatting the code using Ruff's built-in formatter. Currently, the server is intended to be used +alongside another Python Language Server in order to support features like navigation and +autocompletion. + +The Ruff Language Server was available first in Ruff [v0.4.5](https://astral.sh/blog/ruff-v0.4.5) +in beta and stabilized in Ruff [v0.5.3](https://github.com/astral-sh/ruff/releases/tag/0.5.3). + +!!! note + This is the documentation for Ruff's built-in language server written in Rust (`ruff server`). + If you are looking for the documentation for the `ruff-lsp` language server, please refer to the + [README](https://github.com/astral-sh/ruff-lsp) of the `ruff-lsp` repository. diff --git a/docs/editors/migration.md b/docs/editors/migration.md new file mode 100644 index 0000000000000..b9db53e729035 --- /dev/null +++ b/docs/editors/migration.md @@ -0,0 +1,81 @@ +# Migrating from `ruff-lsp` + +While `ruff server` supports the same feature set as [`ruff-lsp`](https://github.com/astral-sh/ruff-lsp), migrating to +`ruff server` may require changes to your Ruff or language server configuration. + +!!! note + The [VS Code extension](https://github.com/astral-sh/ruff-vscode) settings include documentation to indicate which + settings are supported by `ruff server`. As such, this migration guide is primarily targeted at editors that lack + explicit documentation for `ruff server` settings, such as Helix or Neovim. + +## Unsupported Settings + +Several `ruff-lsp` settings are not supported by `ruff server`. These are, as follows: + +- `format.args` +- `ignoreStandardLibrary` +- `interpreter` +- `lint.args` +- `lint.run` +- `path` + +!!! note + Some of these settings, like `interpreter` and `path`, are still accepted by the VS Code + extension. `path`, in particular, can be used to specify a dedicated binary to use when + initializing `ruff server`. But the language server itself will no longer accept such settings. + +## New Settings + +`ruff server` introduces several new settings that `ruff-lsp` does not have. These are, as follows: + +- [`configuration`](settings.md#configuration) +- [`configurationPreference`](settings.md#configurationpreference) +- [`exclude`](settings.md#exclude) +- [`format.preview`](settings.md#format_preview) +- [`lineLength`](settings.md#linelength) +- [`lint.select`](settings.md#select) +- [`lint.extendSelect`](settings.md#extendselect) +- [`lint.ignore`](settings.md#ignore) +- [`lint.preview`](settings.md#lint_preview) + +Several of these new settings are replacements for the now-unsupported `format.args` and `lint.args`. For example, if +you've been passing `--select=` to `lint.args`, you can migrate to the new server by using `lint.select` with a +value of `[""]`. + +## Examples + +Let's say you have these settings in VS Code: + +```json +{ + "ruff.lint.args": "--select=E,F --line-length 80 --config ~/.config/custom_ruff_config.toml" +} +``` + +After enabling the native server, you can migrate your settings like so: + +```json +{ + "ruff.configuration": "~/.config/custom_ruff_config.toml", + "ruff.lineLength": 80, + "ruff.lint.select": ["E", "F"] +} +``` + +Similarly, let's say you have these settings in Helix: + +```toml +[language-server.ruff.config.lint] +args = "--select=E,F --line-length 80 --config ~/.config/custom_ruff_config.toml" +``` + +These can be migrated like so: + +```toml +[language-server.ruff.config] +configuration = "~/.config/custom_ruff_config.toml" +lineLength = 80 + +[language-server.ruff.config.lint] +select = ["E", "F"] +``` diff --git a/docs/editors/settings.md b/docs/editors/settings.md new file mode 100644 index 0000000000000..47e1401bbec7d --- /dev/null +++ b/docs/editors/settings.md @@ -0,0 +1,571 @@ +# Settings + +The Ruff Language Server provides a set of configuration options to customize its behavior +along with the ability to use an existing `pyproject.toml` or `ruff.toml` file to configure the +linter and formatter. This is done by providing these settings while initializing the server. +VS Code provides a UI to configure these settings, while other editors may require manual +configuration. The [setup](./setup.md) section provides instructions on where to place these settings +as per the editor. + +## Top-level + +### `configuration` + +Path to a `ruff.toml` or `pyproject.toml` file to use for configuration. + +By default, Ruff will discover configuration for each project from the filesystem, mirroring the +behavior of the Ruff CLI. + +**Default value**: `null` + +**Type**: `string` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.configuration": "~/path/to/ruff.toml" + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + configuration = "~/path/to/ruff.toml" + } + } + } + ``` + +### `configurationPreference` + +The strategy to use when resolving settings across VS Code and the filesystem. By default, editor +configuration is prioritized over `ruff.toml` and `pyproject.toml` files. + +- `"editorFirst"`: Editor settings take priority over configuration files present in the workspace. +- `"filesystemFirst"`: Configuration files present in the workspace takes priority over editor + settings. +- `"editorOnly"`: Ignore configuration files entirely i.e., only use editor settings. + +**Default value**: `"editorFirst"` + +**Type**: `"editorFirst" | "filesystemFirst" | "editorOnly"` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.configurationPreference": "filesystemFirst" + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + configurationPreference = "filesystemFirst" + } + } + } + ``` + +### `exclude` + +A list of file patterns to exclude from linting and formatting. See [the +documentation](https://docs.astral.sh/ruff/settings/#exclude) for more details. + +**Default value**: `null` + +**Type**: `string[]` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.exclude": ["**/tests/**"] + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + exclude = ["**/tests/**"] + } + } + } + ``` + +### `lineLength` + +The line length to use for the linter and formatter. + +**Default value**: `null` + +**Type**: `int` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.lineLength": 100 + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + lineLength = 100 + } + } + } + ``` + +### `fixAll` + +Whether to register the server as capable of handling `source.fixAll` code actions. + +**Default value**: `true` + +**Type**: `bool` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.fixAll": false + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + fixAll = false + } + } + } + ``` + +### `organizeImports` + +Whether to register the server as capable of handling `source.organizeImports` code actions. + +**Default value**: `true` + +**Type**: `bool` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.organizeImports": false + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + organizeImports = false + } + } + } + ``` + +### `showSyntaxErrors` + +_New in Ruff [v0.5.0](https://astral.sh/blog/ruff-v0.5.0#changes-to-e999-and-reporting-of-syntax-errors)_ + +Whether to show syntax error diagnostics. + +**Default value**: `true` + +**Type**: `bool` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.showSyntaxErrors": false + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + showSyntaxErrors = false + } + } + } + ``` + +### `logLevel` + +The log level to use for the server. + +**Default value**: `"info"` + +**Type**: `"trace" | "debug" | "info" | "warn" | "error"` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.logLevel": "debug" + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + logLevel = "debug" + } + } + } + ``` + +### `logFile` + +Path to the log file to use for the server. + +If not set, logs will be written to stderr. + +**Default value**: `null` + +**Type**: `string` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.logFile": "~/path/to/ruff.log" + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + logFile = "~/path/to/ruff.log" + } + } + } + ``` + +## `codeAction` + +Enable or disable code actions provided by the server. + +### `disableRuleComment.enable` + +Whether to display Quick Fix actions to disable rules via `noqa` suppression comments. + +**Default value**: `true` + +**Type**: `bool` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.codeAction.disableRuleComment.enable": false + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + codeAction = { + disableRuleComment = { + enable = false + } + } + } + } + } + ``` + +### `fixViolation.enable` + +Whether to display Quick Fix actions to autofix violations. + +**Default value**: `true` + +**Type**: `bool` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.codeAction.fixViolation.enable": false + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + codeAction = { + fixViolation = { + enable = false + } + } + } + } + } + ``` + +## `lint` + +Settings specific to the Ruff linter. + +### `enable` {: #lint_enable } + +Whether to enable linting. Set to `false` to use Ruff exclusively as a formatter. + +**Default value**: `true` + +**Type**: `bool` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.lint.enable": false + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + lint = { + enable = false + } + } + } + } + ``` + +### `preview` {: #lint_preview } + +Whether to enable Ruff's preview mode when linting. + +**Default value**: `null` + +**Type**: `bool` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.lint.preview": true + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + lint = { + preview = true + } + } + } + } + ``` + +### `select` + +Rules to enable by default. See [the documentation](https://docs.astral.sh/ruff/settings/#lint_select). + +**Default value**: `null` + +**Type**: `string[]` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.lint.select": ["E", "F"] + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + lint = { + select = {"E", "F"} + } + } + } + } + ``` + +### `extendSelect` + +Rules to enable in addition to those in [`lint.select`](#select). + +**Default value**: `null` + +**Type**: `string[]` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.lint.extendSelect": ["W"] + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + lint = { + extendSelect = {"W"} + } + } + } + } + ``` + +### `ignore` + +Rules to disable by default. See [the documentation](https://docs.astral.sh/ruff/settings/#lint_ignore). + +**Default value**: `null` + +**Type**: `string[]` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.lint.ignore": ["E4", "E7"] + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + lint = { + ignore = {"E4", "E7"} + } + } + } + } + ``` + +### `extendIgnore` + +Rules to disable in addition to those in [`lint.ignore`](#ignore). + +**Default value**: `null` + +**Type**: `string[]` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.lint.extendIgnore": ["W1"] + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + lint = { + extendIgnore = {"W1"} + } + } + } + } + ``` + +## `format` + +Settings specific to the Ruff formatter. + +### `preview` {: #format_preview } + +Whether to enable Ruff's preview mode when formatting. + +**Default value**: `null` + +**Type**: `bool` + +**Example usage**: + +=== "VS Code" + ```json + { + "ruff.format.preview": true + } + ``` + +=== "Neovim" + ```lua + require('lspconfig').ruff.setup { + init_options = { + settings = { + format = { + preview = true + } + } + } + } + ``` + +## VS Code specific + +The extension provides additional settings to control the behavior of the Ruff extension in VS Code. +The detailed documentation for these settings can be found in the UI of the settings editor in VS +Code. + +Refer to the [VS Code extension documentation](https://github.com/astral-sh/ruff-vscode#settings) +for more information. diff --git a/docs/editors/setup.md b/docs/editors/setup.md new file mode 100644 index 0000000000000..9cf6475bd75e6 --- /dev/null +++ b/docs/editors/setup.md @@ -0,0 +1,363 @@ +# Setup + +We have specific setup instructions depending on your editor of choice. If you don't see your editor on this +list and would like a setup guide, please open an issue. + +If you're transferring your configuration from [`ruff-lsp`](https://github.com/astral-sh/ruff-lsp), +regardless of editor, there are several settings which have changed or are no longer available. See +the [migration guide](./migration.md) for more. + +!!! note + The setup instructions provided below are on a best-effort basis. If you encounter any issues + while setting up the Ruff in an editor, please [open an issue](https://github.com/astral-sh/ruff/issues/new) + for assistance and help in improving this documentation. + +!!! tip + Regardless of the editor, it is recommended to disable the older language server + ([`ruff-lsp`](https://github.com/astral-sh/ruff-lsp)) to prevent any conflicts. + +## VS Code + +Install the Ruff extension from the [VS Code +Marketplace](https://marketplace.visualstudio.com/items?itemName=charliermarsh.ruff). It is +recommended to have the Ruff extension version `2024.32.0` or later to get the best experience with +the Ruff Language Server. + +For more documentation on the Ruff extension, refer to the +[README](https://github.com/astral-sh/ruff-vscode/blob/main/README.md) of the extension repository. + +## Neovim + +The [`nvim-lspconfig`](https://github/neovim/nvim-lspconfig) plugin can be used to configure the +Ruff Language Server in Neovim. To set it up, install +[`nvim-lspconfig`](https://github/neovim/nvim-lspconfig) plugin, set it up as per the +[configuration](https://github.com/neovim/nvim-lspconfig#configuration) documentation, and add the +following to your `init.lua`: + +```lua +require('lspconfig').ruff.setup({ + init_options = { + settings = { + -- Ruff language server settings go here + } + } +}) +``` + +If you're using Ruff alongside another language server (like Pyright), you may want to defer to that +language server for certain capabilities, like [`textDocument/hover`](./features.md#hover): + +```lua +vim.api.nvim_create_autocmd("LspAttach", { + group = vim.api.nvim_create_augroup('lsp_attach_disable_ruff_hover', { clear = true }), + callback = function(args) + local client = vim.lsp.get_client_by_id(args.data.client_id) + if client == nil then + return + end + if client.name == 'ruff' then + -- Disable hover in favor of Pyright + client.server_capabilities.hoverProvider = false + end + end, + desc = 'LSP: Disable hover capability from Ruff', +}) +``` + +If you'd like to use Ruff exclusively for linting, formatting, and organizing imports, you can disable those +capabilities for Pyright: + +```lua +require('lspconfig').pyright.setup { + settings = { + pyright = { + -- Using Ruff's import organizer + disableOrganizeImports = true, + }, + python = { + analysis = { + -- Ignore all files for analysis to exclusively use Ruff for linting + ignore = { '*' }, + }, + }, + }, +} +``` + +By default, Ruff will not show any logs. To enable logging in Neovim, you'll need to set the +`RUFF_TRACE` environment variable to either `messages` or `verbose`, and use the +[`logLevel`](./settings.md#loglevel) setting to change the log level: + +```lua +require('lspconfig').ruff.setup { + cmd_env = { RUFF_TRACE = "messages" } + init_options = { + settings = { + logLevel = "debug", + } + } +} +``` + +By default, this will write logs to stderr which will be available in Neovim's LSP client log file +(`:lua vim.print(vim.lsp.get_log_path())`). It's also possible to divert these logs to a separate +file with the [`logFile`](./settings.md#logfile) setting. + +## Vim + +The [`vim-lsp`](https://github.com/prabirshrestha/vim-lsp) plugin can be used to configure the Ruff Language Server in Vim. +To set it up, install [`vim-lsp`](https://github.com/prabirshrestha/vim-lsp) plugin and register the server using the following +in your `.vimrc`: + +```vim +if executable('ruff') + au User lsp_setup call lsp#register_server({ + \ 'name': 'ruff', + \ 'cmd': {server_info->['ruff', 'server']}, + \ 'allowlist': ['python'], + \ 'workspace_config': {}, + \ }) +endif +``` + +See the `vim-lsp` +[documentation](https://github.com/prabirshrestha/vim-lsp/blob/master/doc/vim-lsp.txt) for more +details on how to configure the language server. + +If you're using Ruff alongside another LSP (like Pyright), you may want to defer to that LSP for certain capabilities, +like [`textDocument/hover`](./features.md#hover) by adding the following to the function `s:on_lsp_buffer_enabled()`: + +```vim +function! s:on_lsp_buffer_enabled() abort + " add your keybindings here (see https://github.com/prabirshrestha/vim-lsp?tab=readme-ov-file#registering-servers) + + let l:capabilities = lsp#get_server_capabilities('ruff') + if !empty(l:capabilities) + let l:capabilities.hoverProvider = v:false + endif +endfunction +``` + +Ruff is also available as part of the [coc-pyright](https://github.com/fannheyward/coc-pyright) +extension for [coc.nvim](https://github.com/neoclide/coc.nvim). + +
+With the ALE plugin for Vim or Neovim. + +```vim +" Linter +let g:ale_linters = { "python": ["ruff"] } +" Formatter +let g:ale_fixers = { "python": ["ruff-format"] } +``` + +
+ +
+Ruff can also be integrated via efm language server in just a few lines. +
+ +Following is an example config for efm to use Ruff for linting and formatting Python files: + +```yaml +tools: + python-ruff: + lint-command: "ruff check --stdin-filename ${INPUT} --output-format concise --quiet -" + lint-stdin: true + lint-formats: + - "%f:%l:%c: %m" + format-command: "ruff format --stdin-filename ${INPUT} --quiet -" + format-stdin: true +``` + +
+ +
+With the conform.nvim plugin for Neovim. +
+ +```lua +require("conform").setup({ + formatters_by_ft = { + python = { + -- To fix auto-fixable lint errors. + "ruff_fix", + -- To run the Ruff formatter. + "ruff_format", + -- To organize the imports. + "ruff_organize_imports", + }, + }, +}) +``` + +
+ +
+With the nvim-lint plugin for Neovim. + +```lua +require("lint").linters_by_ft = { + python = { "ruff" }, +} +``` + +
+ +## Helix + +Open the [language configuration file](https://docs.helix-editor.com/languages.html#languagestoml-files) for +Helix and add the language server as follows: + +```toml +[language-server.ruff] +command = "ruff" +args = ["server"] +``` + +Then, you'll register the language server as the one to use with Python. If you don't already have a +language server registered to use with Python, add this to `languages.toml`: + +```toml +[[language]] +name = "python" +language-servers = ["ruff"] +``` + +Otherwise, if you already have `language-servers` defined, you can simply add `"ruff"` to the list. For example, +if you already have `pylsp` as a language server, you can modify the language entry as follows: + +```toml +[[language]] +name = "python" +language-servers = ["ruff", "pylsp"] +``` + +!!! note + Support for multiple language servers for a language is only available in Helix version + [`23.10`](https://github.com/helix-editor/helix/blob/master/CHANGELOG.md#2310-2023-10-24) and later. + +If you want to, as an example, turn on auto-formatting, add `auto-format = true`: + +```toml +[[language]] +name = "python" +language-servers = ["ruff", "pylsp"] +auto-format = true +``` + +See the [Helix documentation](https://docs.helix-editor.com/languages.html) for more settings you can use here. + +You can pass settings into `ruff server` using `[language-server.ruff.config.settings]`. For example: + +```toml +[language-server.ruff.config.settings] +lineLength = 80 + +[language-server.ruff.config.settings.lint] +select = ["E4", "E7"] +preview = false + +[language-server.ruff.config.settings.format] +preview = true +``` + +By default, Ruff does not log anything to Helix. To enable logging, set the `RUFF_TRACE` environment +variable to either `messages` or `verbose`, and use the [`logLevel`](./settings.md#loglevel) setting to change +the log level: + +```toml +[language-server.ruff] +command = "ruff" +args = ["server"] +environment = { "RUFF_TRACE" = "messages" } + +[language-server.ruff.config.settings] +logLevel = "debug" +``` + +You can also divert Ruff's logs to a separate file with the [`logFile`](./settings.md#logfile) setting. + +!!! note + Setting `RUFF_TRACE=verbose` does not enable Helix's verbose mode by itself. You'll need to run + Helix with `-v` for verbose logging. + +## Kate + +1. Activate the [LSP Client plugin](https://docs.kde.org/stable5/en/kate/kate/plugins.html#kate-application-plugins). +1. Setup LSP Client [as desired](https://docs.kde.org/stable5/en/kate/kate/kate-application-plugin-lspclient.html). +1. Finally, add this to `Settings` -> `Configure Kate` -> `LSP Client` -> `User Server Settings`: + +```json +{ + "servers": { + "python": { + "command": ["ruff", "server"], + "url": "https://github.com/astral-sh/ruff", + "highlightingModeRegex": "^Python$", + "settings": {} + } + } +} +``` + +See [LSP Client documentation](https://docs.kde.org/stable5/en/kate/kate/kate-application-plugin-lspclient.html) for more details +on how to configure the server from there. + +!!! important + Kate's LSP Client plugin does not support multiple servers for the same language. + +## Sublime Text + +To use Ruff with Sublime Text, install Sublime Text's [LSP](https://github.com/sublimelsp/LSP) +and [LSP-ruff](https://github.com/sublimelsp/LSP-ruff) package. + +## PyCharm + +### Via External Tool + +Ruff can be installed as an [External Tool](https://www.jetbrains.com/help/pycharm/configuring-third-party-tools.html) +in PyCharm. Open the Preferences pane, then navigate to "Tools", then "External Tools". From there, +add a new tool with the following configuration: + +![Install Ruff as an External Tool](https://user-images.githubusercontent.com/1309177/193155720-336e43f0-1a8d-46b4-bc12-e60f9ae01f7e.png) + +Ruff should then appear as a runnable action: + +![Ruff as a runnable action](https://user-images.githubusercontent.com/1309177/193156026-732b0aaf-3dd9-4549-9b4d-2de6d2168a33.png) + +### Via third-party plugin + +Ruff is also available as the [Ruff](https://plugins.jetbrains.com/plugin/20574-ruff) plugin on the +IntelliJ Marketplace (maintained by [@koxudaxi](https://github.com/koxudaxi)). + +## Emacs + +Ruff is available as [`flymake-ruff`](https://melpa.org/#/flymake-ruff) on MELPA: + +```elisp +(require 'flymake-ruff) +(add-hook 'python-mode-hook #'flymake-ruff-load) +``` + +Ruff is also available as [`emacs-ruff-format`](https://github.com/scop/emacs-ruff-format): + +```elisp +(require 'ruff-format) +(add-hook 'python-mode-hook 'ruff-format-on-save-mode) +``` + +Alternatively, it can be used via the [Apheleia](https://github.com/radian-software/apheleia) formatter library, by setting this configuration: + +```emacs-lisp +;; Replace default (black) to use ruff for sorting import and formatting. +(setf (alist-get 'python-mode apheleia-mode-alist) + '(ruff-isort ruff)) +(setf (alist-get 'python-ts-mode apheleia-mode-alist) + '(ruff-isort ruff)) +``` + +## TextMate + +Ruff is also available via the [`textmate2-ruff-linter`](https://github.com/vigo/textmate2-ruff-linter) +bundle for TextMate. diff --git a/docs/integrations.md b/docs/integrations.md index 15e3fdda8ac7b..ff18d3df0fdbd 100644 --- a/docs/integrations.md +++ b/docs/integrations.md @@ -1,327 +1,5 @@ # Integrations -## VS Code (Official) - -Download the [Ruff VS Code extension](https://marketplace.visualstudio.com/items?itemName=charliermarsh.ruff), -which supports fix actions, import sorting, and more. - -![Ruff VS Code extension](https://user-images.githubusercontent.com/1309177/205175763-cf34871d-5c05-4abf-9916-440afc82dbf8.gif) - -## pre-commit - -Ruff can be used as a [pre-commit](https://pre-commit.com) hook via [`ruff-pre-commit`](https://github.com/astral-sh/ruff-pre-commit): - -```yaml -- repo: https://github.com/astral-sh/ruff-pre-commit - # Ruff version. - rev: v0.5.2 - hooks: - # Run the linter. - - id: ruff - # Run the formatter. - - id: ruff-format -``` - -To enable lint fixes, add the `--fix` argument to the lint hook: - -```yaml -- repo: https://github.com/astral-sh/ruff-pre-commit - # Ruff version. - rev: v0.5.2 - hooks: - # Run the linter. - - id: ruff - args: [ --fix ] - # Run the formatter. - - id: ruff-format -``` - -To run the hooks over Jupyter Notebooks too, add `jupyter` to the list of allowed filetypes: - -```yaml -- repo: https://github.com/astral-sh/ruff-pre-commit - # Ruff version. - rev: v0.5.2 - hooks: - # Run the linter. - - id: ruff - types_or: [ python, pyi, jupyter ] - args: [ --fix ] - # Run the formatter. - - id: ruff-format - types_or: [ python, pyi, jupyter ] -``` - -When running with `--fix`, Ruff's lint hook should be placed _before_ Ruff's formatter hook, and -_before_ Black, isort, and other formatting tools, as Ruff's fix behavior can output code changes -that require reformatting. - -When running without `--fix`, Ruff's formatter hook can be placed before or after Ruff's lint hook. - -(As long as your Ruff configuration avoids any [linter-formatter incompatibilities](formatter.md#conflicting-lint-rules), -`ruff format` should never introduce new lint errors, so it's safe to run Ruff's format hook _after_ -`ruff check --fix`.) - -## Language Server Protocol (Official) - -Ruff supports the [Language Server Protocol](https://microsoft.github.io/language-server-protocol/) -via the [`ruff-lsp`](https://github.com/astral-sh/ruff-lsp) Python package, available on -[PyPI](https://pypi.org/project/ruff-lsp/). - -[`ruff-lsp`](https://github.com/astral-sh/ruff-lsp) enables Ruff to be used with any editor that -supports the Language Server Protocol, including [Neovim](https://github.com/astral-sh/ruff-lsp#example-neovim), -[Sublime Text](https://github.com/astral-sh/ruff-lsp#example-sublime-text), Emacs, and more. - -For example, to use `ruff-lsp` with Neovim, install `ruff-lsp` from PyPI along with -[`nvim-lspconfig`](https://github.com/neovim/nvim-lspconfig). Then, set up the Neovim LSP client -using the [suggested configuration](https://github.com/neovim/nvim-lspconfig/tree/master#configuration) -(`:h lspconfig-keybindings`). Finally, configure `ruff-lsp` in your `init.lua`: - -```lua --- Configure `ruff-lsp`. --- See: https://github.com/neovim/nvim-lspconfig/blob/master/doc/server_configurations.md#ruff_lsp --- For the default config, along with instructions on how to customize the settings -require('lspconfig').ruff_lsp.setup { - init_options = { - settings = { - -- Any extra CLI arguments for `ruff` go here. - args = {}, - } - } -} -``` - -Upon successful installation, you should see Ruff's diagnostics surfaced directly in your editor: - -![Code Actions available in Neovim](https://user-images.githubusercontent.com/1309177/208278707-25fa37e4-079d-4597-ad35-b95dba066960.png) - -To use `ruff-lsp` with other editors, including Sublime Text and Helix, see the [`ruff-lsp` documentation](https://github.com/astral-sh/ruff-lsp#setup). - -## Language Server Protocol (Unofficial) - -Ruff is also available as the [`python-lsp-ruff`](https://github.com/python-lsp/python-lsp-ruff) -plugin for [`python-lsp-server`](https://github.com/python-lsp/python-lsp-server), both of which are -installable from PyPI: - -```shell -pip install python-lsp-server python-lsp-ruff -``` - -The LSP server can then be used with any editor that supports the Language Server Protocol. - -For example, to use `python-lsp-ruff` with Neovim, add something like the following to your -`init.lua`: - -```lua -require'lspconfig'.pylsp.setup { - settings = { - pylsp = { - plugins = { - ruff = { - enabled = true - }, - pycodestyle = { - enabled = false - }, - pyflakes = { - enabled = false - }, - mccabe = { - enabled = false - } - } - } - }, -} -``` - -## Vim & Neovim - -Ruff can be integrated into any editor that supports the Language Server Protocol via [`ruff-lsp`](https://github.com/astral-sh/ruff-lsp) -(see: [Language Server Protocol](#language-server-protocol-official)), including Vim and Neovim. - -It's recommended that you use [`ruff-lsp`](https://github.com/astral-sh/ruff-lsp), the -officially supported LSP server for Ruff. To use `ruff-lsp` with Neovim, install `ruff-lsp` from -PyPI along with [`nvim-lspconfig`](https://github.com/neovim/nvim-lspconfig). Then, add something -like the following to your `init.lua`: - -```lua --- See: https://github.com/neovim/nvim-lspconfig/tree/54eb2a070a4f389b1be0f98070f81d23e2b1a715#suggested-configuration -local opts = { noremap=true, silent=true } -vim.keymap.set('n', 'e', vim.diagnostic.open_float, opts) -vim.keymap.set('n', '[d', vim.diagnostic.goto_prev, opts) -vim.keymap.set('n', ']d', vim.diagnostic.goto_next, opts) -vim.keymap.set('n', 'q', vim.diagnostic.setloclist, opts) - --- Use an on_attach function to only map the following keys --- after the language server attaches to the current buffer -local on_attach = function(client, bufnr) - -- Enable completion triggered by - vim.api.nvim_buf_set_option(bufnr, 'omnifunc', 'v:lua.vim.lsp.omnifunc') - - -- Mappings. - -- See `:help vim.lsp.*` for documentation on any of the below functions - local bufopts = { noremap=true, silent=true, buffer=bufnr } - vim.keymap.set('n', 'gD', vim.lsp.buf.declaration, bufopts) - vim.keymap.set('n', 'gd', vim.lsp.buf.definition, bufopts) - vim.keymap.set('n', 'K', vim.lsp.buf.hover, bufopts) - vim.keymap.set('n', 'gi', vim.lsp.buf.implementation, bufopts) - vim.keymap.set('n', '', vim.lsp.buf.signature_help, bufopts) - vim.keymap.set('n', 'wa', vim.lsp.buf.add_workspace_folder, bufopts) - vim.keymap.set('n', 'wr', vim.lsp.buf.remove_workspace_folder, bufopts) - vim.keymap.set('n', 'wl', function() - print(vim.inspect(vim.lsp.buf.list_workspace_folders())) - end, bufopts) - vim.keymap.set('n', 'D', vim.lsp.buf.type_definition, bufopts) - vim.keymap.set('n', 'rn', vim.lsp.buf.rename, bufopts) - vim.keymap.set('n', 'ca', vim.lsp.buf.code_action, bufopts) - vim.keymap.set('n', 'gr', vim.lsp.buf.references, bufopts) - vim.keymap.set('n', 'f', function() vim.lsp.buf.format { async = true } end, bufopts) -end - --- Configure `ruff-lsp`. --- See: https://github.com/neovim/nvim-lspconfig/blob/master/doc/server_configurations.md#ruff_lsp --- For the default config, along with instructions on how to customize the settings -require('lspconfig').ruff_lsp.setup { - on_attach = on_attach, - init_options = { - settings = { - -- Any extra CLI arguments for `ruff` go here. - args = {}, - } - } -} -``` - -Ruff is also available as part of the [coc-pyright](https://github.com/fannheyward/coc-pyright) -extension for `coc.nvim`. - -
-With the ALE plugin for (Neo)Vim. - -```vim -let g:ale_linters = { "python": ["ruff"] } -let g:ale_fixers = { -\ "python": ["black", "ruff"], -\} -``` - -
- -
- -Ruff can also be integrated via - - efm - -in just a - - few lines. - - -
- -```yaml -tools: - python-ruff: &python-ruff - lint-command: "ruff check --config ~/myconfigs/linters/ruff.toml --quiet ${INPUT}" - lint-stdin: true - lint-formats: - - "%f:%l:%c: %m" - format-command: "ruff check --stdin-filename ${INPUT} --config ~/myconfigs/linters/ruff.toml --fix --exit-zero --quiet -" - format-stdin: true -``` - -
- -
- -With the conform.nvim plugin for Neovim. - -
- -```lua -require("conform").setup({ - formatters_by_ft = { - python = { - -- To fix lint errors. - "ruff_fix", - -- To run the Ruff formatter. - "ruff_format", - }, - }, -}) -``` - -
- -
- -With the nvim-lint plugin for Neovim. - - -```lua -require("lint").linters_by_ft = { - python = { "ruff" }, -} -``` - -
- -## PyCharm (External Tool) - -Ruff can be installed as an [External Tool](https://www.jetbrains.com/help/pycharm/configuring-third-party-tools.html) -in PyCharm. Open the Preferences pane, then navigate to "Tools", then "External Tools". From there, -add a new tool with the following configuration: - -![Install Ruff as an External Tool](https://user-images.githubusercontent.com/1309177/193155720-336e43f0-1a8d-46b4-bc12-e60f9ae01f7e.png) - -Ruff should then appear as a runnable action: - -![Ruff as a runnable action](https://user-images.githubusercontent.com/1309177/193156026-732b0aaf-3dd9-4549-9b4d-2de6d2168a33.png) - -## PyCharm (Unofficial) - -Ruff is also available as the [Ruff](https://plugins.jetbrains.com/plugin/20574-ruff) plugin on the -IntelliJ Marketplace (maintained by @koxudaxi). - -## Emacs (Unofficial) - -Ruff is available as [`flymake-ruff`](https://melpa.org/#/flymake-ruff) on MELPA: - -```elisp -(require 'flymake-ruff) -(add-hook 'python-mode-hook #'flymake-ruff-load) -``` - -Ruff is also available as [`emacs-ruff-format`](https://github.com/scop/emacs-ruff-format): - -```elisp -(require 'ruff-format) -(add-hook 'python-mode-hook 'ruff-format-on-save-mode) -``` - -Alternatively, it can be used via the [Apheleia](https://github.com/radian-software/apheleia) formatter library, by setting this configuration: - -```emacs-lisp -;; Replace default (black) to use ruff for sorting import and formatting. -(setf (alist-get 'python-mode apheleia-mode-alist) - '(ruff-isort ruff)) -(setf (alist-get 'python-ts-mode apheleia-mode-alist) - '(ruff-isort ruff)) -``` - -## TextMate (Unofficial) - -Ruff is also available via the [`textmate2-ruff-linter`](https://github.com/vigo/textmate2-ruff-linter) -bundle for TextMate. - -## mdformat (Unofficial) - -[mdformat](https://mdformat.readthedocs.io/en/stable/users/plugins.html#code-formatter-plugins) is -capable of formatting code blocks within Markdown. The [`mdformat-ruff`](https://github.com/Freed-Wu/mdformat-ruff) -plugin enables mdformat to format Python code blocks with Ruff. - ## GitHub Actions GitHub Actions has everything you need to run Ruff out-of-the-box: @@ -392,3 +70,64 @@ For example, to run `ruff check --select B ./src` using Ruff version `0.0.259`: args: check --select B src: "./src" ``` + +## pre-commit + +Ruff can be used as a [pre-commit](https://pre-commit.com) hook via [`ruff-pre-commit`](https://github.com/astral-sh/ruff-pre-commit): + +```yaml +- repo: https://github.com/astral-sh/ruff-pre-commit + # Ruff version. + rev: v0.5.2 + hooks: + # Run the linter. + - id: ruff + # Run the formatter. + - id: ruff-format +``` + +To enable lint fixes, add the `--fix` argument to the lint hook: + +```yaml +- repo: https://github.com/astral-sh/ruff-pre-commit + # Ruff version. + rev: v0.5.2 + hooks: + # Run the linter. + - id: ruff + args: [ --fix ] + # Run the formatter. + - id: ruff-format +``` + +To run the hooks over Jupyter Notebooks too, add `jupyter` to the list of allowed filetypes: + +```yaml +- repo: https://github.com/astral-sh/ruff-pre-commit + # Ruff version. + rev: v0.5.2 + hooks: + # Run the linter. + - id: ruff + types_or: [ python, pyi, jupyter ] + args: [ --fix ] + # Run the formatter. + - id: ruff-format + types_or: [ python, pyi, jupyter ] +``` + +When running with `--fix`, Ruff's lint hook should be placed _before_ Ruff's formatter hook, and +_before_ Black, isort, and other formatting tools, as Ruff's fix behavior can output code changes +that require reformatting. + +When running without `--fix`, Ruff's formatter hook can be placed before or after Ruff's lint hook. + +(As long as your Ruff configuration avoids any [linter-formatter incompatibilities](formatter.md#conflicting-lint-rules), +`ruff format` should never introduce new lint errors, so it's safe to run Ruff's format hook _after_ +`ruff check --fix`.) + +## `mdformat` + +[mdformat](https://mdformat.readthedocs.io/en/stable/users/plugins.html#code-formatter-plugins) is +capable of formatting code blocks within Markdown. The [`mdformat-ruff`](https://github.com/Freed-Wu/mdformat-ruff) +plugin enables mdformat to format Python code blocks with Ruff. diff --git a/scripts/generate_mkdocs.py b/scripts/generate_mkdocs.py index 5085f4400b82e..897a14da26649 100644 --- a/scripts/generate_mkdocs.py +++ b/scripts/generate_mkdocs.py @@ -8,7 +8,7 @@ import shutil import subprocess from pathlib import Path -from typing import NamedTuple +from typing import NamedTuple, Sequence import mdformat import yaml @@ -22,6 +22,8 @@ class Section(NamedTuple): title: str filename: str generated: bool + # If subsections is present, the `filename` and `generated` value is unused. + subsections: Sequence[Section] | None = None SECTIONS: list[Section] = [ @@ -30,6 +32,18 @@ class Section(NamedTuple): Section("Installing Ruff", "installation.md", generated=False), Section("The Ruff Linter", "linter.md", generated=False), Section("The Ruff Formatter", "formatter.md", generated=False), + Section( + "Editors", + "", + generated=False, + subsections=[ + Section("Editor Integration", "editors/index.md", generated=False), + Section("Setup", "editors/setup.md", generated=False), + Section("Features", "editors/features.md", generated=False), + Section("Settings", "editors/settings.md", generated=False), + Section("Migrating from ruff-lsp", "editors/migration.md", generated=False), + ], + ), Section("Configuring Ruff", "configuration.md", generated=False), Section("Preview", "preview.md", generated=False), Section("Rules", "rules.md", generated=True), @@ -108,7 +122,7 @@ def main() -> None: Path("docs").mkdir(parents=True, exist_ok=True) # Split the README.md into sections. - for title, filename, generated in SECTIONS: + for title, filename, generated, _ in SECTIONS: if not generated: continue @@ -180,7 +194,19 @@ def main() -> None: ) # Add the nav section to mkdocs.yml. - config["nav"] = [{section.title: section.filename} for section in SECTIONS] + config["nav"] = [] + for section in SECTIONS: + if section.subsections is None: + config["nav"].append({section.title: section.filename}) + else: + config["nav"].append( + { + section.title: [ + {subsection.title: subsection.filename} + for subsection in section.subsections + ] + } + ) with Path("mkdocs.generated.yml").open("w+", encoding="utf8") as fp: yaml.safe_dump(config, fp)