aboutsummaryrefslogtreecommitdiff
path: root/config/nvim/lua/plugins/blink.lua
diff options
context:
space:
mode:
authorWilliam Hergès <william@herges.fr>2025-08-12 15:25:31 +0200
committerWilliam Hergès <william@herges.fr>2025-08-12 15:25:31 +0200
commit3fa491d7a40304b27040cbd650ff23cca293e8b2 (patch)
tree2212e26cdc1f3d313a6fc0a8f017a70a838e6527 /config/nvim/lua/plugins/blink.lua
parentab93bfa16d109a09d49e35e77e7fb2634f8bb0c1 (diff)
feat(config): nvim
Diffstat (limited to 'config/nvim/lua/plugins/blink.lua')
-rw-r--r--config/nvim/lua/plugins/blink.lua84
1 files changed, 84 insertions, 0 deletions
diff --git a/config/nvim/lua/plugins/blink.lua b/config/nvim/lua/plugins/blink.lua
new file mode 100644
index 0000000..b69b537
--- /dev/null
+++ b/config/nvim/lua/plugins/blink.lua
@@ -0,0 +1,84 @@
+return {
+ {
+ "saghen/blink.cmp",
+ -- optional: provides snippets for the snippet source
+ dependencies = { "rafamadriz/friendly-snippets" },
+
+ -- Use a release tag to download pre-built binaries
+ version = "*",
+ -- 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 the latest nightly rust with:
+ -- build = 'nix run .#build-plugin',
+
+ 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 = {
+ -- Each keymap may be a list of commands and/or functions
+ preset = "enter",
+ -- Select completions
+ ["<Up>"] = { "select_prev", "fallback" },
+ ["<Down>"] = { "select_next", "fallback" },
+ ["<Tab>"] = { "select_next", "fallback" },
+ ["<S-Tab>"] = { "select_prev", "fallback" },
+ -- Scroll documentation
+ ["<C-b>"] = { "scroll_documentation_up", "fallback" },
+ ["<C-f>"] = { "scroll_documentation_down", "fallback" },
+ -- Show/hide signature
+ ["<C-k>"] = { "show_signature", "hide_signature", "fallback" },
+ },
+
+ appearance = {
+ -- 'mono' (default) for 'Nerd Font Mono' or 'normal' for 'Nerd Font'
+ -- Adjusts spacing to ensure icons are aligned
+ nerd_font_variant = "mono",
+ },
+
+ sources = {
+ -- `lsp`, `buffer`, `snippets`, `path`, and `omni` are built-in
+ -- so you don't need to define them in `sources.providers`
+ default = { "lsp", "path", "snippets", "buffer" },
+
+ -- Sources are configured via the sources.providers table
+ },
+
+ -- (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" },
+ completion = {
+ -- The keyword should only match against the text before
+ keyword = { range = "prefix" },
+ menu = {
+ -- Use treesitter to highlight the label text for the given list of sources
+ draw = {
+ treesitter = { "lsp" },
+ },
+ },
+ -- Show completions after typing a trigger character, defined by the source
+ trigger = { show_on_trigger_character = true },
+ documentation = {
+ -- Show documentation automatically
+ auto_show = true,
+ },
+ },
+
+ -- Signature help when tying
+ signature = { enabled = true },
+ },
+ opts_extend = { "sources.default" },
+ }
+}