From 10d3fbf051da1af4d45e269394433ad072b1f6c7 Mon Sep 17 00:00:00 2001 From: Efraim Flashner Date: Sun, 15 Mar 2020 23:27:45 +0200 Subject: gnu: edirect: Install more programs. * gnu/packages/bioinformatics.scm (edirect)[arguments]: Add 'patch-programs phase to work around not finding binaries in the PATH. Rewrite 'install phase to install many more scripts. Rewrite 'wrap-program to wrap more scripts with more programs. [inputs]: Add edirect-go-programs. [native-search-paths]: New field. --- gnu/packages/bioinformatics.scm | 55 ++++++++++++++++++++++++++++++++++------- 1 file changed, 46 insertions(+), 9 deletions(-) diff --git a/gnu/packages/bioinformatics.scm b/gnu/packages/bioinformatics.scm index 242aafc632..33dda7ef39 100644 --- a/gnu/packages/bioinformatics.scm +++ b/gnu/packages/bioinformatics.scm @@ -2781,19 +2781,48 @@ quantitative phenotypes.") (delete 'configure) (delete 'build) (delete 'check) ; simple check after install + (add-after 'unpack 'patch-programs + (lambda* (#:key inputs #:allow-other-keys) + ;; Ignore errors about missing xtract.Linux and rchive.Linux. + (substitute* "pm-refresh" + (("cat \\\"\\$target") + "grep ^[[:digit:]] \"$target")) + #t)) (replace 'install - (lambda* (#:key outputs #:allow-other-keys) - (install-file "edirect.pl" - (string-append (assoc-ref outputs "out") "/bin")) + (lambda* (#:key inputs outputs #:allow-other-keys) + (let ((bin (string-append (assoc-ref outputs "out") "/bin")) + (edirect-go (assoc-ref inputs "edirect-go-programs"))) + (for-each + (lambda (file) + (install-file file bin)) + '("archive-pubmed" "asp-cp" "asp-ls" "download-ncbi-data" + "download-pubmed" "edirect.pl" "efetch" "epost" "esearch" + "fetch-pubmed" "ftp-cp" "ftp-ls" "has-asp" "index-pubmed" + "pm-prepare" "pm-refresh" "pm-stash" "pm-collect" + "pm-index" "pm-invert" "pm-merge" "pm-promote")) + (symlink (string-append edirect-go "/bin/xtract.Linux") + (string-append bin "/xtract")) + (symlink (string-append edirect-go "/bin/rchive.Linux") + (string-append bin "/rchive"))) #t)) (add-after 'install 'wrap-program (lambda* (#:key outputs #:allow-other-keys) - ;; Make sure 'edirect.pl' finds all perl inputs at runtime. - (let* ((out (assoc-ref outputs "out")) + ;; Make sure everything can run in a pure environment. + (let ((out (assoc-ref outputs "out")) (path (getenv "PERL5LIB"))) - (wrap-program (string-append out "/bin/edirect.pl") - `("PERL5LIB" ":" prefix (,path)))) - #t)) + (for-each + (lambda (file) + (wrap-program file + `("PERL5LIB" ":" prefix (,path))) + (wrap-program file + `("PATH" ":" prefix (,(string-append out "/bin") + ,(dirname (which "sed")) + ,(dirname (which "gzip")) + ,(dirname (which "grep")) + ,(dirname (which "perl")) + ,(dirname (which "uname")))))) + (find-files out "."))) + #t)) (add-after 'wrap-program 'check (lambda* (#:key outputs #:allow-other-keys) (invoke (string-append (assoc-ref outputs "out") @@ -2801,7 +2830,8 @@ quantitative phenotypes.") "-filter" "-help") #t))))) (inputs - `(("perl-html-parser" ,perl-html-parser) + `(("edirect-go-programs" ,edirect-go-programs) + ("perl-html-parser" ,perl-html-parser) ("perl-encode-locale" ,perl-encode-locale) ("perl-file-listing" ,perl-file-listing) ("perl-html-tagset" ,perl-html-tagset) @@ -2831,6 +2861,13 @@ EDirect also provides an argument-driven function that simplifies the extraction of data from document summaries or other results that are returned in structured XML format. This can eliminate the need for writing custom software to answer ad hoc questions.") + (native-search-paths + ;; Ideally this should be set for LWP somewhere. + (list (search-path-specification + (variable "PERL_LWP_SSL_CA_FILE") + (file-type 'regular) + (separator #f) + (files '("/etc/ssl/certs/ca-certificates.crt"))))) (license license:public-domain))) (define-public edirect-go-programs -- cgit v1.2.3