mirror of
https://github.com/pojokcodeid/nvim-lazy.git
synced 2025-06-21 08:35:48 +02:00
202 lines
8.6 KiB
Lua
202 lines
8.6 KiB
Lua
local M = {}
|
|
M.java_filetypes = { "java" }
|
|
M.root_markers = { ".git", "mvnw", "gradlew", "pom.xml", "build.gradle" }
|
|
|
|
-- Utility function to extend or override a config table, similar to the way
|
|
-- that Plugin.opts works.
|
|
---@param config table
|
|
---@param custom function | table | nil
|
|
M.extend_or_override = function(config, custom, ...)
|
|
if type(custom) == "function" then
|
|
config = custom(config, ...) or config
|
|
elseif custom then
|
|
config = vim.tbl_deep_extend("force", config, custom) --[[@as table]]
|
|
end
|
|
return config
|
|
end
|
|
|
|
function M.capabilities()
|
|
local status_ok, cmp_nvim_lsp = pcall(require, "cmp_nvim_lsp")
|
|
if status_ok then
|
|
return cmp_nvim_lsp.default_capabilities()
|
|
end
|
|
|
|
local CAPABILITIES = vim.lsp.protocol.make_client_capabilities()
|
|
CAPABILITIES.textDocument.completion.completionItem.snippetSupport = true
|
|
CAPABILITIES.textDocument.completion.completionItem.resolveSupport = {
|
|
properties = {
|
|
"documentation",
|
|
"detail",
|
|
"additionalTextEdits",
|
|
},
|
|
}
|
|
|
|
return CAPABILITIES
|
|
end
|
|
-- stylua: ignore
|
|
M.lsp_keymaps=function ()
|
|
vim.keymap.set({ "n", "v" }, "<leader>l", "", { desc = "LSP" })
|
|
-- Set vim motion for <Space> + l + h to show code documentation about the code the cursor is currently over if available
|
|
vim.keymap.set("n", "<leader>lh", vim.lsp.buf.hover, { desc = "Code Hover Documentation" })
|
|
-- Set vim motion for <Space> + l + d to go where the code/variable under the cursor was defined
|
|
vim.keymap.set("n", "<leader>ld", vim.lsp.buf.definition, { desc = "Code Goto Definition" })
|
|
-- Set vim motion for <Space> + l + a for display code action suggestions for code diagnostics in both normal and visual mode
|
|
vim.keymap.set({ "n", "v" }, "<leader>la", vim.lsp.buf.code_action, { desc = "Code Actions" })
|
|
-- Set vim motion for <Space> + l + r to display references to the code under the cursor
|
|
vim.keymap.set("n", "<leader>lr", require("telescope.builtin").lsp_references, { desc = "Code Goto References" })
|
|
-- Set vim motion for <Space> + l + i to display implementations to the code under the cursor
|
|
vim.keymap.set("n", "<leader>li", require("telescope.builtin").lsp_implementations, { desc = "Code Goto Implementations" })
|
|
-- Set a vim motion for <Space> + l + <Shift>R to smartly rename the code under the cursor
|
|
vim.keymap.set("n", "<leader>lR", vim.lsp.buf.rename, { desc = "Code Rename" })
|
|
-- Set a vim motion for <Space> + l + <Shift>D to go to where the code/object was declared in the project (class file)
|
|
vim.keymap.set("n", "<leader>lD", vim.lsp.buf.declaration, { desc = "Code Goto Declaration" })
|
|
end
|
|
|
|
-- stylua: ignore
|
|
M.jdtls_keymaps=function ()
|
|
-- add keymaps
|
|
vim.keymap.set('n', '<leader>J', "", { desc = "Java" })
|
|
-- Set a Vim motion to <Space> + <Shift>J + o to organize imports in normal mode
|
|
vim.keymap.set('n', '<leader>Jo', "<Cmd> lua require('jdtls').organize_imports()<CR>", { desc = "Java Organize Imports" })
|
|
-- Set a Vim motion to <Space> + <Shift>J + v to extract the code under the cursor to a variable
|
|
vim.keymap.set('n', '<leader>Jv', "<Cmd> lua require('jdtls').extract_variable()<CR>", { desc = "Java Extract Variable" })
|
|
-- Set a Vim motion to <Space> + <Shift>J + v to extract the code selected in visual mode to a variable
|
|
vim.keymap.set('v', '<leader>Jv', "<Esc><Cmd> lua require('jdtls').extract_variable(true)<CR>", { desc = "Java Extract Variable" })
|
|
-- Set a Vim motion to <Space> + <Shift>J + <Shift>C to extract the code under the cursor to a static variable
|
|
vim.keymap.set('n', '<leader>JC', "<Cmd> lua require('jdtls').extract_constant()<CR>", { desc = "Java Extract Constant" })
|
|
-- Set a Vim motion to <Space> + <Shift>J + <Shift>C to extract the code selected in visual mode to a static variable
|
|
vim.keymap.set('v', '<leader>JC', "<Esc><Cmd> lua require('jdtls').extract_constant(true)<CR>", { desc = "Java Extract Constant" })
|
|
-- Set a Vim motion to <Space> + <Shift>J + t to run the test method currently under the cursor
|
|
vim.keymap.set('n', '<leader>Jt', "<Cmd> lua require('jdtls').test_nearest_method()<CR>", { desc = "Java Test Method" })
|
|
-- Set a Vim motion to <Space> + <Shift>J + t to run the test method that is currently selected in visual mode
|
|
vim.keymap.set('v', '<leader>Jt', "<Esc><Cmd> lua require('jdtls').test_nearest_method(true)<CR>", { desc = "Java Test Method" })
|
|
-- Set a Vim motion to <Space> + <Shift>J + <Shift>T to run an entire test suite (class)
|
|
vim.keymap.set('n', '<leader>JT', "<Cmd> lua require('jdtls').test_class()<CR>", { desc = "Java Test Class" })
|
|
-- Set a Vim motion to <Space> + <Shift>J + u to update the project configuration
|
|
vim.keymap.set('n', '<leader>Ju', "<Cmd> JdtUpdateConfig<CR>", { desc = "Java Update Config" })
|
|
end
|
|
|
|
M.opts = {
|
|
root_dir = require("jdtls.setup").find_root(M.root_markers),
|
|
project_name = function()
|
|
return vim.fn.fnamemodify(vim.fn.getcwd(), ":p:h:t")
|
|
end,
|
|
|
|
-- Where are the config and workspace dirs for a project?
|
|
jdtls_config_dir = function(project_name)
|
|
return vim.fn.stdpath("cache") .. "/jdtls/" .. project_name .. "/config"
|
|
end,
|
|
jdtls_workspace_dir = function(project_name)
|
|
return vim.fn.stdpath("cache") .. "/jdtls/" .. project_name .. "/workspace"
|
|
end,
|
|
cmd = { vim.fn.exepath("jdtls") },
|
|
full_cmd = function(opts)
|
|
local project_name = vim.fn.fnamemodify(vim.fn.getcwd(), ":p:h:t")
|
|
local cmd = vim.deepcopy(opts.cmd)
|
|
if project_name then
|
|
vim.list_extend(cmd, {
|
|
"-configuration",
|
|
opts.jdtls_config_dir(project_name),
|
|
"-data",
|
|
opts.jdtls_workspace_dir(project_name),
|
|
})
|
|
end
|
|
return cmd
|
|
end,
|
|
|
|
-- These depend on nvim-dap, but can additionally be disabled by setting false here.
|
|
dap = { hotcodereplace = "auto", config_overrides = {} },
|
|
dap_main = {},
|
|
test = true,
|
|
settings = {
|
|
java = {
|
|
inlayHints = {
|
|
parameterNames = {
|
|
enabled = "all",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
M.attach_jdtls = function(op)
|
|
M.opts = M.extend_or_override(M.opts, op or {})
|
|
local opt = vim.opt
|
|
opt.shiftwidth = 4
|
|
opt.tabstop = 4
|
|
opt.softtabstop = 4
|
|
opt.ts = 4
|
|
opt.expandtab = true
|
|
|
|
local mason_registry = require("mason-registry")
|
|
local bundles = {} ---@type string[]
|
|
if M.opts.dap and mason_registry.is_installed("java-debug-adapter") then
|
|
local java_dbg_pkg = mason_registry.get_package("java-debug-adapter")
|
|
local java_dbg_path = java_dbg_pkg:get_install_path()
|
|
local jar_patterns = {
|
|
java_dbg_path .. "/extension/server/com.microsoft.java.debug.plugin-*.jar",
|
|
}
|
|
-- java-test also depends on java-debug-adapter.
|
|
if M.opts.test and mason_registry.is_installed("java-test") then
|
|
local java_test_pkg = mason_registry.get_package("java-test")
|
|
local java_test_path = java_test_pkg:get_install_path()
|
|
vim.list_extend(jar_patterns, {
|
|
java_test_path .. "/extension/server/*.jar",
|
|
})
|
|
end
|
|
for _, jar_pattern in ipairs(jar_patterns) do
|
|
for _, bundle in ipairs(vim.split(vim.fn.glob(jar_pattern), "\n")) do
|
|
table.insert(bundles, bundle)
|
|
end
|
|
end
|
|
end
|
|
-- initialisasi config
|
|
local function attach_jdtls()
|
|
-- Configuration can be augmented and overridden by opts.jdtls
|
|
local config = M.extend_or_override({
|
|
cmd = M.opts.full_cmd(M.opts),
|
|
root_dir = require("jdtls.setup").find_root(M.root_markers),
|
|
init_options = {
|
|
bundles = bundles,
|
|
},
|
|
settings = M.opts.settings,
|
|
-- enable CMP capabilities
|
|
-- capabilities = require("user.lsp.handlers").capabilities or nil,
|
|
-- capabilities = require("auto-lsp.lsp.handlers").capabilities or nil,
|
|
capabilities = M.capabilities() or nil,
|
|
}, M.opts.jdtls)
|
|
|
|
-- Existing server will be reused if the root_dir matches.
|
|
require("jdtls").start_or_attach(config)
|
|
end
|
|
|
|
vim.api.nvim_create_autocmd("FileType", {
|
|
pattern = M.java_filetypes,
|
|
callback = attach_jdtls,
|
|
})
|
|
|
|
vim.api.nvim_create_autocmd("LspAttach", {
|
|
callback = function(args)
|
|
local client = vim.lsp.get_client_by_id(args.data.client_id)
|
|
-- stylua: ignore
|
|
if client and client.name == "jdtls" then
|
|
-- M.jdtls_keymaps()
|
|
-- M.lsp_keymaps()
|
|
if M.opts.dap and mason_registry.is_installed("java-debug-adapter") then
|
|
-- custom init for Java debugger
|
|
require("jdtls").setup_dap(M.opts.dap)
|
|
require("jdtls.dap").setup_dap_main_class_configs(M.opts.dap_main)
|
|
end
|
|
|
|
-- User can set additional keymaps in opts.on_attach
|
|
if M.opts.on_attach then
|
|
M.opts.on_attach(args)
|
|
end
|
|
end
|
|
end,
|
|
})
|
|
|
|
attach_jdtls()
|
|
end
|
|
|
|
return M
|