]> arthur.barton.de Git - ConfigScripts.git/blobdiff - sys/profile
Read ~/.profile.user-1st after initializing basic environment
[ConfigScripts.git] / sys / profile
index 2e4f778542a814156d22469bb080eb3eeba9860f..3af1ad9b45bec00c276104f677ed411d1c85131f 100644 (file)
@@ -1,14 +1,16 @@
 #
 # /etc/profile: system-wide profile for the Bourne shell (sh(1)) and
 # Bourne compatible shells (bash(1), ksh(1), ash(1), ...).
-# Written 2003-2014 by Alexander Barton (alex@barton.de)
+# Written 2003-2015 by Alexander Barton (alex@barton.de)
 #
 
-[ -e ~/.ConfigScripts.debug ] && echo " >> /etc/profile ..."
+[ -e ~/.ConfigScripts.debug ] && echo " .. /etc/profile ..."
 
 PROFILEREAD="true"
 export PROFILEREAD
 
+[ -e ~/.ConfigScripts.debug ] && echo " >> /etc/profile ..."
+
 # Setup locale and encoding
 if [ -e ~/.ConfigScripts.debug ]; then
        echo " - TERM=\"$TERM\""
@@ -18,9 +20,9 @@ fi
 # Does LC_CTYPE or LANG indicate an UTF-8 terminal?
 LC_encoding=""
 if [ -n "$LC_CTYPE" ]; then
-       LC_encoding="${LC_CTYPE#*.}"
+       LC_encoding=`echo "$LC_CTYPE" | cut -d. -f2- -s`
 elif [ -n "$LANG" ]; then
-       LC_encoding="${LANG#*.}"
+       LC_encoding=`echo "$LANG" | cut -d. -f2- -s`
 fi
 if [ -z "$LC_encoding" ]; then
        case "$TERM" in
@@ -51,21 +53,22 @@ else
        export PATH
 fi
 # prepend optional directories to PATH ...
-path=""
+unset path
 for d in /Developer/usr/bin /usr/pkg/bin /usr/ucb /usr/lib/ccache /opt/*/bin; do
        if [ -d "$d" -o -h "$d" ]; then
                [ -e "$d/.not_in_path" ] || path="$path$d:"
        fi
 done
 [ -n "$path" ] && PATH="$path$PATH"
+unset path
 if [ "$LOGNAME" = "root" ]; then
-       path=""
        for d in /usr/pkg/sbin /opt/*/sbin; do
                if [ -d "$d" -o -h "$d" ]; then
                        [ -e "$d/.not_in_path" ] || path="$path$d:"
                fi
        done
        [ -n "$path" ] && PATH="$path$PATH"
+       unset path
 fi
 # append optional directories to PATH ...
 for d in /usr/bin/X11 /usr/games /usr/share/php/bin; do
@@ -73,6 +76,7 @@ for d in /usr/bin/X11 /usr/games /usr/share/php/bin; do
                [ -e "$d/.not_in_path" ] || PATH="$PATH:$d"
        fi
 done
+unset d
 # set PATH so it includes user's private executables
 [ -d ~/Applications -a ! -e ~/Applications/.not_in_path ] \
        && PATH=~/Applications:"${PATH}"
@@ -82,7 +86,7 @@ done
        && PATH=~/sbin:"${PATH}"
 
 # Setup MANPATH, if manpath(1) isn't available
-if [ ! "$(type manpath 2>/dev/null)" ]; then
+if [ ! "$(type -t manpath 2>/dev/null)" ]; then
        [ -z "$MANPATH" ] \
                && MANPATH="/usr/local/share/man:/usr/share/man:/usr/man"
        path=""
@@ -92,6 +96,7 @@ if [ ! "$(type manpath 2>/dev/null)" ]; then
        [ -n "$path" ] && MANPATH="$path$MANPATH"
        [ -d ~/share/man ] && MANPATH=~/share/man:"${MANPATH}"
        [ -d ~/man ] && MANPATH=~/man:"${MANPATH}"
+       unset path d
 fi
 
 # set variable identifying the chroot you work in
@@ -102,6 +107,28 @@ fi
 [ -n "$HOSTNAME" ] || HOSTNAME=`hostname 2>/dev/null`
 export HOSTNAME
 
