Neovim plugin that helps manage python requirements.
demo.mp4
- Integrated with
nvim-cmp
andblink.nvim
- Uses
treesitter
parser to readrequirements.txt
, more robust than ad-hoc parsing - Displays diagnostics in
normal
mode with warnings for not using latest version - Cache
pypi
responses within a session to improve performance - Auto upgrade dependencies when keymaps are configured
- Display package description from PyPI in a floating window with syntax highlighting
- Supports custom
index-url
andextra-index-url
for finding packages
- Only supports
requirements.txt
files, if there's interest this can be expanded, more details in ISSUE-10 - Does not read or otherwise interact with
pip.conf
file
- neovim
>= 0.10.0
- treesitter parser:
- requirements:
Used to parse
requirements
files
- requirements:
Used to parse
- System dependencies:
curl
: Used to call pypi API
{
'MeanderingProgrammer/py-requirements.nvim',
dependencies = { 'nvim-treesitter/nvim-treesitter' },
config = function()
require('py-requirements').setup({})
end,
}
Below is the configuration that gets used by default, any part of it can be modified by the user.
require('py-requirements').setup({
-- Enabled by default if you do not use `nvim-cmp` set to false
enable_cmp = true,
-- Endpoint used for getting package versions
index_url = 'https://pypi.org/simple/',
-- Fallback endpoint in case 'index_url' fails to find a package
extra_index_url = nil,
-- Specify which file patterns plugin is active on
-- For info on patterns, see :h pattern
file_patterns = { 'requirements.txt' },
-- Options for how diagnsotics are displayed
diagnostic_opts = { padding = 5 },
-- For available options, see :h vim.lsp.util.open_floating_preview
float_opts = { border = 'rounded' },
filter = {
-- If set to true pull only final release versions, this will ignore alpha,
-- beta, release candidate, post release, and developmental release versions
final_release = false,
-- If set to true (default value) filter out yanked package versions
yanked = true,
},
-- Query to get each dependency present in a file
requirement_query = '(requirement) @requirement',
-- Query to get information out of each dependency
dependency_query = [[
(requirement (package) @name)
(version_spec (version_cmp) @cmp)
(version_spec (version) @version)
]],
})
config = function()
local requirements = require('py-requirements')
vim.keymap.set('n', '<leader>ru', requirements.upgrade, { silent = true, desc = 'Requirements: Upgrade' })
vim.keymap.set('n', '<leader>rU', requirements.upgrade_all, { silent = true, desc = 'Requirements: Upgrade All' })
vim.keymap.set('n', '<leader>rK', requirements.show_description, { silent = true, desc = 'Requirements: Show package description' })
requirements.setup({...})
end
{
'saghen/blink.cmp',
opts = {
sources = {
-- Add pypi to your default sources
default = { 'lsp', 'path', 'snippets', 'buffer', 'pypi' },
providers = {
pypi = {
name = 'Pypi',
module = 'py-requirements.integrations.blink',
fallbacks = { 'lsp' },
},
},
},
},
}
local cmp = require('cmp')
cmp.setup({
...
sources = cmp.config.sources({
...
{ name = 'py-requirements' },
...
}),
...
})
The ideal (latest to oldest version) ordering is defined by the sortText
attribute of each completion item sent to nvim-cmp
.
By default this comparator has been disabled by nvim-cmp
. There are various
ways to enable it including at a file type level. Below is an example of enabling
it globally, note that this will likely impact the ordering of other completion sources.
local cmp = require('cmp')
local compare = require('cmp.config.compare')
cmp.setup({
...
sorting = {
priority_weight = 2,
comparators = {
compare.exact,
compare.score,
compare.sort_text,
compare.offset,
...
},
},
...
})
just test
- crates.nvim: Many ideas were taken from this project and translated to work with Python dependencies rather than Rust crates
- cmp-pypi: Found this one rather late, similar
idea but built to work with
pyproject.toml
files
- Is there a way to configure
nvim-cmp
automatically withrequire('cmp.config').set_buffer
, would likely run as part ofload
autocmd.