gnu: glibc: Install locale data.

* gnu/packages/base.scm (glibc): Add `outputs' field.  Pass
  `--localedir' and set `libc_cv_localedir'.  Add `install-locales'
  phase.
This commit is contained in:
Ludovic Courtès 2013-03-05 18:38:05 +01:00
parent 81eec00cb2
commit 7f614e49e8

View file

@ -508,13 +508,28 @@ (define-public glibc
;; users should automatically pull Linux headers as well. ;; users should automatically pull Linux headers as well.
(propagated-inputs `(("linux-headers" ,linux-libre-headers))) (propagated-inputs `(("linux-headers" ,linux-libre-headers)))
;; Store the locales separately (~100 MiB). Note that "out" retains a
;; reference to them anyway, so there's no space savings here.
;; TODO: Eventually we may want to add a $LOCALE_ARCHIVE search path like
;; Nixpkgs does.
(outputs '("out" "locales"))
(arguments (arguments
`(#:out-of-source? #t `(#:out-of-source? #t
#:patches (list (assoc-ref %build-inputs "patch/ld.so.cache")) #:patches (list (assoc-ref %build-inputs "patch/ld.so.cache"))
#:configure-flags #:configure-flags
(list "--enable-add-ons" (list "--enable-add-ons"
"--sysconfdir=/etc" "--sysconfdir=/etc"
"--localedir=/var/run/current-system/sw/lib/locale" ; XXX (string-append "--localedir=" (assoc-ref %outputs "locales")
"/share/locale")
;; `--localedir' is not honored, so work around it.
;; See <http://sourceware.org/ml/libc-alpha/2013-03/msg00093.html>.
(string-append "libc_cv_localedir="
(assoc-ref %outputs "locales")
"/share/locale")
(string-append "--with-headers=" (string-append "--with-headers="
(assoc-ref %build-inputs "linux-headers") (assoc-ref %build-inputs "linux-headers")
"/include") "/include")
@ -580,7 +595,12 @@ (define-public glibc
(substitute* "libio/iopopen.c" (substitute* "libio/iopopen.c"
(("/bin/sh") (("/bin/sh")
(string-append out "/bin/bash"))))) (string-append out "/bin/bash")))))
%standard-phases))) (alist-cons-after
'install 'install-locales
(lambda _
(zero? (system* "make" "localedata/install-locales")))
%standard-phases))))
(inputs `(("patch/ld.so.cache" (inputs `(("patch/ld.so.cache"
,(search-patch "glibc-no-ld-so-cache.patch")) ,(search-patch "glibc-no-ld-so-cache.patch"))
("static-bash" ,(static-package bash-light)))) ("static-bash" ,(static-package bash-light))))