MirBSD manpage: 13.viref(USD)


                             Vi/Ex Reference Manual

                                  Keith Bostic

                           Computer Science Division
           Department of Electrical Engineering and Computer Science
                       University of California, Berkeley
                          Berkeley, California  94720

                               December 24, 2022

                                    Abstract

          This document is the reference guide for the 4.4BSD implemen-
     tations  of  nex/nvi,  which  are  implementations of the historic
     Berkeley ex/vi editors.

                                   Licensing

     Copyright (c) 1991, 1992, 1993, 1994
          The  Regents  of  the  University  of  California.   All   Rights
     Reserved.

     Copyright (c) 1991, 1992, 1993, 1994, 1995, 1996
          Keith Bostic.  All Rights Reserved.

          The vi program is freely redistributable.   You  are  welcome  to
     copy,  modify  and share it with others under the conditions listed in
     the LICENSE file.  If any company (not individual!)  finds  vi  suffi-
     ciently  useful  that  you  would have purchased it, or if any company
     wishes to redistribute it,  contributions  to  the  authors  would  be
     appreciated.

                                Acknowledgements

          Bruce Englar encouraged the early development of the historic
     ex/vi  editor.  Peter  Kessler  helped bring sanity to version 2's
     command layout. Bill Joy wrote versions 1 and 2.0 through 2.7, and
     created  the  framework that users see in the present editor. Mark
     Horton added macros and other features and made ex/vi  work  on  a
     large number of terminals and Unix systems.

          Nvi is originally derived from software  contributed  to  the
     University of California, Berkeley by Steve Kirkendall, the author
     of the vi clone elvis.

          IEEE Standard Portable Operating System  Interface  for  Com-
     puter Environments (POSIX) 1003.2 style Regular Expression support
     was done by Henry Spencer.

          The curses library was originally done by Ken Arnold.  Scrol-
     ling and reworking for nvi was done by Elan Amir.

          George Neville-Neil added the Tcl interpreter, and Sven  Ver-
     doolaege added the Perl interpreter.

          Rob Mayoff added Cscope support.

          The Institute of Electrical  and  Electronics  Engineers  has
     given  us  permission  to reprint portions of their documentation.
     Portions of this document are reprinted and reproduced  from  IEEE
     Std 1003.2-1992, IEEE Standard Portable Operating System Interface
     for Computer Environments (POSIX), copyright 1992 by the Institute
     of Electrical and Electronics Engineers, Inc.

          The financial support of  UUNET  Communications  Services  is
     gratefully acknowledged.

     USD:13-4                                               Vi/Ex Reference

     1. Description

          Ex is a line-oriented text editor; Vi is  a  screen  oriented
     text  editor.  Ex and vi are different interfaces to the same pro-
     gram, and it is possible to switch back and forth during  an  edit
     session. View is the equivalent of using the -R (read-only) option
     of vi.

          This reference manual is the one provided  with  the  nex/nvi
     versions  of  the ex/vi text editors. Nex/nvi are intended as bug-
     for-bug compatible replacements for the original  Fourth  Berkeley
     Software Distribution (4BSD) ex/vi programs. This reference manual
     is accompanied by a traditional-style  manual  page.  That  manual
     page describes the functionality found in ex/vi in far less detail
     than the description here. In addition, it  describes  the  system
     interface  to  ex/vi, e.g. command line options, session recovery,
     signals, environmental variables, and similar things.

          This reference is intended for users  already  familiar  with
     ex/vi. Anyone else should almost certainly read a good tutorial on
     the editor first. If you are in an unfamiliar environment, and you
     absolutely  have  to  get  work  done immediately, see the section
     entitled "Fast Startup" in the manual page. It is probably  enough
     to get you started.

          There are a few features in nex/nvi that  are  not  found  in
     historic  versions of ex/vi. Some of the more interesting of those
     features are briefly  described  in  the  next  section,  entitled
     "Additional  Features".  For the rest of this document, nex/nvi is
     used only when it is necessary to distinguish it from the historic
     implementations of ex/vi.

          Future versions of this software will  be  periodically  made
     available   by   anonymous   ftp,   and   can  be  retrieved  from
     ftp.cs.berkeley.edu,   ftp.cs.berkeley.edu,   in   the   directory
     ucb/4bsd. ucb/4bsd.

     2. Additional Features in Nex/Nvi

          There are a few features in nex/nvi that  are  not  found  in
     historic  versions of ex/vi. Some of the more interesting of these
     are as follows:

     8-bit clean data, large lines, files
          Nex/nvi will edit any format file. Line lengths  are  limited
          by  available memory, and file sizes are limited by available
          disk space. The vi text input mode  command  <control-X>  can
          insert any possible character value into the text.

     Background and foreground screens
          The bg command backgrounds the current  screen,  and  the  fg
          command foregrounds backgrounded screens. The display command
          can be used to list the background screens.

     Vi/Ex Reference                                               USD:13-5

     Command Editing
          You can enter a normal editing window on the  collected  com-
          mands  that  you've entered on the vi colon command-line, and
          then modify and/or execute the commands. See the  cedit  edit
          option for more information.

     Displays
          The display command  can  be  used  to  display  the  current
          buffers, the backgrounded screens, and the tags stack.

     Extended Regular Expressions
          The extended option causes Regular Expressions to  be  inter-
          preted  as  as  Extended  Regular Expressions, (i.e. egrep(1)
          style Regular Expressions).

     File Name Completion
          It is possible to do  file  name  completion  and  file  name
          displays when entering commands on the vi colon command-line.
          See the filec option for more information.

     Infinite undo
          Changes made during an edit session may  be  rolled  backward
          and  forward.  A . command immediately after a u command con-
          tinues either forward or backward depending on whether the  u
          command was an undo or a redo.

     Left-right scrolling
          The leftright option  causes  nvi  to  do  left-right  screen
          scrolling, instead of the traditional vi line wrapping.

     Message Catalogs
          It is possible to display informational and error messages in
          different  languages  by providing a catalog of messages. See
          the msgcat option and the file catalog/README  catalog/README
          for more information.

     Incrementing numbers
          The # command increments or decrements the number  referenced
          by the cursor.

     Previous file
          The previous command edits the previous file from  the  argu-
          ment list.

     Scripting languages
          The :pe[rl] cmd, :perld[o] cmd and :tc[l] cmd  commands  exe-
          cute  Perl  and  Tcl/Tk commands, respectively, on lines from
          the edit buffer. See the "Scripting  Languages"  section  and
          the specific commands for more information.

     Split screens
          The Edit, Ex, Next, Previous, Tag and  Visual  (in  vi  mode)
          commands  divide the screen into multiple editing regions and

     USD:13-6                                               Vi/Ex Reference

          then
          perform their normal function in a new screen area.
          The
          .CO <control-W>
          command rotates between the foreground screens.
          The
          .CO resize
          command can be used to grow or shrink a particular screen.
          .IP "Tag stacks"
          Tags are now maintained in a stack.
          The
          .CO <control-T>
          command returns to the previous tag location.
          The
          .CO tagpop
          command returns to the most recent tag location by default, or,
          optionally to a specific tag number in the tag stack,
          or the most recent tag from a specified file.
          The
          .CO display
          command can be used to list the tags stack.
          The
          .CO tagtop
          command returns to the top of the tag stack.
          .IP "Usage information"
          The
          .CO exusage
          and
          .CO viusage
          commands provide usage information for all of the
          .CO ex
          and
          .CO vi
          commands by default, or, optionally, for a specific command or key.
          .IP "Word search"
          The
          .CO <control-A>
          command searches for the word referenced by the cursor.
          .SH 1 "Startup Information"
          .pp
          .EV Ex vi
          interprets one of two possible environmental variables and reads up to
          three of five possible files during startup.
          The variables and files are expected to contain
          .CO ex
          commands, not
          .CO vi
          commands.
          In addition, they are interpreted
          .i before
          the file to be edited is read, and therefore many
          .CO ex
          commands may not be used.

     Vi/Ex Reference                                               USD:13-7

          Generally, any command that requires output to the screen or that
          needs a file upon which to operate, will cause an error if included
          in a startup file or environmental variable.
          .pp
          Because the
          .CO ex
          command set supported by
          .EV nex nvi
          is a superset of the command set supported by historical implementations of
          .CO ex ,
          .EV nex nvi
          can use the startup files created for the historical implementations,
          but the converse may not be true.
          .pp
          If the
          .b -s
          (the historic - option)
          is specified, or if standard input is redirected from a file,
          all environmental variables and startup files are ignored.
          .pp
          Otherwise, startup files and environmental variables are handled
          in the following order:
          .np
          The file
          .LI /etc/vi.exrc
          is read,
          as long as it is owned by root or the effective user ID of the user.
          .np
          The environmental variable
          .LI NEXINIT
          (or the variable
          .LI EXINIT ,
          if
          .LI NEXINIT
          is not set) is interpreted.
          .np
          If neither
          .LI NEXINIT
          or
          .LI EXINIT
          was set, and the
          .LI HOME
          environmental variable is set, the file
          .LI $HOME/.nexrc
          (or the file
          .LI $HOME/.exrc ,
          if
          .LI $HOME/.nexrc
          does not exist) is read,
          as long as the effective user ID of the user is root or is the same as
          the owner of the file.
          .sp
          When the $HOME directory is being used for both

     USD:13-8                                               Vi/Ex Reference

          .EV nex nvi
          and an historic implementation of
          .EV ex vi ,
          a possible solution is to put
          .EV nex nvi
          specific commands in the
          .LI .nexrc
          file, along with a
          .CO ":source $HOME/.exrc"
          command to read in the commands common to both implementations.
          .np
          If the
          .OP exrc
          option was turned on by one of the previous startup information
          sources, the file
          .LI .nexrc
          (or the file
          .LI .exrc ,
          if
          .LI .nexrc
          does not exist) is read, as long as the effective user ID of the user
          is the same as the owner of the file.
          .pp
          No startup file is read if it is writable by anyone other than its owner.
          .pp
          It is not an error for any of the startup environmental variables or files
          not to exist.
          .pp
          Once all environmental variables are interpreted,
          and all startup files are read,
          the first file to be edited is read in (or a temporary file is created).
          Then, any commands specified using the
          .b -c
          option are executed, in the context of that file.
          .SH 1 "Recovery"
          .pp
          There is no recovery program for
          .EV nex nvi ,
          nor does
          .EV nex nvi
          run setuid.
          Recovery files are created readable and writable by the owner only.
          Users may recover any file which they can read,
          and the superuser may recover any edit session.
          .pp
          Edit sessions are backed by files in the directory named by the
          .OP recdir
          option (the directory
          .LI /var/tmp/vi.recover
          by default), and are named
          .QC vi.XXXXXXXXXX ,
          where
          .QC XXXXXXXXXX

     Vi/Ex Reference                                               USD:13-9

          is a number related to the process ID.
          When a file is first modified,
          a second recovery file containing an email message for the user is created,
          and is named
          .QC recover.XXXXXXXXXX ,
          where, again,
          .QC XXXXXXXXXX
          is associated with the process ID.
          Both files are removed at the end of a normal edit session,
          but will remain if the edit session is abnormally terminated
          or the user runs the
          .CO ex
          .CO preserve
          command.
          .pp
          The
          .OP recdir
          option may be set in either the user's or system's startup information,
          changing the recovery directory.
          (Note, however, that if a memory based filesystem is used as the backup
          directory, each system reboot will delete all of the recovery files!
          The same caution applies to directories such as
          .LI /tmp
          which are cleared of their contents by a system reboot, or
          .LI /usr/tmp
          which is periodically cleared of old files on many systems.)
          .pp
          The recovery directory should be owned by root, or at least by a pseudo-user.
          In addition, if directory
          .QQ sticky-bit
          semantics are available, the directory should have the sticky-bit
          set so that files may only be removed by their owners.
          The recovery directory must be read, write, and executable by any user,
          i.e. mode 1777.
          .pp
          If the recovery directory does not exist,
          .EV ex vi
          will attempt to create it.
          This can result in the recovery directory being owned by a normal user,
          which means that that user will be able to remove other user's recovery
          and backup files.
          This is annoying, but is not a security issue as the user cannot
          otherwise access or modify the files.
          .pp
          The recovery file has all of the necessary information in it to enable the
          user to recover the edit session.
          In addition, it has all of the necessary email headers for
          .XR sendmail 8 .
          .
          .
          .
          .
          .

     USD:13-10                                              Vi/Ex Reference

          .
          .
          .
          .
          If
          .EV ex vi
          receives a hangup (SIGHUP) signal, or the user executes the
          .CO ex
          .CO preserve
          command,
          .EV ex vi
          will automatically email the recovery information to the user.
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .pp
          Finally, the owner execute bit is set on backup files when they are
          created, and unset when they are first modified, e.g. backup files
          that have no associated email recovery file will have this bit set.
          (There is also a small window where empty files can be created and
          not yet have this bit set.
          This is due to the method in which the files are created.)
          Such files are deleted when the system reboots.
          .pp
          Most of the recovery process is automated on OpenBSD.
          When the system boots, the shell script
          .LI /etc/rc
          executes the vi recovery script
          .LI /usr/libexec/vi.recover .
          This takes care of removing stale files, checking for backup files,
          and sending email notification to the owners of such files.
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .

     Vi/Ex Reference                                              USD:13-11

          .
          .
          .
          .pp
          Consult the manual page for details on recovering preserved or
          aborted editing sessions on startup.
          .SH 1 "Sizing the Screen"
          .pp
          The size of the screen can be set in a number of ways.
          .EV Ex vi
          takes the following steps until values are obtained for both the
          number of rows and number of columns in the screen.
          .np
          If the environmental variable
          .LI LINES
          exists,
          it is used to specify the number of rows in the screen.
          .np
          If the environmental variable
          .LI COLUMNS
          exists,
          it is used to specify the number of columns in the screen.
          .np
          The TIOCGWINSZ ioctl
          see
          .XR tty 4
          is attempted on the standard error file descriptor.
          .np
          The
          .XR terminfo 5
          entry
          is checked for the
          .QQ li
          entry (rows) and the
          .QQ co
          entry (columns).
          .np
          The number of rows is set to 24, and the number of columns is set to 80.
          .pp
          If a window change size signal (SIGWINCH) is received,
          the new window size is retrieved using the TIOCGWINSZ
          .XR ioctl 2
          call, and all other information is ignored.
          .SH 1 "Character Display"
          .pp
          In both
          .CO ex
          and
          .CO vi
          printable characters as defined by
          .XR isprint 3
          are displayed using the local character set.
          .pp

     USD:13-12                                              Vi/Ex Reference

          Non-printable characters, for which
          .XR iscntrl 3
          returns true, and which are less than octal \040,
          are displayed as the string
          .QT ^<character> ,
          where
          .LI <character>
          is the character that is the original character's value offset from the
          .QT @
          character.
          For example, the octal character \001 is displayed as
          .QT ^A .
          If
          .XR iscntrl 3
          returns true for the octal character \177,
          it is displayed as the string
          .QT ^? .
          All other characters are displayed as either hexadecimal values,
          in the form
          .QT "0x<high-halfbyte> ... 0x<low-halfbyte>" ,
          or as octal values, in the form
          .QT "\<high-one-or-two-bits> ... \<low-three-bits>" .
          The display of unknown characters is based on the value of the
          .OP octal
          option.
          .pp
          In
          .CO vi
          command mode, the cursor is always positioned on the last column of
          characters which take up more than one column on the screen.
          In
          .CO vi
          text input mode, the cursor is positioned on the first column of
          characters which take up more than one column on the screen.
          .SH 1 "Multiple Screens"
          .pp
          .CO Nvi
          supports multiple screens by dividing the window into regions.
          It also supports stacks of screens by permitting the user to change
          the set of screens that are currently displayed.
          .pp
          The
          .CO Edit ,
          .CO Ex ,
          .CO Fg ,
          .CO Next ,
          .CO Previous ,
          .CO Tag
          and
          .CO Visual
          (in
          .CO vi
          mode)

     Vi/Ex Reference                                              USD:13-13

          commands divide the current screen into two regions of approximately
          equal size and then perform their usual action in a new screen area.
          If the cursor is in the lower half of the screen, the screen will split
          up, i.e. the new screen will be above the old one.
          If the cursor is in the upper half of the screen, the new screen will be
          below the old one.
          .pp
          When more than one screen is editing a file, changes in any screen are
          reflected in all other screens editing the same file.
          Exiting a screen without saving any changes (or explicitly discarding
          them) is permitted until the last screen editing the file is exited,
          at which time the changes must be saved or discarded.
          .pp
          The
          .CO resize
          command permits resizing of individual screens.
          Screens may be grown, shrunk, or set to an absolute number of rows.
          .pp
          The
          .CO ^W
          command is used to switch between screens.
          Each
          .CO ^W
          moves to the next lower screen in the window, or to the first screen
          in the window if there are no lower screens.
          .pp
          The
          .CO bg
          command
          .QQ backgrounds
          the current screen.
          The screen disappears from the window,
          and the rows it occupied are taken over by a neighboring screen.
          It is an error to attempt to background the only screen in the window.
          .pp
          The
          .CO "display screens"
          command displays the names of the files associated with the current
          backgrounded screens in the window.
          .pp
          The
          .CO "fg [file]"
          command moves the specified screen from the list of backgrounded screens
          to the foreground.
          If no file argument is specified, the first screen on the list is
          foregrounded.
          By default,
          foregrounding consists of backgrounding the current screen,
          and replacing its space in the window with the foregrounded screen.
          .pp
          Capitalizing the first letter of the command, i.e.
          .CO Fg ,
          will foreground the backgrounded screen in a new screen instead of

     USD:13-14                                              Vi/Ex Reference

          swapping it with the current screen.
          .pp
          If the last foregrounded screen in the window is exited,
          and there are backgrounded screens,
          the first screen on the list of backgrounded screens takes over the window.
          .SH 1 "Tags, Tag Stacks, and Cscope"
          .pp
          .CO Nvi
          supports the historic
          .CO vi
          tag command
          .CO <control-]> ,
          and the historic
          .CO ex
          tag command
          .CO tag .
          These commands change the current file context to a new location,
          based on information found in the
          .LI tags
          files.
          If you are unfamiliar with these commands,
          you should review their description in the
          .CO ex
          and
          .CO vi
          commands section of this manual.
          For additional information on tags files,
          see the discussion of the
          .OP tags
          edit option and the system
          .XR ctags 1
          manual page.
          .pp
          In addition,
          .CO nvi
          supports the notion of
          .QQ "tags stacks" ,
          using the
          .CO <control-T>
          command.
          The
          .CO <control-T>
          command returns the user to the previous context, i.e.,
          the last place from which a
          .CO <control-]>
          or
          .CO "tag"
          command was entered.
          These three commands provide the basic functionality which allows you
          to use
          .CO vi
          to review source code in a structured manner.
          .pp

     Vi/Ex Reference                                              USD:13-15

          .CO Nvi
          also provides two other basic
          .CO ex
          commands for tag support:
          .CO tagpop
          and
          .CO tagtop .
          The
          .CO tagpop
          command is identical to the
          .CO <control-T>
          command,
          with the additional functionality that you may specify that modifications
          to the current file are to be discarded.
          This cannot be done using the
          .CO <control-T>
          command.
          The
          .CO tagtop
          command discards all of the contexts that have been pushed onto the tag
          stack, returning to the context from which the first
          .CO <control-]>
          or
          .CO tag
          command was entered.
          .pp
          The historic
          .XR ctags 1
          tags file format supports only a single location per tag,
          normally the function declaration or structure or string definition.
          More sophisticated source code tools often provide multiple locations
          per tag, e.g.,
          a list of the places from which a function is called or a string
          definition is used.
          An example of this functionality is the System V source code tool,
          .CO cscope .
          .sp
          .CO Cscope
          creates a database of information on source code files,
          and supports a query language for that information as described in the
          .XR cscope 1
          manual page.
          .CO Nvi
          contains an interface to the
          .CO cscope
          query language which permits you to query
          .CO cscope
          and then sequentially step through the locations in the sources files which
          .CO cscope
          returns.
          There are two
          .CO nvi
          commands which support this ability to step through multiple locations.

     USD:13-16                                              Vi/Ex Reference

          They are the
          .CO ex
          commands
          .CO tagnext
          and
          .CO tagprev .
          The
          .CO tagnext
          command moves to the next location for the current tag.
          The
          .CO tagprev
          command moves to the previous location for the current tag.
          (See the
          .CO tagnext
          and
          .CO tagprev
          command discussion in the
          .CO ex
          commands section of this manual for more information.)
          At any time during this sequential walk,
          you may use the
          .CO <control-]> ,
          .CO tag
          or
          .CO cscope
          commands to move to a new tag context, and then use the
          .CO <control-T>
          or
          .CO tagpop
          commands to return and continue stepping through the locations for this
          tag.
          This is similar to the previous model of a simple tag stack,
          except that each entry in the tag stack may have more than one file context
          that is of interest.
          .pp
          Although there is no widely distributed version of
          .XR ctags 1
          that creates tags files with multiple locations per tag,
          .CO nvi
          has been written to understand the obvious extension to the historic
          tags file format, i.e., more than a single line in the tags file with
          the same initial tag name.
          If you wish to extend your
          .CO ctags
          implementation or other tool with which you build tags files,
          this extension should be simple and will require no changes to
          .CO nvi .
          .pp
          The
          .CO nvi
          and
          .CO cscope
          interface is based on the new

     Vi/Ex Reference                                              USD:13-17

          .CO ex
          command
          .CO cscope ,
          which has five subcommands:
          .CO add ,
          .CO find ,
          .CO help ,
          .CO kill
          and
          .CO reset .
          The subcommand
          .CO find
          itself has eight subcommands:
          .CO c ,
          .CO d ,
          .CO e ,
          .CO f ,
          .CO g ,
          .CO i ,
          .CO s
          and
          .CO t .
          .pp
          .IP "cs[cope] a[dd] file"
          The
          .CO add
          command attaches to the specified
          .CO cscope
          database.
          The file name is expanded using the standard filename expansions.
          If
          .CO file
          is a directory, the file
          .QQ cscope.out
          in that directory is used as the database.
          .pp
          After
          .CO nvi
          attaches to a new database,
          all subsequent
          .CO cscope
          queries will be asked of that database.
          The result of any single query is the collection of response to the query
          from all of the attached databases.
          .sp
          If the
          .QQ CSCOPE_DIRS
          environmental variable is set when
          .CO nvi
          is run,
          it is expected to be a <colon> or <blank>-separated list of
          .CO cscope
          databases or directories containing

     USD:13-18                                              Vi/Ex Reference

          .CO cscope
          databases, to which the user wishes to attach.
          .IP ":cs[cope] f[ind] c|d|e|f|g|i|s|t buffer|pattern"
          The
          .CO find
          command is the
          .CO cscope
          query command for
          .CO nvi .
          For this command,
          .CO nvi
          queries all attached
          .CO cscope
          databases for the pattern.
          If the pattern is a double-quote character followed by a valid buffer
          name (e.g.,
          .LI """<character>" ),
          then the contents of the named buffer are used as the pattern.
          Otherwise, the pattern is a Regular Expression.
          .sp
          The
          .CO find
          command pushes the current location onto the tags stack,
          and switches to the first location resulting from the query,
          if the query returned at least one result.
          .sp
          File names returned by the
          .CO cscope
          query, if not absolute paths, are searched for relative to the directory
          where the
          .CO cscope
          database is located.
          In addition, if the file
          .QQ cscope.tpath
          appears in the same directory as the
          .CO cscope
          database,
          it is expected to contain a colon-separated list of directory names
          where files referenced by its associated
          .CO cscope
          database may be found.
          .sp
          The
          .CO find
          subcommand is one of the following:
          .SS
          .SP c
          Find callers of the name.
          .SP d
          Find all function calls made from name.
          .SP e
          Find pattern.
          .SP f

     Vi/Ex Reference                                              USD:13-19

          Find files with name as substring.
          .SP g
          Find definition of name.
          .SP i
          Find files #including name.
          .SP s
          Find all uses of name.
          .SP t
          Find assignments to name.
          .SE
          .IP ":cs[cope] h[elp] [command]"
          List the
          .CO cscope
          commands,
          or optionally list usage help for any single
          .CO cscope
          command.
          .IP ":display c[onnections]"
          Display the list of
          .CO cscope
          databases to which
          .CO nvi
          is currently connected.
          .IP ":cs[cope] k[ill] #"
          Disconnect from a specific
          .CO cscope
          database.
          The connection number is the one displayed by the
          .CO ex
          .CO "display connections"
          command.
          .IP ":cs[cope] r[eset]"
          Disconnect from all attached
          .CO cscope
          databases.
          .pp
          Cscope was originally part of the official AT&T Unix distribution.
          In April 2000 the code for Cscope was open sourced under the BSD license.
          Information on downloading this code, and on Cscope itself,
          can be obtained from http://cscope.sourceforge.net/.
          .SH 1 "Regular Expressions and Replacement Strings"
          .pp
          Regular expressions are used in line addresses,
          as the first part of the
          .CO ex
          .CO substitute ,
          .CO global ,
          and
          .CO v
          commands, and in search patterns.
          .pp
          The regular expressions supported by
          .EV ex vi

     USD:13-20                                              Vi/Ex Reference

          are, by default, the Basic Regular Expressions (BRE's) described in the
          IEEE POSIX Standard 1003.2.
          The
          .OP extended
          option causes all regular expressions to be interpreted as the Extended
          Regular Expressions (ERE's) described by the same standard.
          (See
          .XR re_format 7
          for more information.)
          Generally speaking, BRE's are the Regular Expressions found in
          .XR ed 1
          and
          .XR grep 1 ,
          and ERE's are the Regular Expressions found in
          .XR egrep 1 .
          .pp
          The following is not intended to provide a description of Regular
          Expressions.
          The information here only describes strings and characters which
          have special meanings in the
          .EV ex vi
          version of RE's,
          or options which change the meanings of characters that normally
          have special meanings in RE's.
          .np
          An empty RE (e.g.
          .QT //
          or
          .QT ??
          is equivalent to the last RE used.
          .np
          The construct
          .QT \<
          matches the beginning of a word.
          .np
          The construct
          .QT \>
          matches the end of a word.
          .np
          The character
          .QT ~
          matches the replacement part of the last
          .CO substitute
          command.
          .pp
          When the
          .OP magic
          option is
          .i not
          set, the only characters with special meanings are a
          .QT ^
          character at the beginning of an RE, a
          .QT $

     Vi/Ex Reference                                              USD:13-21

          character at the end of an RE, and the escaping character
          .QT \ .
          The characters
          .QT . ,
          .QT * ,
          .QT [
          and
          .QT ~
          are treated as ordinary characters unless preceded by a
          .QT \ ;
          when preceded by a
          .QT \
          they regain their special meaning.
          .pp
          Replacement strings are the second part of a
          .CO substitute
          command.
          .pp
          The character
          .QT &
          (or
          .QT \&
          if the
          .OP magic
          option is
          .i not
          set) in the replacement string stands for the text matched by the RE
          that is being replaced.
          The character
          .QT ~
          (or
          .QT \~
          if the
          .OP magic
          option is
          .i not
          set) stands for the replacement part of the previous
          .CO substitute
          command.
          It is only valid after a
          .CO substitute
          command has been performed.
          .pp
          The string
          .QT \# ,
          where
          .QT #
          is an integer value from 1 to 9, stands for the text matched by
          the portion of the RE enclosed in the
          .QT # 'th
          set of escaped parentheses, e.g.
          .QT \(
          and

     USD:13-22                                              Vi/Ex Reference

          .QT \) .
          For example,
          .QT "s/abc\(.*\)def/\1/"
          deletes the strings
          .QT abc
          and
          .QT def
          from the matched pattern.
          .pp
          The strings
          .QT \l ,
          .QT \u ,
          .QT \L
          and
          .QT \U
          can be used to modify the case of elements in the replacement string.
          The string
          .QT \l
          causes the next character to be converted to lowercase;
          the string
          .QT \u
          behaves similarly, but converts to uppercase
          (e.g.
          .LI s/abc/\U&/
          replaces the string
          .LI abc
          with
          .LI ABC ).
          The string
          .QT \L
          causes characters up to the end of the string or the next occurrence
          of the strings
          .QT \e
          or
          .QT \E
          to be converted to lowercase;
          the string
          .QT \U
          behaves similarly, but converts to uppercase.
          .pp
          If the entire replacement pattern is
          .QT % ,
          then the last replacement pattern is used again.
          .pp
          In
          .CO vi ,
          inserting a
          .LI <control-M>
          into the replacement string will cause
          the matched line to be split into two lines at that point.
          (The
          .LI <control-M>
          will be discarded.)

     Vi/Ex Reference                                              USD:13-23

          .SH 1 "Scripting Languages"
          .pp
          The
          .CO nvi
          editor currently supports two scripting languages, Tcl/Tk and Perl.
          (Note that Perl4 isn't sufficient, and that the Perl5 used must be
          version 5.002 or later.
          See the
          .QB "Building Nvi"
          section for more information.)
          Note that the Tcl/Tk interface is not supported in the current version
          of OpenBSD.
          .pp
          The scripting language interface is still being worked on,
          therefore the following information is probably incomplete,
          probably wrong in cases, and likely to change.
          See the
          .LI perl_api
          and
          .LI tcl_api
          source directories for more information.
          As a quick reference, the following function calls are provided for
          both the Perl and Tcl interfaces.
          The Perl interface uses a slightly different naming convention,
          e.g. ``viFindScreen'' is named ``VI::FindScreen''.
          .IP "viFindScreen file"
          Return the
          .LI "screenId" associated with
          .LI file .
          .IP "viAppendLine screenId lineNumber text"
          Append
          .LI text
          as a new line after line number
          .LI lineNumber ,
          in the screen
          .LI screenId .
          .IP "viDelLine screenId lineNum"
          Delete the line
          .LI lineNumber
          from the screen
          .LI screenId .
          .IP "viGetLine screenId lineNumber"
          Return the line
          .LI lineNumber
          from the screen
          .LI screenId .
          .IP "viInsertLine screenId lineNumber text"
          Insert
          .LI text
          as a new line before line number
          .LI lineNumber
          in the screen
          .LI screenId .

     USD:13-24                                              Vi/Ex Reference

          .IP "viLastLine screenId"
          Return the line number of the last line in the screen
          .LI screenId .
          .IP "viSetLine screenId lineNumber text"
          Change the line
          .LI lineNumber
          in the screen
          .LI screenId
          to match the specified
          .LI text .
          .IP "viGetMark screenId mark"
          Return the current line and column for the specified
          .LI mark
          from the screen
          .LI screenId .
          .IP "viSetMark screenId mark line column"
          Set the specified
          .LI mark
          to be at line
          .LI line ,
          column
          .LI column ,
          in the screen
          .LI screenId .
          .IP "viGetCursor screenId"
          Return the current line and column for the cursor in the screen
          .LI screenId .
          .IP "viSetCursor screenId line column"
          Set the cursor in the screen
          .LI screenId
          to the specified
          .LI line
          and
          .LI column .
          .IP "viMsg screenId text"
          Display the specified
          .LI text
          as a vi message in the screen
          .LI screenId .
          .IP "viNewScreen screenId [file]"
          Create a new screen.
          .IP "viEndScreen screenId"
          Exit the screen
          .LI screenId .
          .IP "viSwitchScreen screenId screenId"
          Switch from the screen
          .LI screenId
          to the screen
          .LI screenId .
          .IP "viMapKey screenId key tclproc"
          Map the specified
          .LI key
          in the screen

     Vi/Ex Reference                                              USD:13-25

          .LI screenId
          to the Tcl procedure
          .LI tclproc .
          .IP "viUnmMapKey screenId key"
          Unmap the specified
          .LI key
          in the screen
          .LI screenId
          .IP "viGetOpt screenId option"
          Return the value of the specified
          .LI option
          from the screen
          .LI screenId .
          .IP "viSetOpt screenId command"
          Set one or more options in the screen
          .LI screenId .
          .SH 1 "General Editor Description"
          .pp
          When
          .CO ex
          or
          .CO vi
          are executed,
          the text of a file is read (or a temporary file is created),
          and then all editing changes happen within the context of the
          copy of the file.
          .i "No changes affect the actual file until the file is written out" ,
          either using a write command or another command which is affected by the
          .OP autowrite
          option.
          .pp
          All files are locked (using the
          .XR flock 2
          or
          .XR fcntl 2
          interfaces) during the edit session,
          to avoid inadvertently making modifications to multiple copies of the file.
          If a lock cannot be obtained for a file because it is locked by another
          process, the edit session is read-only (as if the
          .OP readonly
          option or the
          .b -R
          flag had been specified).
          If a lock cannot be obtained for other reasons, the edit session will
          continue, but the file status information
          (see the
          .CO <control-G>
          command) will reflect this fact.
          .pp
          Both
          .CO ex
          and
          .CO vi

     USD:13-26                                              Vi/Ex Reference

          are modeful editors, i.e. they have two modes,
          .QQ command
          mode and
          .QQ "text input"
          mode.
          The former is intended to permit you to enter commands which modifies
          already existing text.
          The latter is intended to permit you to enter new text.
          When
          .CO ex
          first starts running, it is in command mode, and usually displays a prompt
          (see the
          .OP prompt
          option for more information).
          The prompt is a single colon
          .PQ :
          character.
          There are three commands that switch
          .CO ex
          into text input mode:
          .CO append ,
          .CO change
          and
          .CO insert .
          Once in input mode, entering a line containing only a single period
          .PQ .
          ends text input mode and returns to command mode,
          where the prompt is redisplayed.
          .pp
          When
          .CO vi
          first starts running, it is in command mode as well.
          There are eleven commands that switch
          .CO vi
          into text input mode:
          .CO A ,
          .CO a ,
          .CO C ,
          .CO c ,
          .CO I ,
          .CO i ,
          .CO O ,
          .CO o ,
          .CO R ,
          .CO S
          and
          .CO s .
          Once in input mode, entering an
          .LI <escape>
          character ends text input mode and returns to command mode.
          .pp
          .EV Ex vi
          present three different interfaces to editing a file.

     Vi/Ex Reference                                              USD:13-27

          .CO Ex
          presents a line oriented interface.
          .CO Vi
          presents a full screen display oriented interface,
          also known as
          .QQ "visual mode" .
          In addition, there is a third mode,
          .QQ "open mode" ,
          which is line oriented,
          but supports cursor movement and editing within the displayed line,
          similarly to visual mode.
          Open mode is not yet implemented in
          .CO nvi .
          .pp
          The following words have special meanings in both the
          .CO ex
          and
          .CO vi
          command descriptions:
          .KY <interrupt>
          .IP <interrupt>
          The interrupt character is used to interrupt the current operation.
          Normally
          .LI <control-C> ,
          whatever character is set for the current terminal is used.
          .KY "<literal-next>"
          .IP "<literal-next>"
          The literal next character is used to escape the subsequent character
          from any special meaning.
          This character is always
          .LI <control-V> .
          If the terminal is not set up to do XON/XOFF flow control,
          then
          .LI <control-Q>
          is used to mean literal next as well.
          .KY "current pathname"
          .IP "current pathname"
          The pathname of the file currently being edited by vi.
          When the percent character
          .PQ %
          appears in a file name entered as part of an
          .CO ex
          command argument, it is replaced by the current pathname.
          (The
          .QT %
          character can be escaped by preceding it with a backslash.)
          .KY "alternate pathname"
          .IP "alternate pathname"
          The name of the last file name mentioned in an
          .CO ex
          command, or,
          the previous current pathname if the last file mentioned
          becomes the current file.

     USD:13-28                                              Vi/Ex Reference

          When the hash mark character
          .PQ #
          appears in a file name entered as part of an
          .CO ex
          command argument, it is replaced by the alternate pathname.
          (The
          .QT #
          character can be escaped by preceding it with a backslash.)
          .KY buffer
          .IP buffer
          One of a number of named areas for saving copies of text.
          Commands that change or delete text can save the changed or deleted
          text into a specific buffer, for later use, if the command allows
          it (e.g. the
          .CO ex
          .CO change
          command cannot save the changed text in a named buffer).
          Buffers are named with a single character, preceded by a double quote,
          i.e.
          .LI """<character>"
          in
          .CO vi
          and
          without the double quote, e.g.
          .LI <character> ,
          in
          .CO ex .
          (The double quote isn't necessary for
          .CO ex
          because buffer names are denoted by their position in the command line.)
          Historic implementations of
          .EV ex vi
          limited
          .LI <character>
          to the alphanumeric characters;
          .EV nex nvi
          permits the use of any character without another meaning in the position
          where a buffer name is expected.
          .sp
          Buffers named by uppercase characters are the same as buffers
          named by lowercase characters, e.g. the buffer named by the
          English character
          .QT A
          is the same as the buffer named by the character
          .QT a ,
          with the exception that, if the buffer contents are being changed (as
          with a text deletion or
          .CO vi
          .CO change
          command), the text is
          .i appended
          to the buffer, instead of replacing the current contents.
          .sp

     Vi/Ex Reference                                              USD:13-29

          The buffers named by the numeric characters (in English,
          .QT 1
          through
          .QT 9 ),
          are special.
          If a region of text including characters from more than one line,
          or a single line of text specified by using a line-oriented motion,
          is changed or deleted in the file using the
          .CO vi
          .CO change
          or
          .CO delete
          commands, a copy of the text is placed into the numeric buffer
          .QT 1 ,
          regardless of the user specifying another buffer in which to save it.
          In addition, there are a few commands which, when used as a
          .LI motion
          with the
          .CO vi
          .CO change
          and
          .CO delete
          commands,
          .i always
          copy the specified region of text into the numeric buffers regardless
          of the region including characters from more than one line.
          These commands are:
          .sp
          .ne 3v
          .ft C
          .TS
          .if 0=1 .nr d. 1670-1670-1
          .de 35
          .ps 10
          .vs 40u
          .in 120u
          .if 0 .fi
          .if 1 .ad
          .if 1=0 .na
          ..
          .nf
          .nr #~ 0
          .if n .nr #~ 0.6n
          .ds #d .d
          .if  .ds #d nl
          .fc
          .nr 33 10
          .rm 80 81 82 83
          .nr 80 0
          .nr 38 264
          .if 0<0 .nr 80 0
          .nr 38 288
          .if 0<0 .nr 80 0

     USD:13-30                                              Vi/Ex Reference

          .nr 38 24
          .if 0<0 .nr 80 0
          .80
          .rm 80
          .nr 81 0
          .nr 38 24
          .if 0<0 .nr 81 0
          .nr 38 24
          .if 0<0 .nr 81 0
          .nr 38 24
          .if 0<0 .nr 81 0
          .81
          .rm 81
          .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .82
          .rm 82
          .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .83
          .rm 83
          .nr 38 1n
          .nr 79 0
          .nr 40 0+(0*0)
          .nr 80 +0
          .nr 41 0+(3*0)
          .nr 81 +0
          .nr 42 0+(3*0)
          .nr 82 +0
          .nr 43 0+(3*0)
          .nr 83 +0
          .nr TW 0
          .if t .if 0>1584i .tm Table at line 1675 file Input is too wide - 0 units
          .nr #I 120
          .in +(1584u-0u-120u)/2u
          .fc
          .nr #T 0-1
          .nr #a 0-1
          .eo
          .de T#
          .ds #d .d
          .if  .ds #d nl
          .mk ##
          .nr ## -1v
          .ls 1

     Vi/Ex Reference                                              USD:13-31

          .ls
          ..
          .ec
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          %)control-A>
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          /N<character>
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          {}
          .fc
          .nr T. 1
          .T# 1
          .in 0u
          .35
          .TE
          .if 0=0 .nr c. 1766-0-6
          .ft R
          .sp
          Before this copy is done, the previous contents of buffer
          .QT 1
          are moved into buffer
          .QT 2 ,
          .QT 2
          into buffer
          .QT 3 ,
          and so on.
          The contents of buffer
          .QT 9
          are discarded.
          In
          .CO vi ,
          text may be explicitly stored into the numeric buffers.
          In this case, the buffer rotation described above occurs before the
          replacement of the buffer's contents.
          The numeric buffers are only available in
          .LI visual
          and
          .LI open
          modes,
          and are not accessible by
          .CO ex
          in any way, although changed and deleted text is still stored there
          while in
          .CO ex
          mode.
          .sp
          When a

     USD:13-32                                              Vi/Ex Reference

          .CO vi
          command synopsis shows both a
          .LI [buffer]
          and a
          .LI [count] ,
          they may be presented in any order.
          .sp
          Finally, all buffers are either
          .QQ line
          or
          .QQ character
          oriented.
          All
          .CO ex
          commands which store text into buffers are line oriented.
          Some
          .CO vi
          commands which store text into buffers are line oriented,
          and some are character oriented; the description for each applicable
          .CO vi
          command notes whether text copied into buffers using the command
          is line or character oriented.
          In addition, the
          .CO vi
          command
          .CO "display buffers"
          displays the current orientation for each buffer.
          Generally, the only importance attached to this orientation is that
          if the buffer is subsequently inserted into the text, line oriented
          buffers create new lines for each of the lines they contain, and
          character oriented buffers create new lines for any lines
          .i other
          than the first and last lines they contain.
          The first and last lines are inserted into the text at the current
          cursor position, becoming part of the current line.
          If there is more than one line in the buffer, however, the current
          line itself will be split.
          .KY "unnamed buffer"
          .IP "unnamed buffer"
          The unnamed buffer is a text storage area which is used by commands
          that use or operate on a buffer when no buffer is specified by the user.
          If the command stores text into a buffer,
          the text is stored into the unnamed buffer even if a buffer is also
          specified by the user.
          It is not possible to append text to the unnamed buffer.
          If text is appended to a named buffer,
          the named buffer contains both the old and new text,
          while the unnamed buffer contains only the new text.
          There is no way to explicitly reference the unnamed buffer.
          .sp
          Historically, the contents of the unnamed buffer were discarded by many
          different commands, even ones that didn't store text into it.
          .EV Nex nvi

     Vi/Ex Reference                                              USD:13-33

          never discards the contents of the unnamed buffer until new text
          replaces them.
          .KY whitespace
          .IP whitespace
          The characters <tab> and <space>.
          .KY "<carriage-return>"
          .IP "<carriage-return>"
          The character represented by an ASCII
          .LI <control-M> .
          This character is almost always treated identically to a
          .LI <newline>
          character, but differs in that it can be escaped into the file text or
          into a command.
          .KY <newline>
          .IP <newline>
          The character represented by an ASCII
          .LI <control-J> .
          This character is almost always treated identically to a
          .LI <control-M>
          character, but differs in that it cannot be escaped into the file text or
          into a command.
          .oh 'Vi/Ex Reference (Vi Commands)''USD:13-%'
          .eh 'USD:13-%''Vi/Ex Reference (Vi Commands)'
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .SH 1 "Vi Description"
          .pp
          .CO Vi
          takes up the entire screen to display the edited file,
          except for the bottom line of the screen.
          The bottom line of the screen is used to enter
          .CO ex
          commands, and for
          .CO vi
          error and informational messages.
          If no other information is being displayed,
          the default display can show the current cursor row and cursor column,
          an indication of whether the file has been modified,
          and the current mode of the editor.
          See the
          .OP ruler
          and
          .OP showmode
          options for more information.

     USD:13-34                                              Vi/Ex Reference

          .pp
          Empty lines do not have any special representation on the screen,
          but lines on the screen that would logically come after the end of
          the file are displayed as a single tilde
          .PQ ~
          character.
          To differentiate between empty lines and lines consisting of only
          whitespace characters, use the
          .OP list
          option.
          Historically, implementations of
          .CO vi
          have also displayed some lines as single asterisk
          .PQ @
          characters.
          These were lines that were not correctly displayed, i.e. lines on the
          screen that did not correspond to lines in the file, or lines that did
          not fit on the current screen.
          .CO Nvi
          never displays lines in this fashion.
          .pp
          .CO Vi
          is a modeful editor, i.e. it has two modes,
          .QQ command
          mode and
          .QQ "text input"
          mode.
          When
          .CO vi
          first starts, it is in command mode.
          There are several commands that change
          .CO vi
          into text input mode.
          The
          .LI <escape>
          character is used to resolve the text input into the file,
          and exit back into command mode.
          In
          .CO vi
          command mode, the cursor is always positioned on the last column of
          characters which take up more than one column on the screen.
          In
          .CO vi
          text insert mode, the cursor is positioned on the first column of
          characters which take up more than one column on the screen.
          .pp
          When positioning the cursor to a new line and column,
          the type of movement is defined by the distance to the new cursor position.
          If the new position is close,
          the screen is scrolled to the new location.
          If the new position is far away,
          the screen is repainted so that the new position is on the screen.
          If the screen is scrolled,

     Vi/Ex Reference                                              USD:13-35

          it is moved a minimal amount,
          and the cursor line will usually appear at the top or bottom of the screen.
          If the screen is repainted,
          the cursor line will appear in the center of the screen,
          unless the cursor is sufficiently close to the beginning or end of the file
          that this isn't possible.
          If the
          .OP leftright
          option is set, the screen may be scrolled or repainted in a horizontal
          direction as well as in a vertical one.
          .pp
          A major difference between the historical
          .CO vi
          presentation and
          .CO nvi
          is in the scrolling and screen oriented position commands:
          .CO <control-B> ,
          .CO <control-D> ,
          .CO <control-E> ,
          .CO <control-F> ,
          .CO <control-U> ,
          .CO <control-Y> ,
          .CO H ,
          .CO L
          and
          .CO M .
          In historical implementations of
          .CO vi ,
          these commands acted on physical (as opposed to logical, or screen)
          lines.
          For lines that were sufficiently long in relation to the size of the
          screen, this meant that single line scroll commands might repaint the
          entire screen, scrolling or screen positioning commands might not change
          the screen or move the cursor at all, and some lines simply could not
          be displayed, even though
          .CO vi
          would edit the file that contained them.
          In
          .CO nvi ,
          these commands act on logical, i.e. screen lines.
          You are unlikely to notice any difference unless you are editing files
          with lines significantly longer than a screen width.
          .pp
          .CO Vi
          keeps track of the currently
          .QQ "most attractive"
          cursor position.
          Each command description (for commands that alter the current cursor
          position),
          specifies if the cursor is set to a specific location in the line,
          or if it is moved to the
          .QQ "most attractive cursor position" .
          The latter means that the cursor is moved to the cursor position that

     USD:13-36                                              Vi/Ex Reference

          is horizontally as close as possible to the current cursor position.
          If the current line is shorter than the cursor position
          .CO vi
          would select, the cursor is positioned on the last character in the line.
          (If the line is empty, the cursor is positioned on the first column
          of the line.)
          If a command moves the cursor to the most attractive position,
          it does not alter the current cursor position, and a subsequent
          movement will again attempt to move the cursor to that position.
          Therefore, although a movement to a line shorter than the currently
          most attractive position will cause the cursor to move to the end of
          that line, a subsequent movement to a longer line will cause the
          cursor to move back to the most attractive position.
          .pp
          In addition, the
          .CO $
          command makes the end of each line the most attractive cursor position
          rather than a specific column.
          .pp
          Each
          .CO vi
          command described below notes where the cursor ends up after it is
          executed.
          This position is described in terms of characters on the line, i.e.
          .QQ "the previous character" ,
          or,
          .QQ "the last character in the line" .
          This is to avoid needing to continually refer to on what part of the
          character the cursor rests.
          .pp
          The following words have special meaning for
          .CO vi
          commands.
          .KY "previous context"
          .IP "previous context"
          The position of the cursor before the command which caused the
          last absolute movement was executed.
          Each
          .CO vi
          command described in the next section that is considered an
          absolute movement is so noted.
          In addition, specifying
          .i any
          address to an
          .CO ex
          command is considered an absolute movement.
          .KY "motion"
          .IP "motion"
          A second
          .CO vi
          command can be used as an optional trailing argument to the
          .CO vi
          .CO < ,

     Vi/Ex Reference                                              USD:13-37

          .CO > ,
          .CO ! ,
          .CO c ,
          .CO d ,
          .CO y ,
          and (depending on the
          .OP tildeop
          option)
          .CO ~
          commands.
          This command indicates the end of the region of text that's affected by
          the command.
          The motion command may be either the command character repeated (in
          which case it means the current line) or a cursor movement command.
          In the latter case, the region affected by the command is from the
          starting or stopping cursor position which comes first in the file,
          to immediately before the starting or stopping cursor position which
          comes later in the file.
          Commands that operate on lines instead of using beginning and ending
          cursor positions operate on all of the lines that are wholly or
          partially in the region.
          In addition, some other commands become line oriented depending on
          where in the text they are used.
          The command descriptions below note these special cases.
          .sp
          The following commands may all be used as motion components for
          .CO vi
          commands:
          .sp
          .ne 12v
          .ft C
          .TS
          .if 0=1 .nr d. 2095-2095-1
          .de 35
          .ps 10
          .vs 40u
          .in 120u
          .if 0 .fi
          .if 1 .ad
          .if 1=0 .na
          ..
          .nf
          .nr #~ 0
          .if n .nr #~ 0.6n
          .ds #d .d
          .if  .ds #d nl
          .fc
          .nr 33 10
          .rm 80 81 82 83
          .nr 80 0
          .nr 38 264
          .if 0<0 .nr 80 0
          .nr 38 264

     USD:13-38                                              Vi/Ex Reference

          .if 0<0 .nr 80 0
          .nr 38 24
          .if 0<0 .nr 80 0
          .nr 38 24
          .if 0<0 .nr 80 0
          .nr 38 24
          .if 0<0 .nr 80 0
          .nr 38 24
          .if 0<0 .nr 80 0
          .nr 38 24
          .if 0<0 .nr 80 0
          .nr 38 24
          .if 0<0 .nr 80 0
          .nr 38 24
          .if 0<0 .nr 80 0
          .nr 38 24
          .if 0<0 .nr 80 0
          .nr 38 24
          .if 0<0 .nr 80 0
          .nr 38 24
          .if 0<0 .nr 80 0
          .80
          .rm 80
          .nr 81 0
          .nr 38 264
          .if 0<0 .nr 81 0
          .nr 38 264
          .if 0<0 .nr 81 0
          .nr 38 288
          .if 0<0 .nr 81 0
          .nr 38 24
          .if 0<0 .nr 81 0
          .nr 38 24
          .if 0<0 .nr 81 0
          .nr 38 24
          .if 0<0 .nr 81 0
          .nr 38 24
          .if 0<0 .nr 81 0
          .nr 38 48
          .if 0<0 .nr 81 0
          .nr 38 288
          .if 0<0 .nr 81 0
          .nr 38 24
          .if 0<0 .nr 81 0
          .nr 38 24
          .if 0<0 .nr 81 0
          .nr 38 24
          .if 0<0 .nr 81 0
          .81
          .rm 81
          .nr 82 0
          .nr 38 264
          .if 0<0 .nr 82 0

     Vi/Ex Reference                                              USD:13-39

          .nr 38 168
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .nr 38 48
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .nr 38 24
          .if 0<0 .nr 82 0
          .82
          .rm 82
          .nr 83 0
          .nr 38 264
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .nr 38 24
          .if 0<0 .nr 83 0
          .83
          .rm 83
          .nr 38 1n
          .nr 79 0
          .nr 40 0+(0*0)
          .nr 80 +0

     USD:13-40                                              Vi/Ex Reference

          .nr 41 0+(3*0)
          .nr 81 +0
          .nr 42 0+(3*0)
          .nr 82 +0
          .nr 43 0+(3*0)
          .nr 83 +0
          .nr TW 0
          .if t .if 0>1584i .tm Table at line 2017 file Input is too wide - 0 units
          .fc
          .nr #T 0-1
          .nr #a 0-1
          .eo
          .de T#
          .ds #d .d
          .if  .ds #d nl
          .mk ##
          .nr ## -1v
          .ls 1
          .ls
          ..
          .ec
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          <<ccoonnttrrooll--HM>>
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          <$csopnatcreo>l-P>
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          ')<character>
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          ,/
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          ;B
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          FH
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          MT
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          [^]

     Vi/Ex Reference                                              USD:13-41

          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          `e<character>
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          hk
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          nw
          .ta 0u 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          |}
          .fc
          .nr T. 1
          .T# 1
          .35
          .TE
          .if 0=0 .nr c. 2296-0-14
          .ft R
          .sp
          The optional count prefix available for some of the
          .CO vi
          commands that take motion commands,
          or the count prefix available for the
          .CO vi
          commands that are used as motion components,
          may be included and is
          .i always
          considered part of the motion argument.
          For example, the commands
          .QT c2w
          and
          .QT 2cw
          are equivalent, and the region affected by the
          .CO c
          command is two words of text.
          In addition,
          if the optional count prefix is specified for both the
          .CO vi
          command and its motion component,
          the effect is multiplicative and is considered part of the motion argument.
          For example, the commands
          .QT 4cw
          and
          .QT 2c2w
          are equivalent, and the region affected by the
          .CO c
          command is four words of text.
          .KY "count"

     USD:13-42                                              Vi/Ex Reference

          .IP "count"
          A positive number used as an optional argument to most commands,
          either to give a size or a position (for display or movement commands),
          or as a repeat count (for commands that modify text).
          The count argument is always optional and defaults to 1 unless otherwise
          noted in the command description.
          .sp
          When a
          .CO vi
          command synopsis shows both a
          .LI [buffer]
          and
          .LI [count] ,
          they may be presented in any order.
          .KY word
          .IP word
          Generally, in languages where it is applicable,
          .CO vi
          recognizes two kinds of words.
          First, a sequence of letters, digits and underscores,
          delimited at both ends by:
          characters other than letters, digits, or underscores,
          the beginning or end of a line, and the beginning or end of the file.
          Second, a sequence of characters other than letters, digits, underscores,
          or whitespace characters, delimited at both ends by: a letter, digit,
          underscore, or whitespace character,
          the beginning or end of a line, and the beginning or end of the file.
          For example, the characters
          .QT " !@#abc$%^ "
          contain three words:
          .QT "!@#" ,
          .QT "abc"
          and
          .QT "$%^" .
          .sp
          Groups of empty lines (or lines containing only whitespace characters)
          are treated as a single word.
          .KY "bigword"
          .IP "bigword"
          A set of non-whitespace characters preceded and followed by whitespace
          characters or the beginning or end of the file or line.
          For example, the characters
          .QT " !@#abc$%^ "
          contain one bigword:
          .QT "!@#abc$%^" .
          .sp
          Groups of empty lines (or lines containing only whitespace characters)
          are treated as a single bigword.
          .KY "paragraph"
          .IP "paragraph"
          An area of text that begins with either the beginning of a file,
          an empty line, or a section boundary, and continues until either
          an empty line, section boundary, or the end of the file.

     Vi/Ex Reference                                              USD:13-43

          .sp
          Groups of empty lines (or lines containing only whitespace characters)
          are treated as a single paragraph.
          .sp
          Additional paragraph boundaries can be defined using the
          .OP paragraphs
          option.
          .KY "section"
          .IP "section"
          An area of text that starts with the beginning of the file or a line
          whose first character is an open brace
          .PQ {
          and continues until the next section or the end of the file.
          .sp
          Additional section boundaries can be defined using the
          .OP sections
          option.
          .KY "sentence"
          .IP "sentence"
          An area of text that begins with either the beginning of the file or the
          first nonblank character following the previous sentence, paragraph, or
          section boundary and continues until the end of the file or a period
          .PQ .
          exclamation point
          .PQ !
          or question mark
          .PQ ?
          character,
          followed by either an end-of-line or two whitespace characters.
          Any number of closing parentheses
          .PQ ) ,
          brackets
          .PQ ] ,
          double-quote
          .PQ """"
          or single quote
          .PQ '
          characters can appear between the period, exclamation point,
          or question mark and the whitespace characters or end-of-line.
          .sp
          Groups of empty lines (or lines containing only whitespace characters)
          are treated as a single sentence.
          .SH 1 "Vi Commands"
          .pp
          The following section describes the commands available in the command
          mode of the
          .CO vi
          editor.
          In each entry below, the tag line is a usage synopsis for the command
          character.
          In addition, the final line and column the cursor rests upon,
          and any options which affect the command are noted.
          .KY <control-A>

     USD:13-44                                              Vi/Ex Reference

          .IP "[count] <control-A>"
          Search forward
          .LI count
          times for the current word.
          The current word begins at the first non-whitespace character on or
          after the current cursor position,
          and extends up to the next non-word character or the end of the line.
          The search is literal, i.e. no characters in the word have any special
          meaning in terms of Regular Expressions.
          It is an error if no matching pattern is found between the starting position
          and the end of the file.
          .sp
          The
          .CO <control-A>
          command is an absolute movement.
          The
          .CO <control-A>
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Set to the line where the word is found.
          .SP Column:
          Set to the first character of the word.
          .SP Options:
          Affected by the
          .OP ignorecase
          and
          .OP wrapscan
          options.
          .SE
          .KY <control-B>
          .IP "[count] <control-B>"
          Page backward
          .LI count
          screens.
          Two lines of overlap are maintained, if possible,
          by displaying the window starting at line
          .LI "(top_line - count * window_size) + 2" ,
          where
          .LI window_size
          is the value of the
          .OP window
          option.
          (In the case of split screens, this size is corrected to the
          current screen size.)
          It is an error if the movement is past the beginning of the file.
          .SS
          .SP Line:
          Set to the last line of text displayed on the screen.
          .SP Column:

     Vi/Ex Reference                                              USD:13-45

          Set to the first nonblank character of the line.
          .SP Options:
          Affected by the
          .OP window
          option.
          .SE
          .KY <control-D>
          .IP "[count] <control-D>"
          Scroll forward
          .LI count
          lines.
          If
          .LI count
          is not specified, scroll forward the number of lines specified by the last
          .CO <control-D>
          or
          .CO <control-U>
          command.
          If this is the first
          .CO <control-D>
          or
          .CO <control-U>
          command,
          scroll forward half the number of lines in the screen.
          (In the case of split screens, the default scrolling distance is
          corrected to half the current screen size.)
          It is an error if the movement is past the end of the file.
          .SS
          .SP Line:
          Set to the current line plus the number of lines scrolled.
          .SP Column:
          Set to the first nonblank character of the line.
          .SP Options:
          None.
          .SE
          .KY <control-E>
          .IP "[count] <control-E>"
          Scroll forward
          .LI count
          lines, leaving the cursor on the current line and column, if possible.
          It is an error if the movement is past the end of the file.
          .SS
          .SP Line:
          Unchanged unless the current line scrolls off the screen,
          in which case it is set to the first line on the screen.
          .SP Column:
          Unchanged unless the current line scrolls off the screen,
          in which case it is set to the most attractive cursor position.
          .SP Options:
          None.
          .SE
          .KY <control-F>
          .IP "[count] <control-F>"

     USD:13-46                                              Vi/Ex Reference

          Page forward
          .LI count
          screens.
          Two lines of overlap are maintained, if possible,
          by displaying the window starting at line
          .LI "top_line + count * window_size - 2" ,
          where
          .LI window_size
          is the value of the
          .OP window
          option.
          (In the case of split screens, this size is corrected to the
          current screen size.)
          It is an error if the movement is past the end of the file.
          .SS
          .SP Line:
          Set to the first line on the screen.
          .SP Column:
          Set to the first nonblank character of the current line.
          .SP Options:
          Affected by the
          .OP window
          option.
          .SE
          .KY <control-G>
          .IP "<control-G>"
          Display the file information.
          The information includes the current pathname, the current line,
          the number of total lines in the file, the current line as a percentage
          of the total lines in the file, if the file has been modified,
          was able to be locked, if the file's name has been changed,
          and if the edit session is read-only.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY <control-H>
          .IP "[count] <control-H>"
          .Ip "[count] h"
          Move the cursor back
          .LI count
          characters in the current line.
          It is an error if the cursor is on the first character in the line.
          .sp
          The
          .CO <control-H>
          and
          .CO h
          commands may be used as the motion component of other

     Vi/Ex Reference                                              USD:13-47

          .CO vi
          commands,
          in which case any text copied into a buffer is character oriented.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the
          .LI "current - count"
          character, or, the first character in the line if
          .LI count
          is greater than or equal to the number of characters in the line
          before the cursor.
          .SP Options:
          None.
          .SE
          .KY <control-J>
          .IP "[count] <control-J>"
          .KY <control-N>
          .Ip "[count] <control-N>"
          .KY j
          .Ip "[count] j"
          Move the cursor down
          .LI count
          lines without changing the current column.
          It is an error if the movement is past the end of the file.
          .sp
          The
          .CO <control-J> ,
          .CO <control-N>
          and
          .CO j
          commands may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          line oriented.
          .SS
          .SP Line:
          Set to the current line plus
          .LI count .
          .SP Column:
          The most attractive cursor position.
          .SP Options:
          None.
          .SE
          .KY <control-L>
          .IP "<control-L>"
          .KY <control-R>
          .Ip "<control-R>"
          Repaint the screen.
          .SS
          .SP Line:
          Unchanged.

     USD:13-48                                              Vi/Ex Reference

          .SP Column:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY <control-M>
          .IP "[count] <control-M>"
          .KY +
          .Ip "[count] +"
          Move the cursor down
          .LI count
          lines to the first nonblank character of that line.
          It is an error if the movement is past the end of the file.
          .sp
          The
          .CO <control-M>
          and
          .CO +
          commands may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          line oriented.
          .SS
          .SP Line:
          Set to the current line plus
          .LI count .
          .SP Column:
          Set to the first nonblank character in the line.
          .SP Options:
          None.
          .SE
          .KY <control-P>
          .IP "[count] <control-P>"
          .KY k
          .Ip "[count] k"
          Move the cursor up
          .LI count
          lines, without changing the current column.
          It is an error if the movement is past the beginning of the file.
          .sp
          The
          .CO <control-P>
          and
          .CO k
          commands may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          line oriented.
          .SS
          .SP Line:
          Set to the current line minus
          .LI count .
          .SP Column:

     Vi/Ex Reference                                              USD:13-49

          The most attractive cursor position.
          .SP Options:
          None.
          .SE
          .KY <control-T>
          .IP "<control-T>"
          Return to the most recent tag context.
          The
          .CO <control-T>
          command is an absolute movement.
          .SS
          .SP Line:
          Set to the context of the previous tag command.
          .SP Column:
          Set to the context of the previous tag command.
          .SP Options:
          None.
          .SE
          .KY <control-U>
          .IP "[count] <control-U>"
          Scroll backward
          .LI count
          lines.
          If
          .LI count
          is not specified, scroll backward the number of lines specified by the
          last
          .CO <control-D>
          or
          .CO <control-U>
          command.
          If this is the first
          .CO <control-D>
          or
          .CO <control-U>
          command,
          scroll backward half the number of lines in the screen.
          (In the case of split screens, the default scrolling distance is
          corrected to half the current screen size.)
          It is an error if the movement is past the beginning of the file.
          .SS
          .SP Line:
          Set to the current line minus the amount scrolled.
          .SP Column:
          Set to the first nonblank character in the line.
          .SP Options:
          None.
          .SE
          .KY <control-W>
          .IP "<control-W>"
          Switch to the next lower screen in the window, or, to the first
          screen if there are no lower screens in the window.
          .SS

     USD:13-50                                              Vi/Ex Reference

          .SP Line:
          Set to the previous cursor position in the window.
          .SP Column:
          Set to the previous cursor position in the window.
          .SP Options:
          None.
          .SE
          .KY <control-Y>
          .IP "[count] <control-Y>"
          Scroll backward
          .LI count
          lines, leaving the current line and column as is, if possible.
          It is an error if the movement is past the beginning of the file.
          .SS
          .SP Line:
          Unchanged unless the current line scrolls off the screen,
          in which case it is set to the last line of text displayed
          on the screen.
          .SP Column:
          Unchanged unless the current line scrolls off the screen,
          in which case it is the most attractive cursor position.
          .SP Options:
          None.
          .SE
          .KY <control-Z>
          .IP "<control-Z>"
          Suspend the current editor session.
          If the file has been modified since it was last completely written,
          and the
          .OP autowrite
          option is set, the file is written before the editor session is
          suspended.
          If this write fails, the editor session is not suspended.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Unchanged.
          .SP Options:
          Affected by the
          .OP autowrite
          option.
          .SE
          .KY <escape>
          .IP "<escape>"
          Execute
          .CO ex
          commands or cancel partial commands.
          If an
          .CO ex
          command is being entered (e.g.
          .CO / ,
          .CO ? ,

     Vi/Ex Reference                                              USD:13-51

          .CO :
          or
          .CO ! ),
          the command is executed.
          If a partial command has been entered, e.g.
          .QT "[0-9]*" ,
          or
          .QT "[0-9]*[!<>cdy]" ,
          the command is cancelled.
          Otherwise, it is an error.
          .SS
          .SP Line:
          When an
          .CO ex
          command is being executed, the current line is set as described for
          that command.
          Otherwise, unchanged.
          .SP Column:
          When an
          .CO ex
          command is being executed, the current column is set as described for
          that command.
          Otherwise, unchanged.
          .SP Options:
          None.
          .SE
          .KY <control-]>
          .IP "<control-]>"
          Push a tag reference onto the tag stack.
          The tags files (see the
          .OP tags
          option for more information) are searched for a tag matching the
          current word.
          The current word begins at the first non-whitespace character on or
          after the current cursor position,
          and extends up to the next non-word character or the end of the line.
          If a matching tag is found, the current file is discarded and the
          file containing the tag reference is edited.
          .sp
          If the current file has been modified since it was last completely
          written, the command will fail.
          The
          .CO <control-]>
          command is an absolute movement.
          .SS
          .SP Line:
          Set to the line containing the matching tag string.
          .SP Column:
          Set to the start of the matching tag string.
          .SP Options:
          Affected by the
          .OP tags
          and

     USD:13-52                                              Vi/Ex Reference

          .OP taglength
          options.
          .SE
          .KY <control-^>
          .IP "<control-^>"
          Switch to the most recently edited file.
          .sp
          If the file has been modified since it was last completely written,
          and the
          .OP autowrite
          option is set, the file is written out.
          If this write fails, the command will fail.
          Otherwise, if the current file has been modified since it was last
          completely written, the command will fail.
          .SS
          .SP Line:
          Set to the line the cursor was on when the file was last edited.
          .SP Column:
          Set to the column the cursor was on when the file was last edited.
          .SP Options:
          Affected by the
          .OP autowrite
          option.
          .SE
          .KY <space>
          .IP "[count] <space>"
          .KY l
          .Ip "[count] l"
          Move the cursor forward
          .LI count
          characters without changing the current line.
          It is an error if the cursor is on the last character in the line.
          .sp
          The
          .CO <space>
          and
          .CO l
          commands may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          In addition, these commands may be used as the motion components
          of other commands when the cursor is on the last character in the
          line, without error.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the current character plus the next
          .LI count
          characters, or to the last character on the line if
          .LI count
          is greater than the number of characters in the line after the

     Vi/Ex Reference                                              USD:13-53

          current character.
          .SP Options:
          None.
          .SE
          .KY !
          .IP "[count] ! motion shell-argument(s)<carriage-return>"
          Replace text with results from a shell command.
          Pass the lines specified by the
          .LI count
          and
          .LI motion
          arguments as standard input to the program named by the
          .OP shell
          option, and replace those lines with the output (both
          standard error and standard output) of that command.
          .sp
          After the motion is entered,
          .CO vi
          prompts for arguments to the shell command.
          .sp
          Within those arguments,
          .QT %
          and
          .QT #
          characters are expanded to the current and alternate pathnames,
          respectively.
          The
          .QT !
          character is expanded with the command text of the previous
          .CO !
          or
          .CO :!
          commands.
          (Therefore, the command
          .CO !<motion>!
          repeats the previous
          .CO !
          command.)
          The special meanings of
          .QT % ,
          .QT #
          and
          .QT !
          can be overridden by escaping them with a backslash.
          If no
          .CO !
          or
          .CO :!
          command has yet been executed,
          it is an error to use an unescaped
          .QT !
          character as a shell argument.
          The

     USD:13-54                                              Vi/Ex Reference

          .CO !
          command does
          .i not
          do shell expansion on the strings provided as arguments.
          If any of the above expansions change the arguments the user entered,
          the command is redisplayed at the bottom of the screen.
          .sp
          .CO Vi
          then executes the program named by the
          .OP shell
          option, with a
          .b -c
          flag followed by the arguments (which are bundled into a single argument).
          .sp
          The
          .CO !
          command is permitted in an empty file.
          .sp
          If the file has been modified since it was last completely written,
          the
          .CO !
          command will warn you.
          .SS
          .SP Line:
          The first line of the replaced text.
          .SP Column:
          The first column of the replaced text.
          .SP Options:
          Affected by the
          .OP shell
          option.
          .SE
          .KY #
          .IP "[count] # #|+|-"
          Increment or decrement the number referenced by the cursor.
          If the trailing character is a
          .LI +
          or
          .LI # ,
          the number is incremented by
          .LI count .
          If the trailing character is a
          .LI - ,
          the number is decremented by
          .LI count .
          .sp
          A leading
          .QT 0X
          or
          .QT 0x
          causes the number to be interpreted as a hexadecimal number.
          Otherwise, a leading
          .QT 0

     Vi/Ex Reference                                              USD:13-55

          causes the number to be interpreted as an octal number, unless a non-octal
          digit is found as part of the number.
          Otherwise, the number is interpreted as a decimal number, and may
          have a leading
          .LI +
          or
          .LI -
          sign.
          The current number begins at the first non-blank character at or after
          the current cursor position, and extends up to the end of the line or
          the first character that isn't a possible character for the numeric type.
          The format of the number (e.g. leading 0's, signs) is retained unless
          the new value cannot be represented in the previous format.
          .sp
          Octal and hexadecimal numbers, and the result of the operation, must fit
          into an
          .QT "unsigned long" .
          Similarly, decimal numbers and their result must fit into a
          .QT "signed long" .
          It is an error to use this command when the cursor is not positioned at
          a number.
          .sp
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the first character in the cursor number.
          .SP Options:
          None.
          .SE
          .KY $
          .IP "[count] $"
          Move the cursor to the end of a line.
          If
          .LI count
          is specified, the cursor moves down
          .LI "count - 1"
          lines.
          .sp
          It is not an error to use the
          .CO $
          command when the cursor is on the last character in the line or
          when the line is empty.
          .sp
          The
          .CO $
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented, unless the cursor is at, or before the first
          nonblank character in the line, in which case it is line oriented.
          It is not an error to use the
          .CO $

     USD:13-56                                              Vi/Ex Reference

          command as a motion component when the cursor is on the last character
          in the line, although it is an error when the line is empty.
          .SS
          .SP Line:
          Set to the current line plus
          .LI count
          minus 1.
          .SP Column:
          Set to the last character in the line.
          .SP Options:
          None.
          .SE
          .KY %
          .IP %
          Move to the matching character.
          The cursor moves to the parenthesis or curly brace which
          .i matches
          the parenthesis or curly brace found at the current cursor position
          or which is the closest one to the right of the cursor on the line.
          It is an error to execute the
          .CO %
          command on a line without a parenthesis or curly brace.
          Historically, any
          .LI count
          specified to the
          .CO %
          command was ignored.
          .sp
          The
          .CO %
          command is an absolute movement.
          The
          .CO %
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented, unless the starting point of the region is at
          or before the first nonblank character on its line, and the ending
          point is at or after the last nonblank character on its line, in
          which case it is line oriented.
          .SS
          .SP Line:
          Set to the line containing the matching character.
          .SP Column:
          Set to the matching character.
          .SP Options:
          None.
          .SE
          .KY &
          .IP "&"
          Repeat the previous substitution command on the current line.
          .sp
          Historically, any

     Vi/Ex Reference                                              USD:13-57

          .LI count
          specified to the
          .CO &
          command was ignored.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Unchanged if the cursor was on the last character in the line,
          otherwise set to the first nonblank character in the line.
          .SP Options:
          Affected by the
          .OP edcompatible ,
          .OP extended ,
          .OP ignorecase
          and
          .OP magic
          options.
          .SE
          .KY SQUOTE<character>
          .IP '<character>
          .KY `<character>
          .Ip `<character>
          Return to a context marked by the character
          .LI <character> .
          If
          .LI <character>
          is the
          .QT '
          or
          .QT `
          character, return to the previous context.
          If
          .LI <character>
          is any other character,
          return to the context marked by that character (see the
          .CO m
          command for more information).
          If the command is the
          .CO '
          command, only the line value is restored,
          and the cursor is placed on the first nonblank character of that line.
          If the command is the
          .CO `
          command, both the line and column values are restored.
          .sp
          It is an error if the context no longer exists because of
          line deletion.
          (Contexts follow lines that are moved, or which are deleted
          and then restored.)
          .sp
          The
          .CO '

     USD:13-58                                              Vi/Ex Reference

          and
          .CO `
          commands are both absolute movements.
          They may be used as a motion component for other
          .CO vi
          commands.
          For the
          .CO '
          command, any text copied into a buffer is line oriented.
          For the
          .CO `
          command,
          any text copied into a buffer is character oriented,
          unless it both starts and stops at the first character in the line,
          in which case it is line oriented.
          In addition, when using the
          .CO `
          command as a motion component,
          commands which move backward and started at the first character in the line,
          or move forward and ended at the first character in the line,
          are corrected to the last character of the line preceding the starting and
          ending lines, respectively.
          .SS
          .SP Line:
          Set to the line from the context.
          .SP Column:
          Set to the first nonblank character in the line, for the
          .CO '
          command, and set to the context's column for the
          .CO `
          command.
          .SP Options:
          None.
          .SE
          .KY (
          .IP "[count] ("
          Back up
          .LI count
          sentences.
          .sp
          The
          .CO (
          command is an absolute movement.
          The
          .CO (
          command may be used as the motion component of other
          .CO vi
          commands,
          in which case any text copied into a buffer is character oriented,
          unless the starting and stopping points of the region are the first
          character in the line,
          in which case it is line oriented.
          If it is line oriented,

     Vi/Ex Reference                                              USD:13-59

          the starting point of the region is adjusted to be the end of the line
          immediately before the starting cursor position.
          .SS
          .SP Line:
          Set to the line containing the beginning of the sentence.
          .SP Column:
          Set to the first nonblank character of the sentence.
          .SP Options:
          Affected by the
          .OP lisp
          option.
          .SE
          .KY )
          .IP "[count] )"
          Move forward
          .LI count
          sentences.
          .sp
          The
          .CO )
          command is an absolute movement.
          The
          .CO )
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented, unless the starting point of the region is the
          first character in the line, in which case it is line oriented.
          In the latter case, if the stopping point of the region is also
          the first character in the line, it is adjusted to be the end of the
          line immediately before it.
          .SS
          .SP Line:
          Set to the line containing the beginning of the sentence.
          .SP Column:
          Set to the first nonblank character of the sentence.
          .SP Options:
          Affected by the
          .OP lisp
          option.
          .SE
          .KY ,
          .IP "[count] ,"
          Reverse find character
          .LI count
          times.
          Reverse the last
          .CO F ,
          .CO f ,
          .CO T
          or
          .CO t
          command, searching the other way in the line,

     USD:13-60                                              Vi/Ex Reference

          .LI count
          times.
          It is an error if a
          .CO F ,
          .CO f ,
          .CO T
          or
          .CO t
          command has not been performed yet.
          .sp
          The
          .CO ,
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the searched-for character for the
          .CO F
          and
          .CO f
          commands,
          before the character for the
          .CO t
          command
          and after the character for the
          .CO T
          command.
          .SP Options:
          None.
          .SE
          .KY MINUSSIGN
          .IP "[count] -"
          Move to the first nonblank of the previous line,
          .LI count
          times.
          .sp
          It is an error if the movement is past the beginning of the file.
          .sp
          The
          .CO -
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          line oriented.
          .SS
          .SP Line:
          Set to the current line minus
          .LI count .
          .SP Column:

     Vi/Ex Reference                                              USD:13-61

          Set to the first nonblank character in the line.
          .SP Options:
          None.
          .SE
          .KY .
          .IP "[count] ."
          Repeat the last
          .CO vi
          command that modified text.
          The repeated command may be a command and motion component combination.
          If
          .LI count
          is specified, it replaces
          .i both
          the count specified for the repeated command, and, if applicable, for
          the repeated motion component.
          If
          .LI count
          is not specified, the counts originally specified to the command being
          repeated are used again.
          .sp
          As a special case, if the
          .CO .
          command is executed immediately after the
          .CO u
          command, the change log is rolled forward or backward, depending on
          the action of the
          .CO u
          command.
          .SS
          .SP Line:
          Set as described for the repeated command.
          .SP Column:
          Set as described for the repeated command.
          .SP Options:
          None.
          .SE
          .KY /RE/
          .IP "/RE<carriage-return>"
          .Ip "/RE/ [offset]<carriage-return>"
          .KY ?RE?
          .Ip "?RE<carriage-return>"
          .Ip "?RE? [offset]<carriage-return>"
          .KY N
          .Ip "N"
          .KY n
          .Ip "n"
          Search forward or backward for a regular expression.
          The commands beginning with a slash
          .PQ /
          character are forward searches, the commands beginning with a
          question mark
          .PQ ?

     USD:13-62                                              Vi/Ex Reference

          are backward searches.
          .CO Vi
          prompts with the leading character on the last line of the screen
          for a string.
          It then searches forward or backward in the file for the next
          occurrence of the string, which is interpreted as a Basic Regular
          Expression.
          .sp
          The
          .CO /
          and
          .CO ?
          commands are absolute movements.
          They may be used as the motion components of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented, unless the search started and ended on
          the first column of a line, in which case it is line oriented.
          In addition, forward searches ending at the first character of a line,
          and backward searches beginning at the first character in the line,
          are corrected to begin or end at the last character of the previous line.
          (Note, forward and backward searches can occur for both
          .CO /
          and
          .CO ?
          commands, if the
          .OP wrapscan
          option is set.)
          .sp
          If an offset from the matched line is specified (i.e. a trailing
          .QT /
          or
          .QT ?
          character is followed by a signed offset), the buffer will always
          be line oriented (e.g.
          .QT /string/+0
          will always guarantee a line orientation).
          .sp
          The
          .CO N
          command repeats the previous search, but in the reverse direction.
          The
          .CO n
          command repeats the previous search.
          If either the
          .CO N
          or
          .CO n
          commands are used as motion components for the
          .CO !
          command, you will not be prompted for the text of the bang command;
          instead the previous bang command will be executed.
          .sp

     Vi/Ex Reference                                              USD:13-63

          Missing RE's (e.g.
          .QT //<carriage-return> ,
          .QT /<carriage-return> ,
          .QT ??<carriage-return> ,
          or
          .QT ?<carriage-return>
          search for the last search RE, in the indicated direction.
          .sp
          Searches may be interrupted using the
          .LI <interrupt>
          character.
          .sp
          Multiple search patterns may be grouped together by delimiting
          them with semicolons and zero or more whitespace characters, e.g.
          .LI "/foo/ ; ?bar?"
          searches forward for
          .LI foo
          and then, from that location, backwards for
          .LI bar .
          When search patterns are grouped together in this manner,
          the search patterns are evaluated left to right with the
          final cursor position determined by the last search pattern.
          .sp
          It is also permissible to append a
          .CO z
          command to the search strings, e.g.
          .LI "/foo/ z."
          searches forward for the next occurrence of
          .LI foo ,
          and then positions that line in the middle of screen.
          .SS
          .SP Line:
          Set to the line in which the match occurred.
          .SP Column:
          Set to the first character of the matched string.
          .SP Options:
          Affected by the
          .OP edcompatible ,
          .OP extended ,
          .OP ignorecase ,
          .OP magic ,
          and
          .OP wrapscan
          options.
          .SE
          .KY 0
          .IP "0"
          Move to the first character in the current line.
          It is not an error to use the
          .CO 0
          command when the cursor is on the first character in the line,
          .sp
          The

     USD:13-64                                              Vi/Ex Reference

          .CO 0
          command may be used as the motion component of other
          .CO vi
          commands,
          in which case it is an error if the cursor is on the first character
          in the line,
          and any text copied into a buffer is character oriented.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the first character in the line.
          .SP Options:
          None.
          .SE
          .KY :
          .IP ":"
          Execute an
          .CO ex
          command.
          .CO Vi
          prompts for an
          .CO ex
          command on the last line of the screen, using a colon
          .PQ :
          character.
          The command is terminated by a
          .LI <carriage-return> ,
          .LI <newline>
          or
          .LI <escape>
          character; all of these characters may be escaped by using a
          .LI "<literal-next>"
          character.
          The command is then executed.
          .sp
          If the
          .CO ex
          command writes to the screen,
          .CO vi
          will prompt the user for a
          .LI <carriage-return>
          before continuing
          when the
          .CO ex
          command finishes.
          Large amounts of output from the
          .CO ex
          command will be paged for the user, and the user prompted for a
          .LI <carriage-return>
          or
          .LI <space>
          key to continue.

     Vi/Ex Reference                                              USD:13-65

          In some cases, a quit (normally a
          .QQ q
          character) or
          .LI <interrupt>
          may be entered to interrupt the
          .CO ex
          command.
          .sp
          When the
          .CO ex
          command finishes, and the user is prompted to resume visual mode,
          it is also possible to enter another
          .QT :
          character followed by another
          .CO ex
          command.
          .SS
          .SP Line:
          The current line is set as described for the
          .CO ex
          command.
          .SP Column:
          The current column is set as described for the
          .CO ex
          command.
          .SP Options:
          Affected as described for the
          .CO ex
          command.
          .SE
          .KY ;
          .IP "[count] ;"
          Repeat the last character find
          .LI count
          times.
          The last character find is one of the
          .CO F ,
          .CO f ,
          .CO T
          or
          .CO t
          commands.
          It is an error if a
          .CO F ,
          .CO f ,
          .CO T
          or
          .CO t
          command has not been performed yet.
          .sp
          The
          .CO ;
          command may be used as the motion component of other

     USD:13-66                                              Vi/Ex Reference

          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the searched-for character for the
          .CO F
          and
          .CO f
          commands,
          before the character for the
          .CO t
          command
          and after the character for the
          .CO T
          command.
          .SP Options:
          None.
          .SE
          .KY <
          .IP "[count] < motion"
          .KY >
          .Ip "[count] > motion"
          Shift lines left or right.
          Shift the number of lines in the region specified by the
          .LI count
          and
          .LI motion
          left (for the
          .CO <
          command) or right (for the
          .CO >
          command) by the number of columns specified by the
          .OP shiftwidth
          option.
          Only whitespace characters are deleted when shifting left.
          Once the first character in the line no longer contains a whitespace
          character, the command will succeed,
          but the line will not be modified.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the first nonblank character in the line.
          .SP Options:
          Affected by the
          .OP shiftwidth
          option.
          .SE
          .KY @
          .IP "@ buffer"

     Vi/Ex Reference                                              USD:13-67

          Execute a named buffer.
          Execute the named buffer as
          .CO vi
          commands.
          The buffer may include
          .CO ex
          commands, too, but they must be expressed as a
          .CO :
          command.
          If the buffer is line oriented,
          .LI <newline>
          characters are logically appended to each line of the buffer.
          If the buffer is character oriented,
          .LI <newline>
          characters are logically appended to all but the last line in the buffer.
          .sp
          If the buffer name is
          .QT @ ,
          or
          .QT * ,
          then the last buffer executed shall be used.
          It is an error to specify
          .QT @@
          or
          .QT @*
          if there were no previous buffer executions.
          The text of a buffer may contain a
          .CO @
          command,
          and it is possible to create infinite loops in this manner.
          (The
          .LI <interrupt>
          character may be used to interrupt the loop.)
          .SS
          .SP Line:
          The current line is set as described for the command(s).
          .SP Column:
          The current column is set as described for the command(s).
          .SP Options:
          None.
          .SE
          .KY A
          .IP "[count] A"
          Enter input mode, appending the text after the end of the line.
          If
          .LI count
          is specified, the text is repeatedly input
          .LI "count - 1"
          more times after input mode is exited.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:

     USD:13-68                                              Vi/Ex Reference

          Set to the last character entered.
          .SP Options:
          Affected by the
          .OP altwerase ,
          .OP autoindent ,
          .OP beautify ,
          .OP showmatch ,
          .OP ttywerase
          and
          .OP wrapmargin
          options.
          .SE
          .KY B
          .IP "[count] B"
          Move backward
          .LI count
          bigwords.
          Move the cursor backward to the beginning of a bigword by repeating the
          following algorithm: if the current position is at the beginning of a
          bigword or the character at the current position cannot be part of a bigword,
          move to the first character of the preceding bigword.
          Otherwise, move to the first character of the bigword at the current position.
          If no preceding bigword exists on the current line, move to the first
          character of the last bigword on the first preceding line that contains a
          bigword.
          .sp
          The
          .CO B
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Set to the line containing the word selected.
          .SP Column:
          Set to the first character of the word selected.
          .SP Options:
          None.
          .SE
          .KY C
          .IP "[buffer] [count] C"
          Change text from the current position to the end-of-line.
          If
          .LI count
          is specified, the input text replaces from the current position to
          the end-of-line, plus
          .LI "count - 1"
          subsequent lines.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:

     Vi/Ex Reference                                              USD:13-69

          Set to the last character entered.
          .SP Options:
          Affected by the
          .OP altwerase ,
          .OP autoindent ,
          .OP beautify ,
          .OP showmatch ,
          .OP ttywerase
          and
          .OP wrapmargin
          options.
          .SE
          .KY D
          .IP "[buffer] D"
          Delete text from the current position to the end-of-line.
          .sp
          It is not an error to execute the
          .CO D
          command on an empty line.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the character before the current character, or, column 1 if
          the cursor was on column 1.
          .SP Options:
          None.
          .SE
          .KY E
          .IP "[count] E"
          Move forward
          .LI count
          end-of-bigwords.
          Move the cursor forward to the end of a bigword by repeating the
          following algorithm: if the current position is the end of a
          bigword or the character at that position cannot be part of a bigword,
          move to the last character of the following bigword.
          Otherwise, move to the last character of the bigword at the current
          position.
          If no succeeding bigword exists on the current line,
          move to the last character of the first bigword on the next following
          line that contains a bigword.
          .sp
          The
          .CO E
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Set to the line containing the word selected.
          .SP Column:

     USD:13-70                                              Vi/Ex Reference

          Set to the last character of the word selected.
          .SP Options:
          None.
          .SE
          .KY F
          .IP "[count] F <character>"
          Search
          .LI count
          times backward through the current line for
          .LI <character> .
          .sp
          The
          .CO F
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the searched-for character.
          .SP Options:
          None.
          .SE
          .KY G
          .IP "[count] G"
          Move to line
          .LI count ,
          or the last line of the file if
          .LI count
          not specified.
          .sp
          The
          .CO G
          command is an absolute movement.
          The
          .CO G
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          line oriented.
          .SS
          .SP Line:
          Set to
          .LI count ,
          if specified, otherwise the last line.
          .SP Column:
          Set to the first nonblank character in the line.
          .SP Options:
          None.
          .SE
          .KY H

     Vi/Ex Reference                                              USD:13-71

          .IP "[count] H"
          Move to the screen line
          .LI "count - 1"
          lines below the top of the screen.
          .sp
          The
          .CO H
          command is an absolute movement.
          The
          .CO H
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          line oriented.
          .SS
          .SP Line:
          Set to the line
          .LI "count - 1"
          lines below the top of the screen.
          .SP Column:
          Set to the first nonblank character of the
          .i screen
          line.
          .SP Options:
          None.
          .SE
          .KY I
          .IP "[count] I"
          Enter input mode, inserting the text at the beginning of the line.
          If
          .LI count
          is specified, the text input is repeatedly input
          .LI "count - 1"
          more times.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:
          Set to the last character entered.
          .SP Options:
          None.
          .SE
          .KY J
          .IP "[count] J"
          Join lines.
          If
          .LI count
          is specified,
          .LI count
          lines are joined; a minimum of two lines are always joined,
          regardless of the value of
          .LI count .
          .sp

     USD:13-72                                              Vi/Ex Reference

          If the current line ends with a whitespace character, all whitespace
          is stripped from the next line.
          Otherwise, if the next line starts with a open parenthesis
          .PQ (
          do nothing.
          Otherwise, if the current line ends with a question mark
          .PQ ? ,
          period
          .PQ .
          or exclamation point
          .PQ ! ,
          insert two spaces.
          Otherwise, insert a single space.
          .sp
          It is not an error to join lines past the end of the file,
          i.e. lines that do not exist.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the character after the last character of the next-to-last
          joined line.
          .SP Options:
          None.
          .SE
          .KY L
          .IP "[count] L"
          Move to the screen line
          .LI "count - 1"
          lines above the bottom of the screen.
          .sp
          The
          .CO L
          command is an absolute movement.
          The
          .CO L
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          line oriented.
          .SS
          .SP Line:
          Set to the line
          .LI "count - 1"
          lines above the bottom of the screen.
          .SP Column:
          Set to the first nonblank character of the
          .i screen
          line.
          .SP Options:
          None.
          .SE
          .KY  M

     Vi/Ex Reference                                              USD:13-73

          .IP " M"
          Move to the screen line in the middle of the screen.
          .sp
          The
          .CO M
          command is an absolute movement.
          The
          .CO M
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          line oriented.
          .sp
          Historically, any
          .LI count
          specified to the
          .CO M
          command was ignored.
          .SS
          .SP Line:
          Set to the line in the middle of the screen.
          .SP Column:
          Set to the first nonblank character of the
          .i screen
          line.
          .SP Options:
          None.
          .SE
          .KY O
          .IP "[count] O"
          Enter input mode, appending text in a new line above the current line.
          If
          .LI count
          is specified, the text input is repeatedly input
          .LI "count - 1"
          more times.
          .sp
          Historically, any
          .LI count
          specified to the
          .CO O
          command was ignored.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:
          Set to the last character entered.
          .SP Options:
          Affected by the
          .OP altwerase ,
          .OP autoindent ,
          .OP beautify ,
          .OP showmatch ,

     USD:13-74                                              Vi/Ex Reference

          .OP ttywerase
          and
          .OP wrapmargin
          options.
          .SE
          .KY P
          .IP "[buffer] P"
          Insert text from a buffer.
          Text from the buffer (the unnamed buffer by default) is inserted
          before the current column or, if the buffer is line oriented,
          before the current line.
          .SS
          .SP Line:
          Set to the lowest numbered line insert,
          if the buffer is line oriented, otherwise unchanged.
          .SP Column:
          Set to the first nonblank character of the appended text,
          if the buffer is line oriented, otherwise the last character
          of the appended text.
          .SP Options:
          None.
          .SE
          .KY Q
          .IP "Q"
          Exit
          .CO vi
          (or visual) mode and switch to
          .CO ex
          mode.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          No longer relevant.
          .SP Options:
          None.
          .SE
          .KY R
          .IP "[count] R"
          Enter input mode, replacing the characters in the current line.
          If
          .LI count
          is specified, the text input is repeatedly input
          .LI "count - 1"
          more times.
          .sp
          If the end of the current line is reached, no more characters are
          replaced and any further characters input are appended to the line.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:
          Set to the last character entered.

     Vi/Ex Reference                                              USD:13-75

          .SP Options:
          Affected by the
          .OP altwerase ,
          .OP autoindent ,
          .OP beautify ,
          .OP showmatch ,
          .OP ttywerase
          and
          .OP wrapmargin
          options.
          .SE
          .KY S
          .IP "[buffer] [count] S"
          Substitute
          .LI count
          lines.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:
          Set to the last character entered.
          .SP Options:
          Affected by the
          .OP altwerase ,
          .OP autoindent ,
          .OP beautify ,
          .OP showmatch ,
          .OP ttywerase
          and
          .OP wrapmargin
          options.
          .SE
          .KY T
          .IP "[count] T <character>"
          Search backward,
          .LI count
          times,
          through the current line for the character
          .i after
          the specified
          .LI <character> .
          .sp
          The
          .CO T
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the character

     USD:13-76                                              Vi/Ex Reference

          .i after
          the searched-for character.
          .SP Options:
          None.
          .SE
          .KY U
          .IP "U"
          Restore the current line to its state before the cursor last
          moved to it.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          The first character in the line.
          .SP Options:
          None.
          .SE
          .KY W
          .IP "[count] W"
          Move forward
          .LI count
          bigwords.
          Move the cursor forward to the beginning of a bigword by repeating the
          following algorithm: if the current position is within a bigword or the
          character at that position cannot be part of a bigword, move to the first
          character of the next bigword.
          If no subsequent bigword exists on the current line,
          move to the first character of the first bigword on the first following
          line that contains a bigword.
          .sp
          The
          .CO W
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          The line containing the word selected.
          .SP Column:
          The first character of the word selected.
          .SP Options:
          None.
          .SE
          .KY X
          .IP "[buffer] [count] X"
          Delete
          .LI count
          characters before the cursor.
          If the number of characters to be deleted is greater than or equal to
          the number of characters to the beginning of the line, all of the
          characters before the current cursor position, to the beginning of the
          line, are deleted.

     Vi/Ex Reference                                              USD:13-77

          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the current character minus
          .LI count ,
          or the first character if count is greater than the number of
          characters in the line before the cursor.
          .SP Options:
          None.
          .SE
          .KY Y
          .IP "[buffer] [count] Y"
          Copy (or
          .QQ yank )
          .LI count
          lines into the specified buffer.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY ZZ
          .IP "ZZ"
          Write the file and exit
          .CO vi .
          The file is only written if it has been modified since the last
          complete write of the file to any file.
          .sp
          The
          .CO ZZ
          command will exit the editor after writing the file,
          if there are no further files to edit.
          Entering two
          .QQ quit
          commands (i.e.
          .CO wq ,
          .CO quit ,
          .CO xit
          or
          .CO ZZ )
          in a row will override this check and the editor will exit,
          ignoring any files that have not yet been edited.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Unchanged.
          .SP Options:
          None.

     USD:13-78                                              Vi/Ex Reference

          .SE
          .KY [[
          .IP "[count] [["
          Back up
          .LI count
          section boundaries.
          .sp
          The
          .CO [[
          command is an absolute movement.
          The
          .CO [[
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented, unless the starting position is column 0,
          in which case it is line oriented.
          .sp
          It is an error if the movement is past the beginning of the file.
          .SS
          .SP Line:
          Set to the previous line that is
          .LI count
          section boundaries back,
          or the first line of the file if no more section boundaries exist
          preceding the current line.
          .SP Column:
          Set to the first nonblank character in the line.
          .SP Options:
          Affected by the
          .OP sections
          option.
          .SE
          .KY ]]
          .IP "[count] ]]"
          Move forward
          .LI count
          section boundaries.
          .sp
          The
          .CO ]]
          command is an absolute movement.
          The
          .CO ]]
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented, unless the starting position is column 0,
          in which case it is line oriented.
          .sp
          It is an error if the movement is past the end of the file.
          .SS
          .SP Line:

     Vi/Ex Reference                                              USD:13-79

          Set to the line that is
          .LI count
          section boundaries forward,
          or to the last line of the file if no more section
          boundaries exist following the current line.
          .SP Column:
          Set to the first nonblank character in the line.
          .SP Options:
          Affected by the
          .OP sections
          option.
          .SE
          .KY ^
          .IP "^"
          Move to first nonblank character on the current line.
          .sp
          The
          .CO ^
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the first nonblank character of the current line.
          .SP Options:
          None.
          .SE
          .KY _
          .IP "[count] _"
          Move down
          .LI "count - 1"
          lines, to the first nonblank character.
          The
          .CO _
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          line oriented.
          .sp
          It is not an error to execute the
          .CO _
          command when the cursor is on the first character in the line.
          .SS
          .SP Line:
          The current line plus
          .LI "count - 1" .
          .SP Column:
          The first nonblank character in the line.
          .SP Options:
          None.

     USD:13-80                                              Vi/Ex Reference

          .SE
          .KY a
          .IP "[count] a"
          Enter input mode, appending the text after the cursor.
          If
          .LI count
          is specified, the text input is repeatedly input
          .LI "count - 1"
          more times.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:
          Set to the last character entered.
          .SP Options:
          Affected by the
          .OP altwerase ,
          .OP autoindent ,
          .OP beautify ,
          .OP showmatch ,
          .OP ttywerase
          and
          .OP wrapmargin
          options.
          .SE
          .KY b
          .IP "[count] b"
          Move backward
          .LI count
          words.
          Move the cursor backward to the beginning of a word by repeating the
          following algorithm: if the current position is at the beginning of a word,
          move to the first character of the preceding word.
          Otherwise, the current position moves to the first character of the word
          at the current position.
          If no preceding word exists on the current line, move to the first
          character of the last word on the first preceding line that contains
          a word.
          .sp
          The
          .CO b
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Set to the line containing the word selected.
          .SP Column:
          Set to the first character of the word selected.
          .SP Options:
          None.
          .SE

     Vi/Ex Reference                                              USD:13-81

          .KY c
          .IP "[buffer] [count] c motion"
          Change the region of text specified by the
          .LI count
          and
          .LI motion .
          If only part of a single line is affected, then the last character
          being changed is marked with a
          .QT $ .
          Otherwise, the region of text is deleted, and input mode is entered.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:
          Set to the last character entered.
          .SP Options:
          Affected by the
          .OP altwerase ,
          .OP autoindent ,
          .OP beautify ,
          .OP showmatch ,
          .OP ttywerase
          and
          .OP wrapmargin
          options.
          .SE
          .KY d
          .IP "[buffer] [count] d motion"
          Delete the region of text specified by the
          .LI count
          and
          .LI motion .
          .SS
          .SP Line:
          Set to the line where the region starts.
          .SP Column:
          Set to the first character in the line after the last character in the
          region.
          If no such character exists, set to the last character before the region.
          .SP Options:
          None.
          .SE
          .KY e
          .IP "[count] e"
          Move forward
          .LI count
          end-of-words.
          Move the cursor forward to the end of a word by repeating the following
          algorithm: if the current position is the end of a word,
          move to the last character of the following word.
          Otherwise, move to the last character of the word at the current position.
          If no succeeding word exists on the current line, move to the last character
          of the first word on the next following line that contains a word.

     USD:13-82                                              Vi/Ex Reference

          .sp
          The
          .CO e
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Set to the line containing the word selected.
          .SP Column:
          Set to the last character of the word selected.
          .SP Options:
          None.
          .SE
          .KY f
          .IP "[count] f <character>"
          Search forward,
          .LI count
          times, through the rest of the current line for
          .LI <character> .
          .sp
          The
          .CO f
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the searched-for character.
          .SP Options:
          None.
          .SE
          .KY i
          .IP "[count] i"
          Enter input mode, inserting the text before the cursor.
          If
          .LI count
          is specified, the text input is repeatedly input
          .LI "count - 1"
          more times.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:
          Set to the last character entered.
          .SP Options:
          Affected by the
          .OP altwerase ,
          .OP autoindent ,

     Vi/Ex Reference                                              USD:13-83

          .OP beautify ,
          .OP showmatch ,
          .OP ttywerase
          and
          .OP wrapmargin
          options.
          .SE
          .KY m
          .IP "m <character>"
          Save the current context (line and column) as
          .LI <character> .
          The exact position is referred to by
          .QT `<character> .
          The line is referred to by
          .QT '<character> .
          .sp
          Historically,
          .LI <character>
          was restricted to lower-case letters.
          .CO Nvi
          permits the use of any character.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY o
          .IP "[count] o"
          Enter input mode, appending text in a new line under the current line.
          If
          .LI count
          is specified, the text input is repeatedly input
          .LI "count - 1"
          more times.
          .sp
          Historically, any
          .LI count
          specified to the
          .CO o
          command was ignored.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:
          Set to the last character entered.
          .SP Options:
          Affected by the
          .OP altwerase ,
          .OP autoindent ,
          .OP beautify ,

     USD:13-84                                              Vi/Ex Reference

          .OP showmatch ,
          .OP ttywerase
          and
          .OP wrapmargin
          options.
          .SE
          .KY p
          .IP "[buffer] p"
          Append text from a buffer.
          Text from the buffer (the unnamed buffer by default) is appended
          after the current column or, if the buffer is line oriented,
          after the current line.
          .SS
          .SP Line:
          Set to the first line appended, if the buffer is line oriented,
          otherwise unchanged.
          .SP Column:
          Set to the first nonblank character of the appended text if the buffer
          is line oriented, otherwise the last character of the appended text.
          .SP Options:
          None.
          .SE
          .KY r
          .IP "[count] r <character>"
          Replace characters.
          The next
          .LI count
          characters in the line are replaced with
          .LI <character> .
          Replacing characters with
          .LI <newline>
          characters results in creating new, empty lines into the file.
          .sp
          If
          .LI <character>
          is
          .LI <escape> ,
          the command is cancelled.
          .SS
          .SP Line:
          Unchanged unless the replacement character is a
          .LI <newline> ,
          in which case it is set to the current line plus
          .LI "count - 1" .
          .SP Column:
          Set to the last character replaced,
          unless the replacement character is a
          .LI <newline> ,
          in which case the cursor is in column 1 of the last line inserted.
          .SP Options:
          None.
          .SE
          .KY s

     Vi/Ex Reference                                              USD:13-85

          .IP "[buffer] [count] s"
          Substitute
          .LI count
          characters in the current line starting with the current character.
          .SS
          .SP Line:
          Set to the last line upon which characters were entered.
          .SP Column:
          Set to the last character entered.
          .SP Options:
          Affected by the
          .OP altwerase ,
          .OP autoindent ,
          .OP beautify ,
          .OP showmatch ,
          .OP ttywerase
          and
          .OP wrapmargin
          options.
          .SE
          .KY t
          .IP "[count] t <character>"
          Search forward,
          .LI count
          times, through the current line for the character immediately
          .i before
          .LI <character> .
          .sp
          The
          .CO t
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the character
          .i before
          the searched-for character.
          .SP Options:
          None.
          .SE
          .KY u
          .IP "u"
          Undo the last change made to the file.
          If repeated, the
          .CO u
          command alternates between these two states, and is its own inverse.
          When used after an insert that inserted text on more than one line,
          the lines are saved in the numeric buffers.
          .sp

     USD:13-86                                              Vi/Ex Reference

          The
          .CO .
          command, when used immediately after the
          .CO u
          command, causes the change log to be rolled forward or backward,
          depending on the action of the
          .CO u
          command.
          .SS
          .SP Line:
          Set to the position of the first line changed, if the reversal affects
          only one line or represents an addition or change; otherwise, the line
          preceding the deleted text.
          .SP Column:
          Set to the cursor position before the change was made.
          .SP Options:
          None.
          .SE
          .KY w
          .IP "[count] w"
          Move forward
          .LI count
          words.
          Move the cursor forward to the beginning of a word by repeating the
          following algorithm: if the current position is at the
          beginning of a word, move to the first character of the next word.
          If no subsequent word exists on the current line, move to the first
          character of the first word on the first following line that contains
          a word.
          .sp
          The
          .CO w
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          .SS
          .SP Line:
          Set to the line containing the word selected.
          .SP Column:
          Set to the first character of the word selected.
          .SP Options:
          None.
          .SE
          .KY x
          .IP "[buffer] [count] x"
          Delete
          .LI count
          characters.
          The deletion is at the current character position.
          If the number of characters to be deleted is greater than or equal to
          the number of characters to the end of the line, all of the characters
          from the current cursor position to the end of the line are deleted.

     Vi/Ex Reference                                              USD:13-87

          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Unchanged unless the last character in the line is deleted and the cursor
          is not already on the first character in the line, in which case it is
          set to the previous character.
          .SP Options:
          None.
          .SE
          .KY y
          .IP "[buffer] [count] y motion"
          Copy (or
          .QQ yank )
          the text region specified by the
          .LI count
          and
          .LI motion ,
          into a buffer.
          .SS
          .SP Line:
          Unchanged, unless the region covers more than a single line,
          in which case it is set to the line where the region starts.
          .SP Column:
          Unchanged, unless the region covers more than a single line,
          in which case it is set to the character were the region starts.
          .SP Options:
          None.
          .SE
          .KY z
          .IP "[count1] z [count2] type"
          Redraw the screen with a window
          .LI count2
          lines long, with line
          .LI count1
          placed as specified by the
          .LI type
          character.
          If
          .LI count1
          is not specified, it defaults to the current line.
          If
          .LI count2
          is not specified, it defaults to the current window size.
          .sp
          The following
          .LI type
          characters may be used:
          .SS
          .SP +
          If
          .LI count1
          is specified, place the line

     USD:13-88                                              Vi/Ex Reference

          .LI count1
          at the top of the screen.
          Otherwise, display the screen after the current screen, similarly to the
          .CO <control-F>
          command.
          .SP <carriage-return>
          Place the line
          .LI count1
          at the top of the screen.
          .SP .
          Place the line
          .LI count1
          in the center of the screen.
          .SP -
          Place the line
          .LI count1
          at the bottom of the screen.
          .SP ^
          If
          .LI count1
          is specified, place the line that is at the top of the screen
          when
          .LI count1
          is at the bottom of the screen, at the bottom of the screen,
          i.e. display the screen before the screen before
          .LI count1 .
          Otherwise, display the screen before the current screen, similarly to the
          .CO <control-B>
          command.
          .SE
          .SS
          .SP Line:
          Set to
          .LI count1
          unless
          .LI count1
          is not specified and the
          .LI type
          character was either
          .QT ^
          or
          .QT + ,
          in which case it is set to the line before the first line on the
          previous screen or the line after the last line on the previous
          screen, respectively.
          .SP Column:
          Set to the first nonblank character in the line.
          .SP Options:
          None.
          .SE
          .KY {
          .IP "[count] {"
          Move backward

     Vi/Ex Reference                                              USD:13-89

          .LI count
          paragraphs.
          .sp
          The
          .CO {
          command is an absolute movement.
          The
          .CO {
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented, unless the starting character is the first
          character on its line, in which case it is line oriented.
          .SS
          .SP Line:
          Set to the line containing the beginning of the previous paragraph.
          .SP Column:
          Set to the first nonblank character in the line.
          .SP Options:
          Affected by the
          .OP paragraph
          option.
          .SE
          .KY |
          .IP "[count] |"
          Move to a specific
          .i column
          position on the current line.
          .sp
          The
          .CO |
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented.
          It is an error to use the
          .CO |
          command as a motion component and for the cursor not to move.
          .SS
          .SP Line:
          Unchanged.
          .SP Column:
          Set to the character occupying the column position identified by
          .LI count ,
          if the position exists in the line.
          If the column length of the current line is less than
          .LI count ,
          the cursor is moved to the last character in the line.
          .SP Options:
          None.
          .SE
          .KY }
          .IP "[count] }"

     USD:13-90                                              Vi/Ex Reference

          Move forward
          .LI count
          paragraphs.
          .sp
          The
          .CO }
          command is an absolute movement.
          The
          .CO }
          command may be used as the motion component of other
          .CO vi
          commands, in which case any text copied into a buffer is
          character oriented, unless the starting character is at or
          before any nonblank characters in its line,
          in which case it is line oriented.
          .SS
          .SP Line:
          Set to the line containing the beginning of the next paragraph.
          .SP Column:
          Set to the first nonblank character in the line.
          .SP Options:
          Affected by the
          .OP paragraph
          option.
          .SE
          .KY ~
          .IP "[count] ~"
          Reverse the case of the next
          .LI count
          character(s).
          This is the historic semantic for the
          .CO ~
          command and it is only in effect if the
          .OP tildeop
          option is not set.
          .sp
          Lowercase alphabetic characters are changed to uppercase,
          and uppercase characters are changed to lowercase.
          No other characters are affected.
          .sp
          Historically, the
          .CO ~
          command did not take an associated count, nor did it move past the
          end of the current line.
          As it had no associated motion it was difficult to change the case
          of large blocks of text.
          In
          .CO nvi ,
          if the cursor is on the last character of a line, and there are
          more lines in the file, the cursor moves to the next line.
          .sp
          It is not an error to specify a count larger than the number of
          characters between the cursor and the end of the file.

     Vi/Ex Reference                                              USD:13-91

          .SS
          .SP Line:
          Set to the line of the character after
          .LI count
          characters, or, end of file.
          .SP Column:
          Set to the character after
          .LI count
          characters, or, end-of-file.
          .SP Options:
          Affected by the
          .OP tildeop
          option.
          .SE
          .KY ~
          .IP "[count] ~ motion"
          Reverse the case of the characters in a text region specified by the
          .LI count
          and
          .LI motion .
          Only in effect if the
          .OP tildeop
          option is set.
          .sp
          Lowercase characters are changed to uppercase,
          and uppercase characters are changed to lowercase.
          No other characters are affected.
          .SS
          .SP Line:
          Set to the line of the character after the last character in the region.
          .SP Column:
          Set to the character after the last character in the region.
          .SP Options:
          Affected by the
          .OP tildeop
          option.
          .SE
          .KY <interrupt>
          .IP "<interrupt>"
          Interrupt the current operation.
          Many of the potentially long-running
          .CO vi
          commands may be interrupted using the terminal interrupt character.
          These operations include searches, file reading and writing, filter
          operations and map character expansion.
          Interrupts are also enabled when running commands outside of
          .CO vi .
          .sp
          If the
          .LI <interrupt>
          character is used to interrupt while entering an
          .CO ex
          command, the command is aborted, the cursor returns to its previous

     USD:13-92                                              Vi/Ex Reference

          position, and
          .CO vi
          remains in command mode.
          .sp
          Generally, if the
          .LI <interrupt>
          character is used to interrupt any
          operation, any changes made before the interrupt are left in place.
          .SS
          .SP Line:
          Dependent on the operation being interrupted.
          .SP Column:
          Dependent on the operation being interrupted.
          .SP Options:
          None.
          .SH 1 "Vi Text Input Commands"
          .pp
          The following section describes the commands available in the text
          input mode of the
          .CO vi
          editor.
          .pp
          Historically,
          .CO vi
          implementations only permitted the characters inserted on the current
          line to be erased.
          In addition, only the
          .LI <control-D>
          erase character and the
          .QT 0<control-D>
          and
          .QT ^<control-D>
          erase strings could erase autoindent characters.
          (Autoindent characters include both the characters inserted automatically
          at the beginning of an input line as well as characters inserted using the
          .LI <control-T>
          command.)
          This implementation permits erasure to continue past the beginning
          of the current line, and back to where text input mode was entered.
          In addition, autoindent characters may be erased using the standard
          erase characters.
          For the line and word erase characters, reaching the autoindent
          characters forms a
          .QQ soft
          boundary, denoting the end of the current word or line erase.
          Repeating the word or line erase key will erase the autoindent characters.
          .pp
          Historically,
          .CO vi
          always used
          .LI <control-H>
          and
          .LI <control-W>

     Vi/Ex Reference                                              USD:13-93

          as character and word erase characters, respectively, regardless of
          the current terminal settings.
          This implementation accepts, in addition to these two characters,
          the current terminal characters for those operations.
          .KY <nul>
          .IP "<nul>"
          If the first character of the input is a
          .LI <nul> ,
          the previous input is replayed, as if just entered.
          .KY <control-D>
          .IP "<control-D>"
          If the previous character on the line was an autoindent character,
          erase characters to move the cursor back to the column immediately
          after the previous (1-based) column which is a multiple of the
          .OP shiftwidth
          edit option.
          This may result in any number of
          .LI <tab>
          and
          .LI <space>
          characters preceding the cursor being changed.
          .sp
          Otherwise, if the
          .OP autoindent
          option is set and the user is entering the first character in the line,
          .LI <control-D>
          is ignored.
          Otherwise, a literal
          .LI <control-D>
          character is entered.
          .KY ^<control-D>
          .IP "^<control-D>"
          If the previous character on the line was an autoindent character,
          erase all of the autoindent characters on the line.
          In addition, the autoindent level is reset to 0.
          .KY 0<control-D>
          .IP "0<control-D>"
          If the previous character on the line was an autoindent character,
          erase all of the autoindent characters on the line.
          The autoindent level is not altered.
          .KY <control-T>
          .IP "<control-T>"
          Insert sufficient
          .LI <tab>
          and
          .LI <space>
          characters to move the cursor forward to the column immediately
          after the next (1-based) column which is a multiple of the
          .OP shiftwidth
          edit option.
          This may result in any number of
          .LI <tab>
          and

     USD:13-94                                              Vi/Ex Reference

          .LI <space>
          characters preceding the cursor being changed.
          .sp
          Historically,
          .CO vi
          did not permit the
          .LI <control-T>
          command to be used unless the cursor was at the first column of a new
          line or it was preceded only by autoindent characters.
          .CO Nvi
          permits it to be used at any time during insert mode.
          .KY <erase>
          .IP <erase>
          .KY <control-H>
          .Ip <control-H>
          Erase the last character.
          .KY "<literal-next>"
          .IP "<literal-next>"
          Quote the next character.
          The next character will not be mapped (see the
          .CO map
          command for more information)
          or interpreted specially.
          A caret
          .PQ ^
          character will be displayed immediately as a placeholder,
          but will be replaced by the next character.
          .KY <escape>
          .IP <escape>
          If on the colon command line, and the
          .OP filec
          edit option is set, behave as described for that option.
          Otherwise, if on the colon command line,
          execute the command.
          Otherwise, if not on the colon command line,
          resolve all text input into the file, and return to command mode.
          .KY "<line erase>"
          .IP "<line erase>"
          Erase the current line.
          .KY "<control-W>"
          .IP "<control-W>"
          .KY "<word erase>"
          .Ip "<word erase>"
          Erase the last word.
          The definition of word is dependent on the
          .OP altwerase
          and
          .OP ttywerase
          options.
          .KY "<control-X>"
          .IP "<control-X>[0-9A-Fa-f]+"
          Insert a character with the specified hexadecimal value into the text.
          The value is delimited by any non-hexadecimal character or the input

     Vi/Ex Reference                                              USD:13-95

          of the maximum number of characters that can be translated into a single
          character value.
          .KY <interrupt>
          .IP "<interrupt>"
          Interrupt text input mode, returning to command mode.
          If the
          .LI <interrupt>
          character is used to interrupt inserting text into the file,
          it is as if the
          .LI <escape>
          character was used; all text input up to the interruption is
          resolved into the file.
          .oh 'Vi/Ex Reference''USD:13-%'
          .eh 'USD:13-%''Vi/Ex Reference'
          .SH 1 "Ex Addressing"
          .pp
          Addressing in
          .CO ex
          (and when
          .CO ex
          commands are executed from
          .CO vi )
          relates to the current line.
          In general, the current line is the last line affected by a command.
          The exact effect on the current line is discussed under the description
          of each command.
          When the file contains no lines, the current line is zero.
          .pp
          Addresses are constructed by one or more of the following methods:
          .np
          The address
          .QT .
          refers to the current line.
          .np
          The address
          .QT $
          refers to the last line of the file.
          .np
          The address
          .QT N ,
          where
          .LI N
          is a positive number, refers to the N-th line of the file.
          .np
          The address
          .QT '<character>
          or
          .QT `<character>
          refers to the line marked with the named
          .LI <character> .
          (See the
          .CO k
          or

     USD:13-96                                              Vi/Ex Reference

          .CO m
          commands for more information on how to mark lines.)
          .np
          A regular expression (RE) enclosed by slashes
          .PQ /
          is an address,
          and it refers to the first line found by searching forward from the line
          .i after
          the current line toward the end of the file, and stopping at the
          first line containing a string matching the RE.
          (The trailing slash can be omitted at the end of the command line.)
          .sp
          If no RE is specified, i.e. the pattern is
          .QT // ,
          the last RE used in any command is used in the search.
          .sp
          If the
          .OP extended
          option is set, the RE is handled as an extended RE, not a basic RE.
          If the
          .OP wrapscan
          option is set, the search wraps around to the beginning of the file
          and continues up to and including the current line, so that the entire
          file is searched.
          .sp
          The form
          .QT \/
          is accepted for historic reasons,
          and is identical to
          .QT // .
          .np
          An RE enclosed in question marks
          .PQ ?
          addresses the first line found by searching backward from the line
          .i preceding
          the current line, toward the beginning of the file and stopping at the
          first line containing a string matching the RE.
          (The trailing question mark can be omitted at the end of a command line.)
          .sp
          If no RE is specified, i.e. the pattern is
          .QT ?? ,
          the last RE used in any command is used in the search.
          .sp
          If the
          .OP extended
          option is set, the RE is handled as an extended RE, not a basic RE.
          If the
          .OP wrapscan
          option is set, the search  wraps around from the beginning of the file to
          the end of the file and continues up to and including the current line,
          so that the entire file is searched.
          .sp
          The form

     Vi/Ex Reference                                              USD:13-97

          .QT \?
          is accepted for historic reasons, and is identical to
          .QT ?? .
          .np
          An address followed by a plus sign
          .PQ +
          or a minus sign
          .PQ -
          followed by a number is an offset address and refers to the address
          plus (or minus) the indicated number of lines.
          If the address is omitted, the addition or subtraction is done with
          respect to the current line.
          .np
          An address of
          .QT +
          or
          .QT -
          followed by a number is an offset from the current line.
          For example,
          .QT -5
          is the same as
          .QT .-5 .
          .np
          An address ending with
          .QT +
          or
          .QT -
          has 1 added to or subtracted from the address, respectively.
          As a consequence of this rule and of the previous rule, the address
          .QT -
          refers to the line preceding the current line.
          Moreover, trailing
          .QT +
          and
          .QT -
          characters have a cumulative effect.
          For example,
          .QT ++-++
          refers to the current line plus 3.
          .np
          A percent sign
          .PQ %
          is equivalent to the address range
          .QT 1,$ .
          .pp
          .CO Ex
          commands require zero, one, or two addresses.
          It is an error to specify an address to a command which requires zero
          addresses.
          .pp
          If the user provides more than the expected number of addresses to any
          .CO ex
          command, the first addresses specified are discarded.

     USD:13-98                                              Vi/Ex Reference

          For example,
          .QT 1,2,3,5 print
          prints lines 3 through 5, because the
          .CO print
          command only takes two addresses.
          .pp
          The addresses in a range are separated from each other by a comma
          .PQ ,
          or a semicolon
          .PQ ; .
          In the latter case, the current line
          .PQ .
          is set to the first address, and only then is the second address calculated.
          This feature can be used to determine the starting line for forward and
          backward searches (see rules (5) and (6) above).
          The second address of any two-address sequence corresponds to a line that
          follows, in the file, the line corresponding to the first address.
          The first address must be less than or equal to the second address.
          The first address must be greater than or equal to the first line of the
          file, and the last address must be less than or equal to the last line
          of the file.
          .oh 'Vi/Ex Reference (Ex Commands)''USD:13-%'
          .eh 'USD:13-%''Vi/Ex Reference (Ex Commands)'
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .SH 1 "Ex Description"
          .pp
          The following words have special meanings for
          .CO ex
          commands.
          .KY "<end-of-file>"
          .IP "<end-of-file>"
          The end-of-file character is used to scroll the screen in the
          .CO ex
          editor.
          This character is normally
          .LI <control-D> .
          However, whatever character is set for the current terminal is supported
          as well as
          .LI <control-D> .
          .KY "line"
          .IP "line"
          A single-line address, given in any of the forms described in the
          section entitled

     Vi/Ex Reference                                              USD:13-99

          .QB "Ex Addressing" .
          The default for
          .LI line
          is the current line.
          .KY "range"
          .IP "range"
          A line, or a pair of line addresses, separated by a comma or semicolon.
          (See the section entitled
          .QB "Ex Addressing"
          for more information.)
          The default for range is the current line
          .i only ,
          i.e.
          .QT .,. .
          A percent sign
          .PQ %
          stands for the range
          .QT 1,$ .
          The starting address must be less than, or equal to, the ending address.
          .KY "count"
          .IP "count"
          A positive integer, specifying the number of lines to be affected by
          the command; the default is 1.
          Generally, a count past the end-of-file may be specified, e.g. the
          command
          .QT "p 3000"
          in a 10 line file is acceptable, and will print from the current line
          through the last line in the file.
          .KY "flags"
          .IP "flags"
          One or more of the characters
          .QQ # ,
          .QQ p ,
          and
          .QQ l .
          When a command that accepts these flags completes, the addressed line(s)
          are written out as if by the corresponding
          .CO # ,
          .CO l
          or
          .CO p
          commands.
          In addition, any number of
          .QT +
          or
          .QT -
          characters can be specified before, after, or during the flags, in which
          case the line written is not necessarily the one affected by the command,
          but rather the line addressed by the offset address specified.
          The default for
          .LI flags
          is none.
          .KY "file"

     USD:13-100                                             Vi/Ex Reference

          .IP "file"
          A pattern used to derive a pathname; the default is the current file.
          File names are subjected to normal
          .XR sh 1
          word expansions.
          .pp
          Anywhere a file name is specified, it is also possible to use
          the special string
          .QT /tmp .
          This will be replaced with a temporary file name which can be used
          for temporary work, e.g.
          .QT ":e /tmp"
          creates and edits a new file.
          .pp
          If both a count and a range are specified for commands that use either,
          the starting line for the command is the
          .i last
          line addressed by the range, and
          .LI count - 1
          subsequent lines are affected by the command, e.g. the command
          .QT 2,3p4
          prints out lines 3, 4, 5 and 6.
          .pp
          When only a line or range is specified, with no command, the implied
          command is
          .CO print .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          When no range or count is specified and the command line is a blank line,
          the current line is incremented by 1 and then the current line is displayed.
          .pp
          Zero or more whitespace characters may precede or follow the addresses,
          count, flags, or command name.
          Any object following a command name (such as buffer, file, etc.),
          that begins with an alphabetic character,
          should be separated from the command name by at least one whitespace
          character.
          .pp
          Any character, including
          .LI <carriage-return> ,
          .QT %
          and
          .QT #
          retain their literal value when preceded by a backslash.

     Vi/Ex Reference                                             USD:13-101

          .SH 1 "Ex Commands"
          .pp
          The following section describes the commands available in the
          .CO ex
          editor.
          In each entry below, the tag line is a usage synopsis for the command.
          .pp
          Each command can be entered as the abbreviation
          (those characters in the synopsis command word preceding the
          .QQ [
          character),
          the full command (all characters shown for the command word,
          omitting the
          .QQ [
          and
          .QQ ]
          characters),
          or any leading subset of the full command down to the abbreviation.
          For example, the args command (shown as
          .QT ar[gs]
          in the synopsis)
          can be entered as
          .QT ar ,
          .QT arg
          or
          .QT args .
          .pp
          Each
          .CO ex
          command described below notes the new current line after it
          is executed, as well as any options that affect the command.
          .
          .
          .tr Q"
          .ds ms Q
          .KY DOUBLEQUOTE
          .IP ""
          .tr QQ
          A comment.
          Command lines beginning with the double-quote character
          .PQ """"
          are ignored.
          This permits comments in editor scripts and startup files.
          .KY "<control-D>"
          .KY "<end-of-file>"
          .IP "<control-D>"
          .IP "<end-of-file>"
          Scroll the screen.
          Write the next N lines, where N is the value of the
          .OP scroll
          option.
          The command is the end-of-file terminal character, which may be
          different on different terminals.

     USD:13-102                                             Vi/Ex Reference

          Traditionally, it is the
          .LI <control-D>
          key.
          .sp
          Historically, the
          .CO eof
          command ignored any preceding count, and the
          .LI <end-of-file>
          character was ignored unless it was entered as the first character
          of the command.
          This implementation treats it as a command
          .i only
          if entered as the first character of the command line, and otherwise
          treats it as any other character.
          .SS
          .SP Line:
          Set to the last line written.
          .SP Options:
          Affected by the
          .OP scroll
          option.
          .SE
          .KY "!"
          .IP "! argument(s)"
          .Ip "[range]! argument(s)"
          Execute a shell command, or filter lines through a shell command.
          In the first synopsis, the remainder of the line after the
          .QT !
          character is passed to the program named by the
          .OP shell
          option, as a single argument.
          .sp
          Within the rest of the line,
          .QT %
          and
          .QT #
          are expanded into the current and alternate pathnames, respectively.
          The character
          .QT !
          is expanded with the command text of the previous
          .CO !
          command.
          (Therefore, the command
          .CO !!
          repeats the previous
          .CO !
          command.)
          The special meanings of
          .QT % ,
          .QT # ,
          and
          .QT !
          can be overridden by escaping them with a backslash.

     Vi/Ex Reference                                             USD:13-103

          If no
          .CO !
          or
          .CO :!
          command has yet been executed, it is an error to use an unescaped
          .QT !
          character.
          The
          .CO !
          command does
          .i not
          do shell expansion on the strings provided as arguments.
          If any of the above expansions change the command the user entered,
          the command is redisplayed at the bottom of the screen.
          .sp
          .CO Ex
          then executes the program named by the
          .OP shell
          option, with a
          .b -c
          flag followed by the arguments (which are bundled into a single argument).
          .sp
          The
          .CO !
          command is permitted in an empty file.
          .sp
          If the file has been modified since it was last completely written,
          the
          .Co !
          command will warn you.
          .sp
          A single
          .QT !
          character is displayed when the command completes.
          .sp
          In the second form of the
          .CO !
          command, the remainder of the line after the
          .QT !
          is passed to the program named by the
          .OP shell
          option, as described above.
          The specified lines are passed to the program as standard input,
          and the standard and standard error output of the program replace
          the original lines.
          .SS
          .SP Line:
          Unchanged if no range was specified, otherwise set to the first
          line of the range.
          .SP Options:
          Affected by the
          .OP shell
          and

     USD:13-104                                             Vi/Ex Reference

          .OP warn
          options.
          .SE
          .KY "#"
          .IP "[range] # [count] [flags]"
          .KY "number"
          .Ip "[range] nu[mber] [count] [flags]"
          Display the selected lines, each preceded with its line number.
          .sp
          The line number format is
          .QQ %6d ,
          followed by two spaces.
          .SS
          .SP Line:
          Set to the last line displayed.
          .SP Options:
          Affected by the
          .OP list
          option.
          .SE
          .KY "@"
          .IP "@ buffer"
          .KY "*"
          .Ip "* buffer"
          Execute a buffer.
          Each line in the named buffer is executed as an
          .CO ex
          command.
          If no buffer is specified, or if the specified buffer is
          .QT @
          or
          .QT * ,
          the last buffer executed is used.
          .KY <
          .IP "[range] <[< ...] [count] [flags]"
          Shift lines left or right.
          The specified lines are shifted to the left (for the
          .CO <
          command) or right (for the
          .CO >
          command), by the number of columns specified by the
          .OP shiftwidth
          option.
          Only leading whitespace characters are deleted when shifting left;
          once the first column of the line contains a nonblank character,
          the
          .CO shift
          command will succeed, but the line will not be modified.
          .sp
          If the command character
          .CO <
          or
          .CO >

     Vi/Ex Reference                                             USD:13-105

          is repeated more than once, the command is repeated once for each
          additional command character.
          .SS
          .SP Line:
          If the current line is set to one of the lines that are affected
          by the command, it is unchanged.
          Otherwise, it is set to the first nonblank character of the lowest
          numbered line shifted.
          .SP Options:
          Affected by the
          .OP shiftwidth
          option.
          .SE
          .KY =
          .IP "[line] = [flags]"
          Display the line number of
          .LI line
          (which defaults to the last line in the file).
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY >
          .IP "[range] >[> ...] [count] [flags]"
          Shift right.
          The specified lines are shifted to the right by the number of columns
          specified by the
          .OP shiftwidth
          option, by inserting tab and space characters.
          Empty lines are not changed.
          .sp
          If the command character
          .QT >
          is repeated more than once, the command is repeated once for each
          additional command character.
          .SS
          .SP Line:
          Set to the last line modified by the command.
          .SP Options:
          Affected by the
          .OP shiftwidth
          option.
          .SE
          .KY abbreviate
          .IP "ab[breviate] lhs rhs"
          Add an abbreviation to the current abbreviation list.
          When inserting text in
          .CO vi ,
          each time a non-word character is entered after a word character,
          a set of characters ending at the word character are checked for
          a match with

     USD:13-106                                             Vi/Ex Reference

          .LI lhs .
          If a match is found, they are replaced with
          .LI rhs .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          Abbreviations must end with a word character,
          and may not mix word/non-word characters (except at the end).
          .sp
          For example, the abbreviations:
          .sp
          .ne 3v
          .ft C
          .TS
          .if 0=1 .nr d. 5751-5751-1
          .de 35
          .ps 10
          .vs 40u
          .in 120u
          .if 0 .fi
          .if 1 .ad
          .if 1=0 .na
          ..
          .nf
          .nr #~ 0
          .if n .nr #~ 0.6n
          .ds #d .d
          .if  .ds #d nl
          .fc
          .nr 33 10
          .rm 80 81 82
          .nr 80 0
          .nr 38 264
          .if 0<0 .nr 80 0
          .nr 38 264
          .if 0<0 .nr 80 0

     Vi/Ex Reference                                             USD:13-107

          .nr 38 264
          .if 0<0 .nr 80 0
          .80
          .rm 80
          .nr 81 0
          .nr 38 72
          .if 0<0 .nr 81 0
          .nr 38 48
          .if 0<0 .nr 81 0
          .nr 38 96
          .if 0<0 .nr 81 0
          .81
          .rm 81
          .nr 82 0
          .nr 38 72
          .if 0<0 .nr 82 0
          .nr 38 192
          .if 0<0 .nr 82 0
          .nr 38 240
          .if 0<0 .nr 82 0
          .82
          .rm 82
          .nr 38 1n
          .nr 79 0
          .nr 40 0+(0*0)
          .nr 80 +0
          .nr 41 0+(3*0)
          .nr 81 +0
          .nr 42 0+(3*0)
          .nr 82 +0
          .nr TW 0
          .if t .if 0>1584i .tm Table at line 5476 file Input is too wide - 0 units
          .fc
          .nr #T 0-1
          .nr #a 0-1
          .eo
          .de T#
          .ds #d .d
          .if  .ds #d nl
          .mk ##
          .nr ## -1v
          .ls 1
          .ls
          ..
          .ec
          .ta 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          aAbBcCbreviate
          .ta 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          ##iincludeate

     USD:13-108                                             Vi/Ex Reference

          .ta 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          //**##iincludee
          .fc
          .nr T. 1
          .T# 1
          .35
          .TE
          .if 0=0 .nr c. 5835-0-5
          .ft R
          will all work, while the abbreviations:
          .sp
          .ne 2v
          .ft C
          .TS
          .if 0=1 .nr d. 5842-5842-1
          .de 35
          .ps 10
          .vs 40u
          .in 120u
          .if 0 .fi
          .if 1 .ad
          .if 1=0 .na
          ..
          .nf
          .nr #~ 0
          .if n .nr #~ 0.6n
          .ds #d .d
          .if  .ds #d nl
          .fc
          .nr 33 10
          .rm 80 81 82
          .nr 80 0
          .nr 38 264
          .if 0<0 .nr 80 0
          .nr 38 264
          .if 0<0 .nr 80 0
          .80
          .rm 80
          .nr 81 0
          .nr 38 72
          .if 0<0 .nr 81 0
          .nr 38 48
          .if 0<0 .nr 81 0
          .81
          .rm 81
          .nr 82 0
          .nr 38 216
          .if 0<0 .nr 82 0
          .nr 38 504
          .if 0<0 .nr 82 0
          .82

     Vi/Ex Reference                                             USD:13-109

          .rm 82
          .nr 38 1n
          .nr 79 0
          .nr 40 0+(0*0)
          .nr 80 +0
          .nr 41 0+(3*0)
          .nr 81 +0
          .nr 42 0+(3*0)
          .nr 82 +0
          .nr TW 0
          .if t .if 0>1584i .tm Table at line 5486 file Input is too wide - 0 units
          .fc
          .nr #T 0-1
          .nr #a 0-1
          .eo
          .de T#
          .ds #d .d
          .if  .ds #d nl
          .mk ##
          .nr ## -1v
          .ls 1
          .ls
          ..
          .ec
          .ta 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          aA##iincludete
          .ta 0u 0u 0u
          .nr 31 1
          .nr 35 1m
          //*********************
          .fc
          .nr T. 1
          .T# 1
          .35
          .TE
          .if 0=0 .nr c. 5916-0-4
          .ft R
          will not work, and are not permitted by
          .CO nvi .
          .sp
          To keep the abbreviation expansion from happening,
          the character immediately following the
          .LI lhs
          characters should be quoted with a
          .LI <literal-next>
          character.
          .sp
          The replacement
          .LI rhs
          is itself subject to both further abbreviation expansion and further
          map expansion.

     USD:13-110                                             Vi/Ex Reference

          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY append
          .IP "[line] a[ppend][!]"
          The input text is appended to the specified line.
          If line 0 is specified, the text is inserted at the beginning of the file.
          Set to the last line input.
          If no lines are input, then set to
          .LI line ,
          or to the first line of the file if a
          .LI line
          of 0 was specified.
          Following the command name with a
          .QT !
          character causes the
          .OP autoindent
          option to be toggled for the duration of the command.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          Affected by the
          .OP autoindent
          and
          .OP number
          options.
          .SE
          .KY args
          .IP "ar[gs]"
          Display the argument list.
          The current argument is displayed inside of
          .QT [
          and
          .QT ]
          characters.
          The argument list is the list of operands specified on startup,
          which can be replaced using the
          .CO next
          command.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY bg
          .IP bg
          .CO Vi
          mode only.

     Vi/Ex Reference                                             USD:13-111

          Background the current screen.
          The screen is unchanged,
          but is no longer accessible and disappears from the display.
          Use the
          .CO fg
          command to bring the screen back to the display foreground.
          .SS
          .SP Line:
          Set to the current line when the screen was last edited.
          .SP Options:
          None.
          .SE
          .KY change
          .IP "[range] c[hange][!] [count]"
          Replace the lines with input text.
          Following the command name with a
          .QT !
          character causes the
          .OP autoindent
          option to be toggled for the duration of the command.
          .SS
          .SP Line:
          Set to the last line input, or, if no lines were input,
          set to the line before the target line, or to the first
          line of the file if there are no lines preceding the target line.
          .SP Options:
          Affected by the
          .OP autoindent
          and
          .OP number
          options.
          .SE
          .KY cd
          .KY chdir
          .IP "chd[ir][!] [directory]"
          .Ip "cd[!] [directory]"
          Change the current working directory.
          The
          .LI directory
          argument is subjected to
          .XR sh 1
          word expansions.
          When invoked with no directory argument and the
          .LI HOME
          environment variable is set, the directory named by the
          .LI HOME
          environment variable becomes the new current directory.
          Otherwise, the new current directory becomes the directory returned
          by the
          .XR getpwent 3
          routine.
          .sp
          The

     USD:13-112                                             Vi/Ex Reference

          .CO chdir
          command will fail if the file has been modified since the last complete
          write of the file.
          You can override this check by appending a
          .QT !
          character to the command.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          Affected by the
          .OP cdpath
          option.
          .SE
          .KY copy
          .KY t
          .IP "[range] co[py] line [flags]"
          .Ip "[range] t line [flags]"
          Copy the specified lines (range) after the destination line.
          Line 0 may be specified to insert the lines at the beginning of
          the file.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY cscope
          .IP "cs[cope] command [args]"
          Execute a
          .CO cscope
          command.
          For more information, see the section of the reference manual entitled
          .QB "Tags, Tag Stacks, and Cscope" .
          .KY delete
          .IP "[range] d[elete] [buffer] [count] [flags]"
          Delete the lines from the file.
          The deleted text is saved in the specified buffer, or, if no buffer
          is specified, in the unnamed buffer.
          If the command name is followed by a letter that could be interpreted
          as either a buffer name or a flag value (because neither a
          .LI count
          or
          .LI flags
          values were given),
          .CO ex
          treats the letter as a
          .LI flags
          value if the letter immediately follows the command name,
          without any whitespace separation.
          If the letter is preceded by whitespace characters,
          it treats it as a buffer name.
          .SS

     Vi/Ex Reference                                             USD:13-113

          .SP Line:
          Set to the line following the deleted lines,
          or to the last line if the deleted lines were at the end.
          .SP Options:
          None.
          .SE
          .KY display
          .IP "di[splay] b[uffers] | c[onnections] | s[creens] | t[ags]"
          Display buffers,
          .CO cscope
          connections, screens or tags.
          The
          .CO display
          command takes one of three additional arguments, which are as follows:
          .SS
          .SP b[uffers]
          Display all buffers (including named, unnamed, and numeric)
          that contain text.
          .SP c[onnections]
          Display the source directories for all attached
          .CO cscope
          databases.
          .SP s[creens]
          Display the file names of all background screens.
          .SP t[ags]
          Display the tags stack.
          .SE
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY edit
          .IP "e[dit][!] [+cmd] [file]"
          .Ip "ex[!] [+cmd] [file]"
          Edit a different file.
          If the current buffer has been modified since the last complete write,
          the command will fail.
          You can override this by appending a
          .QT !
          character to the command name.
          .sp
          If the
          .QT +cmd
          option is specified, that
          .CO ex
          command will be executed in the new file.
          Any
          .CO ex
          command may be used, although the most common use of this feature is
          to specify a line number or search pattern to set the initial location
          in the new file.

     USD:13-114                                             Vi/Ex Reference

          .sp
          Capitalizing the first letter of the command, i.e.
          .CO Edit
          or
          .CO Ex ,
          while in
          .CO vi
          mode, will edit the file in a new screen.
          In this case, any modifications to the current file are ignored.
          .SS
          .SP Line:
          If you have previously edited the file, the current line will be set
          to your last position in the file.
          If that position does not exist, or you have not previously edited the
          file, the current line will be set to the first line of the file if
          you are in
          .CO vi
          mode, and the last line of the file if you are in
          .CO ex .
          .SP Options:
          None.
          .SE
          .KY exusage
          .IP "exu[sage] [command]"
          Display usage for an
          .CO ex
          command.
          If
          .LI command
          is specified, a usage statement for that command is displayed.
          Otherwise, usage statements for all
          .CO ex
          commands are displayed.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY file
          .IP "f[ile] [file]"
          Display and optionally change the file name.
          If a file name is specified, the current pathname is changed to the
          specified name.
          The current pathname, the number of lines, and the current position
          in the file are displayed.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY fg

     Vi/Ex Reference                                             USD:13-115

          .IP "fg [name]"
          .CO Vi
          mode only.
          Foreground the specified screen.
          If the argument name doesn't exactly match the name of a file displayed
          by a background screen,
          it is compared against the last component of each of the file names.
          If no background screen is specified,
          the first background screen is foregrounded.
          .sp
          By default,
          foregrounding causes the current screen to be swapped with the backgrounded
          screen.
          Capitalizing the first letter of the command, i.e.
          .CO Fg ,
          will foreground the backgrounded screen in a new screen instead of
          swapping it with the current screen.
          .SS
          .SP Line:
          Set to the current line when the screen was last edited.
          .SP Options:
          None.
          .SE
          .KY global
          .IP "[range] g[lobal] /pattern/ [commands]"
          .KY v
          .Ip "[range] v /pattern/ [commands]"
          Apply commands to lines matching (or not matching) a pattern.
          The lines within the given range that match
          .PQ g[lobal] ,
          or do not match
          .PQ v
          the given pattern are selected.
          Then, the specified
          .CO ex
          command(s) are executed with the current line
          .PQ .
          set to each selected line.
          If no range is specified, the entire file is searched for matching,
          or not matching, lines.
          .sp
          Multiple commands can be specified, one per line, by escaping each
          .LI <newline>
          character with a backslash, or by separating commands with a
          .QT |
          character.
          If no commands are specified, the command defaults to the
          .CO print
          command.
          .sp
          For the
          .CO append ,
          .CO change

     USD:13-116                                             Vi/Ex Reference

          and
          .CO insert
          commands, the input text must be part of the global command line.
          In this case, the terminating period can be omitted if it ends the commands.
          .sp
          The
          .CO visual
          command may also be specified as one of the
          .CO ex
          commands.
          In this mode, input is taken from the terminal.
          Entering a
          .CO Q
          command in
          .CO vi
          mode causes the next line matching the pattern to be selected and
          .CO vi
          to be reentered, until the list is exhausted.
          .sp
          The
          .CO global ,
          .CO v
          and
          .CO undo
          commands cannot be used as part of these commands.
          .sp
          The editor options
          .OP autoindent ,
          .OP autoprint
          and
          .OP report
          are turned off for the duration of the
          .CO global
          and
          .CO v
          commands.
          .SS
          .SP Line:
          The last line modified.
          .SP Options:
          Affected by the
          .OP ignorecase
          and
          .OP magic
          options.
          Turns off the
          .OP autoindent ,
          .OP autoprint
          and
          .OP report
          options.
          .SE
          .KY help

     Vi/Ex Reference                                             USD:13-117

          .IP "he[lp]"
          Display a help message.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY insert
          .IP "[line] i[nsert][!]"
          The input text is inserted before the specified line.
          Following the command name with a
          .QT !
          character causes the
          .OP autoindent
          option setting to be toggled for the duration of this command.
          .SS
          .SP Line:
          Set to the last line input; if no lines were input,
          set to the line before the target line, or to the first line
          of the file if there are no lines preceding the target line.
          Affected by the
          .OP autoindent
          and
          .OP number
          options.
          .SE
          .KY join
          .IP "[range] j[oin][!] [count] [flags]"
          Join lines of text together.
          .sp
          A
          .LI count
          specified to the
          .Sy join
          command specifies that the last line of the
          .LI range
          plus
          .LI count
          subsequent lines will be joined.
          (Note, this differs by one from the general rule where only
          .LI count - 1
          subsequent lines are affected.)
          .sp
          If the current line ends with a whitespace character, all whitespace
          is stripped from the next line.
          Otherwise, if the next line starts with a open parenthesis
          .PQ ( ,
          do nothing.
          Otherwise, if the current line ends with a question mark
          .PQ ? ,
          period
          .PQ .

     USD:13-118                                             Vi/Ex Reference

          or exclamation point
          .PQ ! ,
          insert two spaces.
          Otherwise, insert a single space.
          .sp
          Appending a
          .QT !
          character to the command name causes a simpler join with no
          whitespace processing.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY list
          .IP "[range] l[ist] [count] [flags]"
          Display the lines unambiguously.
          Tabs are displayed as
          .QT ^I ,
          and the end of the line is marked with a
          .QT $
          character.
          .SS
          .SP Line:
          Set to the last line displayed.
          .SP Options:
          Affected by the
          .OP number
          option.
          .SE
          .KY map
          .IP "map[!] [lhs rhs]"
          Define or display maps (for
          .CO vi
          only).
          .sp
          If
          .QT lhs
          and
          .QT rhs
          are not specified, the current set of command mode maps are displayed.
          If a
          .QT !
          character is appended to to the command,
          the text input mode maps are displayed.
          .sp
          Otherwise, when the
          .QT lhs
          character sequence is entered in
          .CO vi ,
          the action is as if the corresponding
          .QT rhs

     Vi/Ex Reference                                             USD:13-119

          had been entered.
          If a
          .QT !
          character is appended to the command name,
          the mapping is effective during text input mode,
          otherwise, it is effective during command mode.
          This allows
          .QT lhs
          to have two different macro definitions at the same time: one for command
          mode and one for input mode.
          .sp
          Whitespace characters require escaping with a
          .LI <literal-next>
          character to be entered in the
          .LI lhs
          string in visual mode.
          .sp
          Normally, keys in the
          .LI rhs
          string are remapped (see the
          .OP remap
          option),
          and it is possible to create infinite loops.
          However, keys which map to themselves are not further remapped,
          regardless of the setting of the
          .OP remap
          option.
          For example, the command
          .QT ":map n nz."
          maps the
          .QT n
          key to the
          .CO n
          and
          .CO z
          commands.
          .sp
          To exit an infinitely looping map, use the terminal
          .LI <interrupt>
          character.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          Affected by the
          .OP remap
          option.
          .SE
          .KY mark
          .KY k
          .IP "[line] ma[rk] <character>"
          .Ip "[line] k <character>"
          Mark the line with the mark

     USD:13-120                                             Vi/Ex Reference

          .LI <character> .
          The expressions
          .QT '<character>
          and
          .QT `<character>
          can then be used as an address in any command that uses one.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY move
          .IP "[range] m[ove] line"
          Move the specified lines after the target line.
          A target line of 0 places the lines at the beginning of the file.
          .SS
          .SP Line:
          Set to the first of the moved lines.
          .SP Options:
          None.
          .SE
          .KY mkexrc
          .IP "mk[exrc][!] file"
          Write the abbreviations, editor options and maps to the specified
          file.
          Information is written in a form which can later be read back in
          using the
          .CO ex
          .CO source
          command.
          If
          .LI file
          already exists, the
          .CO mkexrc
          command will fail.
          This check can be overridden by appending a
          .QT !
          character to the command.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY next
          .IP "n[ext][!] [file ...]"
          Edit the next file from the argument list.
          The
          .CO next
          command will fail if the file has been modified since the last complete
          write.
          This check can be overridden by appending the

     Vi/Ex Reference                                             USD:13-121

          .QT !
          character to the command name.
          The argument list can optionally be replaced by specifying a new one
          as arguments to this command.
          In this case, editing starts with the first file on the new list.
          .sp
          Capitalizing the first letter of the command, i.e.
          .CO Next ,
          while in
          .CO vi
          mode, will set the argument list and edit the file in a new screen.
          In this case, any modifications to the current file are ignored.
          .SS
          .SP Line:
          Set as described for the
          .CO edit
          command.
          .SP Options:
          Affected by the options
          .OP autowrite
          and
          .OP writeany .
          .SE
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .KY preserve
          .IP "pre[serve]"
          Save the file in a form that can later be recovered using the
          .CO ex
          .b -r
          option.
          When the file is preserved, an email message is sent to the user.
          .SS

     USD:13-122                                             Vi/Ex Reference

          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY previous
          .IP "prev[ious][!]"
          Edit the previous file from the argument list.
          The
          .CO previous
          command will fail if the file has been modified since the last complete
          write.
          This check can be overridden by appending the
          .QT !
          character to the command name.
          .sp
          Capitalizing the first letter of the command, i.e.
          .CO Previous ,
          while in
          .CO vi
          mode, will edit the file in a new screen.
          In this case, any modifications to the current file are ignored.
          .SS
          .SP Line:
          Set as described for the
          .CO edit
          command.
          .SP Options:
          Affected by the options
          .OP autowrite
          and
          .OP writeany .
          None.
          .SE
          .KY print
          .IP "[range] p[rint] [count] [flags]"
          Display the specified lines.
          .SS
          .SP Line:
          Set to the last line displayed.
          .SP Options:
          Affected by the
          .OP list
          and
          .OP number
          option.
          .SE
          .KY put
          .IP "[line] pu[t] [buffer]"
          Append buffer contents to the current line.
          If a buffer is specified, its contents are appended to the line,
          otherwise, the contents of the unnamed buffer are used.
          .SS

     Vi/Ex Reference                                             USD:13-123

          .SP Line:
          Set to the line after the current line.
          .SP Options:
          None.
          .SE
          .KY quit
          .IP "q[uit][!]"
          End the editing session.
          If the file has been modified since the last complete write, the
          .CO quit
          command will fail.
          This check may be overridden by appending a
          .QT !
          character to the command.
          .sp
          If there are more files to edit, the
          .CO quit
          command will fail.
          Appending a
          .QT !
          character to the command name or entering two
          .CO quit
          commands (i.e.
          .CO wq ,
          .CO quit ,
          .CO xit
          or
          .CO ZZ )
          in a row will override this check and the editor will exit.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY read
          .IP "[line] r[ead][!] [file]"
          Read a file.
          A copy of the specified file is appended to the line.
          If
          .LI line
          is 0, the copy is inserted at the beginning of the file.
          If no file is specified, the current file is read; if there is no
          current file, then
          .LI file
          becomes the current file.
          If there is no current file and no
          .LI file
          is specified, then the
          .CO read
          command will fail.
          .sp
          If

     USD:13-124                                             Vi/Ex Reference

          .LI file
          is preceded by a
          .QT !
          character,
          .LI file
          is treated as if it were a shell command, and passed to the program
          named by the
          .OP shell
          edit option.
          The standard and standard error outputs of that command are read into
          the file after the specified line.
          The special meaning of the
          .QT !
          character can be overridden by escaping it with a backslash
          .PQ \
          character.
          .SS
          .SP Line:
          When executed from
          .CO ex ,
          the current line is set to the last line read.
          When executed from
          .CO vi ,
          the current line is set to the first line read.
          .SP Options:
          None.
          .SE
          .KY recover
          .IP "rec[over] file"
          Recover
          .LI file
          if it was previously saved.
          If no saved file by that name exists, the
          .CO recover
          command behaves equivalently to the
          .CO edit
          command.
          .SS
          .SP Line:
          Set as described for the
          .CO edit
          command.
          .SP Options:
          None.
          .SE
          .KY resize
          .IP "res[ize] [+|-]size"
          .CO Vi
          mode only.
          Grow or shrink the current screen.
          If
          .LI size
          is a positive, signed number, the current screen is grown by that many lines.

     Vi/Ex Reference                                             USD:13-125

          If
          .LI size
          is a negative, signed number, the current screen is shrunk by that many lines.
          If
          .LI size
          is not signed, the current screen is set to the specified
          .LI size .
          Applicable only to split screens.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY rewind
          .IP "rew[ind][!]"
          Rewind the argument list.
          If the current file has been modified since the last complete write,
          the
          .CO rewind
          command will fail.
          This check may be overridden by appending the
          .QT !
          character to the command.
          .sp
          Otherwise, the current file is set to the first file in the argument
          list.
          .SS
          .SP Line:
          Set as described for the
          .CO edit
          command.
          .SP Options:
          Affected by the
          .OP autowrite
          and
          .OP writeany
          options.
          .SE
          .KY set
          .IP "se[t] [option[=[value]] ...] [nooption ...] [option? ...] [all]"
          Display or set editor options.
          When no arguments are specified, the editor option
          .OP term ,
          and any editor options whose values have been changed from the
          default settings are displayed.
          If the argument
          .LI all
          is specified, the values of all of editor options are displayed.
          .sp
          Specifying an option name followed by the character
          .QT ?
          causes the current value of that option to be displayed.

     USD:13-126                                             Vi/Ex Reference

          The
          .QT ?
          can be separated from the option name by whitespace characters.
          The
          .QT ?
          is necessary only for Boolean valued options.
          Boolean options can be given values by the form
          .QT "set option"
          to turn them on, or
          .QT "set nooption"
          to turn them off.
          String and numeric options can be assigned by the form
          .QT "set option=value" .
          Any whitespace characters in strings can be included literally by preceding
          each with a backslash.
          More than one option can be set or listed by a single set command,
          by specifying multiple arguments, each separated from the next by
          whitespace characters.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY shell
          .IP "sh[ell]"
          Run the shell program.
          The program named by the
          .OP shell
          option is run with a
          .b -i
          (for interactive) flag.
          Editing is resumed when that program exits.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          Affected by the
          .OP shell
          option.
          .SE
          .KY source
          .IP "so[urce] file"
          Read and execute
          .CO ex
          commands from a file.
          .CO Source
          commands may be nested.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.

     Vi/Ex Reference                                             USD:13-127

          .SE
          .KY substitute
          .IP "[range] s[ubstitute] [/pattern/replace/] [options] [count] [flags]"
          .KY &
          .Ip "[range] & [options] [count] [flags]"
          .KY ~
          .Ip "[range] ~ [options] [count] [flags]"
          Make substitutions.
          Replace the first instance of
          .LI pattern
          with the string
          .LI replace
          on the specified line(s).
          If the
          .QT /pattern/replace/
          argument is not specified, the
          .QT /pattern/replace/
          from the previous
          .CO substitute
          command is used.
          Any character other than an alphabetic, numeric, <blank> or backslash
          character may be used as the delimiter.
          .sp
          If
          .LI options
          includes the letter
          .QT c
          (confirm), you will be prompted for confirmation before each replacement
          is done.
          An affirmative response (in English, a
          .QT y
          character) causes the replacement to be made.
          A quit response (in English, a
          .QT q
          character) causes the
          .CO substitute
          command to be terminated.
          Any other response causes the replacement not to be made, and the
          .CO substitute
          command continues.
          If
          .LI options
          includes the letter
          .QT g
          (global), all nonoverlapping instances of
          .LI pattern
          in the line are replaced.
          .sp
          The
          .CO &
          version of the command is the same as not specifying a pattern
          or replacement string to the
          .CO substitute

     USD:13-128                                             Vi/Ex Reference

          command, and the
          .QT &
          is replaced by the pattern and replacement information from the
          previous substitute command.
          .sp
          The
          .CO ~
          version of the command is the same as
          .CO &
          and
          .CO s ,
          except that the search pattern used is the last RE used in
          .i any
          command, not necessarily the one used in the last
          .CO substitute
          command.
          .sp
          For example, in the sequence
          .ft C
          .(b
          s/red/blue/
          /green
          ~
          .)b
          .ft R
          the
          .QT ~
          is equivalent to
          .QT s/green/blue/ .
          .sp
          The
          .CO substitute
          command may be interrupted, using the terminal interrupt character.
          All substitutions completed before the interrupt are retained.
          .SS
          .SP Line:
          Set to the last line upon which a substitution was made.
          .SP Options:
          Affected by the
          .OP ignorecase
          and
          .OP magic
          option.
          .SE
          .KY suspend
          .IP "su[spend][!]"
          .KY stop
          .Ip "st[op][!]"
          .KY <control-Z>
          .Ip <control-Z>
          Suspend the edit session.
          Appending a
          .QT !

     Vi/Ex Reference                                             USD:13-129

          character to these commands turns off the
          .OP autowrite
          option for the command.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          Affected by the
          .OP autowrite
          and
          .OP writeany
          options.
          .SE
          .KY tag
          .IP "ta[g][!] tagstring"
          Edit the file containing the specified tag.
          If the tag is in a different file, then the new file is edited.
          If the current file has been modified since the last complete write,
          the
          .CO tag
          command will fail.
          This check can be overridden by appending the
          .QT !
          character to the command name.
          .sp
          The
          .CO tag
          command searches for
          .LI tagstring
          in the tags file(s) specified by the
          .Op tags
          option.
          (See
          .XR ctags 1
          for more information on tags files.)
          .sp
          Capitalizing the first letter of the command, i.e.
          .CO Tag ,
          while in
          .CO vi
          mode, will edit the file in a new screen.
          In this case, any modifications to the current file are ignored.
          .SS
          .SP Line:
          Set to the line indicated by the tag.
          .SP Options:
          Affected by the
          .OP autowrite ,
          .OP taglength ,
          .OP tags
          and
          .OP writeany
          options.

     USD:13-130                                             Vi/Ex Reference

          .SE
          .KY tagnext
          .IP "tagn[ext][!]"
          Edit the file containing the next context for the current tag.
          If the context is in a different file, then the new file is edited.
          If the current file has been modified since the last complete write,
          the
          .CO tagnext
          command will fail.
          This check can be overridden by appending the
          .QT !
          character to the command name.
          .sp
          Capitalizing the first letter of the command, i.e.
          .CO Tagnext ,
          while in
          .CO vi
          mode, will edit the file in a new screen.
          In this case, any modifications to the current file are ignored.
          .SS
          .SP Line:
          Set to the line indicated by the tag.
          .SP Options:
          Affected by the
          .OP autowrite
          and
          .OP writeany
          options.
          .SE
          .KY tagpop
          .IP "tagp[op][!] [file | number]"
          Pop to the specified tag in the tags stack.
          If neither
          .LI file
          or
          .LI number
          is specified, the
          .CO tagpop
          command pops to the most recent entry on the tags stack.
          If
          .LI file
          or
          .LI number
          is specified, the
          .CO tagpop
          command pops to the most recent entry in the tags stack for that file,
          or numbered entry in the tags stack, respectively.
          (See the
          .CO display
          command for information on displaying the tags stack.)
          .sp
          If the file has been modified since the last complete write, the
          .CO tagpop

     Vi/Ex Reference                                             USD:13-131

          command will fail.
          This check may be overridden by appending a
          .QT !
          character to the command name.
          .SS
          .SP Line:
          Set to the line indicated by the tag.
          .SP Options:
          Affected by the
          .OP autowrite
          and
          .OP writeany
          options.
          .SE
          .KY tagprev
          .IP "tagp[rev][!]"
          Edit the file containing the previous context for the current tag.
          If the context is in a different file, then the new file is edited.
          If the current file has been modified since the last complete write,
          the
          .CO tagprev
          command will fail.
          This check can be overridden by appending the
          .QT !
          character to the command name.
          .sp
          Capitalizing the first letter of the command, i.e.
          .CO Tagprev ,
          while in
          .CO vi
          mode, will edit the file in a new screen.
          In this case, any modifications to the current file are ignored.
          .SS
          .SP Line:
          Set to the line indicated by the tag.
          .SP Options:
          Affected by the
          .OP autowrite
          and
          .OP writeany
          options.
          .SE
          .KY tagtop
          .IP "tagt[op][!]"
          Pop to the least recent tag on the tags stack, clearing the tags stack.
          .sp
          If the file has been modified since the last complete write, the
          .CO tagtop
          command will fail.
          This check may be overridden by appending a
          .QT !
          character to the command name.
          .SS

     USD:13-132                                             Vi/Ex Reference

          .SP Line:
          Set to the line indicated by the tag.
          .SP Options:
          Affected by the
          .OP autowrite
          and
          .OP writeany
          options.
          .SE
          .KY unabbreviate
          .IP "una[bbreviate] lhs"
          Delete an abbreviation.
          Delete
          .LI lhs
          from the current list of abbreviations.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY undo
          .IP "u[ndo]"
          Undo the last change made to the file.
          Changes made by
          .CO global ,
          .CO v ,
          .CO visual
          and map sequences are considered a single command.
          If repeated, the
          .CO u
          command alternates between these two states, and is its own inverse.
          .SS
          .SP Line:
          Set to the last line modified by the command.
          .SP Options:
          None.
          .SE
          .KY unmap
          .IP "unm[ap][!] lhs"
          Unmap a mapped string.
          Delete the command mode map definition for
          .LI lhs .
          If a
          .QT !
          character is appended to the command name, delete the text input mode
          map definition instead.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE

     Vi/Ex Reference                                             USD:13-133

          .KY version
          .IP "ve[rsion]"
          Display the version of the
          .CO ex/vi
          editor.
          .KY visual
          .IP "[line] vi[sual] [type] [count] [flags]"
          .CO Ex
          mode only.
          Enter
          .CO vi .
          The
          .LI type
          is optional, and can be
          .QT - ,
          .QT +
          or
          .QT ^ ,
          as in the
          .CO ex
          .CO z
          command, to specify the position of the specified line in the screen
          window.
          (The default is to place the line at the top of the screen window.)
          A
          .LI count
          specifies the number of lines that will initially be displayed.
          (The default is the value of the
          .OP window
          editor option.)
          .SS
          .SP Line:
          Unchanged unless
          .LI line
          is specified, in which case it is set to that line.
          .SP Options:
          None.
          .SE
          .KY visual
          .IP "vi[sual][!] [+cmd] [file]"
          .CO Vi
          mode only.
          Edit a new file.
          Identical to the
          .QT "edit[!] [+cmd] [file]"
          command.
          .sp
          Capitalizing the first letter of the command, i.e.
          .CO Visual ,
          will edit the file in a new screen.
          In this case, any modifications to the current file are ignored.
          .KY viusage
          .IP "viu[sage] [command]"

     USD:13-134                                             Vi/Ex Reference

          Display usage for a
          .CO vi
          command.
          If
          .LI command
          is specified, a usage statement for that command is displayed.
          Otherwise, usage statements for all
          .CO vi
          commands are displayed.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY write
          .IP "[range] w[rite][!] [>>] [file]"
          .Ip "[range] w[rite] [!] [file]"
          .KY wn
          .Ip "[range] wn[!] [>>] [file]"
          .KY wq
          .Ip "[range] wq[!] [>>] [file]"
          Write the file.
          The specified lines (the entire file, if no range is given) is written
          to
          .LI file .
          If
          .LI file
          is not specified, the current pathname is used.
          If
          .LI file
          is specified, and it exists, or if the current pathname was set using the
          .CO file
          command, and the file already exists, these commands will fail.
          Appending a
          .QT !
          character to the command name will override this check and the write
          will be attempted, regardless.
          .sp
          Specifying the optional
          .QT >>
          string will cause the write to be appended to the file, in which case
          no tests are made for the file already existing.
          .sp
          If the file is preceded by a
          .QT !
          character, the program named by the shell edit option is
          invoked with file as its second argument, and the specified
          lines are passed as standard input to that command.
          The
          .QT !
          in this usage must be separated from command name by at least one
          whitespace character.

     Vi/Ex Reference                                             USD:13-135

          The special meaning of the
          .QT !
          may be overridden by escaping it with a backslash
          .PQ \
          character.
          .sp
          The
          .CO wq
          version of the write command will exit the editor after writing the file,
          if there are no further files to edit.
          Appending a
          .QT !
          character to the command name or entering two
          .QQ quit
          commands (i.e.
          .CO wq ,
          .CO quit ,
          .CO xit
          or
          .CO ZZ )
          in a row will override this check and the editor will exit,
          ignoring any files that have not yet been edited.
          .sp
          The
          .CO wn
          version of the write command will move to the next file after writing
          the file, unless the write fails.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          Affected by the
          .OP readonly
          and
          .OP writeany
          options.
          .SE
          .KY xit
          .IP "[range] x[it][!] [file]"
          Write the file if it has been modified.
          The specified lines are written to
          .LI file ,
          if the file has been modified since the last complete write to any
          file.
          If no
          .LI range
          is specified, the entire file is written.
          .sp
          The
          .CO xit
          command will exit the editor after writing the file,
          if there are no further files to edit.
          Appending a

     USD:13-136                                             Vi/Ex Reference

          .QT !
          character to the command name or entering two
          .QQ quit
          commands (i.e.
          .CO wq ,
          .CO quit ,
          .CO xit
          or
          .CO ZZ )
          in a row will override this check and the editor will exit,
          ignoring any files that have not yet been edited.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          Affected by the
          .OP readonly
          and
          .OP writeany
          options.
          .SE
          .KY yank
          .IP "[range] ya[nk] [buffer] [count]"
          Copy the specified lines to a buffer.
          If no buffer is specified, the unnamed buffer is used.
          .SS
          .SP Line:
          Unchanged.
          .SP Options:
          None.
          .SE
          .KY z
          .IP "[line] z [type] [count] [flags]"
          Adjust the window.
          If no
          .LI type
          is specified, then
          .LI count
          lines following the specified line are displayed.
          The default
          .LI count
          is the value of the
          .OP window
          option.
          The
          .LI type
          argument changes the position at which
          .LI line
          is displayed on the screen by changing the number of lines
          displayed before and after
          .LI line .
          The following
          .LI type

     Vi/Ex Reference                                             USD:13-137

          characters may be used:
          .SS
          .SP -
          Place the line at the bottom of the screen.
          .SP +
          Place the line at the top of the screen.
          .SP .
          Place the line in the middle of the screen.
          .SP ^
          Write out count lines starting
          .LI "count * 2"
          lines before
          .LI line ;
          the net effect of this is that a
          .QT z^
          command following a
          .CO z
          command writes the previous page.
          .SP =
          Center
          .LI line
          on the screen with a line of hyphens displayed immediately before and
          after it.
          The number of preceding and following lines of text displayed are
          reduced to account for those lines.
          .SE
          .SS
          .SP Line:
          Set to the last line displayed, with the exception of the
          .Dq Li =
          .LI type ,
          where the current line is set to the line specified by the command.
          .SP Options:
          Affected by the
          .OP scroll
          option.
          .SE
          .oh 'Vi/Ex Reference (Options)''USD:13-%'
          .eh 'USD:13-%''Vi/Ex Reference (Options)'
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .
          .SH 1 "Set Options"
          .pp
          There are a large number of options that may be set (or unset) to

     USD:13-138                                             Vi/Ex Reference

          change the editor's behavior.
          This section describes the options, their abbreviations and their
          default values.
          .pp
          In each entry below, the first part of the tag line is the full name
          of the option, followed by any equivalent abbreviations.
          (Regardless of the abbreviations, it is only necessary to use the
          minimum number of characters necessary to distinguish an abbreviation
          from all other commands for it to be accepted, in
          .EV nex nvi .
          Historically, only the full name and the official abbreviations
          were accepted by
          .EV ex vi .
          Using full names in your startup files and environment variables will
          probably make them more portable.)
          The part in square brackets is the default value of the option.
          Most of the options are boolean, i.e. they are either on or off,
          and do not have an associated value.
          .pp
          Options apply to both
          .CO ex
          and
          .CO vi
          modes, unless otherwise specified.
          .pp
          With a few exceptions,
          all options are settable per screen, i.e. the
          .OP tags
          option can be set differently in each screen.
          The exceptions are the
          .OP columns ,
          .OP lines ,
          .OP secure
          and
          .OP term
          options.
          Changing these options modifies the respective information for all screens.
          .pp
          For information on modifying the options or to display the options and
          their current values, see the
          .QQ set
          command in the section entitled
          .QB "Ex Commands" .
          .KY altwerase
          .IP "altwerase [off]"
          .CO Vi
          only.
          Change how
          .CO vi
          does word erase during text input.
          When this option is set, text is broken up into three classes:
          alphabetic, numeric and underscore characters, other nonblank
          characters, and blank characters.

     Vi/Ex Reference                                             USD:13-139

          Changing from one class to another marks the end of a word.
          In addition, the class of the first character erased is ignored
          (which is exactly what you want when erasing pathname components).
          .KY autoindent
          .IP "autoindent, ai [off]"
          If this option is set, whenever you create a new line (using the
          .CO vi
          .CO A ,
          .CO a ,
          .CO C ,
          .CO c ,
          .CO I ,
          .CO i ,
          .CO O ,
          .CO o ,
          .CO R ,
          .CO r ,
          .CO S ,
          and
          .CO s
          commands, or the
          .CO ex
          .CO append ,
          .CO change ,
          and
          .CO insert
          commands) the new line is automatically indented to align the cursor with
          the first nonblank character of the line from which you created it.
          Lines are indented using tab characters to the extent possible (based on
          the value of the
          .OP tabstop
          option) and then using space characters as necessary.
          For commands inserting text into the middle of a line, any blank characters
          to the right of the cursor are discarded, and the first nonblank character
          to the right of the cursor is aligned as described above.
          .sp
          The indent characters are themselves somewhat special.
          If you do not enter more characters on the new line before moving to
          another line, or entering
          .LI <escape> ,
          the indent character will be deleted and the line will be empty.
          For example, if you enter
          .LI <carriage-return>
          twice in succession,
          the line created by the first
          .LI <carriage-return>
          will not have any characters in it,
          regardless of the indentation of the previous or subsequent line.
          .sp
          Indent characters also require that you enter additional erase characters
          to delete them.
          For example,
          if you have an indented line, containing only blanks, the first

     USD:13-140                                             Vi/Ex Reference

          .LI <word-erase>
          character you enter will erase up to end of the indent characters,
          and the second will erase back to the beginning of the line.
          (Historically, only the
          .LI <control-D>
          key would erase the indent characters.
          Both the
          .LI <control-D>
          key and the usual erase keys work in
          .CO nvi .)
          In addition, if the cursor is positioned at the end of the indent
          characters, the keys
          .QT 0<control-D>
          will erase all of the indent characters for the current line,
          resetting the indentation level to 0.
          Similarly, the keys
          .QT ^<control-D>
          will erase all of the indent characters for the current line,
          leaving the indentation level for future created lines unaffected.
          .sp
          Finally, if the
          .OP autoindent
          option is set, the
          .CO S
          and
          .CO cc
          commands change from the first nonblank of the line to the end of the
          line, instead of from the beginning of the line to the end of the line.
          .KY autoprint
          .IP "autoprint, ap [on]"
          .CO Ex
          only.
          Cause the current line to be automatically displayed after the
          .CO ex
          commands
          .CO < ,
          .CO > ,
          .CO copy ,
          .CO delete ,
          .CO join ,
          .CO move ,
          .CO put ,
          .CO t ,
          .CO Undo ,
          and
          .CO undo .
          This automatic display is suppressed during
          .CO global
          and
          .CO v
          commands, and for any command where optional flags are used to explicitly
          display the line.
          .KY autowrite

     Vi/Ex Reference                                             USD:13-141

          .IP "autowrite, aw [off]"
          If this option is set, the
          .CO vi
          .CO ! ,
          .CO ^^ ,
          .CO ^]
          and
          .CO <control-Z>
          commands, and the
          .CO ex
          .CO edit ,
          .CO next ,
          .CO rewind ,
          .CO stop ,
          .CO suspend ,
          .CO tag ,
          .CO tagpop ,
          and
          .CO tagtop
          commands automatically write the current file back to the current file name
          if it has been modified since it was last written.
          If the write fails, the command fails and goes no further.
          .sp
          Appending the optional force flag character
          .QT !
          to the
          .CO ex
          commands
          .CO next ,
          .CO rewind ,
          .CO stop ,
          .CO suspend ,
          .CO tag ,
          .CO tagpop ,
          and
          .CO tagtop
          stops the automatic write from being attempted.
          .sp
          (Historically, the
          .CO next
          command ignored the optional force flag.)
          Note, the
          .CO ex
          commands
          .CO edit ,
          .CO quit ,
          .CO shell ,
          and
          .CO xit
          are
          .i not
          affected by the
          .OP autowrite

     USD:13-142                                             Vi/Ex Reference

          option.
          .sp
          The
          .OP autowrite
          option is ignored if the file is considered read-only for any reason.
          .
          .
          .
          .tr Q"
          .ds ms backup [QQ]
          .KY backup
          .IP ""
          .tr QQ
          If this option is set, it specifies a pathname used as a backup file,
          and, whenever a file is written, the file's current contents are copied
          to it.
          The pathname is
          .QT # ,
          .QT %
          and
          .QT !
          expanded.
          .sp
          If the first character of the pathname is
          .QT N ,
          a version number is appended to the pathname (and the
          .QT N
          character is then discarded).
          Version numbers are always incremented, and each backup file will have
          a version number one greater than the highest version number currently
          found in the directory.
          .sp
          Backup files must be regular files, owned by the real user ID of the
          user running the editor, and not accessible by any other user.
          .KY beautify
          .IP "beautify, bf [off]"
          If this option is set, all control characters that are not currently being
          specially interpreted, other than
          .LI <tab> ,
          .LI <newline> ,
          and
          .LI <form-feed> ,
          are
          discarded from commands read in by
          .CO ex
          from command files, and from input text entered to
          .CO vi
          (either into the file or to the colon command line).
          Text files read by
          .EV ex vi
          are
          .i not
          affected by the

     Vi/Ex Reference                                             USD:13-143

          .OP beautify
          option.
          .KY cdpath
          .IP "cdpath [environment variable CDPATH, or current directory]"
          This option is used to specify a colon separated list of directories
          which are used as path prefixes for any relative path names used as
          arguments for the
          .CO cd
          command.
          The value of this option defaults to the value of the environment
          variable
          .LI CDPATH
          if it is set, otherwise to the current directory.
          For compatibility with the POSIX 1003.2 shell, the
          .CO cd
          command does
          .i not
          check the current directory as a path prefix for relative path names
          unless it is explicitly specified.
          It may be so specified by entering an empty string or a
          .QT .
          character into the
          .LI CDPATH
          variable or the option value.
          .KY cedit
          .IP "cedit [no default]"
          This option adds the ability to edit the colon command-line history.
          This option is set to a string.
          Whenever the first character of that string is entered on the colon
          command line,
          you will enter a normal editing window on the collected commands that
          you've entered on the
          .CO vi
          colon command-line.
          You may then modify and/or execute the commands.
          All normal text editing is available,
          except that you cannot use
          .CO <control-W>
          to switch to an alternate screen.
          Entering a
          .CO <carriage-return>
          will execute the current line of the screen window as an ex command in
          the context of the screen from which you created the colon command-line
          screen,
          and you will then return to that screen.
          .sp
          Because of
          .CO vi 's
          parsing rules, it can be difficult to set the colon command-line edit
          character to the
          .LI <escape>
          character.
          To set it to

     USD:13-144                                             Vi/Ex Reference

          .LI <escape> ,
          use
          .QT "set cedit=<literal-next><escape>" .
          .sp
          If the
          .OP cedit
          edit option is set to the same character as the
          .OP filec
          edit option,
          .CO vi
          will perform colon command-line editing if the character is entered as
          the first character of the line,
          otherwise,
          .CO vi
          will perform file name expansion.
          .KY columns
          .IP "columns, co [80]"
          The number of columns in the screen.
          Setting this option causes
          .EV ex vi
          to set (or reset) the environment variable
          .LI COLUMNS .
          See the section entitled
          .QB "Sizing the Screen"
          more information.
          .KY comment
          .IP "comment [off]"
          .CO Vi
          only.
          If the first non-empty line of the file begins with the string
          .QT # ,
          .QT /*
          or
          .QT // ,
          this option causes
          .CO vi
          to skip to the end of that shell, C or C++ comment (probably a
          terribly boring legal notice) before displaying the file.
          .KY directory
          .IP "directory, dir [environment variable TMPDIR, or /tmp]"
          The directory where temporary files are created.
          The environment variable
          .LI TMPDIR
          is used as the default value if it exists, otherwise
          .LI /tmp
          is used.
          .KY edcompatible
          .IP "edcompatible, ed [off]"
          Remember the values of the
          .QQ c
          and
          .QQ g
          suffixes to the

     Vi/Ex Reference                                             USD:13-145

          .CO substitute
          commands, instead of initializing them as unset for each new
          command.
          Specifying pattern and replacement strings to the
          .CO substitute
          command unsets the
          .QQ c
          and
          .QQ g
          suffixes as well.
          .KY escapetime
          .IP "escapetime [1]"
          The 10th's of a second
          .EV ex vi
          waits for a subsequent key to complete an
          .LI <escape>
          key mapping.
          .KY errorbells
          .IP "errorbells, eb [off]"
          .CO Ex
          only.
          .CO Ex
          error messages are normally presented in inverse video.
          If that is not possible for the terminal, setting this option causes
          error messages to be announced by ringing the terminal bell.
          .KY exrc
          .IP "exrc, ex [off]"
          If this option is turned on in the EXINIT environment variables,
          or the system or $HOME startup files,
          the local startup files are read,
          unless they are the same as the system or $HOME startup files or
          fail to pass the standard permission checks.
          See the section entitled
          .QB "Startup Information"
          for more information.
          .KY extended
          .IP "extended [off]"
          This option causes all regular expressions to be treated as POSIX
          1003.2 Extended Regular Expressions (which are similar to historic
          .XR egrep 1
          style expressions).
          .KY filec
          .IP "filec [no default]"
          This option adds the ability to do shell expansion when entering input
          on the colon command line.
          This option is set to a string.
          Whenever the first character of that string is entered on the colon
          command line,
          the <blank> delimited string immediately before the cursor is expanded
          as if it were followed by a
          .LI *
          character, and file name expansion for the
          .CO ex

     USD:13-146                                             Vi/Ex Reference

          edit command was done.
          If no match is found, the screen is flashed and text input resumed.
          If a single match results, that match replaces the expanded text.
          In addition, if the single match is for a directory, a
          .LI /
          character is appended and file completion is repeated.
          If more than a single match results,
          any unique prefix shared by the matches replaces the expanded text,
          the matches are displayed,
          and text input resumed.
          .sp
          Because of
          .CO vi 's
          parsing rules, it can be difficult to set the path completion character
          to two command values,
          .LI <escape>
          and
          .LI <tab> .
          To set it to
          .LI <escape> ,
          use
          .QT "set filec=<literal-next><escape>" .
          To set it to
          .LI <tab> ,
          use
          .QT "set filec=\<tab>" .
          .sp
          If the
          .OP cedit
          edit option is set to the same character as the
          .OP filec
          edit option,
          .CO vi
          will perform colon command-line editing if the character is entered as
          the first character of the line,
          otherwise,
          .CO vi
          will perform file name expansion.
          .KY flash
          .IP "flash [off]"
          This option causes the screen to flash instead of beeping the keyboard,
          on error, if the terminal has the capability.
          .KY hardtabs
          .IP "hardtabs, ht [0]"
          This option defines the spacing between hardware tab settings, i.e.
          the tab expansion done by the operating system and/or the terminal
          itself.
          As
          .EV nex nvi
          never writes
          .LI <tab>
          characters to the terminal, unlike historic versions of
          .EV ex vi ,

     Vi/Ex Reference                                             USD:13-147

          this option does not currently have any affect.
          .KY iclower
          .IP "iclower [off]"
          The
          .OP iclower
          edit option makes all Regular Expressions case-insensitive,
          as long as an upper-case letter does not appear in the search string.
          .KY ignorecase
          .IP "ignorecase, ic [off]"
          This option causes regular expressions, both in
          .CO ex
          commands and in searches,
          to be evaluated in a case-insensitive manner.
          .KY keytime
          .IP "keytime [6]"
          The 10th's of a second
          .EV ex vi
          waits for a subsequent key to complete a key mapping.
          .KY leftright
          .IP "leftright [off]"
          .CO Vi
          only.
          This option causes the screen to be scrolled left-right to view
          lines longer than the screen, instead of the traditional
          .CO vi
          screen interface which folds long lines at the right-hand margin
          of the terminal.
          .KY lines
          .IP "lines, li [24]"
          .CO Vi
          only.
          The number of lines in the screen.
          Setting this option causes
          .EV ex vi
          to set (or reset) the environment variable
          .LI LINES .
          See the section entitled
          .QB "Sizing the Screen"
          for more information.
          .KY lisp
          .IP "lisp [off]"
          .CO Vi
          only.
          This option changes the behavior of the
          .CO vi
          .CO ( ,
          .CO ) ,
          .CO { ,
          .CO } ,
          .CO [[
          and
          .CO ]]
          commands to match the Lisp language.

     USD:13-148                                             Vi/Ex Reference

          Also, the
          .OP autoindent
          option's behavior is changed to be appropriate for Lisp.
          .sp
          .i "This option is not yet implemented."
          .KY list
          .IP "list [off]"
          This option causes lines to be displayed in an unambiguous fashion.
          Specifically, tabs are displayed as control characters, i.e.
          .QT ^I ,
          and the ends of lines are marked with a
          .QT $
          character.
          .KY lock
          .IP "lock [on]"
          This option causes the editor to attempt to get an exclusive lock on
          any file being edited, read or written.
          Reading or writing a file that cannot be locked produces a warning
          message, but no other effect.
          Editing a file that cannot be locked results in a read only edit session,
          as if the
          .OP readonly
          edit option were set.
          .KY magic
          .IP "magic [on]"
          This option is on by default.
          Turning the
          .OP magic
          option off causes all regular expression characters except for
          .QT ^
          and
          .QT $ ,
          to be treated as ordinary characters.
          To re-enable characters individually, when the
          .OP magic
          option is off,
          precede them with a backslash
          .QT \
          character.
          See the section entitled
          .QB "Regular Expressions and Replacement Strings"
          for more information.
          .KY matchtime
          .IP "matchtime [7]"
          .CO Vi
          only.
          The 10th's of a second
          .CO vi
          pauses on the matching character when the
          .OP showmatch
          option is set.
          .KY mesg
          .IP "mesg [on]"

     Vi/Ex Reference                                             USD:13-149

          This option allows other users to contact you using the
          .XR talk 1
          and
          .XR write 1
          utilities, while you are editing.
          .EV Ex vi
          does not turn message on, i.e. if messages were turned off when the
          editor was invoked, they will stay turned off.
          This option only permits you to disallow messages for the edit session.
          See the
          .XR mesg 1
          utility for more information.
          .KY msgcat
          .IP "msgcat [/usr/share/vi/catalog/]"
          This option selects a message catalog to be used to display error and
          informational messages in a specified language.
          If the value of this option ends with a '/', it is treated as the name
          of a directory that contains a message catalog
          .QT "vi_XXXX" ,
          where
          .QT XXXX
          is the value of the
          .LI LANG
          environment variable, if it's set, or the value of the
          .LI LC_MESSAGES
          environment variable if it's not.
          If neither of those environment variables are set,
          or if the option doesn't end in a '/',
          the option is treated as the full path name of the message catalog to use.
          .sp
          If any messages are missing from the catalog,
          the backup text (English) is used instead.
          .sp
          See the distribution file
          .LI catalog/README
          for additional information on building and installing message catalogs.
          .KY modelines
          .IP "modelines, modeline [off]"
          If the
          .OP modelines
          option is set,
          .EV ex vi
          has historically scanned the first and last five lines of each file as
          it is read for editing, looking for any
          .CO ex
          commands that have been placed in those lines.
          After the startup information has been processed, and before the user
          starts editing the file, any commands embedded in the file are executed.
          .sp
          Commands were recognized by the letters
          .QQ e
          or
          .QQ v

     USD:13-150                                             Vi/Ex Reference

          followed by
          .QQ x
          or
          .QQ i ,
          at the beginning of a line or following a tab or space character,
          and followed by a
          .QQ : ,
          an
          .CO ex
          command, and another
          .QQ : .
          .sp
          This option is a security problem of immense proportions,
          and should not be used under any circumstances.
          .sp
          .i "This option will never be implemented."
          .
          .
          .
          .tr Q"
          .ds ms noprint [QQ]
          .KY noprint
          .IP ""
          .tr QQ
          Characters that are never handled as printable characters.
          By default, the C library function
          .XR isprint 3
          is used to determine if a character is printable or not.
          This edit option overrides that decision.
          .KY number
          .IP "number, nu [off]"
          Precede each line displayed with its current line number.
          .KY octal
          .IP "octal [off]"
          Display unknown characters as octal numbers
          .PQ "\###" ,
          instead of the default
          hexadecimal
          .PQ "\x##" .
          .KY open
          .IP "open [on]"
          .CO Ex
          only.
          If this option is not set, the
          .CO open
          and
          .CO visual
          commands are disallowed.
          .KY optimize
          .IP "optimize, opt [on]"
          .CO Vi
          only.
          Throughput of text is expedited by setting the terminal not to do automatic

     Vi/Ex Reference                                             USD:13-151

          carriage returns when printing more than one (logical) line of output,
          greatly speeding output on terminals without addressable cursors when text
          with leading whitespace is printed.
          .sp
          .i "This option is not yet implemented."
          .KY paragraphs
          .IP "paragraphs, para [IPLPPPQPP LIpplpipbp]"
          .CO Vi
          only.
          Define additional paragraph boundaries for the
          .CO {
          and
          .CO }
          commands.
          The value of this option must be a character string consisting
          of zero or more character pairs.
          .sp
          In the text to be edited, the character string
          .LI "<newline>.<char-pair>" ,
          (where
          .LI <char-pair>
          is one of the character pairs in the option's value)
          defines a paragraph boundary.
          For example, if the option were set to
          .LI "LaA<space>##" ,
          then all of the following additional paragraph boundaries would be
          recognized:
          .sp
          .(l
          <newline>.La
          <newline>.A<space>
          <newline>.##
          .)l
          .KY path
          .IP "path []"
          The path option can be used to specify a <colon>-separated list of
          paths, similar to the
          .LI PATH
          environment variable in the shells.
          If this option is set,
          the name of the file to be edited is not an absolute pathname,
          the first component of the filename is not
          .QT .
          or
          .QT .. ,
          and the file to be edited doesn't exist in the current directory,
          the elements of the
          .OP path
          option are sequentially searched for a file of the specified name.
          If such a file is found, it is edited.
          .
          .
          .

     USD:13-152                                             Vi/Ex Reference

          .tr Q"
          .ds ms print [QQ]
          .KY print
          .IP ""
          .tr QQ
          Characters that are always handled as printable characters.
          By default, the C library function
          .XR isprint 3
          is used to determine if a character is printable or not.
          This edit option overrides that decision.
          .KY prompt
          .IP "prompt [on]"
          .CO Ex
          only.
          This option causes
          .CO ex
          to prompt for command input with a
          .QT :
          character; when it is not set, no prompt is displayed.
          .KY readonly
          .IP "readonly, ro [off]"
          This option causes a force flag to be required to attempt to write the file.
          Setting this option is equivalent to using the
          .b -R
          command line option,
          or executing the
          .CO vi
          program using the name
          .CO view .
          .sp
          The
          .OP readonly
          edit option is not usually persistent, like other edit options.
          If the
          .b -R
          command line option is set,
          .CO vi
          is executed as
          .CO view ,
          or the
          .OP readonly
          edit option is explicitly set,
          all files edited in the screen will be marked readonly,
          and the force flag will be required to write them.
          However, if none of these conditions are true,
          or the
          .OP readonly
          edit option is explicitly unset,
          then the
          .OP readonly
          edit option will toggle based on the write permissions of the file currently
          being edited as of when it is loaded into the edit buffer.
          In other words, the

     Vi/Ex Reference                                             USD:13-153

          .OP readonly
          edit option will be set if the current file lacks write permissions,
          and will not be set if the user has write permissions for the file.
          .KY recdir
          .IP "recdir [/var/tmp/vi.recover]"
          The directory where recovery files are stored.
          .sp
          If you change the value of
          .OP recdir ,
          be careful to choose a directory whose contents are not regularly
          deleted.
          Bad choices include directories in memory based filesystems,
          or
          .LI /tmp ,
          on most systems,
          as their contents are removed when the machine is rebooted.
          .sp
          Public directories like
          .LI /usr/tmp
          and
          .LI /var/tmp
          are usually safe, although some sites periodically prune old files
          from them.
          There is no requirement that you use a public directory,
          e.g. a sub-directory of your home directory will work fine.
          .sp
          Finally, if you change the value of
          .OP recdir ,
          you must modify the recovery script to operate in your chosen recovery
          area.
          .sp
          See the section entitled
          .QB "Recovery"
          for further information.
          .KY redraw
          .IP "redraw, re [off]"
          .CO Vi
          only.
          The editor simulates (using great amounts of output), an intelligent
          terminal on a dumb terminal (e.g. during insertions in
          .CO vi
          the characters to the right of the cursor are refreshed as each input
          character is typed).
          .sp
          .i "This option is not yet implemented."
          .KY remap
          .IP "remap [on]"
          If this option is set,
          it is possible to define macros in terms of other macros.
          Otherwise, each key is only remapped up to one time.
          For example, if
          .QT A
          is mapped to

     USD:13-154                                             Vi/Ex Reference

          .QT B ,
          and
          .QT B
          is mapped to
          .QT C ,
          The keystroke
          .QT A
          will be mapped to
          .QT C
          if the
          .OP remap
          option is set, and to
          .QT B
          if it is not set.
          .KY report
          .IP "report [5]"
          Set the threshold of the number of lines that need to be changed or
          yanked before a message will be displayed to the user.
          For everything but the yank command, the value is the largest value
          about which the editor is silent, i.e. by default, 6 lines must be
          deleted before the user is notified.
          However, if the number of lines yanked is greater than
          .i "or equal to"
          the set value, it is reported to the user.
          .KY ruler
          .IP "ruler [off]"
          .CO Vi
          only.
          Display a row/column ruler on the colon command line.
          .KY scroll
          .IP "scroll, scr [(environment variable LINES - 1) / 2]"
          Set the number of lines scrolled by the
          .CO ex
          .CO <control-D>
          and
          .CO <end-of-file>
          commands.
          .sp
          Historically, the
          .CO ex
          .CO z
          command, when specified without a count, used two times the size of the
          scroll value; the POSIX 1003.2 standard specified the window size, which
          is a better choice.
          .KY searchincr
          .IP "searchincr [off]"
          The
          .OP searchincr
          edit option makes the search commands
          .CO /
          and
          .CO ?
          incremental, i.e. the screen is updated and the cursor moves to the matching

     Vi/Ex Reference                                             USD:13-155

          text as the search pattern is entered.
          If the search pattern is not found,
          the screen is beeped and the cursor remains on the colon-command line.
          Erasing characters from the search pattern backs the cursor up to the
          previous matching text.
          .KY sections
          .IP "sections, sect [NHSHH HUnhsh]"
          .CO Vi
          only.
          Define additional section boundaries for the
          .CO [[
          and
          .CO ]]
          commands.
          The
          .OP sections
          option should be set to a character string consisting of zero or
          more character pairs.
          In the text to be edited, the character string
          .LI "<newline>.<char-pair>" ,
          (where
          .LI <char-pair>
          is one of the character pairs in the option's value),
          defines a section boundary in the same manner that
          .OP paragraphs
          option boundaries are defined.
          .KY secure
          .IP "secure [off]"
          The
          .OP secure
          edit option turns off all access to external programs.
          This means that the versions of the
          .CO read
          and
          .CO write
          commands that filter text through other programs,
          the
          .CO vi
          .CO !
          and
          .CO <control-Z>
          commands,
          the
          .CO ex
          .CO ! ,
          .CO script ,
          .CO shell ,
          .CO stop
          and
          .CO suspend
          commands and file name expansion will not be permitted.
          Once set,
          the

     USD:13-156                                             Vi/Ex Reference

          .OP secure
          edit option may not be unset.
          .KY shell
          .IP "shell, sh [environment variable SHELL, or /bin/sh]"
          Select the shell used by the editor.
          The specified path is the pathname of the shell invoked by the
          .CO vi
          .CO !
          shell escape command and by the
          .CO ex
          .CO shell
          command.
          This program is also used to resolve any shell meta-characters in
          .CO ex
          commands.
          .
          .
          .
          .tr Q"
          .ds ms shellmeta [~{[*?$`'Q\]
          .KY shellmeta
          .IP ""
          .tr QQ
          The set of characters that
          .CO ex
          checks for when doing file name expansion.
          If any of the specified characters are found in the file name arguments
          to the
          .CO ex
          commands,
          the arguments are expanded using the program defined by the
          .OP shell
          option.
          The default set of characters is a union of meta characters
          from the Version 7 and the Berkeley C shell.
          .KY shiftwidth
          .IP "shiftwidth, sw [8]"
          Set the autoindent and shift command indentation width.
          This width is used by the
          .OP autoindent
          option and by the
          .CO < ,
          .CO > ,
          and
          .CO shift
          commands.
          .KY showmatch
          .IP "showmatch, sm [off]"
          .CO Vi
          only.
          This option causes
          .CO vi ,
          when a

     Vi/Ex Reference                                             USD:13-157

          .QT }
          or
          .QT )
          is entered, to briefly move the cursor the matching
          .QT {
          or
          .QT ( .
          See the
          .OP matchtime
          option for more information.
          .KY showmode
          .IP "showmode, smd [off]"
          .CO Vi
          only.
          This option causes
          .CO vi
          to display a string identifying the current editor mode on the colon
          command line.
          The string is preceded by an asterisk (``*'') if the file has been
          modified since it was last completely written,
          .KY sidescroll
          .IP "sidescroll [16]"
          .CO Vi
          only.
          Sets the number of columns that are shifted to the left or right,
          when
          .CO vi
          is doing left-right scrolling and the left or right margin is
          crossed.
          See the
          .OP leftright
          option for more information.
          .KY slowopen
          .IP "slowopen, slow [off]"
          This option affects the display algorithm used by
          .CO vi ,
          holding off display updating during input of new text to improve
          throughput when the terminal in use is slow and unintelligent.
          .sp
          .i "This option is not yet implemented."
          .KY sourceany
          .IP "sourceany [off]"
          If this option is turned on,
          .CO vi
          historically read startup files that were owned by someone other than
          the editor user.
          See the section entitled
          .QB "Startup Information"
          for more information.
          This option is a security problem of immense proportions,
          and should not be used under any circumstances.
          .sp
          .i "This option will never be implemented."

     USD:13-158                                             Vi/Ex Reference

          .KY tabstop
          .IP "tabstop, ts [8]"
          This option sets tab widths for the editor display.
          .KY taglength
          .IP "taglength, tl [0]"
          This option sets the maximum number of characters that are considered
          significant in a tag name.
          Setting the value to 0 makes all of the characters in the tag name
          significant.
          .KY tags
          .IP "tags, tag [tags]"
          Sets the list of tags files, in search order,
          which are used when the editor searches for a tag.
          .KY term
          .IP "term, ttytype, tty [environment variable TERM]"
          Set the terminal type.
          Setting this option causes
          .EV ex vi
          to set (or reset) the environment variable
          .LI TERM .
          .KY terse
          .IP "terse [off]"
          This option has historically made editor messages less verbose.
          It has no effect in this implementation.
          See the
          .OP verbose
          option for more information.
          .KY tildeop
          .IP "tildeop [off]"
          Modify the
          .CO ~
          command to take an associated motion.
          .KY timeout
          .IP "timeout, to [on]"
          If this option is set,
          .EV ex vi
          waits for a specific period for a subsequent key to complete a key
          mapping (see the
          .OP keytime
          option).
          If the option is not set, the editor waits until enough keys are
          entered to resolve the ambiguity, regardless of how long it takes.
          .KY ttywerase
          .IP "ttywerase [off]"
          .CO Vi
          only.
          This option changes how
          .CO vi
          does word erase during text input.
          If this option is set, text is broken up into two classes,
          blank characters and nonblank characters.
          Changing from one class to another marks the end of a word.
          .KY verbose

     Vi/Ex Reference                                             USD:13-159

          .IP "verbose [off]"
          .CO Vi
          only.
          .CO Vi
          historically bells the terminal for many obvious mistakes, e.g. trying
          to move past the left-hand margin, or past the end of the file.
          If this option is set, an error message is displayed for all errors.
          .KY w300
          .IP "w300 [no default]"
          .CO Vi
          only.
          Set the window size if the baud rate is less than 1200 baud.
          See the
          .OP window
          option for more information.
          .KY w1200
          .IP "w1200 [no default]"
          .CO Vi
          only.
          Set the window size if the baud rate is equal to 1200 baud.
          See the
          .OP window
          option for more information.
          .KY w9600
          .IP "w9600 [no default]"
          .CO Vi
          only.
          Set the window size if the baud rate is greater than 1200 baud.
          See the
          .OP window
          option for more information.
          .KY warn
          .IP "warn [on]"
          .CO Ex
          only.
          This option causes a warning message to the terminal if the file has
          been modified, since it was last written, before a
          .CO !
          command.
          .KY window
          .IP "window, w, wi [environment variable LINES - 1]"
          This option determines the default number of lines in a screenful,
          as displayed by the
          .CO z
          command.
          It also determines the number of lines scrolled by the
          .CO vi
          commands
          .CO <control-B>
          and
          .CO <control-F> ,
          and the default number of lines scrolled by the
          .CO vi

     USD:13-160                                             Vi/Ex Reference

          commands
          .CO <control-D>
          and
          .CO <control-U> .
          The value of window can be unrelated to the real screen size,
          although it starts out as the number of lines on the screen.
          See the section entitled
          .QB "Sizing the Screen"
          for more information.
          Setting the value of the
          .OP window
          option is the same as using the
          .b -w
          command line option.
          .sp
          If the value of the
          .OP window
          option (as set by the
          .OP window ,
          .OP w300 ,
          .OP w1200
          or
          .OP w9600
          options) is smaller than the actual size of the screen,
          large screen movements will result in displaying only that smaller
          number of lines on the screen.
          (Further movements in that same area will result in the screen being
          filled.)
          This can provide a performance improvement when viewing different
          places in one or more files over a slow link.
          .sp
          Resetting the window size does not reset the default number of lines
          scrolled by the
          .CO <control-D>
          and
          .CO <control-U>
          commands.
          .KY windowname
          .IP "windowname [off]"
          .CO Vi
          changes the name of the editor's icon/window to the current file name
          when it's possible and not destructive, i.e.,
          when the editor can restore it to its original value on exit or when
          the icon/window will be discarded as the editor exits.
          If the
          .OP windowname
          edit option is set,
          .CO vi
          will change the icon/window name even when it's destructive and the
          icon/window name will remain after the editor exits.
          (This is the case for
          .XR xterm 1 ).
          .KY wraplen

     Vi/Ex Reference                                             USD:13-161

          .IP "wraplen, wl [0]"
          This option is identical to the
          .OP wrapmargin
          option, with the exception that it specifies the number of columns
          from the
          .i left
          margin before the line splits, not the right margin.
          .sp
          If both
          .OP wraplen
          and
          .OP wrapmargin
          are set, the
          .OP wrapmargin
          value is used.
          .KY wrapmargin
          .IP "wrapmargin, wm [0]"
          .CO Vi
          only.
          If the value of the
          .OP wrapmargin
          option is non-zero,
          .CO vi
          will split lines so that they end at least that number of columns
          before the right-hand margin of the screen.
          (Note, the value of
          .OP wrapmargin
          is
          .i not
          a text length.
          In a screen that is 80 columns wide, the command
          .QT ":set wrapmargin=8"
          attempts to keep the lines less than or equal to 72 columns wide.)
          .sp
          Lines are split at the previous whitespace character closest to the
          number.
          Any trailing whitespace characters before that character are deleted.
          If the line is split because of an inserted
          .LI <space>
          or
          .LI <tab>
          character, and you then enter another
          .LI <space>
          character, it is discarded.
          .sp
          If wrapmargin is set to 0,
          or if there is no blank character upon which to split the line,
          the line is not broken.
          .sp
          If both
          .OP wraplen
          and
          .OP wrapmargin

     USD:13-162                                             Vi/Ex Reference

          are set, the
          .OP wrapmargin
          value is used.
          .KY wrapscan
          .IP "wrapscan, ws [on]"
          This option causes searches to wrap around the end or the beginning
          of the file, and back to the starting point.
          Otherwise, the end or beginning of the file terminates the search.
          .KY writeany
          .IP "writeany, wa [off]"
          If this option is set, file-overwriting checks that would usually be
          made before the
          .CO write
          and
          .CO xit
          commands, or before an automatic write (see the
          .OP autowrite
          option), are not made.
          This allows a write to any file, provided the file permissions allow it.
          .oh 'Vi/Ex Reference''USD:13-%'
          .eh 'USD:13-%''Vi/Ex Reference'
          .bp
          .SH 1 Index
          .lp
          .2c +0.5i 3
          .ta 1680uR
          .nf

          .fi
          .
          .if o .bp
          .bp 3
          .1c
          .ce 1
          Table of Contents
          .sp
          .xp

Generated on 2022-12-24 01:00:14 by $MirOS: src/scripts/roff2htm,v 1.113 2022/12/21 23:14:31 tg Exp $ — This product includes material provided by mirabilos.

These manual pages and other documentation are copyrighted by their respective writers; their sources are available at the project’s CVSweb, AnonCVS and other mirrors. The rest is Copyright © 2002–2022 MirBSD.

This manual page’s HTML representation is supposed to be valid XHTML/1.1; if not, please send a bug report — diffs preferred.

Kontakt / Impressum & Datenschutzerklärung