2 Commits

29 changed files with 169 additions and 141 deletions

View File

@@ -3,12 +3,13 @@ set -e
[ -n "$TMUXIFIER_DEBUG" ] && set -x [ -n "$TMUXIFIER_DEBUG" ] && set -x
resolve_link() { resolve_link() {
$(type -p greadlink readlink | head -1) $1 $(type -p greadlink readlink | head -1) "$1"
} }
abs_dirname() { abs_dirname() {
local cwd="$(pwd)" local cwd
local path="$1" local path="$1"
cwd="$(pwd)"
while [ -n "$path" ]; do while [ -n "$path" ]; do
cd "${path%/*}" cd "${path%/*}"
@@ -22,11 +23,12 @@ abs_dirname() {
if [ -z "${TMUXIFIER}" ]; then if [ -z "${TMUXIFIER}" ]; then
# Set TMUXIFIER relative to the "tmuxifier" executable. # Set TMUXIFIER relative to the "tmuxifier" executable.
export TMUXIFIER="$(dirname "$(abs_dirname "$0")")" TMUXIFIER="$(dirname "$(abs_dirname "$0")")"
else else
# Strip any trailing slash (/) characters from TMUXIFIER variable. # Strip any trailing slash (/) characters from TMUXIFIER variable.
export TMUXIFIER="${TMUXIFIER%/}" TMUXIFIER="${TMUXIFIER%/}"
fi fi
export TMUXIFIER
# Load tmuxifier environment variables. # Load tmuxifier environment variables.
source "$TMUXIFIER/lib/env.sh" source "$TMUXIFIER/lib/env.sh"
@@ -38,29 +40,25 @@ export PATH="$TMUXIFIER/libexec:$PATH"
export TMUXIFIER_MIN_TMUX_VERSION="1.6" export TMUXIFIER_MIN_TMUX_VERSION="1.6"
if [ "$(tmuxifier-tmux-version "$TMUXIFIER_MIN_TMUX_VERSION")" == "<" ]; then if [ "$(tmuxifier-tmux-version "$TMUXIFIER_MIN_TMUX_VERSION")" == "<" ]; then
echo -e "ERROR: Tmuxifier requires Tmux v${TMUXIFIER_MIN_TMUX_VERSION}" \ echo -e "ERROR: Tmuxifier requires Tmux v${TMUXIFIER_MIN_TMUX_VERSION}" \
"or newer. You have v$(tmuxifier-tmux-version)." >&2 "or newer. You have v$(tmuxifier-tmux-version)." >&2
exit 1 exit 1
fi fi
# Parse given command # Parse given command
command="$1" command="$1"
case "$command" in case "$command" in
"" | "-h" | "--help" ) "" | "-h" | "--help")
echo -e "tmuxifier $(tmuxifier-version)\n$(tmuxifier-help)" >&2 echo -e "tmuxifier $(tmuxifier-version)\n$(tmuxifier-help)" >&2
;; ;;
"-v" | "--version")
"-v" | "--version" )
tmuxifier-version tmuxifier-version
;; ;;
*)
* )
! command_path="$(tmuxifier-resolve-command-path "$command")" ! command_path="$(tmuxifier-resolve-command-path "$command")"
if [ -z "$command_path" ]; then if [ -z "$command_path" ]; then
echo "tmuxifier: no such command '$command'" >&2 echo "tmuxifier: no such command '$command'" >&2
exit 1 exit 1
fi fi
shift 1 shift 1
exec "$command_path" "$@" exec "$command_path" "$@"
;; ;;

View File

@@ -3,11 +3,12 @@ _tmuxifier() {
local word="${COMP_WORDS[COMP_CWORD]}" local word="${COMP_WORDS[COMP_CWORD]}"
if [ "$COMP_CWORD" -eq 1 ]; then if [ "$COMP_CWORD" -eq 1 ]; then
COMPREPLY=( $(compgen -W "$(tmuxifier commands)" -- "$word") ) COMPREPLY=($(compgen -W "$(tmuxifier commands)" -- "$word"))
else else
local command="${COMP_WORDS[1]}" local command="${COMP_WORDS[1]}"
local completions="$(tmuxifier completions "$command")" local completions
COMPREPLY=( $(compgen -W "$completions" -- "$word") ) completions="$(tmuxifier completions "$command")"
COMPREPLY=($(compgen -W "$completions" -- "$word"))
fi fi
} }

View File

