×

2018 更新下vim 插件

@(linux 编程)[工具使用]

周末网上晃荡看到一些关于 vim8 异步和插件的文章,觉得有些新功能挺实用的,所以花了点时间升级下自己的 vim 配置。
本文介绍一些使用到的实用插件以及参考配置。

on ubuntu 18


插件管理

vim-plug

之前使用的插件管理工具是 vundle, 没感觉啥问题,但是当看到 vim-plug 以下特点:

  • 安装方便,直接把 vim-plug.vim 丢 .vim/autoload 下就好了
  • 支持全异步插件安装、升级
  • 延迟加载,提高 vim 启动速度

我就果断抛弃 vundle,把插件管理工具改为她了。
安装配置和使用详细参考 git 主页,使用方式和 bundlue 类似 :PlugInstall,:PlugUpgrade等。

vimrc 中 配置类似:

call plug#begin('~/.vim/plugged') "开始,指定插件安装目录Plug 'junegunn/vim-easy-align'  Plug 'scrooloose/nerdtree', { 'on':  'NERDTreeToggle' }  "触发时才加载Plug 'tpope/vim-fireplace', { 'for': 'clojure' }        "打开对应文件才加载Plug 'rdnetto/YCM-Generator', { 'branch': 'stable' }  "选择插件分支Plug 'fatih/vim-go', { 'do': ':GoInstallBinaries' }  "安装插件时执行命令"....call plug#end()  "结束

符号索引

看源码的时候经常需要跳转,查看函数定义、被哪些地方调用,在 windows 下可以使用 source insight 等工具查看;
linux 下,之前用 vim 一直靠 ctags + cscope 看 c/c++,插件 jedi 查看 python 代码,其他语言没有,而且每次代码修改,都需要手动重新生成索引,感觉挺麻烦的。

在知乎看到这篇 <Vim8中C/C++符号索引:GTags 篇 >,vim8 支持异步模式后,自动符号索引简直太方便,直接打开工程文件,就可以随便查查查。

安装配置详细参考文章,大概基本步骤如下:

  • 重新安装 ctags,使用 Universal CTags (默认的软件源都是Exuberant Ctags,版本太旧了)
"正确设置vimrc,读取tags(当前目录,否则向上级目录查找添加 .tags)set tags=./.tags;,.tags
  • 安装 gtags (系统软件源一般版本比较低,建议自己编译安装)
    gtags 原生支持 6 种语言(C,C++,Java,PHP4,Yacc,汇编), 通过安装 pygments扩展支持 50+ 种语言(包括 go/rust/scala 等,基本覆盖所有主流语言。
pip install pygments
"vimrc 中设置环境变量启用 pygmentslet $GTAGSLABEL = 'native-pygments'let $GTAGSCONF = '/usr/local/share/gtags/gtags.conf' " 此路径根据实际设置(find一下)
  • 安装三个插件 : vim-gutentags 索引自动管理 + 索引数据库切换 + 索引预览
    按下面 vimrc 配置后打开 vim 执行:PlugInstall 完成插件安装,然后就可以开心使用了。
    预设快捷键如下
    • <leader>cg – 查看光标下符号的定义
    • <leader>cs – 查看光标下符号的引用
    • <leader>cc – 查看有哪些函数调用了该函数
    • <leader>cf– 查找光标下的文件
    • <leader>ci– 查找哪些文件 include 了本文件
      查找到索引后跳到弹出的 quikfix 窗口,停留在想查看索引行上,按 小P直接打开预览窗口,大P关闭预览,\d\u 向上向下滚动预览窗口。

vimrc 配置如下:

"自动载入ctags gtagsif version >= 800    Plug 'ludovicchabant/vim-gutentags'    Plug 'skywind3000/gutentags_plus'    let $GTAGSLABEL = 'native-pygments'    let $GTAGSCONF = '/usr/local/share/gtags/gtags.conf'    " gutentags 搜索工程目录的标志,当前文件路径向上递归直到碰到这些文件/目录名    let g:gutentags_project_root = ['.root', '.svn', '.git', '.hg', '.project']    " 所生成的数据文件的名称    let g:gutentags_ctags_tagfile = '.tags'    " 同时开启 ctags 和 gtags 支持:    let g:gutentags_modules = []    if executable('ctags')        let g:gutentags_modules += ['ctags']    endif    if executable('gtags-cscope') && executable('gtags')        let g:gutentags_modules += ['gtags_cscope']    endif    " 将自动生成的 ctags/gtags 文件全部放入 ~/.cache/tags 目录中,避免污染工程目录    let g:gutentags_cache_dir = expand('~/.cache/tags')    " 配置 ctags 的参数    let g:gutentags_ctags_extra_args = ['--fields=+niazS', '--extra=+q']    let g:gutentags_ctags_extra_args += ['--c++-kinds=+px']    let g:gutentags_ctags_extra_args += ['--c-kinds=+px']    " 如果使用 universal ctags 需要增加下面一行    let g:gutentags_ctags_extra_args += ['--output-format=e-ctags']    " 禁用 gutentags 自动加载 gtags 数据库的行为    " 避免多个项目数据库相互干扰    " 使用plus插件解决问题    let g:gutentags_auto_add_gtags_cscope = 0    "预览 quickfix 窗口 ctrl-w z 关闭    Plug 'skywind3000/vim-preview'    "P 预览 大p关闭    autocmd FileType qf nnoremap <silent><buffer> p :PreviewQuickfix<cr>    autocmd FileType qf nnoremap <silent><buffer> P :PreviewClose<cr>    noremap <Leader>u :PreviewScroll -1<cr> " 往上滚动预览窗口    noremap <leader>d :PreviewScroll +1<cr> "  往下滚动预览窗口endif

有个地方需要注意,配置中定义了项目标志文件为 .git, .svn, .root, .project, .hg.., 让 gutentags 可以确定当前文件所属项目的根目录,我们在当前目录打开文件后 guntentags 开始向父目录递归查找,直到找到这些标志文件时停止,对于没有 .git 之类标志文件的工程,可以在自己认为的根目录新建 .root 之类的文件作为标志。

效果图如下:

1534853129638.png

动态检查

静态代码检查是个很实用的东西,能在编写代码的过程中及时发现存在的错误,之前一直使用的插件是 syntastic, vim8 支持异步后可以升级实时 linting 工具 ALE

使用配置如下:

  Plug 'w0rp/ale'" 对应语言需要安装相应的检查工具" https://github.com/w0rp/ale"    let g:ale_linters_explicit = 1 "除g:ale_linters指定,其他不可用"    let g:ale_linters = {"\   'cpp': ['cppcheck','clang','gcc'],"\   'c': ['cppcheck','clang', 'gcc'],"\   'python': ['pylint'],"\   'bash': ['shellcheck'],"\   'go': ['golint'],"\}"    let g:ale_sign_column_always = 1    let g:ale_completion_delay = 500    let g:ale_echo_delay = 20    let g:ale_lint_delay = 500    let g:ale_echo_msg_format = '[%linter%] %code: %%s'    let g:ale_lint_on_text_changed = 'normal'    let g:ale_lint_on_insert_leave = 1    let g:airline#extensions#ale#enabled = 1    "let g:ale_set_quickfix = 1    "let g:ale_open_list = 1"打开quitfix对话框    let g:ale_c_gcc_options = '-Wall -O2 -std=c99'    let g:ale_cpp_gcc_options = '-Wall -O2 -std=c++14'    let g:ale_c_cppcheck_options = ''    let g:ale_cpp_cppcheck_options = ''    let g:ale_sign_error = ">>"    let g:ale_sign_warning = "--"    map <F7> ::ALEToggle<CR>

ALE 支持多种语言的代码检查,前提是系统已经安装了对应的工具(git 主页可见语言及对应工具),诸如 clang cppcheck pylint shellcheck golint等。
安装插件后打开 vim 编辑文件,可以看到检查效果了,可以设置多个检查工具检查不同维度错误,多个工具是并发进行检查的。

cppcheck 检查出指针泄漏,提出编码建议

1534853264187.png

暂时关闭代码检查:ALEDisable, 上述配置设置了快捷键 F7,:ALEDetail查看纤细描述等;

自动补全

vim 本身自带有补全功能,但是比较弱鸡,所以还是推荐百年老字号 YCM,最新版本 YCM 已经全异步化,弹出语义补全毫不卡顿。
安装过程需要编译 ycm_core 库,所以有点久。
参考配置

Plug 'Valloric/YouCompleteMe', {'do':'./install.py --clang-completer --go-completer --java-completer'}set completeopt=menu,menuone "关闭自动弹出的窗口let g:ycm_add_preview_to_completeopt = 0let g:ycm_show_diagnostics_ui = 0let g:ycm_server_log_level = 'info'let g:ycm_min_num_identifier_candidate_chars = 2let g:ycm_collect_identifiers_from_comments_and_strings = 1let g:ycm_complete_in_strings=1let g:ycm_key_invoke_completion = '<c-y>'set completeopt=menu,menuonenoremap <c-y> <NOP>let g:ycm_semantic_triggers =  {            \ 'c,cpp,python,java,go,erlang,perl': ['re!\w{2}'],            \ 'cs,lua,javascript': ['re!\w{2}'],            \ }let g:ycm_global_ycm_extra_conf= '~/.vim/.ycm_extra_conf.py'"附送 括号自动补全Plug 'jiangmiao/auto-pairs'

以上配置 参考

Plug 插件管理安装 YCM 后执行脚本 build.py 编译 ycm_core 库,指定了支持的语言系,如果有其他语言需求需要在安装编译时对应添加语义 flag。

对于 C-family 工程,ycm 需要配置文件 .ycm_extra_conf.py 才能进行语义补全提示(include 库之类的路径)
在上述配置中,最后设置 :
let g:ycm_global_ycm_extra_conf= '~/.vim/.ycm_extra_conf.py'
ycm 尝试从当前目录往上查找读取 .ycm_extra_conf.py 文件导入,最后如果没有找到就使用这个默认配置文件(参考插件例子 ~/.vim/plugged/YouCompleteMe/third_party/ycmd/examples/.ycm_extra_conf.py)。
如果自己工程编译参数,include 不同,可以拷贝默认配置文件修改 flags 后直接放在工程目录下。也可以使用 ycm 提供的 配置文件生成工具

默认的 ycm_extra_conf 文件定义编译 flags 如下

1534906709765.png

语义补全效果(文件前面没有写过的符号):
类方法

1534859936746.png

库函数

1534859969396.png

python

1534861412348.png

查找

leaderF 用于快速模糊查找文件或者函数
简单配置如下

Plug 'Yggdroot/LeaderF', { 'do': './install.sh' }" Ctrl + p 打开文件搜索let g:Lf_ShortcutF = '<c-p>'    "\p 打开函数列表noremap <Leader>p :LeaderfFunction<cr>

快捷键

  • <ctrl-p>: 查找文件
  • \p: 查找函数
  • <Ctrl-J>, 向下, <Ctrl-K>, 向上
  • <Ctrl-X> : open in horizontal split window.
  • <Ctrl-]> : open in vertical split window.
  • <Ctrl-T> : open in new tabpage.

