Major architectural overhaul to transform the flat kickstart.nvim structure
into a maintainable, modular configuration while preserving upstream sync capability.
## Structure Changes
- Migrated from flat `lua/custom/` to organized `lua/core/` and `lua/plugins/`
- Separated plugin specs from configs: `lua/plugins/spec/` and `lua/plugins/config/`
- Complex configs (LSP, Debug) now use directory structure with sub-modules:
- `lsp/init.lua`, `lsp/servers.lua`, `lsp/keymaps.lua`
- `debug/init.lua`, `debug/adapters.lua`, `debug/keymaps.lua`
## Core Improvements
- Created dedicated core modules: options, keymaps, autocmds, bootstrap, health
- Added comprehensive health check (`lua/core/health.lua`) for diagnostics
- Simplified init.lua to just orchestrate module loading
- Better separation of concerns throughout
## Plugin Updates
- Fixed Blink.cmp configuration (removed invalid fuzzy options)
- Integrated Copilot with Blink.cmp for unified completion experience
- Added autopairs and indent-line from kickstart examples
- Optimized for Nix development environments (removed venv assumptions)
## Documentation
- Updated README with modular structure and kickstart sync instructions
- Created comprehensive KEYBIND_ANALYSIS.md with all mappings
- Added modular.txt help documentation
- Created TODO_TEST.md checklist for testing
## Benefits
- Easier to maintain and extend
- Clean separation allows upstream kickstart merges without conflicts
- Scalable architecture for adding new languages/tools
- Better code organization and discoverability
All kickstart functionality preserved while gaining modularity and maintainability.
88 lines
No EOL
2 KiB
Lua
88 lines
No EOL
2 KiB
Lua
-- LSP Server Configurations
|
|
local M = {}
|
|
|
|
local util = require 'lspconfig.util'
|
|
|
|
-- Query driver for clangd to find compilers in various locations
|
|
local function get_clangd_query_driver()
|
|
return table.concat({
|
|
'/nix/store/*/bin/clang*',
|
|
'/opt/homebrew/opt/llvm/bin/clang*',
|
|
'/usr/bin/clang*',
|
|
}, ';')
|
|
end
|
|
|
|
-- Get clang resource directory
|
|
local function get_clang_resource_dir()
|
|
local ok, result = pcall(vim.fn.systemlist, { 'clang++', '--print-resource-dir' })
|
|
if ok and result and result[1] then
|
|
return result[1]
|
|
else
|
|
return '/usr/lib/clang/19/include' -- fallback
|
|
end
|
|
end
|
|
|
|
function M.get_servers()
|
|
return {
|
|
-- C/C++ Language Server
|
|
clangd = {
|
|
cmd = {
|
|
'clangd',
|
|
'--background-index',
|
|
'--clang-tidy',
|
|
'--header-insertion=never',
|
|
'--query-driver=' .. get_clangd_query_driver(),
|
|
'--compile-commands-dir=build',
|
|
'--resource-dir=' .. get_clang_resource_dir(),
|
|
},
|
|
filetypes = { 'c', 'cpp', 'objc', 'objcpp', 'cuda' },
|
|
root_dir = util.root_pattern('CMakeLists.txt', '.git'),
|
|
single_file_support = true,
|
|
},
|
|
|
|
-- Python Language Server
|
|
pyright = {
|
|
settings = {
|
|
python = {
|
|
analysis = {
|
|
autoSearchPaths = true,
|
|
diagnosticMode = 'openFilesOnly',
|
|
useLibraryCodeForTypes = true,
|
|
typeCheckingMode = 'basic',
|
|
},
|
|
},
|
|
},
|
|
positionEncoding = 'utf-8',
|
|
},
|
|
|
|
-- Python Linter/Formatter
|
|
ruff = {},
|
|
|
|
-- Nix Language Server
|
|
nixd = {},
|
|
|
|
-- LaTeX Language Server
|
|
texlab = {},
|
|
|
|
-- CMake Language Server
|
|
cmake = {
|
|
cmd = { 'cmake-language-server' },
|
|
filetypes = { 'cmake' },
|
|
root_dir = util.root_pattern('CMakeLists.txt', '.git'),
|
|
},
|
|
|
|
-- Add more servers here as needed
|
|
-- Example:
|
|
-- rust_analyzer = {
|
|
-- settings = {
|
|
-- ['rust-analyzer'] = {
|
|
-- checkOnSave = {
|
|
-- command = 'clippy',
|
|
-- },
|
|
-- },
|
|
-- },
|
|
-- },
|
|
}
|
|
end
|
|
|
|
return M |