# FUNCTION SETTINGS
+# Make sure every entry in $fpath is unique.
+typeset -U fpath
# Set correct fpath to allow loading my functions (including completion
# functions).
fpath=(~/.zsh/functions $fpath)
# It works with screen and xterm. If screen is running in X11 (DISPLAY is set)
# and stumpwm is used (it's tested if stumpish is available) then the window
# title is also set in stumpwm using stumpish.
+#
+# If a command is run with sudo or if the shell is running as root then a ! is
+# added at the beginning of the command to make this clear. If a command is
+# running on a different computer with ssh a @ is added at the beginning.
if [[ $TERM == screen* || $TERM == xterm* ]]; then
# Set to a non empty value to reset the window name in the next precmd()
# call.
if [[ $? -eq 0 ]]; then
window_stumpwm=yes
fi
+ # Set to a non empty value when the shell is running as root.
+ if [[ $(id -u) -eq 0 ]]; then
+ window_root=yes
+ fi
window_preexec() {
# Get the program name with its arguments.
local program_name=$1
+
# When sudo is used use real program name instead, but with an
# exclamation mark at the beginning.
+ local program_sudo=
if [[ $program_name == sudo* ]]; then
- program_name=!${program_name#sudo }
+ program_name=${program_name#sudo }
+ program_sudo=yes
fi
# Remove all arguments from the program name.
program_name=${program_name%% *}
;;
esac
+ # Add an exclamation mark at the beginning if running with sudo or if
+ # running zsh as root.
+ if [[ -n $program_sudo || -n $window_root ]]; then
+ program_name=!$program_name
+ fi
+
+ # Add an at mark at the beginning if running ssh on a different
+ # computer.
+ if [[ -n $SSH_CONNECTION ]]; then
+ program_name="@$program_name"
+ fi
+
# Set the window name to the currently running program.
window_title "$program_name"
[[ -z $window_reset ]] && return
# Reset the window name to 'zsh'.
- window_title "zsh"
+ if [[ -n $SSH_CONNECTION ]]; then
+ window_title "@zsh"
+ elif [[ -n $window_root ]]; then
+ window_title "!zsh"
+ else
+ window_title "zsh"
+ fi
# Just reset the name, so no screen reset necessary for the moment.
window_reset=