;;; GNU Guix --- Functional package management for GNU ;;; Copyright © 2013, 2014, 2016, 2017 Ludovic Courtès ;;; Copyright © 2015 Taylan Ulrich Bayırlı/Kammer ;;; ;;; 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 . (define-module (guix build pull) #:use-module (guix modules) #:use-module (guix build utils) #:use-module (guix build compile) #:use-module (ice-9 ftw) #:use-module (ice-9 match) #:use-module (ice-9 format) #:use-module (srfi srfi-1) #:use-module (srfi srfi-11) #:use-module (srfi srfi-26) #:use-module (srfi srfi-34) #:export (build-guix)) ;;; Commentary: ;;; ;;; Helpers for the 'guix pull' command to unpack and build Guix. ;;; ;;; Code: (define (has-all-its-dependencies? file) "Return true if the dependencies of the module defined in FILE are available, false otherwise." (let ((module (call-with-input-file file (lambda (port) (match (read port) (('define-module name _ ...) name)))))) ;; If one of the dependencies of MODULE is missing, we get a ;; '&missing-dependency-error'. (guard (c ((missing-dependency-error? c) #f)) (source-module-closure (list module) #:select? (const #t))))) (define (all-scheme-files directory) "Return a sorted list of Scheme files found in DIRECTORY." ;; Load guix/ modules before gnu/ modules to get somewhat steadier ;; progress reporting. (sort (filter (cut string-suffix? ".scm" <>) (find-files directory "\\.scm")) (let ((guix (string-append directory "/guix")) (gnu (string-append directory "/gnu"))) (lambda (a b) (or (and (string-prefix? guix a) (string-prefix? gnu b)) (string