X-Git-Url: https://git.donarmstrong.com/?p=home-base.git;a=blobdiff_plain;f=.bashrc;h=2d47f331bc508e340cb924934fa6307952c3e402;hp=6222be40d9857afeb3b1d9547ac5ec7ff277568e;hb=cc88b4b1c70be4df28e1a66e15607138d7927b18;hpb=9d3bfef8e863af457b10bdd91e0e58bef20dae71 diff --git a/.bashrc b/.bashrc index 6222be4..2d47f33 100644 --- a/.bashrc +++ b/.bashrc @@ -20,54 +20,167 @@ if [ "$PS1" ]; then fi; # bts debian options + if [ -e bin/faf ]; then + complete -F _command faf + fi; + export DEBEMAIL="don@debian.org" + export DEBHOME="$(eval 'echo' '~/projects/debian')" + + export GTK_IM_MODULE=xim + export QT_IM_MODULE=xim # enable color support of ls and also add handy aliases eval `dircolors -b` alias ls='ls --color=auto' - alias gr='gimp-remote-2.2' + alias gr='gimp-remote' alias emc='sane_editor' + alias svn-b="svn-buildpackage --svn-builder 'pdebuild --buildresult ..' --svn-ignore-new" + # set a fancy prompt - PS1='\u@\h:\w\$ ' + #printf '\33]2;%s\007' + + # See if we're in a chroot + if [ -z "$debian_chroot" ] && [ -r /etc/debian_chroot ]; then + debian_chroot=$(cat /etc/debian_chroot) + fi + # we want to set the color based on what machine we're on + # if it's a remote, SSH_CONNECTION will be set + # set variable identifying the chroot you work in (used in the prompt below) + + # disable terminal bell + bind 'set bell-style none' + + if [ -n "$SSH_CONNECTION" -o -n "$SSH_CLIENT" ]; then + # figure out what color to use + COLOR=$(hostname|md5sum|perl -ne 'if (/^([a-f\d]{8})/) { + my $num = unpack(q(L),pack(q(H*),$1)); + my @col = map {(qq(0;${_}m),qq(1;${_}m))} 31..37; + my $col = $col[$num % @col]; + if ($col eq q(0;36m)) { + $col = q(1;30m); + } + print $col; + }') + PS1="${debian_chroot:+($debian_chroot)}\[\033[$COLOR\]\h \[\033[0;36m\]\t \w$\[\033[0m\] " + unset COLOR + else + PS1="${debian_chroot:+($debian_chroot)}\[\033[0;36m\]\h \t \w$\[\033[0m\] " + fi; + # \[\033[1;36m\][\w]\n\[\033[0;36m\][\h|\t]$ \[\033[0m\] + + # make sure the term we're using exists in the termcap + TOEOPT='-a' + if ! toe $TOEOPT >/dev/null 2>&1; then + TOEOPT='' + fi; + if ! toe $TOEOPT|grep -q "^$TERM "; then + # if it doesn't, try to switch + case $TERM in + rxvt*) + TERM="rxvt" + ;; + xterm*) + TERM="xterm" + ;; + *) + ;; + esac + export TERM; + fi; # If this is an xterm set the title to user@host:dir - #case $TERM in - #xterm*) - # PROMPT_COMMAND='echo -ne "\033]0;${USER}@${HOSTNAME}: ${PWD}\007"' - # ;; - #*) - # ;; - #esac + case $TERM in + screen|xterm*) + PROMPT_COMMAND='echo -ne "\033]0;${USER}@${HOSTNAME}: ${PWD}\007"' + ;; + rxvt*) + PROMPT_COMMAND='echo -ne "\033]2;${USER}@${HOSTNAME}: ${PWD}\007"' + ;; + + *) + ;; + esac # enable programmable completion features (you don't need to enable # this, if it's already enabled in /etc/bash.bashrc). if [ -f /etc/bash_completion ]; then . /etc/bash_completion; fi; + + # set up ssh-agent + if which ssh-agent >/dev/null && [ -d ~/.ssh ] && \ + [ -z "$SSH_CONNECTION" ] && [ -z "$SSH_CLIENT" ]; then +# for + if [ -e ~/.ssh/ssh_agent_info ] && \ + [ -n "$(awk -F '[=;]' '/^SSH_AGENT_PID/{print $2}' ~/.ssh/ssh_agent_info)" ] && \ + kill -0 "$(awk -F '[=;]' '/^SSH_AGENT_PID/{print $2}' ~/.ssh/ssh_agent_info)" >/dev/null 2>&1; then + . ~/.ssh/ssh_agent_info > /dev/null + elif [ -e ~/.ssh/ssh_agent_info_$(hostname) ] && \ + kill -0 "$(awk -F '[=;]' '/^SSH_AGENT_PID/{print $2}' ~/.ssh/ssh_agent_info_$(hostname))" >/dev/null 2>&1; then + . ~/.ssh/ssh_agent_info_$(hostname) > /dev/null + else + ssh-agent -s > ~/.ssh/ssh_agent_info_$(hostname) + . ~/.ssh/ssh_agent_info_$(hostname) > /dev/null + fi; + fi; alias aumix2='aumix -d /dev/mixer1 -I' - export LANG="en_US.UTF-8" - export PATH="~/bin:$PATH" + if locale -a |grep -qi en_US.utf8; then + LANG="en_US.UTF-8" + else + LANG=C + fi; + export LANG + + # If we're running on liszt, include /var/list/.bin in the path + if [ "$(hostname)" == "liszt" ] && [ -d /var/list/.bin ]; then + PATH="/var/list/.bin:$PATH" + fi; + export PATH="$(getent passwd $(id -u)|awk -F: '{print $6}')/bin:$PATH" + + if [ ! -e ~/tmp ]; then + mkdir ~/tmp; + fi; + export TMPDIR="$(echo ~/tmp)"; - TODO_OPTIONS="--timeout --summary" +# if [ -n "$(which devtodo)" ]; then +# for a in tda tdd tde; do +# alias "s${a}"="STODO_NO_COMMIT=1 $a" +# done; +# +# TODO_OPTIONS="--timeout --summary" - cd () - { - builtin cd "$@" && [ -r .todo ] && devtodo ${TODO_OPTIONS} - } + cd () + { + # use pushd instead of cd + if [ -z "$1" ] || [ "$1" == "-" ]; then + builtin cd "$@"; # && [ -r .todo ] && devtodo ${TODO_OPTIONS}; + else + builtin pushd "$@" >/dev/null; # && [ -r .todo ] && devtodo ${TODO_OPTIONS}; + fi; + } + + # various livetv streams + alias "watch_cspan"="rtmpdump -v -r rtmp://cp82346.live.edgefcs.net:1935/live -y CSPAN1@14845 -W http://www.c-span.org/cspanVideoHD.swf -p http://www.c-span.org/Live-Video/C-SPAN/ | mplayer -xy 3 -" + alias "watch_cspan2"="rtmpdump -v -r rtmp://cp82347.live.edgefcs.net:1935/live -y CSPAN2@14846 -W http://www.c-span.org/cspanVideoHD.swf -p http://www.c-span.org/Live-Video/C-SPAN2/ | mplayer -xy 3 -" + alias "watch_cspan3"="rtmpdump -v -r rtmp://cp82348.live.edgefcs.net:1935/live -y CSPAN3@14847 -W http://www.c-span.org/cspanVideoHD.swf -p http://www.c-span.org/Live-Video/C-SPAN3/ | mplayer -xy 3-" + alias "watch_cnn"="rtmpdump -v -r rtmp://cp44679.live.edgefcs.net/live -y cnn_stream1_low@2785 -a live -W http://i.cdn.turner.com/cnn/.element/apps/CNNLive/2.1.5.7/assets/swfs/LivePlayer.swf -p http://www.cnn.com/video/flashLive/live.html?stream=1 | mplayer -xy 2 -" + alias "watch_bloomberg"="rtmpt://cp87869.live.edgefcs.net:1935/live -a live -y us_300@21006 -W http://cdn.gotraffic.net/v/20110210_153738//flash/BloombergMediaPlayer.swf -p http://www.bloomberg.com/tv/ | mplayer -xy 2 -" - pushd () - { - builtin pushd "$@" && [ -r .todo ] && devtodo ${TODO_OPTIONS} - } - - popd () - { - builtin popd "$@" && [ -r .todo ] && devtodo ${TODO_OPTIONS} - } - - # Run todo initially upon login - devtodo ${TODO_OPTIONS} +# pushd () +# { +# builtin pushd "$@" && [ -r .todo ] && devtodo ${TODO_OPTIONS} +# } +# +# popd () +# { +# builtin popd "$@" && [ -r .todo ] && devtodo ${TODO_OPTIONS} +# } + + # Run todo initially upon login +# devtodo ${TODO_OPTIONS} +# fi; fi