-- ~/.config/nvim/init.lua -- ============================================================================= -- 1. BOOTSTRAP PAQ (Plugin Manager Installation) -- ============================================================================= local data_path = vim.fn.stdpath("data") .. "/site/pack/paqs/start/" local paq_path = data_path .. "paq-nvim" if vim.fn.empty(vim.fn.glob(paq_path)) > 0 then print("Installiere Paq...") vim.fn.system({ "git", "clone", "--depth=1", "https://github.com/savq/paq-nvim.git", paq_path }) vim.cmd("packadd paq-nvim") end -- ============================================================================= -- 2. PLUGINS LADEN & AUTO-INSTALL -- ============================================================================= local plugins = require("plugins") local paq = require("paq") paq(plugins) local missing_plugins = false for _, plugin in ipairs(plugins) do local plugin_name = type(plugin) == "table" and plugin[1] or plugin local name = plugin_name:match(".*/(.*)") if name and vim.fn.empty(vim.fn.glob(data_path .. name)) > 0 then missing_plugins = true break end end if missing_plugins then print("Neue Plugins gefunden. Installiere... Bitte danach Neovim neu starten.") paq.install() end -- ============================================================================= -- 3. EDITOR OPTIONEN (A11y / Screenreader optimiert) -- ============================================================================= local opt = vim.opt opt.number = false opt.relativenumber = false opt.showcmd = false opt.laststatus = 0 opt.ruler = false opt.showmode = false opt.mouse = "" opt.shortmess:append("atI") opt.hidden = true opt.termguicolors = true -- Wichtig für moderne LSPs/UI -- ============================================================================= -- 4. DIAGNOSTICS (Fehleranzeige) -- ============================================================================= vim.diagnostic.config({ virtual_text = false, -- Kein Text-Rauschen in der Zeile underline = true, -- Fehler werden unterstrichen signs = false, -- Keine Icons am Rand (weniger Lärm) update_in_insert = false, }) -- ============================================================================= -- 5. KEYMAPS (Leader: Leertaste) -- ============================================================================= vim.g.mapleader = " " -- Fehlerliste (Quickfix) öffnen vim.keymap.set("n", "e", vim.diagnostic.setqflist, { desc = "Fehlerliste zeigen" }) -- Dashboard öffnen vim.keymap.set("n", "b", function() local ok, dashboard = pcall(require, "config.dashboard") if ok then dashboard.open() else print("Dashboard nicht gefunden!") end end, { desc = "Zurück zum Dashboard" }) -- Core Update local ok_up, updater = pcall(require, "core.update") if ok_up then vim.keymap.set("n", "U", updater.update, { desc = "Update MonoVim Core" }) end -- ============================================================================= -- 6. MASON & LSP SETUP (VERZÖGERT FÜR STABILITÄT) -- ============================================================================= vim.schedule(function() local ok_mason, mason = pcall(require, "mason") local ok_mason_lsp, mason_lspconfig = pcall(require, "mason-lspconfig") local ok_lspconfig, lspconfig = pcall(require, "lspconfig") if ok_mason and ok_mason_lsp and ok_lspconfig then mason.setup({ ui = { border = "rounded" } }) mason_lspconfig.setup({ ensure_installed = { "basedpyright", "rust_analyzer", "lua_ls" }, }) -- Sicherheitscheck: Existiert die Funktion wirklich? if mason_lspconfig.setup_handlers then mason_lspconfig.setup_handlers({ -- Standard-Handler für jeden installierten Server function(server_name) local opts = {} -- Falls nvim-cmp für Autovervollständigung genutzt wird local ok_cmp, cmp_lsp = pcall(require, "cmp_nvim_lsp") if ok_cmp then opts.capabilities = cmp_lsp.default_capabilities() end lspconfig[server_name].setup(opts) end, -- Spezial-Konfiguration für Lua (verhindert 'vim' Warnungen) ["lua_ls"] = function() lspconfig.lua_ls.setup({ settings = { Lua = { diagnostics = { globals = { "vim" } } } } }) end, }) end end end) local ok_oil, oil = pcall(require, "oil") if ok_oil then oil.setup({ default_file_explorer = true, columns = { "icon" }, -- Du kannst "icon" auch löschen für puren Text view_options = { show_hidden = true, }, }) -- Keymap: Leertaste + f (File) vim.keymap.set("n", "f", "Oil", { desc = "Öffne File Manager" }) end -- ============================================================================= -- 7. BUFFER MANAGEMENT & DASHBOARD LOGIK -- ============================================================================= local ok_mini, bufremove = pcall(require, "mini.bufremove") if ok_mini then bufremove.setup({}) end local function force_dashboard() vim.schedule(function() local listed = vim.fn.getbufinfo({buflisted = 1}) if #listed == 0 or (#listed == 1 and listed[1].name == "" and vim.bo[listed[1].bufnr].filetype == "") then local ok_dash, dashboard = pcall(require, "config.dashboard") if ok_dash then dashboard.open() end end end) end -- Buffer schließen (Speichern-Abfrage integriert) vim.keymap.set("n", "d", function() if vim.bo.modified then local choice = vim.fn.confirm("Änderungen speichern?", "&Ja\n&Nein\n&Abbrechen", 1) if choice == 1 then vim.cmd("write") elseif choice == 3 then return end end if ok_mini then bufremove.delete(0, true) else vim.cmd("bd!") end end, { desc = "Buffer schließen" }) -- Autocommands für Dashboard (beim Start und beim Löschen von Buffern) vim.api.nvim_create_autocmd({ "VimEnter", "BufDelete" }, { callback = function() force_dashboard() end })