xiaoxigua 2019-06-30
本文主要介绍 graphviz.vim, fork 自 wmgraphviz.vim,但是除了复用补全数据,我几乎重写了所有内容,并做了很多改进。
可能很多人没用过 graphviz,它是一个开源的图可视化工具,使用 DOT 语言进行绘制,优点是可以自动布局,尤其适用于复杂的流程图,结构图等等。官方有很多示例,使用时也可以参考一些其他的优秀案例,比如:
本文并不会对 graphviz 本身做太多介绍,而是分享如何在 Vim 中使用 graphviz.vim 插件方便画图。
wmgraphviz.vim 是 graphviz.vim 的前身,提供了一些补全,一键编译,查看编译后文件等功能。但是使用起来感觉不是那么 fashion,很久以来也几乎没怎么更新,比如依然在于 !
进行外部调用。
graphviz.vim 整个插件非常简单,本质上就是封装了一些编译,一键查看的命令而已,主要改进包括:
只有 :Graphviz
和 :GraphvizCompile
两个命令,:Graphviz
用于打开编译后的文件,:GraphvizCompile
用于编译当前文件。如果 :Graphviz!
则相当于 :GraphvizCompile | Graphviz
。对于可选项,我采用了传入参数进行调控。
这个很简单,只是简单封装了下 Omni 补全以适应 ncm2 和 coc.nvim。
使用 vim-plug 进行安装:
Plug 'liuchengxu/graphviz.vim'
:Graphviz
打开编译后的文件,文件名取自当前文件,辅以不同后缀。默认是打开 pdf
类型,比如当前打开的文件叫 foo.dot
,那么 :Graphviz
是尝试打开 foo.pdf
的文件,可以传入扩展名进行指定。
" 默认打开 pdf 文件 " 可选项: 'ps', 'pdf', 'png', 'jpg', 'gif', 'svg' :Graphviz " 打开 png 文件 :Graphviz png
:Graphviz!
会在目标文件不存在的情况下,尝试调用 :GraphvizCompile
进行编译然后再打开,相当于 :GraphvizCompile | Graphviz
。
:GraphvizCompile
用于编译当前文件,可以指定编译程序和扩展名,默认是 dot pdf
。
" :GraphvizCompile [exe] [format] " 默认是用 dot 编译成 pdf " :GraphvizCompile dot pdf :GraphvizCompile " 指定编译成 png 格式 :GraphvizCompile png " 指定用 dot 编译成 gif 格式,实际上我没用过除 dot 的其他编译项:( :GraphvizCompile dot gif
其他一些可选配置项:
" 指定打开文件的命令。默认会根据平台自动选择 " macOS 使用 open, Linux 使用 xdg-open 等 let g:graphviz_viewer = 'open' " 默认编译生成 pdf 格式,如果想要其他格式,将 pdf 换成其他格式即可 let g:graphviz_output_format = 'pdf'
我基本只用 macOS, 所以 Windows 或者 Linux 没怎么测试过,如果遇到问题,可以到 graphviz.vim 提 issue,我会尽量解决 :(。