+# Setup local home directory, when available
+[ -d "/usr/local/home" -a ! -d "/usr/local/home/$LOGNAME" ] \
+       && mkdir "/usr/local/home/$LOGNAME" >/dev/null 2>&1
+[ -w "/usr/local/home/$LOGNAME" ] \
+       && export LOCAL_HOME="/usr/local/home/$LOGNAME" \
+       || export LOCAL_HOME="$HOME"
+
+# Source "~/.profile.user-1st", when available
+[ -r ~/.profile.user-1st ] && . ~/.profile.user-1st
+
+# Setup environment to use local storage (no NFS, if possible!)
+export XDG_CACHE_HOME="$LOCAL_HOME/.cache"
+
+# Setup environment for ccache, if installed
+type -t ccache >/dev/null && export CCACHE_DIR="$XDG_CACHE_HOME/ccache"
+
+# Setup environment for Python "pip", if installed
+if [ "$(type -t pip 2>/dev/null)" ]; then
+       export PIP_REQUIRE_VIRTUALENV=true
+       export PIP_DOWNLOAD_CACHE="$XDG_CACHE_HOME/pip"
+fi
+
 # Move Xauthority file to local storage, so that sudo et all work
 if [ -z "$XAUTHORITY" -a -r ~/.Xauthority ]; then
        cp ~/.Xauthority /tmp/Xauthority-$LOGNAME
@@ -122,25 +149,20 @@ if [ -d /etc/profile.d -o -d /usr/local/etc/profile.d ]; then
                                . "$f"
                esac
        done
+       unset f
 fi
 
 # read local profile, if available
 [ -r "/var/lib/${HOSTNAME}/profile" ] && . /var/lib/${HOSTNAME}/profile
 
-# Setup some directories to use local storage (no NFS)
-[ -d "/usr/local/home/$LOGNAME" ] \
-       || ( mkdir /usr/local/home; mkdir "/usr/local/home/$LOGNAME" ) >/dev/null 2>&1
-if [ -w "/usr/local/home/$LOGNAME" ]; then
-       export LOCAL_HOME="/usr/local/home/$LOGNAME"
-       export CCACHE_DIR="$LOCAL_HOME/.ccache"
-       export XDG_CACHE_HOME="$LOCAL_HOME/.cache"
-fi
-
 # interactive shell?
-[ "$PS1" ] || return
+case "$-" in
+       *i*) ;;
+       *) return ;;
+esac
 
 # validate terminal definition
-type tset >/dev/null 2>&1 && eval `tset -s -Q`
+type -t tset >/dev/null && eval `tset -s -Q`
 
 # generic shell prompt
 [ "$LOGNAME" = "root" ] \
@@ -148,10 +170,9 @@ type tset >/dev/null 2>&1 && eval `tset -s -Q`
        || PS1="<$HOSTNAME> \$ "
 
 # Reminders (once every 60 minutes)
-if [ -z `find ~/.last_reminder -mmin 1 2>/dev/null` ]; then
+if [ -z `find ~/.last_reminder -mmin -60 2>/dev/null` ]; then
        [ -e ~/.ConfigScripts.debug ] && echo " - Reminders ..."
-       type icalBuddy >/dev/null 2>&1
-       if [ $? -eq 0 -a "$LOGNAME" != "root" ]; then
+       if [ "$(type -t icalBuddy >/dev/null)" -a "$LOGNAME" != "root" ]; then
                # icalBuddy(1)
                case "$LANG" in
                        *.UTF*) bul="•"; bul_imp="!"; sep="»"; ;;
@@ -167,14 +188,13 @@ if [ -z `find ~/.last_reminder -mmin 1 2>/dev/null` ]; then
                unset bul bul_imp sep
        else
                # remind(1)
-               type remind >/dev/null 2>&1
-               if [ $? -eq 0 -a -r ~/.remind ]; then
+               if [ "$(type -t remind >/dev/null)" -a -r ~/.remind ]; then
                        remind -h -g -t5 ~/.remind | \
                                grep -v '^Reminders for ' | grep -v '^$'
                        [ $? -eq 0 ] && echo
                fi
        fi
-       touch ~/.last_reminder
+       [ -w ~/ ] && touch ~/.last_reminder
 fi
 
 # bash-specific initialization
@@ -190,7 +210,7 @@ fi
 # Check filesystem quotas
 mount 2>/dev/null | grep quota >/dev/null 2>&1
 if [ $? -eq 0 ]; then
-       type quota >/dev/null 2>&1 && quota -q
+       type -t quota >/dev/null && quota -q
 fi
 
 # -eof-