Use a startup script to get default XKB settings from localed
This commit is contained in:
parent
a861a033bf
commit
baefed44ce
@ -35,6 +35,7 @@ check_PROGRAMS =
|
|||||||
noinst_PROGRAMS =
|
noinst_PROGRAMS =
|
||||||
lib_LTLIBRARIES =
|
lib_LTLIBRARIES =
|
||||||
noinst_LTLIBRARIES =
|
noinst_LTLIBRARIES =
|
||||||
|
bin_SCRIPTS =
|
||||||
|
|
||||||
moduledir = $(libdir)/kmscon
|
moduledir = $(libdir)/kmscon
|
||||||
module_LTLIBRARIES =
|
module_LTLIBRARIES =
|
||||||
@ -475,6 +476,7 @@ mod_pixman_la_LDFLAGS = \
|
|||||||
# built as part of kmscon.
|
# built as part of kmscon.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
bin_SCRIPTS += docs/kmscon.sh
|
||||||
bin_PROGRAMS += kmscon
|
bin_PROGRAMS += kmscon
|
||||||
check_PROGRAMS += \
|
check_PROGRAMS += \
|
||||||
test_output \
|
test_output \
|
||||||
|
@ -3,7 +3,7 @@ Description=KMS System Console
|
|||||||
Documentation=man:kmscon(1)
|
Documentation=man:kmscon(1)
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
ExecStart=/usr/bin/kmscon -l /bin/login
|
ExecStart=/usr/bin/kmscon.sh -l /bin/login
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
|
52
docs/kmscon.sh
Executable file
52
docs/kmscon.sh
Executable file
@ -0,0 +1,52 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
#
|
||||||
|
# Copyright (c) 2018 Aetf <aetf@unlimitedcodeworks.xyz>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
# of this software and associated documentation files (the "Software"), to deal
|
||||||
|
# in the Software without restriction, including without limitation the rights
|
||||||
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
# copies of the Software, and to permit persons to whom the Software is
|
||||||
|
# furnished to do so, subject to the following conditions:
|
||||||
|
#
|
||||||
|
# The above copyright notice and this permission notice shall be included in all
|
||||||
|
# copies or substantial portions of the Software.
|
||||||
|
#
|
||||||
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
# SOFTWARE.
|
||||||
|
|
||||||
|
# Get a property from org.freedesktop.locale1
|
||||||
|
queryLocale1() {
|
||||||
|
dbus-send --system --print-reply=literal --dest=org.freedesktop.locale1 /org/freedesktop/locale1 org.freedesktop.DBus.Properties.Get "string:org.freedesktop.locale1" "string:$1" | awk '{print $1}'
|
||||||
|
}
|
||||||
|
|
||||||
|
# Query and setup system locale settings before start kmscon
|
||||||
|
setupLocale() {
|
||||||
|
# Fallback to do nothing if we don't have the command
|
||||||
|
if ! command -v dbus-send >/dev/null 2>/dev/null; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Don't override existing values. Also there is no point in setting only some of them
|
||||||
|
# as then they would not match anymore.
|
||||||
|
if test -n "${XKB_DEFAULT_MODEL}" -o -n "${XKB_DEFAULT_LAYOUT}" -o -n "${XKB_DEFAULT_VARIANT}" -o -n "${XKB_DEFAULT_OPTIONS}"; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
X11MODEL="$(queryLocale1 X11Model)"
|
||||||
|
X11LAYOUT="$(queryLocale1 X11Layout)"
|
||||||
|
X11VARIANT="$(queryLocale1 X11Variant)"
|
||||||
|
X11OPTIONS="$(queryLocale1 X11Options)"
|
||||||
|
[ -n "${X11MODEL}" ] && export XKB_DEFAULT_MODEL="${X11MODEL}"
|
||||||
|
[ -n "${X11LAYOUT}" ] && export XKB_DEFAULT_LAYOUT="${X11LAYOUT}"
|
||||||
|
[ -n "${X11VARIANT}" ] && export XKB_DEFAULT_VARIANT="${X11VARIANT}"
|
||||||
|
[ -n "${X11OPTIONS}" ] && export XKB_DEFAULT_OPTIONS="${X11OPTIONS}"
|
||||||
|
}
|
||||||
|
|
||||||
|
setupLocale
|
||||||
|
exec kmscon "$@"
|
@ -37,7 +37,7 @@ IgnoreOnIsolate=yes
|
|||||||
ConditionPathExists=/dev/tty0
|
ConditionPathExists=/dev/tty0
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
ExecStart=/usr/bin/kmscon "--vt=%I" --seats=seat0 --no-switchvt
|
ExecStart=/usr/bin/kmscon.sh "--vt=%I" --seats=seat0 --no-switchvt
|
||||||
UtmpIdentifier=%I
|
UtmpIdentifier=%I
|
||||||
TTYPath=/dev/%I
|
TTYPath=/dev/%I
|
||||||
TTYReset=yes
|
TTYReset=yes
|
||||||
|
Loading…
x
Reference in New Issue
Block a user