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