Xref: utzoo comp.editors:923 comp.text:4882 comp.unix.questions:16151 comp.misc:6905
Path: utzoo!attcan!utgpu!jarvis.csri.toronto.edu!mailrus!hellgate.utah.edu!cs.utexas.edu!uunet!mcsun!hp4nl!botter!star.cs.vu.nl!maart
From: maart@cs.vu.nl (Maarten Litmaath)
Newsgroups: comp.editors,comp.text,comp.unix.questions,comp.misc
Subject: the reformatted Vi Reference (patchlevel 4)
Message-ID: <3144@solo4.cs.vu.nl>
Date: 5 Sep 89 02:23:32 GMT
Organization: V.U. Informatica, Amsterdam, the Netherlands
Lines: 600

Some small fixes, some additions (Diomidis & me), prints nicely (Blair).
No use to post context diffs. :-)
Your OS should have the `tr' (translate) command, else you must edit the
CTRL_L assignment below to use a hard ^L.
Enjoy.

: This is a shar archive.  Extract with sh, not csh.
: This archive ends with exit, so do not worry about trailing junk.
: --------------------------- cut here --------------------------
PATH=/bin:/usr/bin:/usr/ucb
CTRL_L="`echo L | tr L '\14'`"
echo Extracting 'vi.ref.4'
sed -e 's/^X//' \
	-e "s/^Control-L$/$CTRL_L/" > 'vi.ref.4' << '+ END-OF-FILE ''vi.ref.4'
X
X
X
X
X
X    ////////////////////////////////////////////////////////////////////////
X    /                         VI REFERENCE (by maart@cs.vu.nl)             /
X    ////////////////////////////////////////////////////////////////////////
X
X    Warning: some vi versions don't support the more esoteric features
X    described in this document.  You can edit/redistribute this document
X    freely, as long as you don't make false claims on original authorship.
X
X    default values          : 1
X    ^X                      : x
X    [*]                     : * is optional
X    <*>                     : * must not be taken literally
X                        : space
X                        : carriage return
X                        : linefeed
X                        : horizontal tab
X                       : escape
X                     : your erase character
X                      : your kill character
X                      : your interrupt character
X                       : an element in the range
X    N                       : number (* = allowed, - = not used)
X    CHAR                    : char unequal to |
X    WORD                    : word followed by ||
XControl-L
X
X
X
X
X
X    /////////////////
X    / move commands /
X    /////////////////
X
X     N | Command            | Meaning
X    ---+--------------------+-----------------------------------------------
X     * | h | ^H             | <*> chars to the left
X     * | j |  | ^N      | <*> lines downward
X     * | l |            | <*> chars to the right
X     * | k | ^P             | <*> lines upward
X     * | $                  | to the end of line <*> from the cursor
X     - | ^                  | to the first CHAR of the line
X     * | _                  | to the first CHAR <*> - 1 lines lower
X     * | -                  | to the first CHAR <*> lines higher
X     * | + |            | to the first CHAR <*> lines lower
X     - | 0                  | to the first char of the line
X     * | |                  | to column <*> (: only to the endpoint!)
X     * | f            | <*> s to the right (find)
X     * | t            | till before <*> s to the right
X     * | F            | <*> s to the left
X     * | T            | till after <*> s to the left
X     * | ;                  | repeat latest "f"|"t"|"F"|"T" <*> times
X     * | ,                  | idem in opposite direction
X     * | w                  | <*> words forward
X     * | W                  | <*> WORDS forward
X     * | b                  | <*> words backward
X     * | B                  | <*> WORDS backward
X     * | e                  | to the end of word <*> forward
X     * | E                  | to the end of WORD <*> forward
X     * | G                  | go to line <*> (default EOF)
X     * | H                  | to line <*> from top of the screen (home)
X     * | L                  | to line <*> from bottom of the screen (last)
X     - | M                  | to the middle line of the screen
X     * | )                  | <*> sentences forward
X     * | (                  | <*> sentences backward
X     * | }                  | <*> paragraphs forward
X     * | {                  | <*> paragraphs backward
X     - | ]]                 | to the next section (default EOF)
X     - | [[                 | to the previous section (default begin of file)
X     - | `             | to the mark
X     - | '             | to the first CHAR of the line with the mark
X     - | ``                 | to the cursor position before the latest absolute
X                            | jump (of which are examples "/" and "G")
X     - | ''                 | to the first CHAR of the line on which the cursor
X                            | was placed before the latest absolute jump
X     - | /          | to the next occurrence of 
X     - | ?          | to the previous occurrence of 
X     - | n                  | repeat latest "/"|"?" (next)
X     - | N                  | idem in opposite direction
X     - | %                  | find the next bracket and go to its match
X                            | (also { } and [ ])
XControl-L
X
X
X
X
X
X    /////////////////////////
X    / searching (see above) /
X    /////////////////////////
X
X    ^]                      | search in the tags file where the function
X                            | under the cursor is defined (file, line) and
X                            | go to it
X    :[x,y]g//  | search globally [from line x to y] for 
X                            | and execute the "ex"  on each occurrence
X
X    ///////////////////
X    / undoing changes /
X    ///////////////////
X
X    u                       | undo the latest change
X    U                       | undo all changes on a line, while not having
X                            | moved off it (unfortunately)
X    :q!                     | quit vi without writing
X    :e!                     | re-edit a messed-up file
X
X    ///////////////////////////////////
X    / appending text (end with ) /
X    ///////////////////////////////////
X
X     * | a                  | <*> times after the cursor
X     * | A                  | <*> times at the end of line
X     * | i                  | <*> times before the cursor (insert)
X     * | I                  | <*> times before the first CHAR of the line
X     * | o                  | on a new line below the current (open)
X                            | the count is only useful on a slow terminal
X     * | O                  | on a new line above the current
X                            | the count is only useful on a slow terminal
X     * | >            | shift the lines described by <*> one
X                            | shiftwidth to the right (layout)
X     * | >>                 | shift <*> lines one shiftwidth to the right
X     * | ["]p       | put the contents of the (default undo)
X                            | buffer <*> times after the cursor;
X                            | a buffer containing lines is put only once,
X                            | below the current line
X     * | ["]P       | put the contents of the (default undo) buffer <*>
X                            | times before the cursor
X                            | a buffer containing lines is put only once, above
X                            | the current line
X     * | .                  | repeat latest command <*> times
X                            | if the last command before a "." command
X                            | references a numbered buffer, the buffer number
X                            | is incremented first (and the count is ignored):
X                            |
X                            | "1pu.u.u.u.u      - `walk through' buffers 1
X                            |                     through 5
X                            | "1P....           - restore them
XControl-L
X
X
X
X
X
X    /////////////////
X    / deleting text /
X    /////////////////
X
X    Everything deleted can be stored into a buffer. This is achieved by
X    putting a " and a letter  before the delete command. The
X    deleted text will be in the buffer with the used letter. If 
X    is used as buffer name, the adjugate buffer  will be augmented
X    instead of overwritten with the text. The undo buffer always
X    contains the latest change. Buffers "<1-9> contain the latest 9
X    LINE deletions ("1 is most recent).
X
X     * | x                  | delete <*> chars under and after the cursor
X     * | X                  | <*> chars before the cursor
X     * | d            | from begin to endpoint of <*>
X     * | dd                 | <*> lines
X     - | D                  | the rest of the line
X     * | <            | shift the lines described by <*> one
X                            | shiftwidth to the left (layout)
X     * | <<                 | shift <*> lines one shiftwidth to the left
X     * | .                  | repeat latest command <*> times
X
X    //////////////////////////////////
X    / changing text (end with ) /
X    //////////////////////////////////
X
X     * | r            | replace <*> chars by  - no 
X     * | R                  | overwrite the rest of the line,
X                            | appending change <*> - 1 times
X     * | s                  | substitute <*> chars
X     * | S                  | <*> lines
X     * | c            | change from begin to endpoint of <*>
X     * | cc                 | <*> lines
X     * | C                  | the rest of the line and <*> - 1 next lines
X     * | =            | if the option 'lisp' is set, this command
X                            | will realign the lines described by <*>
X                            | as though they had been typed with the option
X                            | 'ai' set too
X     - | ~                  | switch lower and upper cases
X     * | J                  | join <*> lines (default 2)
X     * | .                  | repeat latest command <*> times ("J" only once)
X     - | &                  | repeat latest "ex" substitute command, e.g.
X                            | ":s/wrong/good"
XControl-L
X
X
X
X
X
X    ///////////////////////////////////
X    / substitute replacement patterns /
X    ///////////////////////////////////
X
X    The basic metacharacters for the replacement pattern are `&' and `~';
X    these are given as `\&' and `\~' when nomagic is set.  Each instance
X    of `&' is replaced by the characters which the regular expression
X    matched.  The meta- character `~' stands, in the replacement
X    pattern, for the defining text of the previous replacement
X    pattern.  Other metasequences possible in the replacement pattern
X    are always introduced by the escaping character `\'.  The sequence
X    `\n' (with `n' in [1-9]) is replaced by the text matched by the
X    n-th regular subexpression enclosed between `\(' and `\)'.  The
X    sequences `\u' and `\l' cause the immediately following character
X    in the replacement to be converted to upper- or lower-case
X    respectively if this character is a letter.  The sequences `\U' and
X    `\L' turn such conversion on, either until `\E' or `\e' is
X    encountered, or until the end of the replacement pattern.
X
X    //////////////////////////////
X    / remembering text (yanking) /
X    //////////////////////////////
X
X    With yank commands you can put " before the command, just as
X    with delete commands. Otherwise you only copy to the undo buffer.
X    The use of buffers  is THE way of copying text to another
X    file; see the ":e " command.
X
X     * | y            | yank from begin to endpoint of <*>
X     * | yy                 | <*> lines
X     * | Y                  | idem (should be equivalent to "y$" though)
X     - | m             | mark the cursor position with a letter
X
X    ////////////////////////////////////////
X    / commands while in append|change mode /
X    ////////////////////////////////////////
X
X    ^@                      | if typed as the first character of the
X                            | insertion, it is replaced with the previous
X                            | text inserted (max. 128 chars), after which
X                            | the insertion is terminated
X    ^V                      | deprive the next char of its special meaning
X                            | (e.g. )
X    ^D                      | one shiftwidth to the left
X    0^D                     | remove all indentation on the current line
X                            | (there must be no other chars on the line)
X    ^^D                     | idem, except that it is restored on the next line
X    ^T                      | one shiftwidth to the right
X    ^H |             | one char back
X    ^W                      | one word back
X                      | back to the begin of the change on the
X                            | current line
X                      | like 
XControl-L
X
X
X
X
X
X    /////////////////////////////////////////////////
X    / writing, editing other files, and quitting vi /
X    /////////////////////////////////////////////////
X
X    :q                      | quit vi, unless the buffer has been changed
X    :q!                     | quit vi without writing
X    :w                      | write the file
X    :w                | write to the file 
X    :w >>             | append the buffer to the file 
X    :w!               | overwrite the file 
X    :x,y w            | write lines x through y to the file 
X    :wq                     | write the file and quit vi, WITHOUT
X                            | checking if the write has been
X                            | successful (use "ZZ" instead)
X    ZZ                      | write if the buffer has been changed, and
X                            | quit vi; if you have invoked vi with the "-r"
X                            | option, you'd better write the file
X                            | explicitly ("w" or "w!"), or quit the
X                            | editor explicitly ("q!") if you don't want
X                            | to overwrite the file - some versions of vi
X                            | don't handle the "recover" option very well
X    :x                      | idem
X    :x!                     | ":w!" and ":q"
X    :e                | edit another file without quitting vi - the
X                            | buffers are not changed (except the undo
X                            | buffer), so text can be copied from one
X                            | file to another this way
X    :e!               | idem, without writing the current buffer
X    :e#                     | edit the previous file
X    ^^                      | idem
X    :rew                    | edit the first file (when "vi file1 file2 ...")
X    :rew!                   | idem, without writing the current buffer
X    :n []             | edit the next file
X    :n! []            | idem, without writing the current buffer
XControl-L
X
X
X
X
X
X    ////////////////////
X    / display commands /
X    ////////////////////
X
X    ^G                      | give current line number and relative position
X    ^L                      | refresh the screen (sometimes "^P" or "^R")
X    ^R                      | sometimes vi replaces a deleted line by
X                            | a '@', to be deleted by "^R" (also with
X                            | option 'noredraw')
X    [*]^E                   | expose <*> more lines at bottom, cursor
X                            | stays put (if possible)
X    [*]^Y                   | expose <*> more lines at top, cursor
X                            | stays put (if possible)
X    [*]^D                   | scroll <*> lines downward
X                            | (default the number of the previous scroll;
X                            | initialization: half a page)
X    [*]^U                   | scroll <*> lines upward
X                            | (default the number of the previous scroll;
X                            | initialization: half a page)
X    [*]^F                   | <*> pages forward
X    [*]^B                   | <*> pages backward (in older versions "^B" only
X                            | works without count)
X
X    If in the next commands the field  is present, the windowsize
X    will change to . The window will always be displayed at the
X    bottom of the screen.
X
X    [*]z[wi]            | put line <*> at the top of the window
X                            | (default the current line)
X    [*]z[wi]+               | put line <*> at the top of the window
X                            | (default the first line of the next page)
X    [*]z[wi]-               | put line <*> at the bottom of the window
X                            | (default the current line)
X    [*]z[wi].               | put line <*> in the centre of the window
X                            | (default the current line)
XControl-L
X
X
X
X
X
X    ////////////////////////////
X    / mapping and abbreviation /
X    ////////////////////////////
X
X    When mapping take a look at the options 'to' and 'remap' (below).
X
X    :map       |  is interpreted as , e.g.
X                            | ":map ^C :!cc %^V" to compile from within vi
X                            | (vi replaces % with the current file name)
X    :map                    | show all mappings
X    :unmap          | deprive  of its mapping
X                            | when vi complains about non-mapped macros
X                            | (whereas no typos have been made), first do
X                            | something like ":map  Z", followed
X                            | by ":unmap " ('Z' must not be a
X                            | macro itself), or switch to "ex" mode first
X    :map!      | mapping in append mode, e.g.
X                            | ":map! \be begin^Vend;^VO"
X                            | when  is preceded by ^V, no
X                            | mapping is done
X    :map!                   | show all append mode mappings
X    :unmap!         | deprive  of its mapping (see ":unmap")
X    :ab        | whenever in append mode  is followed
X                            | by a breakpoint (e.g.  or ','), it is
X                            | interpreted as , e.g. ":ab p procedure"
X                            | a char preceded by ^V is not considered
X                            | a breakpoint
X    :ab                     | show all abbreviations
X    :unab           | do not consider  an abbreviation
X                            | anymore (see ":unmap")
X    @                  | consider the contents of the named register a
X                            | command, e.g.:
X                            |       o0^D:s/wrong/good/"zdd
X                            | explanation:
X                            |       o              - open a new line
X                            |       0^D            - remove indentation
X                            |       :s/wrong/good/ - this input text is an
X                            |                        "ex" substitute command
X                            |                 - finish the input
X                            |       "zdd           - delete the line just
X                            |                        created into register 'z'
X                            | now you can type @z to substitute `wrong'
X                            | by `good' on the current line
X    @@                      | repeat last register command
XControl-L
X
X
X
X
X
X    /////////////////////////////
X    / switch and shell commands /
X    /////////////////////////////
X
X    Q | ^\ |    | switch from vi to "ex"
X    :                       | an "ex" command can be given
X    :vi                     | switch from "ex" to vi
X    :sh                     | execute a subshell, back to vi by ^D
X    :!                 | execute a shell 
X    :!!                     | repeat the last shell command
X    [*]!         | the shell executes , with as standard
X                            | input the lines described by <*>,
X                            | next the standard output replaces those lines
X                            | (think of cb, sort, nroff, etc.)
X    [*]!!       | append  to the last  and execute it,
X                            | using the lines described by the current
X                            | <*>
X    [*]!!              | give <*> lines as standard input to the
X                            | shell , next let the standard output
X                            | replace those lines
X    [*]!!! []         | use the previous  (and append  to it)
X    :x,y w !           | let lines x to y be standard input for 
X                            | (notice the space between 'w' and '!')
X    :r!                | put the output of  onto a new line
X    :r                | read the file  into the buffer
XControl-L
X
X
X
X
X
X    //////////////
X    / vi startup /
X    //////////////
X
X    vi [file]               : edit the file and display the first page
X
X    The editor can be initialized by the shell variable EXINIT, which
X    looks like:
X
X            EXINIT='||...'
X            :  set options
X                    map ...
X                    ab ...
X            export EXINIT (in the Bourne shell)
X
X    However, the list of initializations can also be put into a file.
X    If this file is located in your home directory, and is named
X    ".exrc" AND the variable EXINIT is NOT set, the list will be
X    executed automatically at startup time. If the 3 conditions are not
X    met, you have to give the execute command yourself:
X
X            :source file
X    or
X            :so file
X
X    On-line initializations can be given with "vi + file", e.g.:
X
X    vi +x file              | the cursor will immediately jump to line x
X                            | (default last line)
X    vi +/ file      | ~ to the first occurrence of 
X
X    You can start at a particular tag with:
X
X    vi -t              | starts in the right file in the right place
X
X    Sometimes (e.g. if the system crashed while you were editing) it is
X    possible to recover files lost in the editor by "vi -r file".  If
X    you just want to view a file by using vi, and you want to avoid any
X    change, instead of vi you can use the "view" or "vi -R" command:
X    the option 'readonly' will be set automatically (with ":w!" you can
X    override this option).
XControl-L
X
X
X
X
X
X    //////////////////////////////
X    / the most important options /
X    //////////////////////////////
X
X    ai                      | autoindent - in append mode after a  the
X                            | cursor will move directly below the first
X                            | CHAR on the previous line.  However, if the
X                            | option 'lisp' is set, the cursor will align
X                            | at the first argument to the last open list.
X    aw                      | autowrite - write at every shell escape
X                            | (useful when compiling from within vi)
X    dir=            | directory - the directory for vi to make
X                            | temporary files (default /tmp)
X    eb                      | errorbells - beeps when you goof
X                            | (not on every terminal)
X    ic                      | ignorecase - no distinction between upper and
X                            | lower cases when searching
X    lisp                    | redefine the following commands:
X                            | "(", ")"   - move backward (forward) over
X                            |              S-expressions
X                            | "{", "}"   - idem, but don't stop at atoms
X                            | "[[", "]]" - go to previous (next) line
X                            |              beginning with a '('
X                            | see option 'ai'
X    list                    |  is shown as '$',  as '^I'
X    magic                   | some metachars can be used when searching:
X                            | ^    -  must begin the line
X                            | $    -  must end the line
X                            | .            - matches any char
X                            | [a-z]        - matches any char in the range
X                            | []   - matches any char in 
X                            | [^]  - matches any char not in 
X                            | *      - 0 or more s
X                            | \<\> -  must be a word
X    nu                      | number - numbers before the lines
X    para=           | paragraphs - every pair of chars in  is
X                            | considered a paragraph delimiter nroff macro
X                            | (for "{" and "}").
X                            | a  preceded by a '\' indicates that
X                            | the previous char is a single letter
X                            | macro.  ":set para=P\ bp" introduces '.P'
X                            | and '.bp' as paragraph delimiters.
X                            | completely empty lines and section
X                            | boundaries are paragraph boundaries too.
X    redraw                  | the screen remains up to date
X    remap                   | if on (default), macros are repeatedly
X                            | expanded until they are unchanged.
X                            | Example: if 'o' is mapped to 'O', and 'O'
X                            | is mapped to 'I', then 'o' will map to 'I'
X                            | if "remap" is set, else it will map to 'O'.
X    report=<*>              | vi reports whenever e.g. a delete
X                            | or yank command affects <*> or more lines
X    ro                      | readonly - the file is not to be changed
X                            | however, ":w!" will override this option
XControl-L
X
X
X
X
X
X    sect=           | sections - gives the section delimiters
X                            | (for "[[" and "]]"); see option 'para',
X                            | however a '{' as first char on a line also
X                            | starts a section (as in C functions)
X    sh=             | shell - which program is to be used for
X                            | shell escapes
X    sw=<*>                  | shiftwidth - gives the shiftwidth (default sw=8)
X    sm                      | showmatch - whenever you append a ')', vi
X                            | tries to show its match by putting the cursor
X                            | for a moment onto it (also with { })
X    terse                   | short error messages
X    to                      | timeout - if this option is set, append mode
X                            | mappings will be interpreted only if they're
X                            | typed fast enough
X    ts=<*>                  | tabstop - the length of a ;
X                            | warning: this is only IN the editor,
X                            | outside of it s have their normal
X                            | length (default ts=8)
X    wa                      | writeany - no checks when writing (dangerous)
X    warn                    | warn you when you try to quit without writing
X    wi=<*>                  | window - the default number of lines vi shows
X    wm=<*>                  | wrapmargin - when in append mode vi
X                            | automatically puts a  whenever there is
X                            | a  or  within  columns from the
X                            | right margin
X    ws                      | wrapscan - when searching, the end is
X                            | considered `stuck' to the begin of the file
X
X    :set