Browse Source

i18n: do not use systemd-vconsole-setup

systemd-vconsole-setup was not designed to be run from udevd.
It checks locale environment to decide, whether UNICODE should
be enabled or disabled. Normally environment is setup by
systemd; but the only environment available in udev rules is
those from device properties. It means systemd-vconsole-setup
always assumes default C locale and disables UNICODE.

Revert to using built-in console_init which explicitly
imports locale settings from /etc/vconsole.conf. Alternative
is to revert 6545b9d7 and call console_init directly :)

Additionally patch fixes console_init to use new namespace as
well as ensures that default font is always installed.

Signed-off-by: Andrey Borzenkov <arvidjaar@gmail.com>
master
Andrey Borzenkov 15 years ago committed by Harald Hoyer
parent
commit
161da365e2
  1. 10
      modules.d/10i18n/console_init
  2. 18
      modules.d/10i18n/install

10
modules.d/10i18n/console_init

@ -4,7 +4,7 @@ @@ -4,7 +4,7 @@

[ -e /etc/vconsole.conf ] && . /etc/vconsole.conf

DEFAULT_SYSFONT=LatArCyrHeb-16
DEFAULT_FONT=LatArCyrHeb-16
DEFAULT_KEYMAP=/etc/sysconfig/console/default.kmap

set_keyboard() {
@ -42,11 +42,11 @@ set_keymap() { @@ -42,11 +42,11 @@ set_keymap() {
set_font() {
local dev=$1; local trans=''; local uni=''

[ -z "${SYSFONT}" ] && SYSFONT=${DEFAULT_SYSFONT}
[ -n "${CONTRANS}" ] && trans="-m ${CONTRANS}"
[ -n "${UNIMAP}" ] && uni="-u ${UNIMAP}"
[ -z "${FONT}" ] && FONT=${DEFAULT_FONT}
[ -n "${FONT_MAP}" ] && trans="-m ${FONT_MAP}"
[ -n "${FONT_UNIMAP}" ] && uni="-u ${FONT_UNIMAP}"

setfont ${SYSFONT} -C ${dev} ${trans} ${uni}
setfont ${FONT} -C ${dev} ${trans} ${uni}
}

dev_close() {

18
modules.d/10i18n/install

@ -73,13 +73,7 @@ gather_vars() { @@ -73,13 +73,7 @@ gather_vars() {
install_base() {
dracut_install setfont loadkeys kbd_mode stty

if [ -x /lib/systemd/systemd-vconsole-setup ]; then
dracut_install /lib/systemd/systemd-vconsole-setup
inst_dir /lib/udev
ln -s /lib/systemd/systemd-vconsole-setup "${initdir}/lib/udev/console_init"
else
inst ${moddir}/console_init /lib/udev/console_init
fi
inst ${moddir}/console_init /lib/udev/console_init
inst_rules ${moddir}/10-console.rules
inst_hook cmdline 20 "${moddir}/parse-i18n.sh"
}
@ -123,9 +117,13 @@ install_local_i18n() { @@ -123,9 +117,13 @@ install_local_i18n() {

inst_opt_decompress ${KEYMAPS}

[[ ${FONT} ]] || FONT=${DEFAULT_FONT}
FONT=${FONT%.psf*}
inst_opt_decompress ${kbddir}/consolefonts/${FONT}.*
inst_opt_decompress ${kbddir}/consolefonts/${DEFAULT_FONT}.*

if [[ ${FONT} ]]
then
FONT=${FONT%.psf*}
inst_opt_decompress ${kbddir}/consolefonts/${FONT}.*
fi

if [[ ${FONT_MAP} ]]
then

Loading…
Cancel
Save