Up
Next
Previous
Editor commands (+)
`bindkey' lists key bindings and `bindkey -l' lists and briefly describes
editor commands.
Only new or especially interesting editor commands are described here.
See emacs(1) and vi(1) for descriptions of each editor's
key bindings.
The character or characters to which each command is bound by default is
given in parentheses.  `^character' means a control character and
`M-character' a meta character, typed as escape-character
on terminals without a meta key.  Case counts, but commands that are bound
to letters by default are bound to both lower- and uppercase letters for
convenience.
- 
backward-char (^B, left)
- 
Move back a character.
Cursor behavior modified by vimode.
 
- 
backward-delete-word (M-^H, M-^?)
- 
Cut from beginning of current word to cursor - saved in cut buffer.
Word boundary behavior modified by vimode.
 
- 
backward-word (M-b, M-B)
- 
Move to beginning of current word.
Word boundary and cursor behavior modified by vimode.
 
- 
beginning-of-line (^A, home)
- 
Move to beginning of line.
Cursor behavior modified by vimode.
 
- 
capitalize-word (M-c, M-C)
- 
Capitalize the characters from cursor to end of current word.
Word boundary behavior modified by vimode.
 
- 
complete-word (tab)
- 
Completes a word as described under Completion and listing.
 
- 
complete-word-back (not bound)
- 
Like complete-word-fwd, but steps up from the end of the list.
 
- 
complete-word-fwd (not bound)
- 
Replaces the current word with the first word in the list of possible
completions.  May be repeated to step down through the list.
At the end of the list, beeps and reverts to the incomplete word.
 
- 
complete-word-raw (^X-tab)
- 
Like complete-word, but ignores user-defined completions.
 
- 
copy-prev-word (M-^_)
- 
Copies the previous word in the current line into the input buffer.
See also insert-last-word.
Word boundary behavior modified by vimode.
 
- 
dabbrev-expand (M-/)
- 
Expands the current word to the most recent preceding one for which
the current is a leading substring, wrapping around the history list
(once) if necessary.
Repeating dabbrev-expand without any intervening typing
changes to the next previous word etc., skipping identical matches
much like history-search-backward does.
 
- 
delete-char (not bound)
- 
Deletes the character under the cursor.
See also delete-char-or-list-or-eof.
Cursor behavior modified by vimode.
 
- 
delete-char-or-eof (not bound)
- 
Does delete-char if there is a character under the cursor
or end-of-file on an empty line.
See also delete-char-or-list-or-eof.
Cursor behavior modified by vimode.
 
- 
delete-char-or-list (not bound)
- 
Does delete-char if there is a character under the cursor
or list-choices at the end of the line.
See also delete-char-or-list-or-eof.
 
- 
delete-char-or-list-or-eof (^D)
- 
Does delete-char if there is a character under the cursor,
list-choices at the end of the line
or end-of-file on an empty line.
See also those three commands, each of which does only a single action, and
delete-char-or-eof, delete-char-or-list and list-or-eof,
each of which does a different two out of the three.
 
- 
delete-word (M-d, M-D)
- 
Cut from cursor to end of current word - save in cut buffer.
Word boundary behavior modified by vimode.
 
- 
down-history (down-arrow, ^N)
- 
Like up-history, but steps down, stopping at the original input line.
 
- 
downcase-word (M-l, M-L)
- 
Lowercase the characters from cursor to end of current word.
Word boundary behavior modified by vimode.
 
- 
end-of-file (not bound)
- 
Signals an end of file, causing the shell to exit unless the ignoreeof
shell variable (q.v.) is set to prevent this.
See also delete-char-or-list-or-eof.
 
- 
end-of-line (^E, end)
- 
Move cursor to end of line.
Cursor behavior modified by vimode.
 
- 
expand-history (M-space)
- 
Expands history substitutions in the current word.
See History substitution.
See also magic-space, toggle-literal-history and
the autoexpand shell variable.
 
- 
expand-glob (^X-*)
- 
Expands the glob-pattern to the left of the cursor.
See Filename substitution.
 
- 
expand-line (not bound)
- 
Like expand-history, but
expands history substitutions in each word in the input buffer.
 
- 
expand-variables (^X-$)
- 
Expands the variable to the left of the cursor.
See Variable substitution.
 
- 
forward-char (^F, right)
- 
Move forward one character.
Cursor behavior modified by vimode.
 
- 
forward-word (M-f, M-F)
- 
Move forward to end of current word.
Word boundary and cursor behavior modified by vimode.
 
- 
history-search-backward (M-p, M-P)
- 
Searches backwards through the history list for a command beginning with
the current contents of the input buffer up to the cursor and copies it
into the input buffer.
The search string may be a glob-pattern (see Filename substitution)
containing `*', `?', `[]' or `{}'.
up-history and down-history will proceed from the
appropriate point in the history list.
Emacs mode only.
See also history-search-forward and i-search-back.
 
- 
history-search-forward (M-n, M-N)
- 
Like history-search-backward, but searches forward.
 
- 
i-search-back (not bound)
- 
Searches backward like history-search-backward, copies the first match
into the input buffer with the cursor positioned at the end of the pattern,
and prompts with `bck: ' and the first match.  Additional characters may be
typed to extend the search, i-search-back may be typed to continue
searching with the same pattern, wrapping around the history list if
necessary, (i-search-back must be bound to a
single character for this to work) or one of the following special characters
may be typed:
- 
^W
- 
Appends the rest of the word under the cursor to the search pattern.
 
- 
delete (or any character bound to backward-delete-char)
- 
Undoes the effect of the last character typed and deletes a character
from the search pattern if appropriate.
 
- 
^G
- 
If the previous search was successful, aborts the entire search.
If not, goes back to the last successful search.
 