@@ -140,7 +140,7 @@ balance_windows_horizontal() {
# #
synchronize_on() { synchronize_on() {
tmuxifier-tmux set-window-option -t "$session:${1:-$window}" \ tmuxifier-tmux set-window-option -t "$session:${1:-$window}" \
synchronize-panes on synchronize-panes on
} }
# Turn off synchronize-panes in a window. # Turn off synchronize-panes in a window.
@@ -150,7 +150,7 @@ synchronize_on() {
# #
synchronize_off() { synchronize_off() {
tmuxifier-tmux set-window-option -t "$session:${1:-$window}" \ tmuxifier-tmux set-window-option -t "$session:${1:-$window}" \
synchronize-panes off synchronize-panes off
} }
# Send/paste keys to the currently active pane/window. # Send/paste keys to the currently active pane/window.
@@ -180,7 +180,9 @@ run_cmd() {
# - $1: Directory path to use for session root. # - $1: Directory path to use for session root.
# #
session_root() { session_root() {
local dir="$(__expand_path $@)" local dir
dir="$(__expand_path "$@")"
if [ -d "$dir" ]; then if [ -d "$dir" ]; then
session_root="$dir" session_root="$dir"
fi fi
@@ -192,7 +194,9 @@ session_root() {
# - $1: Directory path to use for window root. # - $1: Directory path to use for window root.
# #
window_root() { window_root() {
local dir="$(__expand_path $@)" local dir
dir="$(__expand_path "$@")"
if [ -d "$dir" ]; then if [ -d "$dir" ]; then
window_root="$dir" window_root="$dir"
fi fi
@@ -214,9 +218,11 @@ load_window() {
if [ $# -gt 1 ]; then if [ $# -gt 1 ]; then
window="$2" window="$2"
else else
window="${1/%.window.sh}" window="${1/%.window.sh/}"
window="${window/%.sh}" window="${window/%.sh/}"
fi fi
# shellcheck disable=SC1090
source "$file" source "$file"
window= window=
@@ -258,11 +264,12 @@ load_session() {
if [ $# -gt 1 ]; then if [ $# -gt 1 ]; then
session="$2" session="$2"
else else
session="${1/%.session.sh}" session="${1/%.session.sh/}"
session="${session/%.sh}" session="${session/%.sh/}"
fi fi
set_default_path=true set_default_path=true
# shellcheck disable=SC1090
source "$file" source "$file"
session= session=
@@ -304,11 +311,11 @@ initialize_session() {
# Set default-path for session # Set default-path for session
if [ -n "$session_root" ] && [ -d "$session_root" ]; then if [ -n "$session_root" ] && [ -d "$session_root" ]; then
cd "$session_root" cd "$session_root" || return 1
$set_default_path && tmuxifier-tmux \ $set_default_path && tmuxifier-tmux \
set-option -t "$session:" \ set-option -t "$session:" \
default-path "$session_root" 1>/dev/null default-path "$session_root" 1> /dev/null
fi fi
# Tmux 1.9 and later. # Tmux 1.9 and later.
@@ -329,7 +336,8 @@ initialize_session() {
# In order to ensure only specified windows are created, we move the # In order to ensure only specified windows are created, we move the
# default window to position 999, and later remove it with the # default window to position 999, and later remove it with the
# `finalize_and_go_to_session` function. # `finalize_and_go_to_session` function.
local first_window_index=$(__get_first_window_index) local first_window_index
first_window_index="$(__get_first_window_index)"
tmuxifier-tmux move-window \ tmuxifier-tmux move-window \
-s "$session:$first_window_index" -t "$session:999" -s "$session:$first_window_index" -t "$session:999"
} }
@@ -344,13 +352,12 @@ initialize_session() {
# created, but already existed, then we'll need to specifically switch to it. # created, but already existed, then we'll need to specifically switch to it.
# #
finalize_and_go_to_session() { finalize_and_go_to_session() {
! tmuxifier-tmux kill-window -t "$session:999" 2>/dev/null ! tmuxifier-tmux kill-window -t "$session:999" 2> /dev/null
if [[ "$(tmuxifier-current-session)" != "$session" ]]; then if [[ "$(tmuxifier-current-session)" != "$session" ]]; then
__go_to_session __go_to_session
fi fi
} }
# #
# Internal functions # Internal functions
# #
@@ -363,12 +370,17 @@ finalize_and_go_to_session() {
# /Users/jimeh/Projects # /Users/jimeh/Projects
# #
__expand_path() { __expand_path() {
echo $(eval echo "$@") local path="$1"
path="${path/#\~/$HOME}"
echo "$path"
} }
__get_first_window_index() { __get_first_window_index() {
local index=$(tmuxifier-tmux list-windows -t "$session:" \ local index
-F "#{window_index}" 2>/dev/null) index="$(
tmuxifier-tmux list-windows \
-t "$session:" -F "#{window_index}" 2> /dev/null
)"
if [ -n "$index" ]; then if [ -n "$index" ]; then
echo "$index" | head -1 echo "$index" | head -1
@@ -378,16 +390,20 @@ __get_first_window_index() {
} }
__get_current_window_index() { __get_current_window_index() {
local lookup=$(tmuxifier-tmux list-windows -t "$session:" \ local lookup
-F "#{window_active}:#{window_index}" 2>/dev/null | grep "^1:") lookup="$(
tmuxifier-tmux list-windows -t "$session:" \
-F "#{window_active}:#{window_index}" 2> /dev/null | grep "^1:"
)"
if [ -n "$lookup" ]; then if [ -n "$lookup" ]; then
echo "${lookup/1:}" echo "${lookup/1:/}"
fi fi
} }
__go_to_session() { __go_to_session() {
if [ -z "$TMUX" ]; then if [ -z "$TMUX" ]; then
# shellcheck disable=2086
tmuxifier-tmux $TMUXIFIER_TMUX_ITERM_ATTACH -u \ tmuxifier-tmux $TMUXIFIER_TMUX_ITERM_ATTACH -u \
attach-session -t "$session:" attach-session -t "$session:"
else else

View File

@@ -1,11 +1,11 @@
calling-help() { calling-help() {
if [[ " $@ " != *" --help "* ]] && [[ " $@ " != *" -h "* ]]; then if [[ " $* " != *" --help "* ]] && [[ " $* " != *" -h "* ]]; then
return 1 return 1
fi fi
} }
calling-complete() { calling-complete() {
if [[ " $@ " != *" --complete "* ]]; then if [[ " $* " != *" --complete "* ]]; then
return 1 return 1
fi fi
} }

View File

@@ -14,33 +14,37 @@ Resolve a command alias to it's full name."
fi fi
case "$1" in case "$1" in
"session" | "ses" | "s" ) "session" | "ses" | "s")
echo "load-session" echo "load-session"
;; ;;
"window" | "win" | "w" ) "window" | "win" | "w")
echo "load-window" echo "load-window"
;; ;;
"new-ses" | "nses" | "ns" ) "new-ses" | "nses" | "ns")
echo "new-session" echo "new-session"
;; ;;
"new-win" | "nwin" | "nw" ) "new-win" | "nwin" | "nw")
echo "new-window" echo "new-window"
;; ;;
"edit-ses" | "eses" | "es" ) "edit-ses" | "eses" | "es")
echo "edit-session" echo "edit-session"
;; ;;
"edit-win" | "ewin" | "ew" ) "edit-win" | "ewin" | "ew")
echo "edit-window" echo "edit-window"
;; ;;
"l" ) "l")
echo "list" echo "list"
;; ;;
"list-ses" | "lses" | "ls" ) "list-ses" | "lses" | "ls")
echo "list-sessions" echo "list-sessions"
;; ;;
"list-win" | "lwin" | "lw" ) "list-win" | "lwin" | "lw")
echo "list-windows" echo "list-windows"
;; ;;
* ) "completion")
echo "completions"
;;
*)
exit 1 exit 1
;;
esac esac

