Next: Invoking the Debugger Prev: Using Debugger Up: Debugger
Inside the debugger (in Debugger mode), these special commands are
available in addition to the usual cursor motion commands. (Keep in
mind that all the usual facilities of Emacs, such as switching windows
or buffers, are still available.)
The most important use of debugger commands is for stepping through
code, so that you can see how control flows. The debugger can step
through the control structures of an interpreted function, but cannot do
so in a byte-compiled function. If you would like to step through a
byte-compiled function, replace it with an interpreted definition of the
same function. (To do this, visit the source file for the function and
type `C-M-x' on its definition.)
Exit the debugger and continue execution. When continuing is
possible, it resumes execution of the program as if the debugger
had never been entered (aside from the effect of any variables or
data structures you may have changed while inside the debugger).
Continuing is possible after entry to the debugger due to function
entry or exit, explicit invocation, quitting or certain errors.
Most errors cannot be continued; trying to continue an unsuitable
error causes the same error to occur again.
Continue execution, but enter the debugger the next time any Lisp
function is called. This allows you to step through the
subexpressions of an expression, seeing what values the
subexpressions compute, and what else they do.
The stack frame made for the function call which enters the
debugger in this way will be flagged automatically so that the
debugger will be called again when the frame is exited. You can
use the `u' command to cancel this flag.
Flag the current frame so that the debugger will be entered when
the frame is exited. Frames flagged in this way are marked with
stars in the backtrace buffer.
Don't enter the debugger when the current frame is exited. This
cancels a `b' command on that frame.
Read a Lisp expression in the minibuffer, evaluate it, and print
the value in the echo area. This is the same as the command
`M-ESC', except that `e' is not normally disabled like `M-ESC'.
Terminate the program being debugged; return to top-level Emacs
If the debugger was entered due to a `C-g' but you really want to
quit, and not debug, use the `q' command.
Return a value from the debugger. The value is computed by
reading an expression with the minibuffer and evaluating it.
The `r' command makes a difference when the debugger was invoked
due to exit from a Lisp call frame (as requested with `b'); then
the value specified in the `r' command is used as the value of that
You can't use `r' when the debugger was entered due to an error.
automatically generated by info2www