Vim插件neocomplcache 配置心得

对于Vimist 来说,neocomplcache 这个插件让人又爱又恨。主要是功能强大,配置复杂,而且喜欢跟各种插件冲突。

我也是被他折腾了个半死。期间搜索无数次,却找不到详细的配置。在不断摸索和阅读帮助文档以及源代码后,终于有了一点心得。而且把这个插件配置的比较爽了,配合SNIPMATE使用后基本类似VISUAL STUDIO下的VISUAL ASSIST X的感觉。

neocomplcache 其实不用配 SNIPMATE 也基本能用,但是SNIPMATE的snippets比较全,而且网上有加强版本的snippets,snippets的数目要大大超过neocomplcache 。而可悲的是neocomplcache 不能直接调用 SNIPMATE 的 snippets。所以没法去掉SNIPMATE。

但是SNIPMATE把关键的TAB键给占用了(用TAB激活它的snippets,有方法可以改它的源代码来实现)。neocomplcache 选择候选字时就没法通过TAB来很爽的选择了,不过经过配置后我还是有几种方法可以用的比较爽:

1、启用快速匹配:

let g:neocomplcache_enable_quick_match = 1 “For input-saving, this variable controls whether you can  choose a candidate with a alphabet or number displayed beside a candidate after '-'.  When you input 'ho-a',  neocomplcache will select candidate 'a'.

打开这个开关后,每次补全菜单弹出时,可以再按一个”-“键,这是补全菜单中的每个候选词会被标上一个字母,只要再输入对应字母就可以马上完成选择。

2、CTRL-N,CTRL-P:

这两个组合键可以替代TAB的功能,向上或者向下选择你的候选字。

3、使用SPACE:
inoremap <expr><space>  pumvisible() ? neocomplcache#close_popup() . "\<SPACE>" : "\<SPACE>"

用SPACE自动旋转当前的候选字,并附加一个空格。这个才是真正无阻碍的输入方式。在SPACE面前什么<TAB>,<ENTER>都是浮云。neocomplcache 的作者居然都没想到这点 。给出的推荐配置中还在纠结于 <TAB>,<ENTER>。这也是 VISUAL ASSIST X推荐的方式。

 

当然研究这么久 neocomplcache 肯定不止这一点收获。还有几天TIPS:

1、neocomplcache 可以根据文件类型选用 dict 词典,这个是EDITPLUS的首创吧,可以直接拷贝EDITPLUS的语法文件过来了,稍微整理一下就可以指定给neocomplcache去用:

" Define dictionary.
let g:neocomplcache_dictionary_filetype_lists = {
    \ 'default' : '',
    \ 'vimshell' : $HOME.'/.vimshell_hist',
    \ 'scheme' : $HOME.'/.gosh_completions',
    \ 'css' : $VIMFILES.'/dict/css.dic',
    \ 'php' : $VIMFILES.'/dict/php.dic',
    \ 'javascript' : $VIMFILES.'/dict/javascript.dic'
    \ }

2、neocomplcache 默认的回车定义会跟 'auto-pairs' ,'endwise' 之类的通过回车补全的插件相冲突。这个BUG废掉我一个晚上。不过我也从中找出一个寻找冲突插件的配置方法。就是用 pathogen 的禁用功能: call add(g:pathogen_disabled, 目录名) 。先将bundle下的所有插件都用这个函数禁用掉。然后再分批在前面加”注释掉禁用--也就是打开插件。这样多测试几次,只用几分钟就能找到冲突的插件了。

call add(g:pathogen_disabled, 'auto-pairs')  " conflict with neocomplcache
call add(g:pathogen_disabled, 'endwise')     " conflict with neocomplcache

关于 pathogen ,这年头高手管理VIM插件都是用 pathogen 和  git 了。如果你还是将下载的插件混杂在一起,那就该考虑更新一下了。

而GIT对于维护一个时刻保持更新的 网络版的 VIM 配置库是必不可少的。这方面需要严重参考这篇文章:

http://blog.wu-boy.com/2011/09/introduction-to-git-submodule/

也就是说,你基本只用维护你的VIMRC文件,以及插件列表,而将具体的插件,通过PATHOGEN配置到BUNDLE下的各个目录,然后通过GIT SUBMODULE指向各插件的原文件库,这样你就拥有了一个永远最新的VIM 发行版。

有人说EMACS是一个伪装成编辑器的操作系统,VIM又何尝不是。。。启动引导,加载模块,桌面管理,这些概念在这些编辑器中都体现的淋漓尽致。

 

关于键冲突的问题,这里有讨论:https://github.com/sjbach/lusty/issues/20

https://github.com/ervandew/supertab/issues/10

3、neocomplcache 配置文件中用到的一些函数说明:

pumvisible() 这个: 如果弹出菜单可见,返回非零,不然返回零。

neocomplcache#undo_completion  这个看名字就知道,做一次undo,取消补全。

neocomplcache#close_popup() 这个是用候选字补全后关闭弹出框

neocomplcache#cancel_popup()  这个是什么也不做,直接关闭弹出框

neocomplcache#smart_close_popup() 这个直接看函数定义吧。号称是智能的,但是我设置了半天 g:neocomplcache_enable_auto_select  还是无效,索性直接换成 neocomplcache#close_popup() 了。

  1: function! neocomplcache#smart_close_popup()

  2:   return g:neocomplcache_enable_auto_select ? neocomplcache#cancel_popup() : neocomplcache#close_popup()

  3: endfunction

 

最后是我的配置文件,由于配置文件太大,我是直接存了一个 neocomplcache.conf的文件,然后在vimrc中去调用它:

