Return more information on tracebacks
author |
Steve Losh <steve@stevelosh.com> |
date |
Sun, 21 Aug 2016 15:26:37 +0000 (2016-08-21) |
parents |
256edcc8ea1e
|
children |
330b6240a25c
|
branches/tags |
(none) |
files |
.hgignore src/evaluation.lisp |
Changes
--- a/.hgignore Sun Aug 21 13:34:46 2016 +0000
+++ b/.hgignore Sun Aug 21 15:26:37 2016 +0000
@@ -6,3 +6,4 @@
*.un~
tags
scratch.lisp
+*.fasl
--- a/src/evaluation.lisp Sun Aug 21 13:34:46 2016 +0000
+++ b/src/evaluation.lisp Sun Aug 21 15:26:37 2016 +0000
@@ -64,13 +64,28 @@
(defun parse-frame (frame)
- (list* (dissect:call frame) (dissect:args frame)))
+ (let ((call-form (list* (dissect:call frame) (dissect:args frame)))
+ (location (list (dissect:file frame) (dissect:line frame))))
+ (list call-form location)))
(defun parse-stack (stack)
(mapcar #'parse-frame (nthcdr 1 (reverse stack))))
-(defun string-trace (stack)
- (format nil "~{~S~^~%~}" (parse-stack stack)))
+(defun string-trace-whole (trace)
+ (with-output-to-string (s)
+ (loop :for (call-form (file line)) :in trace
+ :do (format s "~S~%" call-form))))
+
+(defun string-trace-components (trace)
+ (loop :for (call-form (file line)) :in trace
+ :collect (list (format nil "~S" call-form)
+ (if file
+ (format nil "~A" file)
+ "")
+ (if line
+ (format nil "~D" line)
+ ""))))
+
(defun nrepl-evaluate-form (form)
(declare (optimize (debug 3)))
@@ -83,11 +98,13 @@
(error 'evaluation-error
:text "Error during evaluation!"
:orig err
- :data (let ((trace (dissect:stack)))
- (setf *last-trace* trace)
+ :data (let* ((raw (dissect:stack))
+ (clean (parse-stack raw)))
+ (setf *last-trace* raw)
(list
"form" (prin1-to-string form)
- "backtrace" (string-trace trace)))))))
+ "stack-trace" (string-trace-components clean)
+ "stack-trace-string" (string-trace-whole clean)))))))
(dissect:with-truncated-stack ()
(eval form)))))