gnu: glibc: Do not install all the locales.

* gnu/packages/base.scm (glibc)[outputs]: Remove "locales".
  [arguments]: Remove --localedir argument.  Change libc_cv_localedir
  value to "/run/current-system/locale".  Remove 'install-locales'
  phase.
This commit is contained in:
Ludovic Courtès 2014-11-26 11:16:05 +01:00
parent c4a298c52c
commit 97e1120903

View file

@ -381,25 +381,27 @@ (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 (outputs '("out" "debug"))
;; 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" "debug"))
(arguments (arguments
`(#:out-of-source? #t `(#:out-of-source? #t
#:configure-flags #:configure-flags
(list "--enable-add-ons" (list "--enable-add-ons"
"--sysconfdir=/etc" "--sysconfdir=/etc"
(string-append "--localedir=" (assoc-ref %outputs "locales")
"/share/locale")
;; Installing a locale archive with all the locales is to
;; expensive (~100 MiB), so we rely on users to install the
;; locales they really want.
;;
;; Set the default locale path. In practice, $LOCPATH may be
;; defined to point whatever locales users want. However, setuid
;; binaries don't honor $LOCPATH, so they'll instead look into
;; $libc_cv_localedir; we choose /run/current-system/locale, with
;; the idea that it is going to be populated by the sysadmin.
;;
;; `--localedir' is not honored, so work around it. ;; `--localedir' is not honored, so work around it.
;; See <http://sourceware.org/ml/libc-alpha/2013-03/msg00093.html>. ;; See <http://sourceware.org/ml/libc-alpha/2013-03/msg00093.html>.
(string-append "libc_cv_localedir=" (string-append "libc_cv_localedir=/run/current-system/locale")
(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")
@ -476,11 +478,7 @@ (define-public glibc
"") "")
(("exec @PERL@") (("exec @PERL@")
"exec perl")))) "exec perl"))))
(alist-cons-after %standard-phases)))
'install 'install-locales
(lambda _
(zero? (system* "make" "localedata/install-locales")))
%standard-phases))))
(inputs `(("static-bash" ,(static-package bash-light)))) (inputs `(("static-bash" ,(static-package bash-light))))