Bram Moolenaar | ded2782 | 2017-01-02 14:27:34 +0100 | [diff] [blame] | 1 | " Test for folding |
| 2 | |
Bram Moolenaar | 1159b16 | 2017-02-28 21:53:56 +0100 | [diff] [blame] | 3 | func! Test_address_fold() |
Bram Moolenaar | ded2782 | 2017-01-02 14:27:34 +0100 | [diff] [blame] | 4 | new |
| 5 | call setline(1, ['int FuncName() {/*{{{*/', 1, 2, 3, 4, 5, '}/*}}}*/', |
| 6 | \ 'after fold 1', 'after fold 2', 'after fold 3']) |
| 7 | setl fen fdm=marker |
| 8 | " The next ccommands should all copy the same part of the buffer, |
| 9 | " regardless of the adressing type, since the part to be copied |
| 10 | " is folded away |
| 11 | :1y |
| 12 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3', '4', '5', '}/*}}}*/'], getreg(0,1,1)) |
| 13 | :.y |
| 14 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3', '4', '5', '}/*}}}*/'], getreg(0,1,1)) |
| 15 | :.+y |
| 16 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3', '4', '5', '}/*}}}*/'], getreg(0,1,1)) |
| 17 | :.,.y |
| 18 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3', '4', '5', '}/*}}}*/'], getreg(0,1,1)) |
| 19 | :sil .1,.y |
| 20 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3', '4', '5', '}/*}}}*/'], getreg(0,1,1)) |
| 21 | " use silent to make E493 go away |
| 22 | :sil .+,.y |
| 23 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3', '4', '5', '}/*}}}*/'], getreg(0,1,1)) |
| 24 | :,y |
| 25 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3', '4', '5', '}/*}}}*/'], getreg(0,1,1)) |
| 26 | :,+y |
| 27 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3', '4', '5', '}/*}}}*/','after fold 1'], getreg(0,1,1)) |
| 28 | " using .+3 as second address should copy the whole folded line + the next 3 |
| 29 | " lines |
| 30 | :.,+3y |
| 31 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3', '4', '5', '}/*}}}*/', |
| 32 | \ 'after fold 1', 'after fold 2', 'after fold 3'], getreg(0,1,1)) |
| 33 | :sil .,-2y |
| 34 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3', '4', '5', '}/*}}}*/'], getreg(0,1,1)) |
| 35 | |
| 36 | " now test again with folding disabled |
| 37 | set nofoldenable |
| 38 | :1y |
| 39 | call assert_equal(['int FuncName() {/*{{{*/'], getreg(0,1,1)) |
| 40 | :.y |
| 41 | call assert_equal(['int FuncName() {/*{{{*/'], getreg(0,1,1)) |
| 42 | :.+y |
| 43 | call assert_equal(['1'], getreg(0,1,1)) |
| 44 | :.,.y |
| 45 | call assert_equal(['int FuncName() {/*{{{*/'], getreg(0,1,1)) |
| 46 | " use silent to make E493 go away |
| 47 | :sil .1,.y |
| 48 | call assert_equal(['int FuncName() {/*{{{*/', '1'], getreg(0,1,1)) |
| 49 | " use silent to make E493 go away |
| 50 | :sil .+,.y |
| 51 | call assert_equal(['int FuncName() {/*{{{*/', '1'], getreg(0,1,1)) |
| 52 | :,y |
| 53 | call assert_equal(['int FuncName() {/*{{{*/'], getreg(0,1,1)) |
| 54 | :,+y |
| 55 | call assert_equal(['int FuncName() {/*{{{*/', '1'], getreg(0,1,1)) |
| 56 | " using .+3 as second address should copy the whole folded line + the next 3 |
| 57 | " lines |
| 58 | :.,+3y |
| 59 | call assert_equal(['int FuncName() {/*{{{*/', '1', '2', '3'], getreg(0,1,1)) |
| 60 | :7 |
| 61 | :sil .,-2y |
| 62 | call assert_equal(['4', '5', '}/*}}}*/'], getreg(0,1,1)) |
| 63 | |
| 64 | quit! |
Bram Moolenaar | 1159b16 | 2017-02-28 21:53:56 +0100 | [diff] [blame] | 65 | endfunc |
Bram Moolenaar | 54b2bfa | 2017-01-02 14:57:08 +0100 | [diff] [blame] | 66 | |
Bram Moolenaar | 1159b16 | 2017-02-28 21:53:56 +0100 | [diff] [blame] | 67 | func! Test_indent_fold() |
Bram Moolenaar | 54b2bfa | 2017-01-02 14:57:08 +0100 | [diff] [blame] | 68 | new |
| 69 | call setline(1, ['', 'a', ' b', ' c']) |
| 70 | setl fen fdm=indent |
| 71 | 2 |
| 72 | norm! >> |
| 73 | let a=map(range(1,4), 'foldclosed(v:val)') |
| 74 | call assert_equal([-1,-1,-1,-1], a) |
Bram Moolenaar | 1159b16 | 2017-02-28 21:53:56 +0100 | [diff] [blame] | 75 | endfunc |
Bram Moolenaar | 54b2bfa | 2017-01-02 14:57:08 +0100 | [diff] [blame] | 76 | |
Bram Moolenaar | 1159b16 | 2017-02-28 21:53:56 +0100 | [diff] [blame] | 77 | func! Test_indent_fold() |
Bram Moolenaar | 54b2bfa | 2017-01-02 14:57:08 +0100 | [diff] [blame] | 78 | new |
| 79 | call setline(1, ['', 'a', ' b', ' c']) |
| 80 | setl fen fdm=indent |
| 81 | 2 |
| 82 | norm! >> |
| 83 | let a=map(range(1,4), 'foldclosed(v:val)') |
| 84 | call assert_equal([-1,-1,-1,-1], a) |
| 85 | bw! |
Bram Moolenaar | 1159b16 | 2017-02-28 21:53:56 +0100 | [diff] [blame] | 86 | endfunc |
Bram Moolenaar | 54b2bfa | 2017-01-02 14:57:08 +0100 | [diff] [blame] | 87 | |
Bram Moolenaar | 1159b16 | 2017-02-28 21:53:56 +0100 | [diff] [blame] | 88 | func! Test_indent_fold2() |
Bram Moolenaar | 54b2bfa | 2017-01-02 14:57:08 +0100 | [diff] [blame] | 89 | new |
| 90 | call setline(1, ['', '{{{', '}}}', '{{{', '}}}']) |
| 91 | setl fen fdm=marker |
| 92 | 2 |
| 93 | norm! >> |
| 94 | let a=map(range(1,5), 'foldclosed(v:val)') |
| 95 | call assert_equal([-1,-1,-1,4,4], a) |
| 96 | bw! |
Bram Moolenaar | 1159b16 | 2017-02-28 21:53:56 +0100 | [diff] [blame] | 97 | endfunc |
| 98 | |
| 99 | func Test_manual_fold_with_filter() |
| 100 | if !executable('cat') |
| 101 | return |
| 102 | endif |
Bram Moolenaar | 3f3897e | 2017-03-04 15:28:53 +0100 | [diff] [blame] | 103 | for type in ['manual', 'marker'] |
| 104 | exe 'set foldmethod=' . type |
| 105 | new |
| 106 | call setline(1, range(1, 20)) |
| 107 | 4,$fold |
| 108 | %foldopen |
| 109 | 10,$fold |
| 110 | %foldopen |
| 111 | " This filter command should not have an effect |
| 112 | 1,8! cat |
| 113 | call feedkeys('5ggzdzMGdd', 'xt') |
| 114 | call assert_equal(['1', '2', '3', '4', '5', '6', '7', '8', '9'], getline(1, '$')) |
| 115 | |
| 116 | bwipe! |
| 117 | set foldmethod& |
| 118 | endfor |
Bram Moolenaar | 1159b16 | 2017-02-28 21:53:56 +0100 | [diff] [blame] | 119 | endfunc |
Bram Moolenaar | eadbc2b | 2017-03-04 18:42:39 +0100 | [diff] [blame] | 120 | |
| 121 | func! Test_indent_fold_with_read() |
| 122 | new |
| 123 | set foldmethod=indent |
| 124 | call setline(1, repeat(["\<Tab>a"], 4)) |
| 125 | for n in range(1, 4) |
| 126 | call assert_equal(1, foldlevel(n)) |
| 127 | endfor |
| 128 | |
| 129 | call writefile(["a", "", "\<Tab>a"], 'Xfile') |
| 130 | foldopen |
| 131 | 2read Xfile |
| 132 | %foldclose |
| 133 | call assert_equal(1, foldlevel(1)) |
| 134 | call assert_equal(2, foldclosedend(1)) |
| 135 | call assert_equal(0, foldlevel(3)) |
| 136 | call assert_equal(0, foldlevel(4)) |
| 137 | call assert_equal(1, foldlevel(5)) |
| 138 | call assert_equal(7, foldclosedend(5)) |
| 139 | |
| 140 | bwipe! |
| 141 | set foldmethod& |
| 142 | call delete('Xfile') |
| 143 | endfunc |
| 144 | |
| 145 | func Test_combining_folds_indent() |
| 146 | new |
| 147 | let one = "\<Tab>a" |
| 148 | let zero = 'a' |
| 149 | call setline(1, [one, one, zero, zero, zero, one, one, one]) |
| 150 | set foldmethod=indent |
| 151 | 3,5d |
| 152 | %foldclose |
| 153 | call assert_equal(5, foldclosedend(1)) |
| 154 | |
| 155 | set foldmethod& |
| 156 | bwipe! |
| 157 | endfunc |
| 158 | |
| 159 | func Test_combining_folds_marker() |
| 160 | new |
| 161 | call setline(1, ['{{{', '}}}', '', '', '', '{{{', '', '}}}']) |
| 162 | set foldmethod=marker |
| 163 | 3,5d |
| 164 | %foldclose |
| 165 | call assert_equal(2, foldclosedend(1)) |
| 166 | |
| 167 | set foldmethod& |
| 168 | bwipe! |
| 169 | endfunc |
| 170 | |
Bram Moolenaar | 025a6b7 | 2017-03-12 20:37:21 +0100 | [diff] [blame] | 171 | func Test_folds_marker_in_comment() |
| 172 | new |
| 173 | call setline(1, ['" foo', 'bar', 'baz']) |
| 174 | setl fen fdm=marker |
| 175 | setl com=sO:\"\ -,mO:\"\ \ ,eO:\"\",:\" cms=\"%s |
| 176 | norm! zf2j |
| 177 | setl nofen |
| 178 | :1y |
| 179 | call assert_equal(['" foo{{{'], getreg(0,1,1)) |
| 180 | :+2y |
| 181 | call assert_equal(['baz"}}}'], getreg(0,1,1)) |
| 182 | |
| 183 | set foldmethod& |
| 184 | bwipe! |
| 185 | endfunc |
| 186 | |
Bram Moolenaar | eadbc2b | 2017-03-04 18:42:39 +0100 | [diff] [blame] | 187 | func s:TestFoldExpr(lnum) |
| 188 | let thisline = getline(a:lnum) |
| 189 | if thisline == 'a' |
| 190 | return 1 |
| 191 | elseif thisline == 'b' |
| 192 | return 0 |
| 193 | elseif thisline == 'c' |
| 194 | return '<1' |
| 195 | elseif thisline == 'd' |
| 196 | return '>1' |
| 197 | endif |
| 198 | return 0 |
| 199 | endfunction |
| 200 | |
| 201 | func Test_update_folds_expr_read() |
| 202 | new |
| 203 | call setline(1, ['a', 'a', 'a', 'a', 'a', 'a']) |
| 204 | set foldmethod=expr |
| 205 | set foldexpr=s:TestFoldExpr(v:lnum) |
| 206 | 2 |
| 207 | foldopen |
| 208 | call writefile(['b', 'b', 'a', 'a', 'd', 'a', 'a', 'c'], 'Xfile') |
| 209 | read Xfile |
| 210 | %foldclose |
| 211 | call assert_equal(2, foldclosedend(1)) |
| 212 | call assert_equal(0, foldlevel(3)) |
| 213 | call assert_equal(0, foldlevel(4)) |
| 214 | call assert_equal(6, foldclosedend(5)) |
| 215 | call assert_equal(10, foldclosedend(7)) |
| 216 | call assert_equal(14, foldclosedend(11)) |
| 217 | |
| 218 | call delete('Xfile') |
| 219 | bwipe! |
| 220 | set foldmethod& foldexpr& |
| 221 | endfunc |