X-Git-Url: https://ruderich.org/simon/gitweb/?a=blobdiff_plain;f=xinitrc;h=aa5bfafb31f9758ce70f7093026fc43a09fc91fb;hb=be213876436409661de8a2fdb908a28851fa482b;hp=e9d81ad3eee9d9465be76ac16af2660d66eeacf6;hpb=ebcd4291a5accbd3e01a691c20c5c4963d13415d;p=config%2Fdotfiles.git diff --git a/xinitrc b/xinitrc index e9d81ad..aa5bfaf 100755 --- a/xinitrc +++ b/xinitrc @@ -42,7 +42,7 @@ error() { xmessage "$@" & else # Log message to a file which is displayed by my Zsh setup on startup. - echo "$@" >> "$HOME/.xinitrc.errors" + printf '%s\n' "$*" >>"$HOME/.xinitrc.errors" fi } # Save PID of the most recently started background process. Used to terminate @@ -74,9 +74,11 @@ if test -f "$HOME/.xinitrc.local"; then fi -# Start ssh-agent if we have private keys, thanks to +# Start ssh-agent if no agent is running and we have private keys, thanks to # http://code.haskell.org/XMonadContrib/scripts/xinitrc (read on 2011-06-19). -if test -x /usr/bin/ssh-agent && test -f "$HOME/.ssh/id_rsa"; then +if test -z "$SSH_AGENT_PID" \ + && test -x /usr/bin/ssh-agent \ + && test -f "$HOME/.ssh/id_rsa"; then # -s to force bourne shell output. This file is a bourne shell script even # if the environment might suggest otherwise. eval `/usr/bin/ssh-agent -s` >/dev/null @@ -90,8 +92,21 @@ if installed setxkbmap; then setxkbmap us fi -# Use my X11 key bindings. -xmodmap "$HOME/.xmodmaprc" +# Use the Caps lock as Ctrl because it's easier to reach and very useful for +# all programs. Caps lock is removed completely. Thanks to +# http://snarfed.org/space/switch%20control%20and%20caps%20lock +if xmodmap | grep -E '^lock.*Caps_Lock' >/dev/null; then + xmodmap -e 'remove Lock = Caps_Lock' + xmodmap -e 'remove Control = Control_L' + xmodmap -e 'keysym Caps_Lock = Control_L' + xmodmap -e 'add Control = Control_L' +fi +# Move grave and tilde next to left shift key. This setting may only be +# necessary because of my German keyboard which I use with English settings. +xmodmap -e 'keycode 94 = grave asciitilde' + +# Disable annoying audio bell. Thanks to Sebastian Rachuj. +xset b off # Change the background if available. if test -f "$HOME/.background" && test -n "$set_background"; then @@ -130,11 +145,22 @@ elif test -n "$screen_lock_force"; then fi -# XMonad doesn't start a terminal emulator on its own, start one when I login. +# My window managers doesn't start a terminal emulator on its own, start one +# when I login. (urxvt || rxvt || xterm) & # Start window manager. -xmonad +if installed herbstluftwm; then + herbstluftwm --locked >~/.config/herbstluftwm/log 2>&1 +elif installed xmonad; then + xmonad +elif installed stumpwm; then + stumpwm +else + error 'no window manager found (sleeping for 3600 seconds)' + sleep 3600 +fi + # Cleanup. #