1. omni complete
omni complete是一个很好用的自动补全工具,支持很多语言,能自动的进行一些补全.在编译安装了vim73后,就自带了.我们要在vimrc下打开
set nocp
filetype plugin on
set ofu=syntaxcomplete#Complete
第一句是关闭兼容模式,第二句则是打开匹配文件类型.一定要加上
打开了之后,就能发现很多代码可以自动补全了.比如css,html等都能很好的工作,
使用方法是
不过这还是不够,对于c/c++程序员来说,我们还需要更强大的工具.类成员变量,类的方法也要补全出来!
所以omnicppcomplete就登场了
cp omnicppcomplete-0.41.zip ~/.vim
cd~/.vimunzip omnicppcomplete-0.41.zip
之后打开vimrc,添加下列几段
"OmniCppComplete
set completeopt=menu,longest,menuone
let OmniCpp_NamespaceSearch= 2let OmniCpp_GlobalScopeSearch= 1let OmniCpp_ShowAccess= 1let OmniCpp_ShowPrototypeInAbbr= 1let OmniCpp_MayCompleteDot= 1let OmniCpp_MayCompleteArrow= 1let OmniCpp_MayCompleteScope= 1let OmniCpp_DefaultNamespaces= ["std", "_GLIBCXX_STD"]
let OmniCpp_SelectFirstItem= 2let OmniCpp_DisplayMode=1au 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插件,下载地址
下载最新的版本放到~/.vim/plugin目录下即可.
再修改vimrc
nmap t :OmniTagsLoad ./tagsnmapu :OmniTagsUpdate
重启vim,在需要自动生成tags的时候,首先加载
t//如果提示没有tag,则会要求创建,选择y即可
u your_files//即可把该文件加入到本目录的tag中,//之后凡是用:w保存,tag都会被更新
现在,配合起omnicppcomplete,写代码就很方便了.
不过感觉提示还是不智能,而且每次要补全了还得自己手动按ctrl+x ctrl+o.不爽不爽
3. autocomplpop
这个插件就是解决我们的烦恼的
同样的
cp vim-autocomplpop.zip ~/.vimunzip vim-autocomplpop.zip
就好了.
这个插件非常强大,自动弹出也满足了我们很多功能.比如自动弹出文件路径等等.
这个插件的默认是keyword completion.而由于咱们已经有了omnicppcomplete,所以其实就够了.
其对于keyword的补全实力非常强大.不过可能有人觉得,还是全部都用omni comp比较好.
于是就在网上搜了这么一段代码
let g:AutoComplPop_Behavior ={
\'c': [ {'command' : "\\",
\'pattern' : ".",
\'repeat' : 0}
\ ]
\}
事实上这个是没有用的,要想使用的话,有两个方式
1. 下载2.6或者更老版本的autocomplpop
从2.7开始,autocomplpop就修改了配置方式,所以之前老的版本已经无效了
2. 修改写法
let g:acp_behavior ={'command' : "\\",'meets': mycppfunc'repeat':0}
在~/.vim/autoLoad/acp.vim中增加函数
照着里头acp#meetsForKeyword的函数写就可以了..
functionmycppfunc(context)
return1endfunction
不过这个在项目大了之后非常非常慢,所以不大推荐.默认的方法就挺好.效率也很高
4. NERDTreeToggle
这个是一个显示文件树形结构的插件,挺方便,一般大家也用
老方法,cp后unzip在~/.vim下即可
在vimrc下加入下面语句
nmap :NERDTreeToggle
以后按F2就可以掉出来,很方便
5. taglist
taglist是利用ctags来读取目前文件下的函数列表,变量等,很方便,推荐使用
还是cp后unzip在~/.vim就可以使用了
在vimrc下加入
let Tlist_Ctags_Cmd='~/bin/ctags' //这个修改成安装ctags的目录
let Tlist_Show_One_File=1let Tlist_OnlyWindow=1let Tlist_Use_Right_Window=0let Tlist_Sort_Type='name'let Tlist_Exit_OnlyWindow=1let Tlist_Show_Menu=1let Tlist_Max_Submenu_Items=10let Tlist_Max_Tag_length=20let Tlist_Use_SingleClick=0let Tlist_Auto_Open=0let Tlist_Close_On_Select=0let Tlist_File_Fold_Auto_Close=1let Tlist_GainFocus_On_ToggleOpen=1let Tlist_Process_File_Always=1let Tlist_WinHeight=10let Tlist_WinWidth=45let Tlist_Use_Horiz_Window=0nmap :Tlist
之后就可以使用F3调出来了
6. stl
vim对于c++的高亮提示的不好,尤其是stl很多方法和容器都没有高亮,看着很是郁闷,这时候stl就派上用场了
有了这个,vim就能对stl进行高亮了.
用法:
$ mkdir -p ~/.vim/after/syntax/cpp $ cp stl.vim ~/.vim/after/syntax/cpp/
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
总结:
差不多把自己目前用的都介绍了.
vim用好了很强大,并不比很多IDE差.同时,由于环境限制,有的时候只能在终端下进行编程,VIM的重要性就体现出来了.用好了能很快提高开发效率.