2015-07-24 10:49:57 -04:00
|
|
|
|
;;; GNU Guix --- Functional package management for GNU
|
2021-01-20 11:04:38 -05:00
|
|
|
|
;;; Copyright © 2015, 2016, 2017, 2018, 2019, 2020, 2021 Ricardo Wurmus <rekado@elephly.net>
|
2020-01-03 10:01:11 -05:00
|
|
|
|
;;; Copyright © 2015, 2016, 2017, 2019, 2020 Ludovic Courtès <ludo@gnu.org>
|
2017-05-04 05:52:33 -04:00
|
|
|
|
;;; Copyright © 2017 Mathieu Othacehe <m.othacehe@gmail.com>
|
2020-02-04 07:18:18 -05:00
|
|
|
|
;;; Copyright © 2020 Martin Becze <mjbecze@riseup.net>
|
2015-07-24 10:49:57 -04:00
|
|
|
|
;;;
|
|
|
|
|
;;; 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 cran)
|
|
|
|
|
#:use-module (ice-9 match)
|
|
|
|
|
#:use-module (ice-9 regex)
|
2020-03-25 04:36:58 -04:00
|
|
|
|
#:use-module (ice-9 popen)
|
2017-03-27 06:53:13 -04:00
|
|
|
|
#:use-module ((ice-9 rdelim) #:select (read-string read-line))
|
2015-07-24 10:49:57 -04:00
|
|
|
|
#:use-module (srfi srfi-1)
|
2018-12-20 03:37:58 -05:00
|
|
|
|
#:use-module (srfi srfi-2)
|
2019-08-27 18:38:31 -04:00
|
|
|
|
#:use-module (srfi srfi-11)
|
2015-10-21 08:36:14 -04:00
|
|
|
|
#:use-module (srfi srfi-26)
|
2016-12-17 09:24:45 -05:00
|
|
|
|
#:use-module (srfi srfi-34)
|
2020-12-11 18:06:18 -05:00
|
|
|
|
#:use-module (srfi srfi-35)
|
2016-05-17 09:17:54 -04:00
|
|
|
|
#:use-module (ice-9 receive)
|
2016-12-17 09:24:45 -05:00
|
|
|
|
#:use-module (web uri)
|
Add (guix memoization).
* guix/combinators.scm (memoize): Remove.
* guix/memoization.scm: New file.
* Makefile.am (MODULES): Add it.
* gnu/packages.scm, gnu/packages/bootstrap.scm,
guix/build-system/gnu.scm, guix/build-system/python.scm,
guix/derivations.scm, guix/gnu-maintenance.scm,
guix/import/cran.scm, guix/import/elpa.scm,
guix/modules.scm, guix/scripts/build.scm,
guix/scripts/graph.scm, guix/scripts/lint.scm,
guix/store.scm, guix/utils.scm: Adjust imports accordingly.
2017-01-28 10:33:57 -05:00
|
|
|
|
#:use-module (guix memoization)
|
2015-07-24 10:49:57 -04:00
|
|
|
|
#:use-module (guix http-client)
|
Switch to Guile-Gcrypt.
This removes (guix hash) and (guix pk-crypto), which now live as part of
Guile-Gcrypt (version 0.1.0.)
* guix/gcrypt.scm, guix/hash.scm, guix/pk-crypto.scm,
tests/hash.scm, tests/pk-crypto.scm: Remove.
* configure.ac: Test for Guile-Gcrypt. Remove LIBGCRYPT and
LIBGCRYPT_LIBDIR assignments.
* m4/guix.m4 (GUIX_ASSERT_LIBGCRYPT_USABLE): Remove.
* README: Add Guile-Gcrypt to the dependencies; move libgcrypt as
"required unless --disable-daemon".
* doc/guix.texi (Requirements): Likewise.
* gnu/packages/bash.scm, guix/derivations.scm, guix/docker.scm,
guix/git.scm, guix/http-client.scm, guix/import/cpan.scm,
guix/import/cran.scm, guix/import/crate.scm, guix/import/elpa.scm,
guix/import/gnu.scm, guix/import/hackage.scm,
guix/import/texlive.scm, guix/import/utils.scm, guix/nar.scm,
guix/pki.scm, guix/scripts/archive.scm,
guix/scripts/authenticate.scm, guix/scripts/download.scm,
guix/scripts/hash.scm, guix/scripts/pack.scm,
guix/scripts/publish.scm, guix/scripts/refresh.scm,
guix/scripts/substitute.scm, guix/store.scm,
guix/store/deduplication.scm, guix/tests.scm, tests/base32.scm,
tests/builders.scm, tests/challenge.scm, tests/cpan.scm,
tests/crate.scm, tests/derivations.scm, tests/gem.scm,
tests/nar.scm, tests/opam.scm, tests/pki.scm,
tests/publish.scm, tests/pypi.scm, tests/store-deduplication.scm,
tests/store.scm, tests/substitute.scm: Adjust imports.
* gnu/system/vm.scm: Likewise.
(guile-sqlite3&co): Rename to...
(gcrypt-sqlite3&co): ... this. Add GUILE-GCRYPT.
(expression->derivation-in-linux-vm)[config]: Remove.
(iso9660-image)[config]: Remove.
(qemu-image)[config]: Remove.
(system-docker-image)[config]: Remove.
* guix/scripts/pack.scm: Adjust imports.
(guile-sqlite3&co): Rename to...
(gcrypt-sqlite3&co): ... this. Add GUILE-GCRYPT.
(self-contained-tarball)[build]: Call 'make-config.scm' without
#:libgcrypt argument.
(squashfs-image)[libgcrypt]: Remove.
[build]: Call 'make-config.scm' without #:libgcrypt.
(docker-image)[config, json]: Remove.
[build]: Add GUILE-GCRYPT to the extensions Remove (guix config) from
the imported modules.
* guix/self.scm (specification->package): Remove "libgcrypt", add
"guile-gcrypt".
(compiled-guix): Remove #:libgcrypt.
[guile-gcrypt]: New variable.
[dependencies]: Add it.
[*core-modules*]: Remove #:libgcrypt from 'make-config.scm' call.
Add #:extensions.
[*config*]: Remove #:libgcrypt from 'make-config.scm' call.
(%dependency-variables): Remove %libgcrypt.
(make-config.scm): Remove #:libgcrypt.
* build-aux/build-self.scm (guile-gcrypt): New variable.
(make-config.scm): Remove #:libgcrypt.
(build-program)[fake-gcrypt-hash]: New variable.
Add (gcrypt hash) to the imported modules. Adjust load path
assignments.
* gnu/packages/package-management.scm (guix)[propagated-inputs]: Add
GUILE-GCRYPT.
[arguments]: In 'wrap-program' phase, add GUILE-GCRYPT to the search
path.
2018-08-31 11:07:07 -04:00
|
|
|
|
#:use-module (gcrypt hash)
|
2015-07-24 10:49:57 -04:00
|
|
|
|
#:use-module (guix store)
|
2019-08-27 18:38:31 -04:00
|
|
|
|
#:use-module ((guix serialization) #:select (write-file))
|
2015-07-24 10:49:57 -04:00
|
|
|
|
#:use-module (guix base32)
|
|
|
|
|
#:use-module ((guix download) #:select (download-to-store))
|
|
|
|
|
#:use-module (guix import utils)
|
2020-03-25 04:36:58 -04:00
|
|
|
|
#:use-module ((guix build utils)
|
|
|
|
|
#:select (find-files
|
|
|
|
|
delete-file-recursively
|
|
|
|
|
with-directory-excursion))
|
2017-03-27 06:53:13 -04:00
|
|
|
|
#:use-module (guix utils)
|
2019-08-27 18:38:31 -04:00
|
|
|
|
#:use-module (guix git)
|
2015-12-16 08:45:28 -05:00
|
|
|
|
#:use-module ((guix build-system r) #:select (cran-uri bioconductor-uri))
|
2020-03-25 11:27:22 -04:00
|
|
|
|
#:use-module (guix ui)
|
2015-10-21 08:36:14 -04:00
|
|
|
|
#:use-module (guix upstream)
|
|
|
|
|
#:use-module (guix packages)
|
2016-05-17 10:38:17 -04:00
|
|
|
|
#:use-module (gnu packages)
|
2020-12-17 04:40:30 -05:00
|
|
|
|
#:export (%input-style
|
|
|
|
|
|
|
|
|
|
cran->guix-package
|
2015-12-16 08:45:28 -05:00
|
|
|
|
bioconductor->guix-package
|
2018-06-08 06:46:43 -04:00
|
|
|
|
cran-recursive-import
|
2015-12-16 08:45:28 -05:00
|
|
|
|
%cran-updater
|
2017-05-16 15:42:18 -04:00
|
|
|
|
%bioconductor-updater
|
2019-09-16 05:16:40 -04:00
|
|
|
|
%bioconductor-version
|
2017-05-16 15:42:18 -04:00
|
|
|
|
|
|
|
|
|
cran-package?
|
|
|
|
|
bioconductor-package?
|
|
|
|
|
bioconductor-data-package?
|
2020-01-16 15:47:36 -05:00
|
|
|
|
bioconductor-experiment-package?
|
|
|
|
|
|
|
|
|
|
description->alist
|
|
|
|
|
description->package))
|
2015-07-24 10:49:57 -04:00
|
|
|
|
|
|
|
|
|
;;; Commentary:
|
|
|
|
|
;;;
|
|
|
|
|
;;; Generate a package declaration template for the latest version of an R
|
2015-12-03 10:12:09 -05:00
|
|
|
|
;;; package on CRAN, using the DESCRIPTION file downloaded from
|
2015-07-24 10:49:57 -04:00
|
|
|
|
;;; cran.r-project.org.
|
|
|
|
|
;;;
|
|
|
|
|
;;; Code:
|
|
|
|
|
|
2020-12-17 04:40:30 -05:00
|
|
|
|
(define %input-style
|
|
|
|
|
(make-parameter 'variable)) ; or 'specification
|
|
|
|
|
|
2015-07-24 10:49:57 -04:00
|
|
|
|
(define string->license
|
|
|
|
|
(match-lambda
|
|
|
|
|
("AGPL-3" 'agpl3+)
|
|
|
|
|
("Artistic-2.0" 'artistic2.0)
|
|
|
|
|
("Apache License 2.0" 'asl2.0)
|
|
|
|
|
("BSD_2_clause" 'bsd-2)
|
2016-12-08 08:37:32 -05:00
|
|
|
|
("BSD_2_clause + file LICENSE" 'bsd-2)
|
2015-07-24 10:49:57 -04:00
|
|
|
|
("BSD_3_clause" 'bsd-3)
|
2016-12-08 08:37:32 -05:00
|
|
|
|
("BSD_3_clause + file LICENSE" 'bsd-3)
|
2017-06-26 16:02:24 -04:00
|
|
|
|
("GPL" '(list gpl2+ gpl3+))
|
2015-12-03 09:00:43 -05:00
|
|
|
|
("GPL (>= 2)" 'gpl2+)
|
|
|
|
|
("GPL (>= 3)" 'gpl3+)
|
2016-12-08 08:35:20 -05:00
|
|
|
|
("GPL-2" 'gpl2)
|
|
|
|
|
("GPL-3" 'gpl3)
|
|
|
|
|
("LGPL-2" 'lgpl2.0)
|
|
|
|
|
("LGPL-2.1" 'lgpl2.1)
|
|
|
|
|
("LGPL-3" 'lgpl3)
|
2015-12-03 09:00:43 -05:00
|
|
|
|
("LGPL (>= 2)" 'lgpl2.0+)
|
2019-12-14 07:34:53 -05:00
|
|
|
|
("LGPL (>= 2.1)" 'lgpl2.1+)
|
2015-12-03 09:00:43 -05:00
|
|
|
|
("LGPL (>= 3)" 'lgpl3+)
|
2016-12-08 08:36:27 -05:00
|
|
|
|
("MIT" 'expat)
|
|
|
|
|
("MIT + file LICENSE" 'expat)
|
2015-07-24 10:49:57 -04:00
|
|
|
|
((x) (string->license x))
|
|
|
|
|
((lst ...) `(list ,@(map string->license lst)))
|
|
|
|
|
(_ #f)))
|
|
|
|
|
|
2015-12-03 10:12:09 -05:00
|
|
|
|
|
|
|
|
|
(define (description->alist description)
|
|
|
|
|
"Convert a DESCRIPTION string into an alist."
|
|
|
|
|
(let ((lines (string-split description #\newline))
|
|
|
|
|
(parse (lambda (line acc)
|
|
|
|
|
(if (string-null? line) acc
|
|
|
|
|
;; Keys usually start with a capital letter and end with
|
|
|
|
|
;; ":". There are some exceptions, unfortunately (such
|
|
|
|
|
;; as "biocViews"). There are no blanks in a key.
|
|
|
|
|
(if (string-match "^[A-Za-z][^ :]+:( |\n|$)" line)
|
|
|
|
|
;; New key/value pair
|
|
|
|
|
(let* ((pos (string-index line #\:))
|
|
|
|
|
(key (string-take line pos))
|
|
|
|
|
(value (string-drop line (+ 1 pos))))
|
|
|
|
|
(cons (cons key
|
|
|
|
|
(string-trim-both value))
|
|
|
|
|
acc))
|
|
|
|
|
;; This is a continuation of the previous pair
|
|
|
|
|
(match-let ((((key . value) . rest) acc))
|
|
|
|
|
(cons (cons key (string-join
|
|
|
|
|
(list value
|
|
|
|
|
(string-trim-both line))))
|
|
|
|
|
rest)))))))
|
|
|
|
|
(fold parse '() lines)))
|
|
|
|
|
|
2015-07-24 10:49:57 -04:00
|
|
|
|
(define (format-inputs names)
|
|
|
|
|
"Generate a sorted list of package inputs from a list of package NAMES."
|
|
|
|
|
(map (lambda (name)
|
2020-12-17 04:40:30 -05:00
|
|
|
|
(case (%input-style)
|
|
|
|
|
((specification)
|
|
|
|
|
(list name (list 'unquote (list 'specification->package name))))
|
|
|
|
|
(else
|
|
|
|
|
(list name (list 'unquote (string->symbol name))))))
|
2015-07-24 10:49:57 -04:00
|
|
|
|
(sort names string-ci<?)))
|
|
|
|
|
|
|
|
|
|
(define* (maybe-inputs package-inputs #:optional (type 'inputs))
|
|
|
|
|
"Given a list of PACKAGE-INPUTS, tries to generate the TYPE field of a
|
|
|
|
|
package definition."
|
|
|
|
|
(match package-inputs
|
|
|
|
|
(()
|
|
|
|
|
'())
|
|
|
|
|
((package-inputs ...)
|
|
|
|
|
`((,type (,'quasiquote ,(format-inputs package-inputs)))))))
|
|
|
|
|
|
2019-01-03 02:32:05 -05:00
|
|
|
|
(define %cran-url "https://cran.r-project.org/web/packages/")
|
2020-02-05 02:26:08 -05:00
|
|
|
|
(define %cran-canonical-url "https://cran.r-project.org/package=")
|
Use HTTPS for bioconductor.org.
* doc/guix.texi (Invoking guix import, Invoking guix refresh): Use HTTPS for
bioconductor.org URLs.
* gnu/packages/bioinformatics.scm (r-annotate, r-geneplotter, r-genefilter)
(r-deseq2, r-dexseq, r-annotationforge, r-rbgl, r-gseabase, r-category)
(r-gostats, r-shortread, r-biocgenerics, r-biocinstaller, r-biocviews)
(r-biocstyle, r-bioccheck, r-s4vectors, r-iranges, r-genomeinfodbdata)
(r-genomeinfodb, r-xvector, r-genomicranges, r-biobase, r-annotationdbi)
(r-biomart, r-biocparallel, r-biostrings, r-rsamtools, r-delayedarray)
(r-summarizedexperiment, r-genomicalignments, r-rtracklayer)
(r-genomicfeatures, r-graph, r-topgo, r-bsgenome, r-impute, r-seqpattern)
(r-seqlogo, r-motifrg, r-bamsignals, r-mutationalpatterns, r-tximport)
(r-rhdf5, r-chipseq, r-sva, r-affy, r-vsn, r-mzid, r-msnid)
(r-interactivedisplaybase, r-annotationhub)[home-page]: Likewise.
* gnu/packages/bioinformatics.scm (r-txdb-hsapiens-ucsc-hg19-knowngene)
(r-go-db, r-bsgenome-hsapiens-1000genomes-hs37d5, r-org-hs-eg-db)
(r-org-ce-eg-db, r-org-dm-eg-db, r-org-mm-eg-db)
(r-bsgenome-hsapiens-ucsc-hg19, r-bsgenome-mmusculus-ucsc-mm9)
(r-bsgenome-mmusculus-ucsc-mm10, r-txdb-mmusculus-ucsc-mm10-knowngene)
(r-bsgenome-celegans-ucsc-ce6, r-bsgenome-celegans-ucsc-ce10)
(r-bsgenome-dmelanogaster-ucsc-dm3, r-copyhelper)[source, home-page]:
Likewise.
* gnu/packages/statistics.scm (r-rcurl)[source]: Likewise.
* guix/build-system/r.scm (bioconductor-uri): Likewise.
* guix/import/cran.scm (%cran-url, bioconductor-package?)
(bioconductor-data-package?, bioconductor-experiment-package?): Likewise.
2017-10-19 20:39:56 -04:00
|
|
|
|
(define %bioconductor-url "https://bioconductor.org/packages/")
|
2015-12-16 08:45:28 -05:00
|
|
|
|
|
2020-11-18 09:27:20 -05:00
|
|
|
|
;; The latest Bioconductor release is 3.12. Bioconductor packages should be
|
2015-12-16 08:45:28 -05:00
|
|
|
|
;; updated together.
|
2020-11-18 09:27:20 -05:00
|
|
|
|
(define %bioconductor-version "3.12")
|
2017-11-06 11:09:06 -05:00
|
|
|
|
|
2019-08-16 08:59:23 -04:00
|
|
|
|
(define* (bioconductor-packages-list-url #:optional type)
|
2017-11-06 11:09:06 -05:00
|
|
|
|
(string-append "https://bioconductor.org/packages/"
|
2019-08-16 08:59:23 -04:00
|
|
|
|
%bioconductor-version
|
|
|
|
|
(match type
|
|
|
|
|
('annotation "/data/annotation")
|
|
|
|
|
('experiment "/data/experiment")
|
|
|
|
|
(_ "/bioc"))
|
|
|
|
|
"/src/contrib/PACKAGES"))
|
2017-11-06 11:09:06 -05:00
|
|
|
|
|
2019-08-16 08:59:23 -04:00
|
|
|
|
(define* (bioconductor-packages-list #:optional type)
|
2017-11-06 11:09:06 -05:00
|
|
|
|
"Return the latest version of package NAME for the current bioconductor
|
|
|
|
|
release."
|
2019-08-16 08:59:23 -04:00
|
|
|
|
(let ((url (string->uri (bioconductor-packages-list-url type))))
|
2017-11-06 11:09:06 -05:00
|
|
|
|
(guard (c ((http-get-error? c)
|
|
|
|
|
(format (current-error-port)
|
|
|
|
|
"error: failed to retrieve list of packages from ~s: ~a (~s)~%"
|
|
|
|
|
(uri->string (http-get-error-uri c))
|
|
|
|
|
(http-get-error-code c)
|
|
|
|
|
(http-get-error-reason c))
|
|
|
|
|
#f))
|
|
|
|
|
;; Split the big list on empty lines, then turn each chunk into an
|
|
|
|
|
;; alist of attributes.
|
|
|
|
|
(map (lambda (chunk)
|
|
|
|
|
(description->alist (string-join chunk "\n")))
|
2020-01-03 10:01:11 -05:00
|
|
|
|
(let* ((port (http-fetch/cached url))
|
|
|
|
|
(lines (read-lines port)))
|
|
|
|
|
(close-port port)
|
|
|
|
|
(chunk-lines lines))))))
|
2017-11-06 11:09:06 -05:00
|
|
|
|
|
2019-08-16 08:59:23 -04:00
|
|
|
|
(define* (latest-bioconductor-package-version name #:optional type)
|
2017-11-06 11:09:06 -05:00
|
|
|
|
"Return the version string corresponding to the latest release of the
|
|
|
|
|
bioconductor package NAME, or #F if the package is unknown."
|
|
|
|
|
(and=> (find (lambda (meta)
|
|
|
|
|
(string=? (assoc-ref meta "Package") name))
|
2019-08-16 08:59:23 -04:00
|
|
|
|
(bioconductor-packages-list type))
|
2017-11-06 11:09:06 -05:00
|
|
|
|
(cut assoc-ref <> "Version")))
|
2015-12-16 08:45:28 -05:00
|
|
|
|
|
2019-08-27 18:38:31 -04:00
|
|
|
|
;; XXX taken from (guix scripts hash)
|
|
|
|
|
(define (vcs-file? file stat)
|
|
|
|
|
(case (stat:type stat)
|
|
|
|
|
((directory)
|
|
|
|
|
(member (basename file) '(".bzr" ".git" ".hg" ".svn" "CVS")))
|
|
|
|
|
((regular)
|
|
|
|
|
;; Git sub-modules have a '.git' file that is a regular text file.
|
|
|
|
|
(string=? (basename file) ".git"))
|
|
|
|
|
(else
|
|
|
|
|
#f)))
|
|
|
|
|
|
2019-01-03 02:31:15 -05:00
|
|
|
|
;; Little helper to download URLs only once.
|
|
|
|
|
(define download
|
|
|
|
|
(memoize
|
2020-03-25 04:36:58 -04:00
|
|
|
|
(lambda* (url #:key method)
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(with-store store
|
2020-03-25 04:36:58 -04:00
|
|
|
|
(cond
|
|
|
|
|
((eq? method 'git)
|
|
|
|
|
(latest-repository-commit store url))
|
|
|
|
|
((eq? method 'hg)
|
|
|
|
|
(call-with-temporary-directory
|
|
|
|
|
(lambda (dir)
|
|
|
|
|
(unless (zero? (system* "hg" "clone" url dir))
|
|
|
|
|
(leave (G_ "~A: hg download failed~%") url))
|
|
|
|
|
(with-directory-excursion dir
|
|
|
|
|
(let* ((port (open-pipe* OPEN_READ "hg" "id" "--id"))
|
|
|
|
|
(changeset (string-trim-right (read-string port))))
|
|
|
|
|
(close-pipe port)
|
|
|
|
|
(for-each delete-file-recursively
|
|
|
|
|
(find-files dir "^\\.hg$" #:directories? #t))
|
|
|
|
|
(let ((store-directory
|
|
|
|
|
(add-to-store store (basename url) #t "sha256" dir)))
|
|
|
|
|
(values store-directory changeset)))))))
|
|
|
|
|
(else (download-to-store store url)))))))
|
2019-01-03 02:31:15 -05:00
|
|
|
|
|
2017-04-05 09:37:03 -04:00
|
|
|
|
(define (fetch-description repository name)
|
2015-12-03 10:12:09 -05:00
|
|
|
|
"Return an alist of the contents of the DESCRIPTION file for the R package
|
2017-04-05 09:37:03 -04:00
|
|
|
|
NAME in the given REPOSITORY, or #f in case of failure. NAME is
|
|
|
|
|
case-sensitive."
|
2017-11-06 11:10:41 -05:00
|
|
|
|
(case repository
|
|
|
|
|
((cran)
|
|
|
|
|
(let ((url (string-append %cran-url name "/DESCRIPTION")))
|
|
|
|
|
(guard (c ((http-get-error? c)
|
|
|
|
|
(format (current-error-port)
|
|
|
|
|
"error: failed to retrieve package information \
|
2016-12-17 09:24:45 -05:00
|
|
|
|
from ~s: ~a (~s)~%"
|
2017-11-06 11:10:41 -05:00
|
|
|
|
(uri->string (http-get-error-uri c))
|
|
|
|
|
(http-get-error-code c)
|
|
|
|
|
(http-get-error-reason c))
|
|
|
|
|
#f))
|
2020-01-03 10:01:11 -05:00
|
|
|
|
(let* ((port (http-fetch url))
|
|
|
|
|
(result (description->alist (read-string port))))
|
|
|
|
|
(close-port port)
|
|
|
|
|
result))))
|
2017-11-06 11:10:41 -05:00
|
|
|
|
((bioconductor)
|
|
|
|
|
;; Currently, the bioconductor project does not offer a way to access a
|
|
|
|
|
;; package's DESCRIPTION file over HTTP, so we determine the version,
|
|
|
|
|
;; download the source tarball, and then extract the DESCRIPTION file.
|
2019-08-16 08:59:23 -04:00
|
|
|
|
(and-let* ((type (or
|
|
|
|
|
(and (latest-bioconductor-package-version name) #t)
|
|
|
|
|
(and (latest-bioconductor-package-version name 'annotation) 'annotation)
|
|
|
|
|
(and (latest-bioconductor-package-version name 'experiment) 'experiment)))
|
|
|
|
|
(version (latest-bioconductor-package-version name type))
|
|
|
|
|
(url (car (bioconductor-uri name version type)))
|
2019-01-03 02:31:15 -05:00
|
|
|
|
(tarball (download url)))
|
2017-11-06 11:10:41 -05:00
|
|
|
|
(call-with-temporary-directory
|
|
|
|
|
(lambda (dir)
|
|
|
|
|
(parameterize ((current-error-port (%make-void-port "rw+"))
|
|
|
|
|
(current-output-port (%make-void-port "rw+")))
|
|
|
|
|
(and (zero? (system* "tar" "--wildcards" "-x"
|
|
|
|
|
"--strip-components=1"
|
|
|
|
|
"-C" dir
|
|
|
|
|
"-f" tarball "*/DESCRIPTION"))
|
2019-08-16 08:59:23 -04:00
|
|
|
|
(and=> (description->alist (with-input-from-file
|
|
|
|
|
(string-append dir "/DESCRIPTION") read-string))
|
|
|
|
|
(lambda (meta)
|
|
|
|
|
(if (boolean? type) meta
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(cons `(bioconductor-type . ,type) meta))))))))))
|
|
|
|
|
((git)
|
2019-09-02 08:46:04 -04:00
|
|
|
|
(and (string-prefix? "http" name)
|
|
|
|
|
;; Download the git repository at "NAME"
|
|
|
|
|
(call-with-values
|
2020-03-25 04:36:58 -04:00
|
|
|
|
(lambda () (download name #:method 'git))
|
2019-09-02 08:46:04 -04:00
|
|
|
|
(lambda (dir commit)
|
|
|
|
|
(and=> (description->alist (with-input-from-file
|
|
|
|
|
(string-append dir "/DESCRIPTION") read-string))
|
|
|
|
|
(lambda (meta)
|
|
|
|
|
(cons* `(git . ,name)
|
|
|
|
|
`(git-commit . ,commit)
|
2020-03-25 04:36:58 -04:00
|
|
|
|
meta)))))))
|
|
|
|
|
((hg)
|
|
|
|
|
(and (string-prefix? "http" name)
|
|
|
|
|
;; Download the mercurial repository at "NAME"
|
|
|
|
|
(call-with-values
|
|
|
|
|
(lambda () (download name #:method 'hg))
|
|
|
|
|
(lambda (dir changeset)
|
|
|
|
|
(and=> (description->alist (with-input-from-file
|
|
|
|
|
(string-append dir "/DESCRIPTION") read-string))
|
|
|
|
|
(lambda (meta)
|
|
|
|
|
(cons* `(hg . ,name)
|
|
|
|
|
`(hg-changeset . ,changeset)
|
2019-09-02 08:46:04 -04:00
|
|
|
|
meta)))))))))
|
2015-12-03 10:12:09 -05:00
|
|
|
|
|
|
|
|
|
(define (listify meta field)
|
|
|
|
|
"Look up FIELD in the alist META. If FIELD contains a comma-separated
|
|
|
|
|
string, turn it into a list and strip off parenthetic expressions. Return the
|
|
|
|
|
empty list when the FIELD cannot be found."
|
|
|
|
|
(let ((value (assoc-ref meta field)))
|
|
|
|
|
(if (not value)
|
|
|
|
|
'()
|
|
|
|
|
;; Strip off parentheses
|
|
|
|
|
(let ((items (string-split (regexp-substitute/global
|
|
|
|
|
#f "( *\\([^\\)]+\\)) *"
|
|
|
|
|
value 'pre 'post)
|
|
|
|
|
#\,)))
|
2015-12-16 08:29:38 -05:00
|
|
|
|
(remove (lambda (item)
|
|
|
|
|
(or (string-null? item)
|
|
|
|
|
;; When there is whitespace inside of items it is
|
|
|
|
|
;; probably because this was not an actual list to
|
|
|
|
|
;; begin with.
|
|
|
|
|
(string-any char-set:whitespace item)))
|
2015-12-03 10:12:09 -05:00
|
|
|
|
(map string-trim-both items))))))
|
|
|
|
|
|
2020-01-16 15:47:36 -05:00
|
|
|
|
;; Trick Guile 3 so that it keeps the 'listify' binding accessible *and*
|
|
|
|
|
;; private even though this module is declarative.
|
|
|
|
|
(set! listify listify)
|
|
|
|
|
|
2016-05-17 09:22:30 -04:00
|
|
|
|
(define default-r-packages
|
2017-03-11 18:21:39 -05:00
|
|
|
|
(list "base"
|
2016-05-17 09:22:30 -04:00
|
|
|
|
"compiler"
|
2020-05-13 07:53:05 -04:00
|
|
|
|
"datasets"
|
2016-05-17 09:22:30 -04:00
|
|
|
|
"grDevices"
|
|
|
|
|
"graphics"
|
|
|
|
|
"grid"
|
|
|
|
|
"methods"
|
|
|
|
|
"parallel"
|
|
|
|
|
"splines"
|
|
|
|
|
"stats"
|
|
|
|
|
"stats4"
|
|
|
|
|
"tcltk"
|
|
|
|
|
"tools"
|
|
|
|
|
"translations"
|
|
|
|
|
"utils"))
|
|
|
|
|
|
2019-05-23 04:54:17 -04:00
|
|
|
|
;; The field for system dependencies is often abused to specify non-package
|
|
|
|
|
;; dependencies (such as c++11). This list is used to ignore them.
|
|
|
|
|
(define invalid-packages
|
2021-01-20 11:04:38 -05:00
|
|
|
|
(list "c++11"
|
|
|
|
|
"c++14"
|
|
|
|
|
"linux"
|
|
|
|
|
"getopt::long"
|
|
|
|
|
"xquartz"))
|
2019-05-23 04:54:17 -04:00
|
|
|
|
|
2018-06-08 06:46:43 -04:00
|
|
|
|
(define cran-guix-name (cut guix-name "r-" <>))
|
2016-07-06 06:42:38 -04:00
|
|
|
|
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(define (tarball-needs-fortran? tarball)
|
2017-03-27 06:53:13 -04:00
|
|
|
|
"Check if the TARBALL contains Fortran source files."
|
|
|
|
|
(define (check pattern)
|
|
|
|
|
(parameterize ((current-error-port (%make-void-port "rw+"))
|
|
|
|
|
(current-output-port (%make-void-port "rw+")))
|
|
|
|
|
(zero? (system* "tar" "--wildcards" "--list" pattern "-f" tarball))))
|
|
|
|
|
(or (check "*.f90")
|
|
|
|
|
(check "*.f95")
|
|
|
|
|
(check "*.f")))
|
|
|
|
|
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(define (directory-needs-fortran? dir)
|
|
|
|
|
"Check if the directory DIR contains Fortran source files."
|
2021-02-23 06:00:21 -05:00
|
|
|
|
(match (find-files dir "\\.f(90|95)$")
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(() #f)
|
|
|
|
|
(_ #t)))
|
|
|
|
|
|
|
|
|
|
(define (needs-fortran? thing tarball?)
|
|
|
|
|
"Check if the THING contains Fortran source files."
|
|
|
|
|
(if tarball?
|
|
|
|
|
(tarball-needs-fortran? thing)
|
|
|
|
|
(directory-needs-fortran? thing)))
|
|
|
|
|
|
|
|
|
|
(define (files-match-pattern? directory regexp . file-patterns)
|
|
|
|
|
"Return #T if any of the files matching FILE-PATTERNS in the DIRECTORY match
|
|
|
|
|
the given REGEXP."
|
|
|
|
|
(let ((pattern (make-regexp regexp)))
|
|
|
|
|
(any (lambda (file)
|
|
|
|
|
(call-with-input-file file
|
|
|
|
|
(lambda (port)
|
|
|
|
|
(let loop ()
|
|
|
|
|
(let ((line (read-line port)))
|
|
|
|
|
(cond
|
|
|
|
|
((eof-object? line) #f)
|
|
|
|
|
((regexp-exec pattern line) #t)
|
|
|
|
|
(else (loop))))))))
|
|
|
|
|
(apply find-files directory file-patterns))))
|
|
|
|
|
|
2017-04-05 12:42:07 -04:00
|
|
|
|
(define (tarball-files-match-pattern? tarball regexp . file-patterns)
|
|
|
|
|
"Return #T if any of the files represented by FILE-PATTERNS in the TARBALL
|
|
|
|
|
match the given REGEXP."
|
2017-03-27 06:53:13 -04:00
|
|
|
|
(call-with-temporary-directory
|
|
|
|
|
(lambda (dir)
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(parameterize ((current-error-port (%make-void-port "rw+")))
|
|
|
|
|
(apply system* "tar"
|
|
|
|
|
"xf" tarball "-C" dir
|
|
|
|
|
`("--wildcards" ,@file-patterns)))
|
|
|
|
|
(files-match-pattern? dir regexp))))
|
|
|
|
|
|
|
|
|
|
(define (directory-needs-zlib? dir)
|
|
|
|
|
"Return #T if any of the Makevars files in the src directory DIR contain a
|
|
|
|
|
zlib linker flag."
|
|
|
|
|
(files-match-pattern? dir "-lz" "(Makevars.*|configure.*)"))
|
|
|
|
|
|
|
|
|
|
(define (tarball-needs-zlib? tarball)
|
2017-04-05 12:42:07 -04:00
|
|
|
|
"Return #T if any of the Makevars files in the src directory of the TARBALL
|
|
|
|
|
contain a zlib linker flag."
|
|
|
|
|
(tarball-files-match-pattern?
|
|
|
|
|
tarball "-lz"
|
|
|
|
|
"*/src/Makevars*" "*/src/configure*" "*/configure*"))
|
|
|
|
|
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(define (needs-zlib? thing tarball?)
|
|
|
|
|
"Check if the THING contains files indicating a dependency on zlib."
|
|
|
|
|
(if tarball?
|
|
|
|
|
(tarball-needs-zlib? thing)
|
|
|
|
|
(directory-needs-zlib? thing)))
|
|
|
|
|
|
|
|
|
|
(define (directory-needs-pkg-config? dir)
|
|
|
|
|
"Return #T if any of the Makevars files in the src directory DIR reference
|
|
|
|
|
the pkg-config tool."
|
|
|
|
|
(files-match-pattern? dir "pkg-config"
|
|
|
|
|
"(Makevars.*|configure.*)"))
|
|
|
|
|
|
|
|
|
|
(define (tarball-needs-pkg-config? tarball)
|
2017-04-05 12:42:08 -04:00
|
|
|
|
"Return #T if any of the Makevars files in the src directory of the TARBALL
|
|
|
|
|
reference the pkg-config tool."
|
|
|
|
|
(tarball-files-match-pattern?
|
|
|
|
|
tarball "pkg-config"
|
|
|
|
|
"*/src/Makevars*" "*/src/configure*" "*/configure*"))
|
|
|
|
|
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(define (needs-pkg-config? thing tarball?)
|
|
|
|
|
"Check if the THING contains files indicating a dependency on pkg-config."
|
|
|
|
|
(if tarball?
|
|
|
|
|
(tarball-needs-pkg-config? thing)
|
|
|
|
|
(directory-needs-pkg-config? thing)))
|
|
|
|
|
|
2020-03-07 13:30:51 -05:00
|
|
|
|
(define (needs-knitr? meta)
|
|
|
|
|
(member "knitr" (listify meta "VignetteBuilder")))
|
|
|
|
|
|
2019-08-27 18:38:31 -04:00
|
|
|
|
;; XXX adapted from (guix scripts hash)
|
|
|
|
|
(define (file-hash file select? recursive?)
|
|
|
|
|
;; Compute the hash of FILE.
|
|
|
|
|
(if recursive?
|
|
|
|
|
(let-values (((port get-hash) (open-sha256-port)))
|
|
|
|
|
(write-file file port #:select? select?)
|
|
|
|
|
(force-output port)
|
|
|
|
|
(get-hash))
|
|
|
|
|
(call-with-input-file file port-sha256)))
|
|
|
|
|
|
2015-12-16 08:45:28 -05:00
|
|
|
|
(define (description->package repository meta)
|
|
|
|
|
"Return the `package' s-expression for an R package published on REPOSITORY
|
|
|
|
|
from the alist META, which was derived from the R package's DESCRIPTION file."
|
|
|
|
|
(let* ((base-url (case repository
|
|
|
|
|
((cran) %cran-url)
|
2019-08-27 18:38:31 -04:00
|
|
|
|
((bioconductor) %bioconductor-url)
|
2020-03-25 04:36:58 -04:00
|
|
|
|
((git) #f)
|
|
|
|
|
((hg) #f)))
|
2020-02-05 02:26:08 -05:00
|
|
|
|
(canonical-url-base (case repository
|
|
|
|
|
((cran) %cran-canonical-url)
|
|
|
|
|
((bioconductor) %bioconductor-url)
|
|
|
|
|
((git) #f)))
|
2015-12-16 08:45:28 -05:00
|
|
|
|
(uri-helper (case repository
|
|
|
|
|
((cran) cran-uri)
|
2019-08-27 18:38:31 -04:00
|
|
|
|
((bioconductor) bioconductor-uri)
|
2020-03-25 04:36:58 -04:00
|
|
|
|
((git) #f)
|
|
|
|
|
((hg) #f)))
|
2015-12-16 08:45:28 -05:00
|
|
|
|
(name (assoc-ref meta "Package"))
|
2015-12-03 10:12:09 -05:00
|
|
|
|
(synopsis (assoc-ref meta "Title"))
|
|
|
|
|
(version (assoc-ref meta "Version"))
|
|
|
|
|
(license (string->license (assoc-ref meta "License")))
|
|
|
|
|
;; Some packages have multiple home pages. Some have none.
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(home-page (case repository
|
|
|
|
|
((git) (assoc-ref meta 'git))
|
2020-03-25 04:36:58 -04:00
|
|
|
|
((hg) (assoc-ref meta 'hg))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(else (match (listify meta "URL")
|
|
|
|
|
((url rest ...) url)
|
2020-02-05 02:26:08 -05:00
|
|
|
|
(_ (string-append canonical-url-base name))))))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(source-url (case repository
|
|
|
|
|
((git) (assoc-ref meta 'git))
|
2020-03-25 04:36:58 -04:00
|
|
|
|
((hg) (assoc-ref meta 'hg))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(else
|
|
|
|
|
(match (apply uri-helper name version
|
|
|
|
|
(case repository
|
|
|
|
|
((bioconductor)
|
|
|
|
|
(list (assoc-ref meta 'bioconductor-type)))
|
|
|
|
|
(else '())))
|
|
|
|
|
((url rest ...) url)
|
|
|
|
|
((? string? url) url)
|
|
|
|
|
(_ #f)))))
|
|
|
|
|
(git? (assoc-ref meta 'git))
|
2020-03-25 04:36:58 -04:00
|
|
|
|
(hg? (assoc-ref meta 'hg))
|
|
|
|
|
(source (download source-url #:method (cond
|
|
|
|
|
(git? 'git)
|
|
|
|
|
(hg? 'hg)
|
|
|
|
|
(else #f))))
|
2017-03-27 06:53:13 -04:00
|
|
|
|
(sysdepends (append
|
2020-03-25 04:36:58 -04:00
|
|
|
|
(if (needs-zlib? source (not (or git? hg?))) '("zlib") '())
|
2019-05-28 17:56:59 -04:00
|
|
|
|
(filter (lambda (name)
|
|
|
|
|
(not (member name invalid-packages)))
|
|
|
|
|
(map string-downcase (listify meta "SystemRequirements")))))
|
2016-05-17 09:22:30 -04:00
|
|
|
|
(propagate (filter (lambda (name)
|
2019-05-23 04:54:17 -04:00
|
|
|
|
(not (member name (append default-r-packages
|
|
|
|
|
invalid-packages))))
|
2016-05-17 09:22:30 -04:00
|
|
|
|
(lset-union equal?
|
|
|
|
|
(listify meta "Imports")
|
|
|
|
|
(listify meta "LinkingTo")
|
|
|
|
|
(delete "R"
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(listify meta "Depends")))))
|
|
|
|
|
(package
|
|
|
|
|
`(package
|
|
|
|
|
(name ,(cran-guix-name name))
|
|
|
|
|
(version ,(case repository
|
|
|
|
|
((git)
|
|
|
|
|
`(git-version ,version revision commit))
|
2020-03-25 04:36:58 -04:00
|
|
|
|
((hg)
|
|
|
|
|
`(string-append ,version "-" revision "." changeset))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(else version)))
|
|
|
|
|
(source (origin
|
2020-03-25 04:36:58 -04:00
|
|
|
|
(method ,(cond
|
|
|
|
|
(git? 'git-fetch)
|
|
|
|
|
(hg? 'hg-fetch)
|
|
|
|
|
(else 'url-fetch)))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(uri ,(case repository
|
|
|
|
|
((git)
|
|
|
|
|
`(git-reference
|
|
|
|
|
(url ,(assoc-ref meta 'git))
|
|
|
|
|
(commit commit)))
|
2020-03-25 04:36:58 -04:00
|
|
|
|
((hg)
|
|
|
|
|
`(hg-reference
|
|
|
|
|
(url ,(assoc-ref meta 'hg))
|
|
|
|
|
(changeset changeset)))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(else
|
|
|
|
|
`(,(procedure-name uri-helper) ,name version
|
|
|
|
|
,@(or (and=> (assoc-ref meta 'bioconductor-type)
|
|
|
|
|
(lambda (type)
|
|
|
|
|
(list (list 'quote type))))
|
|
|
|
|
'())))))
|
2020-03-25 04:36:58 -04:00
|
|
|
|
,@(cond
|
|
|
|
|
(git?
|
|
|
|
|
'((file-name (git-file-name name version))))
|
|
|
|
|
(hg?
|
|
|
|
|
'((file-name (string-append name "-" version "-checkout"))))
|
|
|
|
|
(else '()))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(sha256
|
|
|
|
|
(base32
|
|
|
|
|
,(bytevector->nix-base32-string
|
|
|
|
|
(case repository
|
|
|
|
|
((git)
|
|
|
|
|
(file-hash source (negate vcs-file?) #t))
|
2020-03-25 04:36:58 -04:00
|
|
|
|
((hg)
|
|
|
|
|
(file-hash source (negate vcs-file?) #t))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(else (file-sha256 source))))))))
|
2020-03-25 04:36:58 -04:00
|
|
|
|
,@(if (not (and git? hg?
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(equal? (string-append "r-" name)
|
|
|
|
|
(cran-guix-name name))))
|
|
|
|
|
`((properties ,`(,'quasiquote ((,'upstream-name . ,name)))))
|
|
|
|
|
'())
|
|
|
|
|
(build-system r-build-system)
|
|
|
|
|
,@(maybe-inputs sysdepends)
|
|
|
|
|
,@(maybe-inputs (map cran-guix-name propagate) 'propagated-inputs)
|
|
|
|
|
,@(maybe-inputs
|
2020-03-25 04:36:58 -04:00
|
|
|
|
`(,@(if (needs-fortran? source (not (or git? hg?)))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
'("gfortran") '())
|
2020-03-25 04:36:58 -04:00
|
|
|
|
,@(if (needs-pkg-config? source (not (or git? hg?)))
|
2020-03-07 13:30:51 -05:00
|
|
|
|
'("pkg-config") '())
|
|
|
|
|
,@(if (needs-knitr? meta)
|
|
|
|
|
'("r-knitr") '()))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
'native-inputs)
|
|
|
|
|
(home-page ,(if (string-null? home-page)
|
|
|
|
|
(string-append base-url name)
|
|
|
|
|
home-page))
|
|
|
|
|
(synopsis ,synopsis)
|
|
|
|
|
(description ,(beautify-description (or (assoc-ref meta "Description")
|
|
|
|
|
"")))
|
|
|
|
|
(license ,license))))
|
2016-05-17 09:17:54 -04:00
|
|
|
|
(values
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(case repository
|
|
|
|
|
((git)
|
|
|
|
|
`(let ((commit ,(assoc-ref meta 'git-commit))
|
|
|
|
|
(revision "1"))
|
|
|
|
|
,package))
|
2020-03-25 04:36:58 -04:00
|
|
|
|
((hg)
|
|
|
|
|
`(let ((changeset ,(assoc-ref meta 'hg-changeset))
|
|
|
|
|
(revision "1"))
|
|
|
|
|
,package))
|
2019-08-27 18:38:31 -04:00
|
|
|
|
(else package))
|
2016-05-17 09:17:54 -04:00
|
|
|
|
propagate)))
|
2015-07-24 10:49:57 -04:00
|
|
|
|
|
2016-05-17 10:38:17 -04:00
|
|
|
|
(define cran->guix-package
|
|
|
|
|
(memoize
|
2020-02-04 07:18:18 -05:00
|
|
|
|
(lambda* (package-name #:key (repo 'cran) version)
|
2016-05-17 10:38:17 -04:00
|
|
|
|
"Fetch the metadata for PACKAGE-NAME from REPO and return the `package'
|
2015-12-16 08:45:28 -05:00
|
|
|
|
s-expression corresponding to that package, or #f on failure."
|
2018-12-20 03:37:58 -05:00
|
|
|
|
(let ((description (fetch-description repo package-name)))
|
2019-09-02 08:45:17 -04:00
|
|
|
|
(if description
|
|
|
|
|
(description->package repo description)
|
|
|
|
|
(case repo
|
|
|
|
|
((git)
|
|
|
|
|
;; Retry import from Bioconductor
|
2020-12-04 06:27:29 -05:00
|
|
|
|
(cran->guix-package package-name #:repo 'bioconductor))
|
2020-03-25 04:36:58 -04:00
|
|
|
|
((hg)
|
|
|
|
|
;; Retry import from Bioconductor
|
2020-12-04 06:27:29 -05:00
|
|
|
|
(cran->guix-package package-name #:repo 'bioconductor))
|
2019-09-02 08:45:17 -04:00
|
|
|
|
((bioconductor)
|
|
|
|
|
;; Retry import from CRAN
|
2020-12-04 06:27:29 -05:00
|
|
|
|
(cran->guix-package package-name #:repo 'cran))
|
2020-12-11 18:06:18 -05:00
|
|
|
|
(else
|
|
|
|
|
(raise (condition
|
|
|
|
|
(&message
|
|
|
|
|
(message "couldn't find meta-data for R package")))))))))))
|
2016-05-17 10:38:17 -04:00
|
|
|
|
|
2020-02-04 07:18:18 -05:00
|
|
|
|
(define* (cran-recursive-import package-name #:key (repo 'cran))
|
|
|
|
|
(recursive-import package-name
|
|
|
|
|
#:repo repo
|
2018-06-08 06:46:43 -04:00
|
|
|
|
#:repo->guix-package cran->guix-package
|
|
|
|
|
#:guix-name cran-guix-name))
|
2015-10-21 08:36:14 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
;;;
|
|
|
|
|
;;; Updater.
|
|
|
|
|
;;;
|
|
|
|
|
|
2015-12-16 08:22:17 -05:00
|
|
|
|
(define (package->upstream-name package)
|
|
|
|
|
"Return the upstream name of the PACKAGE."
|
|
|
|
|
(let* ((properties (package-properties package))
|
|
|
|
|
(upstream-name (and=> properties
|
|
|
|
|
(cut assoc-ref <> 'upstream-name))))
|
|
|
|
|
(if upstream-name
|
|
|
|
|
upstream-name
|
|
|
|
|
(match (package-source package)
|
|
|
|
|
((? origin? origin)
|
|
|
|
|
(match (origin-uri origin)
|
2016-03-22 10:12:30 -04:00
|
|
|
|
((or (? string? url) (url _ ...))
|
2015-12-16 08:22:17 -05:00
|
|
|
|
(let ((end (string-rindex url #\_))
|
|
|
|
|
(start (string-rindex url #\/)))
|
|
|
|
|
;; The URL ends on
|
|
|
|
|
;; (string-append "/" name "_" version ".tar.gz")
|
2017-05-04 05:52:33 -04:00
|
|
|
|
(and start end (substring url (+ start 1) end))))
|
2015-12-16 08:22:17 -05:00
|
|
|
|
(_ #f)))
|
|
|
|
|
(_ #f)))))
|
|
|
|
|
|
2019-01-11 03:27:21 -05:00
|
|
|
|
(define (latest-cran-release pkg)
|
|
|
|
|
"Return an <upstream-source> for the latest release of the package PKG."
|
2015-12-03 10:12:09 -05:00
|
|
|
|
|
2015-12-16 08:22:17 -05:00
|
|
|
|
(define upstream-name
|
2019-01-11 03:27:21 -05:00
|
|
|
|
(package->upstream-name pkg))
|
2015-12-03 10:12:09 -05:00
|
|
|
|
|
|
|
|
|
(define meta
|
2017-04-05 09:37:03 -04:00
|
|
|
|
(fetch-description 'cran upstream-name))
|
2015-12-03 10:12:09 -05:00
|
|
|
|
|
|
|
|
|
(and meta
|
|
|
|
|
(let ((version (assoc-ref meta "Version")))
|
|
|
|
|
;; CRAN does not provide signatures.
|
|
|
|
|
(upstream-source
|
2019-01-11 03:27:21 -05:00
|
|
|
|
(package (package-name pkg))
|
2015-12-03 10:12:09 -05:00
|
|
|
|
(version version)
|
2019-01-11 03:27:21 -05:00
|
|
|
|
(urls (cran-uri upstream-name version))
|
|
|
|
|
(input-changes
|
|
|
|
|
(changed-inputs pkg
|
|
|
|
|
(description->package 'cran meta)))))))
|
2015-10-21 08:36:14 -04:00
|
|
|
|
|
2019-01-11 03:27:21 -05:00
|
|
|
|
(define (latest-bioconductor-release pkg)
|
|
|
|
|
"Return an <upstream-source> for the latest release of the package PKG."
|
2015-12-16 08:45:28 -05:00
|
|
|
|
|
|
|
|
|
(define upstream-name
|
2019-01-11 03:27:21 -05:00
|
|
|
|
(package->upstream-name pkg))
|
2015-12-16 08:45:28 -05:00
|
|
|
|
|
2017-11-06 11:10:41 -05:00
|
|
|
|
(define version
|
|
|
|
|
(latest-bioconductor-package-version upstream-name))
|
2015-12-16 08:45:28 -05:00
|
|
|
|
|
2017-11-06 11:10:41 -05:00
|
|
|
|
(and version
|
|
|
|
|
;; Bioconductor does not provide signatures.
|
|
|
|
|
(upstream-source
|
2019-01-11 03:27:21 -05:00
|
|
|
|
(package (package-name pkg))
|
2017-11-06 11:10:41 -05:00
|
|
|
|
(version version)
|
2019-01-11 03:27:21 -05:00
|
|
|
|
(urls (bioconductor-uri upstream-name version))
|
|
|
|
|
(input-changes
|
|
|
|
|
(changed-inputs
|
|
|
|
|
pkg
|
2020-12-04 06:27:29 -05:00
|
|
|
|
(cran->guix-package upstream-name #:repo 'bioconductor))))))
|
2015-12-16 08:45:28 -05:00
|
|
|
|
|
2015-10-21 08:36:14 -04:00
|
|
|
|
(define (cran-package? package)
|
|
|
|
|
"Return true if PACKAGE is an R package from CRAN."
|
2015-12-16 08:45:28 -05:00
|
|
|
|
(and (string-prefix? "r-" (package-name package))
|
2017-05-04 05:52:33 -04:00
|
|
|
|
;; Check if the upstream name can be extracted from package uri.
|
|
|
|
|
(package->upstream-name package)
|
|
|
|
|
;; Check if package uri(s) are prefixed by "mirror://cran".
|
2020-07-03 16:45:21 -04:00
|
|
|
|
((url-predicate (cut string-prefix? "mirror://cran" <>)) package)))
|
2015-12-16 08:45:28 -05:00
|
|
|
|
|
|
|
|
|
(define (bioconductor-package? package)
|
|
|
|
|
"Return true if PACKAGE is an R package from Bioconductor."
|
2016-10-26 03:47:40 -04:00
|
|
|
|
(let ((predicate (lambda (uri)
|
Use HTTPS for bioconductor.org.
* doc/guix.texi (Invoking guix import, Invoking guix refresh): Use HTTPS for
bioconductor.org URLs.
* gnu/packages/bioinformatics.scm (r-annotate, r-geneplotter, r-genefilter)
(r-deseq2, r-dexseq, r-annotationforge, r-rbgl, r-gseabase, r-category)
(r-gostats, r-shortread, r-biocgenerics, r-biocinstaller, r-biocviews)
(r-biocstyle, r-bioccheck, r-s4vectors, r-iranges, r-genomeinfodbdata)
(r-genomeinfodb, r-xvector, r-genomicranges, r-biobase, r-annotationdbi)
(r-biomart, r-biocparallel, r-biostrings, r-rsamtools, r-delayedarray)
(r-summarizedexperiment, r-genomicalignments, r-rtracklayer)
(r-genomicfeatures, r-graph, r-topgo, r-bsgenome, r-impute, r-seqpattern)
(r-seqlogo, r-motifrg, r-bamsignals, r-mutationalpatterns, r-tximport)
(r-rhdf5, r-chipseq, r-sva, r-affy, r-vsn, r-mzid, r-msnid)
(r-interactivedisplaybase, r-annotationhub)[home-page]: Likewise.
* gnu/packages/bioinformatics.scm (r-txdb-hsapiens-ucsc-hg19-knowngene)
(r-go-db, r-bsgenome-hsapiens-1000genomes-hs37d5, r-org-hs-eg-db)
(r-org-ce-eg-db, r-org-dm-eg-db, r-org-mm-eg-db)
(r-bsgenome-hsapiens-ucsc-hg19, r-bsgenome-mmusculus-ucsc-mm9)
(r-bsgenome-mmusculus-ucsc-mm10, r-txdb-mmusculus-ucsc-mm10-knowngene)
(r-bsgenome-celegans-ucsc-ce6, r-bsgenome-celegans-ucsc-ce10)
(r-bsgenome-dmelanogaster-ucsc-dm3, r-copyhelper)[source, home-page]:
Likewise.
* gnu/packages/statistics.scm (r-rcurl)[source]: Likewise.
* guix/build-system/r.scm (bioconductor-uri): Likewise.
* guix/import/cran.scm (%cran-url, bioconductor-package?)
(bioconductor-data-package?, bioconductor-experiment-package?): Likewise.
2017-10-19 20:39:56 -04:00
|
|
|
|
(and (string-prefix? "https://bioconductor.org" uri)
|
2017-04-05 09:37:03 -04:00
|
|
|
|
;; Data packages are neither listed in SVN nor on
|
|
|
|
|
;; the Github mirror, so we have to exclude them
|
|
|
|
|
;; from the set of bioconductor packages that can be
|
|
|
|
|
;; updated automatically.
|
2017-04-05 12:42:05 -04:00
|
|
|
|
(not (string-contains uri "/data/annotation/"))
|
|
|
|
|
;; Experiment packages are in a separate repository.
|
|
|
|
|
(not (string-contains uri "/data/experiment/"))))))
|
2016-10-26 03:47:40 -04:00
|
|
|
|
(and (string-prefix? "r-" (package-name package))
|
2020-07-03 16:45:21 -04:00
|
|
|
|
((url-predicate predicate) package))))
|
2016-10-26 03:47:40 -04:00
|
|
|
|
|
|
|
|
|
(define (bioconductor-data-package? package)
|
|
|
|
|
"Return true if PACKAGE is an R data package from Bioconductor."
|
|
|
|
|
(let ((predicate (lambda (uri)
|
Use HTTPS for bioconductor.org.
* doc/guix.texi (Invoking guix import, Invoking guix refresh): Use HTTPS for
bioconductor.org URLs.
* gnu/packages/bioinformatics.scm (r-annotate, r-geneplotter, r-genefilter)
(r-deseq2, r-dexseq, r-annotationforge, r-rbgl, r-gseabase, r-category)
(r-gostats, r-shortread, r-biocgenerics, r-biocinstaller, r-biocviews)
(r-biocstyle, r-bioccheck, r-s4vectors, r-iranges, r-genomeinfodbdata)
(r-genomeinfodb, r-xvector, r-genomicranges, r-biobase, r-annotationdbi)
(r-biomart, r-biocparallel, r-biostrings, r-rsamtools, r-delayedarray)
(r-summarizedexperiment, r-genomicalignments, r-rtracklayer)
(r-genomicfeatures, r-graph, r-topgo, r-bsgenome, r-impute, r-seqpattern)
(r-seqlogo, r-motifrg, r-bamsignals, r-mutationalpatterns, r-tximport)
(r-rhdf5, r-chipseq, r-sva, r-affy, r-vsn, r-mzid, r-msnid)
(r-interactivedisplaybase, r-annotationhub)[home-page]: Likewise.
* gnu/packages/bioinformatics.scm (r-txdb-hsapiens-ucsc-hg19-knowngene)
(r-go-db, r-bsgenome-hsapiens-1000genomes-hs37d5, r-org-hs-eg-db)
(r-org-ce-eg-db, r-org-dm-eg-db, r-org-mm-eg-db)
(r-bsgenome-hsapiens-ucsc-hg19, r-bsgenome-mmusculus-ucsc-mm9)
(r-bsgenome-mmusculus-ucsc-mm10, r-txdb-mmusculus-ucsc-mm10-knowngene)
(r-bsgenome-celegans-ucsc-ce6, r-bsgenome-celegans-ucsc-ce10)
(r-bsgenome-dmelanogaster-ucsc-dm3, r-copyhelper)[source, home-page]:
Likewise.
* gnu/packages/statistics.scm (r-rcurl)[source]: Likewise.
* guix/build-system/r.scm (bioconductor-uri): Likewise.
* guix/import/cran.scm (%cran-url, bioconductor-package?)
(bioconductor-data-package?, bioconductor-experiment-package?): Likewise.
2017-10-19 20:39:56 -04:00
|
|
|
|
(and (string-prefix? "https://bioconductor.org" uri)
|
2016-10-26 03:47:40 -04:00
|
|
|
|
(string-contains uri "/data/annotation/")))))
|
|
|
|
|
(and (string-prefix? "r-" (package-name package))
|
2020-07-03 16:45:21 -04:00
|
|
|
|
((url-predicate predicate) package))))
|
2015-10-21 08:36:14 -04:00
|
|
|
|
|
2017-04-05 12:42:06 -04:00
|
|
|
|
(define (bioconductor-experiment-package? package)
|
|
|
|
|
"Return true if PACKAGE is an R experiment package from Bioconductor."
|
|
|
|
|
(let ((predicate (lambda (uri)
|
Use HTTPS for bioconductor.org.
* doc/guix.texi (Invoking guix import, Invoking guix refresh): Use HTTPS for
bioconductor.org URLs.
* gnu/packages/bioinformatics.scm (r-annotate, r-geneplotter, r-genefilter)
(r-deseq2, r-dexseq, r-annotationforge, r-rbgl, r-gseabase, r-category)
(r-gostats, r-shortread, r-biocgenerics, r-biocinstaller, r-biocviews)
(r-biocstyle, r-bioccheck, r-s4vectors, r-iranges, r-genomeinfodbdata)
(r-genomeinfodb, r-xvector, r-genomicranges, r-biobase, r-annotationdbi)
(r-biomart, r-biocparallel, r-biostrings, r-rsamtools, r-delayedarray)
(r-summarizedexperiment, r-genomicalignments, r-rtracklayer)
(r-genomicfeatures, r-graph, r-topgo, r-bsgenome, r-impute, r-seqpattern)
(r-seqlogo, r-motifrg, r-bamsignals, r-mutationalpatterns, r-tximport)
(r-rhdf5, r-chipseq, r-sva, r-affy, r-vsn, r-mzid, r-msnid)
(r-interactivedisplaybase, r-annotationhub)[home-page]: Likewise.
* gnu/packages/bioinformatics.scm (r-txdb-hsapiens-ucsc-hg19-knowngene)
(r-go-db, r-bsgenome-hsapiens-1000genomes-hs37d5, r-org-hs-eg-db)
(r-org-ce-eg-db, r-org-dm-eg-db, r-org-mm-eg-db)
(r-bsgenome-hsapiens-ucsc-hg19, r-bsgenome-mmusculus-ucsc-mm9)
(r-bsgenome-mmusculus-ucsc-mm10, r-txdb-mmusculus-ucsc-mm10-knowngene)
(r-bsgenome-celegans-ucsc-ce6, r-bsgenome-celegans-ucsc-ce10)
(r-bsgenome-dmelanogaster-ucsc-dm3, r-copyhelper)[source, home-page]:
Likewise.
* gnu/packages/statistics.scm (r-rcurl)[source]: Likewise.
* guix/build-system/r.scm (bioconductor-uri): Likewise.
* guix/import/cran.scm (%cran-url, bioconductor-package?)
(bioconductor-data-package?, bioconductor-experiment-package?): Likewise.
2017-10-19 20:39:56 -04:00
|
|
|
|
(and (string-prefix? "https://bioconductor.org" uri)
|
2017-04-05 12:42:06 -04:00
|
|
|
|
(string-contains uri "/data/experiment/")))))
|
|
|
|
|
(and (string-prefix? "r-" (package-name package))
|
2020-07-03 16:45:21 -04:00
|
|
|
|
((url-predicate predicate) package))))
|
2017-04-05 12:42:06 -04:00
|
|
|
|
|
2015-10-21 08:36:14 -04:00
|
|
|
|
(define %cran-updater
|
2015-10-26 14:24:53 -04:00
|
|
|
|
(upstream-updater
|
|
|
|
|
(name 'cran)
|
|
|
|
|
(description "Updater for CRAN packages")
|
|
|
|
|
(pred cran-package?)
|
2015-12-16 08:45:28 -05:00
|
|
|
|
(latest latest-cran-release)))
|
|
|
|
|
|
|
|
|
|
(define %bioconductor-updater
|
|
|
|
|
(upstream-updater
|
|
|
|
|
(name 'bioconductor)
|
|
|
|
|
(description "Updater for Bioconductor packages")
|
|
|
|
|
(pred bioconductor-package?)
|
|
|
|
|
(latest latest-bioconductor-release)))
|
2015-10-21 08:36:14 -04:00
|
|
|
|
|
|
|
|
|
;;; cran.scm ends here
|