美文网首页
Life With Vim[1] marker代码折叠

Life With Vim[1] marker代码折叠

作者: 蚂蚁啃骨头oO | 来源:发表于2019-01-09 10:42 被阅读0次

    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代码折叠

          本文链接:https://www.haomeiwen.com/subject/jykwrqtx.html