summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarc Cornellà <marc.cornella@live.com>2018-08-03 22:13:58 +0200
committerMarc Cornellà <marc.cornella@live.com>2018-08-03 22:13:58 +0200
commit54055c4530112439a04bf039d09c30c4b7330c84 (patch)
treed0fd7351ac4955cfaf6d6bcccf63c1f214a96ec5
parent106f826075979ef1a6875cedd2d098e601f2e3f2 (diff)
parentf584de5930467fd53e8b7d2e51f5227bc405e4b2 (diff)
downloadzsh-54055c4530112439a04bf039d09c30c4b7330c84.tar.gz
zsh-54055c4530112439a04bf039d09c30c4b7330c84.tar.bz2
zsh-54055c4530112439a04bf039d09c30c4b7330c84.zip
Merge branch 'apjanke/tmux-detabify-source'
Closes #4412 Fixes #4425
-rw-r--r--plugins/tmux/tmux.plugin.zsh154
1 files changed, 73 insertions, 81 deletions
diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh
index fb514a44c..2d161c377 100644
--- a/plugins/tmux/tmux.plugin.zsh
+++ b/plugins/tmux/tmux.plugin.zsh
@@ -1,6 +1,9 @@
-#
-# Aliases
-#
+if ! (( $+commands[tmux] )); then
+ 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 tad='tmux attach -d -t'
@@ -9,90 +12,79 @@ alias tl='tmux list-sessions'
alias tksv='tmux kill-server'
alias tkss='tmux kill-session -t'
-# Only run if tmux is actually installed
-if which tmux &> /dev/null
- then
- # Configuration variables
- #
- # Automatically start tmux
- [[ -n "$ZSH_TMUX_AUTOSTART" ]] || ZSH_TMUX_AUTOSTART=false
- # Only autostart once. If set to false, tmux will attempt to
- # autostart every time your zsh configs are reloaded.
- [[ -n "$ZSH_TMUX_AUTOSTART_ONCE" ]] || ZSH_TMUX_AUTOSTART_ONCE=true
- # Automatically connect to a previous session if it exists
- [[ -n "$ZSH_TMUX_AUTOCONNECT" ]] || ZSH_TMUX_AUTOCONNECT=true
- # Automatically close the terminal when tmux exits
- [[ -n "$ZSH_TMUX_AUTOQUIT" ]] || ZSH_TMUX_AUTOQUIT=$ZSH_TMUX_AUTOSTART
- # Set term to screen or screen-256color based on current terminal support
- [[ -n "$ZSH_TMUX_FIXTERM" ]] || ZSH_TMUX_FIXTERM=true
- # Set '-CC' option for iTerm2 tmux integration
- [[ -n "$ZSH_TMUX_ITERM2" ]] || ZSH_TMUX_ITERM2=false
- # The TERM to use for non-256 color terminals.
- # Tmux states this should be screen, but you may need to change it on
- # systems without the proper terminfo
- [[ -n "$ZSH_TMUX_FIXTERM_WITHOUT_256COLOR" ]] || ZSH_TMUX_FIXTERM_WITHOUT_256COLOR="screen"
- # 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"
+# CONFIGURATION VARIABLES
+# Automatically start tmux
+: ${ZSH_TMUX_AUTOSTART:=false}
+# Only autostart once. If set to false, tmux will attempt to
+# autostart every time your zsh configs are reloaded.
+: ${ZSH_TMUX_AUTOSTART_ONCE:=true}
+# Automatically connect to a previous session if it exists
+: ${ZSH_TMUX_AUTOCONNECT:=true}
+# Automatically close the terminal when tmux exits
+: ${ZSH_TMUX_AUTOQUIT:=$ZSH_TMUX_AUTOSTART}
+# Set term to screen or screen-256color based on current terminal support
+: ${ZSH_TMUX_FIXTERM:=true}
+# Set '-CC' option for iTerm2 tmux integration
+: ${ZSH_TMUX_ITERM2:=false}
+# The TERM to use for non-256 color terminals.
+# Tmux states this should be screen, but you may need to change it on
+# systems without the proper terminfo
+: ${ZSH_TMUX_FIXTERM_WITHOUT_256COLOR:=screen}
+# 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
+: ${ZSH_TMUX_FIXTERM_WITH_256COLOR:=screen-256color}
+
+# Determine if the terminal supports 256 colors
+if [[ $(tput colors) == 256 ]]; then
+ export ZSH_TMUX_TERM=$ZSH_TMUX_FIXTERM_WITH_256COLOR
+else
+ export ZSH_TMUX_TERM=$ZSH_TMUX_FIXTERM_WITHOUT_256COLOR
+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
- # Get the absolute path to the current directory
- local zsh_tmux_plugin_path="$(cd "$(dirname "$0")" && pwd)"
+# Wrapper function for tmux.
+function _zsh_tmux_plugin_run() {
+ if [[ -n "$@" ]]; then
+ command tmux "$@"
+ return $?
+ fi
- # Determine if the terminal supports 256 colors
- if [[ `tput colors` == "256" ]]
- then
- export ZSH_TMUX_TERM=$ZSH_TMUX_FIXTERM_WITH_256COLOR
- else
- export ZSH_TMUX_TERM=$ZSH_TMUX_FIXTERM_WITHOUT_256COLOR
- fi
+ local -a tmux_cmd=(command tmux)
+ [[ "$ZSH_TMUX_ITERM2" == "true" ]] && tmux_cmd+=(-CC)
- # Set the correct local config file to use.
- if [[ "$ZSH_TMUX_ITERM2" == "false" ]] && [[ -f $HOME/.tmux.conf || -h $HOME/.tmux.conf ]]
- then
- #use this when they have a ~/.tmux.conf
- export _ZSH_TMUX_FIXED_CONFIG="$zsh_tmux_plugin_path/tmux.extra.conf"
- else
- #use this when they don't have a ~/.tmux.conf
- export _ZSH_TMUX_FIXED_CONFIG="$zsh_tmux_plugin_path/tmux.only.conf"
- fi
+ # Try to connect to an existing session.
+ if [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]]; then
+ $tmux_cmd attach
+ fi
- # Wrapper function for tmux.
- function _zsh_tmux_plugin_run()
- {
- # We have other arguments, just run them
- if [[ -n "$@" ]]
- then
- \tmux $@
- # Try to connect to an existing session.
- elif [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]]
- then
- \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
- [[ "$ZSH_TMUX_AUTOQUIT" == "true" ]] && exit
- # Just run tmux, fixing the TERM variable if requested.
- else
- \tmux `[[ "$ZSH_TMUX_ITERM2" == "true" ]] && echo '-CC '` `[[ "$ZSH_TMUX_FIXTERM" == "true" ]] && echo '-f '$_ZSH_TMUX_FIXED_CONFIG`
- [[ "$ZSH_TMUX_AUTOQUIT" == "true" ]] && exit
- fi
- }
+ # If failed, just run tmux, fixing the TERM variable if requested.
+ if [[ $? -ne 0 ]]; then
+ [[ "$ZSH_TMUX_FIXTERM" == "true" ]] && tmux_cmd+=(-f "$_ZSH_TMUX_FIXED_CONFIG")
+ $tmux_cmd new-session
+ fi
- # Use the completions for tmux for our function
- compdef _tmux _zsh_tmux_plugin_run
+ if [[ "$ZSH_TMUX_AUTOQUIT" == "true" ]]; then
+ exit
+ fi
+}
- # Alias tmux to our wrapper function.
- alias tmux=_zsh_tmux_plugin_run
+# Use the completions for tmux for our function
+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.
- if [[ ! -n "$TMUX" && "$ZSH_TMUX_AUTOSTART" == "true" ]]
- then
- # Actually don't autostart if we already did and multiple autostarts are disabled.
- if [[ "$ZSH_TMUX_AUTOSTART_ONCE" == "false" || "$ZSH_TMUX_AUTOSTARTED" != "true" ]]
- then
- export ZSH_TMUX_AUTOSTARTED=true
- _zsh_tmux_plugin_run
- fi
- fi
-else
- print "zsh tmux plugin: tmux not found. Please install tmux before using this plugin."
+# Autostart if not already in tmux and enabled.
+if [[ -z "$TMUX" && "$ZSH_TMUX_AUTOSTART" == "true" ]]; then
+ # Actually don't autostart if we already did and multiple autostarts are disabled.
+ if [[ "$ZSH_TMUX_AUTOSTART_ONCE" == "false" || "$ZSH_TMUX_AUTOSTARTED" != "true" ]]; then
+ export ZSH_TMUX_AUTOSTARTED=true
+ _zsh_tmux_plugin_run
+ fi
fi