mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 20:19:18 -05:00
import: github: Reuse HTTP connection for the /tags URL fallback.
* guix/import/github.scm (fetch-releases-or-tags): Call 'open-connection-for-uri' and reuse the same connection for the two 'http-fetch' calls. * .dir-locals.el (scheme-mode): Add 'call-with-port'.
This commit is contained in:
parent
8786c2e8d7
commit
a8d3033da6
2 changed files with 19 additions and 12 deletions
|
@ -52,6 +52,7 @@
|
||||||
(eval . (put 'test-equal 'scheme-indent-function 1))
|
(eval . (put 'test-equal 'scheme-indent-function 1))
|
||||||
(eval . (put 'test-eq 'scheme-indent-function 1))
|
(eval . (put 'test-eq 'scheme-indent-function 1))
|
||||||
(eval . (put 'call-with-input-string 'scheme-indent-function 1))
|
(eval . (put 'call-with-input-string 'scheme-indent-function 1))
|
||||||
|
(eval . (put 'call-with-port 'scheme-indent-function 1))
|
||||||
(eval . (put 'guard 'scheme-indent-function 1))
|
(eval . (put 'guard 'scheme-indent-function 1))
|
||||||
(eval . (put 'lambda* 'scheme-indent-function 1))
|
(eval . (put 'lambda* 'scheme-indent-function 1))
|
||||||
(eval . (put 'substitute* 'scheme-indent-function 1))
|
(eval . (put 'substitute* 'scheme-indent-function 1))
|
||||||
|
|
|
@ -33,6 +33,7 @@ (define-module (guix import github)
|
||||||
#:use-module ((guix ui) #:select (display-hint))
|
#:use-module ((guix ui) #:select (display-hint))
|
||||||
#:use-module ((guix download) #:prefix download:)
|
#:use-module ((guix download) #:prefix download:)
|
||||||
#:use-module ((guix git-download) #:prefix download:)
|
#:use-module ((guix git-download) #:prefix download:)
|
||||||
|
#:autoload (guix build download) (open-connection-for-uri)
|
||||||
#:use-module (guix import utils)
|
#:use-module (guix import utils)
|
||||||
#:use-module (json)
|
#:use-module (json)
|
||||||
#:use-module (guix packages)
|
#:use-module (guix packages)
|
||||||
|
@ -229,18 +230,23 @@ (define headers
|
||||||
(_
|
(_
|
||||||
(raise c)))))
|
(raise c)))))
|
||||||
|
|
||||||
(let* ((port (http-fetch release-url #:headers headers))
|
(let ((release-uri (string->uri release-url)))
|
||||||
(result (json->scm port)))
|
(call-with-port (open-connection-for-uri release-uri)
|
||||||
(close-port port)
|
(lambda (connection)
|
||||||
|
(let* ((result (json->scm
|
||||||
|
(http-fetch release-uri
|
||||||
|
#:port connection
|
||||||
|
#:keep-alive? #t
|
||||||
|
#:headers headers))))
|
||||||
(match result
|
(match result
|
||||||
(#()
|
(#()
|
||||||
;; We got the empty list, presumably because the user didn't use GitHub's
|
;; We got the empty list, presumably because the user didn't use GitHub's
|
||||||
;; "release" mechanism, but hopefully they did use Git tags.
|
;; "release" mechanism, but hopefully they did use Git tags.
|
||||||
(let* ((port (http-fetch tag-url #:headers headers))
|
(json->scm (http-fetch tag-url
|
||||||
(json (json->scm port)))
|
#:port connection
|
||||||
(close-port port)
|
#:keep-alive? #t
|
||||||
json))
|
#:headers headers)))
|
||||||
(x x))))))
|
(x x)))))))))
|
||||||
|
|
||||||
(define (latest-released-version url package-name)
|
(define (latest-released-version url package-name)
|
||||||
"Return the newest released version and its tag given a string URL like
|
"Return the newest released version and its tag given a string URL like
|
||||||
|
|
Loading…
Reference in a new issue