Updating vimdoc
This commit is contained in:
parent
454a961318
commit
258f3dfd73
@ -28,6 +28,7 @@ Contents ~
|
|||||||
1. The |GoToDeclaration| subcommand
|
1. The |GoToDeclaration| subcommand
|
||||||
2. The |GoToDefinition| subcommand
|
2. The |GoToDefinition| subcommand
|
||||||
3. The |GoToDefinitionElseDeclaration| subcommand
|
3. The |GoToDefinitionElseDeclaration| subcommand
|
||||||
|
4. The |ClearCompilationFlagCache| subcommand
|
||||||
9. Options |youcompleteme-options|
|
9. Options |youcompleteme-options|
|
||||||
1. The |g:ycm_min_num_of_chars_for_completion| option
|
1. The |g:ycm_min_num_of_chars_for_completion| option
|
||||||
2. The |g:ycm_filetype_whitelist| option
|
2. The |g:ycm_filetype_whitelist| option
|
||||||
@ -38,20 +39,21 @@ Contents ~
|
|||||||
7. The |g:ycm_complete_in_comments| option
|
7. The |g:ycm_complete_in_comments| option
|
||||||
8. The |g:ycm_complete_in_strings| option
|
8. The |g:ycm_complete_in_strings| option
|
||||||
9. The |g:ycm_collect_identifiers_from_comments_and_strings| option
|
9. The |g:ycm_collect_identifiers_from_comments_and_strings| option
|
||||||
10. The |g:ycm_add_preview_to_completeopt| option
|
10. The |g:ycm_collect_identifiers_from_tags_files| option
|
||||||
11. The |g:ycm_autoclose_preview_window_after_completion| option
|
11. The |g:ycm_add_preview_to_completeopt| option
|
||||||
12. The |g:ycm_autoclose_preview_window_after_insertion| option
|
12. The |g:ycm_autoclose_preview_window_after_completion| option
|
||||||
13. The |g:ycm_max_diagnostics_to_display| option
|
13. The |g:ycm_autoclose_preview_window_after_insertion| option
|
||||||
14. The |g:ycm_key_list_select_completion| option
|
14. The |g:ycm_max_diagnostics_to_display| option
|
||||||
15. The |g:ycm_key_list_previous_completion| option
|
15. The |g:ycm_key_list_select_completion| option
|
||||||
16. The |g:ycm_key_invoke_completion| option
|
16. The |g:ycm_key_list_previous_completion| option
|
||||||
17. The |g:ycm_key_detailed_diagnostics| option
|
17. The |g:ycm_key_invoke_completion| option
|
||||||
18. The |g:ycm_global_ycm_extra_conf| option
|
18. The |g:ycm_key_detailed_diagnostics| option
|
||||||
19. The |g:ycm_confirm_extra_conf| option
|
19. The |g:ycm_global_ycm_extra_conf| option
|
||||||
20. The |g:ycm_extra_conf_globlist| option
|
20. The |g:ycm_confirm_extra_conf| option
|
||||||
21. The |g:ycm_filepath_completion_use_working_dir| option
|
21. The |g:ycm_extra_conf_globlist| option
|
||||||
22. The |g:ycm_semantic_triggers| option
|
22. The |g:ycm_filepath_completion_use_working_dir| option
|
||||||
23. The |g:ycm_cache_omnifunc| option
|
23. The |g:ycm_semantic_triggers| option
|
||||||
|
24. The |g:ycm_cache_omnifunc| option
|
||||||
10. FAQ |youcompleteme-faq|
|
10. FAQ |youcompleteme-faq|
|
||||||
1. I get a linker warning regarding |libpython| on Mac when compiling YCM
|
1. I get a linker warning regarding |libpython| on Mac when compiling YCM
|
||||||
2. I get a weird window at the top of my file when I use the semantic engine
|
2. I get a weird window at the top of my file when I use the semantic engine
|
||||||
@ -67,11 +69,12 @@ Contents ~
|
|||||||
12. Vim segfaults when I use the semantic completer in Ruby files
|
12. Vim segfaults when I use the semantic completer in Ruby files
|
||||||
13. I get 'LONG_BIT definition appears wrong for platform' when compiling
|
13. I get 'LONG_BIT definition appears wrong for platform' when compiling
|
||||||
14. I get 'Vim: Caught deadly signal SEGV' on Vim startup
|
14. I get 'Vim: Caught deadly signal SEGV' on Vim startup
|
||||||
15. |CTRL-U| in insert mode does not work
|
15. YCM does not read identifiers from my tags files
|
||||||
16. Why isn't YCM just written in plain VimScript, FFS?
|
16. |CTRL-U| in insert mode does not work
|
||||||
17. Why does YCM demand such a recent version of Vim?
|
17. Why isn't YCM just written in plain VimScript, FFS?
|
||||||
18. I get annoying messages in Vim's status area when I type
|
18. Why does YCM demand such a recent version of Vim?
|
||||||
19. Nasty bugs happen if I have the |vim-autoclose| plugin installed
|
19. I get annoying messages in Vim's status area when I type
|
||||||
|
20. Nasty bugs happen if I have the |vim-autoclose| plugin installed
|
||||||
11. Contact |youcompleteme-contact|
|
11. Contact |youcompleteme-contact|
|
||||||
12. License |youcompleteme-license|
|
12. License |youcompleteme-license|
|
||||||
|
|
||||||
@ -118,8 +121,8 @@ top of the menu (so you usually need to press TAB just once).
|
|||||||
|
|
||||||
All of the above works with any programming language because of the
|
All of the above works with any programming language because of the
|
||||||
identifier-based completion engine. It collects all of the identifiers in the
|
identifier-based completion engine. It collects all of the identifiers in the
|
||||||
current file and other files you visit and searches them when you type
|
current file and other files you visit (and your tags files) and searches them
|
||||||
(identifiers are put into per-filetype groups).
|
when you type (identifiers are put into per-filetype groups).
|
||||||
|
|
||||||
The demo also shows the semantic engine in use. When the user presses '.',
|
The demo also shows the semantic engine in use. When the user presses '.',
|
||||||
'->' or '::' while typing in insert mode (for C++; different triggers are used
|
'->' or '::' while typing in insert mode (for C++; different triggers are used
|
||||||
@ -359,6 +362,26 @@ General Usage ~
|
|||||||
that the Shift-TAB binding will not work because the console will not pass
|
that the Shift-TAB binding will not work because the console will not pass
|
||||||
it to Vim. You can remap the keys; see the Options section below.
|
it to Vim. You can remap the keys; see the Options section below.
|
||||||
|
|
||||||
|
Knowing a little bit about how YCM works internally will prevent confusion.
|
||||||
|
YCM has several completion engines: an identifier-based completer that
|
||||||
|
collects all of the identifiers in the current file and other files you visit
|
||||||
|
(and your tags files) and searches them when you type (identifiers are put
|
||||||
|
into per-filetype groups).
|
||||||
|
|
||||||
|
There are also several semantic engines in YCM. There's a libclang-based
|
||||||
|
completer that provides semantic completion for C-family languages. There's a
|
||||||
|
Jedi-based completer for semantic completion for Python. There's also an
|
||||||
|
omnifunc-based completer that uses data from Vim's omnicomplete system to
|
||||||
|
provide semantic completions when no native completer exists for that language
|
||||||
|
in YCM.
|
||||||
|
|
||||||
|
There are also other completion engines, like the UltiSnips completer and the
|
||||||
|
filepath completer.
|
||||||
|
|
||||||
|
YCM automatically detects which completion engine would be the best in any
|
||||||
|
situation. On occasion, it queries several of them at once, merges the outputs
|
||||||
|
and presents the results to you.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
*youcompleteme-completion-string-ranking*
|
*youcompleteme-completion-string-ranking*
|
||||||
Completion string ranking ~
|
Completion string ranking ~
|
||||||
@ -635,6 +658,19 @@ to the symbol's declaration.
|
|||||||
|
|
||||||
Supported in filetypes: 'c, cpp, objc, objcpp, python'
|
Supported in filetypes: 'c, cpp, objc, objcpp, python'
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
The *ClearCompilationFlagCache* subcommand
|
||||||
|
|
||||||
|
YCM caches the flags it gets from the 'FlagsForFile' function in your
|
||||||
|
'ycm_extra_conf.py' file if you return them with the 'do_cache' parameter set
|
||||||
|
to 'True'. The cache is in memory and is never invalidated (unless you restart
|
||||||
|
Vim of course).
|
||||||
|
|
||||||
|
This command clears that cache entirely. YCM will then re-query your
|
||||||
|
'FlagsForFile' function as needed in the future.
|
||||||
|
|
||||||
|
Supported in filetypes: 'c, cpp, objc, objcpp'
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
*youcompleteme-options*
|
*youcompleteme-options*
|
||||||
Options ~
|
Options ~
|
||||||
@ -806,6 +842,24 @@ Default: '0'
|
|||||||
>
|
>
|
||||||
let g:ycm_collect_identifiers_from_comments_and_strings = 0
|
let g:ycm_collect_identifiers_from_comments_and_strings = 0
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
The *g:ycm_collect_identifiers_from_tags_files* option
|
||||||
|
|
||||||
|
When this option is set to '1', YCM's identifier completer will also collect
|
||||||
|
identifiers from tags files. The list of tags files to examine is retrieved
|
||||||
|
from the 'tagfiles()' Vim function which examines the 'tags' Vim option. See
|
||||||
|
':h 'tags' for details.
|
||||||
|
|
||||||
|
YCM will re-index your tags files if it detects that they have been modified.
|
||||||
|
|
||||||
|
The only supported tag format is the Exuberant Ctags format [23]. The format
|
||||||
|
from "plain" ctags is NOT supported. See the FAQ for pointers if YCM does not
|
||||||
|
appear to read your tag files.
|
||||||
|
|
||||||
|
Default: '1'
|
||||||
|
>
|
||||||
|
let g:ycm_collect_identifiers_from_tags_files = 1
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
The *g:ycm_add_preview_to_completeopt* option
|
The *g:ycm_add_preview_to_completeopt* option
|
||||||
|
|
||||||
@ -1155,7 +1209,7 @@ I have a Homebrew Python and/or MacVim; can't compile/SIGABRT when starting ~
|
|||||||
|
|
||||||
You should probably run 'brew rm python; brew install python' to get the
|
You should probably run 'brew rm python; brew install python' to get the
|
||||||
latest fixes that should make YCM work with such a configuration. Also rebuild
|
latest fixes that should make YCM work with such a configuration. Also rebuild
|
||||||
Macvim then. If you still get problems with this, see issue #18 [23] for
|
Macvim then. If you still get problems with this, see issue #18 [24] for
|
||||||
suggestions.
|
suggestions.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
@ -1217,6 +1271,22 @@ So just go through the installation guide and make sure you are using a
|
|||||||
correct 'libclang.so'. I recommend downloading prebuilt binaries from
|
correct 'libclang.so'. I recommend downloading prebuilt binaries from
|
||||||
llvm.org.
|
llvm.org.
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
YCM does not read identifiers from my tags files ~
|
||||||
|
|
||||||
|
Make sure you are using Exuberant Ctags [25] to produce your tags files since
|
||||||
|
the only supported tag format is the Exuberant Ctags format [23]. The format
|
||||||
|
from "plain" ctags is NOT supported. The output of 'ctags --version' should
|
||||||
|
list "Exuberant Ctags".
|
||||||
|
|
||||||
|
NOTE: Mac OS X comes with "plain" ctags installed by default. 'brew install
|
||||||
|
ctags' will get you the Exuberant Ctags version.
|
||||||
|
|
||||||
|
Also make sure that your Vim 'tags' option is set correctly. See ':h 'tags'
|
||||||
|
for details. If you want to see which tag files YCM will read for a given
|
||||||
|
buffer, run ':echo tagfiles()' with the relevant buffer active. Note that that
|
||||||
|
function will only list tag files that already exist.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
*CTRL-U* in insert mode does not work
|
*CTRL-U* in insert mode does not work
|
||||||
|
|
||||||
@ -1261,7 +1331,7 @@ You'll have to learn to ignore them. It's a shitty "solution", I know.
|
|||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Nasty bugs happen if I have the *vim-autoclose* plugin installed
|
Nasty bugs happen if I have the *vim-autoclose* plugin installed
|
||||||
|
|
||||||
Use the delimitMate [24] plugin instead. It does the same thing without
|
Use the delimitMate [26] plugin instead. It does the same thing without
|
||||||
conflicting with YCM.
|
conflicting with YCM.
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
@ -1269,7 +1339,7 @@ conflicting with YCM.
|
|||||||
Contact ~
|
Contact ~
|
||||||
|
|
||||||
If you have questions, bug reports, suggestions, etc. please use the issue
|
If you have questions, bug reports, suggestions, etc. please use the issue
|
||||||
tracker [25]. The latest version is available at http://valloric.github.io/YouCompleteMe/.
|
tracker [27]. The latest version is available at http://valloric.github.io/YouCompleteMe/.
|
||||||
|
|
||||||
The author's homepage is http://val.markovic.io.
|
The author's homepage is http://val.markovic.io.
|
||||||
|
|
||||||
@ -1277,7 +1347,7 @@ The author's homepage is http://val.markovic.io.
|
|||||||
*youcompleteme-license*
|
*youcompleteme-license*
|
||||||
License ~
|
License ~
|
||||||
|
|
||||||
This software is licensed under the GPL v3 license [26]. Copyright 2012
|
This software is licensed under the GPL v3 license [28]. Copyright 2012
|
||||||
Strahinja Val Markovic <val@markovic.io>.
|
Strahinja Val Markovic <val@markovic.io>.
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
@ -1304,11 +1374,13 @@ References ~
|
|||||||
[18] https://github.com/Valloric/YouCompleteMe/blob/master/cpp/ycm/.ycm_extra_conf.py
|
[18] https://github.com/Valloric/YouCompleteMe/blob/master/cpp/ycm/.ycm_extra_conf.py
|
||||||
[19] http://clang.llvm.org/docs/JSONCompilationDatabase.html
|
[19] http://clang.llvm.org/docs/JSONCompilationDatabase.html
|
||||||
[20] http://eclim.org/
|
[20] http://eclim.org/
|
||||||
[21] https://github.com/Valloric/YouCompleteMe/blob/master/python/completers/completer.py
|
[21] https://github.com/Valloric/YouCompleteMe/blob/master/python/ycm/completers/completer.py
|
||||||
[22] https://github.com/Valloric/ListToggle
|
[22] https://github.com/Valloric/ListToggle
|
||||||
[23] https://github.com/Valloric/YouCompleteMe/issues/18
|
[23] http://ctags.sourceforge.net/FORMAT
|
||||||
[24] https://github.com/Raimondi/delimitMate
|
[24] https://github.com/Valloric/YouCompleteMe/issues/18
|
||||||
[25] https://github.com/Valloric/YouCompleteMe/issues?state=open
|
[25] http://ctags.sourceforge.net/
|
||||||
[26] http://www.gnu.org/copyleft/gpl.html
|
[26] https://github.com/Raimondi/delimitMate
|
||||||
|
[27] https://github.com/Valloric/YouCompleteMe/issues?state=open
|
||||||
|
[28] http://www.gnu.org/copyleft/gpl.html
|
||||||
|
|
||||||
vim: ft=help
|
vim: ft=help
|
||||||
|
Loading…
x
Reference in New Issue
Block a user