From: Richard M. Stallman Date: Mon, 17 Jul 2006 21:07:20 +0000 (+0000) Subject: (Processing of Errors): Add command-error-function. X-Git-Tag: emacs-pretest-22.0.90~1398 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=27ddcc192f668cc32cc4ee0560e5179793c4b125;p=emacs.git (Processing of Errors): Add command-error-function. --- diff --git a/lispref/control.texi b/lispref/control.texi index cabadb3b8dc..83bce85e0b3 100644 --- a/lispref/control.texi +++ b/lispref/control.texi @@ -849,11 +849,22 @@ executes in the environment of the @code{condition-case} that established it; all functions called within that @code{condition-case} have already been exited, and the handler cannot return to them. -If there is no applicable handler for the error, the current command is -terminated and control returns to the editor command loop, because the -command loop has an implicit handler for all kinds of errors. The +If there is no applicable handler for the error, it terminates the +current command and returns control to the editor command loop. (The +command loop has an implicit handler for all kinds of errors.) The command loop's handler uses the error symbol and associated data to -print an error message. +print an error message. You can use the variable +@code{command-error-function} to control how this is done: + +@defvar command-error-function +This variable, if non-@code{nil}, specifies a function to use to +handle errors that return control to the Emacs command loop. The +function should take three arguments: @var{data}, a list of the same +form that @code{condition-case} would bind to its variable; +@var{context}, a string describing the situation in which the error +occurred, or (more often) @code{nil}; and @code{caller}, the Lisp +function which called the primitive that signaled the error. +@end defvar @cindex @code{debug-on-error} use An error that has no explicit handler may call the Lisp debugger. The