From 27ff76915d548ebc19bcd1e9f802bb7c0386b4a6 Mon Sep 17 00:00:00 2001 From: Andres Monge Date: Mon, 23 Sep 2024 10:10:53 +0200 Subject: [PATCH] doc(usage): Including a null-ls use with neovim. (#167) Co-authored-by: jsh9 <25124332+jsh9@users.noreply.github.com> --- docs/notes_for_users.md | 44 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) diff --git a/docs/notes_for_users.md b/docs/notes_for_users.md index bffe2e4..ec64706 100644 --- a/docs/notes_for_users.md +++ b/docs/notes_for_users.md @@ -10,6 +10,8 @@ - [4. Notes on writing Sphinx-style docstrings](#4-notes-on-writing-sphinx-style-docstrings) - [5. Notes for Google-style users](#5-notes-for-google-style-users) - [6. How to adopt _pydoclint_ more easily in legacy projects](#6-how-to-adopt-pydoclint-more-easily-in-legacy-projects) +- [7. How to integrate _pydoclint_ with different editors or IDEs](#7-how-to-integrate-pydoclint-with-different-editors-or-ides) + - [7.1. Integrate _pydoclint_ with Neovim using null-ls](#71-integrate-pydoclint-with-neovim-using-null-ls) @@ -187,3 +189,45 @@ somewhere in your repo. For more details, please check out [this section](https://jsh9.github.io/pydoclint/config_options.html#12---baseline). + +## 7. How to integrate _pydoclint_ with different editors or IDEs + +### 7.1. Integrate _pydoclint_ with Neovim using null-ls + +If you use [Neovim](https://neovim.io/), you can integrate _pydoclint_ with +your editor using the [null-ls](https://github.com/nvimtools/none-ls.nvim) +plugin. null-ls allows you to use linters and formatters in Neovim in a simple +and efficient way. First, make sure you have installed null-ls using your +preferred package manager. Next, add the following configuration to your Neovim +config file to register _pydoclint_ as a diagnostic source: + +```lua +local null_ls = require("null-ls") + +null_ls.setup({ + sources = { + null_ls.builtins.diagnostics.pydoclint, + }, +}) +``` + +This will enable _pydoclint_ to provide diagnostic messages for your Python +code directly in Neovim. You can further customize the behavior of _pydoclint_ +by passing additional options: + +```lua +local null_ls = require("null-ls") + +null_ls.setup({ + sources = { + null_ls.builtins.diagnostics.pydoclint.with({ + extra_args = {"--style=google", "--check-return-types=False"}, + }), + }, +}) +``` + +Adjust the extra*args based on your preferred \_pydoclint* configuration. With +this setup, you can now enjoy the benefits of _pydoclint_'s fast and +comprehensive docstring linting directly within your Neovim editing +environment.