X-Git-Url: https://ruderich.org/simon/gitweb/?a=blobdiff_plain;f=xinitrc;h=480fbc65943c0b04bb7172edbea25030f4aef35b;hb=16de0a69ee045bbea7d7b6e3f0b0419bc8a7d754;hp=7ba1d8c6fd9f4781e503932eab5b9ce1d26e9de6;hpb=816a5272aae4e92d4b9bb81cef20dcfb6377a31e;p=config%2Fdotfiles.git diff --git a/xinitrc b/xinitrc index 7ba1d8c..480fbc6 100755 --- a/xinitrc +++ b/xinitrc @@ -2,7 +2,7 @@ # startx configuration file. -# Copyright (C) 2011-2013 Simon Ruderich +# Copyright (C) 2011-2014 Simon Ruderich # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -24,12 +24,6 @@ # LANG set (for Python's decode() function). Therefore load my general shell # environment which also includes $LANG. if test -f "$HOME/.shell/env"; then - # Debug function used in ~/.shell/env. - source_debug() { - # Do nothing. - : - } - . "$HOME/.shell/env" fi @@ -60,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. @@ -74,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 @@ -89,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 @@ -102,12 +93,24 @@ 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 X programs. Xdefaults is deprecated. +xrdb "$HOME/.Xresources" + # Change the background if available. if test -f "$HOME/.background" && test -n "$set_background"; then if installed hsetroot; then @@ -132,32 +135,47 @@ 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 -# XMonad doesn't start a terminal emulator on its own, start one when I login. +# Use compton to get transparent windows. See ~/.Xresources for configuration +# of urxvt. +if installed compton; then + compton & +# xcompmgr as fallback. +elif installed xcompmgr; then + xcompmgr & +fi + + +# 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 + herbstluftwm --locked || failed=1 elif installed xmonad; then - xmonad + xmonad || failed=1 elif installed stumpwm; then - stumpwm + stumpwm || failed=1 else - error 'no window manager found (sleeping for 3600 seconds)' - sleep 3600 + failed='no window manager found' +fi +# Fallback in case my window manager failed to start. Otherwise X terminates +# the session immediately (because xinitrc finishes). +if test -n "$failed"; then + if test x"$failed" = x1; then + failed='failed to start window manager' + fi + error "$failed (spawning fallback terminal)" + urxvt || rxvt || xterm fi @@ -169,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