Vim's autocomplete is excruciatingly slow

后端 未结 3 952
难免孤独
难免孤独 2021-01-29 22:08

Most of the time the autocomplete feature in Vim works nicely for me, but sometimes it seems to be scanning files which the current file references, and then it becomes painfull

相关标签:
3条回答
  • 2021-01-29 22:50

    As I mentioned in a comment I had the same problem. Here's what I found;

    There's a setting telling VIM where to look for completions, called complete.

    :set complete
    complete=.,w,b,u,t,i
    

    this is the default value. My problem is (was actually..) the 'i', which scans all included files. Here are two problems, first one, finding all those files might take quite a while, especially if you, like me, have

    :set path=**
    

    Second problem, once found, they need to be read, and if you're using a networked file system (I'm on clearcase) both finding and reading all those files might trigger cache misses, making it painfully slow.

    I've removed the i for now, as I have a tags-file and more often than not, I also have the relevant files in my buffers (loaded or unloaded) which will be searched as a result of 'b' and 'u'.

    Use

    set complete-=i
    

    to remove the i from the list, note that this is local to the buffer.

    0 讨论(0)
  • 2021-01-29 22:53

    Had a very similar problem since upgrading to Vim 7.3 (from 7.2): I was using the (excellent) ACP plugin and in longer source files (C-files, 1700 LOC), the popup took ages to jump through the suggestions when I was editing near the bottom of the file.

    Using the PerformanceValidator (from Softwareverify), I found out that some fold methods were called again and again and lead to very high processor load and slow completion.

    My workaround was to set the foldmethod (fdm) to manual. And this solved it...

    0 讨论(0)
  • 2021-01-29 23:01

    Do you have a tags file for the project you're working on? If not try generate one with exuberant-ctags and Vim should pick it up with the taglist pluglin.

    0 讨论(0)
提交回复
热议问题