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.
26 lines
No EOL
685 B
Lua
26 lines
No EOL
685 B
Lua
-- LSP Configuration Module
|
|
local M = {}
|
|
|
|
function M.setup()
|
|
local lspconfig = require 'lspconfig'
|
|
|
|
-- Get capabilities from blink.cmp if available
|
|
local capabilities = {}
|
|
pcall(function()
|
|
capabilities = require('blink.cmp').get_lsp_capabilities()
|
|
end)
|
|
|
|
-- Load server configurations
|
|
local servers = require('plugins.config.lsp.servers').get_servers()
|
|
|
|
-- Setup each server with capabilities
|
|
for name, config in pairs(servers) do
|
|
config.capabilities = vim.tbl_deep_extend('force', {}, capabilities, config.capabilities or {})
|
|
lspconfig[name].setup(config)
|
|
end
|
|
|
|
-- Setup LSP keymaps
|
|
require('plugins.config.lsp.keymaps').setup()
|
|
end
|
|
|
|
return M |