Previously executed commands are stored in a history list. The C shell lets you access this list so you can verify commands, repeat them, or execute modified versions of them. The history built-in command displays the history list; the predefined variables histchars, history, and savehist also affect the history mechanism. Accessing the history list involves three things:
Making command substitutions (using ! and ^)
Making argument substitutions (specific words within a command)
Using modifiers to extract or replace parts of a command or word
| ! | 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; execute modified command |
The following command is assumed:
3% vi cprogs/01.c ch002 ch03
| Event Number | Command Typed | Command Executed |
|---|---|---|
| 4 | ^00^0 | vi cprogs/01.c ch02 ch03 |
| 5 | nroff !* | nroff cprogs/01.c ch02 ch03 |
| 6 | nroff !$ | nroff ch03 |
| 7 | !vi | vi cprogs/01.c ch02 ch03 |
| 8 | !6 | nroff ch03 |
| 9 | !?01 | vi cprogs/01.c ch02 ch03 |
| 10 | !{nr}.new | nroff ch03.new |
| 11 | !!|lp | nroff ch03.new | lp |
| 12 | more !?pr?% | more cprogs/01.c |
Word specifiers allow you to retrieve individual words from previous command lines. Colons may precede any word specifier. After an event number, colons are optional unless shown here.
| :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 |
The following command is assumed:
13% cat ch01 ch02 ch03 biblio back
| Event Number | Command Typed | Command Executed |
|---|---|---|
| 14 | ls !13^ | ls ch01 |
| 15 | sort !13:* | sort ch01 ch02 ch03 biblio back |
| 16 | lp !cat:3* | lp ch03 biblio back |
| 17 | !cat:0-3 | cat ch01 ch02 ch03 |
| 18 | vi !-5:4 | vi biblio |
Command and word substitutions can be modified by one or more of these:
| :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 word list. |
| :x | Quote separate words. |
| :r | Extract the first available pathname root. |
| :gr | Extract all pathname roots. |
| :e | Extract the first available pathname extension. |
| :ge | Extract all pathname extensions. |
| :h | Extract the first available pathname header. |
| :gh | Extract all pathname headers. |
| :t | Extract the first available pathname tail. |
| :gt | Extract all pathname tails. |
From the table in Section 5.5.4, command number 17 is:
17% cat ch01 ch02 ch03
| Event # | Command Typed | Command Executed |
|---|---|---|
| 19 | !17:s/ch/CH/ | cat CH01 ch02 ch03 |
| 20 | !:g& | cat CH01 CH02 CH03 |
| 21 | !more:p | more cprogs/01.c (displayed only) |
| 22 | cd !$:h | cd cprogs |
| 23 | vi !mo:$:t | vi 01.c |
| 24 | grep stdio !$ | grep stdio 01.c |
| 25 | ^stdio^include stdio^:q | grep "include stdio" 01.c |
| 26 | nroff !21:t:p | nroff 01.c (is that want I wanted?) |
| 27 | !! | nroff 01.c (execute it) |
Copyright © 2003 O'Reilly & Associates. All rights reserved.