Function: edebug-mode
edebug-mode is an interactive and byte-compiled function defined in
edebug.el.gz.
Signature
(edebug-mode &optional ARG)
Documentation
Mode for Emacs Lisp buffers while in Edebug.
This is a minor mode. If called interactively, toggle the Edebug
mode mode. If the prefix argument is positive, enable the mode, and
if it is zero or negative, disable the mode.
If called from Lisp, toggle the mode if ARG is toggle. Enable the
mode if ARG is nil, omitted, or is a positive number. Disable the
mode if ARG is a negative number.
To check whether the minor mode is enabled in the current buffer,
evaluate edebug-mode(var)/edebug-mode(fun).
The mode's hook is called both when the mode is enabled and when it is disabled.
In addition to all Emacs Lisp commands (except those that modify the
buffer) there are local and global key bindings to several Edebug
specific commands. E.g. edebug-step-mode is bound to C-x X SPC (edebug-step-mode)
in the Edebug buffer and C-x X SPC (edebug-step-mode) in any buffer.
Also see bindings for the eval list buffer *edebug* in edebug-eval-mode.
The edebug buffer commands:
- negative-argument
<intercept-state> all
= edebug-temp-display-freq-count
? edebug-help
B edebug-next-breakpoint
C edebug-Continue-fast-mode
C-M-i completion-at-point
C-M-q indent-pp-sexp
C-M-q indent-sexp
C-M-q prog-indent-sexp
C-M-x eval-defun
C-c C-c edebug-go-mode
C-c C-d edebug-unset-breakpoint
C-c C-l edebug-where
C-c C-n edebug-next-mode
C-c C-s edebug-step-mode
C-c C-t #<anonymous-function>
C-x C-a C-c edebug-go-mode
C-x C-a C-l edebug-where
C-x C-a C-n edebug-next-mode
C-x C-a C-s edebug-step-mode
C-x C-a RET edebug-set-initial-mode
C-x C-e edebug-eval-last-sexp
C-x SPC edebug-set-breakpoint
D edebug-toggle-disable-breakpoint
DEL backward-delete-char-untabify
E edebug-visit-eval-list
G edebug-Go-nonstop-mode
I edebug-instrument-callee
P edebug-view-outside
Q edebug-top-level-nonstop
S edebug-stop
SPC edebug-step-mode
T edebug-Trace-fast-mode
U edebug-unset-breakpoints
W edebug-toggle-save-windows
X edebug-set-global-break-condition
a abort-recursive-edit
b edebug-set-breakpoint
c edebug-continue-mode
d edebug-pop-to-backtrace
e edebug-eval-expression
f edebug-forward-sexp
g edebug-go-mode
h edebug-goto-here
i edebug-step-in
n edebug-next-mode
o edebug-step-out
p edebug-bounce-point
q top-level(var)/top-level(fun)
r edebug-previous-result(var)/edebug-previous-result(fun)
t edebug-trace-mode
u edebug-unset-breakpoint
v edebug-view-outside
w edebug-where
x edebug-set-conditional-breakpoint
Global commands prefixed by edebug-global-prefix:
= edebug-display-freq-count
C edebug-Continue-fast-mode
D edebug-toggle-disable-breakpoint
G edebug-Go-nonstop-mode
Q edebug-top-level-nonstop
SPC edebug-step-mode
T edebug-Trace-fast-mode
U edebug-unset-breakpoints
W edebug-toggle-save-windows
X edebug-set-global-break-condition
a abort-recursive-edit
b edebug-set-breakpoint
c edebug-continue-mode
g edebug-go-mode
q top-level(var)/top-level(fun)
t edebug-trace-mode
u edebug-unset-breakpoint
w edebug-where
x edebug-set-conditional-breakpoint
Options:
edebug-setup-hook
edebug-all-defs(var)/edebug-all-defs(fun)
edebug-all-forms(var)/edebug-all-forms(fun)
edebug-save-windows
edebug-save-displayed-buffer-points
edebug-initial-mode
edebug-trace(var)/edebug-trace(fun)
edebug-test-coverage
edebug-continue-kbd-macro
edebug-print-length
edebug-print-level
edebug-print-circle
edebug-on-error
edebug-on-quit
edebug-unwrap-results
edebug-global-break-condition
Probably introduced at or before Emacs version 27.1.
Key Bindings
Source Code
;; Defined in /usr/src/emacs/lisp/emacs-lisp/edebug.el.gz
(define-minor-mode edebug-mode
"Mode for Emacs Lisp buffers while in Edebug.
In addition to all Emacs Lisp commands (except those that modify the
buffer) there are local and global key bindings to several Edebug
specific commands. E.g. `edebug-step-mode' is bound to \\[edebug-step-mode]
in the Edebug buffer and \\<global-map>\\[edebug-step-mode] in any buffer.
Also see bindings for the eval list buffer *edebug* in `edebug-eval-mode'.
The edebug buffer commands:
\\{edebug-mode-map}
Global commands prefixed by `edebug-global-prefix':
\\{edebug-global-map}
Options:
`edebug-setup-hook'
`edebug-all-defs'
`edebug-all-forms'
`edebug-save-windows'
`edebug-save-displayed-buffer-points'
`edebug-initial-mode'
`edebug-trace'
`edebug-test-coverage'
`edebug-continue-kbd-macro'
`edebug-print-length'
`edebug-print-level'
`edebug-print-circle'
`edebug-on-error'
`edebug-on-quit'
`edebug-unwrap-results'
`edebug-global-break-condition'"
:lighter " *Debugging*"
:keymap edebug-mode-map
;; If the user kills the buffer in which edebug is currently active,
;; exit to top level, because the edebug command loop can't usefully
;; continue running in such a case.
;;
(if (not edebug-mode)
(progn
(while edebug--mode-saved-vars
(let ((setting (pop edebug--mode-saved-vars)))
(if (consp setting)
(set (car setting) (cdr setting))
(kill-local-variable setting))))
(remove-hook 'kill-buffer-hook #'edebug-kill-buffer t))
(pcase-dolist (`(,var . ,val) '((buffer-read-only . t)))
(push
(if (local-variable-p var) (cons var (symbol-value var)) var)
edebug--mode-saved-vars)
(set (make-local-variable var) val))
;; Append `edebug-kill-buffer' to the hook to avoid interfering with
;; other entries that are unguarded against deleted buffer.
(add-hook 'kill-buffer-hook #'edebug-kill-buffer t t)))