gnu: Honor the operating system's locale and timezone.

* gnu/system.scm (etc-directory): Add 'locale' and 'timezone'
  parameters.  Set 'LC_ALL', 'TZ', and 'TZDIR' in /etc/profile.
  (operating-system-derivation): Adjust call accordingly.
* gnu/system/vm.scm (%demo-operating-system): Change locale to
  'en_US.UTF-8'.  Add TZDATA to 'packages'.
This commit is contained in:
Ludovic Courtès 2013-12-10 21:46:59 +01:00
parent dfb74e50b7
commit 3141a8bdb3
2 changed files with 17 additions and 3 deletions

View file

@ -85,7 +85,8 @@ (define-record-type* <operating-system> operating-system
guile
bash
(@ (gnu packages dmd) dmd)
guix)))
guix
tzdata)))
(timezone operating-system-timezone) ; string
(locale operating-system-locale) ; string
@ -214,6 +215,7 @@ (define builder
#:inputs inputs)))
(define* (etc-directory #:key
(locale "C") (timezone "Europe/Paris")
(accounts '())
(groups '())
(pam-services '())
@ -238,9 +240,18 @@ (define* (etc-directory #:key
You can log in as 'guest' or 'root' with no password.
"))
;; Assume TZDATA is installed---e.g., as part of the system packages.
;; Users can choose not to have it.
(tzdir (package-file tzdata "share/zoneinfo"))
;; TODO: Generate bashrc from packages' search-paths.
(bashrc (text-file "bashrc" (string-append "
export PS1='\\u@\\h\\$ '
export LC_ALL=\"" locale "\"
export TZ=\"" timezone "\"
export TZDIR=\"" tzdir "\"
export PATH=$HOME/.guix-profile/bin:" profile "/bin:" profile "/sbin
export CPATH=$HOME/.guix-profile/include:" profile "/include
export LIBRARY_PATH=$HOME/.guix-profile/lib:" profile "/lib
@ -297,6 +308,8 @@ (define (operating-system-derivation os)
(profile -> (derivation->output-path profile-drv))
(etc-drv (etc-directory #:accounts accounts #:groups groups
#:pam-services pam-services
#:locale (operating-system-locale os)
#:timezone (operating-system-timezone os)
#:profile profile))
(etc -> (derivation->output-path etc-drv))
(dmd-conf (dmd-configuration-file services etc))

View file

@ -26,7 +26,7 @@ (define-module (gnu system vm)
#:select (%final-inputs
guile-final gcc-final glibc-final
ld-wrapper binutils-final
coreutils findutils grep sed))
coreutils findutils grep sed tzdata))
#:use-module (gnu packages guile)
#:use-module (gnu packages bash)
#:use-module (gnu packages less)
@ -411,7 +411,7 @@ (define %demo-operating-system
(operating-system
(host-name "gnu")
(timezone "Europe/Paris")
(locale "C.UTF-8")
(locale "en_US.UTF-8")
(users (list (user-account
(name "guest")
(password "")
@ -434,6 +434,7 @@ (define %demo-operating-system
psmisc
zile
less
tzdata
guix))))
(define* (system-qemu-image #:optional (os %demo-operating-system))