" --- NeoComplcache  It's such a big config file that I split into a single file.
source $VIM/vimfiles/neocomplcache.conf

 

 
  
  1: " Disable AutoComplPop.

  2: let g:acp_enableAtStartup = 0

  3: " Use neocomplcache.

  4: let g:neocomplcache_enable_at_startup = 1

  5: " Use smartcase.

  6: let g:neocomplcache_enable_smart_case = 1

  7: " Use camel case completion.

  8: let g:neocomplcache_enable_camel_case_completion = 1

  9: " Use underbar completion.

 10: let g:neocomplcache_enable_underbar_completion = 1

 11: " Set minimum syntax keyword length.

 12: let g:neocomplcache_min_syntax_length = 3

 13: let g:neocomplcache_lock_buffer_name_pattern = '\*ku\*'

 14: 

 15: " AutoComplPop like behavior.

 16: let g:neocomplcache_enable_auto_select = 0

 17: 

 18: " When you input 'ho-a',neocomplcache will select candidate 'a'.

 19: let g:neocomplcache_enable_quick_match = 1

 20: 

 21: " Define dictionary.

 22: let g:neocomplcache_dictionary_filetype_lists = {

 23:     \ 'default' : '',

 24:     \ 'vimshell' : $HOME.'/.vimshell_hist',

 25:     \ 'scheme' : $HOME.'/.gosh_completions',

 26:     \ 'css' : $VIMFILES.'/dict/css.dic',

 27:     \ 'php' : $VIMFILES.'/dict/php.dic',

 28:     \ 'javascript' : $VIMFILES.'/dict/javascript.dic'

 29:     \ }

 30: 

 31: let g:neocomplcache_snippets_dir=$VIMFILES."/snippets"

 32: inoremap <expr><S-TAB>  pumvisible() ? "\<C-p>" : "\<TAB>"

 33: inoremap <expr><C-TAB>  pumvisible() ? "\<C-p>" : "\<TAB>"

 34: 

 35: 

 36: " Define keyword.

 37: if !exists('g:neocomplcache_keyword_patterns')

 38:   let g:neocomplcache_keyword_patterns = {}

 39: endif

 40: let g:neocomplcache_keyword_patterns['default'] = '\h\w*'

 41: 

 42: " Plugin key-mappings.

 43: imap <C-k>     <Plug>(neocomplcache_snippets_expand)

 44: smap <C-k>     <Plug>(neocomplcache_snippets_expand)

 45: inoremap <expr><C-g>     neocomplcache#undo_completion()

 46: inoremap <expr><C-z>     neocomplcache#undo_completion()

 47: inoremap <expr><C-l>     neocomplcache#complete_common_string()

 48: 

 49: " SuperTab like snippets behavior.

 50: "imap <expr><TAB> neocomplcache#sources#snippets_complete#expandable() ? "\<Plug>(neocomplcache_snippets_expand)" : pumvisible() ? "\<C-n>" : "\<TAB>"
 51: 

 52: " Recommended key-mappings.

 53: " <CR>: close popup and save indent.

 54: " inoremap <expr><CR>  neocomplcache#close_popup() . "\<CR>"
 55: inoremap <expr><CR> pumvisible() ? neocomplcache#close_popup() : "\<CR>"

 56: " <TAB>: completion. THIS HAS NO USE WHEN WITH SNIPMATE

 57: " inoremap <expr><TAB>  pumvisible() ? "\<C-n>" : "\<TAB>"
 58: " <SPACE>: completion.

 59: inoremap <expr><space>  pumvisible() ? neocomplcache#close_popup() . "\<SPACE>" : "\<SPACE>"

 60: 

 61: 

 62: " <C-h>, <BS>: close popup and delete backword char.

 63: inoremap <expr><C-h> neocomplcache#close_popup()."\<C-h>"

 64: inoremap <expr><BS> neocomplcache#close_popup()."\<C-h>"

 65: 

 66: inoremap <expr><C-y>  neocomplcache#close_popup()

 67: inoremap <expr><C-e>  neocomplcache#cancel_popup()

 68: 

 69: " Shell like behavior(not recommended).

 70: "set completeopt+=longest

 71: "let g:neocomplcache_enable_auto_select = 1

 72: "let g:neocomplcache_disable_auto_complete = 1

 73: "inoremap <expr><TAB>  pumvisible() ? "\<Down>" : "\<TAB>"
 74: "inoremap <expr><CR>  neocomplcache#close_popup() . "\<CR>"
 75: 

 76: " Enable omni completion.

 77: autocmd FileType css setlocal omnifunc=csscomplete#CompleteCSS

 78: autocmd FileType html,markdown setlocal omnifunc=htmlcomplete#CompleteTags

 79: autocmd FileType javascript setlocal omnifunc=javascriptcomplete#CompleteJS

 80: autocmd FileType python setlocal omnifunc=pythoncomplete#Complete

 81: autocmd FileType xml setlocal omnifunc=xmlcomplete#CompleteTags

 82: autocmd FileType ruby setlocal omnifunc=rubycomplete#Complete

 83: 

 84: " Enable heavy omni completion.

 85: if !exists('g:neocomplcache_omni_patterns')

 86:   let g:neocomplcache_omni_patterns = {}

 87: endif

 88: let g:neocomplcache_omni_patterns.ruby = '[^. *\t]\.\w*\|\h\w*::'

 89: let g:neocomplcache_omni_patterns.php = '[^. \t]->\h\w*\|\h\w*::'

 90: let g:neocomplcache_omni_patterns.c = '\%(\.\|->\)\h\w*'

 91: let g:neocomplcache_omni_patterns.cpp = '\h\w*\%(\.\|->\)\h\w*\|\h\w*::'

你可能感兴趣的:(cache)