From 17d1ba2164223242048c6eebd5ebba2b6cf4c83b Mon Sep 17 00:00:00 2001 From: Lockywolf Date: Mon, 19 Aug 2019 23:52:11 +0800 Subject: Rewrite geiser:eval in order to make it compatible with org-babel. * Add an additional guard construction to geiser:eval in order to catch unexpected I/O errors. --- scheme/chibi/geiser/geiser.scm | 30 ++++++++++++++++-------------- 1 file changed, 16 insertions(+), 14 deletions(-) (limited to 'scheme/chibi') diff --git a/scheme/chibi/geiser/geiser.scm b/scheme/chibi/geiser/geiser.scm index 35a52b7..f12cbfc 100644 --- a/scheme/chibi/geiser/geiser.scm +++ b/scheme/chibi/geiser/geiser.scm @@ -30,27 +30,29 @@ ;;> the result of evaluation \scheme{(write)}'d and the second ;;> field, \scheme{output}, contains everyting that the evaluation ;;> would print to the standard output. +;;> In case of an exception, the message is formatted with +;;> \scheme{(chibi show)} and written to both variables in addition +;;> to whatever was already there. (define (geiser:eval module form . rest) rest (guard (err (else - ;; TODO:We need to save output when returning errors too. The - ;; output may very well be produced before an error occurs. But to - ;; implement it wisely, we probably need something like two guard - ;; expressions. For example, org-mode's ob-scheme.el needs it.:END - - (write `((result ,(show #f err)))))) + (write ; to standard output + "Geiser-chibi falure in scheme code.") + (show #t err))) (let* ((output (open-output-string)) (result (parameterize ((current-output-port output)) - (if module - (let ((mod (module-env (find-module module)))) - (eval form mod)) - (eval form)) - ) - )) - (write `((result ,(write-to-string result)) - (output . ,(get-output-string output)))))) + (guard (err + (else (show #t err) + (write-to-string (show #f err)))) + (if module + (let ((mod (module-env (find-module module)))) + (eval form mod)) + (eval form)))))) + (write ; to standard output (to comint) + `((result ,(write-to-string result)) + (output . ,(get-output-string output)))))) (values)) -- cgit v1.2.3