migrated to vim.lsp.config()

This commit is contained in:
Bryan Ramos 2026-03-08 22:39:14 -04:00
parent d1144e96d3
commit e6ac6638c2
Signed by: bryan
GPG key ID: 6ABDCD144D6643C8
7 changed files with 196 additions and 97 deletions

View file

@ -4,7 +4,10 @@ vim.g.autoformat = false
vim.opt.number = true vim.opt.number = true
vim.opt.relativenumber = true vim.opt.relativenumber = true
vim.opt.cursorline = true vim.opt.cursorline = true
vim.opt.termguicolors = true -- Enable true color if terminal supports it (disabled in TTY/headless)
if vim.env.COLORTERM == "truecolor" or vim.env.COLORTERM == "24bit" then
vim.opt.termguicolors = true
end
vim.opt.tabstop = 2 vim.opt.tabstop = 2
vim.opt.shiftwidth = 2 vim.opt.shiftwidth = 2
@ -12,14 +15,13 @@ vim.opt.softtabstop = 2
vim.opt.expandtab = true vim.opt.expandtab = true
vim.opt.smartindent = true vim.opt.smartindent = true
vim.opt.ignorecase = true vim.opt.ignorecase = true
vim.opt.smartcase = false vim.opt.smartcase = true
vim.opt.incsearch = false vim.opt.incsearch = false
vim.opt.swapfile = false vim.opt.swapfile = false
vim.opt.backup = false vim.opt.backup = false
vim.opt.undofile = true vim.opt.undofile = true
vim.o.termguicolors = false
vim.opt.guicursor = "n-v-c:block,i:block,r:block" vim.opt.guicursor = "n-v-c:block,i:block,r:block"
vim.opt.fillchars = { eob = " " } vim.opt.fillchars = { eob = " " }

View file

@ -4,7 +4,37 @@ return {
version = "*", version = "*",
dependencies = "nvim-tree/nvim-web-devicons", dependencies = "nvim-tree/nvim-web-devicons",
config = function() config = function()
require("bufferline").setup{} require("bufferline").setup{
options = {
separator_style = "thin",
show_buffer_close_buttons = false,
show_close_icon = false,
},
highlights = {
-- Force all icon backgrounds to transparent
buffer_selected = { bg = "NONE" },
buffer_visible = { bg = "NONE" },
background = { bg = "NONE" },
fill = { bg = "NONE" },
separator = { bg = "NONE" },
separator_selected = { bg = "NONE" },
separator_visible = { bg = "NONE" },
close_button = { bg = "NONE" },
close_button_selected = { bg = "NONE" },
close_button_visible = { bg = "NONE" },
modified = { bg = "NONE" },
modified_selected = { bg = "NONE" },
modified_visible = { bg = "NONE" },
duplicate = { bg = "NONE" },
duplicate_selected = { bg = "NONE" },
duplicate_visible = { bg = "NONE" },
indicator_selected = { bg = "NONE" },
indicator_visible = { bg = "NONE" },
pick = { bg = "NONE" },
pick_selected = { bg = "NONE" },
pick_visible = { bg = "NONE" },
},
}
end end
} }
} }

View file

