packages: Cache the result of 'input-grafts'.

This reduces the wall-clock time of

  guix environment gnutls --pure -E true

by ~35%.

* guix/packages.scm (%graft-cache): New variable.
(input-graft): Use 'cached' to cache to %GRAFT-CACHE.
This commit is contained in:
Ludovic Courtès 2016-03-07 23:57:33 +01:00
parent 9775412ee0
commit ced71ac7a7
1 changed files with 12 additions and 6 deletions

View File

@ -843,6 +843,11 @@ and return it."
(&package-error (&package-error
(package package))))))))))) (package package)))))))))))
(define %graft-cache
;; 'eq?' cache mapping package objects to a graft corresponding to their
;; replacement package.
(make-weak-key-hash-table 200))
(define (input-graft store system) (define (input-graft store system)
"Return a procedure that, given a package with a graft, returns a graft, and "Return a procedure that, given a package with a graft, returns a graft, and
#f otherwise." #f otherwise."
@ -850,12 +855,13 @@ and return it."
((? package? package) ((? package? package)
(let ((replacement (package-replacement package))) (let ((replacement (package-replacement package)))
(and replacement (and replacement
(cached (=> %graft-cache) package system
(let ((orig (package-derivation store package system (let ((orig (package-derivation store package system
#:graft? #f)) #:graft? #f))
(new (package-derivation store replacement system))) (new (package-derivation store replacement system)))
(graft (graft
(origin orig) (origin orig)
(replacement new)))))) (replacement new)))))))
(x (x
#f))) #f)))