- 
escape
- 
Ends the search, leaving the current line in the input buffer.
Any other character not bound to self-insert-command terminates the
search, leaving the current line in the input buffer, and
is then interpreted as normal input.  In particular, a carriage return
causes the current line to be executed.
See also i-search-fwd and history-search-backward.
Word boundary behavior modified by vimode.
- 
i-search-fwd (not bound)
- 
Like i-search-back, but searches forward.
Word boundary behavior modified by vimode.
 
- 
insert-last-word (M-_)
- 
Inserts the last word of the previous input line (`!$') into the input buffer.
See also copy-prev-word.
 
- 
list-choices (M-^D)
- 
Lists completion possibilities as described under Completion and listing.
See also delete-char-or-list-or-eof and list-choices-raw.
 
- 
list-choices-raw (^X-^D)
- 
Like list-choices, but ignores user-defined completions.
 
- 
list-glob (^X-g, ^X-G)
- 
Lists (via the ls-F builtin) matches to the glob-pattern
(see Filename substitution) to the left of the cursor.
 
- 
list-or-eof (not bound)
- 
Does list-choices
or end-of-file on an empty line.
See also delete-char-or-list-or-eof.
 
- 
magic-space (not bound)
- 
Expands history substitutions in the current line,
like expand-history, and inserts a space.
magic-space is designed to be bound to the space bar,
but is not bound by default.
 
- 
normalize-command (^X-?)
- 
Searches for the current word in PATH and, if it is found, replaces it with
the full path to the executable.  Special characters are quoted.  Aliases are
expanded and quoted but commands within aliases are not.  This command is
useful with commands that take commands as arguments, e.g., `dbx' and `sh -x'.
 
- 
normalize-path (^X-n, ^X-N)
- 
Expands the current word as described under the `expand' setting
of the symlinks shell variable.
 
- 
overwrite-mode (unbound)
- 
Toggles between input and overwrite modes.
 
- 
run-fg-editor (M-^Z)
- 
Saves the current input line and
looks for a stopped job where the file name portion of its first word
is found in the editors shell variable.
If editors is not set, then the file name portion of the
EDITOR environment variable (`ed' if unset)
and the
VISUAL environment variable (`vi' if unset)
will be used.
If such a job is found, it is restarted as if `fg %job' had been
typed.  This is used to toggle back and forth between an editor and
the shell easily.  Some people bind this command to `^Z' so they
can do this even more easily.
 
- 
run-help (M-h, M-H)
- 
Searches for documentation on the current command, using the same notion of
`current command' as the completion routines, and prints it.  There is no way
to use a pager; run-help is designed for short help files.
If the special alias helpcommand is defined, it is run with the
command name as a sole argument.  Else,
documentation should be in a file named command.help, command.1,
command.6, command.8 or command, which should be in one
of the directories listed in the HPATH environment variable.
If there is more than one help file only the first is printed.
 
- 
self-insert-command (text characters)
- 
In insert mode (the default), inserts the typed character into the input line after the character under the cursor.
In overwrite mode, replaces the character under the cursor with the typed character.
The input mode is normally preserved between lines, but the
inputmode shell variable can be set to `insert' or `overwrite' to put the
editor in that mode at the beginning of each line.
See also overwrite-mode.
 
- 
sequence-lead-in (arrow prefix, meta prefix, ^X)
- 
Indicates that the following characters are part of a
multi-key sequence.  Binding a command to a multi-key sequence really creates
two bindings: the first character to sequence-lead-in and the
whole sequence to the command.  All sequences beginning with a character
bound to sequence-lead-in are effectively bound to undefined-key
unless bound to another command.
 
- 
spell-line (M-$)
- 
Attempts to correct the spelling of each word in the input buffer, like
spell-word, but ignores words whose first character is one of
`-', `!', `^' or `%', or which contain `\', `*' or `?', to avoid problems
with switches, substitutions and the like.
See Spelling correction.
 
- 
spell-word (M-s, M-S)
- 
Attempts to correct the spelling of the current word as described
under Spelling correction.
Checks each component of a word which appears to be a pathname.
 
- 
toggle-literal-history (M-r, M-R)
- 
Expands or `unexpands' history substitutions in the input buffer.
See also expand-history and the autoexpand shell variable.
 
- 
undefined-key (any unbound key)
- 
Beeps.
 
- 
up-history (up-arrow, ^P)
- 
Copies the previous entry in the history list into the input buffer.
If histlit is set, uses the literal form of the entry.
May be repeated to step up through the history list, stopping at the top.
 
- 
upcase-word (M-u, M-U)
- 
Uppercase the characters from cursor to end of current word.
Word boundary behavior modified by vimode.
 
- 
vi-beginning-of-next-word (not bound)
- 
Vi goto the beginning of next word.
Word boundary and cursor behavior modified by vimode.
 
- 
vi-eword (not bound)
- 
Vi move to the end of the current word.
Word boundary behavior modified by vimode.
 
- 
vi-search-back (?)
- 
Prompts with `?' for a search string (which may be a glob-pattern, as with
history-search-backward), searches for it and copies it into the
input buffer.  The bell rings if no match is found.
Hitting return ends the search and leaves the last match in the input
buffer.
Hitting escape ends the search and executes the match.
vi mode only.
 
- 
vi-search-fwd (/)
- 
Like vi-search-back, but searches forward.
 
- 
which-command (M-?)
- 
Does a which (see the description of the builtin command) on the
first word of the input buffer.
 
- 
yank-pop (M-y)
- 
When executed immediately after a yank or another yank-pop,
replaces the yanked string with the next previous string from the
killring. This also has the effect of rotating the killring, such that
this string will be considered the most recently killed by a later
yank command. Repeating yank-pop will cycle through the
killring any number of times.
Up
Next
Previous