[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 10/12] RECURSIVE IMPORTER wip
From: |
David Craven |
Subject: |
[PATCH 10/12] RECURSIVE IMPORTER wip |
Date: |
Sun, 11 Dec 2016 18:25:35 +0100 |
---
guix/import/crate.scm | 61 +++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 61 insertions(+)
diff --git a/guix/import/crate.scm b/guix/import/crate.scm
index 45d5bf846..632c35f0a 100644
--- a/guix/import/crate.scm
+++ b/guix/import/crate.scm
@@ -156,3 +156,64 @@ VERSION, INPUTS, NATIVE-INPUTS, HOME-PAGE, SYNOPSIS,
DESCRIPTION, and LICENSE."
(pred crate-package?)
(latest latest-release)))
+;;;
+;;; Recursive importer
+;;;
+
+(define-public (recursive-import crate-name)
+ (define (crate-inputs crate-name)
+ (crate-fetch
+ crate-name
+ (lambda* (#:key inputs native-inputs #:allow-other-keys)
+ (append inputs native-inputs))))
+
+ (define (crate->input-list crate-name crate-list)
+ (let ((crates (cons crate-name crate-list))
+ (inputs (crate-inputs crate-name)))
+ (for-each
+ (lambda (crate)
+ (when (not (member crate crates))
+ (format #t "Needs ~s crate.~%" crate)
+ (set! crates (crate->input-list crate crates))))
+ inputs)
+ crates))
+
+ (define (recursive-crate-inputs crate-name)
+ (crate->input-list crate-name '()))
+
+ (and-let* ((crates (recursive-crate-inputs crate-name))
+ (crates-sorted (sort crates string<?))
+ (packages (map crate->guix-package crates-sorted))
+ (definitions (map package->definition packages)))
+ (for-each
+ (lambda (expr)
+ (pretty-print expr (newline-rewriting-port
+ (current-output-port))))
+ definitions)))
+
+
+(define (newline-rewriting-port output)
+ "Return an output port that rewrites strings containing the \\n escape
+to an actual newline. This works around the behavior of `pretty-print'
+and `write', which output these as \\n instead of actual newlines,
+whereas we want the `description' field to contain actual newlines
+rather than \\n."
+ (define (write-string str)
+ (let loop ((chars (string->list str)))
+ (match chars
+ (()
+ #t)
+ ((#\\ #\n rest ...)
+ (newline output)
+ (loop rest))
+ ((chr rest ...)
+ (write-char chr output)
+ (loop rest)))))
+
+ (make-soft-port (vector (cut write-char <>)
+ write-string
+ (lambda _ #t) ; flush
+ #f
+ (lambda _ #t) ; close
+ #f)
+ "w"))
--
2.11.0
- [PATCH 04/12] import: Add importer for rust crates., (continued)
- [PATCH 04/12] import: Add importer for rust crates., David Craven, 2016/12/11
- [PATCH 08/12] gnu: Add rustc., David Craven, 2016/12/11
- [PATCH 09/12] gnu: Add rust-libc., David Craven, 2016/12/11
- [PATCH 07/12] gnu: Add rust bootstrap binaries., David Craven, 2016/12/11
- [PATCH 11/12] gnu: Add rust-rand., David Craven, 2016/12/11
- [PATCH 10/12] RECURSIVE IMPORTER wip,
David Craven <=
- [PATCH 12/12] gnu: Add cargo., David Craven, 2016/12/11