[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
01/05: substitute-binary: Allow callers to specify the size of a narinfo
From: |
Ludovic Courtès |
Subject: |
01/05: substitute-binary: Allow callers to specify the size of a narinfo. |
Date: |
Mon, 23 Mar 2015 21:28:58 +0000 |
civodul pushed a commit to branch master
in repository guix.
commit 0561e9ae16c2894d19432f1c6eb8e99ad508dc47
Author: Ludovic Courtès <address@hidden>
Date: Mon Jan 5 22:31:34 2015 +0100
substitute-binary: Allow callers to specify the size of a narinfo.
* guix/scripts/substitute-binary.scm (read-narinfo): Add #:size
parameter and honor it.
---
guix/scripts/substitute-binary.scm | 10 +++++++---
1 files changed, 7 insertions(+), 3 deletions(-)
diff --git a/guix/scripts/substitute-binary.scm
b/guix/scripts/substitute-binary.scm
index a4d153d..85c2c74 100755
--- a/guix/scripts/substitute-binary.scm
+++ b/guix/scripts/substitute-binary.scm
@@ -309,12 +309,16 @@ NARINFO, doesn't match HASH, a bytevector containing the
hash of NARINFO."
(corrupt-signature
(leave (_ "signature on '~a' is corrupt~%") uri)))))
-(define* (read-narinfo port #:optional url)
+(define* (read-narinfo port #:optional url
+ #:key size)
"Read a narinfo from PORT. If URL is true, it must be a string used to
-build full URIs from relative URIs found while reading PORT.
+build full URIs from relative URIs found while reading PORT. When SIZE is
+true, read at most SIZE bytes from PORT; otherwise, read as much as possible.
No authentication and authorization checks are performed here!"
- (let ((str (utf8->string (get-bytevector-all port))))
+ (let ((str (utf8->string (if size
+ (get-bytevector-n port size)
+ (get-bytevector-all port)))))
(alist->record (call-with-input-string str fields->alist)
(narinfo-maker str url)
'("StorePath" "URL" "Compression"