annotate lispref/minibuf.texi @ 68498:528aecb860cf

Revision: emacs@sv.gnu.org/emacs--devo--0--patch-30 Creator: Michael Olson <mwolson@gnu.org> Merge from erc--main--0 2006-01-30 Michael Olson <mwolson@gnu.org> * erc-stamp.el (erc-timestamp-right-align-by-pixel): New option that determines whether to use pixel values to align right timestamps. The default is not to do so, since it only works with Emacs22 on X, and even then some people have trouble. (erc-insert-aligned): Use `erc-timestamp-right-align-by-pixel'.
author Miles Bader <miles@gnu.org>
date Tue, 31 Jan 2006 00:24:36 +0000
parents d9ec339158fe
children 488f65041f04 7beb78bc1f8e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1 @c -*-texinfo-*-
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2 @c This is part of the GNU Emacs Lisp Reference Manual.
64889
e836425ee789 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64859
diff changeset
3 @c Copyright (C) 1990, 1991, 1992, 1993, 1994, 1995, 1998, 1999, 2001, 2002,
e836425ee789 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64859
diff changeset
4 @c 2003, 2004, 2005 Free Software Foundation, Inc.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
5 @c See the file elisp.texi for copying conditions.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
6 @setfilename ../info/minibuf
7337
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
7 @node Minibuffers, Command Loop, Read and Print, Top
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
8 @chapter Minibuffers
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
9 @cindex arguments, reading
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
10 @cindex complex arguments
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
11 @cindex minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
12
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
13 A @dfn{minibuffer} is a special buffer that Emacs commands use to
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
14 read arguments more complicated than the single numeric prefix
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
15 argument. These arguments include file names, buffer names, and
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
16 command names (as in @kbd{M-x}). The minibuffer is displayed on the
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
17 bottom line of the frame, in the same place as the echo area
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
18 (@pxref{The Echo Area}), but only while it is in use for reading an
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
19 argument.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
20
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
21 @menu
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
22 * Intro to Minibuffers:: Basic information about minibuffers.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
23 * Text from Minibuffer:: How to read a straight text string.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
24 * Object from Minibuffer:: How to read a Lisp object or expression.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
25 * Minibuffer History:: Recording previous minibuffer inputs
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
26 so the user can reuse them.
55925
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
27 * Initial Input:: Specifying initial contents for the minibuffer.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
28 * Completion:: How to invoke and customize completion.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
29 * Yes-or-No Queries:: Asking a question with a simple answer.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
30 * Multiple Queries:: Asking a series of similar questions.
23147
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
31 * Reading a Password:: Reading a password from the terminal.
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
32 * Minibuffer Commands:: Commands used as key bindings in minibuffers.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
33 * Minibuffer Contents:: How such commands access the minibuffer text.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
34 * Minibuffer Windows:: Operating on the special minibuffer windows.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
35 * Recursive Mini:: Whether recursive entry to minibuffer is allowed.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
36 * Minibuffer Misc:: Various customization hooks and variables.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
37 @end menu
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
38
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
39 @node Intro to Minibuffers
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
40 @section Introduction to Minibuffers
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
41
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
42 In most ways, a minibuffer is a normal Emacs buffer. Most operations
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
43 @emph{within} a buffer, such as editing commands, work normally in a
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
44 minibuffer. However, many operations for managing buffers do not apply
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
45 to minibuffers. The name of a minibuffer always has the form @w{@samp{
46915
5bae22b90bf5 Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 44275
diff changeset
46 *Minibuf-@var{number}*}}, and it cannot be changed. Minibuffers are
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
47 displayed only in special windows used only for minibuffers; these
22252
40089afa2b1d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 22138
diff changeset
48 windows always appear at the bottom of a frame. (Sometimes frames have
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
49 no minibuffer window, and sometimes a special kind of frame contains
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
50 nothing but a minibuffer window; see @ref{Minibuffers and Frames}.)
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
51
25751
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
52 The text in the minibuffer always starts with the @dfn{prompt string},
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
53 the text that was specified by the program that is using the minibuffer
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
54 to tell the user what sort of input to type. This text is marked
26696
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
55 read-only so you won't accidentally delete or change it. It is also
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
56 marked as a field (@pxref{Fields}), so that certain motion functions,
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
57 including @code{beginning-of-line}, @code{forward-word},
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
58 @code{forward-sentence}, and @code{forward-paragraph}, stop at the
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
59 boundary between the prompt and the actual text. (In older Emacs
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
60 versions, the prompt was displayed using a special mechanism and was not
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
61 part of the buffer contents.)
25751
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
62
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
63 The minibuffer's window is normally a single line; it grows
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
64 automatically if necessary if the contents require more space. You can
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
65 explicitly resize it temporarily with the window sizing commands; it
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
66 reverts to its normal size when the minibuffer is exited. You can
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
67 resize it permanently by using the window sizing commands in the frame's
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
68 other window, when the minibuffer is not active. If the frame contains
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
69 just a minibuffer, you can change the minibuffer's size by changing the
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
70 frame's size.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
71
52485
7fc901c75a7d (Intro to Minibuffers): Explain that the minibuffer
Richard M. Stallman <rms@gnu.org>
parents: 52401
diff changeset
72 Use of the minibuffer reads input events, and that alters the values
7fc901c75a7d (Intro to Minibuffers): Explain that the minibuffer
Richard M. Stallman <rms@gnu.org>
parents: 52401
diff changeset
73 of variables such as @code{this-command} and @code{last-command}
7fc901c75a7d (Intro to Minibuffers): Explain that the minibuffer
Richard M. Stallman <rms@gnu.org>
parents: 52401
diff changeset
74 (@pxref{Command Loop Info}). Your program should bind them around the
7fc901c75a7d (Intro to Minibuffers): Explain that the minibuffer
Richard M. Stallman <rms@gnu.org>
parents: 52401
diff changeset
75 code that uses the minibuffer, if you do not want that to change them.
7fc901c75a7d (Intro to Minibuffers): Explain that the minibuffer
Richard M. Stallman <rms@gnu.org>
parents: 52401
diff changeset
76
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
77 If a command uses a minibuffer while there is an active minibuffer,
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
78 this is called a @dfn{recursive minibuffer}. The first minibuffer is
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
79 named @w{@samp{ *Minibuf-0*}}. Recursive minibuffers are named by
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
80 incrementing the number at the end of the name. (The names begin with a
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
81 space so that they won't show up in normal buffer lists.) Of several
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
82 recursive minibuffers, the innermost (or most recently entered) is the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
83 active minibuffer. We usually call this ``the'' minibuffer. You can
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
84 permit or forbid recursive minibuffers by setting the variable
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
85 @code{enable-recursive-minibuffers} or by putting properties of that
64859
4e8cce76fcf3 (Intro to Minibuffers): Update pxref for previous change in minibuf.texi.
Luc Teirlinck <teirllm@auburn.edu>
parents: 64843
diff changeset
86 name on command symbols (@pxref{Recursive Mini}).
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
87
67414
ba853fd4880c (Intro to Minibuffers): Fix typo.
Luc Teirlinck <teirllm@auburn.edu>
parents: 67396
diff changeset
88 Like other buffers, a minibuffer uses a local keymap
67396
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
89 (@pxref{Keymaps}) to specify special key bindings. The function that
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
90 invokes the minibuffer also sets up its local map according to the job
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
91 to be done. @xref{Text from Minibuffer}, for the non-completion
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
92 minibuffer local maps. @xref{Completion Commands}, for the minibuffer
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
93 local maps for completion.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
94
26696
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
95 When Emacs is running in batch mode, any request to read from the
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
96 minibuffer actually reads a line from the standard input descriptor that
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
97 was supplied when Emacs was started.
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
98
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
99 @node Text from Minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
100 @section Reading Text Strings with the Minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
101
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
102 Most often, the minibuffer is used to read text as a string. It can
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
103 also be used to read a Lisp object in textual form. The most basic
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
104 primitive for minibuffer input is @code{read-from-minibuffer}; it can do
60042
114da1fc3775 (Text from Minibuffer): Minor clarification.
Richard M. Stallman <rms@gnu.org>
parents: 58360
diff changeset
105 either one. There are also specialized commands for reading
114da1fc3775 (Text from Minibuffer): Minor clarification.
Richard M. Stallman <rms@gnu.org>
parents: 58360
diff changeset
106 commands, variables, file names, etc. (@pxref{Completion}).
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
107
12098
a6eb5f12b0f3 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 12067
diff changeset
108 In most cases, you should not call minibuffer input functions in the
a6eb5f12b0f3 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 12067
diff changeset
109 middle of a Lisp function. Instead, do all minibuffer input as part of
22138
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
110 reading the arguments for a command, in the @code{interactive}
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
111 specification. @xref{Defining Commands}.
12098
a6eb5f12b0f3 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 12067
diff changeset
112
58360
0e8e74522f85 (Text from Minibuffer): Document KEEP-ALL arg in read-from-minibuffer.
Richard M. Stallman <rms@gnu.org>
parents: 58280
diff changeset
113 @defun read-from-minibuffer prompt-string &optional initial-contents keymap read hist default inherit-input-method keep-all
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
114 This function is the most general way to get input through the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
115 minibuffer. By default, it accepts arbitrary text and returns it as a
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
116 string; however, if @var{read} is non-@code{nil}, then it uses
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
117 @code{read} to convert the text into a Lisp object (@pxref{Input
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
118 Functions}).
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
119
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
120 The first thing this function does is to activate a minibuffer and
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
121 display it with @var{prompt-string} as the prompt. This value must be a
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
122 string. Then the user can edit text in the minibuffer.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
123
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
124 When the user types a command to exit the minibuffer,
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
125 @code{read-from-minibuffer} constructs the return value from the text in
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
126 the minibuffer. Normally it returns a string containing that text.
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
127 However, if @var{read} is non-@code{nil}, @code{read-from-minibuffer}
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
128 reads the text and returns the resulting Lisp object, unevaluated.
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
129 (@xref{Input Functions}, for information about reading.)
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
130
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
131 The argument @var{default} specifies a default value to make available
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
132 through the history commands. It should be a string, or @code{nil}.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
133 If non-@code{nil}, the user can access it using
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
134 @code{next-history-element}, usually bound in the minibuffer to
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
135 @kbd{M-n}. If @var{read} is non-@code{nil}, then @var{default} is
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
136 also used as the input to @code{read}, if the user enters empty input.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
137 (If @var{read} is non-@code{nil} and @var{default} is @code{nil}, empty
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
138 input results in an @code{end-of-file} error.) However, in the usual
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
139 case (where @var{read} is @code{nil}), @code{read-from-minibuffer}
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
140 ignores @var{default} when the user enters empty input and returns an
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
141 empty string, @code{""}. In this respect, it is different from all
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
142 the other minibuffer input functions in this chapter.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
143
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
144 If @var{keymap} is non-@code{nil}, that keymap is the local keymap to
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
145 use in the minibuffer. If @var{keymap} is omitted or @code{nil}, the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
146 value of @code{minibuffer-local-map} is used as the keymap. Specifying
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
147 a keymap is the most important way to customize the minibuffer for
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
148 various applications such as completion.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
149
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
150 The argument @var{hist} specifies which history list variable to use
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
151 for saving the input and for history commands used in the minibuffer.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
152 It defaults to @code{minibuffer-history}. @xref{Minibuffer History}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
153
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
154 If the variable @code{minibuffer-allow-text-properties} is
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
155 non-@code{nil}, then the string which is returned includes whatever text
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
156 properties were present in the minibuffer. Otherwise all the text
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
157 properties are stripped when the value is returned.
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
158
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
159 If the argument @var{inherit-input-method} is non-@code{nil}, then the
22252
40089afa2b1d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 22138
diff changeset
160 minibuffer inherits the current input method (@pxref{Input Methods}) and
40089afa2b1d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 22138
diff changeset
161 the setting of @code{enable-multibyte-characters} (@pxref{Text
40089afa2b1d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 22138
diff changeset
162 Representations}) from whichever buffer was current before entering the
40089afa2b1d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 22138
diff changeset
163 minibuffer.
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
164
58360
0e8e74522f85 (Text from Minibuffer): Document KEEP-ALL arg in read-from-minibuffer.
Richard M. Stallman <rms@gnu.org>
parents: 58280
diff changeset
165 If @var{keep-all} is non-@code{nil}, even empty and duplicate inputs
0e8e74522f85 (Text from Minibuffer): Document KEEP-ALL arg in read-from-minibuffer.
Richard M. Stallman <rms@gnu.org>
parents: 58280
diff changeset
166 are added to the history list.
0e8e74522f85 (Text from Minibuffer): Document KEEP-ALL arg in read-from-minibuffer.
Richard M. Stallman <rms@gnu.org>
parents: 58280
diff changeset
167
55925
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
168 Use of @var{initial-contents} is mostly deprecated; we recommend using
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
169 a non-@code{nil} value only in conjunction with specifying a cons cell
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
170 for @var{hist}. @xref{Initial Input}.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
171 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
172
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
173 @defun read-string prompt &optional initial history default inherit-input-method
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
174 This function reads a string from the minibuffer and returns it. The
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
175 arguments @var{prompt}, @var{initial}, @var{history} and
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
176 @var{inherit-input-method} are used as in @code{read-from-minibuffer}.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
177 The keymap used is @code{minibuffer-local-map}.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
178
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
179 The optional argument @var{default} is used as in
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
180 @code{read-from-minibuffer}, except that, if non-@code{nil}, it also
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
181 specifies a default value to return if the user enters null input. As
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
182 in @code{read-from-minibuffer} it should be a string, or @code{nil},
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
183 which is equivalent to an empty string.
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
184
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
185 This function is a simplified interface to the
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
186 @code{read-from-minibuffer} function:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
187
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
188 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
189 @group
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
190 (read-string @var{prompt} @var{initial} @var{history} @var{default} @var{inherit})
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
191 @equiv{}
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
192 (let ((value
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
193 (read-from-minibuffer @var{prompt} @var{initial} nil nil
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
194 @var{history} @var{default} @var{inherit})))
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
195 (if (and (equal value "") @var{default})
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
196 @var{default}
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
197 value))
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
198 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
199 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
200 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
201
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
202 @defvar minibuffer-allow-text-properties
22252
40089afa2b1d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 22138
diff changeset
203 If this variable is @code{nil}, then @code{read-from-minibuffer} strips
40089afa2b1d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 22138
diff changeset
204 all text properties from the minibuffer input before returning it.
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
205 This variable also affects @code{read-string}. However,
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
206 @code{read-no-blanks-input} (see below), as well as
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
207 @code{read-minibuffer} and related functions (@pxref{Object from
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
208 Minibuffer,, Reading Lisp Objects With the Minibuffer}), and all
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
209 functions that do minibuffer input with completion, discard text
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
210 properties unconditionally, regardless of the value of this variable.
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
211 @end defvar
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
212
56214
169058aadeda Change position of @anchor's. Add anchor.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55925
diff changeset
213 @defvar minibuffer-local-map
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
214 @anchor{Definition of minibuffer-local-map}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
215 This is the default local keymap for reading from the minibuffer. By
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
216 default, it makes the following bindings:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
217
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
218 @table @asis
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
219 @item @kbd{C-j}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
220 @code{exit-minibuffer}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
221
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
222 @item @key{RET}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
223 @code{exit-minibuffer}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
224
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
225 @item @kbd{C-g}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
226 @code{abort-recursive-edit}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
227
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
228 @item @kbd{M-n}
60042
114da1fc3775 (Text from Minibuffer): Minor clarification.
Richard M. Stallman <rms@gnu.org>
parents: 58360
diff changeset
229 @itemx @key{DOWN}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
230 @code{next-history-element}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
231
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
232 @item @kbd{M-p}
60042
114da1fc3775 (Text from Minibuffer): Minor clarification.
Richard M. Stallman <rms@gnu.org>
parents: 58360
diff changeset
233 @itemx @key{UP}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
234 @code{previous-history-element}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
235
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
236 @item @kbd{M-s}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
237 @code{next-matching-history-element}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
238
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
239 @item @kbd{M-r}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
240 @code{previous-matching-history-element}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
241 @end table
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
242 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
243
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
244 @c In version 18, initial is required
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
245 @c Emacs 19 feature
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
246 @defun read-no-blanks-input prompt &optional initial inherit-input-method
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
247 This function reads a string from the minibuffer, but does not allow
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
248 whitespace characters as part of the input: instead, those characters
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
249 terminate the input. The arguments @var{prompt}, @var{initial}, and
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
250 @var{inherit-input-method} are used as in @code{read-from-minibuffer}.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
251
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
252 This is a simplified interface to the @code{read-from-minibuffer}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
253 function, and passes the value of the @code{minibuffer-local-ns-map}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
254 keymap as the @var{keymap} argument for that function. Since the keymap
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
255 @code{minibuffer-local-ns-map} does not rebind @kbd{C-q}, it @emph{is}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
256 possible to put a space into the string, by quoting it.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
257
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
258 This function discards text properties, regardless of the value of
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
259 @code{minibuffer-allow-text-properties}.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
260
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
261 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
262 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
263 (read-no-blanks-input @var{prompt} @var{initial})
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
264 @equiv{}
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
265 (let (minibuffer-allow-text-properties)
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
266 (read-from-minibuffer @var{prompt} @var{initial} minibuffer-local-ns-map))
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
267 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
268 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
269 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
270
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
271 @defvar minibuffer-local-ns-map
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
272 This built-in variable is the keymap used as the minibuffer local keymap
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
273 in the function @code{read-no-blanks-input}. By default, it makes the
12098
a6eb5f12b0f3 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 12067
diff changeset
274 following bindings, in addition to those of @code{minibuffer-local-map}:
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
275
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
276 @table @asis
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
277 @item @key{SPC}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
278 @cindex @key{SPC} in minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
279 @code{exit-minibuffer}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
280
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
281 @item @key{TAB}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
282 @cindex @key{TAB} in minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
283 @code{exit-minibuffer}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
284
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
285 @item @kbd{?}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
286 @cindex @kbd{?} in minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
287 @code{self-insert-and-exit}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
288 @end table
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
289 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
290
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
291 @node Object from Minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
292 @section Reading Lisp Objects with the Minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
293
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
294 This section describes functions for reading Lisp objects with the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
295 minibuffer.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
296
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
297 @defun read-minibuffer prompt &optional initial
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
298 This function reads a Lisp object using the minibuffer, and returns it
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
299 without evaluating it. The arguments @var{prompt} and @var{initial} are
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
300 used as in @code{read-from-minibuffer}.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
301
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
302 This is a simplified interface to the
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
303 @code{read-from-minibuffer} function:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
304
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
305 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
306 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
307 (read-minibuffer @var{prompt} @var{initial})
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
308 @equiv{}
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
309 (let (minibuffer-allow-text-properties)
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
310 (read-from-minibuffer @var{prompt} @var{initial} nil t))
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
311 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
312 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
313
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
314 Here is an example in which we supply the string @code{"(testing)"} as
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
315 initial input:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
316
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
317 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
318 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
319 (read-minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
320 "Enter an expression: " (format "%s" '(testing)))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
321
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
322 ;; @r{Here is how the minibuffer is displayed:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
323 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
324
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
325 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
326 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
327 Enter an expression: (testing)@point{}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
328 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
329 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
330 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
331
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
332 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
333 The user can type @key{RET} immediately to use the initial input as a
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
334 default, or can edit the input.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
335 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
336
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
337 @defun eval-minibuffer prompt &optional initial
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
338 This function reads a Lisp expression using the minibuffer, evaluates
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
339 it, then returns the result. The arguments @var{prompt} and
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
340 @var{initial} are used as in @code{read-from-minibuffer}.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
341
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
342 This function simply evaluates the result of a call to
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
343 @code{read-minibuffer}:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
344
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
345 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
346 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
347 (eval-minibuffer @var{prompt} @var{initial})
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
348 @equiv{}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
349 (eval (read-minibuffer @var{prompt} @var{initial}))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
350 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
351 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
352 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
353
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
354 @defun edit-and-eval-command prompt form
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
355 This function reads a Lisp expression in the minibuffer, and then
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
356 evaluates it. The difference between this command and
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
357 @code{eval-minibuffer} is that here the initial @var{form} is not
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
358 optional and it is treated as a Lisp object to be converted to printed
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
359 representation rather than as a string of text. It is printed with
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
360 @code{prin1}, so if it is a string, double-quote characters (@samp{"})
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
361 appear in the initial text. @xref{Output Functions}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
362
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
363 The first thing @code{edit-and-eval-command} does is to activate the
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
364 minibuffer with @var{prompt} as the prompt. Then it inserts the printed
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
365 representation of @var{form} in the minibuffer, and lets the user edit it.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
366 When the user exits the minibuffer, the edited text is read with
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
367 @code{read} and then evaluated. The resulting value becomes the value
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
368 of @code{edit-and-eval-command}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
369
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
370 In the following example, we offer the user an expression with initial
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
371 text which is a valid form already:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
372
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
373 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
374 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
375 (edit-and-eval-command "Please edit: " '(forward-word 1))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
376
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
377 ;; @r{After evaluation of the preceding expression,}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
378 ;; @r{the following appears in the minibuffer:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
379 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
380
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
381 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
382 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
383 Please edit: (forward-word 1)@point{}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
384 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
385 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
386 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
387
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
388 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
389 Typing @key{RET} right away would exit the minibuffer and evaluate the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
390 expression, thus moving point forward one word.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
391 @code{edit-and-eval-command} returns @code{nil} in this example.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
392 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
393
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
394 @node Minibuffer History
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
395 @section Minibuffer History
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
396 @cindex minibuffer history
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
397 @cindex history list
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
398
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
399 A @dfn{minibuffer history list} records previous minibuffer inputs so
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
400 the user can reuse them conveniently. A history list is actually a
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
401 symbol, not a list; it is a variable whose value is a list of strings
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
402 (previous inputs), most recent first.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
403
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
404 There are many separate history lists, used for different kinds of
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
405 inputs. It's the Lisp programmer's job to specify the right history
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
406 list for each use of the minibuffer.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
407
63582
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
408 You specify the history list with the optional @var{hist} argument
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
409 to either @code{read-from-minibuffer} or @code{completing-read}. Here
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
410 are the possible values for it:
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
411
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
412 @table @asis
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
413 @item @var{variable}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
414 Use @var{variable} (a symbol) as the history list.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
415
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
416 @item (@var{variable} . @var{startpos})
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
417 Use @var{variable} (a symbol) as the history list, and assume that the
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
418 initial history position is @var{startpos} (a nonnegative integer).
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
419
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
420 Specifying 0 for @var{startpos} is equivalent to just specifying the
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
421 symbol @var{variable}. @code{previous-history-element} will display
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
422 the most recent element of the history list in the minibuffer. If you
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
423 specify a positive @var{startpos}, the minibuffer history functions
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
424 behave as if @code{(elt @var{variable} (1- @var{STARTPOS}))} were the
55925
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
425 history element currently shown in the minibuffer.
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
426
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
427 For consistency, you should also specify that element of the history
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
428 as the initial minibuffer contents, using the @var{initial} argument
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
429 to the minibuffer input function (@pxref{Initial Input}).
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
430 @end table
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
431
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
432 If you don't specify @var{hist}, then the default history list
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
433 @code{minibuffer-history} is used. For other standard history lists,
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
434 see below. You can also create your own history list variable; just
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
435 initialize it to @code{nil} before the first use.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
436
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
437 Both @code{read-from-minibuffer} and @code{completing-read} add new
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
438 elements to the history list automatically, and provide commands to
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
439 allow the user to reuse items on the list. The only thing your program
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
440 needs to do to use a history list is to initialize it and to pass its
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
441 name to the input functions when you wish. But it is safe to modify the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
442 list by hand when the minibuffer input functions are not using it.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
443
48730
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
444 Emacs functions that add a new element to a history list can also
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
445 delete old elements if the list gets too long. The variable
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
446 @code{history-length} specifies the maximum length for most history
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
447 lists. To specify a different maximum length for a particular history
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
448 list, put the length in the @code{history-length} property of the
57017
9f99ae07c452 (Minibuffer History): Add `history-delete-duplicates'.
Juri Linkov <juri@jurta.org>
parents: 56606
diff changeset
449 history list symbol. The variable @code{history-delete-duplicates}
9f99ae07c452 (Minibuffer History): Add `history-delete-duplicates'.
Juri Linkov <juri@jurta.org>
parents: 56606
diff changeset
450 specifies whether to delete duplicates in history.
48730
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
451
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
452 @defvar history-length
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
453 The value of this variable specifies the maximum length for all
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
454 history lists that don't specify their own maximum lengths. If the
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
455 value is @code{t}, that means there no maximum (don't delete old
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
456 elements).
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
457 @end defvar
e7f0249cfca8 Document history-length.
Richard M. Stallman <rms@gnu.org>
parents: 46915
diff changeset
458
57017
9f99ae07c452 (Minibuffer History): Add `history-delete-duplicates'.
Juri Linkov <juri@jurta.org>
parents: 56606
diff changeset
459 @defvar history-delete-duplicates
9f99ae07c452 (Minibuffer History): Add `history-delete-duplicates'.
Juri Linkov <juri@jurta.org>
parents: 56606
diff changeset
460 If the value of this variable is @code{t}, that means when adding a
9f99ae07c452 (Minibuffer History): Add `history-delete-duplicates'.
Juri Linkov <juri@jurta.org>
parents: 56606
diff changeset
461 new history element, all previous identical elements are deleted.
9f99ae07c452 (Minibuffer History): Add `history-delete-duplicates'.
Juri Linkov <juri@jurta.org>
parents: 56606
diff changeset
462 @end defvar
9f99ae07c452 (Minibuffer History): Add `history-delete-duplicates'.
Juri Linkov <juri@jurta.org>
parents: 56606
diff changeset
463
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
464 Here are some of the standard minibuffer history list variables:
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
465
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
466 @defvar minibuffer-history
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
467 The default history list for minibuffer history input.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
468 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
469
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
470 @defvar query-replace-history
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
471 A history list for arguments to @code{query-replace} (and similar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
472 arguments to other commands).
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
473 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
474
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
475 @defvar file-name-history
22138
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
476 A history list for file-name arguments.
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
477 @end defvar
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
478
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
479 @defvar buffer-name-history
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
480 A history list for buffer-name arguments.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
481 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
482
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
483 @defvar regexp-history
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
484 A history list for regular expression arguments.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
485 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
486
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
487 @defvar extended-command-history
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
488 A history list for arguments that are names of extended commands.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
489 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
490
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
491 @defvar shell-command-history
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
492 A history list for arguments that are shell commands.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
493 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
494
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
495 @defvar read-expression-history
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
496 A history list for arguments that are Lisp expressions to evaluate.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
497 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
498
55925
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
499 @node Initial Input
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
500 @section Initial Input
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
501
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
502 Several of the functions for minibuffer input have an argument called
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
503 @var{initial} or @var{initial-contents}. This is a mostly-deprecated
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
504 feature for specifiying that the minibuffer should start out with
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
505 certain text, instead of empty as usual.
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
506
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
507 If @var{initial} is a string, the minibuffer starts out containing the
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
508 text of the string, with point at the end, when the user starts to
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
509 edit the text. If the user simply types @key{RET} to exit the
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
510 minibuffer, it will use the initial input string to determine the
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
511 value to return.
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
512
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
513 @strong{We discourage use of a non-@code{nil} value for
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
514 @var{initial}}, because initial input is an intrusive interface.
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
515 History lists and default values provide a much more convenient method
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
516 to offer useful default inputs to the user.
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
517
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
518 There is just one situation where you should specify a string for an
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
519 @var{initial} argument. This is when you specify a cons cell for the
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
520 @var{hist} or @var{history} argument. @xref{Minibuffer History}.
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
521
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
522 @var{initial} can also be a cons cell of the form @code{(@var{string}
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
523 . @var{position})}. This means to insert @var{string} in the
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
524 minibuffer but put point at @var{position} within the string's text.
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
525
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
526 As a historical accident, @var{position} was implemented
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
527 inconsistently in different functions. In @code{completing-read},
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
528 @var{position}'s value is interpreted as origin-zero; that is, a value
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
529 of 0 means the beginning of the string, 1 means after the first
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
530 character, etc. In @code{read-minibuffer}, and the other
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
531 non-completion minibuffer input functions that support this argument,
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
532 1 means the beginning of the string 2 means after the first character,
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
533 etc.
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
534
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
535 Use of a cons cell as the value for @var{initial} arguments is
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
536 deprecated in user code.
56214
169058aadeda Change position of @anchor's. Add anchor.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55925
diff changeset
537
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
538 @node Completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
539 @section Completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
540 @cindex completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
541
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
542 @dfn{Completion} is a feature that fills in the rest of a name
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
543 starting from an abbreviation for it. Completion works by comparing the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
544 user's input against a list of valid names and determining how much of
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
545 the name is determined uniquely by what the user has typed. For
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
546 example, when you type @kbd{C-x b} (@code{switch-to-buffer}) and then
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
547 type the first few letters of the name of the buffer to which you wish
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
548 to switch, and then type @key{TAB} (@code{minibuffer-complete}), Emacs
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
549 extends the name as far as it can.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
550
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
551 Standard Emacs commands offer completion for names of symbols, files,
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
552 buffers, and processes; with the functions in this section, you can
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
553 implement completion for other kinds of names.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
554
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
555 The @code{try-completion} function is the basic primitive for
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
556 completion: it returns the longest determined completion of a given
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
557 initial string, with a given set of strings to match against.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
558
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
559 The function @code{completing-read} provides a higher-level interface
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
560 for completion. A call to @code{completing-read} specifies how to
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
561 determine the list of valid names. The function then activates the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
562 minibuffer with a local keymap that binds a few keys to commands useful
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
563 for completion. Other functions provide convenient simple interfaces
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
564 for reading certain kinds of names with completion.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
565
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
566 @menu
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
567 * Basic Completion:: Low-level functions for completing strings.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
568 (These are too low level to use the minibuffer.)
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
569 * Minibuffer Completion:: Invoking the minibuffer with completion.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
570 * Completion Commands:: Minibuffer commands that do completion.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
571 * High-Level Completion:: Convenient special cases of completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
572 (reading buffer name, file name, etc.)
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
573 * Reading File Names:: Using completion to read file names.
51914
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
574 * Programmed Completion:: Writing your own completion-function.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
575 @end menu
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
576
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
577 @node Basic Completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
578 @subsection Basic Completion Functions
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
579
63582
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
580 The completion functions @code{try-completion},
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
581 @code{all-completions} and @code{test-completion} have nothing in
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
582 themselves to do with minibuffers. We describe them in this chapter
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
583 so as to keep them near the higher-level completion features that do
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
584 use the minibuffer.
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
585
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
586 @defun try-completion string collection &optional predicate
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
587 This function returns the longest common substring of all possible
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
588 completions of @var{string} in @var{collection}. The value of
60211
31cb6f65b5d5 (Basic Completion): Allow symbols in addition to
Kim F. Storm <storm@cua.dk>
parents: 60042
diff changeset
589 @var{collection} must be a list of strings or symbols, an alist, an
31cb6f65b5d5 (Basic Completion): Allow symbols in addition to
Kim F. Storm <storm@cua.dk>
parents: 60042
diff changeset
590 obarray, a hash table, or a function that implements a virtual set of
31cb6f65b5d5 (Basic Completion): Allow symbols in addition to
Kim F. Storm <storm@cua.dk>
parents: 60042
diff changeset
591 strings (see below).
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
592
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
593 Completion compares @var{string} against each of the permissible
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
594 completions specified by @var{collection}; if the beginning of the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
595 permissible completion equals @var{string}, it matches. If no permissible
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
596 completions match, @code{try-completion} returns @code{nil}. If only
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
597 one permissible completion matches, and the match is exact, then
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
598 @code{try-completion} returns @code{t}. Otherwise, the value is the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
599 longest initial sequence common to all the permissible completions that
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
600 match.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
601
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
602 If @var{collection} is an alist (@pxref{Association Lists}), the
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
603 permissible completions are the elements of the alist that are either
60211
31cb6f65b5d5 (Basic Completion): Allow symbols in addition to
Kim F. Storm <storm@cua.dk>
parents: 60042
diff changeset
604 strings, symbols, or conses whose @sc{car} is a string or symbol.
31cb6f65b5d5 (Basic Completion): Allow symbols in addition to
Kim F. Storm <storm@cua.dk>
parents: 60042
diff changeset
605 Symbols are converted to strings using @code{symbol-name}.
31cb6f65b5d5 (Basic Completion): Allow symbols in addition to
Kim F. Storm <storm@cua.dk>
parents: 60042
diff changeset
606 Other elements of the alist are ignored. (Remember that in Emacs Lisp,
31cb6f65b5d5 (Basic Completion): Allow symbols in addition to
Kim F. Storm <storm@cua.dk>
parents: 60042
diff changeset
607 the elements of alists do not @emph{have} to be conses.) As all
31cb6f65b5d5 (Basic Completion): Allow symbols in addition to
Kim F. Storm <storm@cua.dk>
parents: 60042
diff changeset
608 elements of the alist can be strings, this case actually includes
31cb6f65b5d5 (Basic Completion): Allow symbols in addition to
Kim F. Storm <storm@cua.dk>
parents: 60042
diff changeset
609 lists of strings or symbols, even though we usually do not think of
31cb6f65b5d5 (Basic Completion): Allow symbols in addition to
Kim F. Storm <storm@cua.dk>
parents: 60042
diff changeset
610 such lists as alists.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
611
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
612 @cindex obarray in completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
613 If @var{collection} is an obarray (@pxref{Creating Symbols}), the names
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
614 of all symbols in the obarray form the set of permissible completions. The
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
615 global variable @code{obarray} holds an obarray containing the names of
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
616 all interned Lisp symbols.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
617
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
618 Note that the only valid way to make a new obarray is to create it
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
619 empty and then add symbols to it one by one using @code{intern}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
620 Also, you cannot intern a given symbol in more than one obarray.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
621
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
622 If @var{collection} is a hash table, then the keys that are strings
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
623 are the possible completions. Other keys are ignored.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
624
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
625 You can also use a symbol that is a function as @var{collection}. Then
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
626 the function is solely responsible for performing completion;
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
627 @code{try-completion} returns whatever this function returns. The
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
628 function is called with three arguments: @var{string}, @var{predicate}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
629 and @code{nil}. (The reason for the third argument is so that the same
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
630 function can be used in @code{all-completions} and do the appropriate
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
631 thing in either case.) @xref{Programmed Completion}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
632
51989
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
633 If the argument @var{predicate} is non-@code{nil}, then it must be a
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
634 function of one argument, unless @var{collection} is a hash table, in
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
635 which case it should be a function of two arguments. It is used to
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
636 test each possible match, and the match is accepted only if
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
637 @var{predicate} returns non-@code{nil}. The argument given to
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
638 @var{predicate} is either a string or a cons cell (the @sc{car} of
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
639 which is a string) from the alist, or a symbol (@emph{not} a symbol
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
640 name) from the obarray. If @var{collection} is a hash table,
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
641 @var{predicate} is called with two arguments, the string key and the
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
642 associated value.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
643
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
644 In addition, to be acceptable, a completion must also match all the
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
645 regular expressions in @code{completion-regexp-list}. (Unless
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
646 @var{collection} is a function, in which case that function has to
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
647 handle @code{completion-regexp-list} itself.)
51989
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
648
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
649 In the first of the following examples, the string @samp{foo} is
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
650 matched by three of the alist @sc{car}s. All of the matches begin with
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
651 the characters @samp{fooba}, so that is the result. In the second
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
652 example, there is only one possible match, and it is exact, so the value
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
653 is @code{t}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
654
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
655 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
656 @group
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
657 (try-completion
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
658 "foo"
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
659 '(("foobar1" 1) ("barfoo" 2) ("foobaz" 3) ("foobar2" 4)))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
660 @result{} "fooba"
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
661 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
662
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
663 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
664 (try-completion "foo" '(("barfoo" 2) ("foo" 3)))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
665 @result{} t
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
666 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
667 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
668
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
669 In the following example, numerous symbols begin with the characters
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
670 @samp{forw}, and all of them begin with the word @samp{forward}. In
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
671 most of the symbols, this is followed with a @samp{-}, but not in all,
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
672 so no more than @samp{forward} can be completed.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
673
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
674 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
675 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
676 (try-completion "forw" obarray)
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
677 @result{} "forward"
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
678 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
679 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
680
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
681 Finally, in the following example, only two of the three possible
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
682 matches pass the predicate @code{test} (the string @samp{foobaz} is
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
683 too short). Both of those begin with the string @samp{foobar}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
684
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
685 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
686 @group
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
687 (defun test (s)
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
688 (> (length (car s)) 6))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
689 @result{} test
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
690 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
691 @group
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
692 (try-completion
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
693 "foo"
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
694 '(("foobar1" 1) ("barfoo" 2) ("foobaz" 3) ("foobar2" 4))
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
695 'test)
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
696 @result{} "foobar"
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
697 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
698 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
699 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
700
12067
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
701 @defun all-completions string collection &optional predicate nospace
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
702 This function returns a list of all possible completions of
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
703 @var{string}. The arguments to this function (aside from
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
704 @var{nospace}) are the same as those of @code{try-completion}. Also,
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
705 this function uses @code{completion-regexp-list} in the same way that
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
706 @code{try-completion} does. The optional argument @var{nospace} only
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
707 matters if @var{string} is the empty string. In that case, if
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
708 @var{nospace} is non-@code{nil}, completions that start with a space
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
709 are ignored.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
710
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
711 If @var{collection} is a function, it is called with three arguments:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
712 @var{string}, @var{predicate} and @code{t}; then @code{all-completions}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
713 returns whatever the function returns. @xref{Programmed Completion}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
714
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
715 Here is an example, using the function @code{test} shown in the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
716 example for @code{try-completion}:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
717
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
718 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
719 @group
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
720 (defun test (s)
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
721 (> (length (car s)) 6))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
722 @result{} test
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
723 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
724
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
725 @group
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
726 (all-completions
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
727 "foo"
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
728 '(("foobar1" 1) ("barfoo" 2) ("foobaz" 3) ("foobar2" 4))
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
729 'test)
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
730 @result{} ("foobar1" "foobar2")
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
731 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
732 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
733 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
734
56214
169058aadeda Change position of @anchor's. Add anchor.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55925
diff changeset
735 @defun test-completion string collection &optional predicate
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
736 @anchor{Definition of test-completion}
51989
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
737 This function returns non-@code{nil} if @var{string} is a valid
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
738 completion possibility specified by @var{collection} and
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
739 @var{predicate}. The arguments are the same as in
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
740 @code{try-completion}. For instance, if @var{collection} is a list of
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
741 strings, this is true if @var{string} appears in the list and
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
742 @var{predicate} is satisfied.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
743
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
744 @code{test-completion} uses @code{completion-regexp-list} in the same
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
745 way that @code{try-completion} does.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
746
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
747 If @var{predicate} is non-@code{nil} and if @var{collection} contains
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
748 several strings that are equal to each other, as determined by
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
749 @code{compare-strings} according to @code{completion-ignore-case},
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
750 then @var{predicate} should accept either all or none of them.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
751 Otherwise, the return value of @code{test-completion} is essentially
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
752 unpredictable.
51989
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
753
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
754 If @var{collection} is a function, it is called with three arguments,
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
755 the values @var{string}, @var{predicate} and @code{lambda}; whatever
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
756 it returns, @code{test-completion} returns in turn.
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
757 @end defun
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
758
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
759 @defvar completion-ignore-case
51989
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
760 If the value of this variable is non-@code{nil}, Emacs does not
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
761 consider case significant in completion.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
762 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
763
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
764 @defvar completion-regexp-list
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
765 This is a list of regular expressions. The completion functions only
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
766 consider a completion acceptable if it matches all regular expressions
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
767 in this list, with @code{case-fold-search} (@pxref{Searching and Case})
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
768 bound to the value of @code{completion-ignore-case}.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
769 @end defvar
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
770
67818
5a83c9ee8aa6 (lazy-completion-table): Remove argument `args'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 67629
diff changeset
771 @defmac lazy-completion-table var fun
51914
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
772 This macro provides a way to initialize the variable @var{var} as a
51989
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
773 collection for completion in a lazy way, not computing its actual
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
774 contents until they are first needed. You use this macro to produce a
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
775 value that you store in @var{var}. The actual computation of the
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
776 proper value is done the first time you do completion using @var{var}.
67818
5a83c9ee8aa6 (lazy-completion-table): Remove argument `args'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 67629
diff changeset
777 It is done by calling @var{fun} with no arguments. The
51989
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
778 value @var{fun} returns becomes the permanent value of @var{var}.
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
779
67881
d9ec339158fe (Basic Completion): Update lazy-completion-table examples for removal
Luc Teirlinck <teirllm@auburn.edu>
parents: 67818
diff changeset
780 Here is an example of use:
51914
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
781
63582
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
782 @smallexample
67881
d9ec339158fe (Basic Completion): Update lazy-completion-table examples for removal
Luc Teirlinck <teirllm@auburn.edu>
parents: 67818
diff changeset
783 (defvar foo (lazy-completion-table foo make-my-alist))
63582
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
784 @end smallexample
51914
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
785 @end defmac
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
786
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
787 @node Minibuffer Completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
788 @subsection Completion and the Minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
789
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
790 This section describes the basic interface for reading from the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
791 minibuffer with completion.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
792
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
793 @defun completing-read prompt collection &optional predicate require-match initial hist default inherit-input-method
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
794 This function reads a string in the minibuffer, assisting the user by
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
795 providing completion. It activates the minibuffer with prompt
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
796 @var{prompt}, which must be a string.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
797
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
798 The actual completion is done by passing @var{collection} and
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
799 @var{predicate} to the function @code{try-completion}. This happens
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
800 in certain commands bound in the local keymaps used for completion.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
801 Some of these commands also call @code{test-completion}. Thus, if
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
802 @var{predicate} is non-@code{nil}, it should be compatible with
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
803 @var{collection} and @code{completion-ignore-case}. @xref{Definition
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
804 of test-completion}.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
805
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
806 If @var{require-match} is @code{nil}, the exit commands work regardless
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
807 of the input in the minibuffer. If @var{require-match} is @code{t}, the
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
808 usual minibuffer exit commands won't exit unless the input completes to
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
809 an element of @var{collection}. If @var{require-match} is neither
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
810 @code{nil} nor @code{t}, then the exit commands won't exit unless the
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
811 input already in the buffer matches an element of @var{collection}.
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
812
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
813 However, empty input is always permitted, regardless of the value of
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
814 @var{require-match}; in that case, @code{completing-read} returns
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
815 @var{default}, or @code{""}, if @var{default} is @code{nil}. The
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
816 value of @var{default} (if non-@code{nil}) is also available to the
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
817 user through the history commands.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
818
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
819 The function @code{completing-read} uses
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
820 @code{minibuffer-local-completion-map} as the keymap if
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
821 @var{require-match} is @code{nil}, and uses
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
822 @code{minibuffer-local-must-match-map} if @var{require-match} is
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
823 non-@code{nil}. @xref{Completion Commands}.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
824
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
825 The argument @var{hist} specifies which history list variable to use for
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
826 saving the input and for minibuffer history commands. It defaults to
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
827 @code{minibuffer-history}. @xref{Minibuffer History}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
828
55925
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
829 The argument @var{initial} is mostly deprecated; we recommend using a
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
830 non-@code{nil} value only in conjunction with specifying a cons cell
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
831 for @var{hist}. @xref{Initial Input}. For default input, use
b1e16cd7f843 (Minibuffer Completion): For INITIAL arg,
Richard M. Stallman <rms@gnu.org>
parents: 54327
diff changeset
832 @var{default} instead.
38158
a137fb27df08 Deprecate use of the INITIAL argument for completing-read.
Richard M. Stallman <rms@gnu.org>
parents: 27189
diff changeset
833
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
834 If the argument @var{inherit-input-method} is non-@code{nil}, then the
22252
40089afa2b1d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 22138
diff changeset
835 minibuffer inherits the current input method (@pxref{Input
22138
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
836 Methods}) and the setting of @code{enable-multibyte-characters}
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
837 (@pxref{Text Representations}) from whichever buffer was current before
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
838 entering the minibuffer.
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
839
58280
08330213d737 (Minibuffer Completion): When ignoring case,
Richard M. Stallman <rms@gnu.org>
parents: 57790
diff changeset
840 If the built-in variable @code{completion-ignore-case} is
08330213d737 (Minibuffer Completion): When ignoring case,
Richard M. Stallman <rms@gnu.org>
parents: 57790
diff changeset
841 non-@code{nil}, completion ignores case when comparing the input
08330213d737 (Minibuffer Completion): When ignoring case,
Richard M. Stallman <rms@gnu.org>
parents: 57790
diff changeset
842 against the possible matches. @xref{Basic Completion}. In this mode
08330213d737 (Minibuffer Completion): When ignoring case,
Richard M. Stallman <rms@gnu.org>
parents: 57790
diff changeset
843 of operation, @var{predicate} must also ignore case, or you will get
08330213d737 (Minibuffer Completion): When ignoring case,
Richard M. Stallman <rms@gnu.org>
parents: 57790
diff changeset
844 surprising results.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
845
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
846 Here's an example of using @code{completing-read}:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
847
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
848 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
849 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
850 (completing-read
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
851 "Complete a foo: "
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
852 '(("foobar1" 1) ("barfoo" 2) ("foobaz" 3) ("foobar2" 4))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
853 nil t "fo")
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
854 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
855
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
856 @group
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
857 ;; @r{After evaluation of the preceding expression,}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
858 ;; @r{the following appears in the minibuffer:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
859
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
860 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
861 Complete a foo: fo@point{}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
862 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
863 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
864 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
865
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
866 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
867 If the user then types @kbd{@key{DEL} @key{DEL} b @key{RET}},
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
868 @code{completing-read} returns @code{barfoo}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
869
63582
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
870 The @code{completing-read} function binds variables to pass
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
871 information to the commands that actually do completion.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
872 They are described in the following section.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
873 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
874
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
875 @node Completion Commands
25751
467b88fab665 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 23147
diff changeset
876 @subsection Minibuffer Commands that Do Completion
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
877
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
878 This section describes the keymaps, commands and user options used
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
879 in the minibuffer to do completion. The description refers to the
53930
5ef587160656 *** empty log message ***
Luc Teirlinck <teirllm@auburn.edu>
parents: 53801
diff changeset
880 situation when Partial Completion mode is disabled (as it is by
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
881 default). When enabled, this minor mode uses its own alternatives to
54327
1f35da88bdd8 (Completion Commands): Add xref to Emacs manual for Partial Completion mode.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53930
diff changeset
882 some of the commands described below. @xref{Completion Options,,,
1f35da88bdd8 (Completion Commands): Add xref to Emacs manual for Partial Completion mode.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53930
diff changeset
883 emacs, The GNU Emacs Manual}, for a short description of Partial
1f35da88bdd8 (Completion Commands): Add xref to Emacs manual for Partial Completion mode.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53930
diff changeset
884 Completion mode.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
885
63582
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
886 @defvar minibuffer-completion-table
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
887 The value of this variable is the collection used for completion in
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
888 the minibuffer. This is the global variable that contains what
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
889 @code{completing-read} passes to @code{try-completion}. It is used by
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
890 minibuffer completion commands such as @code{minibuffer-complete-word}.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
891 @end defvar
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
892
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
893 @defvar minibuffer-completion-predicate
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
894 This variable's value is the predicate that @code{completing-read}
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
895 passes to @code{try-completion}. The variable is also used by the other
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
896 minibuffer completion functions.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
897 @end defvar
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
898
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
899 @defvar minibuffer-completion-confirm
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
900 When the value of this variable is non-@code{nil}, Emacs asks for
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
901 confirmation of a completion before exiting the minibuffer.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
902 @code{completing-read} binds this variable, and the function
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
903 @code{minibuffer-complete-and-exit} checks the value before exiting.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
904 @end defvar
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
905
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
906 @deffn Command minibuffer-complete-word
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
907 This function completes the minibuffer contents by at most a single
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
908 word. Even if the minibuffer contents have only one completion,
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
909 @code{minibuffer-complete-word} does not add any characters beyond the
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
910 first character that is not a word constituent. @xref{Syntax Tables}.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
911 @end deffn
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
912
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
913 @deffn Command minibuffer-complete
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
914 This function completes the minibuffer contents as far as possible.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
915 @end deffn
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
916
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
917 @deffn Command minibuffer-complete-and-exit
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
918 This function completes the minibuffer contents, and exits if
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
919 confirmation is not required, i.e., if
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
920 @code{minibuffer-completion-confirm} is @code{nil}. If confirmation
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
921 @emph{is} required, it is given by repeating this command
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
922 immediately---the command is programmed to work without confirmation
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
923 when run twice in succession.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
924 @end deffn
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
925
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
926 @deffn Command minibuffer-completion-help
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
927 This function creates a list of the possible completions of the
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
928 current minibuffer contents. It works by calling @code{all-completions}
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
929 using the value of the variable @code{minibuffer-completion-table} as
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
930 the @var{collection} argument, and the value of
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
931 @code{minibuffer-completion-predicate} as the @var{predicate} argument.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
932 The list of completions is displayed as text in a buffer named
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
933 @samp{*Completions*}.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
934 @end deffn
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
935
66468
448890268bf7 Write about new optional argument for `display-completion-list'.
Masatake YAMATO <jet@gyve.org>
parents: 65758
diff changeset
936 @defun display-completion-list completions &optional common-substring
63582
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
937 This function displays @var{completions} to the stream in
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
938 @code{standard-output}, usually a buffer. (@xref{Read and Print}, for more
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
939 information about streams.) The argument @var{completions} is normally
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
940 a list of completions just returned by @code{all-completions}, but it
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
941 does not have to be. Each element may be a symbol or a string, either
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
942 of which is simply printed. It can also be a list of two strings,
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
943 which is printed as if the strings were concatenated. The first of
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
944 the two strings is the actual completion, the second string serves as
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
945 annotation.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
946
66506
8abfaaf2f6f1 (Completion Commands): Clean up prev change.
Richard M. Stallman <rms@gnu.org>
parents: 66468
diff changeset
947 The argument @var{common-substring} is the prefix that is common to
8abfaaf2f6f1 (Completion Commands): Clean up prev change.
Richard M. Stallman <rms@gnu.org>
parents: 66468
diff changeset
948 all the completions. With normal Emacs completion, it is usually the
8abfaaf2f6f1 (Completion Commands): Clean up prev change.
Richard M. Stallman <rms@gnu.org>
parents: 66468
diff changeset
949 same as the string that was completed. @code{display-completion-list}
8abfaaf2f6f1 (Completion Commands): Clean up prev change.
Richard M. Stallman <rms@gnu.org>
parents: 66468
diff changeset
950 uses this to highlight text in the completion list for better visual
8abfaaf2f6f1 (Completion Commands): Clean up prev change.
Richard M. Stallman <rms@gnu.org>
parents: 66468
diff changeset
951 feedback. This is not needed in the minibuffer; for minibuffer
8abfaaf2f6f1 (Completion Commands): Clean up prev change.
Richard M. Stallman <rms@gnu.org>
parents: 66468
diff changeset
952 completion, you can pass @code{nil}.
66468
448890268bf7 Write about new optional argument for `display-completion-list'.
Masatake YAMATO <jet@gyve.org>
parents: 65758
diff changeset
953
67881
d9ec339158fe (Basic Completion): Update lazy-completion-table examples for removal
Luc Teirlinck <teirllm@auburn.edu>
parents: 67818
diff changeset
954 This function is called by @code{minibuffer-completion-help}. The
63582
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
955 most common way to use it is together with
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
956 @code{with-output-to-temp-buffer}, like this:
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
957
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
958 @example
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
959 (with-output-to-temp-buffer "*Completions*"
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
960 (display-completion-list
66468
448890268bf7 Write about new optional argument for `display-completion-list'.
Masatake YAMATO <jet@gyve.org>
parents: 65758
diff changeset
961 (all-completions (buffer-string) my-alist)
448890268bf7 Write about new optional argument for `display-completion-list'.
Masatake YAMATO <jet@gyve.org>
parents: 65758
diff changeset
962 (buffer-string)))
63582
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
963 @end example
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
964 @end defun
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
965
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
966 @defopt completion-auto-help
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
967 If this variable is non-@code{nil}, the completion commands
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
968 automatically display a list of possible completions whenever nothing
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
969 can be completed because the next character is not uniquely determined.
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
970 @end defopt
6dfe79da09ed Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents: 62595
diff changeset
971
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
972 @defvar minibuffer-local-completion-map
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
973 @code{completing-read} uses this value as the local keymap when an
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
974 exact match of one of the completions is not required. By default, this
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
975 keymap makes the following bindings:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
976
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
977 @table @asis
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
978 @item @kbd{?}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
979 @code{minibuffer-completion-help}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
980
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
981 @item @key{SPC}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
982 @code{minibuffer-complete-word}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
983
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
984 @item @key{TAB}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
985 @code{minibuffer-complete}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
986 @end table
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
987
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
988 @noindent
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
989 with other characters bound as in @code{minibuffer-local-map}
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
990 (@pxref{Definition of minibuffer-local-map}).
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
991 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
992
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
993 @defvar minibuffer-local-must-match-map
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
994 @code{completing-read} uses this value as the local keymap when an
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
995 exact match of one of the completions is required. Therefore, no keys
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
996 are bound to @code{exit-minibuffer}, the command that exits the
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
997 minibuffer unconditionally. By default, this keymap makes the following
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
998 bindings:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
999
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1000 @table @asis
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1001 @item @kbd{?}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1002 @code{minibuffer-completion-help}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1003
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1004 @item @key{SPC}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1005 @code{minibuffer-complete-word}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1006
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1007 @item @key{TAB}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1008 @code{minibuffer-complete}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1009
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1010 @item @kbd{C-j}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1011 @code{minibuffer-complete-and-exit}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1012
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1013 @item @key{RET}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1014 @code{minibuffer-complete-and-exit}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1015 @end table
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1016
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1017 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1018 with other characters bound as in @code{minibuffer-local-map}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1019 @end defvar
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1020
67396
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
1021 @defvar minibuffer-local-filename-completion-map
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
1022 This is like @code{minibuffer-local-completion-map}
67499
91703011b252 (Completion Commands): Add mention of read-file-name
Juri Linkov <juri@jurta.org>
parents: 67414
diff changeset
1023 except that it does not bind @key{SPC}. This keymap is used by the
91703011b252 (Completion Commands): Add mention of read-file-name
Juri Linkov <juri@jurta.org>
parents: 67414
diff changeset
1024 function @code{read-file-name}.
67396
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
1025 @end defvar
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
1026
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
1027 @defvar minibuffer-local-must-match-filename-map
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
1028 This is like @code{minibuffer-local-must-match-map}
67499
91703011b252 (Completion Commands): Add mention of read-file-name
Juri Linkov <juri@jurta.org>
parents: 67414
diff changeset
1029 except that it does not bind @key{SPC}. This keymap is used by the
91703011b252 (Completion Commands): Add mention of read-file-name
Juri Linkov <juri@jurta.org>
parents: 67414
diff changeset
1030 function @code{read-file-name}.
67396
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
1031 @end defvar
2b8ecf96107e (Intro to Minibuffers): Replace list of local maps
Richard M. Stallman <rms@gnu.org>
parents: 66506
diff changeset
1032
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1033 @node High-Level Completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1034 @subsection High-Level Completion Functions
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1035
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1036 This section describes the higher-level convenient functions for
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1037 reading certain sorts of names with completion.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1038
12098
a6eb5f12b0f3 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 12067
diff changeset
1039 In most cases, you should not call these functions in the middle of a
a6eb5f12b0f3 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 12067
diff changeset
1040 Lisp function. When possible, do all minibuffer input as part of
22138
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
1041 reading the arguments for a command, in the @code{interactive}
d4ac295a98b3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21682
diff changeset
1042 specification. @xref{Defining Commands}.
12098
a6eb5f12b0f3 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 12067
diff changeset
1043
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1044 @defun read-buffer prompt &optional default existing
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1045 This function reads the name of a buffer and returns it as a string.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1046 The argument @var{default} is the default name to use, the value to
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1047 return if the user exits with an empty minibuffer. If non-@code{nil},
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1048 it should be a string or a buffer. It is mentioned in the prompt, but
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1049 is not inserted in the minibuffer as initial input.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1050
65758
028c8f536edb (High-Level Completion): Explain that the prompt
Romain Francoise <romain@orebokech.com>
parents: 64889
diff changeset
1051 The argument @var{prompt} should be a string ending with a colon and a
028c8f536edb (High-Level Completion): Explain that the prompt
Romain Francoise <romain@orebokech.com>
parents: 64889
diff changeset
1052 space. If @var{default} is non-@code{nil}, the function inserts it in
028c8f536edb (High-Level Completion): Explain that the prompt
Romain Francoise <romain@orebokech.com>
parents: 64889
diff changeset
1053 @var{prompt} before the colon to follow the convention for reading from
028c8f536edb (High-Level Completion): Explain that the prompt
Romain Francoise <romain@orebokech.com>
parents: 64889
diff changeset
1054 the minibuffer with a default value (@pxref{Programming Tips}).
028c8f536edb (High-Level Completion): Explain that the prompt
Romain Francoise <romain@orebokech.com>
parents: 64889
diff changeset
1055
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1056 If @var{existing} is non-@code{nil}, then the name specified must be
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1057 that of an existing buffer. The usual commands to exit the minibuffer
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1058 do not exit if the text is not valid, and @key{RET} does completion to
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1059 attempt to find a valid name. If @var{existing} is neither @code{nil}
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1060 nor @code{t}, confirmation is required after completion. (However,
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1061 @var{default} is not checked for validity; it is returned, whatever it
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1062 is, if the user exits with the minibuffer empty.)
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1063
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1064 In the following example, the user enters @samp{minibuffer.t}, and
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1065 then types @key{RET}. The argument @var{existing} is @code{t}, and the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1066 only buffer name starting with the given input is
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1067 @samp{minibuffer.texi}, so that name is the value.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1068
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1069 @example
65758
028c8f536edb (High-Level Completion): Explain that the prompt
Romain Francoise <romain@orebokech.com>
parents: 64889
diff changeset
1070 (read-buffer "Buffer name: " "foo" t)
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1071 @group
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1072 ;; @r{After evaluation of the preceding expression,}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1073 ;; @r{the following prompt appears,}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1074 ;; @r{with an empty minibuffer:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1075 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1076
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1077 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1078 ---------- Buffer: Minibuffer ----------
65758
028c8f536edb (High-Level Completion): Explain that the prompt
Romain Francoise <romain@orebokech.com>
parents: 64889
diff changeset
1079 Buffer name (default foo): @point{}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1080 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1081 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1082
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1083 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1084 ;; @r{The user types @kbd{minibuffer.t @key{RET}}.}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1085 @result{} "minibuffer.texi"
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1086 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1087 @end example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1088 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1089
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1090 @defvar read-buffer-function
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1091 This variable specifies how to read buffer names. For example, if you
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1092 set this variable to @code{iswitchb-read-buffer}, all Emacs commands
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1093 that call @code{read-buffer} to read a buffer name will actually use the
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1094 @code{iswitchb} package to read it.
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1095 @end defvar
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1096
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1097 @defun read-command prompt &optional default
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1098 This function reads the name of a command and returns it as a Lisp
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1099 symbol. The argument @var{prompt} is used as in
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1100 @code{read-from-minibuffer}. Recall that a command is anything for
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1101 which @code{commandp} returns @code{t}, and a command name is a symbol
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1102 for which @code{commandp} returns @code{t}. @xref{Interactive Call}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1103
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1104 The argument @var{default} specifies what to return if the user enters
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1105 null input. It can be a symbol or a string; if it is a string,
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1106 @code{read-command} interns it before returning it. If @var{default} is
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1107 @code{nil}, that means no default has been specified; then if the user
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1108 enters null input, the return value is @code{(intern "")}, that is, a
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1109 symbol whose name is an empty string.
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1110
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1111 @example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1112 (read-command "Command name? ")
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1113
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1114 @group
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1115 ;; @r{After evaluation of the preceding expression,}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1116 ;; @r{the following prompt appears with an empty minibuffer:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1117 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1118
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1119 @group
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1120 ---------- Buffer: Minibuffer ----------
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1121 Command name?
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1122 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1123 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1124 @end example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1125
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1126 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1127 If the user types @kbd{forward-c @key{RET}}, then this function returns
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1128 @code{forward-char}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1129
16736
981e116b4ac6 Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents: 16238
diff changeset
1130 The @code{read-command} function is a simplified interface to
981e116b4ac6 Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents: 16238
diff changeset
1131 @code{completing-read}. It uses the variable @code{obarray} so as to
981e116b4ac6 Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents: 16238
diff changeset
1132 complete in the set of extant Lisp symbols, and it uses the
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1133 @code{commandp} predicate so as to accept only command names:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1134
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1135 @cindex @code{commandp} example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1136 @example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1137 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1138 (read-command @var{prompt})
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1139 @equiv{}
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1140 (intern (completing-read @var{prompt} obarray
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1141 'commandp t nil))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1142 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1143 @end example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1144 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1145
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1146 @defun read-variable prompt &optional default
56606
0c7bfbe7453f (High-Level Completion): Add anchor for definition of `read-variable'.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56534
diff changeset
1147 @anchor{Definition of read-variable}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1148 This function reads the name of a user variable and returns it as a
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1149 symbol.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1150
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1151 The argument @var{default} specifies what to return if the user enters
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1152 null input. It can be a symbol or a string; if it is a string,
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1153 @code{read-variable} interns it before returning it. If @var{default}
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1154 is @code{nil}, that means no default has been specified; then if the
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1155 user enters null input, the return value is @code{(intern "")}.
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1156
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1157 @example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1158 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1159 (read-variable "Variable name? ")
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1160
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1161 ;; @r{After evaluation of the preceding expression,}
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1162 ;; @r{the following prompt appears,}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1163 ;; @r{with an empty minibuffer:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1164 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1165
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1166 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1167 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1168 Variable name? @point{}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1169 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1170 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1171 @end example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1172
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1173 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1174 If the user then types @kbd{fill-p @key{RET}}, @code{read-variable}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1175 returns @code{fill-prefix}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1176
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1177 This function is similar to @code{read-command}, but uses the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1178 predicate @code{user-variable-p} instead of @code{commandp}:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1179
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1180 @cindex @code{user-variable-p} example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1181 @example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1182 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1183 (read-variable @var{prompt})
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1184 @equiv{}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1185 (intern
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1186 (completing-read @var{prompt} obarray
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1187 'user-variable-p t nil))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1188 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1189 @end example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1190 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1191
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1192 See also the functions @code{read-coding-system} and
22252
40089afa2b1d *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 22138
diff changeset
1193 @code{read-non-nil-coding-system}, in @ref{User-Chosen Coding Systems}.
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1194
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1195 @node Reading File Names
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1196 @subsection Reading File Names
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1197
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1198 Here is another high-level completion function, designed for reading a
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1199 file name. It provides special features including automatic insertion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1200 of the default directory.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1201
52146
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1202 @defun read-file-name prompt &optional directory default existing initial predicate
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1203 This function reads a file name in the minibuffer, prompting with
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1204 @var{prompt} and providing completion.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1205
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1206 If @var{existing} is non-@code{nil}, then the user must specify the name
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1207 of an existing file; @key{RET} performs completion to make the name
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1208 valid if possible, and then refuses to exit if it is not valid. If the
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1209 value of @var{existing} is neither @code{nil} nor @code{t}, then
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1210 @key{RET} also requires confirmation after completion. If
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1211 @var{existing} is @code{nil}, then the name of a nonexistent file is
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1212 acceptable.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1213
67499
91703011b252 (Completion Commands): Add mention of read-file-name
Juri Linkov <juri@jurta.org>
parents: 67414
diff changeset
1214 The function @code{read-file-name} uses
91703011b252 (Completion Commands): Add mention of read-file-name
Juri Linkov <juri@jurta.org>
parents: 67414
diff changeset
1215 @code{minibuffer-local-filename-completion-map} as the keymap if
91703011b252 (Completion Commands): Add mention of read-file-name
Juri Linkov <juri@jurta.org>
parents: 67414
diff changeset
1216 @var{existing} is @code{nil}, and uses
91703011b252 (Completion Commands): Add mention of read-file-name
Juri Linkov <juri@jurta.org>
parents: 67414
diff changeset
1217 @code{minibuffer-local-must-match-filename-map} if @var{existing} is
91703011b252 (Completion Commands): Add mention of read-file-name
Juri Linkov <juri@jurta.org>
parents: 67414
diff changeset
1218 non-@code{nil}. @xref{Completion Commands}.
91703011b252 (Completion Commands): Add mention of read-file-name
Juri Linkov <juri@jurta.org>
parents: 67414
diff changeset
1219
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1220 The argument @var{directory} specifies the directory to use for
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1221 completion of relative file names. It should be an absolute directory
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1222 name. If @code{insert-default-directory} is non-@code{nil},
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1223 @var{directory} is also inserted in the minibuffer as initial input.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1224 It defaults to the current buffer's value of @code{default-directory}.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1225
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1226 @c Emacs 19 feature
52626
fe75563f4d13 Avoid @strong{Note:}.
Richard M. Stallman <rms@gnu.org>
parents: 52485
diff changeset
1227 If you specify @var{initial}, that is an initial file name to insert
fe75563f4d13 Avoid @strong{Note:}.
Richard M. Stallman <rms@gnu.org>
parents: 52485
diff changeset
1228 in the buffer (after @var{directory}, if that is inserted). In this
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1229 case, point goes at the beginning of @var{initial}. The default for
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1230 @var{initial} is @code{nil}---don't insert any file name. To see what
52626
fe75563f4d13 Avoid @strong{Note:}.
Richard M. Stallman <rms@gnu.org>
parents: 52485
diff changeset
1231 @var{initial} does, try the command @kbd{C-x C-v}. @strong{Please
fe75563f4d13 Avoid @strong{Note:}.
Richard M. Stallman <rms@gnu.org>
parents: 52485
diff changeset
1232 note:} we recommend using @var{default} rather than @var{initial} in
fe75563f4d13 Avoid @strong{Note:}.
Richard M. Stallman <rms@gnu.org>
parents: 52485
diff changeset
1233 most cases.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1234
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1235 If @var{default} is non-@code{nil}, then the function returns
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1236 @var{default} if the user exits the minibuffer with the same non-empty
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1237 contents that @code{read-file-name} inserted initially. The initial
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1238 minibuffer contents are always non-empty if
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1239 @code{insert-default-directory} is non-@code{nil}, as it is by
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1240 default. @var{default} is not checked for validity, regardless of the
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1241 value of @var{existing}. However, if @var{existing} is
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1242 non-@code{nil}, the initial minibuffer contents should be a valid file
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1243 (or directory) name. Otherwise @code{read-file-name} attempts
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1244 completion if the user exits without any editing, and does not return
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1245 @var{default}. @var{default} is also available through the history
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1246 commands.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1247
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1248 If @var{default} is @code{nil}, @code{read-file-name} tries to find a
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1249 substitute default to use in its place, which it treats in exactly the
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1250 same way as if it had been specified explicitly. If @var{default} is
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1251 @code{nil}, but @var{initial} is non-@code{nil}, then the default is
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1252 the absolute file name obtained from @var{directory} and
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1253 @var{initial}. If both @var{default} and @var{initial} are @code{nil}
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1254 and the buffer is visiting a file, @code{read-file-name} uses the
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1255 absolute file name of that file as default. If the buffer is not
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1256 visiting a file, then there is no default. In that case, if the user
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1257 types @key{RET} without any editing, @code{read-file-name} simply
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1258 returns the pre-inserted contents of the minibuffer.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1259
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1260 If the user types @key{RET} in an empty minibuffer, this function
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1261 returns an empty string, regardless of the value of @var{existing}.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1262 This is, for instance, how the user can make the current buffer visit
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1263 no file using @code{M-x set-visited-file-name}.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1264
52146
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1265 If @var{predicate} is non-@code{nil}, it specifies a function of one
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1266 argument that decides which file names are acceptable completion
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1267 possibilities. A file name is an acceptable value if @var{predicate}
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1268 returns non-@code{nil} for it.
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1269
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1270 @code{read-file-name} does not automatically expand file names. You
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1271 must call @code{expand-file-name} yourself if an absolute file name is
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1272 required.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1273
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1274 Here is an example:
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1275
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1276 @example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1277 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1278 (read-file-name "The file is ")
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1279
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1280 ;; @r{After evaluation of the preceding expression,}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1281 ;; @r{the following appears in the minibuffer:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1282 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1283
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1284 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1285 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1286 The file is /gp/gnu/elisp/@point{}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1287 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1288 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1289 @end example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1290
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1291 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1292 Typing @kbd{manual @key{TAB}} results in the following:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1293
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1294 @example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1295 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1296 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1297 The file is /gp/gnu/elisp/manual.texi@point{}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1298 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1299 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1300 @end example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1301
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1302 @c Wordy to avoid overfull hbox in smallbook mode.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1303 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1304 If the user types @key{RET}, @code{read-file-name} returns the file name
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1305 as the string @code{"/gp/gnu/elisp/manual.texi"}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1306 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1307
60783
73b73eabbe62 (Reading File Names): Document read-file-name-function.
Richard M. Stallman <rms@gnu.org>
parents: 60449
diff changeset
1308 @defvar read-file-name-function
73b73eabbe62 (Reading File Names): Document read-file-name-function.
Richard M. Stallman <rms@gnu.org>
parents: 60449
diff changeset
1309 If non-@code{nil}, this should be a function that accepts the same
73b73eabbe62 (Reading File Names): Document read-file-name-function.
Richard M. Stallman <rms@gnu.org>
parents: 60449
diff changeset
1310 arguments as @code{read-file-name}. When @code{read-file-name} is
73b73eabbe62 (Reading File Names): Document read-file-name-function.
Richard M. Stallman <rms@gnu.org>
parents: 60449
diff changeset
1311 called, it calls this function with the supplied arguments instead of
73b73eabbe62 (Reading File Names): Document read-file-name-function.
Richard M. Stallman <rms@gnu.org>
parents: 60449
diff changeset
1312 doing its usual work.
73b73eabbe62 (Reading File Names): Document read-file-name-function.
Richard M. Stallman <rms@gnu.org>
parents: 60449
diff changeset
1313 @end defvar
73b73eabbe62 (Reading File Names): Document read-file-name-function.
Richard M. Stallman <rms@gnu.org>
parents: 60449
diff changeset
1314
60961
059ddef3ce4b (Reading File Names): Document read-file-name-completion-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents: 60783
diff changeset
1315 @defvar read-file-name-completion-ignore-case
059ddef3ce4b (Reading File Names): Document read-file-name-completion-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents: 60783
diff changeset
1316 If this variable is non-@code{nil}, @code{read-file-name} ignores case
059ddef3ce4b (Reading File Names): Document read-file-name-completion-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents: 60783
diff changeset
1317 when performing completion.
059ddef3ce4b (Reading File Names): Document read-file-name-completion-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents: 60783
diff changeset
1318 @end defvar
059ddef3ce4b (Reading File Names): Document read-file-name-completion-ignore-case.
Richard M. Stallman <rms@gnu.org>
parents: 60783
diff changeset
1319
52146
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1320 @defun read-directory-name prompt &optional directory default existing initial
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1321 This function is like @code{read-file-name} but allows only directory
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1322 names as completion possibilities.
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1323
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1324 If @var{default} is @code{nil} and @var{initial} is non-@code{nil},
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1325 @code{read-directory-name} constructs a substitute default by
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1326 combining @var{directory} (or the current buffer's default directory
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1327 if @var{directory} is @code{nil}) and @var{initial}. If both
62595
761fb32ee169 (Reading File Names): Update description of `read-directory-name'.
Luc Teirlinck <teirllm@auburn.edu>
parents: 60961
diff changeset
1328 @var{default} and @var{initial} are @code{nil}, this function uses
761fb32ee169 (Reading File Names): Update description of `read-directory-name'.
Luc Teirlinck <teirllm@auburn.edu>
parents: 60961
diff changeset
1329 @var{directory} as substitute default, or the current buffer's default
761fb32ee169 (Reading File Names): Update description of `read-directory-name'.
Luc Teirlinck <teirllm@auburn.edu>
parents: 60961
diff changeset
1330 directory if @var{directory} is @code{nil}.
52146
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1331 @end defun
c78c690c99e8 (Reading File Names): read-file-name has new arg PREDICATE.
Richard M. Stallman <rms@gnu.org>
parents: 51989
diff changeset
1332
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1333 @defopt insert-default-directory
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1334 This variable is used by @code{read-file-name}, and thus, indirectly,
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1335 by most commands reading file names. (This includes all commands that
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1336 use the code letters @samp{f} or @samp{F} in their interactive form.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1337 @xref{Interactive Codes,, Code Characters for interactive}.) Its
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1338 value controls whether @code{read-file-name} starts by placing the
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1339 name of the default directory in the minibuffer, plus the initial file
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1340 name if any. If the value of this variable is @code{nil}, then
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1341 @code{read-file-name} does not place any initial input in the
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1342 minibuffer (unless you specify initial input with the @var{initial}
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1343 argument). In that case, the default directory is still used for
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1344 completion of relative file names, but is not displayed.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1345
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1346 If this variable is @code{nil} and the initial minibuffer contents are
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1347 empty, the user may have to explicitly fetch the next history element
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1348 to access a default value. If the variable is non-@code{nil}, the
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1349 initial minibuffer contents are always non-empty and the user can
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1350 always request a default value by immediately typing @key{RET} in an
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1351 unedited minibuffer. (See above.)
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1352
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1353 For example:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1354
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1355 @example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1356 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1357 ;; @r{Here the minibuffer starts out with the default directory.}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1358 (let ((insert-default-directory t))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1359 (read-file-name "The file is "))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1360 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1361
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1362 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1363 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1364 The file is ~lewis/manual/@point{}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1365 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1366 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1367
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1368 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1369 ;; @r{Here the minibuffer is empty and only the prompt}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1370 ;; @r{appears on its line.}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1371 (let ((insert-default-directory nil))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1372 (read-file-name "The file is "))
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1373 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1374
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1375 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1376 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1377 The file is @point{}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1378 ---------- Buffer: Minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1379 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1380 @end example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1381 @end defopt
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1382
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1383 @node Programmed Completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1384 @subsection Programmed Completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1385 @cindex programmed completion
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1386
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1387 Sometimes it is not possible to create an alist or an obarray
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1388 containing all the intended possible completions. In such a case, you
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1389 can supply your own function to compute the completion of a given string.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1390 This is called @dfn{programmed completion}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1391
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1392 To use this feature, pass a symbol with a function definition as the
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1393 @var{collection} argument to @code{completing-read}. The function
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1394 @code{completing-read} arranges to pass your completion function along
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1395 to @code{try-completion} and @code{all-completions}, which will then let
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1396 your function do all the work.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1397
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1398 The completion function should accept three arguments:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1399
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1400 @itemize @bullet
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1401 @item
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1402 The string to be completed.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1403
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1404 @item
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1405 The predicate function to filter possible matches, or @code{nil} if
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1406 none. Your function should call the predicate for each possible match,
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1407 and ignore the possible match if the predicate returns @code{nil}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1408
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1409 @item
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1410 A flag specifying the type of operation.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1411 @end itemize
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1412
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1413 There are three flag values for three operations:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1414
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1415 @itemize @bullet
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1416 @item
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1417 @code{nil} specifies @code{try-completion}. The completion function
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1418 should return the completion of the specified string, or @code{t} if the
16157
1713fe640e41 Clarify value returned by programmed completion function.
Richard M. Stallman <rms@gnu.org>
parents: 15768
diff changeset
1419 string is a unique and exact match already, or @code{nil} if the string
1713fe640e41 Clarify value returned by programmed completion function.
Richard M. Stallman <rms@gnu.org>
parents: 15768
diff changeset
1420 matches no possibility.
1713fe640e41 Clarify value returned by programmed completion function.
Richard M. Stallman <rms@gnu.org>
parents: 15768
diff changeset
1421
1713fe640e41 Clarify value returned by programmed completion function.
Richard M. Stallman <rms@gnu.org>
parents: 15768
diff changeset
1422 If the string is an exact match for one possibility, but also matches
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1423 other longer possibilities, the function should return the string, not
16157
1713fe640e41 Clarify value returned by programmed completion function.
Richard M. Stallman <rms@gnu.org>
parents: 15768
diff changeset
1424 @code{t}.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1425
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1426 @item
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1427 @code{t} specifies @code{all-completions}. The completion function
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1428 should return a list of all possible completions of the specified
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1429 string.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1430
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1431 @item
51989
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
1432 @code{lambda} specifies @code{test-completion}. The completion
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1433 function should return @code{t} if the specified string is an exact
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1434 match for some possibility; @code{nil} otherwise.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1435 @end itemize
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1436
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1437 It would be consistent and clean for completion functions to allow
12098
a6eb5f12b0f3 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 12067
diff changeset
1438 lambda expressions (lists that are functions) as well as function
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1439 symbols as @var{collection}, but this is impossible. Lists as
51989
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
1440 completion tables already have other meanings, and it would be
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
1441 unreliable to treat one differently just because it is also a possible
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
1442 function. So you must arrange for any function you wish to use for
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
1443 completion to be encapsulated in a symbol.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1444
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1445 Emacs uses programmed completion when completing file names.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1446 @xref{File Name Completion}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1447
51914
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
1448 @defmac dynamic-completion-table function
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
1449 This macro is a convenient way to write a function that can act as
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
1450 programmed completion function. The argument @var{function} should be
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
1451 a function that takes one argument, a string, and returns an alist of
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
1452 possible completions of it. You can think of
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
1453 @code{dynamic-completion-table} as a transducer between that interface
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
1454 and the interface for programmed completion functions.
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
1455 @end defmac
9cd313749c97 (Basic Completion): Add lazy-completion-table.
Richard M. Stallman <rms@gnu.org>
parents: 51703
diff changeset
1456
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1457 @node Yes-or-No Queries
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1458 @section Yes-or-No Queries
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1459 @cindex asking the user questions
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1460 @cindex querying the user
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1461 @cindex yes-or-no questions
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1462
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1463 This section describes functions used to ask the user a yes-or-no
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1464 question. The function @code{y-or-n-p} can be answered with a single
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1465 character; it is useful for questions where an inadvertent wrong answer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1466 will not have serious consequences. @code{yes-or-no-p} is suitable for
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1467 more momentous questions, since it requires three or four characters to
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1468 answer.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1469
7337
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1470 If either of these functions is called in a command that was invoked
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1471 using the mouse---more precisely, if @code{last-nonmenu-event}
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1472 (@pxref{Command Loop Info}) is either @code{nil} or a list---then it
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1473 uses a dialog box or pop-up menu to ask the question. Otherwise, it
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1474 uses keyboard input. You can force use of the mouse or use of keyboard
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1475 input by binding @code{last-nonmenu-event} to a suitable value around
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1476 the call.
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1477
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1478 Strictly speaking, @code{yes-or-no-p} uses the minibuffer and
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1479 @code{y-or-n-p} does not; but it seems best to describe them together.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1480
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1481 @defun y-or-n-p prompt
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1482 This function asks the user a question, expecting input in the echo
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1483 area. It returns @code{t} if the user types @kbd{y}, @code{nil} if the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1484 user types @kbd{n}. This function also accepts @key{SPC} to mean yes
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1485 and @key{DEL} to mean no. It accepts @kbd{C-]} to mean ``quit'', like
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1486 @kbd{C-g}, because the question might look like a minibuffer and for
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1487 that reason the user might try to use @kbd{C-]} to get out. The answer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1488 is a single character, with no @key{RET} needed to terminate it. Upper
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1489 and lower case are equivalent.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1490
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1491 ``Asking the question'' means printing @var{prompt} in the echo area,
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1492 followed by the string @w{@samp{(y or n) }}. If the input is not one of
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1493 the expected answers (@kbd{y}, @kbd{n}, @kbd{@key{SPC}},
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1494 @kbd{@key{DEL}}, or something that quits), the function responds
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1495 @samp{Please answer y or n.}, and repeats the request.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1496
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1497 This function does not actually use the minibuffer, since it does not
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1498 allow editing of the answer. It actually uses the echo area (@pxref{The
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1499 Echo Area}), which uses the same screen space as the minibuffer. The
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1500 cursor moves to the echo area while the question is being asked.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1501
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1502 The answers and their meanings, even @samp{y} and @samp{n}, are not
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1503 hardwired. The keymap @code{query-replace-map} specifies them.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1504 @xref{Search and Replace}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1505
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1506 In the following example, the user first types @kbd{q}, which is
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1507 invalid. At the next prompt the user types @kbd{y}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1508
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1509 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1510 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1511 (y-or-n-p "Do you need a lift? ")
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1512
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1513 ;; @r{After evaluation of the preceding expression,}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1514 ;; @r{the following prompt appears in the echo area:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1515 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1516
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1517 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1518 ---------- Echo area ----------
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1519 Do you need a lift? (y or n)
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1520 ---------- Echo area ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1521 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1522
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1523 ;; @r{If the user then types @kbd{q}, the following appears:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1524
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1525 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1526 ---------- Echo area ----------
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1527 Please answer y or n. Do you need a lift? (y or n)
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1528 ---------- Echo area ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1529 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1530
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1531 ;; @r{When the user types a valid answer,}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1532 ;; @r{it is displayed after the question:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1533
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1534 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1535 ---------- Echo area ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1536 Do you need a lift? (y or n) y
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1537 ---------- Echo area ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1538 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1539 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1540
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1541 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1542 We show successive lines of echo area messages, but only one actually
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1543 appears on the screen at a time.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1544 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1545
15768
b913a75fddee Add y-or-n-p-with-timeout.
Richard M. Stallman <rms@gnu.org>
parents: 13319
diff changeset
1546 @defun y-or-n-p-with-timeout prompt seconds default-value
b913a75fddee Add y-or-n-p-with-timeout.
Richard M. Stallman <rms@gnu.org>
parents: 13319
diff changeset
1547 Like @code{y-or-n-p}, except that if the user fails to answer within
b913a75fddee Add y-or-n-p-with-timeout.
Richard M. Stallman <rms@gnu.org>
parents: 13319
diff changeset
1548 @var{seconds} seconds, this function stops waiting and returns
b913a75fddee Add y-or-n-p-with-timeout.
Richard M. Stallman <rms@gnu.org>
parents: 13319
diff changeset
1549 @var{default-value}. It works by setting up a timer; see @ref{Timers}.
b913a75fddee Add y-or-n-p-with-timeout.
Richard M. Stallman <rms@gnu.org>
parents: 13319
diff changeset
1550 The argument @var{seconds} may be an integer or a floating point number.
b913a75fddee Add y-or-n-p-with-timeout.
Richard M. Stallman <rms@gnu.org>
parents: 13319
diff changeset
1551 @end defun
b913a75fddee Add y-or-n-p-with-timeout.
Richard M. Stallman <rms@gnu.org>
parents: 13319
diff changeset
1552
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1553 @defun yes-or-no-p prompt
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1554 This function asks the user a question, expecting input in the
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1555 minibuffer. It returns @code{t} if the user enters @samp{yes},
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1556 @code{nil} if the user types @samp{no}. The user must type @key{RET} to
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1557 finalize the response. Upper and lower case are equivalent.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1558
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1559 @code{yes-or-no-p} starts by displaying @var{prompt} in the echo area,
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1560 followed by @w{@samp{(yes or no) }}. The user must type one of the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1561 expected responses; otherwise, the function responds @samp{Please answer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1562 yes or no.}, waits about two seconds and repeats the request.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1563
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1564 @code{yes-or-no-p} requires more work from the user than
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1565 @code{y-or-n-p} and is appropriate for more crucial decisions.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1566
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1567 Here is an example:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1568
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1569 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1570 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1571 (yes-or-no-p "Do you really want to remove everything? ")
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1572
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1573 ;; @r{After evaluation of the preceding expression,}
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1574 ;; @r{the following prompt appears,}
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1575 ;; @r{with an empty minibuffer:}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1576 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1577
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1578 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1579 ---------- Buffer: minibuffer ----------
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48730
diff changeset
1580 Do you really want to remove everything? (yes or no)
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1581 ---------- Buffer: minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1582 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1583 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1584
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1585 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1586 If the user first types @kbd{y @key{RET}}, which is invalid because this
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1587 function demands the entire word @samp{yes}, it responds by displaying
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1588 these prompts, with a brief pause between them:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1589
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1590 @smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1591 @group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1592 ---------- Buffer: minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1593 Please answer yes or no.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1594 Do you really want to remove everything? (yes or no)
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1595 ---------- Buffer: minibuffer ----------
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1596 @end group
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1597 @end smallexample
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1598 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1599
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1600 @node Multiple Queries
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1601 @section Asking Multiple Y-or-N Questions
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1602
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1603 When you have a series of similar questions to ask, such as ``Do you
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1604 want to save this buffer'' for each buffer in turn, you should use
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1605 @code{map-y-or-n-p} to ask the collection of questions, rather than
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1606 asking each question individually. This gives the user certain
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1607 convenient facilities such as the ability to answer the whole series at
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1608 once.
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1609
26696
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1610 @defun map-y-or-n-p prompter actor list &optional help action-alist no-cursor-in-echo-area
21007
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1611 This function asks the user a series of questions, reading a
66d807bdc5b4 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 16736
diff changeset
1612 single-character answer in the echo area for each one.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1613
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1614 The value of @var{list} specifies the objects to ask questions about.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1615 It should be either a list of objects or a generator function. If it is
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1616 a function, it should expect no arguments, and should return either the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1617 next object to ask about, or @code{nil} meaning stop asking questions.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1618
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1619 The argument @var{prompter} specifies how to ask each question. If
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1620 @var{prompter} is a string, the question text is computed like this:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1621
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1622 @example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1623 (format @var{prompter} @var{object})
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1624 @end example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1625
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1626 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1627 where @var{object} is the next object to ask about (as obtained from
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1628 @var{list}).
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1629
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1630 If not a string, @var{prompter} should be a function of one argument
12226
af994773013b changes for 19.29.
Melissa Weisshaus <melissa@gnu.org>
parents: 12098
diff changeset
1631 (the next object to ask about) and should return the question text. If
af994773013b changes for 19.29.
Melissa Weisshaus <melissa@gnu.org>
parents: 12098
diff changeset
1632 the value is a string, that is the question to ask the user. The
af994773013b changes for 19.29.
Melissa Weisshaus <melissa@gnu.org>
parents: 12098
diff changeset
1633 function can also return @code{t} meaning do act on this object (and
af994773013b changes for 19.29.
Melissa Weisshaus <melissa@gnu.org>
parents: 12098
diff changeset
1634 don't ask the user), or @code{nil} meaning ignore this object (and don't
af994773013b changes for 19.29.
Melissa Weisshaus <melissa@gnu.org>
parents: 12098
diff changeset
1635 ask the user).
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1636
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1637 The argument @var{actor} says how to act on the answers that the user
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1638 gives. It should be a function of one argument, and it is called with
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1639 each object that the user says yes for. Its argument is always an
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1640 object obtained from @var{list}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1641
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1642 If the argument @var{help} is given, it should be a list of this form:
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1643
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1644 @example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1645 (@var{singular} @var{plural} @var{action})
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1646 @end example
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1647
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1648 @noindent
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1649 where @var{singular} is a string containing a singular noun that
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1650 describes the objects conceptually being acted on, @var{plural} is the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1651 corresponding plural noun, and @var{action} is a transitive verb
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1652 describing what @var{actor} does.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1653
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1654 If you don't specify @var{help}, the default is @code{("object"
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1655 "objects" "act on")}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1656
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1657 Each time a question is asked, the user may enter @kbd{y}, @kbd{Y}, or
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1658 @key{SPC} to act on that object; @kbd{n}, @kbd{N}, or @key{DEL} to skip
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1659 that object; @kbd{!} to act on all following objects; @key{ESC} or
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1660 @kbd{q} to exit (skip all following objects); @kbd{.} (period) to act on
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1661 the current object and then exit; or @kbd{C-h} to get help. These are
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1662 the same answers that @code{query-replace} accepts. The keymap
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1663 @code{query-replace-map} defines their meaning for @code{map-y-or-n-p}
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1664 as well as for @code{query-replace}; see @ref{Search and Replace}.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1665
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1666 You can use @var{action-alist} to specify additional possible answers
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1667 and what they mean. It is an alist of elements of the form
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1668 @code{(@var{char} @var{function} @var{help})}, each of which defines one
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1669 additional answer. In this element, @var{char} is a character (the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1670 answer); @var{function} is a function of one argument (an object from
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1671 @var{list}); @var{help} is a string.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1672
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1673 When the user responds with @var{char}, @code{map-y-or-n-p} calls
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1674 @var{function}. If it returns non-@code{nil}, the object is considered
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1675 ``acted upon'', and @code{map-y-or-n-p} advances to the next object in
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1676 @var{list}. If it returns @code{nil}, the prompt is repeated for the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1677 same object.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1678
26696
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1679 Normally, @code{map-y-or-n-p} binds @code{cursor-in-echo-area} while
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1680 prompting. But if @var{no-cursor-in-echo-area} is non-@code{nil}, it
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1681 does not do that.
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1682
7337
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1683 If @code{map-y-or-n-p} is called in a command that was invoked using the
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1684 mouse---more precisely, if @code{last-nonmenu-event} (@pxref{Command
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1685 Loop Info}) is either @code{nil} or a list---then it uses a dialog box
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1686 or pop-up menu to ask the question. In this case, it does not use
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1687 keyboard input or the echo area. You can force use of the mouse or use
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1688 of keyboard input by binding @code{last-nonmenu-event} to a suitable
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1689 value around the call.
cd57cd335fff *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 7221
diff changeset
1690
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1691 The return value of @code{map-y-or-n-p} is the number of objects acted on.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1692 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1693
23147
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1694 @node Reading a Password
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1695 @section Reading a Password
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1696 @cindex passwords, reading
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1697
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1698 To read a password to pass to another program, you can use the
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1699 function @code{read-passwd}.
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1700
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1701 @defun read-passwd prompt &optional confirm default
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1702 This function reads a password, prompting with @var{prompt}. It does
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1703 not echo the password as the user types it; instead, it echoes @samp{.}
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1704 for each character in the password.
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1705
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1706 The optional argument @var{confirm}, if non-@code{nil}, says to read the
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1707 password twice and insist it must be the same both times. If it isn't
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1708 the same, the user has to type it over and over until the last two
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1709 times match.
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1710
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1711 The optional argument @var{default} specifies the default password to
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1712 return if the user enters empty input. If @var{default} is @code{nil},
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1713 then @code{read-passwd} returns the null string in that case.
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1714 @end defun
ad9732e88e90 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 23146
diff changeset
1715
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1716 @node Minibuffer Commands
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1717 @section Minibuffer Commands
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1718
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1719 This section describes some commands meant for use in the
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1720 minibuffer.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1721
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1722 @deffn Command exit-minibuffer
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1723 This command exits the active minibuffer. It is normally bound to
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1724 keys in minibuffer local keymaps.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1725 @end deffn
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1726
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1727 @deffn Command self-insert-and-exit
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1728 This command exits the active minibuffer after inserting the last
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1729 character typed on the keyboard (found in @code{last-command-char};
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1730 @pxref{Command Loop Info}).
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1731 @end deffn
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1732
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1733 @deffn Command previous-history-element n
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1734 This command replaces the minibuffer contents with the value of the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1735 @var{n}th previous (older) history element.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1736 @end deffn
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1737
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1738 @deffn Command next-history-element n
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1739 This command replaces the minibuffer contents with the value of the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1740 @var{n}th more recent history element.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1741 @end deffn
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1742
26696
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1743 @deffn Command previous-matching-history-element pattern n
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1744 This command replaces the minibuffer contents with the value of the
26696
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1745 @var{n}th previous (older) history element that matches @var{pattern} (a
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1746 regular expression).
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1747 @end deffn
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1748
26696
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1749 @deffn Command next-matching-history-element pattern n
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1750 This command replaces the minibuffer contents with the value of the
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1751 @var{n}th next (newer) history element that matches @var{pattern} (a
ef5e7bbe6f19 Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents: 25751
diff changeset
1752 regular expression).
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1753 @end deffn
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1754
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1755 @node Minibuffer Windows
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1756 @section Minibuffer Windows
39531
35c1673ff6ab (Minibuffer Misc): Add entries for `minibuffer-contents',
Miles Bader <miles@gnu.org>
parents: 38159
diff changeset
1757
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1758 These functions access and select minibuffer windows
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1759 and test whether they are active.
51989
13ba58726a52 (Basic Completion): Describe test-completion.
Richard M. Stallman <rms@gnu.org>
parents: 51914
diff changeset
1760
12067
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
1761 @defun active-minibuffer-window
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
1762 This function returns the currently active minibuffer window, or
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
1763 @code{nil} if none is currently active.
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
1764 @end defun
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
1765
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1766 @defun minibuffer-window &optional frame
56534
3d8fa211fc46 (Minibuffer Misc): Add anchor.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56485
diff changeset
1767 @anchor{Definition of minibuffer-window}
12067
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
1768 This function returns the minibuffer window used for frame @var{frame}.
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
1769 If @var{frame} is @code{nil}, that stands for the current frame. Note
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
1770 that the minibuffer window used by a frame need not be part of that
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
1771 frame---a frame that has no minibuffer of its own necessarily uses some
73dc8205d259 *** empty log message ***
Karl Heuer <kwzh@gnu.org>
parents: 8753
diff changeset
1772 other frame's minibuffer window.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1773 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1774
53429
246f74971d9a (Minibuffer Misc): Add set-minibuffer-window.
Richard M. Stallman <rms@gnu.org>
parents: 52626
diff changeset
1775 @defun set-minibuffer-window window
246f74971d9a (Minibuffer Misc): Add set-minibuffer-window.
Richard M. Stallman <rms@gnu.org>
parents: 52626
diff changeset
1776 This function specifies @var{window} as the minibuffer window to use.
246f74971d9a (Minibuffer Misc): Add set-minibuffer-window.
Richard M. Stallman <rms@gnu.org>
parents: 52626
diff changeset
1777 This affects where the minibuffer is displayed if you put text in it
246f74971d9a (Minibuffer Misc): Add set-minibuffer-window.
Richard M. Stallman <rms@gnu.org>
parents: 52626
diff changeset
1778 without invoking the usual minibuffer commands. It has no effect on
246f74971d9a (Minibuffer Misc): Add set-minibuffer-window.
Richard M. Stallman <rms@gnu.org>
parents: 52626
diff changeset
1779 the usual minibuffer input functions because they all start by
246f74971d9a (Minibuffer Misc): Add set-minibuffer-window.
Richard M. Stallman <rms@gnu.org>
parents: 52626
diff changeset
1780 choosing the minibuffer window according to the current frame.
246f74971d9a (Minibuffer Misc): Add set-minibuffer-window.
Richard M. Stallman <rms@gnu.org>
parents: 52626
diff changeset
1781 @end defun
246f74971d9a (Minibuffer Misc): Add set-minibuffer-window.
Richard M. Stallman <rms@gnu.org>
parents: 52626
diff changeset
1782
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1783 @c Emacs 19 feature
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1784 @defun window-minibuffer-p &optional window
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1785 This function returns non-@code{nil} if @var{window} is a minibuffer
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1786 window.
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1787 @var{window} defaults to the selected window.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1788 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1789
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1790 It is not correct to determine whether a given window is a minibuffer by
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1791 comparing it with the result of @code{(minibuffer-window)}, because
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1792 there can be more than one minibuffer window if there is more than one
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1793 frame.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1794
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1795 @defun minibuffer-window-active-p window
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1796 This function returns non-@code{nil} if @var{window}, assumed to be
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1797 a minibuffer window, is currently active.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1798 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1799
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1800 @node Minibuffer Contents
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1801 @section Minibuffer Contents
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1802
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1803 These functions access the minibuffer prompt and contents.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1804
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1805 @defun minibuffer-prompt
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1806 This function returns the prompt string of the currently active
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1807 minibuffer. If no minibuffer is active, it returns @code{nil}.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1808 @end defun
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1809
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1810 @defun minibuffer-prompt-end
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1811 @tindex minibuffer-prompt-end
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1812 This function returns the current
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1813 position of the end of the minibuffer prompt, if a minibuffer is
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1814 current. Otherwise, it returns the minimum valid buffer position.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1815 @end defun
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1816
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1817 @defun minibuffer-prompt-width
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1818 This function returns the current display-width of the minibuffer
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1819 prompt, if a minibuffer is current. Otherwise, it returns zero.
52485
7fc901c75a7d (Intro to Minibuffers): Explain that the minibuffer
Richard M. Stallman <rms@gnu.org>
parents: 52401
diff changeset
1820 @end defun
7fc901c75a7d (Intro to Minibuffers): Explain that the minibuffer
Richard M. Stallman <rms@gnu.org>
parents: 52401
diff changeset
1821
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1822 @defun minibuffer-contents
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1823 @tindex minibuffer-contents
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1824 This function returns the editable
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1825 contents of the minibuffer (that is, everything except the prompt) as
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1826 a string, if a minibuffer is current. Otherwise, it returns the
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1827 entire contents of the current buffer.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1828 @end defun
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1829
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1830 @defun minibuffer-contents-no-properties
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1831 @tindex minibuffer-contents-no-properties
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1832 This is like @code{minibuffer-contents}, except that it does not copy text
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1833 properties, just the characters themselves. @xref{Text Properties}.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1834 @end defun
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1835
67619
8ae5d2f218aa (Minibuffer Contents): Add minibuffer-completion-contents.
Juri Linkov <juri@jurta.org>
parents: 67499
diff changeset
1836 @defun minibuffer-completion-contents
8ae5d2f218aa (Minibuffer Contents): Add minibuffer-completion-contents.
Juri Linkov <juri@jurta.org>
parents: 67499
diff changeset
1837 @tindex minibuffer-completion-contents
67629
f488d808c052 (Minibuffer Contents): Minor cleanup.
Richard M. Stallman <rms@gnu.org>
parents: 67619
diff changeset
1838 This is like @code{minibuffer-contents}, except that it returns only
f488d808c052 (Minibuffer Contents): Minor cleanup.
Richard M. Stallman <rms@gnu.org>
parents: 67619
diff changeset
1839 the contents before point. That is the part that completion commands
f488d808c052 (Minibuffer Contents): Minor cleanup.
Richard M. Stallman <rms@gnu.org>
parents: 67619
diff changeset
1840 operate on. @xref{Minibuffer Completion}.
67619
8ae5d2f218aa (Minibuffer Contents): Add minibuffer-completion-contents.
Juri Linkov <juri@jurta.org>
parents: 67499
diff changeset
1841 @end defun
8ae5d2f218aa (Minibuffer Contents): Add minibuffer-completion-contents.
Juri Linkov <juri@jurta.org>
parents: 67499
diff changeset
1842
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1843 @defun delete-minibuffer-contents
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1844 @tindex delete-minibuffer-contents
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1845 This function erases the editable contents of the minibuffer (that is,
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1846 everything except the prompt), if a minibuffer is current. Otherwise,
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1847 it erases the entire current buffer.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1848 @end defun
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1849
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1850 @node Recursive Mini
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1851 @section Recursive Minibuffers
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1852
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1853 These functions and variables deal with recursive minibuffers
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1854 (@pxref{Recursive Editing}):
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1855
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1856 @defun minibuffer-depth
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1857 This function returns the current depth of activations of the
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1858 minibuffer, a nonnegative integer. If no minibuffers are active, it
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1859 returns zero.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1860 @end defun
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1861
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1862 @defopt enable-recursive-minibuffers
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1863 If this variable is non-@code{nil}, you can invoke commands (such as
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1864 @code{find-file}) that use minibuffers even while the minibuffer window
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1865 is active. Such invocation produces a recursive editing level for a new
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1866 minibuffer. The outer-level minibuffer is invisible while you are
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1867 editing the inner one.
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1868
21682
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1869 If this variable is @code{nil}, you cannot invoke minibuffer
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1870 commands when the minibuffer window is active, not even if you switch to
90da2489c498 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 21007
diff changeset
1871 another window to do it.
6555
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1872 @end defopt
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1873
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1874 @c Emacs 19 feature
771fa0ddb356 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1875 If a command name has a property @code{enable-recursive-minibuffers}
7221
a2c7acc3be9c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 6555
diff changeset
1876 that is non-@code{nil}, then the command can use the minibuffer to read
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1877 arguments even if it is invoked from the minibuffer. A command can
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1878 also achieve this by binding @code{enable-recursive-minibuffers}
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1879 to @code{t} in the interactive declaration (@pxref{Using Interactive}).
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1880 The minibuffer command @code{next-matching-history-element} (normally
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1881 @kbd{M-s} in the minibuffer) does the latter.
50603
86ea12469954 (Minibuffer Misc): Document fn minibuffer-message.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
1882
64843
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1883 @node Minibuffer Misc
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1884 @section Minibuffer Miscellany
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1885
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1886 @defun minibufferp &optional buffer-or-name
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1887 This function returns non-@code{nil} if @var{buffer-or-name} is a
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1888 minibuffer. If @var{buffer-or-name} is omitted, it tests the current
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1889 buffer.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1890 @end defun
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1891
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1892 @defvar minibuffer-setup-hook
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1893 This is a normal hook that is run whenever the minibuffer is entered.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1894 @xref{Hooks}.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1895 @end defvar
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1896
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1897 @defvar minibuffer-exit-hook
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1898 This is a normal hook that is run whenever the minibuffer is exited.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1899 @xref{Hooks}.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1900 @end defvar
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1901
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1902 @defvar minibuffer-help-form
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1903 @anchor{Definition of minibuffer-help-form}
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1904 The current value of this variable is used to rebind @code{help-form}
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1905 locally inside the minibuffer (@pxref{Help Functions}).
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1906 @end defvar
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1907
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1908 @defvar minibuffer-scroll-window
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1909 @anchor{Definition of minibuffer-scroll-window}
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1910 If the value of this variable is non-@code{nil}, it should be a window
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1911 object. When the function @code{scroll-other-window} is called in the
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1912 minibuffer, it scrolls this window.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1913 @end defvar
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1914
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1915 @defun minibuffer-selected-window
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1916 This function returns the window which was selected when the
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1917 minibuffer was entered. If selected window is not a minibuffer
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1918 window, it returns @code{nil}.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1919 @end defun
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1920
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1921 @defopt max-mini-window-height
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1922 This variable specifies the maximum height for resizing minibuffer
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1923 windows. If a float, it specifies a fraction of the height of the
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1924 frame. If an integer, it specifies a number of lines.
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1925 @end defopt
6c4d2fa924e4 (Minibuffer Misc): Node split up.
Richard M. Stallman <rms@gnu.org>
parents: 63582
diff changeset
1926
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1927 @defun minibuffer-message string
50603
86ea12469954 (Minibuffer Misc): Document fn minibuffer-message.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
1928 This function displays @var{string} temporarily at the end of the
53801
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1929 minibuffer text, for two seconds, or until the next input event
7fda9e6236d5 (Text from Minibuffer): Various corrections and clarifications.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53429
diff changeset
1930 arrives, whichever comes first.
50603
86ea12469954 (Minibuffer Misc): Document fn minibuffer-message.
Richard M. Stallman <rms@gnu.org>
parents: 49600
diff changeset
1931 @end defun
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 52146
diff changeset
1932
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 52146
diff changeset
1933 @ignore
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 52146
diff changeset
1934 arch-tag: bba7f945-9078-477f-a2ce-18818a6e1218
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 52146
diff changeset
1935 @end ignore