aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristopher Baines <mail@cbaines.net>2019-12-31 08:44:12 +0000
committerChristopher Baines <mail@cbaines.net>2019-12-31 10:23:29 +0000
commitdf9d0bbdd173cbff294511d0f3d571926c3329a3 (patch)
treeade01c376bed50bc8933d50326bb2bca07bbcc8a
parent2cb5309851b3868dcdb0e88145d676b474c575aa (diff)
downloaddata-service-df9d0bbdd173cbff294511d0f3d571926c3329a3.tar
data-service-df9d0bbdd173cbff294511d0f3d571926c3329a3.tar.gz
Improve generating derivations for foreign architectures
Use the second argument to package-transitive-supported-systems to correctly identify the different bootstrap path for non x86_64 and i686-linux. The previous implementation did work, but only up until a merge of core-updates changed the bootstrap approach.
-rw-r--r--guix-data-service/jobs/load-new-guix-revision.scm107
1 files changed, 65 insertions, 42 deletions
diff --git a/guix-data-service/jobs/load-new-guix-revision.scm b/guix-data-service/jobs/load-new-guix-revision.scm
index 235ded0..7782758 100644
--- a/guix-data-service/jobs/load-new-guix-revision.scm
+++ b/guix-data-service/jobs/load-new-guix-revision.scm
@@ -353,59 +353,82 @@ WHERE job_id = $1"
(define (proc packages system-target-pairs)
`(lambda (store)
+ (define package-transitive-supported-systems-supports-multiple-arguments? #t)
+
+ (define (get-supported-systems package system)
+ (or (and package-transitive-supported-systems-supports-multiple-arguments?
+ (catch
+ 'wrong-number-of-args
+ (lambda ()
+ (package-transitive-supported-systems package system))
+ (lambda (key . args)
+ ;; Older Guix revisions don't support two
+ ;; arguments to
+ ;; package-transitive-supported-systems
+ (simple-format
+ (current-error-port)
+ "info: package-transitive-supported-systems doesn't support two arguments, falling back to one\n")
+ (set! package-transitive-supported-systems-supports-multiple-arguments? #f)
+ #f)))
+ (catch
+ #t
+ (lambda ()
+ (package-transitive-supported-systems package))
+ (lambda (key . args)
+ (simple-format
+ (current-error-port)
+ "error: while processing ~A, unable to compute transitive supported systems\n"
+ (package-name package))
+ (simple-format
+ (current-error-port)
+ "error ~A: ~A\n" key args)
+ #f))))
+
+ (define (derivations-for-system-and-target inferior-package-id package system target)
+ (catch
+ 'misc-error
+ (lambda ()
+ (guard (c ((package-cross-build-system-error? c)
+ #f))
+ (list inferior-package-id
+ system
+ target
+ (derivation-file-name
+ (if (string=? system target)
+ (package-derivation store package system)
+ (package-cross-derivation store package
+ target
+ system))))))
+ (lambda args
+ ;; misc-error #f ~A ~S (No
+ ;; cross-compilation for
+ ;; clojure-build-system yet:
+ #f)))
+
(append-map
(lambda (inferior-package-id)
(let ((package (hashv-ref %package-table inferior-package-id)))
(catch
#t
(lambda ()
- (let ((supported-systems
- (catch
- #t
- (lambda ()
- (package-transitive-supported-systems package))
- (lambda (key . args)
- (simple-format
- (current-error-port)
- "error: while processing ~A, unable to compute transitive supported systems\n"
- (package-name package))
- (simple-format
- (current-error-port)
- "error ~A: ~A\n" key args)
- #f))))
- (if supported-systems
- (append-map
- (lambda (system)
+ (append-map
+ (lambda (system)
+ (let ((supported-systems (get-supported-systems package system)))
+ (if supported-systems
(filter-map
(lambda (target)
- (catch
- 'misc-error
- (lambda ()
- (guard (c ((package-cross-build-system-error? c)
- #f))
- (list inferior-package-id
- system
- target
- (derivation-file-name
- (if (string=? system target)
- (package-derivation store package system)
- (package-cross-derivation store package
- target
- system))))))
- (lambda args
- ;; misc-error #f ~A ~S (No
- ;; cross-compilation for
- ;; clojure-build-system yet:
- #f)))
+ (derivations-for-system-and-target inferior-package-id
+ package
+ system
+ target))
(lset-intersection
string=?
supported-systems
- (list ,@(map cdr system-target-pairs)))))
- (lset-intersection
- string=?
- supported-systems
- (list ,@(map car system-target-pairs))))
- '())))
+ (list ,@(map cdr system-target-pairs))))
+ '())))
+ (delete-duplicates
+ (list ,@(map car system-target-pairs))
+ string=?)))
(lambda (key . args)
(if (and (eq? key 'system-error)
(eq? (car args) 'fport_write))