mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-27 13:09:23 -05:00
gnu: Improve memoization of 'package-with-bootstrap-guile'.
Before that, the command: GUIX_PROFILING=memoization guix build -e '(@@ (gnu packages commencement) gnu-make-final)' -nd would show that 'package-with-bootstrap-guile' was called 2256 times (hit rate: 89%). Now, it is called 745 times (hit rate: 85%). "guix build libreoffice -nd" goes from 2.60s to 2.40s (-8%). * gnu/packages/commencement.scm (gnu-make-final) (coreutils-final, grep-final, sed-final, %final-inputs): Call 'package-with-bootstrap-guile' before 'package-with-explicit-inputs'.
This commit is contained in:
parent
d7e29a2b26
commit
099dbc4fd3
1 changed files with 27 additions and 28 deletions
|
@ -2403,18 +2403,16 @@ (define (%boot5-inputs)
|
|||
|
||||
(define gnu-make-final
|
||||
;; The final GNU Make, which uses the final Guile.
|
||||
(package-with-bootstrap-guile
|
||||
(package-with-explicit-inputs gnu-make
|
||||
(package-with-explicit-inputs (package-with-bootstrap-guile gnu-make)
|
||||
(lambda _
|
||||
`(("guile" ,guile-final)
|
||||
,@(%boot5-inputs)))
|
||||
(current-source-location))))
|
||||
(current-source-location)))
|
||||
|
||||
(define coreutils-final
|
||||
;; The final Coreutils. Treat them specially because some packages, such as
|
||||
;; Findutils, keep a reference to the Coreutils they were built with.
|
||||
(package-with-bootstrap-guile
|
||||
(package-with-explicit-inputs coreutils
|
||||
(package-with-explicit-inputs (package-with-bootstrap-guile coreutils)
|
||||
%boot5-inputs
|
||||
(current-source-location)
|
||||
|
||||
|
@ -2422,15 +2420,16 @@ (define coreutils-final
|
|||
;; final libc with working iconv, so that
|
||||
;; 'substitute*' works well when touching
|
||||
;; test files in Gettext.
|
||||
#:guile guile-final)))
|
||||
#:guile guile-final))
|
||||
|
||||
(define grep-final
|
||||
;; The final grep. Gzip holds a reference to it (via zgrep), so it must be
|
||||
;; built before gzip.
|
||||
(let ((grep (package-with-bootstrap-guile
|
||||
(package-with-explicit-inputs grep %boot5-inputs
|
||||
(let ((grep (package-with-explicit-inputs
|
||||
(package-with-bootstrap-guile grep)
|
||||
%boot5-inputs
|
||||
(current-source-location)
|
||||
#:guile guile-final))))
|
||||
#:guile guile-final)))
|
||||
(package/inherit grep
|
||||
(inputs (alist-delete "pcre" (package-inputs grep)))
|
||||
(native-inputs `(("perl" ,perl-boot0))))))
|
||||
|
@ -2443,10 +2442,10 @@ (define (%boot6-inputs)
|
|||
|
||||
(define sed-final
|
||||
;; The final sed.
|
||||
(let ((sed (package-with-bootstrap-guile
|
||||
(package-with-explicit-inputs sed %boot6-inputs
|
||||
(let ((sed (package-with-explicit-inputs (package-with-bootstrap-guile sed)
|
||||
%boot6-inputs
|
||||
(current-source-location)
|
||||
#:guile guile-final))))
|
||||
#:guile guile-final)))
|
||||
(package/inherit sed (native-inputs `(("perl" ,perl-boot0))))))
|
||||
|
||||
(define-public %final-inputs
|
||||
|
@ -2454,9 +2453,9 @@ (define-public %final-inputs
|
|||
;; still use 'package-with-bootstrap-guile' so that the bootstrap tools are
|
||||
;; used for origins that have patches, thereby avoiding circular
|
||||
;; dependencies.
|
||||
(let ((finalize (compose package-with-bootstrap-guile
|
||||
(cut package-with-explicit-inputs <> %boot6-inputs
|
||||
(current-source-location)))))
|
||||
(let ((finalize (compose (cut package-with-explicit-inputs <> %boot6-inputs
|
||||
(current-source-location))
|
||||
package-with-bootstrap-guile)))
|
||||
`(,@(map (match-lambda
|
||||
((name package)
|
||||
(list name (finalize package))))
|
||||
|
|
Loading…
Reference in a new issue