mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-19 05:57:04 +01:00
download: Autoload (guix build download).
* guix/download.scm: Autoload (guix build download). (url-fetch): Rename to... (url-fetch*): ... this, locally, to allow for #:autoload. * guix/status.scm: Autoload (guix build download).
This commit is contained in:
parent
c1940fde43
commit
f7008ca713
2 changed files with 26 additions and 28 deletions
|
@ -27,7 +27,7 @@ (define-module (guix download)
|
|||
#:use-module (guix derivations)
|
||||
#:use-module (guix packages)
|
||||
#:use-module (guix store)
|
||||
#:use-module ((guix build download) #:prefix build:)
|
||||
#:autoload (guix build download) (url-fetch)
|
||||
#:use-module (guix monads)
|
||||
#:use-module (guix gexp)
|
||||
#:use-module (guix utils)
|
||||
|
@ -35,7 +35,7 @@ (define-module (guix download)
|
|||
#:use-module (srfi srfi-1)
|
||||
#:use-module (srfi srfi-26)
|
||||
#:export (%mirrors
|
||||
url-fetch
|
||||
(url-fetch* . url-fetch)
|
||||
url-fetch/executable
|
||||
url-fetch/tarbomb
|
||||
url-fetch/zipbomb
|
||||
|
@ -449,11 +449,11 @@ (define* (built-in-download file-name url
|
|||
;; for that built-in is widespread.
|
||||
#:local-build? #t)))
|
||||
|
||||
(define* (url-fetch url hash-algo hash
|
||||
#:optional name
|
||||
#:key (system (%current-system))
|
||||
(guile (default-guile))
|
||||
executable?)
|
||||
(define* (url-fetch* url hash-algo hash
|
||||
#:optional name
|
||||
#:key (system (%current-system))
|
||||
(guile (default-guile))
|
||||
executable?)
|
||||
"Return a fixed-output derivation that fetches data from URL (a string, or a
|
||||
list of strings denoting alternate URLs), which is expected to have hash HASH
|
||||
of type HASH-ALGO (a symbol). By default, the file name is the base name of
|
||||
|
@ -499,10 +499,10 @@ (define* (url-fetch/executable url hash-algo hash
|
|||
#:key (system (%current-system))
|
||||
(guile (default-guile)))
|
||||
"Like 'url-fetch', but make the downloaded file executable."
|
||||
(url-fetch url hash-algo hash name
|
||||
#:system system
|
||||
#:guile guile
|
||||
#:executable? #t))
|
||||
(url-fetch* url hash-algo hash name
|
||||
#:system system
|
||||
#:guile guile
|
||||
#:executable? #t))
|
||||
|
||||
(define* (url-fetch/tarbomb url hash-algo hash
|
||||
#:optional name
|
||||
|
@ -521,11 +521,11 @@ (define gzip
|
|||
(define tar
|
||||
(module-ref (resolve-interface '(gnu packages base)) 'tar))
|
||||
|
||||
(mlet %store-monad ((drv (url-fetch url hash-algo hash
|
||||
(string-append "tarbomb-"
|
||||
(or name file-name))
|
||||
#:system system
|
||||
#:guile guile))
|
||||
(mlet %store-monad ((drv (url-fetch* url hash-algo hash
|
||||
(string-append "tarbomb-"
|
||||
(or name file-name))
|
||||
#:system system
|
||||
#:guile guile))
|
||||
(guile (package->derivation guile system)))
|
||||
;; Take the tar bomb, and simply unpack it as a directory.
|
||||
;; Use ungrafted tar/gzip so that the resulting tarball doesn't depend on
|
||||
|
@ -559,11 +559,11 @@ (define file-name
|
|||
(define unzip
|
||||
(module-ref (resolve-interface '(gnu packages compression)) 'unzip))
|
||||
|
||||
(mlet %store-monad ((drv (url-fetch url hash-algo hash
|
||||
(string-append "zipbomb-"
|
||||
(or name file-name))
|
||||
#:system system
|
||||
#:guile guile))
|
||||
(mlet %store-monad ((drv (url-fetch* url hash-algo hash
|
||||
(string-append "zipbomb-"
|
||||
(or name file-name))
|
||||
#:system system
|
||||
#:guile guile))
|
||||
(guile (package->derivation guile system)))
|
||||
;; Take the zip bomb, and simply unpack it as a directory.
|
||||
;; Use ungrafted unzip so that the resulting tarball doesn't depend on
|
||||
|
@ -598,10 +598,9 @@ (define uri
|
|||
(lambda (temp port)
|
||||
(let ((result
|
||||
(parameterize ((current-output-port log))
|
||||
(build:url-fetch url temp
|
||||
#:mirrors %mirrors
|
||||
#:verify-certificate?
|
||||
verify-certificate?))))
|
||||
(url-fetch url temp
|
||||
#:mirrors %mirrors
|
||||
#:verify-certificate? verify-certificate?))))
|
||||
(close port)
|
||||
(and result
|
||||
(add-to-store store name recursive? "sha256" temp)))))))
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
;;; GNU Guix --- Functional package management for GNU
|
||||
;;; Copyright © 2017, 2018, 2019, 2020 Ludovic Courtès <ludo@gnu.org>
|
||||
;;; Copyright © 2017, 2018, 2019, 2020, 2021 Ludovic Courtès <ludo@gnu.org>
|
||||
;;; Copyright © 2018, 2019 Ricardo Wurmus <rekado@elephly.net>
|
||||
;;;
|
||||
;;; This file is part of GNU Guix.
|
||||
|
@ -23,8 +23,7 @@ (define-module (guix status)
|
|||
#:use-module (guix colors)
|
||||
#:use-module (guix progress)
|
||||
#:autoload (guix build syscalls) (terminal-columns)
|
||||
#:use-module ((guix build download)
|
||||
#:select (nar-uri-abbreviation))
|
||||
#:autoload (guix build download) (nar-uri-abbreviation)
|
||||
#:use-module (guix store)
|
||||
#:use-module (guix derivations)
|
||||
#:use-module (guix memoization)
|
||||
|
|
Loading…
Reference in a new issue