终极 vim 配置: space-vim

2016-12-03 18:32:12 +08:00
 simple26

Quick Install

初衷

spacemacs 可能已经成为 emacs 社区中 “唯我独尊”的配置,在 github 上有近万的 star , contributor 众多。它的 “社区驱动” (community-driven) 真的是很 “耐力持久”,贡献的人很多, UI 很漂亮,功能也很强大。作为 emacs 长久以来的对家 vim, 如果也能有一个这样一个社区驱动的配置,相信也会给大家带来很多便利。

正如 spacemacs 所称,“ The best editor is neither Emacs nor Vim, it's Emacs and Vim!”, 最好的编辑器既不是 Emacs 也不是 Vim, 而是 Emacs 和 Vim! 所以不管是从实用角度,还是从设计概念,操作哲学的角度,这两个都是非常值得学习的。此外,“编辑器”始终是编辑器,取代不了 IDE ,因为吸引我们的更多是深入其中的过程。

就我自身的使用而言, GUI 环境下我会选择 spacemacs, 但是终端环境下 vim 依然是我的首选。我希望尽量保持这两个环境下操作的一致性。此外, vim 社区中,虽有 spf13-vim, k-vim 等一些比较有名的 vim 配置,但始终整合的不够,散落着很多适用特定环境的很好的配置,比如针对 c-c++, python, ruby 等等不同语言环境。还有大多也不够漂亮(当然了,这个有点主观,但不管怎么说,年轻人就是要挑“好看”的-_-)。

随着 vim8 的升级,会有很多新的更好的插件诞生,比如我用来替代 syntasticale, ale 使用了异步特性,再也不用因为语法检查而拖慢速度了。还有asyncrun.vim 等等,都会成为我们新的选择。 spf13-vim 等的更新似乎不太跟得上步伐,希望集体智慧能够给我们带来一个更好用的 vim 配置。

愿景

集百家之长,惠千家万家。

概览

名词解释

space-vim 既然是从 spacemacs 启发而来,自然借鉴了非常多的东西,其中最重要的一个概念便是 “ Layer ”.

Layer

space-vim 目前实现了 Layer 的概念, 就像这样:


    call LayersBegin()
    
    Layer 'fzf'
    Layer 'emoji'
    Layer 'colors'
    Layer 'python'
    Layer 'markdown'
    Layer 'syntax-checking'
    
    call LayersEnd()

在 space-vim 中,所谓的一个 Layer ,其实很简单,就是集成了一些相关的 vim 插件及其配置,涉及到两个文件: config.vim 与 packages.vim. 不难理解, config.vim 为该 Layer 的相关配置信息, packages.vim 则为该 Layer 所需的一些 vim 插件。

比如 Layer better-defaults, packages.vim 中的插件有:


    Plug 'liuchengxu/vim-better-default'
    Plug 'SirVer/ultisnips'
    Plug 'honza/vim-snippets'
    Plug 'Raimondi/delimitMate'
    Plug 'tpope/vim-surround'
    Plug 'easymotion/vim-easymotion'
    Plug 'mhinz/vim-startify'
    Plug 'scrooloose/nerdtree', { 'on': 'NERDTreeToggle' }
    Plug 'Xuyuanp/nerdtree-git-plugin', { 'on': 'NERDTreeToggle' }
    Plug 'tiagofumo/vim-nerdtree-syntax-highlight', { 'on': 'NERDTreeToggle' }
    Plug 'bronson/vim-trailing-whitespace', { 'on': 'FixWhitespace' }

调整,增加 Layer 都非常方便, 这也为 “集百家之长” 提供了土壤。

.spacevim

这个对应的是 .spacemacs, 用户可以自己决定启用哪些 Layer, 可以加载 space-vim 中没有的插件. 首次安装 space-vim 时,.spacevim 会在当前用户目录默认生成,其中主要有两个函数:


    " Put layers you want to enable as well as extra private plugins
    function! UserInit()
    
        " Space has been set as the default leader key,
        " if you want to change it, uncomment and set it here.
        " let g:spacevim_leader = "<\Space>"
        " let g:spacevim_localleader = ','
    
        " Put the layers you want to enable
        Layer 'fzf'
    
        " Put private plugins
        Plug 'junegunn/vim-github-dashboard'
    
    endfunction
    
    " Customize configuration
    function! UserConfig()
    
        color space-vim-dark
    
    endfunction

LayerStatus 可以查看启用了哪些 Layer.

如何使用

个人配置文件为 .spacevim, 如果没有 .spacevim, 那么 space-vim 仅会加载默认的 Layer. .space-vim 中定义了两个函数分别用于加载 Layer 与个人配置信息。


    function! UserInit()
    
        Layer 'fzf'
        Layer 'ycmd'
        Layer 'syntax-checking'
    
        Layer 'emoji'
        Layer 'goyo'
    
        Layer 'html'
        Layer 'python'
        Layer 'markdown'
        Layer 'c-c++'
    
        " 加载 space-vim Layer 中没有的插件
        Plug 'tpope/vim-fugitive'
        Plug 'junegunn/vim-github-dashboard'
        
    endfunction
        
    function! UserConfig()
        
        color gruvbox
        
    endfunction