使用效果 :
搜索文件 : ctrl-p

1534866470448.png

搜索函数 : \p

1534866419863.png

目录列表

左 nerdtree 右 taglist,老插件了。

1534914065501.png
**"当打开vim且没有文件时自动打开NERDTreeautocmd vimenter * if !argc() | NERDTree | endif" 只剩 NERDTree时自动关闭autocmd bufenter * if (winnr("$") == 1 && exists("b:NERDTreeType") && b:NERDTreeType == "primary") | q | endiflet NERDTreeShowLineNumbers=1let NERDTreeAutoCenter=1let NERDTreeShowHidden=1let NERDTreeIgnore=['\.pyc','\~$','\.swp','\.git']map <silent><F3> :NERDTreeToggle<CR>imap <F3> <ESC> :NERDTreeToggle<CR>
  • Taglist
    taglist依赖于ctags,所以要先装ctags;
    此插件显示打开文件的符号,命名空间,类名等。
"默认打开Taglistlet Tlist_Sort_Type = "name"    " 按照名称排序let Tlist_Auto_Open=0let Tlist_Ctags_Cmd = '/usr/local/bin/ctags'let Tlist_File_Fold_Auto_Close = 1let Tlist_Exit_OnlyWindow = 1 "如果taglist窗口是最后一个窗口,则退出vimlet Tlist_Use_Right_Window = 1 "在右侧窗口中显示taglist窗口let Tlist_Compart_Format = 1    " 压缩方式let Tlist_Exist_OnlyWindow = 1  " 如果只有一个buffer,kill窗口也kill掉bufferlet Tlist_Show_One_File=1            "不同时显示多个文件的tag,只显示当前文件的

其他插件

  • vim-signify 修改标记
    通过 signify 这个插件,对于打开有版本控制的文件,可以在文件侧边实时显示文件的修改情况。
    :SignifyDiff 可以直接打开新 tab 对比版本差异,常用可以设置快捷键触发
    1534865414540.png

另外一个在vim中打开终端的插件 python-repl


以上插件,你可以在终端直接执行(Ubuntu18)

wget -qO- https://raw.githubusercontent.com/orientlu/vim/master/setup.sh | sh -x

安装配置好的vim,需要手动升级ctags和gtags,参考 install_tags.md


参考

人已赞赏
0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
有新消息 消息中心
搜索