]> git.ipfire.org Git - thirdparty/bash.git/blob - lib/readline/doc/hsuser.texi
bash-4.4 beta release
[thirdparty/bash.git] / lib / readline / doc / hsuser.texi
1 @ignore
2 This file documents the user interface to the GNU History library.
3
4 Copyright (C) 1988--2014 Free Software Foundation, Inc.
5 Authored by Brian Fox and Chet Ramey.
6
7 Permission is granted to make and distribute verbatim copies of this manual
8 provided the copyright notice and this permission notice are preserved on
9 all copies.
10
11 Permission is granted to process this file through Tex and print the
12 results, provided the printed document carries copying permission notice
13 identical to this one except for the removal of this paragraph (this
14 paragraph not being relevant to the printed manual).
15
16 Permission is granted to copy and distribute modified versions of this
17 manual under the conditions for verbatim copying, provided also that the
18 GNU Copyright statement is available to the distributee, and provided that
19 the entire resulting derived work is distributed under the terms of a
20 permission notice identical to this one.
21
22 Permission is granted to copy and distribute translations of this manual
23 into another language, under the above conditions for modified versions.
24 @end ignore
25
26 @node Using History Interactively
27 @chapter Using History Interactively
28
29 @ifclear BashFeatures
30 @defcodeindex bt
31 @end ifclear
32
33 @ifset BashFeatures
34 This chapter describes how to use the @sc{gnu} History Library
35 interactively, from a user's standpoint.
36 It should be considered a user's guide.
37 For information on using the @sc{gnu} History Library in other programs,
38 see the @sc{gnu} Readline Library Manual.
39 @end ifset
40 @ifclear BashFeatures
41 This chapter describes how to use the @sc{gnu} History Library interactively,
42 from a user's standpoint. It should be considered a user's guide. For
43 information on using the @sc{gnu} History Library in your own programs,
44 @pxref{Programming with GNU History}.
45 @end ifclear
46
47 @ifset BashFeatures
48 @menu
49 * Bash History Facilities:: How Bash lets you manipulate your command
50 history.
51 * Bash History Builtins:: The Bash builtin commands that manipulate
52 the command history.
53 * History Interaction:: What it feels like using History as a user.
54 @end menu
55 @end ifset
56 @ifclear BashFeatures
57 @menu
58 * History Interaction:: What it feels like using History as a user.
59 @end menu
60 @end ifclear
61
62 @ifset BashFeatures
63 @node Bash History Facilities
64 @section Bash History Facilities
65 @cindex command history
66 @cindex history list
67
68 When the @option{-o history} option to the @code{set} builtin
69 is enabled (@pxref{The Set Builtin}),
70 the shell provides access to the @dfn{command history},
71 the list of commands previously typed.
72 The value of the @env{HISTSIZE} shell variable is used as the
73 number of commands to save in a history list.
74 The text of the last @env{$HISTSIZE}
75 commands (default 500) is saved.
76 The shell stores each command in the history list prior to
77 parameter and variable expansion
78 but after history expansion is performed, subject to the
79 values of the shell variables
80 @env{HISTIGNORE} and @env{HISTCONTROL}.
81
82 When the shell starts up, the history is initialized from the
83 file named by the @env{HISTFILE} variable (default @file{~/.bash_history}).
84 The file named by the value of @env{HISTFILE} is truncated, if
85 necessary, to contain no more than the number of lines specified by
86 the value of the @env{HISTFILESIZE} variable.
87 When a shell with history enabled exits, the last
88 @env{$HISTSIZE} lines are copied from the history list to the file
89 named by @env{$HISTFILE}.
90 If the @code{histappend} shell option is set (@pxref{Bash Builtins}),
91 the lines are appended to the history file,
92 otherwise the history file is overwritten.
93 If @env{HISTFILE}
94 is unset, or if the history file is unwritable, the history is not saved.
95 After saving the history, the history file is truncated
96 to contain no more than @env{$HISTFILESIZE} lines.
97 If @env{HISTFILESIZE} is unset, or set to null, a non-numeric value, or
98 a numeric value less than zero, the history file is not truncated.
99
100 If the @env{HISTTIMEFORMAT} is set, the time stamp information
101 associated with each history entry is written to the history file,
102 marked with the history comment character.
103 When the history file is read, lines beginning with the history
104 comment character followed immediately by a digit are interpreted
105 as timestamps for the previous history line.
106
107 The builtin command @code{fc} may be used to list or edit and re-execute
108 a portion of the history list.
109 The @code{history} builtin may be used to display or modify the history
110 list and manipulate the history file.
111 When using command-line editing, search commands
112 are available in each editing mode that provide access to the
113 history list (@pxref{Commands For History}).
114
115 The shell allows control over which commands are saved on the history
116 list. The @env{HISTCONTROL} and @env{HISTIGNORE}
117 variables may be set to cause the shell to save only a subset of the
118 commands entered.
119 The @code{cmdhist}
120 shell option, if enabled, causes the shell to attempt to save each
121 line of a multi-line command in the same history entry, adding
122 semicolons where necessary to preserve syntactic correctness.
123 The @code{lithist}
124 shell option causes the shell to save the command with embedded newlines
125 instead of semicolons.
126 The @code{shopt} builtin is used to set these options.
127 @xref{Bash Builtins}, for a description of @code{shopt}.
128
129 @node Bash History Builtins
130 @section Bash History Builtins
131 @cindex history builtins
132
133 Bash provides two builtin commands which manipulate the
134 history list and history file.
135
136 @table @code
137
138 @item fc
139 @btindex fc
140 @example
141 @code{fc [-e @var{ename}] [-lnr] [@var{first}] [@var{last}]}
142 @code{fc -s [@var{pat}=@var{rep}] [@var{command}]}
143 @end example
144
145 The first form selects a range of commands from @var{first} to
146 @var{last} from the history list and displays or edits and re-executes
147 them.
148 Both @var{first} and
149 @var{last} may be specified as a string (to locate the most recent
150 command beginning with that string) or as a number (an index into the
151 history list, where a negative number is used as an offset from the
152 current command number). If @var{last} is not specified it is set to
153 @var{first}. If @var{first} is not specified it is set to the previous
154 command for editing and @minus{}16 for listing. If the @option{-l} flag is
155 given, the commands are listed on standard output. The @option{-n} flag
156 suppresses the command numbers when listing. The @option{-r} flag
157 reverses the order of the listing. Otherwise, the editor given by
158 @var{ename} is invoked on a file containing those commands. If
159 @var{ename} is not given, the value of the following variable expansion
160 is used: @code{$@{FCEDIT:-$@{EDITOR:-vi@}@}}. This says to use the
161 value of the @env{FCEDIT} variable if set, or the value of the
162 @env{EDITOR} variable if that is set, or @code{vi} if neither is set.
163 When editing is complete, the edited commands are echoed and executed.
164
165 In the second form, @var{command} is re-executed after each instance
166 of @var{pat} in the selected command is replaced by @var{rep}.
167 @var{command} is intepreted the same as @var{first} above.
168
169 A useful alias to use with the @code{fc} command is @code{r='fc -s'}, so
170 that typing @samp{r cc} runs the last command beginning with @code{cc}
171 and typing @samp{r} re-executes the last command (@pxref{Aliases}).
172
173 @item history
174 @btindex history
175 @example
176 history [@var{n}]
177 history -c
178 history -d @var{offset}
179 history [-anrw] [@var{filename}]
180 history -ps @var{arg}
181 @end example
182
183 With no options, display the history list with line numbers.
184 Lines prefixed with a @samp{*} have been modified.
185 An argument of @var{n} lists only the last @var{n} lines.
186 If the shell variable @env{HISTTIMEFORMAT} is set and not null,
187 it is used as a format string for @var{strftime} to display
188 the time stamp associated with each displayed history entry.
189 No intervening blank is printed between the formatted time stamp
190 and the history line.
191
192 Options, if supplied, have the following meanings:
193
194 @table @code
195 @item -c
196 Clear the history list. This may be combined
197 with the other options to replace the history list completely.
198
199 @item -d @var{offset}
200 Delete the history entry at position @var{offset}.
201 @var{offset} should be specified as it appears when the history is
202 displayed.
203
204 @item -a
205 Append the new history lines to the history file.
206 These are history lines entered since the beginning of the current
207 Bash session, but not already appended to the history file.
208
209 @item -n
210 Append the history lines not already read from the history file
211 to the current history list. These are lines appended to the history
212 file since the beginning of the current Bash session.
213
214 @item -r
215 Read the history file and append its contents to
216 the history list.
217
218 @item -w
219 Write out the current history list to the history file.
220
221 @item -p
222 Perform history substitution on the @var{arg}s and display the result
223 on the standard output, without storing the results in the history list.
224
225 @item -s
226 The @var{arg}s are added to the end of
227 the history list as a single entry.
228
229 @end table
230
231 When any of the @option{-w}, @option{-r}, @option{-a}, or @option{-n} options is
232 used, if @var{filename}
233 is given, then it is used as the history file. If not, then
234 the value of the @env{HISTFILE} variable is used.
235
236 @end table
237 @end ifset
238
239 @node History Interaction
240 @section History Expansion
241 @cindex history expansion
242
243 The History library provides a history expansion feature that is similar
244 to the history expansion provided by @code{csh}. This section
245 describes the syntax used to manipulate the history information.
246
247 History expansions introduce words from the history list into
248 the input stream, making it easy to repeat commands, insert the
249 arguments to a previous command into the current input line, or
250 fix errors in previous commands quickly.
251
252 @ifset BashFeatures
253 History expansion is performed immediately after a complete line
254 is read, before the shell breaks it into words.
255 @end ifset
256
257 History expansion takes place in two parts. The first is to determine
258 which line from the history list should be used during substitution.
259 The second is to select portions of that line for inclusion into the
260 current one. The line selected from the history is called the
261 @dfn{event}, and the portions of that line that are acted upon are
262 called @dfn{words}. Various @dfn{modifiers} are available to manipulate
263 the selected words. The line is broken into words in the same fashion
264 that Bash does, so that several words
265 surrounded by quotes are considered one word.
266 History expansions are introduced by the appearance of the
267 history expansion character, which is @samp{!} by default.
268 @ifset BashFeatures
269 Only @samp{\} and @samp{'} may be used to escape the history expansion
270 character, but the history expansion character is
271 also treated as quoted if it immediately precedes the closing double quote
272 in a double-quoted string.
273 @end ifset
274
275 @ifset BashFeatures
276 Several shell options settable with the @code{shopt}
277 builtin (@pxref{Bash Builtins}) may be used to tailor
278 the behavior of history expansion. If the
279 @code{histverify} shell option is enabled, and Readline
280 is being used, history substitutions are not immediately passed to
281 the shell parser.
282 Instead, the expanded line is reloaded into the Readline
283 editing buffer for further modification.
284 If Readline is being used, and the @code{histreedit}
285 shell option is enabled, a failed history expansion will be
286 reloaded into the Readline editing buffer for correction.
287 The @option{-p} option to the @code{history} builtin command
288 may be used to see what a history expansion will do before using it.
289 The @option{-s} option to the @code{history} builtin may be used to
290 add commands to the end of the history list without actually executing
291 them, so that they are available for subsequent recall.
292 This is most useful in conjunction with Readline.
293
294 The shell allows control of the various characters used by the
295 history expansion mechanism with the @code{histchars} variable,
296 as explained above (@pxref{Bash Variables}). The shell uses
297 the history comment character to mark history timestamps when
298 writing the history file.
299 @end ifset
300
301 @menu
302 * Event Designators:: How to specify which history line to use.
303 * Word Designators:: Specifying which words are of interest.
304 * Modifiers:: Modifying the results of substitution.
305 @end menu
306
307 @node Event Designators
308 @subsection Event Designators
309 @cindex event designators
310
311 An event designator is a reference to a command line entry in the
312 history list.
313 Unless the reference is absolute, events are relative to the current
314 position in the history list.
315 @cindex history events
316
317 @table @asis
318
319 @item @code{!}
320 @ifset BashFeatures
321 Start a history substitution, except when followed by a space, tab,
322 the end of the line, @samp{=} or @samp{(} (when the
323 @code{extglob} shell option is enabled using the @code{shopt} builtin).
324 @end ifset
325 @ifclear BashFeatures
326 Start a history substitution, except when followed by a space, tab,
327 the end of the line, or @samp{=}.
328 @end ifclear
329
330 @item @code{!@var{n}}
331 Refer to command line @var{n}.
332
333 @item @code{!-@var{n}}
334 Refer to the command @var{n} lines back.
335
336 @item @code{!!}
337 Refer to the previous command. This is a synonym for @samp{!-1}.
338
339 @item @code{!@var{string}}
340 Refer to the most recent command
341 preceding the current position in the history list
342 starting with @var{string}.
343
344 @item @code{!?@var{string}[?]}
345 Refer to the most recent command
346 preceding the current position in the history list
347 containing @var{string}.
348 The trailing
349 @samp{?} may be omitted if the @var{string} is followed immediately by
350 a newline.
351
352 @item @code{^@var{string1}^@var{string2}^}
353 Quick Substitution. Repeat the last command, replacing @var{string1}
354 with @var{string2}. Equivalent to
355 @code{!!:s/@var{string1}/@var{string2}/}.
356
357 @item @code{!#}
358 The entire command line typed so far.
359
360 @end table
361
362 @node Word Designators
363 @subsection Word Designators
364
365 Word designators are used to select desired words from the event.
366 A @samp{:} separates the event specification from the word designator. It
367 may be omitted if the word designator begins with a @samp{^}, @samp{$},
368 @samp{*}, @samp{-}, or @samp{%}. Words are numbered from the beginning
369 of the line, with the first word being denoted by 0 (zero). Words are
370 inserted into the current line separated by single spaces.
371
372 @need 0.75
373 For example,
374
375 @table @code
376 @item !!
377 designates the preceding command. When you type this, the preceding
378 command is repeated in toto.
379
380 @item !!:$
381 designates the last argument of the preceding command. This may be
382 shortened to @code{!$}.
383
384 @item !fi:2
385 designates the second argument of the most recent command starting with
386 the letters @code{fi}.
387 @end table
388
389 @need 0.75
390 Here are the word designators:
391
392 @table @code
393
394 @item 0 (zero)
395 The @code{0}th word. For many applications, this is the command word.
396
397 @item @var{n}
398 The @var{n}th word.
399
400 @item ^
401 The first argument; that is, word 1.
402
403 @item $
404 The last argument.
405
406 @item %
407 The word matched by the most recent @samp{?@var{string}?} search.
408
409 @item @var{x}-@var{y}
410 A range of words; @samp{-@var{y}} abbreviates @samp{0-@var{y}}.
411
412 @item *
413 All of the words, except the @code{0}th. This is a synonym for @samp{1-$}.
414 It is not an error to use @samp{*} if there is just one word in the event;
415 the empty string is returned in that case.
416
417 @item @var{x}*
418 Abbreviates @samp{@var{x}-$}
419
420 @item @var{x}-
421 Abbreviates @samp{@var{x}-$} like @samp{@var{x}*}, but omits the last word.
422
423 @end table
424
425 If a word designator is supplied without an event specification, the
426 previous command is used as the event.
427
428 @node Modifiers
429 @subsection Modifiers
430
431 After the optional word designator, you can add a sequence of one or more
432 of the following modifiers, each preceded by a @samp{:}.
433
434 @table @code
435
436 @item h
437 Remove a trailing pathname component, leaving only the head.
438
439 @item t
440 Remove all leading pathname components, leaving the tail.
441
442 @item r
443 Remove a trailing suffix of the form @samp{.@var{suffix}}, leaving
444 the basename.
445
446 @item e
447 Remove all but the trailing suffix.
448
449 @item p
450 Print the new command but do not execute it.
451
452 @ifset BashFeatures
453 @item q
454 Quote the substituted words, escaping further substitutions.
455
456 @item x
457 Quote the substituted words as with @samp{q},
458 but break into words at spaces, tabs, and newlines.
459 @end ifset
460
461 @item s/@var{old}/@var{new}/
462 Substitute @var{new} for the first occurrence of @var{old} in the
463 event line. Any delimiter may be used in place of @samp{/}.
464 The delimiter may be quoted in @var{old} and @var{new}
465 with a single backslash. If @samp{&} appears in @var{new},
466 it is replaced by @var{old}. A single backslash will quote
467 the @samp{&}. The final delimiter is optional if it is the last
468 character on the input line.
469
470 @item &
471 Repeat the previous substitution.
472
473 @item g
474 @itemx a
475 Cause changes to be applied over the entire event line. Used in
476 conjunction with @samp{s}, as in @code{gs/@var{old}/@var{new}/},
477 or with @samp{&}.
478
479 @item G
480 Apply the following @samp{s} modifier once to each word in the event.
481
482 @end table