prompt with attached jobs status, current git branch info and glitche avoidance ; history append ; colored gcc alias ; progress on rsync aliases
This commit is contained in:
parent
7be98763e3
commit
b1cd2796f8
1 changed files with 85 additions and 10 deletions
107
.bashrc
107
.bashrc
|
|
@ -57,21 +57,91 @@ WHITE="\[\033[1;37m\]"
|
||||||
RED="\[\033[0;31m\]"
|
RED="\[\033[0;31m\]"
|
||||||
NO_COL="\[\033[00m\]"
|
NO_COL="\[\033[00m\]"
|
||||||
|
|
||||||
#Set some prompts...
|
jobcount()
|
||||||
if [ $CONN = lcl -a $USR = nou_root ] ; then
|
{
|
||||||
PS1="${WHITE}[\u \w]\\$ ${NO_COL}"
|
rep=""
|
||||||
elif [ $CONN = lcl -a $USR = u_root ] ; then
|
running=`jobs -r | wc -l | tr -d " "`
|
||||||
PS1="${YELLOW}[\w]\\$ ${NO_COL}"
|
stopped=`jobs -s | wc -l | tr -d " "`
|
||||||
elif [ $CONN = tel -a $USR = nou_root ] ; then
|
|
||||||
PS1="[\u${LIGHT_GREEN}@\h${NO_COL} \w]\\$ "
|
if [ $running != "0" -a $stopped != "0" ] ; then
|
||||||
elif [ $CONN = tel -a $USR = u_root ] ; then
|
rep=" ${running}r/${stopped}s "
|
||||||
PS1="${RED}[\u @${YELLOW}\h${RED} \w]\\$ ${NO_COL}"
|
|
||||||
elif [ $CONN = ssh -a $USR = nou_root ] ; then
|
elif [ $running != "0" -a $stopped == "0" ] ; then
|
||||||
PS1="[\u @${LIGHT_BLUE}\h${NO_COL} \w]\\$ "
|
rep=" ${running}r "
|
||||||
elif [ $CONN = ssh -a $USR = u_root ] ; then
|
|
||||||
PS1="${RED}[\u @${LIGHT_BLUE}\h${RED} \w]\\$ ${NO_COL}"
|
elif [ $running == "0" -a $stopped != "0" ] ; then
|
||||||
|
rep=" ${stopped}s "
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
echo -ne "$rep"
|
||||||
|
}
|
||||||
|
|
||||||
|
git_branch()
|
||||||
|
{
|
||||||
|
if git rev-parse --git-dir >/dev/null 2>&1 ; then
|
||||||
|
gitver=$(git branch 2>/dev/null| sed -n '/^\*/s/^\* //p')
|
||||||
|
else
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
echo -e " $gitver"
|
||||||
|
}
|
||||||
|
|
||||||
|
git_branch_color()
|
||||||
|
{
|
||||||
|
if git rev-parse --git-dir >/dev/null 2>&1 ; then
|
||||||
|
red=`tput setaf 1`
|
||||||
|
green=`tput setaf 2`
|
||||||
|
yellow=`tput setaf 3`
|
||||||
|
|
||||||
|
color=""
|
||||||
|
if git diff --quiet 2>/dev/null >&2 ; then
|
||||||
|
if git rev-list --quiet origin/master..master 2>&1 >/dev/null ; then
|
||||||
|
color="${yellow}" # some commits to push
|
||||||
|
else
|
||||||
|
color="${green}" # nothing to commit or push
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
color="${red}" # changes to commit
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
echo -ne $color
|
||||||
|
}
|
||||||
|
|
||||||
|
# different colors depending on connexion type and user
|
||||||
|
if [ $CONN = lcl -a $USR = nou_root ] ; then
|
||||||
|
PS1="${WHITE}[\u \w]${NO_COL}"
|
||||||
|
elif [ $CONN = lcl -a $USR = u_root ] ; then
|
||||||
|
PS1="${YELLOW}[\w]${NO_COL}"
|
||||||
|
elif [ $CONN = tel -a $USR = nou_root ] ; then
|
||||||
|
PS1="[\u${LIGHT_GREEN}@\h${NO_COL} \w]${NO_COL}"
|
||||||
|
elif [ $CONN = tel -a $USR = u_root ] ; then
|
||||||
|
PS1="${RED}[\u @${YELLOW}\h${RED} \w]${NO_COL}"
|
||||||
|
elif [ $CONN = ssh -a $USR = nou_root ] ; then
|
||||||
|
PS1="[\u @${LIGHT_BLUE}\h${NO_COL} \w]${NO_COL}"
|
||||||
|
elif [ $CONN = ssh -a $USR = u_root ] ; then
|
||||||
|
PS1="${RED}[\u @${LIGHT_BLUE}\h${RED} \w]${NO_COL}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# add job count
|
||||||
|
PS1="$PS1${LIGHT_BLUE}\$(jobcount)${NO_COL}"
|
||||||
|
|
||||||
|
# add git branch and status
|
||||||
|
PS1="$PS1\$(git_branch_color)\$(git_branch)${NO_COL}"
|
||||||
|
|
||||||
|
# add prompt mark
|
||||||
|
if [ $USR = nou_root ] ; then
|
||||||
|
PS1="$PS1${WHITE}\\$ ${NO_COL}"
|
||||||
|
elif [ $USR = u_root ] ; then
|
||||||
|
PS1="$PS1${RED}\\$ ${NO_COL}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Glue the bash prompt always go to the first column .
|
||||||
|
# Avoid glitches after interrupting a command with Ctrl-C
|
||||||
|
PS1="\[\033[G\]$PS1"
|
||||||
|
|
||||||
|
|
||||||
# Prevents accidentally clobbering files.
|
# Prevents accidentally clobbering files.
|
||||||
alias mv='mv -i'
|
alias mv='mv -i'
|
||||||
alias mkdir='mkdir -p'
|
alias mkdir='mkdir -p'
|
||||||
|
|
@ -167,12 +237,14 @@ HISTCONTROL=ignoreboth
|
||||||
HISTTIMEFORMAT='%F %T'
|
HISTTIMEFORMAT='%F %T'
|
||||||
# one command per line
|
# one command per line
|
||||||
shopt -s cmdhist
|
shopt -s cmdhist
|
||||||
|
# append history rather than overwritting it
|
||||||
|
PROMPT_COMMAND='history -a'
|
||||||
# store history immediately
|
# store history immediately
|
||||||
PROMPT_COMMAND='history -a; history -n'
|
#; history -n'
|
||||||
|
|
||||||
# baskcup shortcuts
|
# baskcup shortcuts
|
||||||
alias rcp='rsync -avz --rsh "ssh -l nojhan" '
|
alias rcp='rsync -avz --ignore-existing --progress --rsh "ssh -l nojhan" '
|
||||||
alias rcp_443='rsync -avz --rsh "ssh -p 443 -l nojhan" '
|
alias rcp_443='rsync -avz --ignore-existing --progress --rsh "ssh -p 443 -l nojhan" '
|
||||||
|
|
||||||
# ipython shell with correct default apps
|
# ipython shell with correct default apps
|
||||||
alias ipy='ipython -pylab -p scipy --editor="gvim"'
|
alias ipy='ipython -pylab -p scipy --editor="gvim"'
|
||||||
|
|
@ -180,6 +252,9 @@ alias ipy='ipython -pylab -p scipy --editor="gvim"'
|
||||||
# nautilus file manager in browser mode without ddestkop management
|
# nautilus file manager in browser mode without ddestkop management
|
||||||
alias nautile='nautilus --no-desktop --browser'
|
alias nautile='nautilus --no-desktop --browser'
|
||||||
|
|
||||||
|
alias cgcc="colout :[0-9]+: yellow standard | colout error | colout warning magenta | colout pragma green standard"
|
||||||
|
|
||||||
|
|
||||||
# Added by autojump install.sh
|
# Added by autojump install.sh
|
||||||
source /etc/profile.d/autojump.bash
|
source /etc/profile.d/autojump.bash
|
||||||
|
/usr/games/fortune vimtips
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue