]> ruderich.org/simon Gitweb - config/dotfiles.git/blobdiff - xinitrc
katarakt.ini: set default_layout to grid
[config/dotfiles.git] / xinitrc
diff --git a/xinitrc b/xinitrc
index 8a649a144ec5865b6d445e86d6a984ce498d6b5b..480fbc65943c0b04bb7172edbea25030f4aef35b 100755 (executable)
--- a/xinitrc
+++ b/xinitrc
@@ -54,12 +54,11 @@ background_pids=
 #
 # Default to use a background image.
 set_background=yes
-# Default to display a warning if `xautolock` is not available.
+# Default to display a warning if no screen locker is not available.
 screen_lock_force=yes
-# Lock screen after x minutes of inactivity, requires `xautolock` to be
-# installed.
+# Lock screen after x minutes of inactivity.
 screen_lock_time=3
-# Locker program to lock the screen, used below with `xautolock`.
+# Locker program to lock the screen (with xautolock).
 screen_locker=xtrlock
 
 # Load settings for the local system.
@@ -68,11 +67,9 @@ if test -f "$HOME/.xinitrc.local"; then
 fi
 
 
-# Start ssh-agent if no agent is running and we have private keys, thanks to
+# Start ssh-agent if no agent is running, thanks to
 # http://code.haskell.org/XMonadContrib/scripts/xinitrc (read on 2011-06-19).
-if test -z "$SSH_AGENT_PID" \
-        && 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; 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
@@ -83,7 +80,7 @@ xsetroot -solid black
 
 # Force English keyboard layout.
 if installed setxkbmap; then
-    setxkbmap us
+    setxkbmap -option compose:menu us
 fi
 
 # Use the Caps lock as Ctrl because it's easier to reach and very useful for
@@ -96,14 +93,23 @@ if xmodmap | grep -E '^lock.*Caps_Lock' >/dev/null; then
     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.
+# necessary because of my German keyboard which I use with an English layout.
 xmodmap -e 'keycode 94 = grave asciitilde'
 
+# Enable scrolling with trackpoint and middle mouse on Thinkpads, also disable
+# touchpad. Thanks to DerRoteBaron.
+if xinput 2>/dev/null | grep 'TPPS/2 IBM TrackPoint' >/dev/null; then
+    xinput set-int-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation" 8 1
+    xinput set-int-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation Button" 8 2
+    xinput set-int-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation Axes" 8 6 7 4 5
+    xinput --disable "SynPS/2 Synaptics TouchPad"
+fi
+
 # Disable annoying audio bell. Thanks to Sebastian Rachuj.
 xset b off
 
-# Load settings for programs. Xdefaults is deprecated.
-xrdb ~/.Xresources
+# Load settings for programs. Xdefaults is deprecated.
+xrdb "$HOME/.Xresources"
 
 # Change the background if available.
 if test -f "$HOME/.background" && test -n "$set_background"; then
@@ -129,18 +135,14 @@ if installed redshift; then
     redshift -l 49.9:10.9 -t 5500:4500 >/dev/null &
 fi
 
-# Automatically lock the screen after x minutes of inactivity if `xautolock`
-# is available. Warn if locker wasn't found.
-if installed xautolock; then
-    if installed "$screen_locker"; then
-        xautolock -secure -time "$screen_lock_time" -locker "$screen_locker" &
-    else
-        error "Locker '$screen_locker' not installed. Auto lock won't work!"
-    fi
-elif test -n "$screen_lock_force"; then
-    error "'xautolock' not found. Auto lock won't work!"
+
+# Start best available screen locker.
+xlockscreen=`"$HOME/.xlockscreen" start "$screen_lock_time" "$screen_locker"`
+if test $? -ne 0 && test -n "$screen_lock_force"; then
+    error "$xlockscreen"
 fi
 
+
 # Use compton to get transparent windows. See ~/.Xresources for configuration
 # of urxvt.
 if installed compton; then
@@ -151,14 +153,14 @@ elif installed xcompmgr; then
 fi
 
 
-# My window managers doesn't start a terminal emulator on its own, start one
+# My window manager doesn't start a terminal emulator on its own, start one
 # when I login.
 (urxvt || rxvt || xterm) &
 
 # Start window manager.
 failed=
 if installed herbstluftwm; then
-    herbstluftwm --locked >~/.config/herbstluftwm/log 2>&1 || failed=1
+    herbstluftwm --locked || failed=1
 elif installed xmonad; then
     xmonad || failed=1
 elif installed stumpwm; then
@@ -185,4 +187,6 @@ if test -x /usr/bin/ssh-agent; then
     # No `eval` necessary, we terminate anyway.
 fi
 # Kill remaining background processes.
-kill $background_pids
+if test -n "$background_pids"; then
+    kill $background_pids
+fi