mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-26 12:39:36 -05:00
packages: Add 'package-upstream-name*'.
* guix/packages.scm (package-upstream-name*): New procedure. * tests/packages.scm ("package-upstream-name*"): New test. Signed-off-by: Ludovic Courtès <ludo@gnu.org>
This commit is contained in:
parent
a2f0297af0
commit
052faadde7
2 changed files with 37 additions and 0 deletions
|
@ -89,6 +89,7 @@ (define-module (guix packages)
|
||||||
this-package
|
this-package
|
||||||
package-name
|
package-name
|
||||||
package-upstream-name
|
package-upstream-name
|
||||||
|
package-upstream-name*
|
||||||
package-version
|
package-version
|
||||||
package-full-name
|
package-full-name
|
||||||
package-source
|
package-source
|
||||||
|
@ -691,6 +692,38 @@ (define (package-upstream-name package)
|
||||||
(or (assq-ref (package-properties package) 'upstream-name)
|
(or (assq-ref (package-properties package) 'upstream-name)
|
||||||
(package-name package)))
|
(package-name package)))
|
||||||
|
|
||||||
|
(define (package-upstream-name* package)
|
||||||
|
"Return the upstream name of PACKAGE, accounting for commonly-used
|
||||||
|
package name prefixes in addition to the @code{upstream-name} property."
|
||||||
|
(let ((namespaces (list "cl-"
|
||||||
|
"ecl-"
|
||||||
|
"emacs-"
|
||||||
|
"ghc-"
|
||||||
|
"go-"
|
||||||
|
"guile-"
|
||||||
|
"java-"
|
||||||
|
"julia-"
|
||||||
|
"lua-"
|
||||||
|
"minetest-"
|
||||||
|
"node-"
|
||||||
|
"ocaml-"
|
||||||
|
"perl-"
|
||||||
|
"python-"
|
||||||
|
"r-"
|
||||||
|
"ruby-"
|
||||||
|
"rust-"
|
||||||
|
"sbcl-"
|
||||||
|
"texlive-"))
|
||||||
|
(name (package-name package)))
|
||||||
|
(or (assq-ref (package-properties package) 'upstream-name)
|
||||||
|
(let loop ((prefixes namespaces))
|
||||||
|
(match prefixes
|
||||||
|
(() name)
|
||||||
|
((prefix rest ...)
|
||||||
|
(if (string-prefix? prefix name)
|
||||||
|
(substring name (string-length prefix))
|
||||||
|
(loop rest))))))))
|
||||||
|
|
||||||
(define (hidden-package p)
|
(define (hidden-package p)
|
||||||
"Return a \"hidden\" version of P--i.e., one that 'fold-packages' and thus,
|
"Return a \"hidden\" version of P--i.e., one that 'fold-packages' and thus,
|
||||||
user interfaces, ignores."
|
user interfaces, ignores."
|
||||||
|
|
|
@ -626,6 +626,10 @@ (define read-at
|
||||||
(build-derivations %store (list drv))
|
(build-derivations %store (list drv))
|
||||||
(call-with-input-file output get-string-all)))
|
(call-with-input-file output get-string-all)))
|
||||||
|
|
||||||
|
(test-equal "package-upstream-name*"
|
||||||
|
(package-upstream-name* (specification->package "guile-gcrypt"))
|
||||||
|
"gcrypt")
|
||||||
|
|
||||||
|
|
||||||
;;;
|
;;;
|
||||||
;;; Source derivation with snippets.
|
;;; Source derivation with snippets.
|
||||||
|
|
Loading…
Reference in a new issue