;;; GNU Guix --- Functional package management for GNU ;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018 Ludovic Courtès ;;; Copyright © 2017 Jan Nieuwenhuizen ;;; Copyright © 2018, 2019 Clément Lassieur ;;; ;;; This file is part of GNU Guix. ;;; ;;; GNU Guix is free software; you can redistribute it and/or modify it ;;; under the terms of the GNU General Public License as published by ;;; the Free Software Foundation; either version 3 of the License, or (at ;;; your option) any later version. ;;; ;;; GNU Guix is distributed in the hope that it will be useful, but ;;; WITHOUT ANY WARRANTY; without even the implied warranty of ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;;; GNU General Public License for more details. ;;; ;;; You should have received a copy of the GNU General Public License ;;; along with GNU Guix. If not, see . ;;; ;;; This file defines build jobs for the Hydra continuation integration ;;; tool. ;;; (use-modules (guix inferior) (guix channels) (guix) (guix ui) (srfi srfi-1) (ice-9 match)) ;; XXX: Debugging hack: since `hydra-eval-guile-jobs' redirects the output ;; port to the bit bucket, let us write to the error port instead. (setvbuf (current-error-port) _IOLBF) (set-current-output-port (current-error-port)) (define (find-current-checkout arguments) "Find the first checkout of ARGUMENTS that provided the current file. Return #f if no such checkout is found." (let ((current-root (canonicalize-path (string-append (dirname (current-filename)) "/../..")))) (find (lambda (argument) (and=> (assq-ref argument 'file-name) (lambda (name) (string=? name current-root)))) arguments))) (define (hydra-jobs store arguments) "Return a list of jobs where each job is a NAME/THUNK pair." (define checkout (find-current-checkout arguments)) (define commit (assq-ref checkout 'revision)) (define source (assq-ref checkout 'file-name)) (define instance (checkout->channel-instance source #:commit commit)) (define derivation ;; Compute the derivation of Guix for COMMIT. (run-with-store store (channel-instances->derivation (list instance)))) (show-what-to-build store (list derivation)) (build-derivations store (list derivation)) ;; Open an inferior for the just-built Guix. (let ((inferior (open-inferior (derivation->output-path derivation)))) (inferior-eval '(use-modules (gnu ci) (ice-9 match)) inferior) (map (match-lambda ((name . fields) ;; Hydra expects a thunk, so here it is. (cons name (lambda () fields)))) (inferior-eval-with-store inferior store `(lambda (store) (map (match-lambda ((name . thunk) (cons name (thunk)))) (hydra-jobs store '((superior-guix-checkout . ,checkout) ,@arguments)))))))) tion value='15'>15space:mode:
authorLudovic Courtès <ludo@gnu.org>2019-11-23 16:10:47 +0100
committerLudovic Courtès <ludo@gnu.org>2019-11-23 22:45:21 +0100
commit01c11aeb9516819cec3053a5abbd839b9205b60c (patch)
treee033db6d80a181479bb1607f6ae285aeda42cc32 /gnu/packages/ghostscript.scm
parent60353203ed9322326590cec30ff8ca870f694288 (diff)
downloadguix-01c11aeb9516819cec3053a5abbd839b9205b60c.tar.gz
guix-01c11aeb9516819cec3053a5abbd839b9205b60c.zip
gnu: guile-git: Add "guile3.0-git" variant.
* gnu/packages/guile.scm (guile-git)[source](modules, snippet): New fields. * gnu/packages/guile.scm (guile3.0-git): New variable.
Diffstat (limited to 'gnu/packages/ghostscript.scm')
0 files changed, 0 insertions, 0 deletions