Optimize LP_HOST

Simplify _lp_connection (code reduced by 70%, much less external
programs used).
Call _lp_connection just once at init time.
Inline _lp_host_color.
LP_HOST is now a global defined just once.
This commit is contained in:
Olivier Mengué 2012-08-14 11:43:58 +02:00
parent 8e3d2fe0c8
commit c9d43a52fa

View File

@ -292,65 +292,46 @@ _lp_user()
_lp_connection()
{
local THIS_TTY
THIS_TTY=$(awk -v pid=$$ -v wkshell=${_LP_WORKING_SHELL} '$0 ~ pid && $0 ~ wkshell { print $7 }' < <(ps aux) )
local SESS_SRC
SESS_SRC=$(who | awk -v thistty="$THIS_TTY" '$0 ~ thistty { print $6 }')
# Are we in an SSH connexion?
local SSH_FLAG
SSH_FLAG=0
local SSH_IP
SSH_IP=${SSH_CLIENT%% *}
if [[ ! -z $SSH_IP ]] ; then
SSH_FLAG=1
fi
local SSH2_IP
SSH2_IP=$(echo $SSH2_CLIENT | awk '{ print $1 }')
if [[ ! -z $SSH2_IP ]] ; then
SSH_FLAG=1
fi
local CONN
if [[ $SSH_FLAG -eq 1 ]] ; then
CONN="ssh"
elif [[ -z $SESS_SRC ]] ; then
CONN="lcl"
elif [[ $SESS_SRC = "(:0.0)" || $SESS_SRC = "" ]] ; then
CONN="lcl"
if [[ -n "$SSH_CLIENT$SSH2_CLIENT" ]] ; then
echo ssh
else
CONN="tel"
# TODO check on *BSD
local sess_src=$(who am i | sed -n 's/.*(\(.*\))/\1/p')
if [[ -z "$sess_src" || "$sess_src" = :0.0 ]] ; then
echo lcl # Local
else
echo tel # Telnet
fi
fi
echo -ne $CONN
}
# Put the hostname if not locally connected
# color it in cyan within SSH, and a warning red if within telnet
# else diplay the host without color
_lp_host_color()
{
local conn
conn=$(_lp_connection)
local ret
ret="${NO_COL}"
if [[ "$conn" == "lcl" ]] ; then
# The connection is not expected to change from inside the shell, so we
# build this just once
case "$(_lp_connection)" in
lcl)
if [[ $LP_HOSTNAME_ALWAYS == 0 ]] ; then
ret="${ret}" # no hostname if local
LP_HOST="${NO_COL}" # no hostname if local
else
ret="${ret}@${LP_COLOR_HOST}${_LP_HOST_SYMBOL}"
fi
elif [[ "$conn" == "ssh" ]] ; then
ret="${ret}@${LP_COLOR_SSH}${_LP_HOST_SYMBOL}"
elif [[ "$conn" == "tel" ]] ; then
ret="${ret}@${LP_COLOR_TELNET}${_LP_HOST_SYMBOL}"
else
ret="${ret}@${_LP_HOST_SYMBOL}" # defaults to no color
LP_HOST="${NO_COL}@${LP_COLOR_HOST}${_LP_HOST_SYMBOL}${NO_COL}"
fi
;;
ssh)
LP_HOST="${NO_COL}@${LP_COLOR_SSH}${_LP_HOST_SYMBOL}${NO_COL}"
;;
tel)
LP_HOST="${NO_COL}@${LP_COLOR_TELNET}${_LP_HOST_SYMBOL}${NO_COL}"
;;
*)
LP_HOST="${NO_COL}@${_LP_HOST_SYMBOL}" # defaults to no color
;;
esac
# Useless now, so undefine
unset _lp_connection
echo -ne "${ret}${NO_COL}"
}
# put an arrow if an http proxy is set
_lp_proxy()
@ -906,7 +887,7 @@ _lp_set_bash_prompt()
# in main prompt: no space
LP_USER=$(_lp_user)
LP_HOST=$(_lp_host_color)
# LP_HOST is a global set at load time
LP_PERM=$(_lp_permissions_color)
LP_PWD=$(_lp_shorten_path "$PWD" $LP_PATH_LENGTH)
LP_PROXY=$(_lp_proxy)