Life With Vim[1] marker代码折叠

Vim中的代码折叠的方法,除了diff我都(试图)用过。总结下来最好用的还是网络上大家提及最少的marker最好用。

  • indent/syntax这两种,属于全自动。看上去好用。但实际上,它常常会在你不想折叠的地方折叠而想折叠的地方它折叠不了(因为nesting设置起来很矛盾)。它还会托慢vim的速度,但这又是另一说了。
  • expr这种,我只是浅尝了一下。纯手动定义语义来进行折叠。定义一个完美的折叠方式非常费事,但定义完了就是全自动。我也懒得深究。
  • manual。在此之前是我用的最久的折叠方式。好处是你可以自己选取自己想要的段落用zf就可以永久自定义一个折叠区了。删除光标所在的折叠区用zd,递归删除zD,全文删除折叠区zE。在问题在于,它记录折叠区域的方式有问题。一旦我在文中有增减行数的行为,我修改处以下的所有折叠区都会乱(Vim估计是用的行号来记录的)。

marker其实就是一个用户显式定义折叠区边际的manual模式。如果说manual是vim在后台记录行数来确定折叠区起始和结束位置。marker就是在文章/代码中用可见字符来标记。这个可见字符就是{{{n}}}n(其中n是一个代表foldlevel`的整数,可在嵌套折叠时使用,如果使用得当忽略这个也没什么问题)。

因为这种折叠自己可以显式定义边界,就不会出现manual模式下那样修改上文打乱下文折叠的局面。

另外,marker模式也是可以使用折叠快捷键的。

zf 创建折叠区。它会自动在你选择的区域在起始和结束的地方加上{{{}}}

  • 如果是Vim认识的filetype的话,它还会自动注释这写折叠标记。
  • 它不会用{{{把折叠起始行的内容框进去,而是在起始行行末添加标记。这样你起始行的的内容就会成为折叠区的“标题”。方便浏览全文。

比如,为func1函数定义做折叠的话:

// 原文
int func1() {
    return 1;
} 

// 选取func1,包含函数上下各一个空行,然后zf
/*{{{*/
int func1() {
    return 1;
} 
/*}}}*/

// 只选取func1,不包含空行,然后zf
int func1() {/*{{{*/
    return a;
} /*}}}*/


// 如果func1上有注释,把注释也框选,然后zf
// returns 1{{{
int func1() {
    return a;
} /*}}}*/

所有的折叠标记,只需要使用zEzd或其他删除折叠区的快件键就可以删的不留痕迹。所以不用担心把代码分享给使用其他编辑器的同事时被唾弃。

你可能感兴趣的:(Life With Vim[1] marker代码折叠)