summaryrefslogtreecommitdiff
path: root/guix/import
diff options
context:
space:
mode:
authorLudovic Courtès <ludo@gnu.org>2014-11-11 15:30:58 +0100
committerLudovic Courtès <ludo@gnu.org>2014-11-11 15:31:35 +0100
commit7047133f0777789107bd9f61f62c7d6ca10ed164 (patch)
tree3d7cfbdd51d0dc54cd83cb9aa58c0692b4274bc4 /guix/import
parent501d76475185127388c7776f89fb6526db4f1336 (diff)
import: Add GNU importer.
Suggested by Karl Berry <karl@gnu.org> and Andreas Enge <andreas@enge.fr>. * guix/import/gnu.scm, guix/scripts/import/gnu.scm: New files. * Makefile.am (MODULES): Add them. * guix/scripts/import.scm (importers): Add "gnu". * guix/gnu-maintenance.scm (gnu-release-archive-types): New procedure. (download-tarball): Export.
Diffstat (limited to 'guix/import')
-rw-r--r--guix/import/gnu.scm116
1 files changed, 116 insertions, 0 deletions
diff --git a/guix/import/gnu.scm b/guix/import/gnu.scm
new file mode 100644
index 0000000000..763b8d2a12
--- /dev/null
+++ b/guix/import/gnu.scm
@@ -0,0 +1,116 @@
+;;; GNU Guix --- Functional package management for GNU
+;;; Copyright © 2014 Ludovic Courtès <ludo@gnu.org>
+;;;
+;;; 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 <http://www.gnu.org/licenses/>.
+
+(define-module (guix import gnu)
+ #:use-module (guix gnu-maintenance)
+ #:use-module (guix utils)
+ #:use-module (guix store)
+ #:use-module (guix hash)
+ #:use-module (guix base32)
+ #:use-module (srfi srfi-1)
+ #:use-module (srfi srfi-11)
+ #:use-module (srfi srfi-26)
+ #:use-module (srfi srfi-34)
+ #:use-module (srfi srfi-35)
+ #:use-module (ice-9 match)
+ #:use-module (ice-9 regex)
+ #:export (gnu->guix-package))
+
+;;; Commentary:
+;;;
+;;; Generate a package declaration template for the latest version of a GNU
+;;; package, using meta-data available upstream for the package.
+;;;
+;;; Code:
+
+(define (file-sha256 file)
+ "Return the SHA256 hash of FILE as a bytevector."
+ (call-with-input-file file port-sha256))
+
+(define (qualified-url url)
+ "Return a fully-qualified URL based on URL."
+ (if (string-prefix? "/" url)
+ (string-append "http://www.gnu.org" url)
+ url))
+
+(define (preferred-archive-type release)
+ "Return the preferred type of archive for downloading RELEASE."
+ (find (cute member <> (gnu-release-archive-types release))
+ '("xz" "lz" "bz2" "tbz2" "gz" "tgz" "Z")))
+
+(define* (gnu-package->sexp package release
+ #:key (key-download 'interactive))
+ "Return the 'package' sexp for the RELEASE (a <gnu-release>) of PACKAGE (a
+<gnu-package>). Use KEY-DOWNLOAD as the OpenPGP key download policy (see
+'download-tarball' for details.)"
+ (define name
+ (gnu-package-name package))
+
+ (define url-base
+ ;; XXX: We assume that RELEASE's directory starts with "/gnu".
+ (string-append "mirror:/" (gnu-release-directory release)
+ "/" name "-"))
+
+ (define archive-type
+ (preferred-archive-type release))
+
+ (let ((tarball (with-store store
+ (download-tarball store name
+ (gnu-release-directory release)
+ (gnu-release-version release)
+ #:archive-type archive-type
+ #:key-download key-download))))
+ `(package
+ (name ,name)
+ (version ,(gnu-release-version release))
+ (source (origin
+ (method url-fetch)
+ (uri (string-append ,url-base version
+ ,(string-append ".tar." archive-type)))
+ (sha256
+ (base32
+ ,(bytevector->base32-string (file-sha256 tarball))))))
+ (build-system gnu-build-system)
+ (synopsis ,(gnu-package-doc-summary package))
+ (description ,(gnu-package-doc-description package))
+ (home-page ,(match (gnu-package-doc-urls package)
+ ((head . tail) (qualified-url head))))
+ (license find-by-yourself!))))
+
+(define* (gnu->guix-package name
+ #:key (key-download 'interactive))
+ "Return the package declaration for NAME as an s-expression. Use
+KEY-DOWNLOAD as the OpenPGP key download policy (see 'download-tarball' for
+details.)"
+ (match (latest-release name)
+ ((? gnu-release? release)
+ (let ((version (gnu-release-version release)))
+ (match (find-packages (regexp-quote name))
+ ((info . _)
+ (gnu-package->sexp info release))
+ (()
+ (raise (condition
+ (&message
+ (message "couldn't find meta-data for GNU package"))))))))
+ (_
+ (raise (condition
+ (&message
+ (message
+ "failed to determine latest release of GNU package")))))))
+
+;;; gnu.scm ends here