X-Git-Url: https://defaria.com/gitweb/?a=blobdiff_plain;f=rc%2Fbash_login;h=8207eaee0d42aa94090dc086d4a1e03131baa8ca;hb=6cf0d2cda8a454c46c0cd44fc2edd2093cd8c83a;hp=ff64550bdc75802346ae65ab3aa0cadf07e2511d;hpb=fb369fc18c24c43e0ff44b19912fd339a5e52f95;p=clearscm.git diff --git a/rc/bash_login b/rc/bash_login index ff64550..8207eae 100644 --- a/rc/bash_login +++ b/rc/bash_login @@ -1,7 +1,7 @@ ################################################################################ # # File: $RCSfile: bash_login,v $ -# Revision: $Revision: 1.29 $ +# Revision: $Revision: 1.29 $ # Description: bash startup file # Author: Andrew@DeFaria.com # Created: Mon Aug 20 17:35:01 2001 @@ -11,6 +11,26 @@ # (c) Copyright 2000-2005, Andrew@DeFaria.com, all rights reserved. # ################################################################################ +# The following will set HOME, temporarily, to the directory of my $HOME so that +# somebody other than me can envoke my startup scripts. I use this mainly for +# when I become root with sudo -s and what a better environment that the bare +# bones root environment gives you. Note that for us to be effective one must +# source (or .) this file and if so the ${BASH_ARGV[0]} is the normal $0 +if [ -n "${BASH_ARGV[0]}" ]; then + home=$(dirname ${BASH_ARGV[0]}) +else + home=$HOME +fi + +# Strip off .rc +home=${home/%\/\.rc/} + +# Now set $HOME if $home is different. +saved_home=$HOME +if [ "$HOME" != "$home" ]; then + HOME=$home +fi + # Set ARCHITECTURE of the machine KERNEL=$(uname -s) if [[ $KERNEL = CYGWIN* ]]; then @@ -21,17 +41,26 @@ elif [ $KERNEL = "SunOS" ]; then export ARCHITECTURE=sun elif [ $KERNEL = "FreeBSD" ]; then export ARCHITECTURE=$KERNEL +elif [ $KERNEL = "Darwin" ]; then + export ARCHITECTURE=$KERNEL else export ARCHITECTURE='' echo "Warning: Unknown architecture ($KERNEL)" fi -# Architectual differences (AKA Silly Sun) -if [ $ARCHITECTURE = "sun" ]; then - alias id=/usr/xpg4/bin/id - alias tr=/usr/xpg4/bin/tr - - export id=/usr/xpg4/bin/id +# Hack: Just set TERM to xterm +if [ $ARCHITECTURE = 'sun' ]; then + id=/usr/xpg4/bin/id + tr=/usr/xpg4/bin/tr + TERM=xtermc +else + id=id + tr=tr + if [ $ARCHITECTURE = 'cygwin' ]; then + TERM=cygwin + else + TERM=xterm + fi fi # Set colors @@ -68,14 +97,6 @@ else export SYSNAME="*Unknown Systemname*:" fi -# System dependencies -# Note: I don't like doing this but an alias doesn't work... -if [ $ARCHITECTURE = "sun" ]; then - id=/usr/xpg4/bin/id -else - id=id -fi - umask 002 if [ "$interactive" = "true" ]; then @@ -129,10 +150,24 @@ set -o emacs set -o monitor set +u +# Shell options +if [ $ARCHITECTURE != 'Darwin' -a $ARCHITECTURE != 'sun' ]; then + ls /etc/*release > /dev/null 2>&1 + + if [ $? = 0 ]; then + if ! grep -qP '5\.(6|7|8|9|10)' /etc/*release; then + shopt -s autocd > /dev/null 2>&1 + shopt -s dirspell > /dev/null 2>&1 + fi + fi +fi + +shopt -s cdspell +shopt -s histappend shopt -s lithist # Aliases: -if [ $ARCHITECTURE = "FreeBSD" ]; then +if [ $ARCHITECTURE = "FreeBSD" -o $ARCHITECTURE = "Darwin" ]; then alias ls="ls -FG" else if [ -f ~/.rc/dircolors ]; then @@ -157,13 +192,25 @@ if [ $ARCHITECTURE = "cygwin" ]; then alias host=nslookup fi -export LANG=C +if [ -f "$SYSTEMDRIVE/Perl64/bin/perl" ]; then + alias asperl="$SYSTEMDRIVE/Perl64/bin/perl" +fi + +if [ -f "$SYSTEMDRIVE/Perl/bin/perl" ]; then + alias asperl="$SYSTEMDRIVE/Perl64/bin/perl" +fi + +if [ $(locale -a | grep -c en_US.utf8) != 0 ]; then + export LANG=en_US.utf8 +else + export LANG=C +fi -if [ $(type -p vim) ]; then +if [ "$(type -p vim)" ]; then alias vi=vim fi -if [ $(type -p ncftp) ]; then +if [ "$(type -p ncftp)" ]; then alias ftp=ncftp alias ftpput=ncftpput alias ftpget=ncftpget @@ -171,13 +218,15 @@ fi #alias grep="grep -d skip" -if [ "$TERM" = "hpterm" -o \ - "$TERM" = "hp" -o \ - "$TERM" = "dtterm" -o \ - "$TERM" = "sun-color" -o \ - "$TERM" = "vt100" -o \ - "$TERM" = "vt220" -o \ - "$TERM" = "xterm" -o \ +if [ "$TERM" = "hpterm" -o \ + "$TERM" = "hp" -o \ + "$TERM" = "dtterm" -o \ + "$TERM" = "sun-color" -o \ + "$TERM" = "vt100" -o \ + "$TERM" = "vt220" -o \ + "$TERM" = "xtermc" -o \ + "$TERM" = "xterm" -o \ + "$TERM" = "xterm-256color" -o \ "$TERM" = "cygwin" ]; then alias cd=mycd alias pushd=mypushd @@ -231,6 +280,11 @@ if [ -d /opt/clearscm/lib ]; then export PERL5LIB="$PERL5LIB:/opt/clearscm/lib" fi +# Lessfile +if type lessfile > /dev/null 2>&1; then + eval $(lessfile) +fi + # Client specific customizations for script in $(\ls ~/.rc/client_scripts); do # This is not working as long as ACLs are not supported from the remote @@ -245,9 +299,15 @@ for script in $(\ls ~/.rc/client_scripts); do done # Set display to local + export DISPLAY=${DISPLAY:-:0} +# Reset home in case it changed +HOME=$saved_home + +# Odd but Eclipse's Egit can't seem to work with defaria.com unless this is set. +export GIT_SSH=/usr/bin/ssh # Now go home (in case we were not autmatically cd'ed there) -if [ $(id -u) -ne 0 ]; then +if [ $($id -u) -ne 0 ]; then cd fi