* configure.in: Fix last change.
[emacs.git] / doc / lispref / abbrevs.texi
bloba64e8a0bd5123c448ce632bf79e5107a681f33b5
1 @c -*-texinfo-*-
2 @c This is part of the GNU Emacs Lisp Reference Manual.
3 @c Copyright (C) 1990-1994, 1999, 2001-2012 Free Software Foundation, Inc.
4 @c See the file elisp.texi for copying conditions.
5 @setfilename ../../info/abbrevs
6 @node Abbrevs, Processes, Syntax Tables, Top
7 @chapter Abbrevs and Abbrev Expansion
8 @cindex abbrev
9 @c  @cindex abbrev table  Redundant with "abbrev".
11   An abbreviation or @dfn{abbrev} is a string of characters that may be
12 expanded to a longer string.  The user can insert the abbrev string and
13 find it replaced automatically with the expansion of the abbrev.  This
14 saves typing.
16   The set of abbrevs currently in effect is recorded in an @dfn{abbrev
17 table}.  Each buffer has a local abbrev table, but normally all buffers
18 in the same major mode share one abbrev table.  There is also a global
19 abbrev table.  Normally both are used.
21   An abbrev table is represented as an obarray.  @xref{Creating
22 Symbols}, for information about obarrays.  Each abbreviation is
23 represented by a symbol in the obarray.  The symbol's name is the
24 abbreviation; its value is the expansion; its function definition is
25 the hook function for performing the expansion (@pxref{Defining
26 Abbrevs}); and its property list cell contains various additional
27 properties, including the use count and the number of times the
28 abbreviation has been expanded (@pxref{Abbrev Properties}).
30 @cindex system abbrev
31   Certain abbrevs, called @dfn{system abbrevs}, are defined by a major
32 mode instead of the user.  A system abbrev is identified by its
33 non-@code{nil} @code{:system} property (@pxref{Abbrev Properties}).
34 When abbrevs are saved to an abbrev file, system abbrevs are omitted.
35 @xref{Abbrev Files}.
37   Because the symbols used for abbrevs are not interned in the usual
38 obarray, they will never appear as the result of reading a Lisp
39 expression; in fact, normally they are never used except by the code
40 that handles abbrevs.  Therefore, it is safe to use them in a
41 nonstandard way.
43   If the minor mode Abbrev mode is enabled, the buffer-local variable
44 @code{abbrev-mode} is non-@code{nil}, and abbrevs are automatically
45 expanded in the buffer.  For the user-level commands for abbrevs, see
46 @ref{Abbrevs,, Abbrev Mode, emacs, The GNU Emacs Manual}.
48 @menu
49 * Tables: Abbrev Tables.        Creating and working with abbrev tables.
50 * Defining Abbrevs::            Specifying abbreviations and their expansions.
51 * Files: Abbrev Files.          Saving abbrevs in files.
52 * Expansion: Abbrev Expansion.  Controlling expansion; expansion subroutines.
53 * Standard Abbrev Tables::      Abbrev tables used by various major modes.
54 * Abbrev Properties::           How to read and set abbrev properties.
55                                 Which properties have which effect.
56 * Abbrev Table Properties::     How to read and set abbrev table properties.
57                                 Which properties have which effect.
58 @end menu
60 @node Abbrev Tables, Defining Abbrevs, Abbrevs, Abbrevs
61 @section Abbrev Tables
63   This section describes how to create and manipulate abbrev tables.
65 @defun make-abbrev-table &optional props
66 This function creates and returns a new, empty abbrev table---an
67 obarray containing no symbols.  It is a vector filled with zeros.
68 @var{props} is a property list that is applied to the new table
69 (@pxref{Abbrev Table Properties}).
70 @end defun
72 @defun abbrev-table-p object
73 This function returns a non-@code{nil} value if @var{object} is an
74 abbrev table.
75 @end defun
77 @defun clear-abbrev-table abbrev-table
78 This function undefines all the abbrevs in @var{abbrev-table}, leaving
79 it empty.
80 @c Don't see why this needs saying.
81 @c It always returns @code{nil}.
82 @end defun
84 @defun copy-abbrev-table abbrev-table
85 This function returns a copy of @var{abbrev-table}---a new abbrev
86 table containing the same abbrev definitions.  It does @emph{not} copy
87 any property lists; only the names, values, and functions.
88 @end defun
90 @defun define-abbrev-table tabname definitions &optional docstring &rest props
91 This function defines @var{tabname} (a symbol) as an abbrev table
92 name, i.e., as a variable whose value is an abbrev table.  It defines
93 abbrevs in the table according to @var{definitions}, a list of
94 elements of the form @code{(@var{abbrevname} @var{expansion}
95 [@var{hook}] [@var{props}...])}.  These elements are passed as
96 arguments to @code{define-abbrev}.  @c The return value is always @code{nil}.
98 The optional string @var{docstring} is the documentation string of the
99 variable @var{tabname}.  The property list @var{props} is applied to
100 the abbrev table (@pxref{Abbrev Table Properties}).
102 If this function is called more than once for the same @var{tabname},
103 subsequent calls add the definitions in @var{definitions} to
104 @var{tabname}, rather than overwriting the entire original contents.
105 (A subsequent call only overrides abbrevs explicitly redefined or
106 undefined in @var{definitions}.)
107 @end defun
109 @defvar abbrev-table-name-list
110 This is a list of symbols whose values are abbrev tables.
111 @code{define-abbrev-table} adds the new abbrev table name to this list.
112 @end defvar
114 @defun insert-abbrev-table-description name &optional human
115 This function inserts before point a description of the abbrev table
116 named @var{name}.  The argument @var{name} is a symbol whose value is an
117 abbrev table.  @c The return value is always @code{nil}.
119 If @var{human} is non-@code{nil}, the description is human-oriented.
120 System abbrevs are listed and identified as such.  Otherwise the
121 description is a Lisp expression---a call to @code{define-abbrev-table}
122 that would define @var{name} as it is currently defined, but without
123 the system abbrevs.  (The mode or package using @var{name} is supposed
124 to add these to @var{name} separately.)
125 @end defun
127 @node Defining Abbrevs, Abbrev Files, Abbrev Tables, Abbrevs
128 @comment  node-name,  next,  previous,  up
129 @section Defining Abbrevs
131   @code{define-abbrev} is the low-level basic function for defining an
132 abbrev in an abbrev table.
134   When a major mode defines a system abbrev, it should call
135 @code{define-abbrev} and specify @code{t} for the @code{:system}
136 property.  Be aware that any saved non-``system'' abbrevs are restored
137 at startup, i.e. before some major modes are loaded.  Therefore, major
138 modes should not assume that their abbrev tables are empty when they
139 are first loaded.
141 @defun define-abbrev abbrev-table name expansion &optional hook &rest props
142 This function defines an abbrev named @var{name}, in
143 @var{abbrev-table}, to expand to @var{expansion} and call @var{hook},
144 with properties @var{props} (@pxref{Abbrev Properties}).  The return
145 value is @var{name}.  The @code{:system} property in @var{props} is
146 treated specially here: if it has the value @code{force}, then it will
147 overwrite an existing definition even for a non-``system'' abbrev of
148 the same name.
150 @var{name} should be a string.  The argument @var{expansion} is
151 normally the desired expansion (a string), or @code{nil} to undefine
152 the abbrev.  If it is anything but a string or @code{nil}, then the
153 abbreviation ``expands'' solely by running @var{hook}.
155 The argument @var{hook} is a function or @code{nil}.  If @var{hook} is
156 non-@code{nil}, then it is called with no arguments after the abbrev is
157 replaced with @var{expansion}; point is located at the end of
158 @var{expansion} when @var{hook} is called.
160 @cindex @code{no-self-insert} property
161 If @var{hook} is a non-@code{nil} symbol whose @code{no-self-insert}
162 property is non-@code{nil}, @var{hook} can explicitly control whether
163 to insert the self-inserting input character that triggered the
164 expansion.  If @var{hook} returns non-@code{nil} in this case, that
165 inhibits insertion of the character.  By contrast, if @var{hook}
166 returns @code{nil}, @code{expand-abbrev} (or @code{abbrev-insert})
167 also returns @code{nil}, as if expansion had not really occurred.
169 Normally, @code{define-abbrev} sets the variable
170 @code{abbrevs-changed} to @code{t}, if it actually changes the abbrev.
171 This is so that some commands will offer to save the abbrevs.  It
172 does not do this for a system abbrev, since those aren't saved anyway.
173 @end defun
175 @defopt only-global-abbrevs
176 If this variable is non-@code{nil}, it means that the user plans to use
177 global abbrevs only.  This tells the commands that define mode-specific
178 abbrevs to define global ones instead.  This variable does not alter the
179 behavior of the functions in this section; it is examined by their
180 callers.
181 @end defopt
183 @node Abbrev Files, Abbrev Expansion, Defining Abbrevs, Abbrevs
184 @section Saving Abbrevs in Files
186   A file of saved abbrev definitions is actually a file of Lisp code.
187 The abbrevs are saved in the form of a Lisp program to define the same
188 abbrev tables with the same contents.  Therefore, you can load the file
189 with @code{load} (@pxref{How Programs Do Loading}).  However, the
190 function @code{quietly-read-abbrev-file} is provided as a more
191 convenient interface.  Emacs automatically calls this function at
192 startup.
194   User-level facilities such as @code{save-some-buffers} can save
195 abbrevs in a file automatically, under the control of variables
196 described here.
198 @defopt abbrev-file-name
199 This is the default file name for reading and saving abbrevs.
200 @end defopt
202 @defun quietly-read-abbrev-file &optional filename
203 This function reads abbrev definitions from a file named @var{filename},
204 previously written with @code{write-abbrev-file}.  If @var{filename} is
205 omitted or @code{nil}, the file specified in @code{abbrev-file-name} is
206 used.
208 As the name implies, this function does not display any messages.
209 @c It returns @code{nil}.
210 @end defun
212 @defopt save-abbrevs
213 A non-@code{nil} value for @code{save-abbrevs} means that Emacs should
214 offer to save abbrevs (if any have changed) when files are saved.  If
215 the value is @code{silently}, Emacs saves the abbrevs without asking
216 the user.  @code{abbrev-file-name} specifies the file to save the
217 abbrevs in.
218 @end defopt
220 @defvar abbrevs-changed
221 This variable is set non-@code{nil} by defining or altering any
222 abbrevs (except system abbrevs).  This serves as a flag for various
223 Emacs commands to offer to save your abbrevs.
224 @end defvar
226 @deffn Command write-abbrev-file &optional filename
227 Save all abbrev definitions (except system abbrevs), for all abbrev
228 tables listed in @code{abbrev-table-name-list}, in the file
229 @var{filename}, in the form of a Lisp program that when loaded will
230 define the same abbrevs.  If @var{filename} is @code{nil} or omitted,
231 @code{abbrev-file-name} is used.  This function returns @code{nil}.
232 @end deffn
234 @node Abbrev Expansion, Standard Abbrev Tables, Abbrev Files, Abbrevs
235 @comment  node-name,  next,  previous,  up
236 @section Looking Up and Expanding Abbreviations
238   Abbrevs are usually expanded by certain interactive commands,
239 including @code{self-insert-command}.  This section describes the
240 subroutines used in writing such commands, as well as the variables they
241 use for communication.
243 @defun abbrev-symbol abbrev &optional table
244 This function returns the symbol representing the abbrev named
245 @var{abbrev}.  It returns @code{nil} if that abbrev is not
246 defined.  The optional second argument @var{table} is the abbrev table
247 in which to look it up.  If @var{table} is @code{nil}, this function
248 tries first the current buffer's local abbrev table, and second the
249 global abbrev table.
250 @end defun
252 @defun abbrev-expansion abbrev &optional table
253 This function returns the string that @var{abbrev} would expand into (as
254 defined by the abbrev tables used for the current buffer).  It returns
255 @code{nil} if @var{abbrev} is not a valid abbrev.
256 The optional argument @var{table} specifies the abbrev table to use,
257 as in @code{abbrev-symbol}.
258 @end defun
260 @deffn Command expand-abbrev
261 This command expands the abbrev before point, if any.  If point does not
262 follow an abbrev, this command does nothing.  The command returns the
263 abbrev symbol if it did expansion, @code{nil} otherwise.
265 If the abbrev symbol has a hook function that is a symbol whose
266 @code{no-self-insert} property is non-@code{nil}, and if the hook
267 function returns @code{nil} as its value, then @code{expand-abbrev}
268 returns @code{nil} even though expansion did occur.
269 @end deffn
271 @defun abbrev-insert abbrev &optional name start end
272 This function inserts the abbrev expansion of @code{abbrev}, replacing
273 the text between @code{start} and @code{end}.  If @code{start} is
274 omitted, it defaults to point.  @code{name}, if non-@code{nil}, should
275 be the name by which this abbrev was found (a string); it is used to
276 figure out whether to adjust the capitalization of the expansion.  The
277 function returns @code{abbrev} if the abbrev was successfully
278 inserted.
279 @end defun
281 @deffn Command abbrev-prefix-mark &optional arg
282 This command marks the current location of point as the beginning of
283 an abbrev.  The next call to @code{expand-abbrev} will use the text
284 from here to point (where it is then) as the abbrev to expand, rather
285 than using the previous word as usual.
287 First, this command expands any abbrev before point, unless @var{arg}
288 is non-@code{nil}.  (Interactively, @var{arg} is the prefix argument.)
289 Then it inserts a hyphen before point, to indicate the start of the
290 next abbrev to be expanded.  The actual expansion removes the hyphen.
291 @end deffn
293 @defopt abbrev-all-caps
294 When this is set non-@code{nil}, an abbrev entered entirely in upper
295 case is expanded using all upper case.  Otherwise, an abbrev entered
296 entirely in upper case is expanded by capitalizing each word of the
297 expansion.
298 @end defopt
300 @defvar abbrev-start-location
301 The value of this variable is a buffer position (an integer or a marker)
302 for @code{expand-abbrev} to use as the start of the next abbrev to be
303 expanded.  The value can also be @code{nil}, which means to use the
304 word before point instead.  @code{abbrev-start-location} is set to
305 @code{nil} each time @code{expand-abbrev} is called.  This variable is
306 also set by @code{abbrev-prefix-mark}.
307 @end defvar
309 @defvar abbrev-start-location-buffer
310 The value of this variable is the buffer for which
311 @code{abbrev-start-location} has been set.  Trying to expand an abbrev
312 in any other buffer clears @code{abbrev-start-location}.  This variable
313 is set by @code{abbrev-prefix-mark}.
314 @end defvar
316 @defvar last-abbrev
317 This is the @code{abbrev-symbol} of the most recent abbrev expanded.  This
318 information is left by @code{expand-abbrev} for the sake of the
319 @code{unexpand-abbrev} command (@pxref{Expanding Abbrevs,, Expanding
320 Abbrevs, emacs, The GNU Emacs Manual}).
321 @end defvar
323 @defvar last-abbrev-location
324 This is the location of the most recent abbrev expanded.  This contains
325 information left by @code{expand-abbrev} for the sake of the
326 @code{unexpand-abbrev} command.
327 @end defvar
329 @defvar last-abbrev-text
330 This is the exact expansion text of the most recent abbrev expanded,
331 after case conversion (if any).  Its value is @code{nil} if the abbrev
332 has already been unexpanded.  This contains information left by
333 @code{expand-abbrev} for the sake of the @code{unexpand-abbrev} command.
334 @end defvar
336 @defvar abbrev-expand-functions
337 This is a wrapper hook (@pxref{Running Hooks}) run around the
338 @code{expand-abbrev} function.  Each function on this hook is called
339 with a single argument: a function that performs the normal abbrev
340 expansion.  The hook function can hence do anything it wants before
341 and after performing the expansion.  It can also choose not to call
342 its argument, thus overriding the default behavior; or it may even
343 call it several times.  The function should return the abbrev symbol
344 if expansion took place.
345 @end defvar
347   The following sample code shows a simple use of
348 @code{abbrev-expand-functions}.  It assumes that @code{foo-mode} is a
349 mode for editing certain files in which lines that start with @samp{#}
350 are comments.  You want to use Text mode abbrevs for those lines.  The
351 regular local abbrev table, @code{foo-mode-abbrev-table} is
352 appropriate for all other lines.  @xref{Standard Abbrev Tables}, for the
353 definitions of @code{local-abbrev-table} and @code{text-mode-abbrev-table}.
355 @smallexample
356 (defun foo-mode-abbrev-expand-function (expand)
357   (if (not (save-excursion (forward-line 0) (eq (char-after) ?#)))
358       ;; Performs normal expansion.
359       (funcall expand)
360     ;; We're inside a comment: use the text-mode abbrevs.
361     (let ((local-abbrev-table text-mode-abbrev-table))
362       (funcall expand))))
364 (add-hook 'foo-mode-hook
365           #'(lambda ()
366               (add-hook 'abbrev-expand-functions
367                         'foo-mode-abbrev-expand-function
368                         nil t)))
369 @end smallexample
371 @node Standard Abbrev Tables, Abbrev Properties, Abbrev Expansion, Abbrevs
372 @comment  node-name,  next,  previous,  up
373 @section Standard Abbrev Tables
375   Here we list the variables that hold the abbrev tables for the
376 preloaded major modes of Emacs.
378 @defvar global-abbrev-table
379 This is the abbrev table for mode-independent abbrevs.  The abbrevs
380 defined in it apply to all buffers.  Each buffer may also have a local
381 abbrev table, whose abbrev definitions take precedence over those in the
382 global table.
383 @end defvar
385 @defvar local-abbrev-table
386 The value of this buffer-local variable is the (mode-specific)
387 abbreviation table of the current buffer.  It can also be a list of
388 such tables.
389 @end defvar
391 @defvar abbrev-minor-mode-table-alist
392 The value of this variable is a list of elements of the form
393 @code{(@var{mode} . @var{abbrev-table})} where @var{mode} is the name
394 of a variable: if the variable is bound to a non-@code{nil} value,
395 then the @var{abbrev-table} is active, otherwise it is ignored.
396 @var{abbrev-table} can also be a list of abbrev tables.
397 @end defvar
399 @defvar fundamental-mode-abbrev-table
400 This is the local abbrev table used in Fundamental mode; in other words,
401 it is the local abbrev table in all buffers in Fundamental mode.
402 @end defvar
404 @defvar text-mode-abbrev-table
405 This is the local abbrev table used in Text mode.
406 @end defvar
408 @defvar lisp-mode-abbrev-table
409 This is the local abbrev table used in Lisp mode.  It is the parent
410 of the local abbrev table used in Emacs Lisp mode.  @xref{Abbrev Table
411 Properties}.
412 @end defvar
414 @node Abbrev Properties, Abbrev Table Properties, Standard Abbrev Tables, Abbrevs
415 @section Abbrev Properties
417 Abbrevs have properties, some of which influence the way they work.
418 You can provide them as arguments to @code{define-abbrev}, and
419 manipulate them with the following functions:
421 @defun abbrev-put abbrev prop val
422 Set the property @var{prop} of @var{abbrev} to value @var{val}.
423 @end defun
425 @defun abbrev-get abbrev prop
426 Return the property @var{prop} of @var{abbrev}, or @code{nil} if the
427 abbrev has no such property.
428 @end defun
430 The following properties have special meanings:
432 @table @code
433 @item :count
434 This property counts the number of times the abbrev has
435 been expanded.  If not explicitly set, it is initialized to 0 by
436 @code{define-abbrev}.
438 @item :system
439 If non-@code{nil}, this property marks the abbrev as a system abbrev.
440 Such abbrevs are not saved (@pxref{Abbrev Files}).
442 @item :enable-function
443 If non-@code{nil}, this property should be a function of no
444 arguments which returns @code{nil} if the abbrev should not be used
445 and @code{t} otherwise.
447 @item :case-fixed
448 If non-@code{nil}, this property indicates that the case of the
449 abbrev's name is significant and should only match a text with the
450 same pattern of capitalization.  It also disables the code that
451 modifies the capitalization of the expansion.
452 @end table
454 @node Abbrev Table Properties,  , Abbrev Properties, Abbrevs
455 @section Abbrev Table Properties
457 Like abbrevs, abbrev tables have properties, some of which influence
458 the way they work.  You can provide them as arguments to
459 @code{define-abbrev-table}, and manipulate them with the functions:
461 @defun abbrev-table-put table prop val
462 Set the property @var{prop} of abbrev table @var{table} to value @var{val}.
463 @end defun
465 @defun abbrev-table-get table prop
466 Return the property @var{prop} of abbrev table @var{table}, or @code{nil}
467 if the abbrev has no such property.
468 @end defun
470 The following properties have special meaning:
472 @table @code
473 @item :enable-function
474 This is like the @code{:enable-function} abbrev property except that
475 it applies to all abbrevs in the table.  It is used before even trying
476 to find the abbrev before point, so it can dynamically modify the
477 abbrev table.
479 @item :case-fixed
480 This is like the @code{:case-fixed} abbrev property except that it
481 applies to all abbrevs in the table.
483 @item :regexp
484 If non-@code{nil}, this property is a regular expression that
485 indicates how to extract the name of the abbrev before point, before
486 looking it up in the table.  When the regular expression matches
487 before point, the abbrev name is expected to be in submatch 1.
488 If this property is @code{nil}, the default is to use
489 @code{backward-word} and @code{forward-word} to find the name.  This
490 property allows the use of abbrevs whose name contains characters of
491 non-word syntax.
493 @item :parents
494 This property holds a list of tables from which to inherit
495 other abbrevs.
497 @item :abbrev-table-modiff
498 This property holds a counter incremented each time a new abbrev is
499 added to the table.
501 @end table