Fix hash table pretty printing. Thanks, CLR.
author |
Steve Losh <steve@stevelosh.com> |
date |
Fri, 09 Nov 2018 21:23:48 -0500 (2018-11-10) |
parents |
3cddaf4f6564
|
children |
edbdc9c9cb0a
|
branches/tags |
(none) |
files |
package.lisp src/debugging.lisp |
Changes
--- a/package.lisp Wed Nov 07 18:08:28 2018 -0500
+++ b/package.lisp Fri Nov 09 21:23:48 2018 -0500
@@ -289,10 +289,8 @@
:dis
:gimme
:hex
- :pht
:pr
- :print-hash-table
- :print-hash-table-concisely
+ :pretty-print-hash-table
:print-table
:prl
:shut-up
--- a/src/debugging.lisp Wed Nov 07 18:08:28 2018 -0500
+++ b/src/debugging.lisp Fri Nov 09 21:23:48 2018 -0500
@@ -138,58 +138,20 @@
(values))
-(defun print-hash-table (hash-table &optional (stream t))
- "Print a pretty representation of `hash-table` to `stream.`
-
- Respects `*print-length*` when printing the elements.
+(defun pretty-print-hash-table (*standard-output* ht)
+ (pprint-logical-block
+ (*standard-output* (hash-table-contents ht) :prefix "{" :suffix "}")
+ (pprint-exit-if-list-exhausted)
+ (loop (destructuring-bind (k v) (pprint-pop)
+ (write k)
+ (write-string ": ")
+ (write v)
+ (pprint-exit-if-list-exhausted)
+ (write-string ", ")
+ (pprint-newline :linear)))))
- "
- (let* ((keys (hash-table-keys hash-table))
- (vals (hash-table-values hash-table))
- (count (hash-table-count hash-table))
- (key-width (-<> keys
- (mapcar (compose #'length #'prin1-to-string) <>)
- (reduce #'max <> :initial-value 0)
- (clamp 0 20 <>))))
- (print-unreadable-object (hash-table stream :type t)
- (princ
- ;; Something shits the bed and output gets jumbled (in SBCL at least) if
- ;; we try to print to `stream` directly in the format statement inside
- ;; `print-unreadable-object`, so instead we can just render to a string
- ;; and `princ` that.
- (format nil ":test ~A :count ~D {~%~{~{ ~vs ~s~}~%~}}"
- (hash-table-test hash-table)
- count
- (loop
- :with limit = (or *print-length* 40)
- :for key :in keys
- :for val :in vals
- :for i :from 0 :to limit
- :collect
- (if (= i limit)
- (list key-width :too-many-items (list (- count i) :more))
- (list key-width key val))))
- stream)))
- (terpri stream)
- (values))
-(defun pht (hash-table &optional (stream t))
- "Synonym for `print-hash-table` for less typing at the REPL."
- (print-hash-table hash-table stream))
-
-(defun print-hash-table-concisely (hash-table &optional (stream t))
- "Print a concise representation of `hash-table` to `stream.`
-
- Should respect `*print-length*` when printing the elements.
-
- "
- (print-unreadable-object (hash-table stream :type t)
- (prin1 (hash-table-test hash-table))
- (write-char #\space stream)
- (prin1 (hash-table-contents hash-table) stream)))
-
-(defmethod print-object ((object hash-table) stream)
- (print-hash-table-concisely object stream))
+(set-pprint-dispatch 'hash-table 'pretty-print-hash-table)
#+sbcl