summary refs log tree commit diff
diff options
context:
space:
mode:
authorLudovic Courtès <ludo@gnu.org>2013-04-01 00:41:55 +0200
committerLudovic Courtès <ludo@gnu.org>2013-04-01 00:41:55 +0200
commitef8c03407dce8d6ebdfcf53318ac9a09b5ee8461 (patch)
treeaa4573cd0261ca0912d9ad9d819f87486fcbf756
parentfdfd3d5d9c647876a0d7422b25fde1a6b8e9e654 (diff)
downloadguix-ef8c03407dce8d6ebdfcf53318ac9a09b5ee8461.tar.gz
gnu-maintenance: Adjust `http-fetch' to the various Guile versions.
* guix/gnu-maintenance.scm (http-fetch): Try #:streaming? #t, or
  'http-get*', or 'http-get' as a last resort.  Check whether DATA is
  #f, a string, or an input port.
-rw-r--r--guix/gnu-maintenance.scm15
1 files changed, 11 insertions, 4 deletions
diff --git a/guix/gnu-maintenance.scm b/guix/gnu-maintenance.scm
index 979678d076..89e7f25589 100644
--- a/guix/gnu-maintenance.scm
+++ b/guix/gnu-maintenance.scm
@@ -66,12 +66,18 @@
 (define (http-fetch uri)
   "Return an input port containing the textual data at URI, a string."
   (let*-values (((resp data)
-                (http-get (string->uri uri)))
+                 (let ((uri (string->uri uri)))
+                   ;; Try hard to use the API du jour to get an input port.
+                   (if (version>? "2.0.7" (version))
+                       (if (defined? 'http-get*)
+                           (http-get* uri)
+                           (http-get uri))       ; old Guile, returns a string
+                       (http-get uri #:streaming? #t)))) ; 2.0.8 or later
                ((code)
                 (response-code resp)))
     (case code
       ((200)
-       (cond ((string<=? (version) "2.0.5")
+       (cond ((not data)
               (begin
                 ;; XXX: Guile 2.0.5 and earlier did not support chunked transfer
                 ;; encoding, which is required when fetching %PACKAGE-LIST-URL
@@ -85,9 +91,10 @@
                         (response-transfer-encoding resp))
                 (error "download failed; use a newer Guile"
                        uri resp)))
-             ((string<=? (version) "2.0.7")
+             ((string? data)                 ; old `http-get' returns a string
               (open-input-string data))
-             (else data)))
+             (else                           ; input port
+              data)))
       (else
        (error "download failed" uri code
               (response-reason-phrase resp))))))