fx
This commit is contained in:
parent
3bc7ea9b47
commit
05452a244c
23 changed files with 905 additions and 2504 deletions
|
|
@ -1,151 +0,0 @@
|
|||
-- JDTLS (Java LSP) configuration
|
||||
local jdtls = require("jdtls")
|
||||
local project_name = vim.fn.fnamemodify(vim.fn.getcwd(), ":p:h:t")
|
||||
local workspace_dir = vim.env.HOME .. "/jdtls-workspace/" .. project_name
|
||||
|
||||
-- Needed for debugging
|
||||
local bundles = {
|
||||
vim.fn.glob(
|
||||
vim.env.HOME .. "/.local/share/nvim/mason/share/java-debug-adapter/com.microsoft.java.debug.plugin.jar"
|
||||
),
|
||||
}
|
||||
|
||||
-- Needed for running/debugging unit tests
|
||||
vim.list_extend(
|
||||
bundles,
|
||||
vim.split(vim.fn.glob(vim.env.HOME .. "/.local/share/nvim/mason/share/java-test/*.jar", 1), "\n")
|
||||
)
|
||||
|
||||
-- See `:help vim.lsp.start_client` for an overview of the supported `config` options.
|
||||
local config = {
|
||||
-- The command that starts the language server
|
||||
-- See: https://github.com/eclipse/eclipse.jdt.ls#running-from-the-command-line
|
||||
cmd = {
|
||||
"java",
|
||||
"-Declipse.application=org.eclipse.jdt.ls.core.id1",
|
||||
"-Dosgi.bundles.defaultStartLevel=4",
|
||||
"-Declipse.product=org.eclipse.jdt.ls.core.product",
|
||||
"-Dlog.protocol=true",
|
||||
"-Dlog.level=ALL",
|
||||
"-javaagent:" .. vim.env.HOME .. "/.local/share/nvim/mason/share/jdtls/lombok.jar",
|
||||
"-Xmx4g",
|
||||
"--add-modules=ALL-SYSTEM",
|
||||
"--add-opens",
|
||||
"java.base/java.util=ALL-UNNAMED",
|
||||
"--add-opens",
|
||||
"java.base/java.lang=ALL-UNNAMED",
|
||||
|
||||
-- Eclipse jdtls location
|
||||
"-jar",
|
||||
vim.env.HOME .. "/.local/share/nvim/mason/share/jdtls/plugins/org.eclipse.equinox.launcher.jar",
|
||||
-- TODO Update this to point to the correct jdtls subdirectory for your OS (config_linux, config_mac, config_win, etc)
|
||||
"-configuration",
|
||||
vim.env.HOME .. "/.local/share/nvim/mason/packages/jdtls/config_linux",
|
||||
"-data",
|
||||
workspace_dir,
|
||||
},
|
||||
|
||||
-- This is the default if not provided, you can remove it. Or adjust as needed.
|
||||
-- One dedicated LSP server & client will be started per unique root_dir
|
||||
root_dir = require("jdtls.setup").find_root({ ".git", "mvnw", "pom.xml", "build.gradle" }),
|
||||
|
||||
-- Here you can configure eclipse.jdt.ls specific settings
|
||||
-- See https://github.com/eclipse/eclipse.jdt.ls/wiki/Running-the-JAVA-LS-server-from-the-command-line#initialize-request
|
||||
settings = {
|
||||
java = {
|
||||
-- TODO Replace this with the absolute path to your main java version (JDK 17 or higher)
|
||||
home = "/usr/lib/jvm/java-17-openjdk-amd64",
|
||||
eclipse = {
|
||||
downloadSources = true,
|
||||
},
|
||||
configuration = {
|
||||
updateBuildConfiguration = "interactive",
|
||||
-- TODO Update this by adding any runtimes that you need to support your Java projects and removing any that you don't have installed
|
||||
-- The runtime name parameters need to match specific Java execution environments. See https://github.com/tamago324/nlsp-settings.nvim/blob/2a52e793d4f293c0e1d61ee5794e3ff62bfbbb5d/schemas/_generated/jdtls.json#L317-L334
|
||||
runtimes = {
|
||||
{
|
||||
-- name = "JavaSE-11",
|
||||
-- path = "/usr/lib/jvm/java-11-openjdk-amd64",
|
||||
},
|
||||
{
|
||||
name = "JavaSE-17",
|
||||
path = "/usr/lib/jvm/java-17-openjdk-amd64",
|
||||
},
|
||||
{
|
||||
-- name = "JavaSE-19",
|
||||
-- path = "/usr/lib/jvm/java-19-openjdk-amd64",
|
||||
},
|
||||
},
|
||||
},
|
||||
maven = {
|
||||
downloadSources = true,
|
||||
},
|
||||
implementationsCodeLens = {
|
||||
enabled = true,
|
||||
},
|
||||
referencesCodeLens = {
|
||||
enabled = true,
|
||||
},
|
||||
references = {
|
||||
includeDecompiledSources = true,
|
||||
},
|
||||
signatureHelp = { enabled = true },
|
||||
format = {
|
||||
enabled = true,
|
||||
-- Formatting works by default, but you can refer to a specific file/URL if you choose
|
||||
-- settings = {
|
||||
-- url = "https://github.com/google/styleguide/blob/gh-pages/intellij-java-google-style.xml",
|
||||
-- profile = "GoogleStyle",
|
||||
-- },
|
||||
},
|
||||
},
|
||||
completion = {
|
||||
favoriteStaticMembers = {
|
||||
"org.hamcrest.MatcherAssert.assertThat",
|
||||
"org.hamcrest.Matchers.*",
|
||||
"org.hamcrest.CoreMatchers.*",
|
||||
"org.junit.jupiter.api.Assertions.*",
|
||||
"java.util.Objects.requireNonNull",
|
||||
"java.util.Objects.requireNonNullElse",
|
||||
"org.mockito.Mockito.*",
|
||||
},
|
||||
importOrder = {
|
||||
"java",
|
||||
"javax",
|
||||
"com",
|
||||
"org",
|
||||
},
|
||||
},
|
||||
extendedClientCapabilities = jdtls.extendedClientCapabilities,
|
||||
sources = {
|
||||
organizeImports = {
|
||||
starThreshold = 9999,
|
||||
staticStarThreshold = 9999,
|
||||
},
|
||||
},
|
||||
codeGeneration = {
|
||||
toString = {
|
||||
template = "${object.className}{${member.name()}=${member.value}, ${otherMembers}}",
|
||||
},
|
||||
useBlocks = true,
|
||||
},
|
||||
},
|
||||
-- Needed for auto-completion with method signatures and placeholders
|
||||
capabilities = require("cmp_nvim_lsp").default_capabilities(),
|
||||
flags = {
|
||||
allow_incremental_sync = true,
|
||||
},
|
||||
init_options = {
|
||||
-- References the bundles defined above to support Debugging and Unit Testing
|
||||
bundles = bundles,
|
||||
},
|
||||
}
|
||||
|
||||
-- Needed for debugging
|
||||
config["on_attach"] = function(client, bufnr)
|
||||
jdtls.setup_dap({ hotcodereplace = "auto" })
|
||||
require("jdtls.dap").setup_dap_main_class_configs()
|
||||
end
|
||||
|
||||
-- This starts a new client & server, or attaches to an existing client & server based on the `root_dir`.
|
||||
jdtls.start_or_attach(config)
|
||||
Loading…
Add table
Add a link
Reference in a new issue