build-system: Bags record their system and target.

* guix/build-system.scm (<bag>)[system, target]: New fields.
  (make-bag): Add #:system parameter and pass it to LOWER.
* gnu/packages/bootstrap.scm (make-raw-bag): Initialize 'system' field.
* guix/build-system/cmake.scm (lower): Likewise.
* guix/build-system/perl.scm (lower): Likewise.
* guix/build-system/python.scm (lower): Likewise.
* guix/build-system/ruby.scm (lower): Likewise.
* guix/build-system/trivial.scm (lower): Likewise.
* guix/build-system/gnu.scm (lower): Initialize 'system' and 'target'
  fields.
* guix/packages.scm (bag->derivation, bag->cross-derivation): New
  procedures.
  (package-derivation, package-cross-derivation): Use 'bag->derivation'.
* tests/packages.scm ("search paths"): Initialize 'system' and 'target'
  fields.
  ("package->bag", "package->bag, cross-compilation", "bag->derivation",
  "bag->derivation, cross-compilation"): New tests.
This commit is contained in:
Ludovic Courtès 2014-10-05 16:32:25 +02:00
parent b4469d8c12
commit d3d337d2d8
10 changed files with 137 additions and 69 deletions

View file

@ -198,9 +198,11 @@ (define (->store file)
#:inputs `((,bash) (,builder))))) #:inputs `((,bash) (,builder)))))
(define* (make-raw-bag name (define* (make-raw-bag name
#:key source inputs native-inputs outputs target) #:key source inputs native-inputs outputs
system target)
(bag (bag
(name name) (name name)
(system system)
(build-inputs inputs) (build-inputs inputs)
(build raw-build))) (build raw-build)))

View file

@ -28,6 +28,8 @@ (define-module (guix build-system)
bag bag
bag? bag?
bag-name bag-name
bag-system
bag-target
bag-build-inputs bag-build-inputs
bag-host-inputs bag-host-inputs
bag-target-inputs bag-target-inputs
@ -43,12 +45,19 @@ (define-record-type* <build-system> build-system make-build-system
(description build-system-description) ; short description (description build-system-description) ; short description
(lower build-system-lower)) ; args ... -> bags (lower build-system-lower)) ; args ... -> bags
;; "Bags" are low-level representations of "packages". Here we use ;; "Bags" are low-level representations of "packages". The system and target
;; build/host/target in the sense of the GNU tool chain (info "(autoconf) ;; of a bag is fixed when it's created. This is because build systems may
;; Specifying Target Triplets"). ;; choose inputs as a function of the system and target.
(define-record-type* <bag> bag %make-bag (define-record-type* <bag> bag %make-bag
bag? bag?
(name bag-name) ;string (name bag-name) ;string
(system bag-system) ;string
(target bag-target ;string | #f
(default #f))
;; Here we use build/host/target in the sense of the GNU tool chain (info
;; "(autoconf) Specifying Target Triplets").
(build-inputs bag-build-inputs ;list of packages (build-inputs bag-build-inputs ;list of packages
(default '())) (default '()))
(host-inputs bag-host-inputs ;list of packages (host-inputs bag-host-inputs ;list of packages
@ -72,7 +81,7 @@ (define-record-type* <bag> bag %make-bag
(define* (make-bag build-system name (define* (make-bag build-system name
#:key source (inputs '()) (native-inputs '()) #:key source (inputs '()) (native-inputs '())
(outputs '()) (arguments '()) (outputs '()) (arguments '())
target) system target)
"Ask BUILD-SYSTEM to return a 'bag' for NAME, with the given SOURCE, "Ask BUILD-SYSTEM to return a 'bag' for NAME, with the given SOURCE,
INPUTS, NATIVE-INPUTS, OUTPUTS, and additional ARGUMENTS. If TARGET is not INPUTS, NATIVE-INPUTS, OUTPUTS, and additional ARGUMENTS. If TARGET is not
#f, it must be a string with the GNU triplet of a cross-compilation target. #f, it must be a string with the GNU triplet of a cross-compilation target.
@ -82,6 +91,7 @@ (define* (make-bag build-system name
(match build-system (match build-system
(($ <build-system> _ description lower) (($ <build-system> _ description lower)
(apply lower name (apply lower name
#:system system
#:source source #:source source
#:inputs inputs #:inputs inputs
#:native-inputs native-inputs #:native-inputs native-inputs

View file

@ -43,7 +43,7 @@ (define (default-cmake)
(module-ref module 'cmake))) (module-ref module 'cmake)))
(define* (lower name (define* (lower name
#:key source inputs native-inputs outputs target #:key source inputs native-inputs outputs system target
(cmake (default-cmake)) (cmake (default-cmake))
#:allow-other-keys #:allow-other-keys
#:rest arguments) #:rest arguments)
@ -54,6 +54,7 @@ (define private-keywords
(and (not target) ;XXX: no cross-compilation (and (not target) ;XXX: no cross-compilation
(bag (bag
(name name) (name name)
(system system)
(host-inputs `(,@(if source (host-inputs `(,@(if source
`(("source" ,source)) `(("source" ,source))
'()) '())

View file

@ -210,7 +210,7 @@ (define (standard-packages)
(define* (lower name (define* (lower name
#:key source inputs native-inputs outputs target #:key source inputs native-inputs outputs target
(implicit-inputs? #t) (implicit-cross-inputs? #t) (implicit-inputs? #t) (implicit-cross-inputs? #t)
(strip-binaries? #t) (strip-binaries? #t) system
#:allow-other-keys #:allow-other-keys
#:rest arguments) #:rest arguments)
"Return a bag for NAME from the given arguments." "Return a bag for NAME from the given arguments."
@ -221,6 +221,7 @@ (define private-keywords
(bag (bag
(name name) (name name)
(system system) (target target)
(build-inputs `(,@(if source (build-inputs `(,@(if source
`(("source" ,source)) `(("source" ,source))
'()) '())

View file

@ -43,7 +43,8 @@ (define (default-perl)
(module-ref module 'perl))) (module-ref module 'perl)))
(define* (lower name (define* (lower name
#:key source inputs native-inputs outputs target #:key source inputs native-inputs outputs
system target
(perl (default-perl)) (perl (default-perl))
#:allow-other-keys #:allow-other-keys
#:rest arguments) #:rest arguments)
@ -54,6 +55,7 @@ (define private-keywords
(and (not target) ;XXX: no cross-compilation (and (not target) ;XXX: no cross-compilation
(bag (bag
(name name) (name name)
(system system)
(host-inputs `(,@(if source (host-inputs `(,@(if source
`(("source" ,source)) `(("source" ,source))
'()) '())

View file

@ -93,7 +93,7 @@ (define package-with-python2
(cut package-with-explicit-python <> (default-python2) "python-" "python2-")) (cut package-with-explicit-python <> (default-python2) "python-" "python2-"))
(define* (lower name (define* (lower name
#:key source inputs native-inputs outputs target #:key source inputs native-inputs outputs system target
(python (default-python)) (python (default-python))
#:allow-other-keys #:allow-other-keys
#:rest arguments) #:rest arguments)
@ -104,6 +104,7 @@ (define private-keywords
(and (not target) ;XXX: no cross-compilation (and (not target) ;XXX: no cross-compilation
(bag (bag
(name name) (name name)
(system system)
(host-inputs `(,@(if source (host-inputs `(,@(if source
`(("source" ,source)) `(("source" ,source))
'()) '())

View file

@ -35,7 +35,7 @@ (define (default-ruby)
(module-ref ruby 'ruby))) (module-ref ruby 'ruby)))
(define* (lower name (define* (lower name
#:key source inputs native-inputs outputs target #:key source inputs native-inputs outputs system target
(ruby (default-ruby)) (ruby (default-ruby))
#:allow-other-keys #:allow-other-keys
#:rest arguments) #:rest arguments)
@ -46,6 +46,7 @@ (define private-keywords
(and (not target) ;XXX: no cross-compilation (and (not target) ;XXX: no cross-compilation
(bag (bag
(name name) (name name)
(system system)
(host-inputs `(,@(if source (host-inputs `(,@(if source
`(("source" ,source)) `(("source" ,source))
'()) '())

View file

@ -35,11 +35,12 @@ (define (guile-for-build store guile system)
(package-derivation store guile system))))) (package-derivation store guile system)))))
(define* (lower name (define* (lower name
#:key source inputs native-inputs outputs target #:key source inputs native-inputs outputs system target
guile builder modules) guile builder modules)
"Return a bag for NAME." "Return a bag for NAME."
(bag (bag
(name name) (name name)
(system system)
(host-inputs `(,@(if source (host-inputs `(,@(if source
`(("source" ,source)) `(("source" ,source))
'()) '())

View file

@ -95,6 +95,7 @@ (define-module (guix packages)
package-cross-build-system-error? package-cross-build-system-error?
package->bag package->bag
bag->derivation
bag-transitive-inputs bag-transitive-inputs
bag-transitive-host-inputs bag-transitive-host-inputs
bag-transitive-build-inputs bag-transitive-build-inputs
@ -629,6 +630,7 @@ (define* (package->bag package #:optional
args inputs propagated-inputs native-inputs self-native-input? args inputs propagated-inputs native-inputs self-native-input?
outputs) outputs)
(or (make-bag build-system (package-full-name package) (or (make-bag build-system (package-full-name package)
#:system system
#:target target #:target target
#:source source #:source source
#:inputs (append (inputs) #:inputs (append (inputs)
@ -647,18 +649,16 @@ (define* (package->bag package #:optional
(&package-error (&package-error
(package package)))))))))) (package package))))))))))
(define* (package-derivation store package (define* (bag->derivation store bag
#:optional (system (%current-system))) #:optional context)
"Return the <derivation> object of PACKAGE for SYSTEM." "Return the derivation to build BAG for SYSTEM. Optionally, CONTEXT can be
a package object describing the context in which the call occurs, for improved
;; Compute the derivation and cache the result. Caching is important error reporting."
;; because some derivations, such as the implicit inputs of the GNU build (if (bag-target bag)
;; system, will be queried many, many times in a row. (bag->cross-derivation store bag)
(cached package system (let* ((system (bag-system bag))
(let* ((bag (package->bag package system #f))
(inputs (bag-transitive-inputs bag)) (inputs (bag-transitive-inputs bag))
(input-drvs (map (cut expand-input (input-drvs (map (cut expand-input store context <> system)
store package <> system)
inputs)) inputs))
(paths (delete-duplicates (paths (delete-duplicates
(append-map (match-lambda (append-map (match-lambda
@ -669,30 +669,26 @@ (define* (package-derivation store package
inputs)))) inputs))))
(apply (bag-build bag) (apply (bag-build bag)
store (bag-name bag) store (bag-name bag) input-drvs
input-drvs
#:search-paths paths #:search-paths paths
#:outputs (bag-outputs bag) #:system system #:outputs (bag-outputs bag) #:system system
(bag-arguments bag))))) (bag-arguments bag)))))
(define* (package-cross-derivation store package target (define* (bag->cross-derivation store bag
#:optional (system (%current-system))) #:optional context)
"Cross-build PACKAGE for TARGET (a GNU triplet) from host SYSTEM (a Guix "Return the derivation to build BAG, which is actually a cross build.
system identifying string)." Optionally, CONTEXT can be a package object denoting the context of the call.
(cached package (cons system target) This is an internal procedure."
(let* ((bag (package->bag package system target)) (let* ((system (bag-system bag))
(target (bag-target bag))
(host (bag-transitive-host-inputs bag)) (host (bag-transitive-host-inputs bag))
(host-drvs (map (cut expand-input (host-drvs (map (cut expand-input store context <> system target)
store package <>
system target)
host)) host))
(target* (bag-transitive-target-inputs bag)) (target* (bag-transitive-target-inputs bag))
(target-drvs (map (cut expand-input (target-drvs (map (cut expand-input store context <> system)
store package <> system)
target*)) target*))
(build (bag-transitive-build-inputs bag)) (build (bag-transitive-build-inputs bag))
(build-drvs (map (cut expand-input (build-drvs (map (cut expand-input store context <> system)
store package <> system)
build)) build))
(all (append build target* host)) (all (append build target* host))
(paths (delete-duplicates (paths (delete-duplicates
@ -717,7 +713,26 @@ (define* (package-cross-derivation store package target
#:native-search-paths npaths #:native-search-paths npaths
#:outputs (bag-outputs bag) #:outputs (bag-outputs bag)
#:system system #:target target #:system system #:target target
(bag-arguments bag))))) (bag-arguments bag))))
(define* (package-derivation store package
#:optional (system (%current-system)))
"Return the <derivation> object of PACKAGE for SYSTEM."
;; Compute the derivation and cache the result. Caching is important
;; because some derivations, such as the implicit inputs of the GNU build
;; system, will be queried many, many times in a row.
(cached package system
(bag->derivation store (package->bag package system #f)
package)))
(define* (package-cross-derivation store package target
#:optional (system (%current-system)))
"Cross-build PACKAGE for TARGET (a GNU triplet) from host SYSTEM (a Guix
system identifying string)."
(cached package (cons system target)
(bag->derivation store (package->bag package system target)
package)))
(define* (package-output store package (define* (package-output store package
#:optional (output "out") (system (%current-system))) #:optional (output "out") (system (%current-system)))

View file

@ -281,9 +281,11 @@ (define read-at
(s (build-system (s (build-system
(name 'raw) (name 'raw)
(description "Raw build system with direct store access") (description "Raw build system with direct store access")
(lower (lambda* (name #:key source inputs #:allow-other-keys) (lower (lambda* (name #:key source inputs system target
#:allow-other-keys)
(bag (bag
(name name) (name name)
(system system) (target target)
(build-inputs inputs) (build-inputs inputs)
(build (build
(lambda* (store name inputs (lambda* (store name inputs
@ -339,6 +341,38 @@ (define read-at
(package-cross-derivation %store p "mips64el-linux-gnu") (package-cross-derivation %store p "mips64el-linux-gnu")
#f))) #f)))
(test-equal "package->bag"
`("foo86-hurd" #f (,(package-source gnu-make))
(,(canonical-package glibc)) (,(canonical-package coreutils)))
(let ((bag (package->bag gnu-make "foo86-hurd")))
(list (bag-system bag) (bag-target bag)
(assoc-ref (bag-build-inputs bag) "source")
(assoc-ref (bag-build-inputs bag) "libc")
(assoc-ref (bag-build-inputs bag) "coreutils"))))
(test-equal "package->bag, cross-compilation"
`(,(%current-system) "foo86-hurd"
(,(package-source gnu-make))
(,(canonical-package glibc)) (,(canonical-package coreutils)))
(let ((bag (package->bag gnu-make (%current-system) "foo86-hurd")))
(list (bag-system bag) (bag-target bag)
(assoc-ref (bag-build-inputs bag) "source")
(assoc-ref (bag-build-inputs bag) "libc")
(assoc-ref (bag-build-inputs bag) "coreutils"))))
(test-assert "bag->derivation"
(let ((bag (package->bag gnu-make))
(drv (package-derivation %store gnu-make)))
(parameterize ((%current-system "foox86-hurd")) ;should have no effect
(equal? drv (bag->derivation %store bag)))))
(test-assert "bag->derivation, cross-compilation"
(let ((bag (package->bag gnu-make (%current-system) "mips64el-linux-gnu"))
(drv (package-cross-derivation %store gnu-make "mips64el-linux-gnu")))
(parameterize ((%current-system "foox86-hurd") ;should have no effect
(%current-target-system "foo64-linux-gnu"))
(equal? drv (bag->derivation %store bag)))))
(unless (false-if-exception (getaddrinfo "www.gnu.org" "80" AI_NUMERICSERV)) (unless (false-if-exception (getaddrinfo "www.gnu.org" "80" AI_NUMERICSERV))
(test-skip 1)) (test-skip 1))
(test-assert "GNU Make, bootstrap" (test-assert "GNU Make, bootstrap"