From 7c573528ed5c5cefc4a4856f5c4d1816d9b524f6 Mon Sep 17 00:00:00 2001 From: Strahinja Val Markovic Date: Thu, 31 Jan 2013 19:21:11 -0800 Subject: [PATCH] New YcmDiags command that shows diagnostics Docs updated to mention it. Syntastic is still a better option than calling this command. --- README.md | 24 +++++++++++++++++++++++- autoload/youcompleteme.vim | 20 +++++++++++++++++++- 2 files changed, 42 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index fe135e9f..85d3b05b 100644 --- a/README.md +++ b/README.md @@ -289,7 +289,10 @@ then the sorting system kicks in. It's actually very complicated and uses lots of factors, but suffice it to say that "word boundary" (WB) subsequence character matches are "worth" more than non-WB matches. In effect, this means given an input of "gua", the completion "getUserAccount" would be ranked higher -in the list than the "Fooguxa" completion (both of which are subsequence matches). A word-boundary character are all capital characters, characters preceded by an underscore and the first letter character in the completion string. +in the list than the "Fooguxa" completion (both of which are subsequence +matches). A word-boundary character are all capital characters, characters +preceded by an underscore and the first letter character in the completion +string. ### Semantic Completion Engine Usage @@ -320,6 +323,17 @@ project. That should be enough for 99% of projects. Yes, [Clang's `CompilationDatabase` system][compdb] is also supported. Again, see the above linked example file. +If Clang encounters errors when compiling the header files that your file +includes, then it's probably going to take a long time to get completions. When +the completion menu finally appears, it's going to have a large number of +unrelated completion strings (type/function names that are not actually +members). This is because Clang fails to build a precompiled preamble for your +file if there are any errors in the included headers and that preamble is key to +getting fast completions. + +Call the `:YcmDiags` command to see if any errors or warnings were detected in +your file. Even better, use Syntastic. + ### Syntastic integration YCM has explicit support for [Syntastic][] (and vice-versa) if you compiled YCM @@ -593,6 +607,14 @@ 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 + +This means that libclang (which YCM uses for C-family semantic completion) +failed to 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 +suggest calling the `:YcmDiags` command to see what they were (even better, have +Syntastic installed and call `:lopen`). + Contact ------- diff --git a/autoload/youcompleteme.vim b/autoload/youcompleteme.vim index 3621766f..ecac0fd0 100644 --- a/autoload/youcompleteme.vim +++ b/autoload/youcompleteme.vim @@ -424,7 +424,7 @@ endfunction command! YcmDebugInfo call s:DebugInfo() -function! s:ForceCompileAndDiagnostics() +function! s:ForceCompile() if !pyeval( 'ycm_state.FiletypeCompletionEnabledForCurrentFile()' ) echom "Filetype completion not supported for current file, " \ . "cannot force recompilation." @@ -440,7 +440,11 @@ function! s:ForceCompileAndDiagnostics() endif sleep 100m endwhile +endfunction + +function! s:ForceCompileAndDiagnostics() + call s:ForceCompile() call s:UpdateDiagnosticNotifications() echom "Diagnostics refreshed." endfunction @@ -448,6 +452,20 @@ endfunction command! YcmForceCompileAndDiagnostics call s:ForceCompileAndDiagnostics() +function! s:ShowDiagnostics() + call s:ForceCompile() + let diags = pyeval( 'ycm_state.GetDiagnosticsForCurrentFile()' ) + if !empty( diags ) + call setloclist( 0, diags ) + lopen + else + echom "No warnings or errors detected" + endif +endfunction + +command! YcmDiags call s:ShowDiagnostics() + + " This is basic vim plugin boilerplate let &cpo = s:save_cpo unlet s:save_cpo