|
|
|
@ -16,7 +16,10 @@ |
|
|
|
|
#:optional name |
|
|
|
|
#:key (system (%current-system)) |
|
|
|
|
(guile (default-guile))) |
|
|
|
|
"Similar to 'url-fetch' but decompress the xz file at URL." |
|
|
|
|
"Similar to 'url-fetch' but decompress the xz file at URL as the result. |
|
|
|
|
This is mainly used for adding xz-compressed patches to a origin definition. |
|
|
|
|
|
|
|
|
|
\".xz\" extension in the URL is assumed." |
|
|
|
|
(define file-name |
|
|
|
|
(match url |
|
|
|
|
((head _ ...) |
|
|
|
@ -27,13 +30,13 @@ |
|
|
|
|
(module-ref (resolve-interface '(gnu packages compression)) 'xz)) |
|
|
|
|
|
|
|
|
|
(mlet %store-monad ((drv (url-fetch* url hash-algo hash |
|
|
|
|
(or name file-name) |
|
|
|
|
(or name (basename file-name ".xz")) |
|
|
|
|
#:system system |
|
|
|
|
#:guile guile)) |
|
|
|
|
(guile (package->derivation guile system))) |
|
|
|
|
;; Take the xz file, and simply decompress it. |
|
|
|
|
;; Use ungrafted xz so that the resulting tarball doesn't depend on |
|
|
|
|
;; whether grafts are enabled. |
|
|
|
|
;; Use ungrafted xz so that the resulting file doesn't depend on whether |
|
|
|
|
;; grafts are enabled. |
|
|
|
|
(gexp->derivation (or name file-name) |
|
|
|
|
(with-imported-modules '((guix build utils)) |
|
|
|
|
#~(begin |
|
|
|
|