diff options
author | Jose Antonio Ortega Ruiz <jao@gnu.org> | 2009-09-23 18:03:52 +0200 |
---|---|---|
committer | Jose Antonio Ortega Ruiz <jao@gnu.org> | 2009-09-23 18:03:52 +0200 |
commit | ed48236fe7c336924ff4694275555649e9b269b5 (patch) | |
tree | 033c3c46a4ec36f4185834d65a861e6812ad653b /scheme/guile | |
parent | 46d6d573013661b3266ca3d0bd77b8a26a738eef (diff) | |
download | geiser-chez-ed48236fe7c336924ff4694275555649e9b269b5.tar.gz geiser-chez-ed48236fe7c336924ff4694275555649e9b269b5.tar.bz2 |
Guile: bug fix: evaluation works again (1.9.3 or better required).
Diffstat (limited to 'scheme/guile')
-rw-r--r-- | scheme/guile/geiser/evaluation.scm | 22 |
1 files changed, 7 insertions, 15 deletions
diff --git a/scheme/guile/geiser/evaluation.scm b/scheme/guile/geiser/evaluation.scm index 642c185..3e44834 100644 --- a/scheme/guile/geiser/evaluation.scm +++ b/scheme/guile/geiser/evaluation.scm @@ -38,29 +38,21 @@ (current-module))) (result #f) (captured-stack #f) - (error #f) + (err #f) (ev (lambda () - (save-module-excursion - (lambda () - (set-current-module module) - (set! result (call-with-values - (lambda () (compile form)) - (lambda vs - (map (lambda (v) - (with-output-to-string - (lambda () (write v)))) - vs))))))))) + (set! result (call-with-values + (lambda () (compile form #:env module)) + (lambda vs (map object->string vs))))))) (let ((output (with-output-to-string (lambda () (catch #t (lambda () (start-stack 'geiser-eval (ev))) (lambda args - (set! error #t) - (apply handle-error captured-stack args)) + (set! err (apply handle-error captured-stack args))) (lambda args - (set! captured-stack (make-stack #t 2 15)))))))) - (write `(,(if error result (cons 'result result)) + (set! captured-stack (make-stack #t 2 7)))))))) + (write `(,(or err (cons 'result result)) (output . ,output))) (newline)))) |