From 208f7cd155abdf07ae4f858aeeb26892eb08df88 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ludovic=20Court=C3=A8s?= Date: Wed, 27 Jun 2012 23:58:07 +0200 Subject: [PATCH] Abstract build systems. * Makefile.am (MODULES): Add `guix/build-system.scm' and `guix/build-system/gnu.scm'. Remove `guix/gnu-build-system.scm'. * guix/build-system.scm: New file. * guix/gnu-build-system.scm: Rename to... * guix/build-system/gnu.scm: ... this. (gnu-build-system): New variable. * tests/builders.scm: Adjust `use-module' clauses. ("gnu-build-system"): New test. --- Makefile.am | 3 +- guix/build-system.scm | 34 +++++++++++++++++++ .../gnu.scm} | 12 +++++-- tests/builders.scm | 7 +++- 4 files changed, 52 insertions(+), 4 deletions(-) create mode 100644 guix/build-system.scm rename guix/{gnu-build-system.scm => build-system/gnu.scm} (87%) diff --git a/Makefile.am b/Makefile.am index 814bd3b355..d41e55a188 100644 --- a/Makefile.am +++ b/Makefile.am @@ -18,7 +18,8 @@ MODULES = \ guix/derivations.scm \ - guix/gnu-build-system.scm \ + guix/build-system.scm \ + guix/build-system/gnu.scm \ guix/http.scm \ guix/store.scm \ guix/utils.scm \ diff --git a/guix/build-system.scm b/guix/build-system.scm new file mode 100644 index 0000000000..179e7ef2df --- /dev/null +++ b/guix/build-system.scm @@ -0,0 +1,34 @@ +;;; Guix --- Nix package management from Guile. -*- coding: utf-8 -*- +;;; Copyright (C) 2012 Ludovic Courtès +;;; +;;; This file is part of Guix. +;;; +;;; 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. +;;; +;;; 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 Guix. If not, see . + +(define-module (guix build-system) + #:use-module (guix utils) + #:export (build-system + build-system? + build-system-name + build-system-description + build-system-builder + build-system-cross-builder)) + +(define-record-type* build-system make-build-system + build-system? + (name build-system-name) ; symbol + (description build-system-description) ; short description + (build build-system-builder) ; (store system name source inputs) + (cross-build build-system-cross-builder ; (store system x-system ...) + (default #f))) diff --git a/guix/gnu-build-system.scm b/guix/build-system/gnu.scm similarity index 87% rename from guix/gnu-build-system.scm rename to guix/build-system/gnu.scm index 0311aaa76f..e9eb02f251 100644 --- a/guix/gnu-build-system.scm +++ b/guix/build-system/gnu.scm @@ -16,12 +16,14 @@ ;;; You should have received a copy of the GNU General Public License ;;; along with Guix. If not, see . -(define-module (guix gnu-build-system) +(define-module (guix build-system gnu) #:use-module (guix store) #:use-module (guix utils) #:use-module (guix derivations) + #:use-module (guix build-system) #:use-module (srfi srfi-1) - #:export (gnu-build)) + #:export (gnu-build + gnu-build-system)) ;; Commentary: ;; @@ -63,3 +65,9 @@ input derivation INPUTS, using the usual procedure of the GNU Build System." #:outputs outputs #:modules '((guix build gnu-build-system) (guix build utils)))) + +(define gnu-build-system + (build-system (name 'gnu) + (description + "The GNU Build System—i.e., ./configure && make && make install") + (build gnu-build))) ; TODO: add `gnu-cross-build' diff --git a/tests/builders.scm b/tests/builders.scm index 851baa9ebf..17bae2c754 100644 --- a/tests/builders.scm +++ b/tests/builders.scm @@ -19,7 +19,8 @@ (define-module (test-builders) #:use-module (guix http) - #:use-module (guix gnu-build-system) + #:use-module (guix build-system) + #:use-module (guix build-system gnu) #:use-module (guix store) #:use-module (guix utils) #:use-module (guix derivations) @@ -41,6 +42,10 @@ (and (build-derivations %store (list drv-path)) (file-exists? (derivation-path->output-path drv-path))))) +(test-assert "gnu-build-system" + (and (build-system? gnu-build-system) + (eq? gnu-build (build-system-builder gnu-build-system)))) + (test-assert "gnu-build" (let* ((url "http://ftp.gnu.org/gnu/hello/hello-2.8.tar.gz") (hash (nix-base32-string->bytevector