此外, private 可以看做是一个 Layer ,如果个人配置比较多,可以放在这里, private 目录可以有 Layer 的两个 "标准" 文件, space-vim 也会进行加载:

如何贡献

展望

一个人的精力始终是有限的,非常欢迎大家分享自己的使用经验。三个臭皮匠还赛过诸葛亮呢,还不行? 那就四个:p 。

当然啦,可能很多人觉得 vimscript 没有 lisp 那么有表现力,稍显蹩脚。 Anyway, 都是工具,乐趣而已。如果能够集思广益,也是利己利人。

初期阶段,可做的事情还很多,欢迎大家分享与贡献. :space-vim

致谢


15796 次点击
所在节点    Vim
104 条回复
simple26
2016-12-04 09:17:33 +08:00
@ashfinal airline 使用的主题名字叫, violet ,。。。,也是自己改的,目前只是在 space-vim-dark 下面,欢迎进一步调整哈
loggerhead
2016-12-04 10:49:44 +08:00
亦可赛艇,对于楼主这种行为,我只能给出赞赞赞! PS : append 加个 github 地址吧 :smile:
simple26
2016-12-04 10:58:45 +08:00
@loggerhead 已 append ,发挥人民群众的力量, 利己利人~~~😀
ashfinal
2016-12-04 11:01:33 +08:00
@simple26 谢谢 我一直想 clone space-emacs 的主题来着 但是懒癌犯了。。。
simple26
2016-12-04 11:09:17 +08:00
@ashfinal 这个主题 clone 的目前不是很规范,肯定还有很多细节,觉得不舒服的地方欢迎修改分享出来哈
Yeoman
2016-12-04 11:26:07 +08:00
Error detected while processing /home/mickir/.vimrc:
line 2:
E492: Not an editor command: ^M
line 4:
E488: Trailing characters
line 7:
E488: Trailing characters
line 10:
E488: Trailing characters
line 14:
E492: Not an editor command: ^M
line 18:
E492: Not an editor command: ^M
line 20:
E492: Not an editor command: ^M
line 22:
E15: Invalid expression: filereadable(expand("~/.vimrc.plug.list"))^M
line 258:
E171: Missing :endif


set ff=unix please....
simple26
2016-12-04 11:30:38 +08:00
@Yeoman 这个是最新的? .vimrc.plug.list 这个文件时很久之前版本的...,现在已经弃用了,我去检查一下,有什么更详细的信息吗? 另外推荐有问题到 issue~~~,或许能有更多人一起解决
gimp
2016-12-04 11:31:22 +08:00
赞! 不会折腾 VIM ,现在在用这个 ( https://github.com/carlhuda/janus)
ashfinal
2016-12-04 11:31:34 +08:00
@simple26 嗯 之前做过一个主题。 https://github.com/ashfinal/vim-colors-paper

可以考虑做成我这种的, Light/Dark 一体,并嵌入 Airline 支持,能实现一键切换。
simple26
2016-12-04 11:33:00 +08:00
@Yeoman 你是不是看的是 tutorial_cn.md 。。。。, 抱歉没有更新,那个内容已经不大试用了,个人配置文件现在放在当前用户目录下的 .spacevim 中
simple26
2016-12-04 11:36:22 +08:00
@gimp 这个当然也好啦,经过时间检验的,能让初学者,不想折腾的人少走弯路。不过 space-vim 也会不断改进哒~
simple26
2016-12-04 11:38:10 +08:00
@ashfinal 恩,等稳定有时间了就考虑~~~
Yeoman
2016-12-04 11:46:12 +08:00
@Yeoman autocrlf.....的锅,无视我吧
simple26
2016-12-04 11:49:56 +08:00
@Yeoman 吓得我赶紧拜了拜关二爷😀
openroc
2016-12-04 11:56:22 +08:00
先 mark 一下,最近没有时间折腾
lsmgeb89
2016-12-04 12:04:33 +08:00
路过,瞄一眼 ML ……
simple26
2016-12-04 12:07:35 +08:00
@openroc 恩,这种事情适合无聊的时候~
simple26
2016-12-04 12:09:22 +08:00
@lsmgeb89 出其不意。。。
honmaple
2016-12-04 12:13:47 +08:00
2333
Lycnir
2016-12-04 13:43:21 +08:00
安装脚本还是很有问题:
OS: gentoo with zsh

==> Downloading vim-plug ......
:!curl -fLo ~/.vim/autoload/plug.vim https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
Warning: Failed to create the file /home/lyncir/.vim/autoload/plug.vim: Not a
Warning: directory
curl: (23) Failed writing body (0 != 1931)

shell returned 23

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/325062

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX