[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
01/04: gnu-maintenance: 'sourceforge' updater reuses the same connection
From: |
guix-commits |
Subject: |
01/04: gnu-maintenance: 'sourceforge' updater reuses the same connection. |
Date: |
Thu, 8 Apr 2021 17:30:08 -0400 (EDT) |
civodul pushed a commit to branch master
in repository guix.
commit eb6ac483a5541481a97ab7227c33353074ff9964
Author: Ludovic Courtès <ludo@gnu.org>
AuthorDate: Thu Apr 8 09:34:03 2021 +0200
gnu-maintenance: 'sourceforge' updater reuses the same connection.
* guix/gnu-maintenance.scm (latest-sourceforge-release): Call
'open-socket-for-uri' upfront. Pass #:port and #:keep-alive? to
'http-head'. Wrap body in 'dynamic-wind' and call 'close-port' upon
exit.
---
guix/gnu-maintenance.scm | 63 +++++++++++++++++++++++++++---------------------
1 file changed, 36 insertions(+), 27 deletions(-)
diff --git a/guix/gnu-maintenance.scm b/guix/gnu-maintenance.scm
index ba659c0..fece84b 100644
--- a/guix/gnu-maintenance.scm
+++ b/guix/gnu-maintenance.scm
@@ -31,7 +31,7 @@
#:use-module (srfi srfi-34)
#:use-module (rnrs io ports)
#:use-module (system foreign)
- #:use-module (guix http-client)
+ #:use-module ((guix http-client) #:hide (open-socket-for-uri))
#:use-module (guix ftp-client)
#:use-module (guix utils)
#:use-module (guix memoization)
@@ -669,10 +669,10 @@ GNOME packages; EMMS is included though, because its
releases are on gnu.org."
#:host (uri-host uri)
#:path (string-append (uri-path uri) extension)))
- (define (valid-uri? uri)
+ (define (valid-uri? uri port)
;; Return true if URI is reachable.
(false-if-exception
- (case (response-code (http-head uri))
+ (case (response-code (http-head uri #:port port #:keep-alive? #t))
((200 302) #t)
(else #f))))
@@ -680,30 +680,39 @@ GNOME packages; EMMS is included though, because its
releases are on gnu.org."
(base (string-append "https://sourceforge.net/projects/"
name "/files"))
(url (string-append base "/latest/download"))
- (response (false-if-exception (http-head url))))
- (and response
- (= 302 (response-code response))
- (response-location response)
- (match (string-tokenize (uri-path (response-location response))
- (char-set-complement (char-set #\/)))
- ((_ components ...)
- (let* ((path (string-join components "/"))
- (url (string-append "mirror://sourceforge/" path)))
- (and (release-file? name (basename path))
-
- ;; Take the heavy-handed approach of probing 3 additional
- ;; URLs. XXX: Would be nicer if this could be avoided.
- (let* ((loc (response-location response))
- (sig (any (lambda (extension)
- (let ((uri (uri-append loc extension)))
- (and (valid-uri? uri)
- (string-append url extension))))
- '(".asc" ".sig" ".sign"))))
- (upstream-source
- (package name)
- (version (tarball->version (basename path)))
- (urls (list url))
- (signature-urls (and sig (list sig))))))))))))
+ (uri (string->uri url))
+ (port (false-if-exception (open-socket-for-uri uri)))
+ (response (and port
+ (http-head uri #:port port #:keep-alive? #t))))
+ (dynamic-wind
+ (const #t)
+ (lambda ()
+ (and response
+ (= 302 (response-code response))
+ (response-location response)
+ (match (string-tokenize (uri-path (response-location response))
+ (char-set-complement (char-set #\/)))
+ ((_ components ...)
+ (let* ((path (string-join components "/"))
+ (url (string-append "mirror://sourceforge/" path)))
+ (and (release-file? name (basename path))
+
+ ;; Take the heavy-handed approach of probing 3
additional
+ ;; URLs. XXX: Would be nicer if this could be avoided.
+ (let* ((loc (response-location response))
+ (sig (any (lambda (extension)
+ (let ((uri (uri-append loc
extension)))
+ (and (valid-uri? uri port)
+ (string-append url
extension))))
+ '(".asc" ".sig" ".sign"))))
+ (upstream-source
+ (package name)
+ (version (tarball->version (basename path)))
+ (urls (list url))
+ (signature-urls (and sig (list sig)))))))))))
+ (lambda ()
+ (when port
+ (close-port port))))))
(define (latest-xorg-release package)
"Return the latest release of PACKAGE."