今天分享一下我至今为止写的最满意的一个 Vim 插件:https://github.com/liuchengxu/vim-clap, 它是一个用于模糊查找和搜索的 Vim 插件,在同类插件中最早同时支持 neovim 的floating_win
和 vim 的popup
, 这也是我造这个轮子的初衷之一。
在早期,作为一个纯 vimscript 实现的 Vim 插件,vim-clap 在进行大规模搜索时天然会有严重的性能问题,不过自从通过使用 Rust 对插件进行扩展以后,现在已经不存在有性能问题,可以轻松面对上百万的文件搜索。同时,vim-clap 也提供了二进制供直接下载,并且提供了方便的安装方式。如果使用 vim-plug:
" 本地编译 Rust 扩展,需要安装 cargo
Plug 'liuchengxu/vim-clap', { 'do': ':Clap install-binary' }
" 如果加上 !, 则当本地不存在 cargo 时, 直接下载 GitHub Release 上提供的二进制
Plug 'liuchengxu/vim-clap', { 'do': ':Clap install-binary!' }
v0.6 的一些新特性:
g:clap_layout
支持g:clap_layout
控制窗口的弹出位置,现在的默认位置相对于唤出 clap 的所在窗口,大小也是相对于该窗口的大小。
g:clap_layout
模拟的是 neovim 的 API, 如果希望打开位置相对于整个编辑器而不是所在窗口:
let g:clap_layout = { 'relative': 'editor' }
宽度更宽一点:
let g:clap_layout = { 'width': '95%', 'col': '5%' }
g:clap_theme
vim-clap 在 UI 上非常丰富,默认情况下是从用户的 colorscheme 中提取颜色,所以自适应于各种主题。但是即使是自适应,也无法保证对所有主题都适用,而且好像很多人不太会配置主题,所以 v0.6 内置了一个主题material_design_dark
, 在自适应表现不好的情况下,可以使用内置主题:
let g:clap_theme = 'material_design_dark'
也可以改变material_design_dark
的部分颜色, 比如将搜索文本改为红色:
let g:clap_theme = { 'search_text': {'guifg': 'red', 'ctermfg': 'red'} }
还有一些其他改进参见https://github.com/liuchengxu/vim-clap/releases/tag/v0.6, 比如新增loclist
provider, 很多 linter 可以将信息填充到 location list, 现在可以很方便的通过 vim-clap 进行过滤查看错误信息,同时支持预览功能:
很多其他特性就不一一介绍了,详情查看https://github.com/liuchengxu/vim-clap/blob/master/README.md和https://github.com/liuchengxu/vim-clap/blob/master/CHANGELOG.md。