1
0
mirror of https://github.com/SpaceVim/SpaceVim.git synced 2025-01-28 03:30:06 +08:00
SpaceVim/docs/layers/lang/java.md

154 lines
5.1 KiB
Markdown

---
title: "SpaceVim lang#java layer"
description: "This layer is for Java development. All the features such as code completion, formatting, syntax checking, REPL and debug have be done in this layer."
---
# [Available Layers](../../) >> lang#java
<!-- vim-markdown-toc GFM -->
- [Description](#description)
- [Feature](#feature)
- [Install](#install)
- [Layer options](#layer-options)
- [Key bindings](#key-bindings)
- [Import key bindings](#import-key-bindings)
- [Generate key bindings](#generate-key-bindings)
- [Code formatting](#code-formatting)
- [Maven support](#maven-support)
- [Gradle support](#gradle-support)
- [Code runner](#code-runner)
- [Inferior REPL process](#inferior-repl-process)
<!-- vim-markdown-toc -->
## Description
This layer is for Java development.
## Feature
- code completion: `autocomplete` layer
- code formatting: `format` layer
- refactoring
- syntax checking: `checkers` layer
- REPL(requires `jshell`)
- code runner
- debug: check out the `debug` layer
## Install
To use this configuration layer, update custom configuration file with:
```toml
[[layers]]
name = "lang#java"
```
## Layer options
- `format_on_save`: Enable/disabled code formatting when saving current file.
The default value is `false`. To enable this feature:
```toml
[[layers]]
name = 'lang#java'
format_on_save = true
```
- `java_formatter_jar`: Set the full path of [google's formater jar](https://github.com/google/google-java-format).
```toml
[[layers]]
name = 'lang#java'
java_formatter_jar = 'path/to/google-java-format.jar'
```
- `java_file_head`: The default file header for new java file. by default it is:
```toml
[[layers]]
name = 'lang#java'
java_file_head = [
'/**',
' * @author : `fnamemodify(expand("~"), ":t")`',
' * @created : `strftime("%Y-%m-%d")`',
'**/',
''
]
```
## Key bindings
### Import key bindings
| Key Bindings | Descriptions |
| ------------------- | ------------------------------- |
| `SPC l I` | Import missing classes |
| `SPC l R` | Remove unused classes |
| `SPC l i` | smart import class under cursor |
| `Ctrl-j I` (Insert) | Import missing classes |
| `Ctrl-j R` (Insert) | Remove unused classes |
| `Ctrl-j i` (Insert) | smart import class under cursor |
### Generate key bindings
| Mode | Key Bindings | Descriptions |
| ------------- | ------------ | ------------------------------------- |
| normal | `SPC l g A` | generate accessors |
| normal/visual | `SPC l g s` | generate setter accessor |
| normal/visual | `SPC l g g` | generate getter accessor |
| normal/visual | `SPC l g a` | generate setter and getter accessor |
| normal | `SPC l g M` | generate abstract methods |
| insert | `Ctrl-j s` | generate setter accessor |
| insert | `Ctrl-j g` | generate getter accessor |
| insert | `Ctrl-j a` | generate getter and setter accessor |
| normal | `SPC l g t` | generate toString function |
| normal | `SPC l g e` | generate equals and hashcode function |
| normal | `SPC l g c` | generate constructor |
| normal | `SPC l g C` | generate default constructor |
### Code formatting
The default formater of java language is [google's formater jar](https://github.com/google/google-java-format).
You need to download the jar and set the `java_formatter_jar` layer option.
The default key bindings for format current buffer is `SPC b f`.
And this key binding is defined in [`format`](../layers/format/) layer.
You can also use `g=` to indent current buffer.
### Maven support
| Key Bindings | Descriptions |
| ------------ | ------------------------------ |
| `SPC l m i` | Run maven clean install |
| `SPC l m I` | Run maven install |
| `SPC l m p` | Run one already goal from list |
| `SPC l m r` | Run maven goals |
| `SPC l m R` | Run one maven goal |
| `SPC l m t` | Run maven test |
### Gradle support
| Key Bindings | Descriptions |
| ------------ | ------------------ |
| `SPC l a b` | gradle build |
| `SPC l a B` | gradle clean build |
| `SPC l a r` | gradle run |
| `SPC l a t` | gradle test |
### Code runner
| Key bindings | Descriptions |
| ------------ | ------------------------------- |
| `SPC l r m` | run main method of current file |
| `SPC l r m` | run current method |
| `SPC l r t` | run all test methods |
### Inferior REPL process
Start a `jshell` inferior REPL process with `SPC l s i`.
Send code to inferior process commands:
| Key Bindings | Descriptions |
| ------------ | ------------------------------------------------ |
| `SPC l s b` | send buffer and keep code buffer focused |
| `SPC l s l` | send line and keep code buffer focused |
| `SPC l s s` | send selection text and keep code buffer focused |