doq (python docstring generator) extension for coc.nvim
CocInstall:
:CocInstall coc-pydocstring
vim-plug:
Plug 'yaegassy/coc-pydocstring', {'do': 'yarn install --frozen-lockfile'}
Quickly generate docstrings for python.
- Code Action
- Command
- Built-in installer
pydocstring.doqPath
setting- PATH environment (e.g. system global PATH or venv, etc ...)
- builtin: extension-only "venv" (Installation commands are also provided)
coc-pydocstring allows you to create an extension-only "venv" and install "doq".
The first time you use coc-pydocstring, if "doq" command is not detected, you will be prompted to do a built-in installation.
You can also run the installation command manually.
:CocCommand pydocstring.install
pydocstring.enable
: Enable coc-pydocstring extension, default:true
pydocstring.doqPath
: The path to the doq tool (Absolute path), default:""
pydocstring.builtin.pythonPath
: Python 3.x path (Absolute path) to be used for built-in install, default:""
pydocstring.enableInstallPrompt
: Prompt the user before install, default:true
pydocstring.formatter
: Docstring formatter (--formatter), valid options["sphinx", "google", "numpy"]
, default:"sphinx"
pydocstring.templatePath
: Path to template directory (--template_path), Settings starting with/
are recognized asabsolute path
, while others are treated asrelative path
from theworkspace root
. Additionally, both~
and$HOME
are also available and will be expanded asabsolute path
, default:""
pydocstring.ignoreException
: Ignore exception statements (--ignore_exception), default:false
pydocstring.ignoreYield
: Ignore yield statements (--ignore_yield), default:false
pydocstring.ignoreInit
: Ignore generate docstring to__init__
method (--ignore_init). This option only available at:CocCommand pydocstring.runFile
, default:false
pydocstring.enableFileAction
: Enable file-level code action, default:false
Example key mapping (Code Action related):
nmap <silent> ga <Plug>(coc-codeaction-line)
xmap <silent> ga <Plug>(coc-codeaction-selected)
nmap <silent> gA <Plug>(coc-codeaction)
Usage:
In a "line" or "selection" containing def
, async def
, or class
, enter the mapped key (e.g. ga
) and display a list of code actions that can be performed.
Add docstring for "Line or Selected" by pydocstring
Add docstring for "File" by pydocstring
- File-level code actions are disabled (
false
) by default. - If you want to use it, set
pydocstring.enableFileAction
totrue
in "coc-settings.json".
- File-level code actions are disabled (
pydocstring.runFile
: Run doq for filepydocstring.install
: Install doq- It will be installed in this path:
- Mac/Linux:
~/.config/coc/extensions/coc-pydocstring-data/doq/venv/bin/doq
- Windows:
~/AppData/Local/coc/extensions/coc-pydocstring-data/doq/venv/Scripts/doq.exe
- Mac/Linux:
- It will be installed in this path:
pydocstring.showOutput
: Show pydocstring output channel
- heavenshell/vim-pydocstring
- This is a vim plugin by the author of doq.
MIT
This extension is built with create-coc-extension