diff options
author | Ludovic Courtès <ludo@gnu.org> | 2012-11-27 21:33:54 +0100 |
---|---|---|
committer | Ludovic Courtès <ludo@gnu.org> | 2012-11-27 21:33:54 +0100 |
commit | 480943dd461690358f25ad579c2d0a30351669aa (patch) | |
tree | 46fde215b375566170b9f38794ddb47b304aef4b /guix | |
parent | 5321f74f234742ad9e039de33e60288a9a830949 (diff) | |
download | gnu-guix-480943dd461690358f25ad579c2d0a30351669aa.tar gnu-guix-480943dd461690358f25ad579c2d0a30351669aa.tar.gz |
download: Keep only one slash when concatenating URIs.
* guix/build/download.scm (url-fetch)[uri-vicinity]: New procedure.
[maybe-expand-mirrors]: Use it.
Diffstat (limited to 'guix')
-rw-r--r-- | guix/build/download.scm | 8 |
1 files changed, 7 insertions, 1 deletions
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 @@ which is not available during bootstrap." "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 @@ on success." (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))))) |