summaryrefslogtreecommitdiff
path: root/scheme/racket/geiser/images.rkt
diff options
context:
space:
mode:
authorJose Antonio Ortega Ruiz <jao@gnu.org>2014-12-31 20:18:19 +0100
committerJose Antonio Ortega Ruiz <jao@gnu.org>2014-12-31 20:26:13 +0100
commit27b7eacc9c062328d189337e02c2229b4be3e3c7 (patch)
tree06fcee46eacb3f2ceb47c4ccf2e816aabb82688b /scheme/racket/geiser/images.rkt
parent0dbd605e631beea9b46f526deda2a7d05928c49f (diff)
downloadgeiser-chez-27b7eacc9c062328d189337e02c2229b4be3e3c7.tar.gz
geiser-chez-27b7eacc9c062328d189337e02c2229b4be3e3c7.tar.bz2
Racket: displaying graphics in structured objects
By hooking the pretty-printer, as discovered by Greg in issue #49. To attain nirvana, we would still need (display (list graph)) to work...
Diffstat (limited to 'scheme/racket/geiser/images.rkt')
-rw-r--r--scheme/racket/geiser/images.rkt15
1 files changed, 14 insertions, 1 deletions
diff --git a/scheme/racket/geiser/images.rkt b/scheme/racket/geiser/images.rkt
index 2cdcadb..b97546f 100644
--- a/scheme/racket/geiser/images.rkt
+++ b/scheme/racket/geiser/images.rkt
@@ -17,7 +17,9 @@
(provide image-cache
maybe-print-image
maybe-write-image
- make-port-print-handler)
+ make-port-print-handler
+ make-pretty-print-size-hook
+ make-pretty-print-print-hook)
(define image-cache
(let ([ensure-dir (lambda (dir)
@@ -51,3 +53,14 @@
(define (make-port-print-handler ph)
(lambda (value port . rest)
(apply ph (or (maybe-save-image value) value) port rest)))
+
+(define (make-pretty-print-size-hook [orig (pretty-print-size-hook)])
+ (lambda (value display? port)
+ (if (convertible? value)
+ (pretty-print-columns)
+ (orig value display? port))))
+
+(define (make-pretty-print-print-hook [orig (pretty-print-print-hook)])
+ (lambda (value display? port)
+ (let [(img (maybe-save-image value))]
+ (if img (print img port) (orig value display? port)))))