forked from okuoku/xitomatl
-
Notifications
You must be signed in to change notification settings - Fork 1
/
debug.sls
60 lines (53 loc) · 1.81 KB
/
debug.sls
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#!r6rs
;; Copyright 2009 Derick Eddington. My MIT-style license is in the file named
;; LICENSE from the original collection this file is distributed with.
(library (xitomatl debug)
(export
dprint dprint-mark
eprint eprint-mark
format printf fprintf pretty-print
print-exception print-condition)
(import
(rnrs)
(srfi :39 parameters)
(only (xitomatl common) format printf fprintf pretty-print)
(only (xitomatl exceptions) print-exception reraise)
(only (xitomatl conditions) print-condition))
(define dprint-mark (make-parameter "***"))
(define-syntax dprint
(lambda (stx)
(syntax-case stx ()
((_ expr ...)
(positive? (length #'(expr ...)))
#'(let ((cep (current-error-port))
(mark (dprint-mark)))
(fprintf cep "~a\n" mark)
(let-values ((vs expr))
(pretty-print 'expr cep) ;; does newline
(display "=>\n" cep)
(for-each (lambda (v) (pretty-print v cep))
vs)
(fprintf cep "~a\n" mark)
(apply values vs))
...)))))
(define eprint-mark (make-parameter "***"))
(define (print-exn exn)
(let ((cep (current-error-port))
(mark (eprint-mark)))
(fprintf cep "~a\n" mark)
(print-exception exn cep)
(fprintf cep "~a\n" mark)
(reraise exn)))
(define-syntax eprint
(lambda (stx)
(syntax-case stx ()
((_ expr ...)
(positive? (length #'(expr ...)))
#'(begin
;; TODO: Why the let-values?
(let-values ((vs (with-exception-handler
print-exn
(lambda () #F expr))))
(apply values vs))
...)))))
)