-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgps-debugger.lisp
25 lines (21 loc) · 903 Bytes
/
gps-debugger.lisp
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
(defvar *dbg-ids* nil
"Identifiers used by dbg")
(defun dbg (id format-string &rest args)
"Print debugging information if (DEBUG-ID) has been specified."
(when (member id *dbg-ids*)
(fresh-line *debug-io*)
(apply #'format *debug-io* format-string args)))
;;; Using gps-debug because 'debug' reserved in SBCL
(defun gps-debug (&rest ids)
"Start dbg output on the given ids."
(setf *dbg-ids* (union ids *dbg-ids*)))
(defun undebug (&rest ids)
"Stop dbg on the ids. With no ids, stop debugging altogether."
(setf *dbg-ids* (if (null ids) nil
(set-difference *dbg-ids* ids))))
(defun dbg-indent (id indent format-string &rest args)
"Print indented debugging info if (DEBUG ID) has been specified."
(when (member id *dbg-ids*)
(fresh-line *debug-io*)
(dotimes (i indent) (princ " " *debug-io*))
(apply #'format *debug-io* format-string args)))