2014-12-20 08:24:26 +01:00
|
|
|
# Set terminal window and tab/icon title
|
|
|
|
#
|
|
|
|
# usage: title short_tab_title [long_window_title]
|
|
|
|
#
|
|
|
|
# See: http://www.faqs.org/docs/Linux-mini/Xterm-Title.html#ss3.1
|
|
|
|
# Fully supports screen, iterm, and probably most modern xterm and rxvt
|
|
|
|
# (In screen, only short_tab_title is used)
|
|
|
|
# Limited support for Apple Terminal (Terminal can't set window and tab separately)
|
2011-01-30 08:21:49 +01:00
|
|
|
function title {
|
2021-11-09 09:08:18 +01:00
|
|
|
setopt localoptions nopromptsubst
|
2014-04-23 02:35:47 +02:00
|
|
|
|
2021-09-29 17:19:25 +02:00
|
|
|
# Don't set the title if inside emacs, unless using vterm
|
2021-11-25 23:55:21 +01:00
|
|
|
[[ -n "${INSIDE_EMACS:-}" && "$INSIDE_EMACS" != vterm ]] && return
|
2015-02-10 19:43:25 +01:00
|
|
|
|
|
|
|
# if $2 is unset use $1 as default
|
|
|
|
# if it is set and empty, leave it as is
|
|
|
|
: ${2=$1}
|
|
|
|
|
2015-12-01 14:04:12 +01:00
|
|
|
case "$TERM" in
|
2023-04-04 16:47:13 +02:00
|
|
|
cygwin|xterm*|putty*|rxvt*|konsole*|ansi|mlterm*|alacritty|st*|foot|contour*)
|
2020-09-27 14:15:50 +02:00
|
|
|
print -Pn "\e]2;${2:q}\a" # set window name
|
|
|
|
print -Pn "\e]1;${1:q}\a" # set tab name
|
2015-12-01 14:04:12 +01:00
|
|
|
;;
|
2019-03-21 20:41:55 +01:00
|
|
|
screen*|tmux*)
|
2020-09-27 14:15:50 +02:00
|
|
|
print -Pn "\ek${1:q}\e\\" # set screen hardstatus
|
2015-12-01 14:04:12 +01:00
|
|
|
;;
|
|
|
|
*)
|
|
|
|
if [[ "$TERM_PROGRAM" == "iTerm.app" ]]; then
|
2020-09-27 14:15:50 +02:00
|
|
|
print -Pn "\e]2;${2:q}\a" # set window name
|
|
|
|
print -Pn "\e]1;${1:q}\a" # set tab name
|
2015-11-19 18:03:56 +01:00
|
|
|
else
|
2021-09-29 17:19:25 +02:00
|
|
|
# Try to use terminfo to set the title if the feature is available
|
|
|
|
if (( ${+terminfo[fsl]} && ${+terminfo[tsl]} )); then
|
|
|
|
print -Pn "${terminfo[tsl]}$1${terminfo[fsl]}"
|
2020-03-03 20:17:01 +01:00
|
|
|
fi
|
2015-12-01 14:04:12 +01:00
|
|
|
fi
|
|
|
|
;;
|
|
|
|
esac
|
2011-01-30 08:21:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
ZSH_THEME_TERM_TAB_TITLE_IDLE="%15<..<%~%<<" #15 char left truncated PWD
|
2020-10-08 19:20:47 +02:00
|
|
|
ZSH_THEME_TERM_TITLE_IDLE="%n@%m:%~"
|
2015-08-09 21:15:12 +02:00
|
|
|
# Avoid duplication of directory in terminals with independent dir display
|
2015-12-01 14:05:18 +01:00
|
|
|
if [[ "$TERM_PROGRAM" == Apple_Terminal ]]; then
|
2015-08-09 21:15:12 +02:00
|
|
|
ZSH_THEME_TERM_TITLE_IDLE="%n@%m"
|
|
|
|
fi
|
2011-01-30 08:21:49 +01:00
|
|
|
|
2015-02-04 07:00:51 +01:00
|
|
|
# Runs before showing the prompt
|
2011-11-15 07:14:03 +01:00
|
|
|
function omz_termsupport_precmd {
|
2021-11-09 09:08:18 +01:00
|
|
|
[[ "${DISABLE_AUTO_TITLE:-}" != true ]] || return
|
|
|
|
title "$ZSH_THEME_TERM_TAB_TITLE_IDLE" "$ZSH_THEME_TERM_TITLE_IDLE"
|
2011-01-30 08:21:49 +01:00
|
|
|
}
|
|
|
|
|
2015-02-04 07:00:51 +01:00
|
|
|
# Runs before executing the command
|
2011-11-15 07:14:03 +01:00
|
|
|
function omz_termsupport_preexec {
|
2021-11-09 09:08:18 +01:00
|
|
|
[[ "${DISABLE_AUTO_TITLE:-}" != true ]] || return
|
2020-03-03 20:17:01 +01:00
|
|
|
|
2015-08-18 02:55:41 +02:00
|
|
|
emulate -L zsh
|
2015-12-01 14:05:18 +01:00
|
|
|
setopt extended_glob
|
|
|
|
|
2020-03-03 20:10:43 +01:00
|
|
|
# split command into array of arguments
|
|
|
|
local -a cmdargs
|
|
|
|
cmdargs=("${(z)2}")
|
|
|
|
# if running fg, extract the command from the job description
|
|
|
|
if [[ "${cmdargs[1]}" = fg ]]; then
|
|
|
|
# get the job id from the first argument passed to the fg command
|
|
|
|
local job_id jobspec="${cmdargs[2]#%}"
|
|
|
|
# logic based on jobs arguments:
|
|
|
|
# http://zsh.sourceforge.net/Doc/Release/Jobs-_0026-Signals.html#Jobs
|
|
|
|
# https://www.zsh.org/mla/users/2007/msg00704.html
|
|
|
|
case "$jobspec" in
|
|
|
|
<->) # %number argument:
|
|
|
|
# use the same <number> passed as an argument
|
|
|
|
job_id=${jobspec} ;;
|
|
|
|
""|%|+) # empty, %% or %+ argument:
|
|
|
|
# use the current job, which appears with a + in $jobstates:
|
|
|
|
# suspended:+:5071=suspended (tty output)
|
|
|
|
job_id=${(k)jobstates[(r)*:+:*]} ;;
|
|
|
|
-) # %- argument:
|
|
|
|
# use the previous job, which appears with a - in $jobstates:
|
|
|
|
# suspended:-:6493=suspended (signal)
|
|
|
|
job_id=${(k)jobstates[(r)*:-:*]} ;;
|
|
|
|
[?]*) # %?string argument:
|
|
|
|
# use $jobtexts to match for a job whose command *contains* <string>
|
|
|
|
job_id=${(k)jobtexts[(r)*${(Q)jobspec}*]} ;;
|
|
|
|
*) # %string argument:
|
|
|
|
# use $jobtexts to match for a job whose command *starts with* <string>
|
|
|
|
job_id=${(k)jobtexts[(r)${(Q)jobspec}*]} ;;
|
|
|
|
esac
|
2014-03-25 21:01:34 +01:00
|
|
|
|
2020-03-03 20:10:43 +01:00
|
|
|
# override preexec function arguments with job command
|
2020-03-03 20:17:01 +01:00
|
|
|
if [[ -n "${jobtexts[$job_id]}" ]]; then
|
|
|
|
1="${jobtexts[$job_id]}"
|
|
|
|
2="${jobtexts[$job_id]}"
|
2019-07-06 18:10:30 +02:00
|
|
|
fi
|
2014-12-20 08:24:26 +01:00
|
|
|
fi
|
|
|
|
|
2014-03-25 21:01:34 +01:00
|
|
|
# cmd name only, or if this is sudo or ssh, the next cmd
|
2021-11-09 09:08:18 +01:00
|
|
|
local CMD="${1[(wr)^(*=*|sudo|ssh|mosh|rake|-*)]:gs/%/%%}"
|
2013-12-14 04:30:29 +01:00
|
|
|
local LINE="${2:gs/%/%%}"
|
2014-03-25 21:01:34 +01:00
|
|
|
|
2021-11-09 09:08:18 +01:00
|
|
|
title "$CMD" "%100>...>${LINE}%<<"
|
2011-01-30 08:21:49 +01:00
|
|
|
}
|
2011-11-15 07:14:03 +01:00
|
|
|
|
2021-09-29 17:19:25 +02:00
|
|
|
autoload -Uz add-zsh-hook
|
2015-02-11 19:58:33 +01:00
|
|
|
|
2021-09-29 17:19:25 +02:00
|
|
|
if [[ -z "$INSIDE_EMACS" || "$INSIDE_EMACS" = vterm ]]; then
|
|
|
|
add-zsh-hook precmd omz_termsupport_precmd
|
|
|
|
add-zsh-hook preexec omz_termsupport_preexec
|
|
|
|
fi
|
2015-02-11 19:58:33 +01:00
|
|
|
|
2021-05-16 18:58:38 +02:00
|
|
|
# Keep terminal emulator's current working directory correct,
|
|
|
|
# even if the current working directory path contains symbolic links
|
|
|
|
#
|
|
|
|
# References:
|
|
|
|
# - Apple's Terminal.app: https://superuser.com/a/315029
|
|
|
|
# - iTerm2: https://iterm2.com/documentation-escape-codes.html (iTerm2 Extension / CurrentDir+RemoteHost)
|
|
|
|
# - Konsole: https://bugs.kde.org/show_bug.cgi?id=327720#c1
|
|
|
|
# - libvte (gnome-terminal, mate-terminal, …): https://bugzilla.gnome.org/show_bug.cgi?id=675987#c14
|
|
|
|
# Apparently it had a bug before ~2012 were it would display the unknown OSC 7 code
|
|
|
|
#
|
|
|
|
# As of May 2021 mlterm, PuTTY, rxvt, screen, termux & xterm simply ignore the unknown OSC.
|
|
|
|
|
|
|
|
# Don't define the function if we're inside Emacs
|
|
|
|
if [[ -n "$INSIDE_EMACS" ]]; then
|
|
|
|
return
|
2015-02-15 01:05:27 +01:00
|
|
|
fi
|
2021-05-16 18:58:38 +02:00
|
|
|
|
|
|
|
# Don't define the function if we're in an unsupported terminal
|
|
|
|
case "$TERM" in
|
|
|
|
# all of these either process OSC 7 correctly or ignore entirely
|
|
|
|
xterm*|putty*|rxvt*|konsole*|mlterm*|alacritty|screen*|tmux*) ;;
|
|
|
|
contour*|foot*) ;;
|
|
|
|
*)
|
|
|
|
# Terminal.app and iTerm2 process OSC 7 correctly
|
|
|
|
case "$TERM_PROGRAM" in
|
|
|
|
Apple_Terminal|iTerm.app) ;;
|
|
|
|
*) return ;;
|
|
|
|
esac ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
# Emits the control sequence to notify many terminal emulators
|
|
|
|
# of the cwd
|
|
|
|
#
|
|
|
|
# Identifies the directory using a file: URI scheme, including
|
|
|
|
# the host name to disambiguate local vs. remote paths.
|
|
|
|
function omz_termsupport_cwd {
|
|
|
|
# Percent-encode the host and path names.
|
|
|
|
local URL_HOST URL_PATH
|
|
|
|
URL_HOST="$(omz_urlencode -P $HOST)" || return 1
|
|
|
|
URL_PATH="$(omz_urlencode -P $PWD)" || return 1
|
|
|
|
|
|
|
|
# common control sequence (OSC 7) to set current host and path
|
|
|
|
printf "\e]7;%s\a" "file://${URL_HOST}${URL_PATH}"
|
|
|
|
}
|
|
|
|
|
|
|
|
# Use a precmd hook instead of a chpwd hook to avoid contaminating output
|
|
|
|
# i.e. when a script or function changes directory without `cd -q`, chpwd
|
|
|
|
# will be called the output may be swallowed by the script or function.
|
|
|
|
add-zsh-hook precmd omz_termsupport_cwd
|