Commit 54055c45 authored by Marc Cornellà's avatar Marc Cornellà
Browse files

Merge branch 'apjanke/tmux-detabify-source'

Closes #4412
Fixes #4425
parents 106f8260 f584de59
# if ! (( $+commands[tmux] )); then
# Aliases print "zsh tmux plugin: tmux not found. Please install tmux before using this plugin." >&2
# return 1
fi
# ALIASES
alias ta='tmux attach -t' alias ta='tmux attach -t'
alias tad='tmux attach -d -t' alias tad='tmux attach -d -t'
...@@ -9,90 +12,79 @@ alias tl='tmux list-sessions' ...@@ -9,90 +12,79 @@ alias tl='tmux list-sessions'
alias tksv='tmux kill-server' alias tksv='tmux kill-server'
alias tkss='tmux kill-session -t' alias tkss='tmux kill-session -t'
# Only run if tmux is actually installed # CONFIGURATION VARIABLES
if which tmux &> /dev/null # Automatically start tmux
then : ${ZSH_TMUX_AUTOSTART:=false}
# Configuration variables # Only autostart once. If set to false, tmux will attempt to
# # autostart every time your zsh configs are reloaded.
# Automatically start tmux : ${ZSH_TMUX_AUTOSTART_ONCE:=true}
[[ -n "$ZSH_TMUX_AUTOSTART" ]] || ZSH_TMUX_AUTOSTART=false # Automatically connect to a previous session if it exists
# Only autostart once. If set to false, tmux will attempt to : ${ZSH_TMUX_AUTOCONNECT:=true}
# autostart every time your zsh configs are reloaded. # Automatically close the terminal when tmux exits
[[ -n "$ZSH_TMUX_AUTOSTART_ONCE" ]] || ZSH_TMUX_AUTOSTART_ONCE=true : ${ZSH_TMUX_AUTOQUIT:=$ZSH_TMUX_AUTOSTART}
# Automatically connect to a previous session if it exists # Set term to screen or screen-256color based on current terminal support
[[ -n "$ZSH_TMUX_AUTOCONNECT" ]] || ZSH_TMUX_AUTOCONNECT=true : ${ZSH_TMUX_FIXTERM:=true}
# Automatically close the terminal when tmux exits # Set '-CC' option for iTerm2 tmux integration
[[ -n "$ZSH_TMUX_AUTOQUIT" ]] || ZSH_TMUX_AUTOQUIT=$ZSH_TMUX_AUTOSTART : ${ZSH_TMUX_ITERM2:=false}
# Set term to screen or screen-256color based on current terminal support # The TERM to use for non-256 color terminals.
[[ -n "$ZSH_TMUX_FIXTERM" ]] || ZSH_TMUX_FIXTERM=true # Tmux states this should be screen, but you may need to change it on
# Set '-CC' option for iTerm2 tmux integration # systems without the proper terminfo
[[ -n "$ZSH_TMUX_ITERM2" ]] || ZSH_TMUX_ITERM2=false : ${ZSH_TMUX_FIXTERM_WITHOUT_256COLOR:=screen}
# The TERM to use for non-256 color terminals. # The TERM to use for 256 color terminals.
# Tmux states this should be screen, but you may need to change it on # Tmux states this should be screen-256color, but you may need to change it on
# systems without the proper terminfo # systems without the proper terminfo
[[ -n "$ZSH_TMUX_FIXTERM_WITHOUT_256COLOR" ]] || ZSH_TMUX_FIXTERM_WITHOUT_256COLOR="screen" : ${ZSH_TMUX_FIXTERM_WITH_256COLOR:=screen-256color}
# The TERM to use for 256 color terminals.
# Tmux states this should be screen-256color, but you may need to change it on
# systems without the proper terminfo
[[ -n "$ZSH_TMUX_FIXTERM_WITH_256COLOR" ]] || ZSH_TMUX_FIXTERM_WITH_256COLOR="screen-256color"
# Get the absolute path to the current directory
local zsh_tmux_plugin_path="$(cd "$(dirname "$0")" && pwd)"
# Determine if the terminal supports 256 colors # Determine if the terminal supports 256 colors
if [[ `tput colors` == "256" ]] if [[ $(tput colors) == 256 ]]; then
then
export ZSH_TMUX_TERM=$ZSH_TMUX_FIXTERM_WITH_256COLOR export ZSH_TMUX_TERM=$ZSH_TMUX_FIXTERM_WITH_256COLOR
else else
export ZSH_TMUX_TERM=$ZSH_TMUX_FIXTERM_WITHOUT_256COLOR export ZSH_TMUX_TERM=$ZSH_TMUX_FIXTERM_WITHOUT_256COLOR
fi fi
# Set the correct local config file to use.
if [[ "$ZSH_TMUX_ITERM2" == "false" && -e "$HOME/.tmux.conf" ]]; then
export _ZSH_TMUX_FIXED_CONFIG="${0:h:a}/tmux.extra.conf"
else
export _ZSH_TMUX_FIXED_CONFIG="${0:h:a}/tmux.only.conf"
fi
# Set the correct local config file to use. # Wrapper function for tmux.
if [[ "$ZSH_TMUX_ITERM2" == "false" ]] && [[ -f $HOME/.tmux.conf || -h $HOME/.tmux.conf ]] function _zsh_tmux_plugin_run() {
then if [[ -n "$@" ]]; then
#use this when they have a ~/.tmux.conf command tmux "$@"
export _ZSH_TMUX_FIXED_CONFIG="$zsh_tmux_plugin_path/tmux.extra.conf" return $?
else
#use this when they don't have a ~/.tmux.conf
export _ZSH_TMUX_FIXED_CONFIG="$zsh_tmux_plugin_path/tmux.only.conf"
fi fi
# Wrapper function for tmux. local -a tmux_cmd=(command tmux)
function _zsh_tmux_plugin_run() [[ "$ZSH_TMUX_ITERM2" == "true" ]] && tmux_cmd+=(-CC)
{
# We have other arguments, just run them
if [[ -n "$@" ]]
then
\tmux $@
# Try to connect to an existing session. # Try to connect to an existing session.
elif [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] if [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]]; then
then $tmux_cmd attach
\tmux `[[ "$ZSH_TMUX_ITERM2" == "true" ]] && echo '-CC '` attach || \tmux `[[ "$ZSH_TMUX_ITERM2" == "true" ]] && echo '-CC '` `[[ "$ZSH_TMUX_FIXTERM" == "true" ]] && echo '-f '$_ZSH_TMUX_FIXED_CONFIG` new-session fi
[[ "$ZSH_TMUX_AUTOQUIT" == "true" ]] && exit
# Just run tmux, fixing the TERM variable if requested. # If failed, just run tmux, fixing the TERM variable if requested.
else if [[ $? -ne 0 ]]; then
\tmux `[[ "$ZSH_TMUX_ITERM2" == "true" ]] && echo '-CC '` `[[ "$ZSH_TMUX_FIXTERM" == "true" ]] && echo '-f '$_ZSH_TMUX_FIXED_CONFIG` [[ "$ZSH_TMUX_FIXTERM" == "true" ]] && tmux_cmd+=(-f "$_ZSH_TMUX_FIXED_CONFIG")
[[ "$ZSH_TMUX_AUTOQUIT" == "true" ]] && exit $tmux_cmd new-session
fi fi
}
# Use the completions for tmux for our function if [[ "$ZSH_TMUX_AUTOQUIT" == "true" ]]; then
compdef _tmux _zsh_tmux_plugin_run exit
fi
}
# Alias tmux to our wrapper function. # Use the completions for tmux for our function
alias tmux=_zsh_tmux_plugin_run compdef _tmux _zsh_tmux_plugin_run
# Alias tmux to our wrapper function.
alias tmux=_zsh_tmux_plugin_run
# Autostart if not already in tmux and enabled. # Autostart if not already in tmux and enabled.
if [[ ! -n "$TMUX" && "$ZSH_TMUX_AUTOSTART" == "true" ]] if [[ -z "$TMUX" && "$ZSH_TMUX_AUTOSTART" == "true" ]]; then
then
# Actually don't autostart if we already did and multiple autostarts are disabled. # Actually don't autostart if we already did and multiple autostarts are disabled.
if [[ "$ZSH_TMUX_AUTOSTART_ONCE" == "false" || "$ZSH_TMUX_AUTOSTARTED" != "true" ]] if [[ "$ZSH_TMUX_AUTOSTART_ONCE" == "false" || "$ZSH_TMUX_AUTOSTARTED" != "true" ]]; then
then
export ZSH_TMUX_AUTOSTARTED=true export ZSH_TMUX_AUTOSTARTED=true
_zsh_tmux_plugin_run _zsh_tmux_plugin_run
fi fi
fi
else
print "zsh tmux plugin: tmux not found. Please install tmux before using this plugin."
fi fi
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment