blob: f11ca0812d37a706baa5419b2b52797480b08609 [file] [log] [blame]
Bram Moolenaareb490412022-06-28 13:44:46 +01001*fold.txt* For Vim version 9.0. Last change: 2022 Jan 22
Bram Moolenaar071d4272004-06-13 20:20:40 +00002
3
4 VIM REFERENCE MANUAL by Bram Moolenaar
5
6
Bram Moolenaar8f3f58f2010-01-06 20:52:26 +01007Folding *Folding* *folding* *folds*
Bram Moolenaar071d4272004-06-13 20:20:40 +00008
9You can find an introduction on folding in chapter 28 of the user manual.
10|usr_28.txt|
11
121. Fold methods |fold-methods|
132. Fold commands |fold-commands|
143. Fold options |fold-options|
154. Behavior of folds |fold-behavior|
16
Bram Moolenaardb84e452010-08-15 13:50:43 +020017{not available when compiled without the |+folding| feature}
Bram Moolenaar071d4272004-06-13 20:20:40 +000018
19==============================================================================
201. Fold methods *fold-methods*
21
22The folding method can be set with the 'foldmethod' option.
23
24When setting 'foldmethod' to a value other than "manual", all folds are
25deleted and new ones created. Switching to the "manual" method doesn't remove
26the existing folds. This can be used to first define the folds automatically
27and then change them manually.
28
29There are six methods to select folds:
30 manual manually define folds
31 indent more indent means a higher fold level
32 expr specify an expression to define folds
33 syntax folds defined by syntax highlighting
34 diff folds for unchanged text
35 marker folds defined by markers in the text
36
37
38MANUAL *fold-manual*
39
40Use commands to manually define the fold regions. This can also be used by a
41script that parses text to find folds.
42
43The level of a fold is only defined by its nesting. To increase the fold
44level of a fold for a range of lines, define a fold inside it that has the
45same lines.
46
47The manual folds are lost when you abandon the file. To save the folds use
48the |:mkview| command. The view can be restored later with |:loadview|.
49
50
51INDENT *fold-indent*
52
53The folds are automatically defined by the indent of the lines.
54
55The foldlevel is computed from the indent of the line, divided by the
56'shiftwidth' (rounded down). A sequence of lines with the same or higher fold
57level form a fold, with the lines with a higher level forming a nested fold.
58
59The nesting of folds is limited with 'foldnestmax'.
60
61Some lines are ignored and get the fold level of the line above or below it,
Bram Moolenaar446beb42011-05-10 17:18:44 +020062whichever is lower. These are empty or white lines and lines starting
Bram Moolenaar071d4272004-06-13 20:20:40 +000063with a character in 'foldignore'. White space is skipped before checking for
64characters in 'foldignore'. For C use "#" to ignore preprocessor lines.
65
Bram Moolenaar214641f2017-03-05 17:04:09 +010066When you want to ignore lines in another way, use the "expr" method. The
Bram Moolenaar071d4272004-06-13 20:20:40 +000067|indent()| function can be used in 'foldexpr' to get the indent of a line.
68
69
70EXPR *fold-expr*
71
72The folds are automatically defined by their foldlevel, like with the "indent"
73method. The value of the 'foldexpr' option is evaluated to get the foldlevel
74of a line. Examples:
Bram Moolenaar666771a2007-05-12 14:03:30 +000075This will create a fold for all consecutive lines that start with a tab: >
Bram Moolenaar071d4272004-06-13 20:20:40 +000076 :set foldexpr=getline(v:lnum)[0]==\"\\t\"
Bram Moolenaar071d4272004-06-13 20:20:40 +000077This will make a fold out of paragraphs separated by blank lines: >
78 :set foldexpr=getline(v:lnum)=~'^\\s*$'&&getline(v:lnum+1)=~'\\S'?'<1':1
Bram Moolenaar3c2881d2017-03-21 19:18:29 +010079This does the same: >
Bram Moolenaar071d4272004-06-13 20:20:40 +000080 :set foldexpr=getline(v:lnum-1)=~'^\\s*$'&&getline(v:lnum)=~'\\S'?'>1':1
81
82Note that backslashes must be used to escape characters that ":set" handles
83differently (space, backslash, double quote, etc., see |option-backslash|).
84
Bram Moolenaar87b4e5c2022-10-01 15:32:46 +010085The most efficient is to call a compiled function without arguments: >
86 :set foldexpr=MyFoldLevel()
87The function must use v:lnum. See |expr-option-function|.
88
Bram Moolenaar071d4272004-06-13 20:20:40 +000089These are the conditions with which the expression is evaluated:
90- The current buffer and window are set for the line.
91- The variable "v:lnum" is set to the line number.
92- The result is used for the fold level in this way:
93 value meaning ~
94 0 the line is not in a fold
95 1, 2, .. the line is in a fold with this level
96 -1 the fold level is undefined, use the fold level of a
97 line before or after this line, whichever is the
98 lowest.
99 "=" use fold level from the previous line
100 "a1", "a2", .. add one, two, .. to the fold level of the previous
Bram Moolenaard042dc82015-11-24 19:18:36 +0100101 line, use the result for the current line
Bram Moolenaar071d4272004-06-13 20:20:40 +0000102 "s1", "s2", .. subtract one, two, .. from the fold level of the
Bram Moolenaard042dc82015-11-24 19:18:36 +0100103 previous line, use the result for the next line
Bram Moolenaar071d4272004-06-13 20:20:40 +0000104 "<1", "<2", .. a fold with this level ends at this line
105 ">1", ">2", .. a fold with this level starts at this line
106
107It is not required to mark the start (end) of a fold with ">1" ("<1"), a fold
108will also start (end) when the fold level is higher (lower) than the fold
109level of the previous line.
110
111There must be no side effects from the expression. The text in the buffer,
112cursor position, the search patterns, options etc. must not be changed.
Bram Moolenaare2f98b92006-03-29 21:18:24 +0000113You can change and restore them if you are careful.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000114
115If there is some error in the expression, or the resulting value isn't
116recognized, there is no error message and the fold level will be zero.
117For debugging the 'debug' option can be set to "msg", the error messages will
118be visible then.
119
120Note: Since the expression has to be evaluated for every line, this fold
121method can be very slow!
122
123Try to avoid the "=", "a" and "s" return values, since Vim often has to search
124backwards for a line for which the fold level is defined. This can be slow.
125
Yegappan Lakshmanan8bb65f22021-12-26 10:51:39 +0000126If the 'foldexpr' expression starts with s: or |<SID>|, then it is replaced
Yegappan Lakshmanan27708e62021-12-26 21:54:43 +0000127with the script ID (|local-function|). Examples: >
Yegappan Lakshmanan8bb65f22021-12-26 10:51:39 +0000128 set foldexpr=s:MyFoldExpr()
129 set foldexpr=<SID>SomeFoldExpr()
130<
Bram Moolenaard042dc82015-11-24 19:18:36 +0100131An example of using "a1" and "s1": For a multi-line C comment, a line
132containing "/*" would return "a1" to start a fold, and a line containing "*/"
133would return "s1" to end the fold after that line: >
134 if match(thisline, '/\*') >= 0
135 return 'a1'
136 elseif match(thisline, '\*/') >= 0
137 return 's1'
138 else
139 return '='
140 endif
141However, this won't work for single line comments, strings, etc.
142
Bram Moolenaar071d4272004-06-13 20:20:40 +0000143|foldlevel()| can be useful to compute a fold level relative to a previous
144fold level. But note that foldlevel() may return -1 if the level is not known
145yet. And it returns the level at the start of the line, while a fold might
146end in that line.
147
Bram Moolenaar214641f2017-03-05 17:04:09 +0100148It may happen that folds are not updated properly. You can use |zx| or |zX|
Bram Moolenaar00a927d2010-05-14 23:24:24 +0200149to force updating folds.
150
Bram Moolenaar071d4272004-06-13 20:20:40 +0000151
152SYNTAX *fold-syntax*
153
154A fold is defined by syntax items that have the "fold" argument. |:syn-fold|
155
156The fold level is defined by nesting folds. The nesting of folds is limited
157with 'foldnestmax'.
158
159Be careful to specify proper syntax syncing. If this is not done right, folds
160may differ from the displayed highlighting. This is especially relevant when
161using patterns that match more than one line. In case of doubt, try using
162brute-force syncing: >
163 :syn sync fromstart
164
165
166DIFF *fold-diff*
167
168The folds are automatically defined for text that is not part of a change or
169close to a change.
170
171This method only works properly when the 'diff' option is set for the current
172window and changes are being displayed. Otherwise the whole buffer will be
173one big fold.
174
175The 'diffopt' option can be used to specify the context. That is, the number
176of lines between the fold and a change that are not included in the fold. For
177example, to use a context of 8 lines: >
178 :set diffopt=filler,context:8
179The default context is six lines.
180
181When 'scrollbind' is also set, Vim will attempt to keep the same folds open in
182other diff windows, so that the same text is visible.
183
184
185MARKER *fold-marker*
186
187Markers in the text tell where folds start and end. This allows you to
188precisely specify the folds. This will allow deleting and putting a fold,
189without the risk of including the wrong lines. The 'foldtext' option is
190normally set such that the text before the marker shows up in the folded line.
191This makes it possible to give a name to the fold.
192
193Markers can have a level included, or can use matching pairs. Including a
194level is easier, you don't have to add end markers and avoid problems with
195non-matching marker pairs. Example: >
196 /* global variables {{{1 */
197 int varA, varB;
198
199 /* functions {{{1 */
200 /* funcA() {{{2 */
201 void funcA() {}
202
203 /* funcB() {{{2 */
204 void funcB() {}
205
206A fold starts at a "{{{" marker. The following number specifies the fold
207level. What happens depends on the difference between the current fold level
208and the level given by the marker:
2091. If a marker with the same fold level is encountered, the previous fold
210 ends and another fold with the same level starts.
2112. If a marker with a higher fold level is found, a nested fold is started.
Bram Moolenaar3c2881d2017-03-21 19:18:29 +01002123. If a marker with a lower fold level is found, all folds up to and including
Bram Moolenaar071d4272004-06-13 20:20:40 +0000213 this level end and a fold with the specified level starts.
214
Bram Moolenaar009b2592004-10-24 19:18:58 +0000215The number indicates the fold level. A zero cannot be used (a marker with
216level zero is ignored). You can use "}}}" with a digit to indicate the level
217of the fold that ends. The fold level of the following line will be one less
218than the indicated level. Note that Vim doesn't look back to the level of the
219matching marker (that would take too much time). Example: >
Bram Moolenaar071d4272004-06-13 20:20:40 +0000220
221 {{{1
222 fold level here is 1
223 {{{3
224 fold level here is 3
225 }}}3
226 fold level here is 2
227
228You can also use matching pairs of "{{{" and "}}}" markers to define folds.
229Each "{{{" increases the fold level by one, each "}}}" decreases the fold
230level by one. Be careful to keep the markers matching! Example: >
231
232 {{{
233 fold level here is 1
234 {{{
235 fold level here is 2
236 }}}
237 fold level here is 1
238
239You can mix using markers with a number and without a number. A useful way of
240doing this is to use numbered markers for large folds, and unnumbered markers
241locally in a function. For example use level one folds for the sections of
242your file like "structure definitions", "local variables" and "functions".
243Use level 2 markers for each definition and function, Use unnumbered markers
244inside functions. When you make changes in a function to split up folds, you
245don't have to renumber the markers.
246
247The markers can be set with the 'foldmarker' option. It is recommended to
248keep this at the default value of "{{{,}}}", so that files can be exchanged
249between Vim users. Only change it when it is required for the file (e.g., it
250contains markers from another folding editor, or the default markers cause
251trouble for the language of the file).
252
253 *fold-create-marker*
254"zf" can be used to create a fold defined by markers. Vim will insert the
255markers for you. Vim will append the start and end marker, as specified with
256'foldmarker'. The markers are appended to the end of the line.
257'commentstring' is used if it isn't empty.
258This does not work properly when:
259- The line already contains a marker with a level number. Vim then doesn't
260 know what to do.
261- Folds nearby use a level number in their marker which gets in the way.
262- The line is inside a comment, 'commentstring' isn't empty and nested
263 comments don't work. For example with C: adding /* {{{ */ inside a comment
264 will truncate the existing comment. Either put the marker before or after
265 the comment, or add the marker manually.
266Generally it's not a good idea to let Vim create markers when you already have
267markers with a level number.
268
269 *fold-delete-marker*
270"zd" can be used to delete a fold defined by markers. Vim will delete the
271markers for you. Vim will search for the start and end markers, as specified
272with 'foldmarker', at the start and end of the fold. When the text around the
273marker matches with 'commentstring', that text is deleted as well.
274This does not work properly when:
275- A line contains more than one marker and one of them specifies a level.
276 Only the first one is removed, without checking if this will have the
277 desired effect of deleting the fold.
278- The marker contains a level number and is used to start or end several folds
279 at the same time.
280
281==============================================================================
2822. Fold commands *fold-commands* *E490*
283
284All folding commands start with "z". Hint: the "z" looks like a folded piece
285of paper, if you look at it from the side.
286
287
288CREATING AND DELETING FOLDS ~
289 *zf* *E350*
290zf{motion} or
291{Visual}zf Operator to create a fold.
292 This only works when 'foldmethod' is "manual" or "marker".
293 The new fold will be closed for the "manual" method.
294 'foldenable' will be set.
295 Also see |fold-create-marker|.
296
297 *zF*
Bram Moolenaar5e3dae82010-03-02 16:19:40 +0100298zF Create a fold for [count] lines. Works like "zf".
Bram Moolenaar071d4272004-06-13 20:20:40 +0000299
300:{range}fo[ld] *:fold* *:fo*
301 Create a fold for the lines in {range}. Works like "zf".
302
303 *zd* *E351*
Bram Moolenaar81695252004-12-29 20:58:21 +0000304zd Delete one fold at the cursor. When the cursor is on a folded
Bram Moolenaar071d4272004-06-13 20:20:40 +0000305 line, that fold is deleted. Nested folds are moved one level
Bram Moolenaardfb18412013-12-11 18:53:29 +0100306 up. In Visual mode one level of all folds (partially) in the
307 selected area are deleted.
308 Careful: This easily deletes more folds than you expect and
309 there is no undo for manual folding.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000310 This only works when 'foldmethod' is "manual" or "marker".
311 Also see |fold-delete-marker|.
312
313 *zD*
314zD Delete folds recursively at the cursor. In Visual mode all
315 folds (partially) in the selected area and all nested folds in
316 them are deleted.
317 This only works when 'foldmethod' is "manual" or "marker".
318 Also see |fold-delete-marker|.
319
320 *zE* *E352*
321zE Eliminate all folds in the window.
322 This only works when 'foldmethod' is "manual" or "marker".
323 Also see |fold-delete-marker|.
324
325
326OPENING AND CLOSING FOLDS ~
327
328A fold smaller than 'foldminlines' will always be displayed like it was open.
329Therefore the commands below may work differently on small folds.
330
331 *zo*
332zo Open one fold under the cursor. When a count is given, that
333 many folds deep will be opened. In Visual mode one level of
334 folds is opened for all lines in the selected area.
335
336 *zO*
337zO Open all folds under the cursor recursively. Folds that don't
338 contain the cursor line are unchanged.
339 In Visual mode it opens all folds that are in the selected
340 area, also those that are only partly selected.
341
342 *zc*
343zc Close one fold under the cursor. When a count is given, that
344 many folds deep are closed. In Visual mode one level of folds
345 is closed for all lines in the selected area.
346 'foldenable' will be set.
347
348 *zC*
349zC Close all folds under the cursor recursively. Folds that
350 don't contain the cursor line are unchanged.
351 In Visual mode it closes all folds that are in the selected
352 area, also those that are only partly selected.
353 'foldenable' will be set.
354
355 *za*
Bram Moolenaar402d2fe2005-04-15 21:00:38 +0000356za When on a closed fold: open it. When folds are nested, you
Bram Moolenaar071d4272004-06-13 20:20:40 +0000357 may have to use "za" several times. When a count is given,
358 that many closed folds are opened.
359 When on an open fold: close it and set 'foldenable'. This
360 will only close one level, since using "za" again will open
361 the fold. When a count is given that many folds will be
362 closed (that's not the same as repeating "za" that many
363 times).
364
365 *zA*
366zA When on a closed fold: open it recursively.
367 When on an open fold: close it recursively and set
368 'foldenable'.
369
370 *zv*
371zv View cursor line: Open just enough folds to make the line in
372 which the cursor is located not folded.
373
374 *zx*
375zx Update folds: Undo manually opened and closed folds: re-apply
376 'foldlevel', then do "zv": View cursor line.
Bram Moolenaar00a927d2010-05-14 23:24:24 +0200377 Also forces recomputing folds. This is useful when using
378 'foldexpr' and the buffer is changed in a way that results in
379 folds not to be updated properly.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000380
381 *zX*
382zX Undo manually opened and closed folds: re-apply 'foldlevel'.
Bram Moolenaar00a927d2010-05-14 23:24:24 +0200383 Also forces recomputing folds, like |zx|.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000384
385 *zm*
Bram Moolenaar7d2757a2015-03-31 17:46:22 +0200386zm Fold more: Subtract |v:count1| from 'foldlevel'. If 'foldlevel' was
Bram Moolenaar071d4272004-06-13 20:20:40 +0000387 already zero nothing happens.
388 'foldenable' will be set.
389
390 *zM*
391zM Close all folds: set 'foldlevel' to 0.
392 'foldenable' will be set.
393
394 *zr*
Bram Moolenaar7d2757a2015-03-31 17:46:22 +0200395zr Reduce folding: Add |v:count1| to 'foldlevel'.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000396
397 *zR*
398zR Open all folds. This sets 'foldlevel' to highest fold level.
399
400 *:foldo* *:foldopen*
401:{range}foldo[pen][!]
402 Open folds in {range}. When [!] is added all folds are
403 opened. Useful to see all the text in {range}. Without [!]
404 one level of folds is opened.
405
406 *:foldc* *:foldclose*
407:{range}foldc[lose][!]
408 Close folds in {range}. When [!] is added all folds are
409 closed. Useful to hide all the text in {range}. Without [!]
410 one level of folds is closed.
411
412 *zn*
413zn Fold none: reset 'foldenable'. All folds will be open.
414
415 *zN*
416zN Fold normal: set 'foldenable'. All folds will be as they
417 were before.
418
419 *zi*
420zi Invert 'foldenable'.
421
422
423MOVING OVER FOLDS ~
424 *[z*
425[z Move to the start of the current open fold. If already at the
426 start, move to the start of the fold that contains it. If
427 there is no containing fold, the command fails.
Bram Moolenaar5e3dae82010-03-02 16:19:40 +0100428 When a count is used, repeats the command [count] times.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000429
430 *]z*
431]z Move to the end of the current open fold. If already at the
432 end, move to the end of the fold that contains it. If there
433 is no containing fold, the command fails.
Bram Moolenaar5e3dae82010-03-02 16:19:40 +0100434 When a count is used, repeats the command [count] times.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000435
436 *zj*
437zj Move downwards to the start of the next fold. A closed fold
438 is counted as one fold.
Bram Moolenaar5e3dae82010-03-02 16:19:40 +0100439 When a count is used, repeats the command [count] times.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000440 This command can be used after an |operator|.
441
442 *zk*
443zk Move upwards to the end of the previous fold. A closed fold
444 is counted as one fold.
Bram Moolenaar5e3dae82010-03-02 16:19:40 +0100445 When a count is used, repeats the command [count] times.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000446 This command can be used after an |operator|.
447
448
449EXECUTING COMMANDS ON FOLDS ~
450
Bram Moolenaar61da1bf2019-06-06 12:14:49 +0200451:[range]foldd[oopen] {cmd} *:foldd* *:folddo* *:folddoopen*
Bram Moolenaar071d4272004-06-13 20:20:40 +0000452 Execute {cmd} on all lines that are not in a closed fold.
453 When [range] is given, only these lines are used.
454 Each time {cmd} is executed the cursor is positioned on the
455 line it is executed for.
456 This works like the ":global" command: First all lines that
457 are not in a closed fold are marked. Then the {cmd} is
458 executed for all marked lines. Thus when {cmd} changes the
459 folds, this has no influence on where it is executed (except
460 when lines are deleted, of course).
461 Example: >
462 :folddoopen s/end/loop_end/ge
463< Note the use of the "e" flag to avoid getting an error message
464 where "end" doesn't match.
465
466:[range]folddoc[losed] {cmd} *:folddoc* *:folddoclosed*
467 Execute {cmd} on all lines that are in a closed fold.
468 Otherwise like ":folddoopen".
469
470==============================================================================
4713. Fold options *fold-options*
472
473COLORS *fold-colors*
474
475The colors of a closed fold are set with the Folded group |hl-Folded|. The
476colors of the fold column are set with the FoldColumn group |hl-FoldColumn|.
477Example to set the colors: >
478
479 :highlight Folded guibg=grey guifg=blue
480 :highlight FoldColumn guibg=darkgrey guifg=white
481
482
483FOLDLEVEL *fold-foldlevel*
484
485'foldlevel' is a number option: The higher the more folded regions are open.
486When 'foldlevel' is 0, all folds are closed.
Bram Moolenaar81695252004-12-29 20:58:21 +0000487When 'foldlevel' is positive, some folds are closed.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000488When 'foldlevel' is very high, all folds are open.
489'foldlevel' is applied when it is changed. After that manually folds can be
490opened and closed.
491When increased, folds above the new level are opened. No manually opened
492folds will be closed.
493When decreased, folds above the new level are closed. No manually closed
494folds will be opened.
495
496
497FOLDTEXT *fold-foldtext*
498
499'foldtext' is a string option that specifies an expression. This expression
500is evaluated to obtain the text displayed for a closed fold. Example: >
501
502 :set foldtext=v:folddashes.substitute(getline(v:foldstart),'/\\*\\\|\\*/\\\|{{{\\d\\=','','g')
503
504This shows the first line of the fold, with "/*", "*/" and "{{{" removed.
505Note the use of backslashes to avoid some characters to be interpreted by the
506":set" command. It's simpler to define a function and call that: >
507
508 :set foldtext=MyFoldText()
509 :function MyFoldText()
510 : let line = getline(v:foldstart)
511 : let sub = substitute(line, '/\*\|\*/\|{{{\d\=', '', 'g')
Bram Moolenaarc51cf032022-02-26 12:25:45 +0000512 : return v:folddashes .. sub
Bram Moolenaar071d4272004-06-13 20:20:40 +0000513 :endfunction
514
515Evaluating 'foldtext' is done in the |sandbox|. The current window is set to
Bram Moolenaar6f4754b2022-01-23 12:07:04 +0000516the window that displays the line. The context is set to the script where the
517option was last set.
518
519Errors are ignored. For debugging set the 'debug' option to "throw".
Bram Moolenaar071d4272004-06-13 20:20:40 +0000520
521The default value is |foldtext()|. This returns a reasonable text for most
522types of folding. If you don't like it, you can specify your own 'foldtext'
523expression. It can use these special Vim variables:
524 v:foldstart line number of first line in the fold
525 v:foldend line number of last line in the fold
526 v:folddashes a string that contains dashes to represent the
527 foldlevel.
528 v:foldlevel the foldlevel of the fold
529
530In the result a TAB is replaced with a space and unprintable characters are
531made into printable characters.
532
533The resulting line is truncated to fit in the window, it never wraps.
534When there is room after the text, it is filled with the character specified
535by 'fillchars'.
536
Yegappan Lakshmanan27708e62021-12-26 21:54:43 +0000537If the 'foldtext' expression starts with s: or |<SID>|, then it is replaced
538with the script ID (|local-function|). Examples: >
539 set foldtext=s:MyFoldText()
540 set foldtext=<SID>SomeFoldText()
541<
Bram Moolenaar071d4272004-06-13 20:20:40 +0000542Note that backslashes need to be used for characters that the ":set" command
543handles differently: Space, backslash and double-quote. |option-backslash|
544
545
546FOLDCOLUMN *fold-foldcolumn*
547
548'foldcolumn' is a number, which sets the width for a column on the side of the
549window to indicate folds. When it is zero, there is no foldcolumn. A normal
Bram Moolenaar578b49e2005-09-10 19:22:57 +0000550value is 4 or 5. The minimal useful value is 2, although 1 still provides
551some information. The maximum is 12.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000552
553An open fold is indicated with a column that has a '-' at the top and '|'
554characters below it. This column stops where the open fold stops. When folds
555nest, the nested fold is one character right of the fold it's contained in.
556
557A closed fold is indicated with a '+'.
558
Bram Moolenaar53f7fcc2021-07-28 20:10:16 +0200559These characters can be changed with the 'fillchars' option.
560
Bram Moolenaar071d4272004-06-13 20:20:40 +0000561Where the fold column is too narrow to display all nested folds, digits are
562shown to indicate the nesting level.
563
564The mouse can also be used to open and close folds by clicking in the
565fold column:
566- Click on a '+' to open the closed fold at this row.
567- Click on any other non-blank character to close the open fold at this row.
568
569
570OTHER OPTIONS
571
572'foldenable' 'fen': Open all folds while not set.
573'foldexpr' 'fde': Expression used for "expr" folding.
574'foldignore' 'fdi': Characters used for "indent" folding.
575'foldmarker' 'fmr': Defined markers used for "marker" folding.
576'foldmethod' 'fdm': Name of the current folding method.
577'foldminlines' 'fml': Minimum number of screen lines for a fold to be
578 displayed closed.
579'foldnestmax' 'fdn': Maximum nesting for "indent" and "syntax" folding.
580'foldopen' 'fdo': Which kinds of commands open closed folds.
581'foldclose' 'fcl': When the folds not under the cursor are closed.
582
583==============================================================================
5844. Behavior of folds *fold-behavior*
585
586When moving the cursor upwards or downwards and when scrolling, the cursor
587will move to the first line of a sequence of folded lines. When the cursor is
588already on a folded line, it moves to the next unfolded line or the next
589closed fold.
590
591While the cursor is on folded lines, the cursor is always displayed in the
592first column. The ruler does show the actual cursor position, but since the
593line is folded, it cannot be displayed there.
594
595Many movement commands handle a sequence of folded lines like an empty line.
596For example, the "w" command stops once in the first column.
597
598When in Insert mode, the cursor line is never folded. That allows you to see
599what you type!
600
601When using an operator, a closed fold is included as a whole. Thus "dl"
602deletes the whole closed fold under the cursor.
603
Bram Moolenaara3306952016-01-02 21:41:06 +0100604For Ex commands that work on buffer lines the range is adjusted to always
605start at the first line of a closed fold and end at the last line of a closed
606fold. Thus this command: >
Bram Moolenaar071d4272004-06-13 20:20:40 +0000607 :s/foo/bar/g
608when used with the cursor on a closed fold, will replace "foo" with "bar" in
609all lines of the fold.
610This does not happen for |:folddoopen| and |:folddoclosed|.
611
612When editing a buffer that has been edited before, the last used folding
613settings are used again. For manual folding the defined folds are restored.
614For all folding methods the manually opened and closed folds are restored.
615If this buffer has been edited in this window, the values from back then are
616used. Otherwise the values from the window where the buffer was edited last
617are used.
618
619==============================================================================
Bram Moolenaar91f84f62018-07-29 15:07:52 +0200620 vim:tw=78:ts=8:noet:ft=help:norl: