gnu: commencement: Use system in %final-inputs.

Otherwise this causes odd issues, I presume arising from when %current-system
differs from the system argument passed to %final-inputs.

* gnu/packages/commencement.scm (%final-inputs): Set %current-system to
system.
* gnu/packages/base.scm (%final-inputs): Add optional system parameter.
* gnu/ci.scm (base-packages): New procedure to memoize the base packages
depending on system.
(package->job): Pass system to base-packages.

Co-authored-by: Josselin Poiret <dev@jpoiret.xyz>
Signed-off-by: Josselin Poiret <dev@jpoiret.xyz>
Signed-off-by: Ludovic Courtès <ludo@gnu.org>
This commit is contained in:
Christopher Baines 2023-08-09 09:38:31 +02:00 committed by Ludovic Courtès
parent 10f3dd0e9e
commit 560cb51e7b
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5
3 changed files with 55 additions and 49 deletions

View file

@ -24,6 +24,7 @@ (define-module (gnu ci)
#:use-module (guix build-system channel) #:use-module (guix build-system channel)
#:use-module (guix config) #:use-module (guix config)
#:autoload (guix describe) (package-channels) #:autoload (guix describe) (package-channels)
#:use-module (guix memoization)
#:use-module (guix store) #:use-module (guix store)
#:use-module (guix profiles) #:use-module (guix profiles)
#:use-module (guix packages) #:use-module (guix packages)
@ -342,29 +343,32 @@ (define job-name
;; Return the name of a package's job. ;; Return the name of a package's job.
package-name) package-name)
(define base-packages
(mlambda (system)
"Return the set of packages considered to be part of the base for SYSTEM."
(delete-duplicates
(append-map (match-lambda
((_ package _ ...)
(match (package-transitive-inputs package)
(((_ inputs _ ...) ...)
inputs))))
(%final-inputs system)))))
(define package->job (define package->job
(let ((base-packages (lambda* (store package system #:key (suffix ""))
(delete-duplicates "Return a job for PACKAGE on SYSTEM, or #f if this combination is not
(append-map (match-lambda
((_ package _ ...)
(match (package-transitive-inputs package)
(((_ inputs _ ...) ...)
inputs))))
(%final-inputs)))))
(lambda* (store package system #:key (suffix ""))
"Return a job for PACKAGE on SYSTEM, or #f if this combination is not
valid. Append SUFFIX to the job name." valid. Append SUFFIX to the job name."
(cond ((member package base-packages) (cond ((member package (base-packages system))
(package-job store (string-append "base." (job-name package)) (package-job store (string-append "base." (job-name package))
package system #:suffix suffix)) package system #:suffix suffix))
((supported-package? package system) ((supported-package? package system)
(let ((drv (package-derivation store package system (let ((drv (package-derivation store package system
#:graft? #f))) #:graft? #f)))
(and (substitutable-derivation? drv) (and (substitutable-derivation? drv)
(package-job store (job-name package) (package-job store (job-name package)
package system #:suffix suffix)))) package system #:suffix suffix))))
(else (else
#f))))) #f))))
(define %x86-64-micro-architectures (define %x86-64-micro-architectures
;; Micro-architectures for which we build tuned variants. ;; Micro-architectures for which we build tuned variants.

View file

@ -78,7 +78,8 @@ (define-module (gnu packages base)
#:export (glibc #:export (glibc
libc-for-target libc-for-target
make-ld-wrapper make-ld-wrapper
libiconv-if-needed)) libiconv-if-needed
%final-inputs))
;;; Commentary: ;;; Commentary:
;;; ;;;
@ -1648,10 +1649,10 @@ (define-public (canonical-package package)
(proc (module-ref iface 'canonical-package))) (proc (module-ref iface 'canonical-package)))
(proc package))) (proc package)))
(define-public (%final-inputs) (define* (%final-inputs #:optional (system (%current-system)))
"Return the list of \"final inputs\"." "Return the list of \"final inputs\"."
;; Avoid circular dependency by lazily resolving 'commencement'. ;; Avoid circular dependency by lazily resolving 'commencement'.
(let ((iface (resolve-interface '(gnu packages commencement)))) (let ((iface (resolve-interface '(gnu packages commencement))))
((module-ref iface '%final-inputs) (%current-system)))) ((module-ref iface '%final-inputs) system)))
;;; base.scm ends here ;;; base.scm ends here

View file

@ -3459,31 +3459,32 @@ (define-public %final-inputs
;; still use 'package-with-bootstrap-guile' so that the bootstrap tools are ;; still use 'package-with-bootstrap-guile' so that the bootstrap tools are
;; used for origins that have patches, thereby avoiding circular ;; used for origins that have patches, thereby avoiding circular
;; dependencies. ;; dependencies.
(let ((finalize (compose with-boot6 (parameterize ((%current-system system))
package-with-bootstrap-guile))) (let ((finalize (compose with-boot6
`(,@(map (match-lambda package-with-bootstrap-guile)))
((name package) `(,@(map (match-lambda
(list name (finalize package)))) ((name package)
`(("tar" ,tar) (list name (finalize package))))
("gzip" ,gzip) `(("tar" ,tar)
("bzip2" ,bzip2) ("gzip" ,gzip)
("file" ,file) ("bzip2" ,bzip2)
("diffutils" ,diffutils) ("file" ,file)
("patch" ,patch) ("diffutils" ,diffutils)
("findutils" ,findutils) ("patch" ,patch)
("gawk" ,gawk))) ("findutils" ,findutils)
("sed" ,sed-final) ("gawk" ,gawk)))
("grep" ,grep-final) ("sed" ,sed-final)
("xz" ,xz-final) ("grep" ,grep-final)
("coreutils" ,coreutils-final) ("xz" ,xz-final)
("make" ,gnu-make-final) ("coreutils" ,coreutils-final)
("bash" ,bash-final) ("make" ,gnu-make-final)
("ld-wrapper" ,ld-wrapper) ("bash" ,bash-final)
("binutils" ,binutils-final) ("ld-wrapper" ,ld-wrapper)
("gcc" ,gcc-final) ("binutils" ,binutils-final)
("libc" ,glibc-final) ("gcc" ,gcc-final)
("libc:static" ,glibc-final "static") ("libc" ,glibc-final)
("locales" ,glibc-utf8-locales-final))))) ("libc:static" ,glibc-final "static")
("locales" ,glibc-utf8-locales-final))))))
(define-public canonical-package (define-public canonical-package
(let ((name->package (mlambda (system) (let ((name->package (mlambda (system)