diff --git a/README.md b/README.md index 3936b85c..fc568057 100644 --- a/README.md +++ b/README.md @@ -2882,6 +2882,19 @@ executable first in your PATH when the virtual environment is active then if you set `g:ycm_python_binary_path` to just `'python'` it will be found as the first Python and used to run [JediHTTP][]. +### I want to defer loading of YouCompleteMe until after Vim finishes booting + +In recent versions of Vim, you can install YCM in a folder under +`~/.vim/pack/*/opt` and then load it once the user is idle via an autocommand: + +```viml +augroup load_ycm + autocmd! + autocmd CursorHold, CursorHoldI * :packadd YouCompleteMe + \ | autocmd! load_ycm +augroup END +``` + Contributor Code of Conduct --------------------------- diff --git a/plugin/youcompleteme.vim b/plugin/youcompleteme.vim index ac0f88ab..0cb82e8f 100644 --- a/plugin/youcompleteme.vim +++ b/plugin/youcompleteme.vim @@ -128,14 +128,15 @@ let g:ycm_goto_buffer_command = let g:ycm_disable_for_files_larger_than_kb = \ get( g:, 'ycm_disable_for_files_larger_than_kb', 1000 ) -" On-demand loading. Let's use the autoload folder and not slow down vim's -" startup procedure. -if has( 'vim_starting' ) " loading at startup +if has( 'vim_starting' ) && has ( 'gui' ) " loading at startup, in gui + " We defer loading until after VimEnter to allow the gui to fork (see + " `:h gui-fork`) and avoid a deadlock situation, as explained here: + " https://github.com/Valloric/YouCompleteMe/pull/2473#issuecomment-267716136 augroup youcompletemeStart autocmd! autocmd VimEnter * call youcompleteme#Enable() augroup END -else " manual loading with :packadd +else " manual loading with :packadd, or not starting the gui call youcompleteme#Enable() endif