Just install and start writing public static void main(String[] args).
[!TIP] You can find cool tips & tricks here https://github.com/nvim-java/nvim-java/wiki/Tips-&-Tricks
https://github.com/nvim-java/nvim-java/assets/18459807/047c8c46-9a0a-4869-b342-d5c2e15647bc
Requirements: Neovim 0.11.5+
vim.packvim.pack.add({
{
src = 'https://github.com/JavaHello/spring-boot.nvim',
version = '218c0c26c14d99feca778e4d13f5ec3e8b1b60f0',
},
'https://github.com/MunifTanjim/nui.nvim',
'https://github.com/mfussenegger/nvim-dap',
'https://github.com/nvim-java/nvim-java',
})
require('java').setup()
vim.lsp.enable('jdtls')
lazy.nvimInstall using lazy.nvim:
{
'nvim-java/nvim-java',
config = function()
require('java').setup()
vim.lsp.enable('jdtls')
end,
}
Yep! That's all :)
JavaBuildBuildWorkspace - Runs a full workspace build
JavaBuildCleanWorkspace - Clear the workspace cache
(for now you have to close and reopen to restart the language server after
the deletion)
JavaRunnerRunMain - Runs the application or selected main class (if there
are multiple main classes):JavaRunnerRunMain
:JavaRunnerRunMain <arguments> <to> <pass>
JavaRunnerStopMain - Stops the running applicationJavaRunnerToggleLogs - Toggle between show & hide runner log windowJavaDapConfig - DAP is autoconfigured on start up, but in case you want to
force configure it again, you can use this APIJavaTestRunCurrentClass - Run the test class in the active bufferJavaTestDebugCurrentClass - Debug the test class in the active bufferJavaTestRunCurrentMethod - Run the test method on the cursorJavaTestDebugCurrentMethod - Debug the test method on the cursorJavaTestRunAllTests - Run all tests in the workspaceJavaTestDebugAllTests - Debug all tests in the workspaceJavaTestViewLastReport - Open the last test report in a popup windowJavaProfile - Opens the profiles UIJavaRefactorExtractVariable - Create a variable from value at cursor/selectionJavaRefactorExtractVariableAllOccurrence - Create a variable for all
occurrences from value at cursor/selectionJavaRefactorExtractConstant - Create a constant from the value at cursor/selectionJavaRefactorExtractMethod - Create a method from the value at cursor/selectionJavaRefactorExtractField - Create a field from the value at cursor/selectionJavaSettingsChangeRuntime - Change the JDK version to anotherbuild.build_workspace - Runs a full workspace buildrequire('java').build.build_workspace()
build.clean_workspace - Clear the workspace cache
(for now you have to close and reopen to restart the language server after
the deletion)require('java').build.clean_workspace()
built_in.run_app - Runs the application or selected main class (if there
are multiple main classes)require('java').runner.built_in.run_app({})
require('java').runner.built_in.run_app({'arguments', 'to', 'pass', 'to', 'main'})
built_in.stop_app - Stops the running applicationrequire('java').runner.built_in.stop_app()
built_in.toggle_logs - Toggle between show & hide runner log windowrequire('java').runner.built_in.toggle_logs()
config_dap - DAP is autoconfigured on start up, but in case you want to force
configure it again, you can use this APIrequire('java').dap.config_dap()
run_current_class - Run the test class in the active bufferrequire('java').test.run_current_class()
debug_current_class - Debug the test class in the active bufferrequire('java').test.debug_current_class()
run_current_method - Run the test method on the cursorrequire('java').test.run_current_method()
debug_current_method - Debug the test method on the cursorrequire('java').test.debug_current_method()
run_all_tests - Run all tests in the workspacerequire('java').test.run_all_tests()
debug_all_tests - Debug all tests in the workspacerequire('java').test.debug_all_tests()
view_report - Open the last test report in a popup windowrequire('java').test.view_last_report()
require('java').profile.ui()
extract_variable - Create a variable from value at cursor/selectionrequire('java').refactor.extract_variable()
extract_variable_all_occurrence - Create a variable for all occurrences from
value at cursor/selectionrequire('java').refactor.extract_variable_all_occurrence()
extract_constant - Create a constant from the value at cursor/selectionrequire('java').refactor.extract_constant()
extract_method - Create method from the value at cursor/selectionrequire('java').refactor.extract_method()
extract_field - Create a field from the value at cursor/selectionrequire('java').refactor.extract_field()
change_runtime - Change the JDK version to anotherrequire('java').settings.change_runtime()
Use vim.lsp.config() to override the default JDTLS settings:
vim.lsp.config('jdtls', {
settings = {
java = {
configuration = {
runtimes = {
{
name = "JavaSE-21",
path = "/opt/jdk-21",
default = true,
}
}
}
}
}
})
For most users changing the default configuration is not necessary. But if you want, following options are available:
require('java').setup({
-- Startup checks
checks = {
nvim_version = true, -- Check Neovim version
nvim_jdtls_conflict = true, -- Check for nvim-jdtls conflict
},
-- JDTLS configuration
jdtls = {
version = '1.43.0',
},
-- Extensions
lombok = {
enable = true,
version = '1.18.40',
},
java_test = {
enable = true,
version = '0.40.1',
},
java_debug_adapter = {
enable = true,
version = '0.58.2',
},
spring_boot_tools = {
enable = true,
version = '1.55.1',
},
-- JDK installation
jdk = {
auto_install = true,
version = '17',
},
-- Logging
log = {
use_console = true,
use_file = true,
level = 'info',
log_file = vim.fn.stdpath('state') .. '/nvim-java.log',
max_lines = 1000,
show_location = false,
},
})
Following is the high level idea. Jdtls is the language server nvim-java communicates with. However, we don't have all the features we need just in Jdtls. So, we are loading java-test & java-debug-adapter extensions when we launch Jdtls. Once the language server is started, we communicate with the language server to do stuff.
For instance, to run the current test,
┌────────────┐ ┌────────────┐
│ │ │ │
│ Neovim │ │ VSCode │
│ │ │ │
└─────▲──────┘ └──────▲─────┘
│ │
│ │
│ │
│ │
┌───────▼───────┐ ┌──────────────▼──────────────┐
│ │ │ │
│ nvim-java │ │ Extension Pack for Java │
│ │ │ │
└───────▲───────┘ └──────────────▲──────────────┘
│ │
│ │
│ │
│ │
│ │
│ ┌───────────┐ │
│ │ │ │
└──────────────► JDTLS ◄────────────┘
│ │
└───▲───▲───┘
│ │
│ │
│ │
│ │
│ │
┌───────────────┐ │ │ ┌────────────────────────┐
│ │ │ │ │ │
│ java-test ◄────────┘ └─────────► java-debug-adapter │
│ │ │ │
└───────────────┘ └────────────────────────┘
spring-boot.nvim is the one
that starts sts4 & do other necessary jdtls sts4 sync command registration
in nvim-java.
nvim-jdtls is a plugin that follows "Keep it simple, stupid!" approach. If you love customizing things by yourself, then give nvim-jdtls a try.