summaryrefslogtreecommitdiff
path: root/.config/coc/extensions/node_modules/coc-clangd/README.md
blob: b6e52104d5f0bad37bd1b9aa58e907febfec3e24 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
# coc-clangd

This extension connects [coc.nvim][] to the [clangd][] language server.

## Quick Start

1. install [Node.js][]. `coc.nvim` and `coc-clangd` run on Node.js.
1. install `coc.nvim`. Instructions using `vim-plug` (check out [coc.nvim Wiki][] other options):
   - add to `.vimrc`: `vim Plug 'neoclide/coc.nvim', {'branch': 'release'}`
   - in vim, run `:PlugInstall`
1. in vim, run `:CocInstall coc-clangd`
1. `coc-clangd` will try to find `clangd` from your `$PATH`, if not found, you can run `:CocCommand clangd.install` to install the [latest release][] from GitHub
1. follow [Project setup][] to generate `compile_commands.json` for your project

> **Note**: If you've configured `clangd` as a languageServer in `coc-settings.json`, you should remove it to avoid running clangd twice!

## Protocol extensions

`clangd` supports some [extensions][] that are not in the official [Language Server Protocol specification][lsp].

`coc-clangd` adds support for:

- Switching between header and implementation file: `:CocCommand clangd.switchSourceHeader`
  - You can open in split buffer by `:CocCommand clangd.switchSourceHeader vsplit`
- File status monitor, shows on NeoVim statusline
- Describe symbol under the cursor: `:CocCommand clangd.symbolInfo`
- Completions that adjust text near the cursor (e.g. correcting `.` to `->`)

## Configurations

`:CocConfig` opens your global `coc-settings.json`. `:CocLocalConfig` opens local configuration for your project (`$PROJECTROOT/.vim/coc-settings.json`)

| Configurations                        | Description                                                                          | Default  |
| -------------------------------       | ------------------------------------------------------------------------------------ | -------- |
| clangd.enabled                        | enable `coc-clangd`                                                                  | `true`   |
| clangd.arguments                      | arguments for `clangd` server                                                        | `[]`     |
| clangd.checkUpdates                   | check for clangd language server updates on startup                                  | `false`  |
| clangd.disableCompletion              | disable completion source from clangd                                                | `false`  |
| clangd.disableDiagnostics             | disable diagnostics from clangd                                                      | `false`  |
| clangd.disableSnippetCompletion       | disable completion snippet from clangd                                               | `false`  |
| clangd.disableProgressNotifications   | disable indexing progress notifications from clangd                                  | `false`  |
| clangd.compilationDatabasePath        | specifies the directory containing the compilation database                          | `''`     |
| clangd.fallbackFlags                  | extra clang flags used to parse files when no compilation database is found          | `[]`     |
| clangd.path                           | path to `clangd` executable                                                          | `clangd` |
| clangd.inlayHints.enable              | whether to enable the Inlay Hints feature                                            | `true`   |

## Commands

- `clangd.switchSourceHeader`: switch between source/header files
- `clangd.symbolInfo`: resolve symbol info under the cursor
- `clangd.memoryUsage`: show memory usage
- `clangd.ast`: show AST
- `clangd.install`: install latest clangd release from GitHub
- `clangd.update`: check for updates to clangd from GitHub
- `clangd.inlayHints.toggle`: toggles displaying Inlay Hints

## License

Apache 2.0 with LLVM Exception

This is the [standard LLVM license](https://llvm.org/foundation/relicensing/).

---

> This extension is built with [create-coc-extension](https://github.com/fannheyward/create-coc-extension)

[node.js]: https://nodejs.org/en/
[clangd]: https://clangd.llvm.org/installation.html
[coc.nvim]: https://github.com/neoclide/coc.nvim
[coc.nvim wiki]: https://github.com/neoclide/coc.nvim/wiki/Install-coc.nvim
[lsp]: https://microsoft.github.io/language-server-protocol/specification
[extensions]: https://clangd.llvm.org/extensions.html
[latest release]: https://github.com/clangd/clangd/releases
[project setup]: https://clangd.llvm.org/installation.html#project-setup