summary refs log tree commit diff
path: root/hydra.scm
diff options
context:
space:
mode:
authorLudovic Courtès <ludo@gnu.org>2013-05-24 23:12:56 +0200
committerLudovic Courtès <ludo@gnu.org>2013-05-24 23:12:56 +0200
commit929c0f69de155a1ca41296515541ee51856bd2bb (patch)
treefbe31a1a7601b671f0355524f07896cb75e7564f /hydra.scm
parente55ec43d8b98fed6c51d536c000f4fba72641c53 (diff)
downloadguix-929c0f69de155a1ca41296515541ee51856bd2bb.tar.gz
build: `hydra.scm' adds cross-build jobs.
* hydra.scm (package->alist): Add `package-derivation' argument.
  (package-cross-job): New procedure.
  (%packages-to-cross-build, %cross-targets): New variables.
  (hydra-jobs): Add cross jobs.
Diffstat (limited to 'hydra.scm')
-rw-r--r--hydra.scm44
1 files changed, 37 insertions, 7 deletions
diff --git a/hydra.scm b/hydra.scm
index 8cbfecf34c..9506cf0c94 100644
--- a/hydra.scm
+++ b/hydra.scm
@@ -42,6 +42,8 @@
              (gnu packages)
              (gnu packages base)
              (gnu packages guile)
+             (gnu packages multiprecision)
+             (gnu packages make-bootstrap)
              (srfi srfi-1)
              (srfi srfi-26)
              (ice-9 match))
@@ -51,7 +53,8 @@
 (setvbuf (current-error-port) _IOLBF)
 (set-current-output-port (current-error-port))
 
-(define (package->alist store package system)
+(define* (package->alist store package system
+                         #:optional (package-derivation package-derivation))
   "Convert PACKAGE to an alist suitable for Hydra."
   `((derivation . ,(package-derivation store package system))
     (description . ,(package-synopsis package))
@@ -64,12 +67,41 @@
   "Return a job called JOB-NAME that builds PACKAGE on SYSTEM."
   `(,job-name . ,(cut package->alist store package system)))
 
+(define (package-cross-job store job-name package target system)
+  "Return a job called TARGET.JOB-NAME that cross-builds PACKAGE for TARGET on
+SYSTEM."
+  `(,(symbol-append (string->symbol target) (string->symbol ".") job-name) .
+    ,(cute package->alist store package system
+           (cut package-cross-derivation <> <> target <>))))
+
+(define %packages-to-cross-build
+  (list gmp mpfr mpc coreutils findutils diffutils patch hello guile-2.0
+        %bootstrap-binaries-tarball
+        %binutils-bootstrap-tarball
+        %glibc-bootstrap-tarball
+        %gcc-bootstrap-tarball
+        %guile-bootstrap-tarball))
+
+(define %cross-targets
+  '("mips64el-linux-gnu"))
+
 (define (hydra-jobs store arguments)
   "Return Hydra jobs."
   (define system
     (or (assoc-ref arguments system)
         (%current-system)))
 
+  (define job-name
+    (compose string->symbol package-full-name))
+
+  (define cross-jobs
+    (append-map (lambda (target)
+                  (map (lambda (package)
+                         (package-cross-job store (job-name package)
+                                            package target system))
+                       %packages-to-cross-build))
+                %cross-targets))
+
   ;; Return one job for each package, except bootstrap packages.
   (let ((base-packages (delete-duplicates
                         (append-map (match-lambda
@@ -82,9 +114,7 @@
     (fold-packages (lambda (package result)
                      (if (member package base-packages)
                          result
-                         (let ((name (string->symbol
-                                      (package-full-name package))))
-                           (cons (package-job store name package
-                                              system)
-                                 result))))
-                   '())))
+                         (cons (package-job store (job-name package)
+                                            package system)
+                               result)))
+                   cross-jobs)))