diff options
| -rw-r--r-- | geiser-guile.el | 13 | 
1 files changed, 12 insertions, 1 deletions
| diff --git a/geiser-guile.el b/geiser-guile.el index 5069f92..f2d6f2a 100644 --- a/geiser-guile.el +++ b/geiser-guile.el @@ -83,6 +83,10 @@ exported modules."  If nil, only the last frame is shown."    :type 'boolean) +(geiser-custom--defcustom geiser-guile-debug-show-full-bt-p t +  "Whether to show full backtraces in the debugger, including local variables." +  :type 'boolean) +  (geiser-custom--defcustom geiser-guile-show-debug-help-p t    "Whether to show brief help in the echo area when entering the debugger."    :type 'boolean) @@ -179,6 +183,13 @@ This function uses `geiser-guile-init-file' if it exists."    "Concatenate the list ARGS."    (mapconcat 'identity args " ")) +(defun geiser-guile--debug-cmd (args) +  (let ((args (if (and geiser-guile-debug-show-full-bt-p +                       (string= (car args) "backtrace")) +                  '("backtrace" "#:full?" "#t") +                args))) +    (concat "," (geiser-guile--linearize-args args) "\n\"\""))) +  (defun geiser-guile--geiser-procedure (proc &rest args)    "Transform PROC in string for a scheme procedure using ARGS."    (cl-case proc @@ -188,7 +199,7 @@ This function uses `geiser-guile-init-file' if it exists."                              (if (cddr args) "" " ()")))      ((load-file compile-file) (format ",geiser-load-file %s" (car args)))      ((no-values) ",geiser-no-values") -    ((debug) (concat "," (geiser-guile--linearize-args args) "\n\"\"")) +    ((debug) (geiser-guile--debug-cmd args))      (t (format "ge:%s (%s)" proc (geiser-guile--linearize-args args)))))  (defun geiser-guile--clean-up-output (str) | 
