blob: 38b36dde17dd7d5fb87a2ae71fab24b7e1a0e728 [file] [log] [blame]
Bram Moolenaareab6dff2020-03-01 19:06:45 +01001*usr_03.txt* For Vim version 8.2. Last change: 2020 Feb 29
Bram Moolenaar071d4272004-06-13 20:20:40 +00002
3 VIM USER MANUAL - by Bram Moolenaar
4
5 Moving around
6
7
8Before you can insert or delete text the cursor has to be moved to the right
9place. Vim has a large number of commands to position the cursor. This
10chapter shows you how to use the most important ones. You can find a list of
11these commands below |Q_lr|.
12
13|03.1| Word movement
14|03.2| Moving to the start or end of a line
15|03.3| Moving to a character
Bram Moolenaar4399ef42005-02-12 14:29:27 +000016|03.4| Matching a parenthesis
Bram Moolenaar071d4272004-06-13 20:20:40 +000017|03.5| Moving to a specific line
18|03.6| Telling where you are
19|03.7| Scrolling around
20|03.8| Simple searches
21|03.9| Simple search patterns
22|03.10| Using marks
23
24 Next chapter: |usr_04.txt| Making small changes
25 Previous chapter: |usr_02.txt| The first steps in Vim
26Table of contents: |usr_toc.txt|
27
28==============================================================================
29*03.1* Word movement
30
31To move the cursor forward one word, use the "w" command. Like most Vim
32commands, you can use a numeric prefix to move past multiple words. For
33example, "3w" moves three words. This figure shows how it works:
34
35 This is a line with example text ~
36 --->-->->----------------->
37 w w w 3w
38
39Notice that "w" moves to the start of the next word if it already is at the
40start of a word.
41 The "b" command moves backward to the start of the previous word:
42
43 This is a line with example text ~
44 <----<--<-<---------<---
45 b b b 2b b
46
47There is also the "e" command that moves to the next end of a word and "ge",
48which moves to the previous end of a word:
49
50 This is a line with example text ~
51 <- <--- -----> ---->
52 ge ge e e
53
54If you are at the last word of a line, the "w" command will take you to the
55first word in the next line. Thus you can use this to move through a
56paragraph, much faster than using "l". "b" does the same in the other
57direction.
58
59A word ends at a non-word character, such as a ".", "-" or ")". To change
Bram Moolenaar256972a2015-12-29 19:10:25 +010060what Vim considers to be a word, see the 'iskeyword' option. If you try this
61out in the help directly, 'iskeyword' needs to be reset for the examples to
62work: >
63 :set iskeyword&
64It is also possible to move by white-space separated WORDs. This is not a
Bram Moolenaar071d4272004-06-13 20:20:40 +000065word in the normal sense, that's why the uppercase is used. The commands for
66moving by WORDs are also uppercase, as this figure shows:
67
68 ge b w e
69 <- <- ---> --->
70 This is-a line, with special/separated/words (and some more). ~
71 <----- <----- --------------------> ----->
72 gE B W E
73
74With this mix of lowercase and uppercase commands, you can quickly move
75forward and backward through a paragraph.
76
77==============================================================================
78*03.2* Moving to the start or end of a line
79
80The "$" command moves the cursor to the end of a line. If your keyboard has
81an <End> key it will do the same thing.
82
83The "^" command moves to the first non-blank character of the line. The "0"
Bram Moolenaar0c0734d2019-11-26 21:44:46 +010084command (zero) moves to the very first character of the line, and the <Home>
85key does the same thing. In a picture:
Bram Moolenaar071d4272004-06-13 20:20:40 +000086
87 ^
88 <------------
89 .....This is a line with example text ~
90 <----------------- --------------->
91 0 $
92
93(the "....." indicates blanks here)
94
95 The "$" command takes a count, like most movement commands. But moving to
96the end of the line several times doesn't make sense. Therefore it causes the
97editor to move to the end of another line. For example, "1$" moves you to
98the end of the first line (the one you're on), "2$" to the end of the next
99line, and so on.
100 The "0" command doesn't take a count argument, because the "0" would be
101part of the count. Unexpectedly, using a count with "^" doesn't have any
102effect.
103
104==============================================================================
105*03.3* Moving to a character
106
107One of the most useful movement commands is the single-character search
108command. The command "fx" searches forward in the line for the single
109character x. Hint: "f" stands for "Find".
110 For example, you are at the beginning of the following line. Suppose you
111want to go to the h of human. Just execute the command "fh" and the cursor
112will be positioned over the h:
113
114 To err is human. To really foul up you need a computer. ~
115 ---------->--------------->
116 fh fy
117
118This also shows that the command "fy" moves to the end of the word really.
119 You can specify a count; therefore, you can go to the "l" of "foul" with
120"3fl":
121
122 To err is human. To really foul up you need a computer. ~
123 --------------------->
124 3fl
125
126The "F" command searches to the left:
127
128 To err is human. To really foul up you need a computer. ~
129 <---------------------
130 Fh
131
132The "tx" command works like the "fx" command, except it stops one character
133before the searched character. Hint: "t" stands for "To". The backward
134version of this command is "Tx".
135
136 To err is human. To really foul up you need a computer. ~
137 <------------ ------------->
138 Th tn
139
140These four commands can be repeated with ";". "," repeats in the other
141direction. The cursor is never moved to another line. Not even when the
142sentence continues.
143
144Sometimes you will start a search, only to realize that you have typed the
145wrong command. You type "f" to search backward, for example, only to realize
146that you really meant "F". To abort a search, press <Esc>. So "f<Esc>" is an
147aborted forward search and doesn't do anything. Note: <Esc> cancels most
148operations, not just searches.
149
150==============================================================================
Bram Moolenaar4399ef42005-02-12 14:29:27 +0000151*03.4* Matching a parenthesis
Bram Moolenaar071d4272004-06-13 20:20:40 +0000152
153When writing a program you often end up with nested () constructs. Then the
154"%" command is very handy: It moves to the matching paren. If the cursor is
155on a "(" it will move to the matching ")". If it's on a ")" it will move to
156the matching "(".
157
158 %
159 <----->
160 if (a == (b * c) / d) ~
161 <---------------->
162 %
163
164This also works for [] and {} pairs. (This can be defined with the
165'matchpairs' option.)
166
167When the cursor is not on a useful character, "%" will search forward to find
168one. Thus if the cursor is at the start of the line of the previous example,
169"%" will search forward and find the first "(". Then it moves to its match:
170
171 if (a == (b * c) / d) ~
172 ---+---------------->
173 %
174
175==============================================================================
176*03.5* Moving to a specific line
177
178If you are a C or C++ programmer, you are familiar with error messages such as
179the following:
180
181 prog.c:33: j undeclared (first use in this function) ~
182
183This tells you that you might want to fix something on line 33. So how do you
184find line 33? One way is to do "9999k" to go to the top of the file and "32j"
Bram Moolenaar3df01732017-02-17 22:47:16 +0100185to go down thirty-two lines. It is not a good way, but it works. A much
Bram Moolenaar071d4272004-06-13 20:20:40 +0000186better way of doing things is to use the "G" command. With a count, this
187command positions you at the given line number. For example, "33G" puts you
188on line 33. (For a better way of going through a compiler's error list, see
189|usr_30.txt|, for information on the :make command.)
190 With no argument, "G" positions you at the end of the file. A quick way to
191go to the start of a file use "gg". "1G" will do the same, but is a tiny bit
192more typing.
193
194 | first line of a file ^
195 | text text text text |
196 | text text text text | gg
197 7G | text text text text |
198 | text text text text
199 | text text text text
200 V text text text text |
201 text text text text | G
202 text text text text |
203 last line of a file V
204
205Another way to move to a line is using the "%" command with a count. For
206example "50%" moves you to halfway the file. "90%" goes to near the end.
207
208The previous assumes that you want to move to a line in the file, no matter if
209it's currently visible or not. What if you want to move to one of the lines
210you can see? This figure shows the three commands you can use:
211
212 +---------------------------+
213 H --> | text sample text |
214 | sample text |
215 | text sample text |
216 | sample text |
217 M --> | text sample text |
218 | sample text |
219 | text sample text |
220 | sample text |
221 L --> | text sample text |
222 +---------------------------+
223
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100224Hints: "H" stands for Home, "M" for Middle and "L" for Last. Alternatively,
225"H" for high, "M" for Middle and "L" for low.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000226
227==============================================================================
228*03.6* Telling where you are
229
230To see where you are in a file, there are three ways:
231
2321. Use the CTRL-G command. You get a message like this (assuming the 'ruler'
233 option is off):
234
235 "usr_03.txt" line 233 of 650 --35%-- col 45-52 ~
236
237 This shows the name of the file you are editing, the line number where the
238 cursor is, the total number of lines, the percentage of the way through
239 the file and the column of the cursor.
240 Sometimes you will see a split column number. For example, "col 2-9".
241 This indicates that the cursor is positioned on the second character, but
242 because character one is a tab, occupying eight spaces worth of columns,
243 the screen column is 9.
244
2452. Set the 'number' option. This will display a line number in front of
246 every line: >
247
248 :set number
249<
250 To switch this off again: >
251
252 :set nonumber
253<
254 Since 'number' is a boolean option, prepending "no" to its name has the
255 effect of switching it off. A boolean option has only these two values,
256 it is either on or off.
257 Vim has many options. Besides the boolean ones there are options with
258 a numerical value and string options. You will see examples of this where
259 they are used.
260
2613. Set the 'ruler' option. This will display the cursor position in the
262 lower right corner of the Vim window: >
263
264 :set ruler
265
266Using the 'ruler' option has the advantage that it doesn't take much room,
267thus there is more space for your text.
268
269==============================================================================
270*03.7* Scrolling around
271
272The CTRL-U command scrolls down half a screen of text. Think of looking
273through a viewing window at the text and moving this window up by half the
274height of the window. Thus the window moves up over the text, which is
275backward in the file. Don't worry if you have a little trouble remembering
276which end is up. Most users have the same problem.
277 The CTRL-D command moves the viewing window down half a screen in the file,
278thus scrolls the text up half a screen.
279
280 +----------------+
281 | some text |
282 | some text |
283 | some text |
284 +---------------+ | some text |
285 | some text | CTRL-U --> | |
286 | | | 123456 |
287 | 123456 | +----------------+
288 | 7890 |
289 | | +----------------+
290 | example | CTRL-D --> | 7890 |
291 +---------------+ | |
292 | example |
293 | example |
294 | example |
295 | example |
296 +----------------+
297
298To scroll one line at a time use CTRL-E (scroll up) and CTRL-Y (scroll down).
299Think of CTRL-E to give you one line Extra. (If you use MS-Windows compatible
300key mappings CTRL-Y will redo a change instead of scroll.)
301
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100302To scroll forward by a whole screen (except for two lines) use CTRL-F. To
303scroll backwards, use CTRL-B. These should be easy to remember: F for
304Forwards and B for Backwards.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000305
306A common issue is that after moving down many lines with "j" your cursor is at
307the bottom of the screen. You would like to see the context of the line with
308the cursor. That's done with the "zz" command.
309
310 +------------------+ +------------------+
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100311 | earlier text | | earlier text |
312 | earlier text | | earlier text |
313 | earlier text | | earlier text |
314 | earlier text | zz --> | line with cursor |
315 | earlier text | | later text |
316 | earlier text | | later text |
317 | line with cursor | | later text |
Bram Moolenaar071d4272004-06-13 20:20:40 +0000318 +------------------+ +------------------+
319
320The "zt" command puts the cursor line at the top, "zb" at the bottom. There
321are a few more scrolling commands, see |Q_sc|. To always keep a few lines of
322context around the cursor, use the 'scrolloff' option.
323
324==============================================================================
325*03.8* Simple searches
326
327To search for a string, use the "/string" command. To find the word include,
328for example, use the command: >
329
330 /include
331
332You will notice that when you type the "/" the cursor jumps to the last line
333of the Vim window, like with colon commands. That is where you type the word.
334You can press the backspace key (backarrow or <BS>) to make corrections. Use
335the <Left> and <Right> cursor keys when necessary.
336 Pressing <Enter> executes the command.
337
338 Note:
Bram Moolenaar402d2fe2005-04-15 21:00:38 +0000339 The characters .*[]^%/\?~$ have special meanings. If you want to use
Bram Moolenaar071d4272004-06-13 20:20:40 +0000340 them in a search you must put a \ in front of them. See below.
341
342To find the next occurrence of the same string use the "n" command. Use this
343to find the first #include after the cursor: >
344
345 /#include
346
347And then type "n" several times. You will move to each #include in the text.
348You can also use a count if you know which match you want. Thus "3n" finds
Bram Moolenaareab6dff2020-03-01 19:06:45 +0100349the third match. You can also use a count with "/": "4/the" goes to the
350fourth match of "the".
Bram Moolenaar071d4272004-06-13 20:20:40 +0000351
352The "?" command works like "/" but searches backwards: >
353
354 ?word
355
356The "N" command repeats the last search the opposite direction. Thus using
Bram Moolenaarb6e0ec62017-07-23 22:12:20 +0200357"N" after a "/" command searches backwards, using "N" after "?" searches
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100358forwards.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000359
360
361IGNORING CASE
362
363Normally you have to type exactly what you want to find. If you don't care
364about upper or lowercase in a word, set the 'ignorecase' option: >
365
366 :set ignorecase
367
368If you now search for "word", it will also match "Word" and "WORD". To match
369case again: >
370
371 :set noignorecase
372
373
374HISTORY
375
376Suppose you do three searches: >
377
378 /one
379 /two
380 /three
381
382Now let's start searching by typing a simple "/" without pressing <Enter>. If
383you press <Up> (the cursor key), Vim puts "/three" on the command line.
384Pressing <Enter> at this point searches for three. If you do not press
385<Enter>, but press <Up> instead, Vim changes the prompt to "/two". Another
386press of <Up> moves you to "/one".
387 You can also use the <Down> cursor key to move through the history of
388search commands in the other direction.
389
390If you know what a previously used pattern starts with, and you want to use it
391again, type that character before pressing <Up>. With the previous example,
392you can type "/o<Up>" and Vim will put "/one" on the command line.
393
394The commands starting with ":" also have a history. That allows you to recall
395a previous command and execute it again. These two histories are separate.
396
397
398SEARCHING FOR A WORD IN THE TEXT
399
400Suppose you see the word "TheLongFunctionName" in the text and you want to
401find the next occurrence of it. You could type "/TheLongFunctionName", but
402that's a lot of typing. And when you make a mistake Vim won't find it.
403 There is an easier way: Position the cursor on the word and use the "*"
404command. Vim will grab the word under the cursor and use it as the search
405string.
406 The "#" command does the same in the other direction. You can prepend a
407count: "3*" searches for the third occurrence of the word under the cursor.
408
409
410SEARCHING FOR WHOLE WORDS
411
412If you type "/the" it will also match "there". To only find words that end
413in "the" use: >
414
415 /the\>
416
417The "\>" item is a special marker that only matches at the end of a word.
Bram Moolenaaracb4f222016-01-10 15:59:26 +0100418Similarly "\<" only matches at the beginning of a word. Thus to search for
419the word "the" only: >
Bram Moolenaar071d4272004-06-13 20:20:40 +0000420
421 /\<the\>
422
423This does not match "there" or "soothe". Notice that the "*" and "#" commands
424use these start-of-word and end-of-word markers to only find whole words (you
425can use "g*" and "g#" to match partial words).
426
427
428HIGHLIGHTING MATCHES
429
430While editing a program you see a variable called "nr". You want to check
431where it's used. You could move the cursor to "nr" and use the "*" command
432and press "n" to go along all the matches.
433 There is another way. Type this command: >
434
435 :set hlsearch
436
437If you now search for "nr", Vim will highlight all matches. That is a very
438good way to see where the variable is used, without the need to type commands.
439 To switch this off: >
440
441 :set nohlsearch
442
443Then you need to switch it on again if you want to use it for the next search
444command. If you only want to remove the highlighting, use this command: >
445
446 :nohlsearch
447
448This doesn't reset the option. Instead, it disables the highlighting. As
449soon as you execute a search command, the highlighting will be used again.
450Also for the "n" and "N" commands.
451
452
453TUNING SEARCHES
454
455There are a few options that change how searching works. These are the
456essential ones:
457>
458 :set incsearch
459
460This makes Vim display the match for the string while you are still typing it.
461Use this to check if the right match will be found. Then press <Enter> to
462really jump to that location. Or type more to change the search string.
463>
464 :set nowrapscan
465
466This stops the search at the end of the file. Or, when you are searching
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100467backwards, it stops the search at the start of the file. The 'wrapscan'
468option is on by default, thus searching wraps around the end of the file.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000469
470
471INTERMEZZO
472
473If you like one of the options mentioned before, and set it each time you use
474Vim, you can put the command in your Vim startup file.
475 Edit the file, as mentioned at |not-compatible|. Or use this command to
476find out where it is: >
477
478 :scriptnames
479
480Edit the file, for example with: >
481
482 :edit ~/.vimrc
483
484Then add a line with the command to set the option, just like you typed it in
485Vim. Example: >
486
487 Go:set hlsearch<Esc>
488
489"G" moves to the end of the file. "o" starts a new line, where you type the
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100490":set" command. You end insert mode with <Esc>. Then write and close the
491file: >
Bram Moolenaar071d4272004-06-13 20:20:40 +0000492
493 ZZ
494
495If you now start Vim again, the 'hlsearch' option will already be set.
496
497==============================================================================
498*03.9* Simple search patterns
499
500The Vim editor uses regular expressions to specify what to search for.
501Regular expressions are an extremely powerful and compact way to specify a
502search pattern. Unfortunately, this power comes at a price, because regular
503expressions are a bit tricky to specify.
504 In this section we mention only a few essential ones. More about search
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100505patterns and commands can be found in chapter 27 |usr_27.txt|. You can find
506the full explanation here: |pattern|.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000507
508
509BEGINNING AND END OF A LINE
510
511The ^ character matches the beginning of a line. On an English-US keyboard
512you find it above the 6. The pattern "include" matches the word include
513anywhere on the line. But the pattern "^include" matches the word include
514only if it is at the beginning of a line.
515 The $ character matches the end of a line. Therefore, "was$" matches the
516word was only if it is at the end of a line.
517
Bram Moolenaarb6e0ec62017-07-23 22:12:20 +0200518Let's mark the places where "/the" matches in this example line with "x"s:
Bram Moolenaar071d4272004-06-13 20:20:40 +0000519
520 the solder holding one of the chips melted and the ~
521 xxx xxx xxx
522
523Using "/the$" we find this match:
524
525 the solder holding one of the chips melted and the ~
526 xxx
527
528And with "/^the" we find this one:
529 the solder holding one of the chips melted and the ~
530 xxx
531
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100532You can try searching with "/^the$"; it will only match a single line
533consisting entirely of "the". White space does matter here, thus if a line
534contains a space after the word, like "the ", the pattern will not match.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000535
536
537MATCHING ANY SINGLE CHARACTER
538
539The . (dot) character matches any existing character. For example, the
540pattern "c.m" matches a string whose first character is a c, whose second
Bram Moolenaar8a94d872015-01-25 13:02:57 +0100541character is anything, and whose third character is m. Example:
Bram Moolenaar071d4272004-06-13 20:20:40 +0000542
543 We use a computer that became the cummin winter. ~
544 xxx xxx xxx
545
546
547MATCHING SPECIAL CHARACTERS
548
549If you really want to match a dot, you must avoid its special meaning by
550putting a backslash before it.
551 If you search for "ter.", you will find these matches:
552
553 We use a computer that became the cummin winter. ~
554 xxxx xxxx
555
556Searching for "ter\." only finds the second match.
557
558==============================================================================
559*03.10* Using marks
560
561When you make a jump to a position with the "G" command, Vim remembers the
562position from before this jump. This position is called a mark. To go back
563where you came from, use this command: >
564
565 ``
566
567This ` is a backtick or open single-quote character.
568 If you use the same command a second time you will jump back again. That's
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100569because the "`" command is a jump itself, and the position from before this
570jump is remembered.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000571
572Generally, every time you do a command that can move the cursor further than
573within the same line, this is called a jump. This includes the search
574commands "/" and "n" (it doesn't matter how far away the match is). But not
575the character searches with "fx" and "tx" or the word movements "w" and "e".
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100576 Also, "j" and "k" are not considered to be a jump, even when you use a
Bram Moolenaar071d4272004-06-13 20:20:40 +0000577count to make them move the cursor quite a long way away.
578
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100579The "``" command jumps back and forth, between two points. The CTRL-O command
Bram Moolenaar071d4272004-06-13 20:20:40 +0000580jumps to older positions (Hint: O for older). CTRL-I then jumps back to newer
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100581positions (Hint: for many common keyboard layouts, I is just next to O).
582Consider this sequence of commands: >
Bram Moolenaar071d4272004-06-13 20:20:40 +0000583
584 33G
585 /^The
586 CTRL-O
587
588You first jump to line 33, then search for a line that starts with "The".
589Then with CTRL-O you jump back to line 33. Another CTRL-O takes you back to
590where you started. If you now use CTRL-I you jump to line 33 again. And
591to the match for "The" with another CTRL-I.
592
593
594 | example text ^ |
595 33G | example text | CTRL-O | CTRL-I
596 | example text | |
597 V line 33 text ^ V
598 | example text | |
599 /^The | example text | CTRL-O | CTRL-I
600 V There you are | V
601 example text
602
603 Note:
604 CTRL-I is the same as <Tab>.
605
606The ":jumps" command gives a list of positions you jumped to. The entry which
607you used last is marked with a ">".
608
609
Bram Moolenaar8fef2ad2005-04-23 20:42:23 +0000610NAMED MARKS *bookmark*
Bram Moolenaar071d4272004-06-13 20:20:40 +0000611
612Vim enables you to place your own marks in the text. The command "ma" marks
613the place under the cursor as mark a. You can place 26 marks (a through z) in
614your text. You can't see them, it's just a position that Vim remembers.
Bram Moolenaar9964e462007-05-05 17:54:07 +0000615 To go to a mark, use the command `{mark}, where {mark} is the mark letter.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000616Thus to move to the a mark:
617>
618 `a
619
Bram Moolenaar0c0734d2019-11-26 21:44:46 +0100620The command "'mark" (single quotation mark, or apostrophe) moves you to the
621beginning of the line containing the mark. This differs from the "`mark"
622command, which also moves you to the marked column.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000623
624The marks can be very useful when working on two related parts in a file.
625Suppose you have some text near the start of the file you need to look at,
626while working on some text near the end of the file.
627 Move to the text at the start and place the s (start) mark there: >
628
629 ms
630
Bram Moolenaar9964e462007-05-05 17:54:07 +0000631Then move to the text you want to work on and put the e (end) mark there: >
Bram Moolenaar071d4272004-06-13 20:20:40 +0000632
633 me
634
635Now you can move around, and when you want to look at the start of the file,
636you use this to jump there: >
637
638 's
639
640Then you can use '' to jump back to where you were, or 'e to jump to the text
641you were working on at the end.
642 There is nothing special about using s for start and e for end, they are
643just easy to remember.
644
645You can use this command to get a list of marks: >
646
647 :marks
648
649You will notice a few special marks. These include:
650
651 ' The cursor position before doing a jump
652 " The cursor position when last editing the file
653 [ Start of the last change
654 ] End of the last change
655
656==============================================================================
657
658Next chapter: |usr_04.txt| Making small changes
659
Bram Moolenaard473c8c2018-08-11 18:00:22 +0200660Copyright: see |manual-copyright| vim:tw=78:ts=8:noet:ft=help:norl: