1. vimrc 基本配置
1.1. 配置文件的位置
在目录 /etc/ 下面,有个名为vimrc 的文件,这是系统中公共的vim
配置文件,对所有用户都有效。而在每个用户的主目录下,都可以自己建立私有的配置文件,命名为:“.vimrc” 。例如,/root
目录下,通常已经存在一个.vimrc 文件。
一个配置实例vimrc.7z
1.2. 设置语法高亮显示
(1 )打开vimrc ,添加以下语句来使得语法高亮显示:
syntax on
(2 )如果此时语法还是没有高亮显示,那么在/etc 目录下的profile 文件中添加以下语句:
export TERM=xterm-color
(3 )设置Windows 风格的C/C++ 自动缩进(添加以下set 语句到vimrc 中)
不讨论制表符为8 还是为4 较好,这里设置(软)制表符宽度为4 :
set tabstop=4
set softtabstop=4
设置缩进的空格数为4
set shiftwidth=4
设置自动缩进:即每行的缩进值与上一行相等;使用 noautoindent 取消设置:
set autoindent
设置使用 C/C++ 语言的自动缩进方式
set cindent
设置C/C++ 语言的具体缩进方式(以我的windows 风格为例):
set cinoptions={0,1s,t0,n-2,p2s,(03s,=.5s,>1s,=1s,:1s
如果想在左侧显示文本的行号,可以用以下语句:
set nu
最后,如果没有下列语句,就加上吧:
if &term=="xterm"
set t_Co=8
set t_Sb=^[[4%dm
set t_Sf=^[[3%dm
endif
PS :
自动缩进有两个选项:
代码:
set autoindent
set cindent
autoindent 就是自动缩进的意思,当你在输入状态用回车键插入一个新行,或者在 normal 状态用 o 或者 O
插入一个新行时,autoindent 会自动地将当前行的缩进拷贝到新行,也就是"
自动对齐”,当然了,如果你在新行没有输入任何字符,那么这个缩进将自动删除。
cindent 就不同了,它会按照 C 语言的语法,自动地调整缩进的长度,比如,当你输入了半条语句然后回车时,缩进会自动增加一个 TABSTOP
值,当你键入了一个右花括号时,会自动减少一个 TABSTOP 值。
设置配文件:
colorscheme wombat
wombat下载地址:
/scripts/script.php?script_id=1778
1.3. 括号自动补全
在/etc/vim/vimrc 中添加如下代码:
:inoremap ( ()<ESC>i
:inoremap ) <c-r>=ClosePair(')')<CR>
:inoremap { {}<ESC>i
:inoremap } <c-r>=ClosePair('}')<CR>
:inoremap [ []<ESC>i
:inoremap ] <c-r>=ClosePair(']')<CR>
:inoremap ' ''<ESC>i
:
inoremap " ""<ESC>i
function ClosePa
ir(char)
if getline('.')[col('.') - 1] == a:char
return "/<Right>"
else
return a:char
endif
endf
2. ctags 插件安装
你在读程序时看了一个函数调用, 或者一个变量, 或者一个宏等等, 你想知道它们的定义在哪儿, 怎么办呢?就用Ctag来实现这个功能:
到ctags.sourceforge/下载,解压后顺序执行“./configure”、“make”、“make
install”即可完成安装。
然后去你的源码目录, 如果你的源码是多层的目录, 就去最上层的目录, 在该目录下运行命令ctags -R,现在以我的
~/download/anjuta-2.4.0/src/为例,
$ cd ~/download/anjuta-2.4.0/
$ ctags -R
此时在~/download/anjuta-2.4.0/目录下会生成一个 tags 文件,
现在用vim打开~/download/anjuta-2.4.0/src/main.c
再在vim中运行命令:
:set tags=~/download/anjuta-2.4.0/tags
该命令将tags文件加入到vim中来, 你也可以将这句话放到vimrc中去, 如果你经常在这个工程编程的话.
此时,将鼠标移到一个变量上后,按下Ctrl+],便会自动跳转到该变量的定义处,再按下Ctrl+T,便会返回到原来处。
使用对象为变量, 结构, 宏, 等等, 都可以的, 赶快试试吧.....
不过还有一个小瑕疵, 你修改程序后, 比如增加了函数定义, 删除了变量定义, tags文件不能自动rebuild, 你必须手动再运行一下命令:
$ ctags -R
使tags文件更新一下, 不过让人感到欣慰的是vim不用重新启动, 正在编写的程序也不用退出, 马上就可以又正确使用<C-]>和<C-T>了.
3. taglist插件安装
unzip –d taglist taglist_42.zip
cd taglist
将taglist 目录下的 文件拷贝到/usr/share/vim/vim72/doc 目录下;
将taglist 目录下的taglist.vim 文件拷贝到/usr/share/vim/vim72/plugin 目录下。
vim /usr/share/vim/vim72/plugin/taglist.vim
在if !exists(“loaded_taglist”) 的前一行,加上一句:
let Tlist_Ctags_Cmd=”/usr/local/bin/ctags”
至此,打开cpp 文件,输入变量,再按ctrl + p 就可以有自动补全的功能了。
还可以根据需要对taglist 进行定制,
vim /usr/share/vim/vim72/plugin/taglist.vim
let Tlist_Auto_Open=1
启动vim 自动打开Tlist
let Tlist_File_Fold_Auto_Close=1
当同时显示多个文件中的tag 时,可使taglist 只显示当前文件tag ,其它文件的tag 都被折叠起来。
4. code_complete插件安装
下载code_complete 插件,将其拷贝到/usr/share/vim/vim72/plugin/ 目录下。
5. tabbar.vim插件安装
下载tabbar.vim 插件,将其拷贝到/usr/share/vim/vim72/plugin/ 目录下。
注意: 在打开新文件时,光标一定要处在主编辑界面中,这样才能保证标签的位置的位置合适。
关闭标签页使用:
6. a.vim插件安装
下载tabbar.vim 插件,将其拷贝到/usr/share/vim/vim72/plugin/ 目录下。
< if you are editing foo.c and need to edit foo.h simply execute :A and
you will be editting foo.h, to switch back to foo.c execute :A again.
7. ShowFuncc.vim 插件安装
下载ShowFuncc.vim 插件,将其拷贝到/usr/share/vim/vim72/plugin/ 目录下。
这个插件实现了按下 fd, 就可以提示当前光标所在函数的定义,另外还实现了当输入 '(' 时,会自动匹配 tags ,展示函数的定义原型。
8. omni 插件安装
参考~/.vim/
按照 omni 插件
下载omnicppcomplete-0[1].41.zip ,执行如下命令:
unzip –n omnicppcomplete-0[1].41.zip –d ~/.vim
将该文件解压到~/.vim 文件夹下, 有after 、autoload 、doc 三个文件夹。
生成 tags 文件
方法 1
在当前原文件所在目录下执行
ctags –R –c++-kinds=+p –fields=+iaS –extra=+q . (注意:最后有个. )
方法 2
每次都执行这个长的命令有些麻烦,可以这样设置:
touch ~/.ctags
打开.ctags 文件vim ~/.ctags ,添加如下三行命令i :
--c++-kinds=+p
--fields=+iaS
--extra=+q
在源文件所在的目录下执行
貌似直接用ctags –R 命令也可以。
在VIM 中执行
!ctags –R . 命令即可。(注意:最后有个点)
设置 vimrc
设置/etc/vim/vimrc
set nocp
filetype plugin on
set tags+=./tags
let OmniCpp_DefaultNamespaces=[“std”]
let OmniCpp_GlobalScopeSearch=1
let OmniCpp_NamespaceSearch=1
let OmniCpp_DisplayMode=1
let OmniCpp_ShowScopeAbbr=0
let OmniCpp_ShowPrototypeInAbbr=1
let OmniCpp_ShowAccess=1
let OmniCpp_MayCompleteDot=1
let OmniCpp_MayCompleteArrow=1
let OmniCpp_MayCompleteScope=1
set omnifunc=complete#Complete
set completeopt=longest,menu
9. WinManager 插件安装
( 1 ) 在当前用户下生效
下载winmanager.zip ,执行如下命令:
unzip –n winmanager.zip –d ~/.vim
打开一个.cpp 文件,在VIM 命令模式下输入WMToggle 展开文件夹,输入Tlist 打开taglist 列表。
使用ctrl 加两个w 键,将光标跳转到文件浏览,在光标选中的源文件按回车键,会在编辑窗口打开标签。
在当前文件夹下,创建新文件时,winmanager 并不会自动更新,需要利用ctrl+w 将光标转移到文件浏览器窗口(FileExplorer
),按F5 键
后,会进行刷新。
vim /etc/vim/vimrc
let g:winManagerWindowLayout=”FileExplorer,Taglist”
在VIM 只显示文fileexplorer 和taglist ,即只有文件夹中的文件和taglist ,也可以设置成:
let g:winManagerWindowLayout=” BufExplorer,FileExplorer,Taglist”
在VIM 中同时会显示缓冲区文件,即在文件浏览器中会显示.swp 文件。
let g:winManagerWidth=30
let g:defaultExplorer=0
10. C 语言相关符号高亮显示
vim /usr/share/vim/vim72/syntax/c.vim
( 1 )函数高亮显示
syn match cFunctions display
"[a-zA-Z_]/{-1,}/s/{-0,}(/{1}"ms=s,me=e-1
hi def link cFunctions Type
( 2 ) 指针符号高亮显示
syn match cPointer display "*"
hi def link cPointer Conditional
( 3 ) 指针操作符高亮显示
syn match cPointerOperator display "->/|/."
hi def link cPointerOperator Conditional
( 4 )逻辑运算符高亮显示
syn match cLogicalOperator display "[!<>]=/="
syn match cLogicalOperator display "=="
hi def link cLogicalOperator Conditional
( 5 ) 位运算符高亮显示
syn match cBinaryOperator display "/(&/||/|/^/|<</|>>/)=/="
syn match cBinaryOperator display "/~"
hi def link cBinaryOperator Conditional
( 6 ) 逻辑运算赋高亮显示
syn match cLogicalOperator display "/&& /| ||"
hi def link cLogicalOperatro Conditional
11. Doxygen
11.1. DoxygenToolkit 设置
下载DoxygenToolkit.vim 到/usr/share/vim/vim72/plugin 目录中。
将doxygenToolkit.vim 中的
“ let s:licenseTag = “ Copyright © /<enter>/<enter>” 的注释去掉。
在/etc/vim/vimrc 中添加
let g:doxygenToolkit_authorName="siceaner@gmail"
let s:licenseTag="Copyright (C) 2010 CheJiang University EE/<enter>"
let s:licenseTag=s:licenseTag."All rights reserved"
vim命令进入编辑模式let g:DoxygenToolkit_licenseTag=s:licenseTag
let g:doxygenToolkit_briefTag_funcName="yes"
let g:DoxygenToolkit_enhanced_color=1
这样,就可以这样,你就可以通过DoxAuthor ,DoxLic ,Dox ,Doxb
等几个命令来生成文件、函数等常用的注释,完成doxygen 风格的文档了。
11.2. Doxygen 设置
安装Doxygen 生成注释文档。
( 1 )安装 doxygen
sudo apt-get install doxygen doxygen-doc doxygen-gui graphviz
( 2 ) 生成配置文件
在程序所在目录下执行doxygen -g 生成doxygen 配置文件
( 3 ) 生成注释文档
在配置文件所在目录下,执行doxygen 配置文件名,生成注释文档。
12. 快捷键设置
vim /etc/vim/vimrc
nmap <F8> :Tlist
nmap <F9> :WMToggle
nmap doxq :DoxAuthor
nmap doxw :DoxLic
nmap doxe :Dox
nmap doxr :DoxBlock
///////////////////////////////////////////////////////////////////////////////////////
有重复的部分:
在没有怎么太深的接触vi/vim之前,也曾经搞不懂为什么有好多linux下的程序员说vi/vim是个超级的代码编辑器或者编译器,也有不少的(我认
为是刚在linux编程不久的人)说,“。。头让门挤啦,有那么多功能强大的linux环境下的IDE不用,竟然就用个简单的vi/vim,不用说界面类
似DOS,连编译都要用命令。。”。。等等类似的评价吧。
我开始也不懂它到底哪强大,但我仍坚持使用vim可以说是据以两点原因:
1、既然有那么多的前辈说它强大,那么就必定有他的道理
2、我规定自己以后的发展方向是 The Embedded System on
Linux,所以,在嵌入式硬件平台资源很有限的情况下,使用耗资大的IDE有点不现实,但是vi/vim却非
常适合应用在这种硬件平台上。
好了,其实我现在也是个linux下编程的新手,但我坚信我选择用vi/vim是正确的。
下面我们就在Ubuntu7.10下用vi/vim搭建c/c++的编程环境,至于到底超不超级的,相信大家自有评价 ^.^
注:本文主要参考和引用了 吴垠 的文章《手把手交你把Vim改装成一个IDE编程环境》, 如果涉及到版权问题,请通知我,我会及时处理 ^.^
不过该文章主要是用gvim在RedHat上搭建的,考虑到在嵌入式系统的硬件平台可能用不了gvim,故采用纯粹的vi/vim,而且主机环境为
Ubuntu7.10,这样,一些文件的安装路径可能和RedHat的有所区别,请读者自己注意吧 :)
本文已经假设你已经升级到了完整版的Vim7.1.56,而且已经安装了如gcc和g++等必须的编译器。
1、Vi/Vim中文帮助手册的安装。
a、
下载帮助中文包/-》UN*X打包文件,我下到的是vimcdoc-1.6.,解压后,进入到该解压后的文件夹vimcdoc-1.6.0,执行命令
$ sudo ./vimcdoc.sh -i //对中文帮助文件进行安装,详细可参考文件“INSTALL”
安装完成后, 在终端打开vi/vim,输入命令":help",即可看到,显示的帮助文件已经为中文了。
b、vim编程常用命令(引):
建议先看看帮助手册中的下面章节, 其中有关tags文件的部分你可以先跳过, 在后面的章节中会讲到, 到时候你在回来看看,
就觉得很简单了:
:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论