8.6. Command History
Previously executed commands are
stored in a history list. You can access this list to verify
commands, repeat them, or execute modified versions of them. The
history built-in command displays
the history list; the predefined variables histchars and history also affect the history mechanism.
There are a number of ways to use the history list:
-
Rerun a previous command
-
Edit a previous command
-
Make command substitutions
-
Make argument substitutions (replace specific words in a command)
-
Extract or replace parts of a command or word
The easiest way to take advantage of the command history is to use
the arrow keys to move around in the history, select the command you
want, and then rerun it or use the editing features described in
Section 8.7.5, later in this
chapter, to modify the command. The arrow keys are:
Key
|
Description
|
Up arrow
|
Previous command.
|
Down arrow
|
Next command.
|
Left arrow
|
Move left in command line.
|
Right arrow
|
Move right in command line.
|
The next sections describe some tools for editing and rerunning
commands. With the C shell, which does not have the command-line
editing features of tcsh, these
tools are important for rerunning commands. With tcsh, they are less often used, but they still
work.
8.6.1. Command Substitution
Command
|
Description
|
!
|
Begin a history substitution.
|
!!
|
Previous command.
|
!N
|
Command number N in history list.
|
!-N
|
Nth command back from current command.
|
!string
|
Most recent command that starts with string.
|
!?string?
|
Most recent command that contains string.
|
!?string?%
|
Most recent command argument that contains
string.
|
!$
|
Last argument of previous command.
|
!!string
|
Previous command, then append string.
|
!N string
|
Command N, then append
string.
|
!{s1}s2
|
Most recent command starting with string s1,
then append string s2.
|
^old^new^
|
Quick substitution; change string old to
new in previous command, and execute modified
command.
|
8.6.3. Word Substitution
Colons may precede any word
specifier.
Specifier
|
Description
|
:0
|
Command name
|
:n
|
Argument number n
|
^
|
First argument
|
$
|
Last argument
|
:n-m
|
Arguments n through m
|
-m
|
Words 0 through m; same as
:0-m
|
:n-
|
Arguments n through next-to-last
|
:n*
|
Arguments n through last; same as
n-$
|
*
|
All arguments; same as ^-$ or
1-$
|
#
|
Current command line up to this point; fairly useless
|
8.6.5. History Modifiers
Command and word substitutions can be
modified by one or more of the following modifiers:
8.6.5.1. Printing, substitution, and quoting
Modifier
|
Description
|
:p
|
Display command, but don't execute.
|
:s/old/new
|
Substitute string new for
old, first instance only.
|
:gs/old/new
|
Substitute string new for
old, all instances.
|
:&
|
Repeat previous substitution (:s or
^ command), first instance only.
|
:g&
|
Repeat previous substitution, all instances.
|
:q
|
Quote a wordlist.
|
:x
|
Quote separate words.
|
8.6.5.2. Truncation
Modifier
|
Description
|
:r
|
Extract the first available pathname root (the portion before the
last period).
|
:gr
|
Extract all pathname roots.
|
:e
|
Extract the first available pathname extension (the portion after the
last period).
|
:ge
|
Extract all pathname extensions.
|
:h
|
Extract the first available pathname header (the portion before the
last slash).
|
:gh
|
Extract all pathname headers.
|
:t
|
Extract the first available pathname tail (the portion after the last
slash).
|
:gt
|
Extract all pathname tails.
|
:u
|
Make first lowercase letter uppercase.
|
:l
|
Make first uppercase letter lowercase.
|
:a
|
Apply modifier(s) following a as
many times as possible to a word. If used with g, a is
applied to all words.
|
 |  |  | 8.5. Expressions |  | 8.7. Command-Line Manipulation |
Copyright © 2003 O'Reilly & Associates. All rights reserved.
|
|