X-Git-Url: https://ruderich.org/simon/gitweb/?a=blobdiff_plain;f=xinitrc;h=ae38da63cc2af9ceb3c9d2e95f6e2b45ad594430;hb=b71680c55e6e492ed008f8ec5af3bf169b272f09;hp=af210f6b3f277492c8c83357b8b433af2398eda7;hpb=e2791639d441f294a22faaa8a731faa5fa894362;p=config%2Fdotfiles.git diff --git a/xinitrc b/xinitrc index af210f6..ae38da6 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 @@ -21,20 +21,55 @@ # Some systems don't set the LANG environment variable when starting xinitrc, # this causes problems for rxvt-unicode-256color which fails to display UTF-8 # characters correctly when LANG is missing and for notify.py which also needs -# LANG set (for Python's decode() function). Therefore set it here, might be -# overwritten by shell setup scripts. -LANG=en_US.UTF-8 -export LANG +# LANG set (for Python's decode() function). Therefore load my general shell +# environment which also includes $LANG. +if test -f "$HOME/.shell/env"; then + . "$HOME/.shell/env" +fi installed() { type "$1" >/dev/null 2>&1 } +error() { + if installed xmessage; then + xmessage "$@" & + else + # Log message to a file which is displayed by my Zsh setup on startup. + printf '%s\n' "$*" >>"$HOME/.xinitrc.errors" + fi +} +# Save PID of the most recently started background process. Used to terminate +# them when logging out to prevent unused background processes. On some +# systems this is only necessary for some programs (like ssh-agent), haven't +# yet figured out why. +save_background_pid() { + background_pids="$background_pids $!" +} +background_pids= -# Start ssh-agent if we have private keys, thanks to +# Options, can be modified in ~/.xinitrc.local. To disable a boolean option +# set it to an empty value. +# +# Default to use a background image. +set_background=yes +# Default to display a warning if no screen locker is not available. +screen_lock_force=yes +# Lock screen after x minutes of inactivity. +screen_lock_time=3 +# Locker program to lock the screen (with xautolock). +screen_locker=xtrlock + +# Load settings for the local system. +if test -f "$HOME/.xinitrc.local"; then + . "$HOME/.xinitrc.local" +fi + + +# Start ssh-agent if no agent is running, 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; 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 @@ -48,16 +83,24 @@ 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 an English layout. +xmodmap -e 'keycode 94 = grave asciitilde' -# Default to use a background image. Can be disabled in .xinitrc.local. -set_background=yes +# Disable annoying audio bell. Thanks to Sebastian Rachuj. +xset b off -# Load settings for the local system. -if test -f "$HOME/.xinitrc.local"; then - . "$HOME/.xinitrc.local" -fi +# 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 @@ -75,6 +118,7 @@ fi # Display timed reminders and recheck the file for changes every minute (-z1). if installed remind && test -f "$HOME/.reminders"; then remind -z1 -k'.shell/bin/notify.py %s &' "$HOME/.reminders" & + save_background_pid fi # Set color temperature of display according to time of day. @@ -83,8 +127,57 @@ if installed redshift; then fi -# XMonad doesn't start a shell on its own, start one when I login. +# 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 + 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. -xmonad +failed= +if installed herbstluftwm; then + herbstluftwm --locked || failed=1 +elif installed xmonad; then + xmonad || failed=1 +elif installed stumpwm; then + stumpwm || failed=1 +else + 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 + + +# Cleanup. +# +# Kill ssh-agent to prevent unused background processes. +if test -x /usr/bin/ssh-agent; then + /usr/bin/ssh-agent -k >/dev/null + # No `eval` necessary, we terminate anyway. +fi +# Kill remaining background processes. +if test -n "$background_pids"; then + kill $background_pids +fi