mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 20:19:18 -05:00
profiles: 'info-dir-file' hook now produces 'dir.LANG' files.
Previously, entries for 'guix.fr.info' would end up in 'dir', above the 'guix.info' entries; consequently, running 'info guix' would actually open 'guix.fr.info', which was confusing for non-French readers. * guix/profiles.scm (info-dir-file)[glibc-utf8-locales]: New variable. [build](info-file-language): New procedure. (install-info): Use it, to create 'dir.LANG' files. Set GUIX_LOCPATH.
This commit is contained in:
parent
a51cf16031
commit
5b0c648a7c
1 changed files with 26 additions and 4 deletions
|
@ -703,6 +703,8 @@ (define texinfo ;lazy reference
|
||||||
(module-ref (resolve-interface '(gnu packages texinfo)) 'texinfo))
|
(module-ref (resolve-interface '(gnu packages texinfo)) 'texinfo))
|
||||||
(define gzip ;lazy reference
|
(define gzip ;lazy reference
|
||||||
(module-ref (resolve-interface '(gnu packages compression)) 'gzip))
|
(module-ref (resolve-interface '(gnu packages compression)) 'gzip))
|
||||||
|
(define glibc-utf8-locales ;lazy reference
|
||||||
|
(module-ref (resolve-interface '(gnu packages base)) 'glibc-utf8-locales))
|
||||||
|
|
||||||
(define build
|
(define build
|
||||||
(with-imported-modules '((guix build utils))
|
(with-imported-modules '((guix build utils))
|
||||||
|
@ -720,11 +722,31 @@ (define (info-files top)
|
||||||
(map (cut string-append infodir "/" <>)
|
(map (cut string-append infodir "/" <>)
|
||||||
(or (scandir infodir info-file?) '()))))
|
(or (scandir infodir info-file?) '()))))
|
||||||
|
|
||||||
|
(define (info-file-language file)
|
||||||
|
(let* ((base (if (string-suffix? ".gz" file)
|
||||||
|
(basename file ".info.gz")
|
||||||
|
(basename file ".info")))
|
||||||
|
(dot (string-rindex base #\.)))
|
||||||
|
(if dot
|
||||||
|
(string-drop base (+ 1 dot))
|
||||||
|
"en")))
|
||||||
|
|
||||||
(define (install-info info)
|
(define (install-info info)
|
||||||
(setenv "PATH" (string-append #+gzip "/bin")) ;for info.gz files
|
(let ((language (info-file-language info)))
|
||||||
(zero?
|
;; We need to choose a valid locale for $LANGUAGE to be honored.
|
||||||
(system* (string-append #+texinfo "/bin/install-info") "--silent"
|
(setenv "LC_ALL" "en_US.utf8")
|
||||||
info (string-append #$output "/share/info/dir"))))
|
(setenv "LANGUAGE" language)
|
||||||
|
(zero?
|
||||||
|
(system* #+(file-append texinfo "/bin/install-info")
|
||||||
|
"--silent" info
|
||||||
|
(apply string-append #$output "/share/info/dir"
|
||||||
|
(if (string=? "en" language)
|
||||||
|
'("")
|
||||||
|
`("." ,language)))))))
|
||||||
|
|
||||||
|
(setenv "PATH" (string-append #+gzip "/bin")) ;for info.gz files
|
||||||
|
(setenv "GUIX_LOCPATH"
|
||||||
|
#+(file-append glibc-utf8-locales "/lib/locale"))
|
||||||
|
|
||||||
(mkdir-p (string-append #$output "/share/info"))
|
(mkdir-p (string-append #$output "/share/info"))
|
||||||
(exit (every install-info
|
(exit (every install-info
|
||||||
|
|
Loading…
Reference in a new issue