More doc updates for diagnostics UI

This commit is contained in:
Strahinja Val Markovic 2014-01-08 20:03:33 -08:00
parent 5efd920815
commit 34f654e3a4

View File

@ -467,6 +467,15 @@ YCM will display diagnostic notifications if you compiled YCM with Clang
support. Since YCM continuously recompiles your file as you type, you'll get support. Since YCM continuously recompiles your file as you type, you'll get
notified of errors and warnings in your file as fast as possible. notified of errors and warnings in your file as fast as possible.
Here are the various pieces of the diagnostic UI:
- Icons in the Vim gutter on lines that have a diagnostic.
- Regions of text related to diagnostics are highlighted (by default, a red
wawy underline in `gvim` and a red background in `vim`).
- Moving the cursor to a line with a diagnostic echoes the diagnostic text.
- Vim's location list is automatically populated with diagnostic data (off by
default, see options).
The new diagnostics (if any) will be displayed the next time you press any key The new diagnostics (if any) will be displayed the next time you press any key
on the keyboard. So if you stop typing and just wait for the new diagnostics to on the keyboard. So if you stop typing and just wait for the new diagnostics to
come in, that _will not work_. You need to press some key for the GUI to update. come in, that _will not work_. You need to press some key for the GUI to update.
@ -492,12 +501,34 @@ cursor is on the line with the diagnostic.
You can also see the full diagnostic message for all the diagnostics in the You can also see the full diagnostic message for all the diagnostics in the
current file in Vim's `locationlist`, which can be opened with the `:lopen` and current file in Vim's `locationlist`, which can be opened with the `:lopen` and
`:lclose` commands (make sure you have set `let `:lclose` commands (make sure you have set `let
g:syntastic_always_populate_loc_list = 1` in your vimrc). A good way to toggle g:ycm_always_populate_location_list = 1` in your vimrc). A good way to toggle
the display of the `locationlist` with a single key mapping is provided by the display of the `locationlist` with a single key mapping is provided by
another (very small) Vim plugin called [ListToggle][] (which also makes it another (very small) Vim plugin called [ListToggle][] (which also makes it
possible to change the height of the `locationlist` window), also written by possible to change the height of the `locationlist` window), also written by
yours truly. yours truly.
#### Diagnostic highlighting groups
You can change the styling for the highlighting groups YCM uses. For the signs
in the Vim gutter, the relevant groups are:
- `YcmErrorSign`, which falls back to group `SyntasticErrorSign` and then
`error` if they exist
- `YcmErrorSign`, which falls back to group `SyntasticWarningSign` and then
`todo` if they exist
You can also style the line that has the warning/error with these groups:
- `YcmErrorLine`, which falls back to group `SyntasticErrorLine` if it exists
- `YcmWarningLine`, which falls back to group `SyntasticWarningLine` if it
exists
Here's how you'd change the style for a group:
```
highlight YcmErrorLine guibg=#3f0000
```
Commands Commands
-------- --------
@ -521,10 +552,6 @@ You may want to map this command to a key; try putting `nnoremap <F5>
Calling this command will fill Vim's `locationlist` with errors or warnings if Calling this command will fill Vim's `locationlist` with errors or warnings if
any were detected in your file and then open it. any were detected in your file and then open it.
A better option would be to use Syntastic which will keep your `locationlist`
up to date automatically and will also show error/warning notifications in Vim's
gutter.
### The `:YcmShowDetailedDiagnostic` command ### The `:YcmShowDetailedDiagnostic` command
This command shows the full diagnostic text when the user's cursor is on the This command shows the full diagnostic text when the user's cursor is on the
@ -671,8 +698,8 @@ Default: `0`
When set to `0`, this option turns off YCM's identifier completer (the When set to `0`, this option turns off YCM's identifier completer (the
as-you-type popup) _and_ the semantic triggers (the popup you'd get after typing as-you-type popup) _and_ the semantic triggers (the popup you'd get after typing
`.` or `->` in say C++). The Syntastic integration remains working and you can `.` or `->` in say C++). You can still force semantic completion with the
still force semantic completion with the `<C-Space>` shortcut. `<C-Space>` shortcut.
If you want to just turn off the identifier completer but keep the semantic If you want to just turn off the identifier completer but keep the semantic
triggers, you should set `g:ycm_min_num_of_chars_for_completion` to a high triggers, you should set `g:ycm_min_num_of_chars_for_completion` to a high
@ -1103,8 +1130,7 @@ Default: `0`
This option controls the maximum number of diagnostics shown to the user when This option controls the maximum number of diagnostics shown to the user when
errors or warnings are detected in the file. This option is only relevant if you errors or warnings are detected in the file. This option is only relevant if you
are using the semantic completion engine and have installed the version of the are using the C-family semantic completion engine.
Syntastic plugin that supports YCM.
Default: `30` Default: `30`
@ -1347,35 +1373,17 @@ Also, you may want to run the `:YcmDebugInfo` command; it will make YCM spew out
various debugging information, including the compile flags for the file if the various debugging information, including the compile flags for the file if the
file is a C-family language file and you have compiled in Clang support. file is a C-family language file and you have compiled in Clang support.
### I cannot get the Syntastic integration to work
Try to update your version of Syntastic. At the time of writing (Jan 2013), the
YCM integration is very recent and it's likely that your version of Syntastic
does not have it.
### Sometimes it takes much longer to get semantic completions than normal ### Sometimes it takes much longer to get semantic completions than normal
This means that libclang (which YCM uses for C-family semantic completion) This means that libclang (which YCM uses for C-family semantic completion)
failed to pre-compile your file's preamble. In other words, there was an error failed to pre-compile your file's preamble. In other words, there was an error
compiling some of the source code you pulled in through your header files. I compiling some of the source code you pulled in through your header files. I
suggest calling the `:YcmDiags` command to see what they were (even better, have suggest calling the `:YcmDiags` command to see what they were.
Syntastic installed and call `:lopen`).
Bottom line, if libclang can't pre-compile your file's preamble because there Bottom line, if libclang can't pre-compile your file's preamble because there
were errors in it, you're going to get slow completions because there's no AST were errors in it, you're going to get slow completions because there's no AST
cache. cache.
### Vim flickers every time I move the cursor or moving the cursor is slow
You probably have an old version of Syntastic installed. If you are using
Vundle, make sure that your bundle command is `Bundle 'scrooloose/syntastic'`
and **not** `Bundle 'Syntastic'`. The first command pulls in the latest version of
Syntastic from GitHub while the second one pulls in an old version from vim.org.
Because of [a Vundle bug][vundle-bug], make sure you have completely removed
everything in your Vundle bundle directory (`~/.vim/bundle` by default) before
switching from one Syntastic bundle command to the other.
### YCM auto-inserts completion strings I don't want! ### YCM auto-inserts completion strings I don't want!
This means you probably have some mappings that interfere with YCM's internal This means you probably have some mappings that interfere with YCM's internal
@ -1597,15 +1605,15 @@ mismatch in assumptions causes performance problems since Syntastic code isn't
optimized for this use case of constant diagnostic refreshing. optimized for this use case of constant diagnostic refreshing.
Poor support for this use case also led to crash bugs in Vim caused by Poor support for this use case also led to crash bugs in Vim caused by
Syntastic-Vim interactions ([issue #593][issue-593]) and incredibly annoying Syntastic-Vim interactions ([issue #593][issue-593]) and other problems, like
screen flickering ([issue #669][issue-669]). Attempts were made to resolve these random Vim flickering. Attempts were made to resolve these issues in
issues in Syntastic, but ultimately some of them failed (for various reasons). Syntastic, but ultimately some of them failed (for various reasons).
Implementing diagnostic display code directly in YCM resolves all of these Implementing diagnostic display code directly in YCM resolves all of these
problems. Performance should also improve substantially since the relevant code problems. Performance also improved substantially since the relevant code is now
is now written in Python instead of VimScript (which is very slow) and is written in Python instead of VimScript (which is very slow) and is tailored only
tailored only for YCM's use-cases. We're also able to introduce new features in for YCM's use-cases. We were also able to introduce new features in this area
this area since we're not limited to the Syntastic checker API. since we're now not limited to the Syntastic checker API.
We've tried to implement this in the most backwards-compatible way possible; YCM We've tried to implement this in the most backwards-compatible way possible; YCM
options that control diagnostic display fall back to Syntastic options that options that control diagnostic display fall back to Syntastic options that