105 lines
4.0 KiB
Lua
105 lines
4.0 KiB
Lua
return {
|
|
{
|
|
'milanglacier/minuet-ai.nvim',
|
|
dependencies = {
|
|
'nvim-lua/plenary.nvim',
|
|
'Saghen/blink.cmp'
|
|
},
|
|
config = function()
|
|
require('minuet').setup {
|
|
provider = 'openai_fim_compatible',
|
|
n_completions = 1, -- recommend for local model for resource saving
|
|
-- I recommend beginning with a small context window size and incrementally
|
|
-- expanding it, depending on your local computing power. A context window
|
|
-- of 512, serves as an good starting point to estimate your computing
|
|
-- power. Once you have a reliable estimate of your local computing power,
|
|
-- you should adjust the context window to a larger value.
|
|
context_window = 512,
|
|
provider_options = {
|
|
openai_fim_compatible = {
|
|
-- For Windows users, TERM may not be present in environment variables.
|
|
-- Consider using APPDATA instead.
|
|
api_key = 'TERM',
|
|
name = 'Ollama',
|
|
end_point = 'http://localhost:11434/v1/completions',
|
|
model = 'qwen2.5-coder:7b',
|
|
optional = {
|
|
max_tokens = 56,
|
|
top_p = 0.9,
|
|
},
|
|
},
|
|
},
|
|
}
|
|
end,
|
|
},
|
|
{
|
|
'saghen/blink.cmp',
|
|
-- optional: provides snippets for the snippet source
|
|
dependencies = { 'rafamadriz/friendly-snippets' },
|
|
|
|
-- use a release tag to download pre-built binaries
|
|
version = '1.*',
|
|
-- AND/OR build from source, requires nightly: https://rust-lang.github.io/rustup/concepts/channels.html#working-with-nightly-rust
|
|
-- build = 'cargo build --release',
|
|
-- If you use nix, you can build from source using latest nightly rust with:
|
|
-- build = 'nix run .#build-plugin',
|
|
|
|
---@module 'blink.cmp'
|
|
---@type blink.cmp.Config
|
|
opts = {
|
|
-- 'default' (recommended) for mappings similar to built-in completions (C-y to accept)
|
|
-- 'super-tab' for mappings similar to vscode (tab to accept)
|
|
-- 'enter' for enter to accept
|
|
-- 'none' for no mappings
|
|
--
|
|
-- All presets have the following mappings:
|
|
-- C-space: Open menu or open docs if already open
|
|
-- C-n/C-p or Up/Down: Select next/previous item
|
|
-- C-e: Hide menu
|
|
-- C-k: Toggle signature help (if signature.enabled = true)
|
|
--
|
|
-- See :h blink-cmp-config-keymap for defining your own keymap
|
|
keymap = { preset = 'default' },
|
|
|
|
appearance = {
|
|
-- 'mono' (default) for 'Nerd Font Mono' or 'normal' for 'Nerd Font'
|
|
-- Adjusts spacing to ensure icons are aligned
|
|
nerd_font_variant = 'mono'
|
|
},
|
|
|
|
completion = { trigger = { prefetch_on_insert = false }, documentation = { auto_show = false } },
|
|
|
|
-- Default list of enabled providers defined so that you can extend it
|
|
-- elsewhere in your config, without redefining it, due to `opts_extend`
|
|
sources = {
|
|
default = { 'lsp', 'path', 'snippets', 'buffer', 'minuet' },
|
|
},
|
|
-- (Default) Rust fuzzy matcher for typo resistance and significantly better performance
|
|
-- You may use a lua implementation instead by using `implementation = "lua"` or fallback to the lua implementation,
|
|
-- when the Rust fuzzy matcher is not available, by using `implementation = "prefer_rust"`
|
|
--
|
|
-- See the fuzzy documentation for more information
|
|
fuzzy = { implementation = "prefer_rust_with_warning" }
|
|
},
|
|
opts_extend = { "sources.default" },
|
|
config = function()
|
|
require('blink-cmp').setup {
|
|
sources = {
|
|
default = { 'lsp', 'path', 'buffer', 'snippets', 'minuet' },
|
|
providers = {
|
|
minuet = {
|
|
name = 'minuet',
|
|
module = 'minuet.blink',
|
|
async = true,
|
|
-- Should match minuet.config.request_timeout * 1000,
|
|
-- since minuet.config.request_timeout is in seconds
|
|
timeout_ms = 3000,
|
|
score_offset = 50, -- Gives minuet higher priority among suggestions
|
|
},
|
|
},
|
|
},
|
|
}
|
|
end
|
|
}
|
|
}
|