mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-12 14:16:55 -05:00
guix: import texlive: Implement auto-updates.
* guix/import/texlive.scm (package-from-texlive-repository?): (latest-release): (tlpdb-guix-packages): (%texlive-updater): New variables. (tlpdb): Include Guix-specific package TEXLIVE-HYPHEN-COMPLETE. * guix/upstream.scm (package-update/svn-multi-fetch): New variable. (%method-updates): Extend it to support SVN-MULTI-FETCH. (update-package-source): Also update revisions and locations from svn-multi-reference sources. Change-Id: I6d7f2cfe1e2f78887f410233bfd2799ffab80f3c
This commit is contained in:
parent
9dc279e2fd
commit
c15b66ac67
2 changed files with 190 additions and 63 deletions
|
@ -45,7 +45,8 @@ (define-module (guix import texlive)
|
||||||
#:use-module (srfi srfi-19)
|
#:use-module (srfi srfi-19)
|
||||||
#:use-module (srfi srfi-26)
|
#:use-module (srfi srfi-26)
|
||||||
#:export (texlive->guix-package
|
#:export (texlive->guix-package
|
||||||
texlive-recursive-import))
|
texlive-recursive-import
|
||||||
|
%texlive-updater))
|
||||||
|
|
||||||
;;; Commentary:
|
;;; Commentary:
|
||||||
;;;
|
;;;
|
||||||
|
@ -102,6 +103,42 @@ (define no-bin-propagation-packages
|
||||||
"tie"
|
"tie"
|
||||||
"web"))
|
"web"))
|
||||||
|
|
||||||
|
;; Guix introduces two specific packages based on TEXLIVE-BUILD-SYSTEM. Add
|
||||||
|
;; an entry for them in the package database, so they can be imported, and
|
||||||
|
;; updated, like any other regular TeX Live package.
|
||||||
|
(define tlpdb-guix-packages
|
||||||
|
'(("hyphen-complete"
|
||||||
|
(docfiles "texmf-dist/doc/generic/dehyph-exptl/"
|
||||||
|
"texmf-dist/doc/generic/elhyphen/"
|
||||||
|
"texmf-dist/doc/generic/huhyphen/"
|
||||||
|
"texmf-dist/doc/generic/hyph-utf8/"
|
||||||
|
"texmf-dist/doc/luatex/hyph-utf8/"
|
||||||
|
"texmf-dist/doc/generic/ukrhyph/")
|
||||||
|
(runfiles "texmf-dist/tex/generic/config/"
|
||||||
|
"texmf-dist/tex/generic/dehyph/"
|
||||||
|
"texmf-dist/tex/generic/dehyph-exptl/"
|
||||||
|
"texmf-dist/tex/generic/hyph-utf8/"
|
||||||
|
"texmf-dist/tex/generic/hyphen/"
|
||||||
|
"texmf-dist/tex/generic/ruhyphen/"
|
||||||
|
"texmf-dist/tex/generic/ukrhyph/"
|
||||||
|
"texmf-dist/tex/luatex/hyph-utf8/")
|
||||||
|
(srcfiles "texmf-dist/source/generic/hyph-utf8/"
|
||||||
|
"texmf-dist/source/luatex/hyph-utf8/"
|
||||||
|
"texmf-dist/source/generic/ruhyphen/")
|
||||||
|
(shortdesc . "Hyphenation patterns expressed in UTF-8")
|
||||||
|
(longdesc . "Modern native UTF-8 engines such as XeTeX and LuaTeX
|
||||||
|
need hyphenation patterns in UTF-8 format, whereas older systems require
|
||||||
|
hyphenation patterns in the 8-bit encoding of the font in use (such encodings
|
||||||
|
are codified in the LaTeX scheme with names like OT1, T2A, TS1, OML, LY1,
|
||||||
|
etc). The present package offers a collection of conversions of existing
|
||||||
|
patterns to UTF-8 format, together with converters for use with 8-bit fonts in
|
||||||
|
older systems.
|
||||||
|
|
||||||
|
This Guix-specific package provides hyphenation patterns for all languages
|
||||||
|
supported in TeX Live. It is a strict super-set of code{hyphen-base} package
|
||||||
|
and should be preferred to it whenever a package would otherwise depend on
|
||||||
|
@code{hyph-utf8}."))))
|
||||||
|
|
||||||
(define (svn-command . args)
|
(define (svn-command . args)
|
||||||
"Execute \"svn\" command with arguments ARGS, provided as strings, and
|
"Execute \"svn\" command with arguments ARGS, provided as strings, and
|
||||||
return its output as a string. Raise an error if the command execution did
|
return its output as a string. Raise an error if the command execution did
|
||||||
|
@ -301,7 +338,8 @@ (define (tlpdb version)
|
||||||
(last-property #false))
|
(last-property #false))
|
||||||
(let ((line (read-line port)))
|
(let ((line (read-line port)))
|
||||||
(cond
|
(cond
|
||||||
((eof-object? line) (values all))
|
;; End of file. Don't forget to include Guix-specific package.
|
||||||
|
((eof-object? line) (values (append tlpdb-guix-packages all)))
|
||||||
|
|
||||||
;; End of record.
|
;; End of record.
|
||||||
((string-null? line)
|
((string-null? line)
|
||||||
|
@ -617,4 +655,33 @@ (define* (texlive-recursive-import name #:key repo version)
|
||||||
#:repo->guix-package texlive->guix-package
|
#:repo->guix-package texlive->guix-package
|
||||||
#:guix-name guix-name))
|
#:guix-name guix-name))
|
||||||
|
|
||||||
|
;;;
|
||||||
|
;;; Updates.
|
||||||
|
;;;
|
||||||
|
|
||||||
|
(define (package-from-texlive-repository? package)
|
||||||
|
(and (string-prefix? "texlive-" (package-name package))
|
||||||
|
(eq? 'texlive (build-system-name (package-build-system package)))))
|
||||||
|
|
||||||
|
(define* (latest-release package #:key version)
|
||||||
|
"Return an <upstream-source> for the latest release of PACKAGE. Optionally
|
||||||
|
include a VERSION string to fetch a specific version."
|
||||||
|
(let* ((version (or version (latest-texlive-tag)))
|
||||||
|
(database (tlpdb/cached version))
|
||||||
|
(upstream-name (package-upstream-name* package)))
|
||||||
|
(upstream-source
|
||||||
|
(package upstream-name)
|
||||||
|
(version version)
|
||||||
|
(urls (texlive->svn-multi-reference upstream-name version database))
|
||||||
|
(inputs (list-upstream-inputs upstream-name version database)))))
|
||||||
|
|
||||||
|
(define %texlive-updater
|
||||||
|
;; The TeX Live updater. It is restricted to TeX Live releases (2023.0,
|
||||||
|
;; 2024.2, ...); it doesn't include revision bumps for individual packages.
|
||||||
|
(upstream-updater
|
||||||
|
(name 'texlive)
|
||||||
|
(description "Updater for TeX Live packages")
|
||||||
|
(pred package-from-texlive-repository?)
|
||||||
|
(import latest-release)))
|
||||||
|
|
||||||
;;; texlive.scm ends here
|
;;; texlive.scm ends here
|
||||||
|
|
|
@ -28,6 +28,7 @@ (define-module (guix upstream)
|
||||||
#:use-module ((guix download)
|
#:use-module ((guix download)
|
||||||
#:select (download-to-store url-fetch))
|
#:select (download-to-store url-fetch))
|
||||||
#:use-module (guix git-download)
|
#:use-module (guix git-download)
|
||||||
|
#:use-module (guix svn-download)
|
||||||
#:use-module (guix gnupg)
|
#:use-module (guix gnupg)
|
||||||
#:use-module (guix packages)
|
#:use-module (guix packages)
|
||||||
#:use-module (guix diagnostics)
|
#:use-module (guix diagnostics)
|
||||||
|
@ -49,6 +50,7 @@ (define-module (guix upstream)
|
||||||
#:use-module (srfi srfi-35)
|
#:use-module (srfi srfi-35)
|
||||||
#:use-module (rnrs bytevectors)
|
#:use-module (rnrs bytevectors)
|
||||||
#:use-module (ice-9 match)
|
#:use-module (ice-9 match)
|
||||||
|
#:use-module (ice-9 regex)
|
||||||
#:export (upstream-source
|
#:export (upstream-source
|
||||||
upstream-source?
|
upstream-source?
|
||||||
upstream-source-package
|
upstream-source-package
|
||||||
|
@ -107,7 +109,7 @@ (define-record-type* <upstream-source>
|
||||||
upstream-source?
|
upstream-source?
|
||||||
(package upstream-source-package) ;string
|
(package upstream-source-package) ;string
|
||||||
(version upstream-source-version) ;string
|
(version upstream-source-version) ;string
|
||||||
(urls upstream-source-urls) ;list of strings|git-reference
|
(urls upstream-source-urls) ;list of strings|git-references...
|
||||||
(signature-urls upstream-source-signature-urls ;#f | list of strings
|
(signature-urls upstream-source-signature-urls ;#f | list of strings
|
||||||
(default #f))
|
(default #f))
|
||||||
(inputs upstream-source-inputs ;#f | list of <upstream-input>
|
(inputs upstream-source-inputs ;#f | list of <upstream-input>
|
||||||
|
@ -463,10 +465,19 @@ (define ref (upstream-source-urls source)) ; a <git-reference>
|
||||||
#:recursive? (git-reference-recursive? ref))
|
#:recursive? (git-reference-recursive? ref))
|
||||||
source))
|
source))
|
||||||
|
|
||||||
|
(define* (package-update/svn-multi-fetch store package source
|
||||||
|
#:key key-download key-server)
|
||||||
|
"Return the version, checkout, and SOURCE, to update PACKAGE to
|
||||||
|
SOURCE, an <upstream-source>."
|
||||||
|
(values (upstream-source-version source)
|
||||||
|
(download-multi-svn-to-store store (upstream-source-urls source))
|
||||||
|
source))
|
||||||
|
|
||||||
(define %method-updates
|
(define %method-updates
|
||||||
;; Mapping of origin methods to source update procedures.
|
;; Mapping of origin methods to source update procedures.
|
||||||
`((,url-fetch . ,package-update/url-fetch)
|
`((,url-fetch . ,package-update/url-fetch)
|
||||||
(,git-fetch . ,package-update/git-fetch)))
|
(,git-fetch . ,package-update/git-fetch)
|
||||||
|
(,svn-multi-fetch . ,package-update/svn-multi-fetch)))
|
||||||
|
|
||||||
(define* (package-update store package
|
(define* (package-update store package
|
||||||
#:optional (updaters (force %updaters))
|
#:optional (updaters (force %updaters))
|
||||||
|
@ -608,9 +619,9 @@ (define* (update-package-source package source hash)
|
||||||
"Modify the source file that defines PACKAGE to refer to SOURCE, an
|
"Modify the source file that defines PACKAGE to refer to SOURCE, an
|
||||||
<upstream-source> whose tarball has SHA256 HASH (a bytevector). Return the
|
<upstream-source> whose tarball has SHA256 HASH (a bytevector). Return the
|
||||||
new version string if an update was made, and #f otherwise."
|
new version string if an update was made, and #f otherwise."
|
||||||
(define (update-expression expr replacements)
|
(define (replace-atom expr replacements)
|
||||||
;; Apply REPLACEMENTS to package expression EXPR, a string. REPLACEMENTS
|
;; Apply REPLACEMENTS to package expression EXPR, a string. REPLACEMENTS
|
||||||
;; must be a list of replacement pairs, either bytevectors or strings.
|
;; must be a list of replacement pairs, either of byte-vectors or strings.
|
||||||
(fold (lambda (replacement str)
|
(fold (lambda (replacement str)
|
||||||
(match replacement
|
(match replacement
|
||||||
(((? bytevector? old-bv) . (? bytevector? new-bv))
|
(((? bytevector? old-bv) . (? bytevector? new-bv))
|
||||||
|
@ -623,62 +634,111 @@ (define (update-expression expr replacements)
|
||||||
expr
|
expr
|
||||||
replacements))
|
replacements))
|
||||||
|
|
||||||
(let ((name (package-name package))
|
(define (replace-commit old new expr)
|
||||||
(version (upstream-source-version source))
|
;; Replace OLD commit or revision with NEW commit or revision in package
|
||||||
(version-loc (package-field-location package 'version)))
|
;; expression EXPR. Special care is given to ensure the commit or
|
||||||
(if version-loc
|
;; revision does not inadvertently match a part of a bigger item.
|
||||||
(let* ((loc (package-location package))
|
(let ((regexp (make-regexp (format #f " ~s($|[ )])" old)
|
||||||
(old-version (package-version package))
|
regexp/newline)))
|
||||||
(old-hash (content-hash-value
|
(regexp-substitute/global
|
||||||
(origin-hash (package-source package))))
|
#f regexp expr 'pre (lambda (m) (format #f " ~s" new)) 1 'post)))
|
||||||
(old-url (match (origin-uri (package-source package))
|
|
||||||
((? string? url) url)
|
(define (replace-list old new expr)
|
||||||
((? git-reference? ref)
|
;; Replace list OLD with list NEW in package expression EXPR. Elements in
|
||||||
(git-reference-url ref))
|
;; NEW are aligned vertically, at the same column as the first element in
|
||||||
(_ #f)))
|
;; OLD.
|
||||||
(new-url (match (upstream-source-urls source)
|
(if (equal? old new)
|
||||||
((first _ ...) first)
|
expr
|
||||||
((? git-reference? ref)
|
(let ((regexp
|
||||||
(git-reference-url ref))
|
(make-regexp
|
||||||
(_ #f)))
|
(string-append
|
||||||
(old-commit (match (origin-uri (package-source package))
|
"(^[^\"]*)" ;initial indentation in group 1
|
||||||
((? git-reference? ref)
|
(string-join (map (compose regexp-quote object->string) old)
|
||||||
(git-reference-commit ref))
|
"[ \t\n]*"))
|
||||||
(_ #f)))
|
regexp/newline))
|
||||||
(new-commit (match (upstream-source-urls source)
|
(f
|
||||||
((? git-reference? ref)
|
(lambda (m)
|
||||||
(git-reference-commit ref))
|
(let* ((lead (match:substring m 1))
|
||||||
(_ #f)))
|
(indent (make-string (string-length lead) #\space)))
|
||||||
(file (and=> (location-file loc)
|
(string-append
|
||||||
(cut search-path %load-path <>))))
|
lead
|
||||||
(if file
|
(string-join (map object->string new)
|
||||||
;; Be sure to use absolute filename. Replace the URL directory
|
(string-append "\n" indent)))))))
|
||||||
;; when OLD-URL is available; this is useful notably for
|
(regexp-substitute/global #f regexp expr 'pre f 'post))))
|
||||||
;; mirror://cpan/ URLs where the directory may change as a
|
|
||||||
;; function of the person who uploads the package. Note that
|
(let* ((name (package-name package))
|
||||||
;; package definitions usually concatenate fragments of the URL,
|
(loc (package-location package))
|
||||||
;; which is why we only attempt to replace a subset of the URL.
|
(version (upstream-source-version source))
|
||||||
(let ((replacements `((,old-version . ,version)
|
(old-version (package-version package))
|
||||||
(,old-hash . ,hash)
|
(old-hash (content-hash-value
|
||||||
,@(if (and old-commit new-commit)
|
(origin-hash (package-source package))))
|
||||||
`((,old-commit . ,new-commit))
|
(old-url (match (origin-uri (package-source package))
|
||||||
'())
|
((? string? url) url)
|
||||||
,@(if (and old-url new-url)
|
((? git-reference? ref)
|
||||||
`((,(dirname old-url) .
|
(git-reference-url ref))
|
||||||
,(dirname new-url)))
|
((? svn-multi-reference? ref)
|
||||||
'()))))
|
(svn-multi-reference-url ref))
|
||||||
(and (edit-expression (location->source-properties
|
(_ #f)))
|
||||||
(absolute-location loc))
|
(old-commit (match (origin-uri (package-source package))
|
||||||
(cut update-expression <> replacements))
|
((? git-reference? ref)
|
||||||
(or (not (upstream-source-inputs source))
|
(git-reference-commit ref))
|
||||||
(update-package-inputs package source))
|
((? svn-multi-reference? ref)
|
||||||
version))
|
(svn-multi-reference-revision ref))
|
||||||
(begin
|
(_ #f)))
|
||||||
(warning (G_ "~a: could not locate source file")
|
(old-locations (match (origin-uri (package-source package))
|
||||||
(location-file loc))
|
((? svn-multi-reference? ref)
|
||||||
#f)))
|
(svn-multi-reference-locations ref))
|
||||||
(warning (package-location package)
|
(_ #f)))
|
||||||
(G_ "~a: no `version' field in source; skipping~%")
|
(new-url (match (upstream-source-urls source)
|
||||||
name))))
|
((first _ ...) first)
|
||||||
|
((? git-reference? ref)
|
||||||
|
(git-reference-url ref))
|
||||||
|
((? svn-multi-reference? ref)
|
||||||
|
(svn-multi-reference-url ref))
|
||||||
|
(_ #f)))
|
||||||
|
(new-commit (match (upstream-source-urls source)
|
||||||
|
((? git-reference? ref)
|
||||||
|
(git-reference-commit ref))
|
||||||
|
((? svn-multi-reference? ref)
|
||||||
|
(svn-multi-reference-revision ref))
|
||||||
|
(_ #f)))
|
||||||
|
(new-locations (match (upstream-source-urls source)
|
||||||
|
((? svn-multi-reference? ref)
|
||||||
|
(svn-multi-reference-locations ref))
|
||||||
|
(_ #f))))
|
||||||
|
(cond
|
||||||
|
;; Ensure package exists, has a version field, and is stored in a file
|
||||||
|
;; with an absolute file name.
|
||||||
|
((not (package-field-location package 'version))
|
||||||
|
(warning (package-location package)
|
||||||
|
(G_ "~a: no `version' field in source; skipping~%")
|
||||||
|
name))
|
||||||
|
((not (and=> (location-file loc)
|
||||||
|
(cut search-path %load-path <>)))
|
||||||
|
(warning (G_ "~a: could not locate source file")
|
||||||
|
(location-file loc))
|
||||||
|
#f)
|
||||||
|
;; Proceed with replacements.
|
||||||
|
(else
|
||||||
|
(let ((replacement-pairs
|
||||||
|
`((,old-version . ,version)
|
||||||
|
(,old-hash . ,hash)
|
||||||
|
;; Replace the URL directory when OLD-URL is available; this is
|
||||||
|
;; useful notably for mirror://cpan/ URLs where the directory
|
||||||
|
;; may change as a function of the person who uploads the
|
||||||
|
;; package. Note that package definitions usually concatenate
|
||||||
|
;; fragments of the URL, which is why we only attempt to
|
||||||
|
;; replace a subset of the URL.
|
||||||
|
,@(if (and old-url new-url)
|
||||||
|
`((,(dirname old-url) . ,(dirname new-url)))
|
||||||
|
'()))))
|
||||||
|
(and (edit-expression
|
||||||
|
(location->source-properties (absolute-location loc))
|
||||||
|
(compose (cut replace-atom <> replacement-pairs)
|
||||||
|
(cut replace-commit old-commit new-commit <>)
|
||||||
|
(cut replace-list old-locations new-locations <>)))
|
||||||
|
(or (not (upstream-source-inputs source))
|
||||||
|
(update-package-inputs package source))
|
||||||
|
version))))))
|
||||||
|
|
||||||
;;; upstream.scm ends here
|
;;; upstream.scm ends here
|
||||||
|
|
Loading…
Reference in a new issue