summary refs log tree commit diff
diff options
context:
space:
mode:
authorLudovic Courtès <ludo@gnu.org>2016-02-26 12:42:15 +0100
committerLudovic Courtès <ludo@gnu.org>2016-02-26 23:35:29 +0100
commitacb01e37466a1d3fff81f10e00fe15a4ef20e2db (patch)
treed31307f0a23a1b1304a8fcbf860d1569dd141613
parent70ac09a552ad3a402bfa3848e9b2c5ef92610673 (diff)
downloadguix-acb01e37466a1d3fff81f10e00fe15a4ef20e2db.tar.gz
grafts: Add record type printer.
* guix/grafts.scm (write-graft): New procedure.  Register it as a
printer for <graft>.
-rw-r--r--guix/grafts.scm17
1 files changed, 17 insertions, 0 deletions
diff --git a/guix/grafts.scm b/guix/grafts.scm
index 5074809c43..a1f7d8801a 100644
--- a/guix/grafts.scm
+++ b/guix/grafts.scm
@@ -21,6 +21,7 @@
   #:use-module (guix derivations)
   #:use-module ((guix utils) #:select (%current-system))
   #:use-module (srfi srfi-1)
+  #:use-module (srfi srfi-9 gnu)
   #:use-module (srfi srfi-26)
   #:use-module (ice-9 match)
   #:export (graft?
@@ -44,6 +45,22 @@
   (replacement-output graft-replacement-output    ;string | #f
                       (default "out")))
 
+(define (write-graft graft port)
+  "Write a concise representation of GRAFT to PORT."
+  (define (->string thing output)
+    (if (derivation? thing)
+        (derivation->output-path thing output)
+        thing))
+
+  (match graft
+    (($ <graft> origin origin-output replacement replacement-output)
+     (format port "#<graft ~a ==> ~a ~a>"
+             (->string origin origin-output)
+             (->string replacement replacement-output)
+             (number->string (object-address graft) 16)))))
+
+(set-record-type-printer! <graft> write-graft)
+
 (define* (graft-derivation store drv grafts
                            #:key
                            (name (derivation-name drv))