http://newbiedoc.sourceforge.net/text_editing/vim.html.en
http://www.cnblogs.com/marchtea/archive/2012/10/17/2727852.html
多窗口分别打开多个文件:
vim -O file1 file2 file3 ... //垂直窗口
vim -o file1 file2 file3 ... //水平窗口
移动
ma:在当前光标的位置标记一个书签,名字为 a。书签名只能是小写字母。你看不见书签的存在,但它确实已经在那里了。
`a:到书签 a 处。注意这个不是单引号,它一般位于大部分键盘的 1 的左边。
`.:到你上次编辑文件的地方。这个命令很有用,而且你不用自己去标记它。
输入
c{motion}:删除 motion 命令跨过的字符,并且进入插入模式。比如:c$,这将会删除从光标位置到行尾的字符并且进入插入模式。ct!,这会删除从光标位置到下一个叹号(但不包括),然后进入插入模式。被删除的字符被存在了剪贴板里面,并且可以再粘贴出来。
d{motion}:和上面差不多,但是不进入插入模式。
]p:和 p 的功能差不多,但是它会自动调整被粘贴的文本的缩进去适应当前代码的位置。
gd:到达光标所在处函数或者变量的定义处。
【guu 】 – 把一行的文字变成全小写。或是【Vu】
【gUU】 – 把一行的文件变成全大写。或是【VU】
按【v】键进入选择模式,然后移动光标选择你要的文本,按【u】转小写,按【U】转大写
【ga】 – 查看光标处字符的ascii码
【g8】 – 查看光标处字符的utf-8编码
【gf】 - 打开光标处所指的文件 (这个命令在打到#include头文件时挺好用的,当然,仅限于有路径的)
【>>】向右给它进当前行 【<<】向左缩进当前行
【=】 - 缩进当前行 (和上面不一样的是,它会对齐缩进)
【=%】 – 把光标位置移到语句块的括号上,然后按=%,缩进整个语句块(%是括号匹配)
【G=gg】 或是 【gg=G】 - 缩进整个文件(G是到文件结尾,gg是到文件开头)
关键字补全
Ctrl + X 和 Ctrl + D 宏定义补齐
Ctrl + X 和 Ctrl + ] 是Tag 补齐
Ctrl + X 和 Ctrl + F 是文件名 补齐
Ctrl + X 和 Ctrl + I 也是关键词补齐,但是关键后会有个文件名,告诉你这个关键词在哪个文件中
Ctrl + X 和 Ctrl +V 是表达式补齐
Ctrl + X 和 Ctrl +L 这可以对整个行补齐,
分屏
插件:
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
在完成了前面的配置之后,我们的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就登场了
下载: OmniCppComplete - C/C++ omni-completion with ctags database : vim online
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插件,下载地址
OmniTags - This plugin can help you to maintenance tags file. : vim online
下载最新的版本放到~/.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
这个插件就是解决我们的烦恼的
下载: AutoComplPop - Automatically opens popup menu for completions : vim online
同样的
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
这个是一个显示文件树形结构的插件,挺方便,一般大家也用
下载:The NERD tree - A tree explorer plugin for navigating the filesystem : vim online
老方法,cp后unzip在~/.vim下即可
在vimrc下加入下面语句
nmap <F2> :NERDTreeToggle<CR>
以后按F2就可以掉出来,很方便
5. taglist
taglist是利用ctags来读取目前文件下的函数列表,变量等,很方便,推荐使用
下载:taglist.vim - Source code browser (supports C/C++, java, perl, python, tcl, sql, php, etc) : vim online
还是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就派上用场了
下载:STL improved - Improved C++ STL syntax highlighting : vim online
有了这个,vim就能对stl进行高亮了.
用法:
$ mkdir -p ~/.vim/after/syntax/cpp
$ cp stl.vim ~/.vim/after/syntax/cpp/
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------