import: crate: Memorize crate->guix-package.
This adds memorization to procedures that involve network lookups. 'lookup-crate*' is used on every dependency of a package to get its version list. It is also used to lookup a package's metadata. 'crate-recursive-import' is also memorized since creating the same package twice will trigger a lookup on its dependencies. * guix/import/crate.scm (lookup-crate*): New procedure. (crate->guix-package): Memorize package metadata lookups. (crate-recursive-import): Memorize package creation.master
parent
269c1db41b
commit
d9feb23e10
|
@ -27,6 +27,7 @@
|
||||||
#:use-module (guix import json)
|
#:use-module (guix import json)
|
||||||
#:use-module (guix import utils)
|
#:use-module (guix import utils)
|
||||||
#:use-module ((guix licenses) #:prefix license:)
|
#:use-module ((guix licenses) #:prefix license:)
|
||||||
|
#:use-module (guix memoization)
|
||||||
#:use-module (guix monads)
|
#:use-module (guix monads)
|
||||||
#:use-module (guix packages)
|
#:use-module (guix packages)
|
||||||
#:use-module (guix upstream)
|
#:use-module (guix upstream)
|
||||||
|
@ -110,6 +111,8 @@ record or #f if it was not found."
|
||||||
(json->crate `(,@alist
|
(json->crate `(,@alist
|
||||||
("actual_versions" . ,versions))))))))
|
("actual_versions" . ,versions))))))))
|
||||||
|
|
||||||
|
(define lookup-crate* (memoize lookup-crate))
|
||||||
|
|
||||||
(define (crate-version-dependencies version)
|
(define (crate-version-dependencies version)
|
||||||
"Return the list of <crate-dependency> records of VERSION, a
|
"Return the list of <crate-dependency> records of VERSION, a
|
||||||
<crate-version>."
|
<crate-version>."
|
||||||
|
@ -215,7 +218,7 @@ version of CRATE-NAME."
|
||||||
(eq? (crate-dependency-kind dependency) 'normal)))
|
(eq? (crate-dependency-kind dependency) 'normal)))
|
||||||
|
|
||||||
(define crate
|
(define crate
|
||||||
(lookup-crate crate-name))
|
(lookup-crate* crate-name))
|
||||||
|
|
||||||
(define version-number
|
(define version-number
|
||||||
(and crate
|
(and crate
|
||||||
|
@ -247,7 +250,7 @@ version of CRATE-NAME."
|
||||||
(define (sort-map-dependencies deps)
|
(define (sort-map-dependencies deps)
|
||||||
(sort (map (lambda (dep)
|
(sort (map (lambda (dep)
|
||||||
(let* ((name (crate-dependency-id dep))
|
(let* ((name (crate-dependency-id dep))
|
||||||
(crate (lookup-crate name))
|
(crate (lookup-crate* name))
|
||||||
(req (crate-dependency-requirement dep))
|
(req (crate-dependency-requirement dep))
|
||||||
(ver (find-crate-version crate req)))
|
(ver (find-crate-version crate req)))
|
||||||
(list name
|
(list name
|
||||||
|
@ -276,7 +279,7 @@ version of CRATE-NAME."
|
||||||
|
|
||||||
(define* (crate-recursive-import crate-name #:key version)
|
(define* (crate-recursive-import crate-name #:key version)
|
||||||
(recursive-import crate-name
|
(recursive-import crate-name
|
||||||
#:repo->guix-package crate->guix-package
|
#:repo->guix-package (memoize crate->guix-package)
|
||||||
#:version version
|
#:version version
|
||||||
#:guix-name crate-name->package-name))
|
#:guix-name crate-name->package-name))
|
||||||
|
|
||||||
|
|
Reference in New Issue