1
0
mirror of https://github.com/SpaceVim/SpaceVim.git synced 2025-01-24 06:40:05 +08:00
SpaceVim/docs/layers/lang/php.md

108 lines
3.0 KiB
Markdown
Raw Normal View History

2017-08-28 04:40:37 +08:00
---
title: "SpaceVim lang#php layer"
description: "PHP language support, including code completion, syntax lint and code runner"
2017-08-28 04:40:37 +08:00
---
2018-06-23 14:37:41 +08:00
# [Available Layers](../../) >> lang#php
2017-08-28 04:40:37 +08:00
<!-- vim-markdown-toc GFM -->
2017-12-02 23:23:58 +08:00
- [Description](#description)
- [Installation](#installation)
- [Enable language layer](#enable-language-layer)
- [Language tools](#language-tools)
2021-04-24 16:47:59 +08:00
- [Layer options](#layer-options)
- [Key bindings](#key-bindings)
- [Jump to definition](#jump-to-definition)
- [Running current script](#running-current-script)
2021-04-24 16:47:59 +08:00
- [Inferior REPL process](#inferior-repl-process)
- [LSP key Bindings](#lsp-key-bindings)
2017-08-28 04:40:37 +08:00
<!-- vim-markdown-toc -->
2017-08-28 04:40:37 +08:00
## Description
2021-04-24 16:47:59 +08:00
`lang#php` layer provides PHP language support in SpaceVim.
2021-04-24 16:47:59 +08:00
- code completion (`autocomplete` layer)
- code formatting (`format` layer)
- syntax checking (`checkers` layer)
2017-12-23 21:12:09 +08:00
- goto definition
2021-04-24 16:47:59 +08:00
- reference finder (`gtags` layer)
- language server protocol support (`lsp` layer)
2017-12-23 21:12:09 +08:00
## Installation
### Enable language layer
2017-08-28 04:40:37 +08:00
2021-04-24 16:47:59 +08:00
This layer is not enabled by default. To use this layer, you need to add following
snippet into SpaceVim configuration file:
2018-06-23 14:37:41 +08:00
```toml
[[layers]]
name = "lang#php"
```
### Language tools
- **language server**
To enable php support of `lsp` layer. You may need to install `intelephense`:
```
npm install -g intelephense
```
Also you need enable `lsp` layer with intelephense client:
```
[[layers]]
name = 'lsp'
enabled_clients = ['intelephense']
```
2017-08-28 04:40:37 +08:00
2021-04-24 16:47:59 +08:00
## Layer options
- `php_interpreter`: Set the PHP interpreter, by default, it is `php`.
## Key bindings
2017-08-28 04:40:37 +08:00
### Jump to definition
2017-12-23 21:12:09 +08:00
| Mode | Key Bindings | Description |
| ------ | ------------ | ------------------------------------------------ |
| normal | `g d` | Jump to the definition position of cursor symbol |
### Running current script
2021-06-21 20:39:29 +08:00
To run a php script, you can press `SPC l r` to run the current file without losing focus,
and the result will be shown in a runner buffer.
2021-04-24 16:47:59 +08:00
### Inferior REPL process
Start a `php` 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 |
### LSP key Bindings
If the lsp layer is enabled for php, the following key bindings can
be used:
| key binding | Description |
| ----------- | ----------------------- |
| `g D` | jump to type definition |
| `SPC l e` | rename symbol |
| `SPC l x` | show references |
| `SPC l s` | show line diagnostics |
| `SPC l d` | show document |
| `K` | show document |
| `SPC l w l` | list workspace folder |
| `SPC l w a` | add workspace folder |
| `SPC l w r` | remove workspace folder |