2 @c This is part of the GNU Emacs Lisp Reference Manual.
3 @c Copyright (C) 1990-1993, 1999, 2001-2012 Free Software Foundation, Inc.
4 @c See the file elisp.texi for copying conditions.
5 @setfilename ../../info/errors
6 @node Standard Errors, Standard Keymaps, GNU Emacs Internals, Top
7 @appendix Standard Errors
8 @cindex standard errors
10 Here is a list of the more important error symbols in standard Emacs,
11 grouped by concept. The list includes each symbol's message (on the
12 @code{error-message} property of the symbol) and a cross reference to a
13 description of how the error can occur.
15 Each error symbol has an @code{error-conditions} property that is a
16 list of symbols. Normally this list includes the error symbol itself
17 and the symbol @code{error}. Occasionally it includes additional
18 symbols, which are intermediate classifications, narrower than
19 @code{error} but broader than a single error symbol. For example, all
20 the errors in accessing files have the condition @code{file-error}. If
21 we do not say here that a certain error symbol has additional error
22 conditions, that means it has none.
24 As a special exception, the error symbol @code{quit} does not have the
25 condition @code{error}, because quitting is not considered an error.
27 @c You can grep for "(put 'foo 'error-conditions ...) to find
28 @c examples defined in Lisp. Eg soap-client.el, sasl.el.
29 Most of these error symbols are defined in C (mainly @file{data.c}),
30 but some are defined in Lisp. For example, the file @file{userlock.el}
31 defines the @code{file-locked} and @code{file-supersession} errors.
32 Several of the specialized Lisp libraries distributed with Emacs
33 define their own error symbols. We do not attempt to list of all
36 @xref{Errors}, for an explanation of how errors are generated and
48 @item args-out-of-range
49 @code{"Args out of range"}@*
50 This happens when trying to access an element beyond the range of a
52 @xref{Sequences Arrays Vectors}, @xref{Text}.
55 @code{"Arithmetic error"}@*
56 @xref{Arithmetic Operations}.
58 @item beginning-of-buffer
59 @code{"Beginning of buffer"}@*
60 @xref{Character Motion}.
62 @item buffer-read-only
63 @code{"Buffer is read-only"}@*
64 @xref{Read Only Buffers}.
67 @code{"List contains a loop"}@*
68 This happens when some operations (e.g. resolving face names)
69 encounter circular structures.@*
70 @xref{Circular Objects}.
72 @item cl-assertion-failed
73 @code{"Assertion failed"}@*
74 This happens when the @code{assert} macro fails a test.@*
75 @xref{Assertions,,, cl, Common Lisp Extensions}.
77 @item coding-system-error
78 @code{"Invalid coding system"}@*
79 @xref{Lisp and Coding Systems}.
81 @item cyclic-function-indirection
82 @code{"Symbol's chain of function indirections contains a loop"}@*
83 @xref{Function Indirection}.
85 @item cyclic-variable-indirection
86 @code{"Symbol's chain of variable indirections contains a loop"}@*
87 @xref{Variable Aliases}.
90 @code{"D-Bus error"}@*
91 This is only defined if Emacs was compiled with D-Bus support.@*
92 @xref{Errors and Events,,, dbus, D-Bus integration in Emacs}.
95 @code{"End of buffer"}@*
96 @xref{Character Motion}.
99 @code{"End of file during parsing"}@*
100 Note that this is not a subcategory of @code{file-error},
101 because it pertains to the Lisp reader, not to file I/O.@*
102 @xref{Input Functions}.
104 @item file-already-exists
105 This is a subcategory of @code{file-error}.@*
106 @xref{Writing to Files}.
108 @item file-date-error
109 This is a subcategory of @code{file-error}. It occurs when
110 @code{copy-file} tries and fails to set the last-modification time of
112 @xref{Changing Files}.
115 We do not list the error-strings of this error and its subcategories,
116 because the error message is normally constructed from the data items
117 alone when the error condition @code{file-error} is present. Thus,
118 the error-strings are not very relevant. However, these error symbols
119 do have @code{error-message} properties, and if no data is provided,
120 the @code{error-message} property @emph{is} used.@*
124 @item compression-error
125 This is a subcategory of @code{file-error}, which results from
126 problems handling a compressed file.@*
127 @xref{How Programs Do Loading}.
131 This is a subcategory of @code{file-error}.@*
135 @item file-supersession
136 This is a subcategory of @code{file-error}.@*
137 @xref{Modification Time}.
141 This is a subcategory of @code{file-error}, which results from problems
142 in accessing a remote file using ftp.@*
143 @xref{Remote Files,,, emacs, The GNU Emacs Manual}.
145 @item invalid-function
146 @code{"Invalid function"}@*
147 @xref{Function Indirection}.
149 @item invalid-read-syntax
150 @code{"Invalid read syntax"}@*
151 @xref{Printed Representation}.
154 @code{"Invalid regexp"}@*
155 @xref{Regular Expressions}.
159 @code{"The mark is not active now"}@*
163 @code{"No catch for tag"}@*
164 @xref{Catch and Throw}.
167 @c Not actually used for anything? Probably definition should be removed.
168 @item protected-field
169 @code{"Attempt to modify a protected field"}
173 @code{"Scan error"}@*
174 This happens when certain syntax-parsing functions
175 find invalid syntax or mismatched parentheses.@*
176 @xref{List Motion}, and @ref{Parsing Expressions}.
179 @code{"Search failed"}@*
180 @xref{Searching and Matching}.
182 @item setting-constant
183 @code{"Attempt to set a constant symbol"}@*
184 The values of the symbols @code{nil} and @code{t},
185 and any symbols that start with @samp{:},
186 may not be changed.@*
187 @xref{Constant Variables, , Variables that Never Change}.
191 @code{"Text is read-only"}@*
192 This is a subcategory of @code{buffer-read-only}.@*
193 @xref{Special Properties}.
195 @item undefined-color
196 @code{"Undefined color"}@*
200 @code{"Symbol's function definition is void"}@*
201 @xref{Function Cells}.
204 @code{"Symbol's value as variable is void"}@*
205 @xref{Accessing Variables}.
207 @item wrong-number-of-arguments
208 @code{"Wrong number of arguments"}@*
209 @xref{Classifying Lists}.
211 @item wrong-type-argument
212 @code{"Wrong type argument"}@*
213 @xref{Type Predicates}.
216 The following kinds of error, which are classified as special cases of
217 @code{arith-error}, can occur on certain systems for invalid use of
218 mathematical functions. @xref{Math Functions}.
222 @code{"Arithmetic domain error"}
225 @code{"Arithmetic overflow error"}@*
226 This is a subcategory of @code{domain-error}.
229 @code{"Arithmetic range error"}
231 @item singularity-error
232 @code{"Arithmetic singularity error"}@*
233 This is a subcategory of @code{domain-error}.
235 @item underflow-error
236 @code{"Arithmetic underflow error"}@*
237 This is a subcategory of @code{domain-error}.