View File

@@ -16,7 +16,8 @@ fi
shopt -s nullglob shopt -s nullglob
{ for path in ${PATH//:/$'\n'}; do {
for path in ${PATH//:/$'\n'}; do
for command in "${path}/tmuxifier-"*; do for command in "${path}/tmuxifier-"*; do
command="${command##*tmuxifier-}" command="${command##*tmuxifier-}"
echo "$command" echo "$command"

View File

@@ -7,7 +7,9 @@ source "$TMUXIFIER/lib/util.sh"
# Provide tmuxifier help # Provide tmuxifier help
if calling-help "$@"; then if calling-help "$@"; then
echo "usage: tmuxifier completion <command> echo "usage: tmuxifier completions <command>
Aliases: completion
Print a list of available completions for specified command." Print a list of available completions for specified command."
exit exit
@@ -20,15 +22,15 @@ if calling-complete "$@"; then
fi fi
has-completions() { has-completions() {
grep -i "^# Provide tmuxifier completions" "$1" >/dev/null grep -i "^# Provide tmuxifier completions" "$1" > /dev/null
} }
if [ -z "$1" ]; then if [ -z "$1" ]; then
echo "$(tmuxifier-help completions $@)" >&2 tmuxifier-help completions "$@" >&2
exit 1 exit 1
fi fi
! command_path="$(tmuxifier-resolve-command-path "$1")" command_path="$(tmuxifier-resolve-command-path "$1")" || true
if [ -n "$command_path" ] && has-completions "$command_path"; then if [ -n "$command_path" ] && has-completions "$command_path"; then
shift shift

View File

@@ -14,8 +14,8 @@ Outputs the name of the current Tmux session."
fi fi
if [ -n "$TMUX" ]; then if [ -n "$TMUX" ]; then
for item in $(tmuxifier-tmux list-pane -F "#{session_name}");do for item in $(tmuxifier-tmux list-pane -F "#{session_name}"); do
echo $item echo "$item"
exit 0 exit 0
done done
fi fi

View File

@@ -22,7 +22,7 @@ if calling-complete "$@"; then
fi fi
if [ -z "$1" ]; then if [ -z "$1" ]; then
echo "$(tmuxifier-help edit-session $@)" >&2 tmuxifier-help edit-session "$@" >&2
exit 1 exit 1
fi fi

View File

@@ -22,7 +22,7 @@ if calling-complete "$@"; then
fi fi
if [ -z "$1" ]; then if [ -z "$1" ]; then
echo "$(tmuxifier-help edit-window $@)" >&2 tmuxifier-help edit-window "$@" >&2
exit 1 exit 1
fi fi

View File

@@ -18,7 +18,7 @@ if calling-complete "$@"; then
fi fi
has-help() { has-help() {
grep -i "^# Provide tmuxifier help" "$1" >/dev/null grep -i "^# Provide tmuxifier help" "$1" > /dev/null
} }
if [ -z "$1" ]; then if [ -z "$1" ]; then
@@ -43,7 +43,7 @@ See 'tmuxifier help <command>' for information on a specific command."
exit exit
fi fi
! command_path="$(tmuxifier-resolve-command-path "$1")" command_path="$(tmuxifier-resolve-command-path "$1")" || true
if [ -z "$command_path" ]; then if [ -z "$command_path" ]; then
echo "tmuxifier: no such command '$1'" >&2 echo "tmuxifier: no such command '$1'" >&2

View File

@@ -2,6 +2,9 @@
set -e set -e
[ -n "$TMUXIFIER_DEBUG" ] && set -x [ -n "$TMUXIFIER_DEBUG" ] && set -x
# Load internal utility functions.
source "$TMUXIFIER/lib/util.sh"
# Set shell to first argument that is not "-", "-h" or "--help". # Set shell to first argument that is not "-", "-h" or "--help".
for arg in "$@"; do for arg in "$@"; do
if [ "$arg" != "-" ] && [ "$arg" != "-h" ] && [ "$arg" != "--help" ]; then if [ "$arg" != "-" ] && [ "$arg" != "-h" ] && [ "$arg" != "--help" ]; then
@@ -14,46 +17,46 @@ if [ -z "$shell" ]; then
fi fi
case "$shell" in case "$shell" in
bash ) bash)
profile='~/.bash_profile' profile='.bash_profile'
;; ;;
zsh ) zsh)
profile='~/.zshrc' profile='.zshrc'
;; ;;
ksh ) ksh)
profile='~/.profile' profile='.profile'
;; ;;
csh ) csh)
profile='~/.cshrc' profile='.cshrc'
;; ;;
tcsh ) tcsh)
profile='~/.tcshrc' profile='.tcshrc'
;; ;;
fish ) fish)
profile='~/.config/fish/config.fish' profile='.config/fish/config.fish'
;; ;;
* ) *)
profile='shell init file' profile='shell init file'
;; ;;
esac esac
# Provide tmuxifier help # Provide tmuxifier help
if [[ " $@ " == *" --help "* ]]; then if calling-help "$@"; then
echo "usage: tmuxifier init - echo "usage: tmuxifier init -
Load Tmuxifier by adding the following to your ${profile}: Load Tmuxifier by adding the following to your ~/${profile}:
" "
case "$shell" in case "$shell" in
csh | tcsh ) csh | tcsh)
echo " eval \`tmuxifier init -\` echo " eval \`tmuxifier init -\`
" "
;; ;;
fish ) fish)
echo " eval (tmuxifier init -) echo " eval (tmuxifier init -)
" "
;; ;;
* ) *)
echo " eval \"\$(tmuxifier init -)\" echo " eval \"\$(tmuxifier init -)\"
" "
;; ;;
@@ -64,26 +67,26 @@ Load Tmuxifier by adding the following to your ${profile}:
fi fi
# Print help if "-" argument is not given # Print help if "-" argument is not given
if [[ " $@ " != *" - "* ]]; then if [[ " $* " != *" - "* ]]; then
echo "$(tmuxifier-help init $@)" >&2 tmuxifier-help init "$@" >&2
exit 1 exit 1
fi fi
case "$shell" in case "$shell" in
csh | tcsh ) csh | tcsh)
echo "setenv TMUXIFIER \"$TMUXIFIER\";" echo "setenv TMUXIFIER \"$TMUXIFIER\";"
echo "source \"\$TMUXIFIER/init.tcsh\";" echo "source \"\$TMUXIFIER/init.tcsh\";"
;; ;;
fish ) fish)
echo "set -gx TMUXIFIER \"$TMUXIFIER\";" echo "set -gx TMUXIFIER \"$TMUXIFIER\";"
# fish shell 2.0.0 does not have the source alias # fish shell 2.0.0 does not have the source alias
if [[ $(fish --version 2>&1 | awk -F'version ' '{print $2}') = '2.0.0' ]]; then if [[ $(fish --version 2>&1 | awk -F'version ' '{print $2}') = '2.0.0' ]]; then
echo ". \"\$TMUXIFIER/init.fish\";" echo ". \"\$TMUXIFIER/init.fish\";"
else else
echo "source \"\$TMUXIFIER/init.fish\";" echo "source \"\$TMUXIFIER/init.fish\";"
fi fi
;; ;;
* ) *)
echo "export TMUXIFIER=\"$TMUXIFIER\";" echo "export TMUXIFIER=\"$TMUXIFIER\";"
echo "source \"\$TMUXIFIER/init.sh\";" echo "source \"\$TMUXIFIER/init.sh\";"
;; ;;

View File

@@ -30,7 +30,7 @@ if calling-complete "$@"; then
fi fi
if [ -z "$1" ]; then if [ -z "$1" ]; then
echo "$(tmuxifier-help load-session $@)" >&2 tmuxifier-help load-session "$@" >&2
exit 1 exit 1
fi fi

View File

@@ -26,14 +26,14 @@ if calling-complete "$@"; then
fi fi
if [ -z "$1" ]; then if [ -z "$1" ]; then
echo "$(tmuxifier-help load-window $@)" >&2 tmuxifier-help load-window "$@" >&2
exit 1 exit 1
fi fi
# Load runtime functions. # Load runtime functions.
source "$TMUXIFIER/lib/runtime.sh" source "$TMUXIFIER/lib/runtime.sh"
if [ ! -z $TMUX ]; then if [ -n "$TMUX" ]; then
session="$(tmuxifier-current-session)" session="$(tmuxifier-current-session)"
load_window "$1" load_window "$1"
else else

View File

@@ -22,7 +22,7 @@ if calling-complete "$@"; then
fi fi
if [ -z "$1" ]; then if [ -z "$1" ]; then
echo "$(tmuxifier-help new-session $@)" >&2 tmuxifier-help new-session "$@" >&2
exit 1 exit 1
fi fi

View File

@@ -22,7 +22,7 @@ if calling-complete "$@"; then
fi fi
if [ -z "$1" ]; then if [ -z "$1" ]; then
echo "$(tmuxifier-help new-window $@)" >&2 tmuxifier-help new-window "$@" >&2
exit 1 exit 1
fi fi

View File

@@ -14,11 +14,11 @@ Outputs the absolute path to the given command or command alias."
fi fi
if [ -n "$1" ]; then if [ -n "$1" ]; then
! command_path="$(command -v "tmuxifier-$1")" command_path="$(command -v "tmuxifier-$1")" || true
if [ -z "$command_path" ]; then if [ -z "$command_path" ]; then
resolved="$(tmuxifier-alias "$1")" resolved="$(tmuxifier-alias "$1")"
if [ -n "$resolved" ]; then if [ -n "$resolved" ]; then
! command_path="$(command -v "tmuxifier-$resolved")" command_path="$(command -v "tmuxifier-$resolved")" || true
fi fi
fi fi
fi fi

View File

@@ -2,4 +2,5 @@
set -e set -e
[ -n "$TMUXIFIER_DEBUG" ] && set -x [ -n "$TMUXIFIER_DEBUG" ] && set -x
# shellcheck disable=SC2086
tmux $TMUXIFIER_TMUX_OPTS "$@" tmux $TMUXIFIER_TMUX_OPTS "$@"

View File

@@ -19,16 +19,17 @@ fi
# The vercomp() function is shamelessly ripped/borrowed from the following # The vercomp() function is shamelessly ripped/borrowed from the following
# StackOverflow answer: http://stackoverflow.com/a/4025065/42146 # StackOverflow answer: http://stackoverflow.com/a/4025065/42146
vercomp () { vercomp() {
if [[ $1 == $2 ]]; then return 0; fi if [[ "$1" == "$2" ]]; then return 0; fi
local IFS=. local IFS=.
# shellcheck disable=SC2206
local i ver1=($1) ver2=($2) local i ver1=($1) ver2=($2)
# fill empty fields in ver1 with zeros # fill empty fields in ver1 with zeros
for ((i=${#ver1[@]}; i<${#ver2[@]}; i++)); do ver1[i]=0; done for ((i = ${#ver1[@]}; i < ${#ver2[@]}; i++)); do ver1[i]=0; done
for ((i=0; i<${#ver1[@]}; i++)); do for ((i = 0; i < ${#ver1[@]}; i++)); do
# fill empty fields in ver2 with zeros # fill empty fields in ver2 with zeros
if [[ -z ${ver2[i]} ]]; then ver2[i]=0; fi if [[ -z ${ver2[i]} ]]; then ver2[i]=0; fi
@@ -63,8 +64,8 @@ else
vercomp "$version" "$1" vercomp "$version" "$1"
case $? in case $? in
0) echo '=';; 0) echo '=' ;;
1) echo '>';; 1) echo '>' ;;
2) echo '<';; 2) echo '<' ;;
esac esac
fi fi

View File

@@ -11,21 +11,25 @@ TMUXIFER="/path/to/tmuxifier"
# When TMUXIFIER_LAYOUT_PATH is not set. # When TMUXIFIER_LAYOUT_PATH is not set.
source "${root}/lib/env.sh" source "${root}/lib/env.sh"
# shellcheck disable=SC2016
assert 'echo $TMUXIFIER_LAYOUT_PATH' "${TMUXIFIER}/layouts" assert 'echo $TMUXIFIER_LAYOUT_PATH' "${TMUXIFIER}/layouts"
# When TMUXIFIER_LAYOUT_PATH is set and has a trailing slash. # When TMUXIFIER_LAYOUT_PATH is set and has a trailing slash.
TMUXIFIER_LAYOUT_PATH="/path/to/layouts/" TMUXIFIER_LAYOUT_PATH="/path/to/layouts/"
source "${root}/lib/env.sh" source "${root}/lib/env.sh"
# shellcheck disable=SC2016
assert 'echo $TMUXIFIER_LAYOUT_PATH' "/path/to/layouts" assert 'echo $TMUXIFIER_LAYOUT_PATH' "/path/to/layouts"
unset TMUXIFIER_LAYOUT_PATH unset TMUXIFIER_LAYOUT_PATH
# When TMUXIFIER_LAYOUT_PATH is set and does not have a trailing slash. # When TMUXIFIER_LAYOUT_PATH is set and does not have a trailing slash.
TMUXIFIER_LAYOUT_PATH="/path/to/layouts" TMUXIFIER_LAYOUT_PATH="/path/to/layouts"
source "${root}/lib/env.sh" source "${root}/lib/env.sh"
# shellcheck disable=SC2016
assert 'echo $TMUXIFIER_LAYOUT_PATH' "/path/to/layouts" assert 'echo $TMUXIFIER_LAYOUT_PATH' "/path/to/layouts"
unset TMUXIFIER_LAYOUT_PATH unset TMUXIFIER_LAYOUT_PATH
# Tear down. # Tear down.
# shellcheck disable=SC2034
TMUXIFER="$realTMUXIFIER" TMUXIFER="$realTMUXIFIER"
unset realTMUXIFIER unset realTMUXIFIER

View File

@@ -19,6 +19,12 @@ assert '__expand_path "/path/to/file"' "/path/to/file"
# When given a path containing spaces, it returns path correctly. # When given a path containing spaces, it returns path correctly.
assert '__expand_path "~/Path To/File"' "${HOME}/Path To/File" assert '__expand_path "~/Path To/File"' "${HOME}/Path To/File"
# When given a relative path, it returns path as is.
assert '__expand_path "foo/bar"' "foo/bar"
# When given a relative parent path, it returns path as is.
assert '__expand_path "../foo/bar"' "../foo/bar"
# Tear down. # Tear down.
HOME="$realHOME" HOME="$realHOME"
unset realHOME unset realHOME

View File

@@ -7,25 +7,25 @@ source "${root}/lib/layout-helpers.sh"
# #
# When current window is the first and only window. # When current window is the first and only window.
create-test-session create-test-session "test"
assert "__get_current_window_index" "0" assert "__get_current_window_index" "0"
kill-test-session kill-test-session "test"
# When creating a second window. # When creating a second window.
create-test-session create-test-session "test"
test-socket-tmux new-window -t "$session:1" test-socket-tmux new-window -t "$session:1"
assert "__get_current_window_index" "1" assert "__get_current_window_index" "1"
kill-test-session kill-test-session "test"
# When creating a second window and then switching back to the first window. # When creating a second window and then switching back to the first window.
create-test-session create-test-session "test"
test-socket-tmux new-window -t "$session:1" test-socket-tmux new-window -t "$session:1"
test-socket-tmux select-window -t "$session:0" test-socket-tmux select-window -t "$session:0"
assert "__get_current_window_index" "0" assert "__get_current_window_index" "0"
kill-test-session kill-test-session "test"
# When creating multiples windows and switching between them randomly. # When creating multiples windows and switching between them randomly.
create-test-session create-test-session "test"
assert "__get_current_window_index" "0" assert "__get_current_window_index" "0"
test-socket-tmux new-window -t "$session:1" test-socket-tmux new-window -t "$session:1"
assert "__get_current_window_index" "1" assert "__get_current_window_index" "1"
@@ -41,8 +41,7 @@ test-socket-tmux select-window -t "$session:3"
assert "__get_current_window_index" "3" assert "__get_current_window_index" "3"
test-socket-tmux select-window -t "$session:2" test-socket-tmux select-window -t "$session:2"
assert "__get_current_window_index" "2" assert "__get_current_window_index" "2"
kill-test-session kill-test-session "test"
# End of tests. # End of tests.
assert_end "__get_current_window_index()" assert_end "__get_current_window_index()"

View File

@@ -7,24 +7,23 @@ source "${root}/lib/layout-helpers.sh"
# #
# When first window has a index of 0. # When first window has a index of 0.
create-test-session create-test-session "test"
assert "__get_first_window_index" "0" assert "__get_first_window_index" "0"
kill-test-session kill-test-session "test"
# When first window has a index of 1. # When first window has a index of 1.
create-test-session create-test-session "test"
test-socket-tmux new-window -t "$session:1" test-socket-tmux new-window -t "$session:1"
test-socket-tmux kill-window -t "$session:0" test-socket-tmux kill-window -t "$session:0"
assert "__get_first_window_index" "1" assert "__get_first_window_index" "1"
kill-test-session kill-test-session "test"
# When first window has a index of 2. # When first window has a index of 2.
create-test-session create-test-session "test"
test-socket-tmux new-window -t "$session:2" test-socket-tmux new-window -t "$session:2"
test-socket-tmux kill-window -t "$session:0" test-socket-tmux kill-window -t "$session:0"
assert "__get_first_window_index" "2" assert "__get_first_window_index" "2"
kill-test-session kill-test-session "test"
# End of tests. # End of tests.
assert_end "__get_first_window_index()" assert_end "__get_first_window_index()"

View File

@@ -12,7 +12,6 @@ __go_to_window_or_session_path
assert "stub_called_times run_cmd" "0" assert "stub_called_times run_cmd" "0"
restore run_cmd restore run_cmd
# When only $window_root is set, runs cd to $window_root path. # When only $window_root is set, runs cd to $window_root path.
stub run_cmd stub run_cmd
window_root="/tmp" window_root="/tmp"
@@ -22,7 +21,6 @@ assert 'stub_called_with_times run_cmd clear' "1"
unset window_root unset window_root
restore run_cmd restore run_cmd
# When only $TMUXIFIER_SESSION_ROOT is set, runs cd to $TMUXIFIER_SESSION_ROOT # When only $TMUXIFIER_SESSION_ROOT is set, runs cd to $TMUXIFIER_SESSION_ROOT
# path. # path.
stub run_cmd stub run_cmd
@@ -33,7 +31,6 @@ assert 'stub_called_with_times run_cmd clear' "1"
unset TMUXIFIER_SESSION_ROOT unset TMUXIFIER_SESSION_ROOT
restore run_cmd restore run_cmd
# When only $session_root is set, runs cd to $session_root path. # When only $session_root is set, runs cd to $session_root path.
stub run_cmd stub run_cmd
session_root="/usr" session_root="/usr"
@@ -43,7 +40,6 @@ assert 'stub_called_with_times run_cmd clear' "1"
unset session_root unset session_root
restore run_cmd restore run_cmd
# When $window_root and $session_root are set, runs cd to $window_root path. # When $window_root and $session_root are set, runs cd to $window_root path.
stub run_cmd stub run_cmd
window_root="/tmp" window_root="/tmp"
@@ -55,7 +51,6 @@ unset window_root
unset session_root unset session_root
restore run_cmd restore run_cmd
# When $TMUXIFIER_SESSION_ROOT and $session_root are set, runs cd to # When $TMUXIFIER_SESSION_ROOT and $session_root are set, runs cd to
# $TMUXIFIER_SESSION_ROOT path. # $TMUXIFIER_SESSION_ROOT path.
stub run_cmd stub run_cmd
@@ -68,7 +63,6 @@ unset TMUXIFIER_SESSION_ROOT
unset session_root unset session_root
restore run_cmd restore run_cmd
# When $window_root, $TMUXIFIER_SESSION_ROOT, and $session_root are set, runs # When $window_root, $TMUXIFIER_SESSION_ROOT, and $session_root are set, runs
# cd to $window_root path. # cd to $window_root path.
stub run_cmd stub run_cmd
@@ -83,6 +77,5 @@ unset TMUXIFIER_SESSION_ROOT
unset session_root unset session_root
restore run_cmd restore run_cmd
# End of tests. # End of tests.
assert_end "__go_to_window_or_session_path()" assert_end "__go_to_window_or_session_path()"

View File

@@ -7,29 +7,29 @@ source "${root}/lib/layout-helpers.sh"
# #
# When called without arguments, creates new window. # When called without arguments, creates new window.
create-test-session create-test-session "test"
stub __go_to_window_or_session_path stub __go_to_window_or_session_path
assert "test-socket-window-count" "1" assert "test-socket-window-count" "1"
new_window new_window
assert "test-socket-window-count" "2" assert "test-socket-window-count" "2"
assert "stub_called_times __go_to_window_or_session_path" "1" assert "stub_called_times __go_to_window_or_session_path" "1"
restore __go_to_window_or_session_path restore __go_to_window_or_session_path
kill-test-session kill-test-session "test"
# When called with name argument, creates new window with specified name. # When called with name argument, creates new window with specified name.
create-test-session create-test-session "test"
stub __go_to_window_or_session_path stub __go_to_window_or_session_path
assert "test-socket-window-count yippieezzz" "0" assert "test-socket-window-count yippieezzz" "0"
new_window "yippieezzz" new_window "yippieezzz"
assert "test-socket-window-count" "2" assert "test-socket-window-count" "2"
assert "test-socket-window-count yippieezzz" "1" assert "test-socket-window-count yippieezzz" "1"
restore __go_to_window_or_session_path restore __go_to_window_or_session_path
kill-test-session kill-test-session "test"
# When called with name and command argument, creates new window with # When called with name and command argument, creates new window with
# specified name and executes given command. # specified name and executes given command.
rm "/tmp/tmuxifier-new_window-test" &> /dev/null rm "/tmp/tmuxifier-new_window-test" &> /dev/null
create-test-session create-test-session "test"
stub __go_to_window_or_session_path stub __go_to_window_or_session_path
new_window "foobardoo" "touch /tmp/tmuxifier-new_window-test; bash" new_window "foobardoo" "touch /tmp/tmuxifier-new_window-test; bash"
assert "test-socket-window-count" "2" assert "test-socket-window-count" "2"
@@ -37,13 +37,13 @@ assert "test-socket-window-count foobardoo" "1"
sleep 0.1 # attempt to avoid timing issue causing flicker sleep 0.1 # attempt to avoid timing issue causing flicker
assert_raises 'test -f "/tmp/tmuxifier-new_window-test"' 0 assert_raises 'test -f "/tmp/tmuxifier-new_window-test"' 0
restore __go_to_window_or_session_path restore __go_to_window_or_session_path
kill-test-session kill-test-session "test"
rm "/tmp/tmuxifier-new_window-test" &> /dev/null rm "/tmp/tmuxifier-new_window-test" &> /dev/null
# When called ensure it sets the $window variable to the index of the newly # When called ensure it sets the $window variable to the index of the newly
# created window. # created window.
unset window unset window
create-test-session create-test-session "test"
stub __go_to_window_or_session_path stub __go_to_window_or_session_path
new_window "foo" new_window "foo"
assert "echo $window" "1" assert "echo $window" "1"
@@ -52,7 +52,7 @@ assert "echo $window" "2"
new_window "bar" new_window "bar"
assert "echo $window" "3" assert "echo $window" "3"
restore __go_to_window_or_session_path restore __go_to_window_or_session_path
kill-test-session kill-test-session "test"
unset window unset window
# End of tests. # End of tests.

View File

@@ -8,11 +8,11 @@ source "${root}/lib/layout-helpers.sh"
window_list() { window_list() {
test-socket-tmux list-windows -t "$session:" \ test-socket-tmux list-windows -t "$session:" \
-F "#{window_active}:#{window_index}" 2>/dev/null -F "#{window_active}:#{window_index}" 2> /dev/null
} }
# Selects given window when passed a window index # Selects given window when passed a window index
create-test-session create-test-session "test"
test-socket-tmux new-window -t "$session:1" test-socket-tmux new-window -t "$session:1"
test-socket-tmux new-window -t "$session:2" test-socket-tmux new-window -t "$session:2"
select_window 0 select_window 0
@@ -21,23 +21,22 @@ select_window 1
assert "window_list | grep '^1:'" "1:1" assert "window_list | grep '^1:'" "1:1"
select_window 2 select_window 2
assert "window_list | grep '^1:'" "1:2" assert "window_list | grep '^1:'" "1:2"
kill-test-session kill-test-session "test"
# Selects given window when passed a window name # Selects given window when passed a window name
create-test-session create-test-session "test"
test-socket-tmux new-window -t "$session:1" -n "foo" test-socket-tmux new-window -t "$session:1" -n "foo"
test-socket-tmux new-window -t "$session:2" -n "bar" test-socket-tmux new-window -t "$session:2" -n "bar"
select_window foo select_window foo
assert "window_list | grep '^1:'" "1:1" assert "window_list | grep '^1:'" "1:1"
select_window bar select_window bar
assert "window_list | grep '^1:'" "1:2" assert "window_list | grep '^1:'" "1:2"
kill-test-session kill-test-session "test"
# When called ensure it sets the $window variable to the index of the newly # When called ensure it sets the $window variable to the index of the newly
# created window. # created window.
unset window unset window
create-test-session create-test-session "test"
test-socket-tmux new-window -t "$session:1" -n "foo" test-socket-tmux new-window -t "$session:1" -n "foo"
test-socket-tmux new-window -t "$session:2" -n "bar" test-socket-tmux new-window -t "$session:2" -n "bar"
select_window "foo" select_window "foo"
@@ -48,7 +47,7 @@ select_window 1
assert "echo $window" "1" assert "echo $window" "1"
select_window 2 select_window 2
assert "echo $window" "2" assert "echo $window" "2"
kill-test-session kill-test-session "test"
unset window unset window
# End of tests. # End of tests.

View File

@@ -8,9 +8,11 @@ source "../test-helper.sh"
source "${root}/lib/runtime.sh" source "${root}/lib/runtime.sh"
# We assume env.sh has been sourced if $TMUXIFIER_LAYOUT_PATH has been set. # We assume env.sh has been sourced if $TMUXIFIER_LAYOUT_PATH has been set.
# shellcheck disable=SC2016
assert 'echo $TMUXIFIER_LAYOUT_PATH' "${TMUXIFIER}/layouts" assert 'echo $TMUXIFIER_LAYOUT_PATH' "${TMUXIFIER}/layouts"
# We ensure $session_root is set to $HOME by default. # We ensure $session_root is set to $HOME by default.
# shellcheck disable=SC2016
assert 'echo $session_root' "$HOME" assert 'echo $session_root' "$HOME"
# We assume layout-helpers.sh has been sourced if a few of them are available. # We assume layout-helpers.sh has been sourced if a few of them are available.
@@ -18,6 +20,5 @@ for helper in new_window split_v split_h select_window select_pane; do
assert "type $helper | head -1" "$helper is a function" assert "type $helper | head -1" "$helper is a function"
done done
# End of tests. # End of tests.
assert_end "runtime.sh" assert_end "runtime.sh"

View File

@@ -34,7 +34,6 @@ assert_raises 'calling-help welcome-home' 1
# End of tests. # End of tests.
assert_end "calling-help()" assert_end "calling-help()"
# #
# calling-complete() tests. # calling-complete() tests.
# #

View File

@@ -5,8 +5,9 @@ resolve_link() {
} }
abs_dirname() { abs_dirname() {
local cwd="$(pwd)" local cwd
local path="$1" local path="$1"
cwd="$(pwd)"
while [ -n "$path" ]; do while [ -n "$path" ]; do
cd "${path%/*}" cd "${path%/*}"
@@ -47,14 +48,13 @@ unset TMUXIFIER_NO_COMPLETE
source "${testroot}/assert.sh" source "${testroot}/assert.sh"
source "${testroot}/stub.sh" source "${testroot}/stub.sh"
# #
# Test Helpers # Test Helpers
# #
test-socket-tmux() { test-socket-tmux() {
export TMUXIFIER_TMUX_OPTS="-L tmuxifier-tests" export TMUXIFIER_TMUX_OPTS="-L tmuxifier-tests"
"$TMUX_BIN" $TMUXIFIER_TMUX_OPTS $@ "$TMUX_BIN" $TMUXIFIER_TMUX_OPTS "$@"
} }
create-test-session() { create-test-session() {
@@ -78,9 +78,10 @@ kill-test-server() {
} }
test-socket-window-count() { test-socket-window-count() {
local list="$(test-socket-tmux list-windows)" local list
list="$(test-socket-tmux list-windows)"
if [ -n "$1" ]; then if [ -n "$1" ]; then
echo "$list" | grep $1 | wc -l | awk '{print $1}' echo "$list" | grep "$1" -c | awk '{print $1}'
else else
echo "$list" | wc -l | awk '{print $1}' echo "$list" | wc -l | awk '{print $1}'
fi fi