From 480943dd461690358f25ad579c2d0a30351669aa Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ludovic=20Court=C3=A8s?= Date: Tue, 27 Nov 2012 21:33:54 +0100 Subject: [PATCH] download: Keep only one slash when concatenating URIs. * guix/build/download.scm (url-fetch)[uri-vicinity]: New procedure. [maybe-expand-mirrors]: Use it. --- guix/build/download.scm | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/guix/build/download.scm b/guix/build/download.scm index 7af16da65f..9d90971f28 100644 --- a/guix/build/download.scm +++ b/guix/build/download.scm @@ -135,6 +135,12 @@ (define* (url-fetch url file #:key (mirrors '())) "Fetch FILE from URL; URL may be either a single string, or a list of string denoting alternate URLs for FILE. Return #f on failure, and FILE on success." + (define (uri-vicinity dir file) + ;; Concatenate DIR, slash, and FILE, keeping only one slash in between. + ;; This is required by some HTTP servers. + (string-append (string-trim-right dir #\/) "/" + (string-trim file #\/))) + (define (maybe-expand-mirrors uri) (case (uri-scheme uri) ((mirror) @@ -142,7 +148,7 @@ (define (maybe-expand-mirrors uri) (path (uri-path uri))) (match (assoc-ref mirrors kind) ((mirrors ..1) - (map (compose string->uri (cut string-append <> path)) + (map (compose string->uri (cut uri-vicinity <> path)) mirrors)) (_ (error "unsupported URL mirror kind" kind uri)))))