这篇文章还是承接了上一篇的内容.
上一篇讲述了一些基本的vim配置方法,现在讲述些我用到的插件和安装方法.
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
在完成了前面的配置之后,我们的vim应该已经很好用了.不过还是有些问题没有解决.没有自动补全.
这时候就要出马啦.
1. omni complete
omni complete是一个很好用的自动补全工具,支持很多语言,能自动的进行一些补全.在编译安装了vim73后,就自带了.我们要在vimrc下打开
set nocp
filetype plugin on
set ofu=syntaxcomplete#Complete
第一句是关闭兼容模式,第二句则是打开匹配文件类型.一定要加上
打开了之后,就能发现很多代码可以自动补全了.比如css,html等都能很好的工作,
使用方法是<ctrl+x><ctrl+o>
不过这还是不够,对于c/c++程序员来说,我们还需要更强大的工具.类成员变量,类的方法也要补全出来!
所以omnicppcomplete就登场了
下载: http://www.vim.org/scripts/script.php?script_id=1520
cp omnicppcomplete-0.41.zip ~/.vim cd ~/.vim unzip omnicppcomplete-0.41.zip
之后打开vimrc,添加下列几段
" OmniCppComplete set completeopt=menu,longest,menuone let OmniCpp_NamespaceSearch = 2 let OmniCpp_GlobalScopeSearch = 1 let OmniCpp_ShowAccess = 1 let OmniCpp_ShowPrototypeInAbbr = 1 let OmniCpp_MayCompleteDot = 1 let OmniCpp_MayCompleteArrow = 1 let OmniCpp_MayCompleteScope = 1 let OmniCpp_DefaultNamespaces = ["std", "_GLIBCXX_STD"] let OmniCpp_SelectFirstItem = 2 let OmniCpp_DisplayMode=1 au CursorMovedI,InsertLeave * if pumvisible() == 0|silent! pclose|endif
再次打开vim,omnicpp就安装上了.
不过,这类成员变量还是不出来啊.
原来omnicpp利用的是tag来判断的,因此我们需要利用ctags来生成
首先要保证机器里有ctags,而且最好要5.4以上.好像是之前的有bug.
进入所在的cpp的目录,
运行
ctags --c-kinds=+px --c++-kinds=+px --fields=+iafksS --extra=+qf your_file.cpp
这会生成一个tag文件,打开vim,运行
:set tags += tags
就会加载了.
使用的时候,在遇到->和.的时候就会自动弹出.
不过吧,这样还是麻烦.每次还得自己运行一遍ctags,然后把tags加载进来,而且,那意味着我们的有些库的头文件也不能自动补全么?
首先是自动加载tags,在vimrc中加入
set tags+=tags
set tags+=/home/summer/tags/lib_tags
对于我们平常用到的头文件,可以自己手动生成一份,放到固定的文件夹下,之后写代码就方便了.
比如我的lib_tags就是编译了linux的头文件生成的
ctags --c-kinds=+px --c++-kinds=+px --fields=+iafksS --extra=+qf -R /usr/include/*
有了这个tag,还可以发挥vim的跳转功能.记得--extra一定要+f,这样遇到头文件我们也能跳转进头文件了.
另外我加入了当前目录下的tags,这样当我们生成一个tag之后,vim就回自动加载了.
而对于自动生成tags.事实上,还有人写了一个方便的工具,下面介绍
2. omnitags
这个是国人写的vim插件,下载地址
http://www.vim.org/scripts/script.php?script_id=2870
下载最新的版本放到~/.vim/plugin目录下即可.
再修改vimrc
nmap <silent><leader>t :OmniTagsLoad ./tags<CR>
nmap <leader>u :OmniTagsUpdate
重启vim,在需要自动生成tags的时候,首先加载
<leader>t //如果提示没有tag,则会要求创建,选择y即可 <leader>u your_files //即可把该文件加入到本目录的tag中, //之后凡是用:w保存,tag都会被更新
现在,配合起omnicppcomplete,写代码就很方便了.
不过感觉提示还是不智能,而且每次要补全了还得自己手动按ctrl+x ctrl+o.不爽不爽
3. autocomplpop
这个插件就是解决我们的烦恼的
下载: http://www.vim.org/scripts/script.php?script_id=1879
同样的
cp vim-autocomplpop.zip ~/.vim unzip vim-autocomplpop.zip
就好了.
这个插件非常强大,自动弹出也满足了我们很多功能.比如自动弹出文件路径等等.
这个插件的默认是keyword completion.而由于咱们已经有了omnicppcomplete,所以其实就够了.
其对于keyword的补全实力非常强大.不过可能有人觉得,还是全部都用omni comp比较好.
于是就在网上搜了这么一段代码
let g:AutoComplPop_Behavior = { \ 'c': [ {'command' : "\<C-x>\<C-o>", \ 'pattern' : ".", \ 'repeat' : 0} \ ] \}
事实上这个是没有用的,要想使用的话,有两个方式
1. 下载2.6或者更老版本的autocomplpop
从2.7开始,autocomplpop就修改了配置方式,所以之前老的版本已经无效了
2. 修改写法
let g:acp_behavior = { 'command' : "\<C-x>\<C-o>", 'meets': mycppfunc 'repeat':0 }
在~/.vim/autoLoad/acp.vim中增加函数
照着里头acp#meetsForKeyword的函数写就可以了..
function mycppfunc(context) return 1 endfunction
不过这个在项目大了之后非常非常慢,所以不大推荐.默认的方法就挺好.效率也很高
4. NERDTreeToggle
这个是一个显示文件树形结构的插件,挺方便,一般大家也用
下载:http://www.vim.org/scripts/script.php?script_id=1658
老方法,cp后unzip在~/.vim下即可
在vimrc下加入下面语句
nmap <F2> :NERDTreeToggle<CR>
以后按F2就可以掉出来,很方便
5. taglist
taglist是利用ctags来读取目前文件下的函数列表,变量等,很方便,推荐使用
下载:http://www.vim.org/scripts/script.php?script_id=273
还是cp后unzip在~/.vim就可以使用了
在vimrc下加入
let Tlist_Ctags_Cmd='~/bin/ctags' //这个修改成安装ctags的目录 let Tlist_Show_One_File=1 let Tlist_OnlyWindow=1 let Tlist_Use_Right_Window=0 let Tlist_Sort_Type='name' let Tlist_Exit_OnlyWindow=1 let Tlist_Show_Menu=1 let Tlist_Max_Submenu_Items=10 let Tlist_Max_Tag_length=20 let Tlist_Use_SingleClick=0 let Tlist_Auto_Open=0 let Tlist_Close_On_Select=0 let Tlist_File_Fold_Auto_Close=1 let Tlist_GainFocus_On_ToggleOpen=1 let Tlist_Process_File_Always=1 let Tlist_WinHeight=10 let Tlist_WinWidth=45 let Tlist_Use_Horiz_Window=0 nmap <F3> :Tlist<CR>
之后就可以使用F3调出来了
6. stl
vim对于c++的高亮提示的不好,尤其是stl很多方法和容器都没有高亮,看着很是郁闷,这时候stl就派上用场了
下载:http://www.vim.org/scripts/script.php?script_id=2224
有了这个,vim就能对stl进行高亮了.
用法:
$ mkdir -p ~/.vim/after/syntax/cpp
$ cp stl.vim ~/.vim/after/syntax/cpp/
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
总结:
差不多把自己目前用的都介绍了.
vim用好了很强大,并不比很多IDE差.同时,由于环境限制,有的时候只能在终端下进行编程,VIM的重要性就体现出来了.用好了能很快提高开发效率.
目前笔者仅仅使用了这几款插件.觉得很好用,如果大家还有推荐的话,可以分享下.