diff options
author | pascal <pascal@b9310e46-f624-0410-8ea1-cfbb3a30dc96> | 2009-01-09 11:30:38 +0000 |
---|---|---|
committer | pascal <pascal@b9310e46-f624-0410-8ea1-cfbb3a30dc96> | 2009-01-09 11:30:38 +0000 |
commit | 3e48e52705172e15f8b82c965913b1e85b2c3fab (patch) | |
tree | db7ff152d6b54b3aa28260c2efab46553ae24950 /linux/bin/uiae | |
parent | 25ff2c73459634908461448137524eebb66bc209 (diff) | |
download | neo-layout-3e48e52705172e15f8b82c965913b1e85b2c3fab.tar.gz neo-layout-3e48e52705172e15f8b82c965913b1e85b2c3fab.tar.bz2 neo-layout-3e48e52705172e15f8b82c965913b1e85b2c3fab.zip |
Skripte vereinfacht, alle Ausgaben auf deutsch, Farben angepasst
git-svn-id: https://svn.neo-layout.org@1411 b9310e46-f624-0410-8ea1-cfbb3a30dc96
Diffstat (limited to 'linux/bin/uiae')
-rwxr-xr-x | linux/bin/uiae | 67 |
1 files changed, 52 insertions, 15 deletions
diff --git a/linux/bin/uiae b/linux/bin/uiae index ae9792a..4015e1c 100755 --- a/linux/bin/uiae +++ b/linux/bin/uiae @@ -13,13 +13,13 @@ orange="\033[33m" green="\033[32m" if [ -f "${NEO_CONFIG}" ]; then - . "${NEO_CONFIG}" || die "Failed to source ${NEO_CONFIG}" + . "${NEO_CONFIG}" || die "Fehler beim Verwenden der Konfigurationsdatei ${NEO_CONFIG}" elif [ -f "${HOME}"/.neorc ]; then - . "${HOME}"/.neorc || die "Failed to source ${HOME}/.neorc" + . "${HOME}"/.neorc || die "Fehler beim Verwenden der Konfigurationsdatei ${HOME}/.neorc" elif [ -f /etc/neo.conf ]; then - . /etc/neo.conf || die "Failed to source /etc/neo.conf" + . /etc/neo.conf || die "Fehler beim Verwenden der Konfigurationsdatei /etc/neo.conf" else - echo "No configuration file found. Using default values, this might fail!" + echo "${red}Keine Konfigurationsdatei für NEO gefunden. Das Verwenden der Standardwerte kann fehlschlagen!${normal}" fi @@ -27,14 +27,22 @@ fi STD_X_VARIANTE=${STD_X_VARIANTE:-xkbmap} STD_XKBMAP=${STD_XKBMAP:-de} STD_XKBVARIANT=${STD_XKBVARIANT:-nodeadkeys} +STD_XMODMAP=${STD_XMODMAP:-""} STD_CONSOLE_KEYMAP="${STD_CONSOLE_KEYMAP:-de-latin1-nodeadkeys}" NUM_LOCK_STATUS=${NUM_LOCK_STATUS:-on} help() { cat <<HELP -Aufruf: $0 [-q] +Aufruf: $0 [-q] [Standard-X-Variante] Aktiviert die Standard-Tastaturbelegung. + NEO-X-Variante als Standard-X-Variante kann verwendet werden: + xkmbap in den meisten Fällen richtig (Standardeinstellung) + xmodmap nur sinnvoll, wenn eine eigene Xmodmap als Standardbelegung verwendet wird + + Das Skript erkennt, falls sich der Benutzer nur auf einer Textkonsole befindet und ändert + auch dort die Belegung (hierfür sind allerdings Rootrechte erforderlich!) + -q, --quiet gibt – abgesehen von Fehlern – keine Meldungen aus NEO-Tastaturbelegung @@ -52,14 +60,14 @@ die() { set_xmodmap() { if [ -f "$@" ]; then - xmodmap "$@" || die "Failed to set xmodmap $@." + xmodmap "$@" || die "Fehler beim Laden der Xmodmap $@." else - die "Cannot use $@ for xmodmap." + die "Die Xmodmap-Datei ${orange}$@${red} gibt es nicht." fi } set_xkbmap() { - setxkbmap "$@" || die "Failed to select xkbmap $@." + setxkbmap "$@" || die "Die xkbmap ${orange}$@${red} wurde nicht gefunden." } set_keymap() { @@ -70,6 +78,24 @@ set_keymap() { fi } + +while [ ! -z "$1" ]; do + case $1 in + -h | --help ) + help + ;; + -q | --quiet ) + quiet=1 + ;; + * ) + STD_X_VARIANTE=${1-$STD_X_VARIANTE} + shift $# + ;; + esac + shift +done + + if [ -n "$SSH_CONNECTION" ]; then die "In einer ssh-session kann die Belegung nicht geändert werden." fi @@ -85,30 +111,41 @@ if [ -z ${DISPLAY} ]; then else for modifier in 51 94; do - xset r ${modifier} || echo "Failed to set repeat for modifier ${modifier}." >&2 + xset r ${modifier} || echo -e "${orange}Fehler beim Wiederherstellen von Autorepeat beim Modifier ${modifier}.${normal}" >&2 done for deadkey in 21 35 49; do - xset r ${deadkey} || echo "Failed to set repeat for deadkey ${deakey}." >&2 + xset r ${deadkey} || echo -e "${orange}Fehler beim Wiederherstellen von Autorepead bei der toten Taste ${deakey}.${normal}" >&2 done case "${STD_X_VARIANTE}" in xkbmap) + [ $quiet ] || echo "Die Standardbelegung wird geladen…" set_xkbmap "${STD_XKBMAP}" "${STD_XKBVARIANT}" ;; xmodmap) - set_xkbmap de - set_xmodmap "${STD_XMODMAP}" + if [ "${STD_XMODMAP}" ]; then + [ $quiet ] || echo "Die Standard-Xmodmap wird geladen…" + set_xmodmap "${STD_XMODMAP}" + else + echo -e "${red}Es wurde keine Standard-Xmodmap definiert." >&2 + die "${red}In der Regel ist ${green}uiae${red} ohne weitere Angaben erfolgreich." + fi ;; *) - die "Unknown standard X variant ${STD_X_VARIANTE}." + die "${orange}${STD_X_VARIANTE}${red} ist eine unbekannte X-Variante der NEO-Belegung." ;; esac if [ "${NUM_LOCK_STATUS}" = "on" ]; then - numlockx on || die "Failed to set num lock status to on." + numlockx on || echo -e "${orange}Fehler beim setzen des Status von NumLock." >&2 else - numlockx off || die "Failed to set num lock status to off." + numlockx off || echo -e "${orange}Fehler beim setzen des Status von NumLock." >&2 fi fi +if [ ! "$quiet" ]; then + echo + echo "Die Tastaturbelegung wurde auf die Standardbelegung geändert." + echo -e "Durch ${green}asdf${normal} kehrt man wieder zur NEO-Belegung zurück." +fi
\ No newline at end of file |