@ -37,6 +37,23 @@ return {
hi DiffChange ctermbg=none guibg=none hi DiffChange ctermbg=none guibg=none
hi DiffDelete ctermbg=none guibg=none hi DiffDelete ctermbg=none guibg=none
hi DiffText ctermbg=none guibg=none hi DiffText ctermbg=none guibg=none
" Bufferline - dark background, readable text
hi BufferLineFill guibg=NONE ctermbg=NONE
hi BufferLineBackground guibg=NONE ctermbg=NONE guifg=#5c6370 ctermfg=Gray
hi BufferLineBuffer guibg=NONE ctermbg=NONE guifg=#5c6370 ctermfg=Gray
hi BufferLineBufferSelected guibg=NONE ctermbg=NONE guifg=#FFFFFF ctermfg=White gui=bold cterm=bold
hi BufferLineBufferVisible guibg=NONE ctermbg=NONE guifg=#abb2bf ctermfg=White
hi BufferLineCloseButton guibg=NONE ctermbg=NONE guifg=#5c6370 ctermfg=Gray
hi BufferLineCloseButtonSelected guibg=NONE ctermbg=NONE guifg=#e06c75 ctermfg=Red
hi BufferLineCloseButtonVisible guibg=NONE ctermbg=NONE guifg=#5c6370 ctermfg=Gray
hi BufferLineModified guibg=NONE ctermbg=NONE guifg=#e5c07b ctermfg=Yellow
hi BufferLineModifiedSelected guibg=NONE ctermbg=NONE guifg=#e5c07b ctermfg=Yellow
hi BufferLineModifiedVisible guibg=NONE ctermbg=NONE guifg=#e5c07b ctermfg=Yellow
hi BufferLineSeparator guibg=NONE ctermbg=NONE guifg=#3e4452 ctermfg=DarkGray
hi BufferLineSeparatorSelected guibg=NONE ctermbg=NONE guifg=#3e4452 ctermfg=DarkGray
hi BufferLineSeparatorVisible guibg=NONE ctermbg=NONE guifg=#3e4452 ctermfg=DarkGray
hi BufferLineIndicatorSelected guibg=NONE ctermbg=NONE guifg=#61afef ctermfg=Blue
]]) ]])
vim.api.nvim_create_autocmd("TextYankPost", { vim.api.nvim_create_autocmd("TextYankPost", {

View file

@ -1,19 +1,16 @@
-- https://github.com/neovim/nvim-lspconfig/blob/master/doc/configs.md -- Neovim 0.11+ LSP configuration
local servers = { -- Uses nvim-lspconfig for server definitions + vim.lsp.enable() API
"ts_ls",
"pyright", -- Detect NixOS (Mason doesn't work on NixOS due to FHS issues)
"nil_ls", local is_nixos = vim.fn.filereadable("/etc/NIXOS") == 1
"cssls",
"html", -- Servers to ensure are installed via Mason (non-NixOS only)
"lua_ls", -- On NixOS, install these via extraPackages or per-project devShells
"marksman", local mason_ensure_installed = {
"tailwindcss", "lua_ls", -- Neovim config
"bashls", "nil_ls", -- Nix
"clangd", "bashls", -- Shell scripts
"jsonls", "jsonls", -- JSON configs
"vuels",
"rust_analyzer"
--"arduino-language-server"
} }
return { return {
@ -59,47 +56,6 @@ return {
end end
}, },
--{
-- "nvim-treesitter/nvim-treesitter-context",
-- dependencies = { "nvim-treesitter/nvim-treesitter" },
-- config = function()
-- require("treesitter-context").setup({
-- enable = true, -- Enable this plugin (Can be enabled/disabled later via commands)
-- max_lines = 3, -- How many lines the window should span. Values <= 0 mean no limit.
-- min_window_height = 0, -- Minimum editor window height to enable context. Values <= 0 mean no limit.
-- line_numbers = false,
-- multiline_threshold = 20, -- Maximum number of lines to collapse for a single context line
-- trim_scope = "outer", -- Which context lines to discard if `max_lines` is exceeded. Choices: 'inner', 'outer'
-- mode = "cursor", -- Line used to calculate context. Choices: 'cursor', 'topline'
-- -- Separator between context and content. Should be a single character string, like '-'.
-- -- When separator is set, the context will only show up when there are at least 2 lines above cursorline.
-- separator = "x",
-- zindex = 20, -- The Z-index of the context window
-- on_attach = nil, -- (fun(buf: integer): boolean) rurn false to disable attaching
-- })
-- end,
--},
{
"VonHeikemen/lsp-zero.nvim",
branch = "v2.x",
dependencies = {
{ "neovim/nvim-lspconfig" },
{ "hrsh7th/nvim-cmp" },
{ "hrsh7th/cmp-buffer" },
{ "hrsh7th/cmp-path" },
{ "hrsh7th/cmp-nvim-lsp" },
{ "L3MON4D3/LuaSnip" },
},
config = function()
local lsp = require('lsp-zero').preset({})
lsp.setup_servers(servers)
lsp.setup()
end
},
{ {
"hrsh7th/nvim-cmp", "hrsh7th/nvim-cmp",
dependencies = { dependencies = {
@ -152,26 +108,64 @@ return {
end end
}, },
-- Mason: portable LSP installer (disabled on NixOS where it doesn't work)
{
"williamboman/mason.nvim",
enabled = not is_nixos,
config = function()
require("mason").setup()
end
},
{
"williamboman/mason-lspconfig.nvim",
enabled = not is_nixos,
dependencies = { "williamboman/mason.nvim" },
config = function()
require("mason-lspconfig").setup({
ensure_installed = mason_ensure_installed,
automatic_installation = false, -- Only install what's in ensure_installed
})
end
},
{ {
"neovim/nvim-lspconfig", "neovim/nvim-lspconfig",
dependencies = {
"hrsh7th/cmp-nvim-lsp",
},
config = function() config = function()
local lsp = require('lspconfig') local lspconfig = require('lspconfig')
local navic = require('nvim-navic')
-- Get all known server names by scanning lspconfig's lsp directory
local function get_all_servers()
local servers = {}
local lsp_path = vim.fn.stdpath('data') .. '/lazy/nvim-lspconfig/lsp'
local files = vim.fn.globpath(lsp_path, '*.lua', false, true)
for _, file in ipairs(files) do
local server = vim.fn.fnamemodify(file, ':t:r')
table.insert(servers, server)
end
return servers
end
local all_servers = get_all_servers()
-- local navic = require('nvim-navic')
local capabilities = require('cmp_nvim_lsp').default_capabilities() local capabilities = require('cmp_nvim_lsp').default_capabilities()
for _, server in ipairs(servers) do -- Global config applied to all servers
lsp[server].setup { vim.lsp.config('*', {
-- Prevent LSP from autostarting autostart = false, -- Don't auto-attach, use <leader>css to start manually
autostart = false,
capabilities = capabilities, capabilities = capabilities,
on_attach = function(client, bufnr) -- on_attach = function(client, bufnr)
if client.server_capabilities.documentSymbolProvider then -- if client.server_capabilities.documentSymbolProvider then
navic.attach(client, bufnr) -- navic.attach(client, bufnr)
end -- end
end, -- end,
} })
end
lsp.lua_ls.setup { -- Server-specific settings (merged with lspconfig defaults)
vim.lsp.config.lua_ls = {
settings = { settings = {
Lua = { Lua = {
diagnostics = { diagnostics = {
@ -180,17 +174,70 @@ return {
} }
} }
} }
-- Check if server binary is available
local function is_server_installed(config)
if config.default_config and config.default_config.cmd then
local cmd = config.default_config.cmd[1]
return vim.fn.executable(cmd) == 1
end
return false
end
-- Find and start LSP server(s) for current filetype
local function lsp_start_smart()
local ft = vim.bo.filetype
if ft == '' then
vim.notify("No filetype detected", vim.log.levels.WARN)
return
end
-- Find all matching servers (filetype match + binary installed)
local matching = {}
for _, server in ipairs(all_servers) do
local ok, config = pcall(require, 'lspconfig.configs.' .. server)
if ok and config.default_config and config.default_config.filetypes then
if vim.tbl_contains(config.default_config.filetypes, ft) and is_server_installed(config) then
table.insert(matching, server)
end
end
end
-- Sort for consistent ordering
table.sort(matching)
local function start_server(server)
vim.lsp.enable(server) -- Register on-demand
vim.cmd('LspStart ' .. server)
end
if #matching == 0 then
vim.notify("No LSP server installed for filetype: " .. ft, vim.log.levels.WARN)
elseif #matching == 1 then
start_server(matching[1])
else
vim.ui.select(matching, {
prompt = "Select LSP server:",
}, function(choice)
if choice then
start_server(choice)
end
end)
end
end
-- LSP keybindings
require("which-key").add({ require("which-key").add({
{ "<leader>cs", group = "LSP Commands" }, { "<leader>cs", group = "LSP Commands" },
{ "<leader>cf", ":LspFormat<CR>", desc = "Code Format" }, { "<leader>cf", function() vim.lsp.buf.format() end, desc = "Code Format" },
{ "<leader>csi", ":LspInfo<CR>", desc = "LSP Info" }, { "<leader>csi", ":checkhealth vim.lsp<CR>", desc = "LSP Info" },
{ "<leader>csl", ":LspLog<CR>", desc = "LSP Log" },
{ "<leader>csr", ":LspRestart<CR>", desc = "LSP Restart" }, { "<leader>csr", ":LspRestart<CR>", desc = "LSP Restart" },
{ "<leader>css", ":LspStart<CR>", desc = "LSP Start" }, { "<leader>css", lsp_start_smart, desc = "LSP Start" },
{ "<leader>csx", ":LspStop<CR>", desc = "LSP Stop" }, { "<leader>csx", ":LspStop<CR>", desc = "LSP Stop" },
}) })
end end
}, },
{ {
"taproot-wizards/bitcoin-script-hints.nvim", "taproot-wizards/bitcoin-script-hints.nvim",
dependencies = { "nvim-treesitter/nvim-treesitter" }, dependencies = { "nvim-treesitter/nvim-treesitter" },

View file

@ -13,9 +13,16 @@ return {
position = "left", position = "left",
width = 20, width = 20,
}, },
--filesystem = { event_handlers = {
-- hijack_netrw_behavior = "disabled", {
--}, event = "neo_tree_window_after_open",
handler = function()
local win = vim.api.nvim_get_current_win()
vim.wo[win].winfixwidth = true
vim.wo[win].winfixbuf = true
end
},
},
}) })
local function toggle_neotree() local function toggle_neotree()

View file

@ -10,7 +10,7 @@ end
return { return {
{ {
"nvim-telescope/telescope.nvim", "nvim-telescope/telescope.nvim",
brach = '0.1.x', branch = '0.1.x',
dependencies = { dependencies = {
{ 'nvim-lua/plenary.nvim' }, { 'nvim-lua/plenary.nvim' },
{ 'nvim-tree/nvim-web-devicons' } { 'nvim-tree/nvim-web-devicons' }
@ -31,7 +31,7 @@ return {
-- Code -- Code
{ "gd", { "gd",
function() function()
local attached = vim.lsp.buf_get_clients(0) local attached = vim.lsp.get_clients({ bufnr = 0 })
if next(attached) ~= nil then if next(attached) ~= nil then
require('telescope.builtin').lsp_definitions() require('telescope.builtin').lsp_definitions()
else else

View file

@ -1,22 +1,18 @@
{ pkgs, ... }: { pkgs, ... }:
let let
# Essential LSPs for config files (project-specific LSPs go in devShells)
lsp = with pkgs; [ lsp = with pkgs; [
nil nixd
lua-language-server
marksman marksman
lua-language-server stylua taplo # TOML
nodePackages."@tailwindcss/language-server"
pyright
clang-tools
rust-analyzer
#arduino-language-server
]; ];
lsp' = with pkgs.nodePackages; [ lsp' = with pkgs.nodePackages; [
typescript-language-server vscode-langservers-extracted # jsonls, html, cssls
vscode-langservers-extracted
bash-language-server bash-language-server
#vls yaml-language-server
]; ];
extraPackages = with pkgs; [ extraPackages = with pkgs; [