emacs-elpa-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[nongnu] elpa/geiser-guile 44f40a6db6 1/2: new option geiser-guile-debug


From: ELPA Syncer
Subject: [nongnu] elpa/geiser-guile 44f40a6db6 1/2: new option geiser-guile-debug-backwards-backtrace
Date: Wed, 21 Sep 2022 08:58:55 -0400 (EDT)

branch: elpa/geiser-guile
commit 44f40a6db656e4c33ce7b42099d3c09073c2c2b8
Author: jao <jao@gnu.org>
Commit: jao <jao@gnu.org>

    new option geiser-guile-debug-backwards-backtrace
    
    Fixes #22
---
 geiser-guile.el | 10 ++++++++++
 1 file changed, 10 insertions(+)

diff --git a/geiser-guile.el b/geiser-guile.el
index 273e1970d3..e5f6476517 100644
--- a/geiser-guile.el
+++ b/geiser-guile.el
@@ -84,6 +84,10 @@ exported modules."
 If nil, only the last frame is shown."
   :type 'boolean)
 
+(geiser-custom--defcustom geiser-guile-debug-backwards-backtrace t
+  "Whether to configure backtraces using the 'backwards' ordering."
+  :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)
@@ -497,6 +501,11 @@ See `geiser-guile-use-declarative-modules-p'."
     (let ((code '(begin (eval-when (expand) (user-modules-declarative? :f)) 
'ok)))
       (geiser-eval--send/wait code))))
 
+(defun geiser-guile--set-up-backtrace ()
+  "Set up Guile's backtrace ordering."
+  (when geiser-guile-debug-backwards-backtrace
+    (geiser-eval--send/wait '(debug-enable 'backwards))))
+
 (defun geiser-guile--startup (remote)
   "Startup function, for a remote connection if REMOTE is t."
   (geiser-guile--set-up-error-links)
@@ -507,6 +516,7 @@ See `geiser-guile-use-declarative-modules-p'."
     (when (or geiser-guile--conn-address remote)
       (geiser-guile--set-geiser-load-path))
     (geiser-guile--set-up-declarative-modules)
+    (geiser-guile--set-up-backtrace)
     (geiser-eval--send/wait ",use (geiser emacs)\n'done")
     (dolist (dir g-load-path)
       (let ((dir (expand-file-name dir)))



reply via email to

[Prev in Thread] Current Thread [Next in Thread]