2017-02-18 22:21:30 +08:00
---
title: "Use Vim as a Java IDE"
2018-05-27 20:54:33 +08:00
categories: [tutorials, blog]
2020-05-10 14:05:04 +08:00
description: "A general guide for using SpaceVim as Java IDE, including layer configuration and requiems installation."
2017-02-18 22:28:49 +08:00
redirect_from: "/2017/02/11/use-vim-as-a-java-ide.html"
2020-05-17 14:08:03 +08:00
type: article
2018-01-25 22:57:56 +08:00
comments: true
2018-07-05 16:16:34 +08:00
commentsID: "Use Vim as a Java IDE"
2017-02-18 22:21:30 +08:00
---
2018-10-02 21:04:30 +08:00
# [Blogs](../blog/) >> Use Vim as a Java IDE
2017-02-11 11:37:50 +08:00
2020-11-16 22:31:00 +08:00
This tutorial introduces you to SpaceVim as a Java environment,
by using the `lang#java` layer, you make SpaceVim into a great lightweight Java IDE.
2018-10-02 21:04:30 +08:00
Each of the following sections will be covered:
2017-02-11 12:08:12 +08:00
2018-10-02 21:04:30 +08:00
<!-- vim - markdown - toc GFM -->
2017-02-11 12:08:12 +08:00
2020-11-16 22:31:00 +08:00
- [Enable language layer ](#enable-language-layer )
2019-02-23 13:24:26 +08:00
- [Language server ](#language-server )
2018-10-02 21:04:30 +08:00
- [Code completion ](#code-completion )
2019-02-23 13:24:26 +08:00
- [Code outline ](#code-outline )
- [Rename symbol ](#rename-symbol )
- [Javadoc hovers ](#javadoc-hovers )
2018-10-02 21:04:30 +08:00
- [Syntax lint ](#syntax-lint )
- [Import packages ](#import-packages )
- [Jump to test file ](#jump-to-test-file )
2020-11-16 22:31:00 +08:00
- [Code running ](#code-running )
2018-10-02 21:04:30 +08:00
- [Code formatting ](#code-formatting )
- [REPL ](#repl )
2017-02-11 11:37:50 +08:00
2018-10-02 21:04:30 +08:00
<!-- vim - markdown - toc -->
2020-11-16 22:31:00 +08:00
This tutorial is not intended to teach you Java itself.
2018-10-02 21:04:30 +08:00
2020-11-16 22:31:00 +08:00
If you have any problems,
feel free to join the [SpaceVim gitter chatting room ](https://gitter.im/SpaceVim/SpaceVim )
for general discussion.
2018-10-02 21:04:30 +08:00
2020-11-16 22:31:00 +08:00
### Enable language layer
2017-02-11 10:48:06 +08:00
2020-11-16 22:31:00 +08:00
`lang#java` layer is not loaded by default in SpaceVim, to use SpaceVim for java,
you need to enable this layer in SpaceVim configuration file.
Press `SPC f v d` to open SpaceVim configuration file, and add following section:
2018-10-02 21:04:30 +08:00
```toml
[[layers]]
name = "lang#java"
```
2017-02-11 12:08:12 +08:00
2019-02-23 13:24:26 +08:00
### Language server
To enable language server protocol support, you may need to enable lsp layer.
```toml
[[layers]]
name = "lsp"
filetypes = [
"java"
]
[layers.override_cmd]
java = [
"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=NONE",
"-noverify",
"-Xmx1G",
"-jar",
"D:\\dev\\jdt-language-server-latest\\plugins\\org.eclipse.equinox.launcher_1.5.200.v20180922-1751.jar",
"-configuration",
"D:\\dev\\jdt-language-server-latest\\config_win",
"-data",
"C:\\Users\\Administrator\\.cache\\javalsp"
]
```
You need to replace `D:\dev\jdt-language-server-latest\plugins\org.eclipse.equinox.launcher_1.5.200.v20180922-1751.jar` with the actual name of the org.eclipse.equinox.launcher jar
The configuration flag can point to either:
- `config_win` , for Windows
- `config_mac` , for MacOS
- `config_linux` , for Linux
The data flag value should be the absolute path to the working directory of the server.
This should be different from the path of the user's project files (which is sent during the initialize handshake).
### Code completion
2017-02-11 11:37:50 +08:00
2018-10-02 21:04:30 +08:00
javacomplete2 which has been included in `lang#java` layer provides omnifunc for java file and deoplete source.
with this plugin and `autocomplete` layer, the completion popup menu will be opened automatically。
2017-02-11 12:17:37 +08:00
2018-10-02 21:04:30 +08:00
![code complete ](https://user-images.githubusercontent.com/13142418/46297202-ba0ab980-c5ce-11e8-81a0-4a4a85bc98a5.png )
2017-12-19 21:32:07 +08:00
2019-02-23 13:24:26 +08:00
### Code outline
The default outline plugin is tagbar, and the key binding is `F2` . This key binding will open an outline sidebar on the left.
![java outline ](https://user-images.githubusercontent.com/13142418/53250502-7c313d80-36f5-11e9-8fa2-8437ecf57a78.png )
To fuzzy find outline in current buffer, you need to enable a fuzzy find layer, for example denite layer,
then press `Leader f o` :
![java fuzzy outline ](https://user-images.githubusercontent.com/13142418/53250728-f1047780-36f5-11e9-923d-0b34568f9566.gif )
### Rename symbol
2020-11-16 22:31:00 +08:00
To rename java symbol, you need to enable `lsp` layer for java. The default key binding
for rename symbol under the cursor is `SPC l e` .
2019-02-23 13:24:26 +08:00
![rename java symblo ](https://user-images.githubusercontent.com/13142418/53250190-da115580-36f4-11e9-9590-bf945fa8dcc0.gif )
### Javadoc hovers
The default key binding to get doc of cursor symbol is `SPC l d` or `K` :
![javadoc ](https://user-images.githubusercontent.com/13142418/53255520-bf44de00-3700-11e9-9f47-50bc50ed6e83.gif )
### Syntax lint
2017-02-11 12:08:12 +08:00
2018-10-02 21:04:30 +08:00
`checkers` layer provides asynchronous linting feature, this layer use [neomake ](https://github.com/neomake/neomake ) by default.
neomake support maven, gradle and eclipse project. it will generate classpath automatically for these project.
2017-02-11 12:17:37 +08:00
2018-10-02 21:04:30 +08:00
![lint-java ](https://user-images.githubusercontent.com/13142418/46323584-99b81a80-c621-11e8-8ca5-d8eb7fbd93cf.png )
2017-02-11 10:48:06 +08:00
2018-10-02 21:04:30 +08:00
within above picture, we can see the checkers layer provides following feature:
2017-02-11 12:08:12 +08:00
2018-10-02 21:04:30 +08:00
- list errors and warnings in quickfix windows
- sign error and warning position on the left side
- show numbers of errors and warnings on statusline
- show cursor error and warning information below current line
2017-02-11 12:08:12 +08:00
2019-02-23 13:24:26 +08:00
### Import packages
2018-10-02 21:04:30 +08:00
2020-11-16 22:31:00 +08:00
There are two kind features for importing packages, import packages automatically and manually.
SpaceVim will import the packages after selecting the class name on popmenu.
Also, you can use key binding `SPC l i` to import the class at the cursor point.
If there are more than one class, a menu will be shown below current windows.
2018-10-02 21:04:30 +08:00
![import class ](https://user-images.githubusercontent.com/13142418/46298485-c04e6500-c5d1-11e8-96f3-01d84f9fe237.png )
2019-02-23 13:24:26 +08:00
### Jump to test file
2017-02-11 10:48:06 +08:00
2018-10-02 21:04:30 +08:00
SpaceVim use vim-project to manager the files in a project, you can add a `.projections.json` to the root of your project with following content:
```json
{
2020-11-16 22:31:00 +08:00
"src/main/java/*.java": {
"alternate": "src/test/java/{dirname}/Test{basename}.java"
},
"src/test/java/**/Test*.java": { "alternate": "src/main/java/{}.java" }
2018-10-02 21:04:30 +08:00
}
```
with this configuration, you can jump between the source code and test file via command `:A`
![jump-test ](https://user-images.githubusercontent.com/13142418/46322905-12b57300-c61e-11e8-81a2-53c69d10140f.gif )
2020-11-16 22:31:00 +08:00
### Code running
2018-10-02 21:04:30 +08:00
Base on JavaUnite, you can use `SPC l r c` to run current function or use `SPC l r m` to run the main function of current Class.
![run-main ](https://user-images.githubusercontent.com/13142418/46323137-61174180-c61f-11e8-94df-61b6998b8907.gif )
2019-02-23 13:24:26 +08:00
### Code formatting
2018-10-02 21:04:30 +08:00
2020-11-16 22:31:00 +08:00
Code formatting is provided by `format` layer, which is loaded by default.
The default format engine is `neoformat` , it will run google's [java formatter ](https://github.com/google/google-java-format )
asynchronously. The key binding for formatting current file is `SPC b f` .
To use this feature, you need to download the google's java formatter jar, and set the
path of this jar file in layer option.
```toml
[[layers]]
name = 'lang#java'
2021-02-09 12:24:19 +08:00
java_formatter_jar = 'path/to/google-java-format.jar'
2020-11-16 22:31:00 +08:00
```
2017-02-11 12:17:37 +08:00
2018-10-02 21:04:30 +08:00
![format-java ](https://user-images.githubusercontent.com/13142418/46323426-ccadde80-c620-11e8-9726-d99025f3bf76.gif )
2017-02-11 10:48:06 +08:00
2019-02-23 13:24:26 +08:00
### REPL
2017-12-19 21:32:07 +08:00
2018-03-12 23:22:31 +08:00
you need to install jdk9 which provide a build-in tools `jshell` , and SpaceVim use the `jshell` as default inferior REPL process:
2017-02-11 10:48:06 +08:00
2017-12-19 21:32:07 +08:00
![REPl-JAVA ](https://user-images.githubusercontent.com/13142418/34159605-758461ba-e48f-11e7-873c-fc358ce59a42.gif )