X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=.xsession;h=d622c432f0cdadb8fc779ed13cf22c38f1677246;hb=8cb930080f1858b8eaa19a8b9b71add730554cf7;hp=1904d13f027e6bee5d392190ab6a1ca5edb08fc5;hpb=36dc63c8fda104199735172755f6df35cc7b814a;p=x_base.git diff --git a/.xsession b/.xsession index 1904d13..d622c43 100755 --- a/.xsession +++ b/.xsession @@ -1,5 +1,17 @@ #!/bin/sh +cmd_exists () { + if which "$1" >/dev/null 2>&1; then + return 0; + else + return 1; + fi; +} + +fork () { + ( "$@" >/dev/null 2>&1 & ) +} + echo "Starting new session" DATE=$(date "+%Y%m%d_%H%M%S") @@ -8,7 +20,7 @@ mv ~/.xsession-errors ~/.xsession-errors_${DATE}; ln -sf ~/.xsession-errors_${DATE} ~/.xsession-errors-current; # delete old xsession error files find ~/ -maxdepth 1 -mindepth 1 -type f \ - -iname '.xsession-errors*' -ctime +30 -delete; + -iname '.xsession-errors_*' -ctime +30 -delete; if locale -a |grep -qi en_US.utf8; then LANG="en_US.UTF-8" @@ -44,46 +56,39 @@ if [ -e ~/.Xauthority ]; then cp -f .Xauthority .Xauthority.bak fi -if [ -x /usr/bin/xscreensaver -a -e ~/.xscreensaver ]; then - ( XENVIRONMENT=~/.xscreensaver /usr/bin/xscreensaver >/dev/null 2>&1 &) -elif [ -x /usr/bin/xautolock ]; then - (/usr/bin/xautolock -notifier true -bell 0 >/de/vnull 2>&1 &) +if cmd_exists slock && cmd_exists xautolock; then + fork xautolock -notifier true -bell 0 -locker slock; +elif cmd_exists xscreensaver && [ -e ~/.xscreensaver ]; then + fork XENVIRONMENT=~/.xscreensaver /usr/bin/xscreensaver; +elif cmd_exists xautolock; then + fork xautolock -notifier true -bell 0; fi; -if which redshift >/dev/null 2>&1; then - (redshift >/dev/null 2>&1 &) +if cmd_exists redshift; then + fork redshift; fi; -if which mopidy >/dev/null 2>&1 && [ -e ~/.config/mopidy/mopidy.conf ]; then - (mopidy > /dev/null 2>&1 & ); -elif which mpd >/dev/null 2>&1 && [ -e ~/.mpdconf ]; then - (mpd >/dev/null 2>&1 &); +if cmd_exists mpd && [ -e ~/.mpdconf ]; then + fork mpd; MPD_HOST=$(awk '/^bind_to_address/{print $2}' ~/.mpdconf|sed "s|~|$HOME|; s/^\"//; s/\"$//; "); export MPD_HOST; +elif cmd_exists mopidy && [ -e ~/.config/mopidy/mopidy.conf ]; then + fork mopidy; fi; -if [ -x /sbin/iw ] && which nm-applet >/dev/null 2>&1 && /sbin/iw list|grep -q '^Wiphy'; then - ( nm-applet > /dev/null 2>&1 & ); +if [ -x /sbin/iw ] && cmd_exists nm-applet && /sbin/iw list|grep -q '^Wiphy'; then + fork nm-applet; fi; -if [ -x /usr/bin/i3 ]; then +if cmd_exists i3; then if [ -x ~/.config/i3/build_config.sh ]; then ~/.config/i3/build_config.sh; fi; exec /usr/bin/i3; -elif [ -x /usr/bin/awesome ]; then - exec /usr/bin/awesome; -elif [ -x /usr/bin/ion3 ]; then - exec /usr/bin/ion3; -elif [ -x /usr/bin/openbox ]; then - exec /usr/bin/openbox; -elif [ -x /usr/bin/rxvt ]; then - exec /usr/bin/rxvt; -elif [ -x /usr/bin/rxvt-unicode ]; then - exec /usr/bin/rxvt-unicode; -elif [ -x /usr/bin/xterm ]; then - exec /usr/bin/xterm; else - # we're screwed. - sleep 2s; + for prog in awesome ion3 openbox stterm st rxvt rxvt-unicode xterm; do + if cmd_exists $prog; then + exec $(which $prog) + fi + done; fi;