chore: remove local/unused plugins and refactor core configs

- Remove locally-developed or rarely-used plugin packages (codetyper, curls, edgy, flash) to reduce maintenance surface, external deps, and startup cost; these were local/optional and caused complexity.
- Clean up stale/keymap docs and small duplicate or experimental files (keymaps/README.md, sudoku keymaps).
- Apply targeted refactors to core modules for readability, robustness, and to align Java/DAP/Copilot integrations with local environment.
- Removed plugin modules:
  - lua/cargdev/plugins/codetyper.lua (deleted)
  - lua/cargdev/plugins/curls.lua (deleted)
  - lua/cargdev/plugins/edgy.lua (deleted)
  - lua/cargdev/plugins/flash.lua (deleted)
  - Added .codetyper to .gitignore
- Java / JDTLS:
  - ftplugin/java.lua: pin jdtls java executable to JDK 25, switch to mac_arm config, enable LSP formatter and declare multiple runtimes (JavaSE-17, JavaSE-25).
- Notifications & startup UX:
  - lua/cargdev/core/function/notification_manager.lua: large refactor — use local aliases (api, cmd, loop, opt), improved docs, dashboard-aware handling, nvim-notify fallback, safer tracking and cleanup of notifications.
- Utilities & monitors:
  - lua/cargdev/core/function/performance_monitor.lua: use local references, better notify usage and docs.
  - lua/cargdev/core/function/project_commands.lua: add docs, use local api/fn/notify, clearer RunProject/DebugProject commands.
- Terminal helper:
  - lua/cargdev/core/function/openTerminal.lua: add module docs and small refactor to use local cmd/api aliases and expose keymap.
- Keymaps & docs:
  - Removed stale keymaps README (lua/cargdev/core/keymaps/README.md).
  - Reworked many keymap files: docstrings, renamed/moved mappings to avoid conflicts, moved DAP mappings into dap plugin config, removed/disabled experimental mappings (see files under lua/cargdev/core/keymaps/*).
  - Adjusted quick keybindings and prefixes to reduce overlaps.
- Plugins & integrations:
  - lua/cargdev/plugins/formatting.lua: disabled google-java-format fallback for java (prefer JDTLS).
  - lua/cargdev/plugins/dap.lua: added additional DAP configs (Bun launch, attach helper), moved/registered dap keymaps here.
  - lua/cargdev/plugins/copilot.lua: reorganized Copilot/Copilot-cmp/CopilotChat config and added copilot source to nvim-cmp.
  - lua/cargdev/plugins/nvim-cmp.lua: added copilot source and small formatting tweak.
This commit is contained in:
2026-02-10 12:17:36 -05:00
parent 832a664fa0
commit 06dbe4d892
34 changed files with 899 additions and 950 deletions

View File

@@ -88,7 +88,9 @@ return {
require("mason-nvim-dap").setup({
ensure_installed = { "python", "js", "javadbg", "javatest" },
automatic_installation = true,
handlers = {},
handlers = {
firefox = function() end, -- Disable Firefox auto-config for TS/JS
},
})
-- 🔍 Virtual Text
@@ -232,6 +234,20 @@ return {
}
dap.configurations.typescript = {
{
name = "Launch with Bun",
type = "pwa-node",
request = "launch",
runtimeExecutable = "bun",
runtimeArgs = { "--inspect-brk" },
program = "${file}",
cwd = "${workspaceFolder}",
sourceMaps = true,
resolveSourceMapLocations = { "${workspaceFolder}/**", "!**/node_modules/**" },
console = "internalConsole",
skipFiles = { "<node_internals>/**", "node_modules/**" },
attachSimplePort = 6499,
},
{
name = "Launch NestJS (dist/main.js)",
type = "pwa-node",
@@ -245,7 +261,7 @@ return {
skipFiles = { "<node_internals>/**", "node_modules/**" },
},
{
name = "Launch Current File",
name = "Launch Current File (Node)",
type = "pwa-node",
request = "launch",
program = "${file}",
@@ -289,6 +305,74 @@ return {
},
}
-- 🎮 DAP Keymaps (registered here so dap/dapui are already loaded)
keymap("n", "<leader>dcr", dap.continue, { desc = "▶ Start Debugging" })
keymap("n", "<leader>do", dap.step_over, { desc = "⏭ Step Over" })
keymap("n", "<leader>di", dap.step_into, { desc = "⤵ Step Into" })
keymap("n", "<leader>dot", dap.step_out, { desc = "⤴ Step Out" })
keymap("n", "<leader>db", dap.toggle_breakpoint, { desc = "🔴 Toggle Breakpoint" })
keymap("n", "<leader>dB", function()
dap.set_breakpoint(fn.input("Breakpoint condition: "))
end, { desc = "⚠ Conditional Breakpoint" })
keymap("n", "<leader>dr", dap.repl.open, { desc = "💬 Open REPL" })
keymap("n", "<leader>dl", dap.run_last, { desc = "🔁 Run Last Debug" })
keymap("n", "<leader>du", dapui.toggle, { desc = "🧩 Toggle DAP UI" })
keymap("n", "<leader>dq", dap.terminate, { desc = "⛔ Stop Debugging" })
keymap("n", "<leader>drt", function()
dap.terminate()
dapui.close()
vim.defer_fn(function()
dapui.open()
end, 200)
end, { desc = "🧼 Reset DAP UI Layout" })
keymap("n", "<leader>dcf", function()
local ft = vim.bo.filetype
local configs = dap.configurations[ft] or {}
if #configs == 0 then
vim.notify("No DAP configurations for filetype: " .. ft, vim.log.levels.WARN)
return
end
vim.ui.select(configs, {
prompt = "Select DAP configuration:",
format_item = function(item) return item.name end,
}, function(config)
if config then dap.run(config) end
end)
end, { desc = "🔭 DAP Configs" })
keymap("n", "<leader>dcb", function()
dap.list_breakpoints()
vim.cmd("copen")
end, { desc = "🧷 List Breakpoints" })
keymap("n", "<leader>dco", dap.repl.open, { desc = "⚙️ DAP Commands" })
-- 🔌 Dynamic Debug Attach (no hardcoded ports)
-- Bun requires --inspect=host:port/debug to set a known WebSocket path
-- because it doesn't implement /json/list for auto-discovery.
keymap("n", "<leader>jd", function()
vim.ui.input({ prompt = "Inspector port (default 6499): " }, function(input)
if input == nil then return end -- cancelled
local port = input ~= "" and input or "6499"
local port_num = tonumber(port)
if not port_num then
vim.notify("Invalid port number", vim.log.levels.ERROR)
return
end
local ws_url = "ws://localhost:" .. port .. "/debug"
vim.notify("Attaching to " .. ws_url, vim.log.levels.INFO)
dap.run({
name = "Attach (" .. ws_url .. ")",
type = "pwa-node",
request = "attach",
websocketAddress = ws_url,
cwd = fn.getcwd(),
sourceMaps = true,
resolveSourceMapLocations = { "${workspaceFolder}/**", "!**/node_modules/**" },
skipFiles = { "<node_internals>/**", "node_modules/**" },
restart = true,
})
end)
end, { desc = "🔌 Debug Attach (dynamic)" })
-- JavaScript uses same configurations as TypeScript
dap.configurations.javascript = {
{
@@ -309,5 +393,9 @@ return {
skipFiles = { "<node_internals>/**", "node_modules/**" },
},
}
-- TSX/JSX use the same configurations as their base languages
dap.configurations.typescriptreact = dap.configurations.typescript
dap.configurations.javascriptreact = dap.configurations.javascript
end,
}