mirror of
https://github.com/jimeh/tmuxifier.git
synced 2026-02-19 09:56:39 +00:00
Compare commits
33 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 8987dd4492 | |||
| 9049818b25 | |||
| 47ef3bd857 | |||
| a9ca566c28 | |||
| 87e31a03c9 | |||
| 7f3ec1cd5b | |||
| 9baadfbb1e | |||
| 2adc885bb8 | |||
| 7cc0fa2d0e | |||
|
|
e41b15c515 | ||
|
|
690a4465b0 | ||
|
|
9bcfbd3428 | ||
| 7aeeaf31d1 | |||
| ca6dcfaaf2 | |||
|
|
fdbb1704e0 | ||
|
|
499c5abd83 | ||
| 3563c3d975 | |||
| 3bfbc50918 | |||
|
|
3a8a43ccdc | ||
|
|
a9a87992df | ||
| 5f4dd92d7f | |||
|
|
bdaa272ca5 | ||
| dce4fb3ad2 | |||
|
|
6f8773133d | ||
| 92d188f9f5 | |||
| 8d1751daea | |||
| dafa938923 | |||
| 595269dd6a | |||
|
|
3c37e18987 | ||
| b801aade99 | |||
| a888efe6d0 | |||
| 4a4f62fcf2 | |||
| 41da75ad39 |
@@ -4,10 +4,11 @@ env:
|
|||||||
- TMUX_VERSION="1.7"
|
- TMUX_VERSION="1.7"
|
||||||
- TMUX_VERSION="1.8"
|
- TMUX_VERSION="1.8"
|
||||||
- TMUX_VERSION="1.9a"
|
- TMUX_VERSION="1.9a"
|
||||||
|
- TMUX_VERSION="2.0"
|
||||||
before_install:
|
before_install:
|
||||||
- sudo apt-get update
|
- sudo apt-get update
|
||||||
- sudo apt-get install -y bc build-essential libevent-dev libncurses5-dev
|
- sudo apt-get install -y bc build-essential libevent-dev libncurses5-dev
|
||||||
- wget http://downloads.sourceforge.net/tmux/tmux-${TMUX_VERSION}.tar.gz
|
- wget https://github.com/tmux/tmux/releases/download/${TMUX_VERSION}/tmux-${TMUX_VERSION}.tar.gz
|
||||||
- tar -zxf tmux-${TMUX_VERSION}.tar.gz
|
- tar -zxf tmux-${TMUX_VERSION}.tar.gz
|
||||||
- cd tmux-${TMUX_VERSION}
|
- cd tmux-${TMUX_VERSION}
|
||||||
- ./configure && make && sudo make install
|
- ./configure && make && sudo make install
|
||||||
|
|||||||
18
README.md
18
README.md
@@ -105,7 +105,7 @@ __In fish:__
|
|||||||
And add the following to your `~/.config/fish/config.fish` or equivalent:
|
And add the following to your `~/.config/fish/config.fish` or equivalent:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
eval (tmuxifier init -)
|
eval (tmuxifier init - fish)
|
||||||
```
|
```
|
||||||
|
|
||||||
### Custom Tmux Arguments
|
### Custom Tmux Arguments
|
||||||
@@ -202,6 +202,22 @@ any reason you need to disable it, just set `$TMUXIFIER_NO_COMPLETE`.
|
|||||||
export TMUXIFIER_NO_COMPLETE=1
|
export TMUXIFIER_NO_COMPLETE=1
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Tips
|
||||||
|
|
||||||
|
### iTerm2 Integration
|
||||||
|
|
||||||
|
Tmuxifier supports iTerm2's [Tmux integration][]. It can be used in two ways:
|
||||||
|
|
||||||
|
- Passing `-CC` as a second argument to the `load-session` command. For
|
||||||
|
example:
|
||||||
|
|
||||||
|
tmuxifier load-session my-awesome-session -CC
|
||||||
|
|
||||||
|
- Setting the `TMUXIFIER_TMUX_ITERM_ATTACH` environment variable to `-CC`
|
||||||
|
before calling the `load-session` command.
|
||||||
|
|
||||||
|
[tmux integration]: https://gitlab.com/gnachman/iterm2/wikis/TmuxIntegration
|
||||||
|
|
||||||
## Inspiration
|
## Inspiration
|
||||||
|
|
||||||
- Tmuxifier is largely inspired by [Tmuxinator][].
|
- Tmuxifier is largely inspired by [Tmuxinator][].
|
||||||
|
|||||||
@@ -11,7 +11,10 @@ end
|
|||||||
# If `tmuxifier` is available, and `$TMUXIFIER_NO_COMPLETE` is not set, then
|
# If `tmuxifier` is available, and `$TMUXIFIER_NO_COMPLETE` is not set, then
|
||||||
# load Tmuxifier shell completion.
|
# load Tmuxifier shell completion.
|
||||||
if test -n (which tmuxifier); and test -z $TMUXIFIER_NO_COMPLETE
|
if test -n (which tmuxifier); and test -z $TMUXIFIER_NO_COMPLETE
|
||||||
source "$TMUXIFIER/completion/tmuxifier.fish"
|
# fish shell 2.0.0 does not have the source alias
|
||||||
|
if [ (fish --version 2>| awk -F'version ' '{print $2}') = '2.0.0' ];
|
||||||
|
. "$TMUXIFIER/completion/tmuxifier.fish"
|
||||||
|
else
|
||||||
|
source "$TMUXIFIER/completion/tmuxifier.fish"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -22,6 +22,10 @@ new_window() {
|
|||||||
if [ -n "$2" ]; then local command=("$2"); fi
|
if [ -n "$2" ]; then local command=("$2"); fi
|
||||||
|
|
||||||
tmuxifier-tmux new-window -t "$session:" "${winarg[@]}" "${command[@]}"
|
tmuxifier-tmux new-window -t "$session:" "${winarg[@]}" "${command[@]}"
|
||||||
|
|
||||||
|
# Disable renaming if a window name was given.
|
||||||
|
if [ -n "$1" ]; then tmuxifier-tmux set-option -t "$1" allow-rename off; fi
|
||||||
|
|
||||||
window="$(__get_current_window_index)"
|
window="$(__get_current_window_index)"
|
||||||
__go_to_window_or_session_path
|
__go_to_window_or_session_path
|
||||||
}
|
}
|
||||||
@@ -101,6 +105,44 @@ select_pane() {
|
|||||||
tmuxifier-tmux select-pane -t "$session:$window.$1"
|
tmuxifier-tmux select-pane -t "$session:$window.$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Balance windows vertically with the "even-vertical" layout.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: (optional) Window ID or name to operate on.
|
||||||
|
#
|
||||||
|
balance_windows_vertical() {
|
||||||
|
tmuxifier-tmux select-layout -t "$session:${1:-$window}" even-vertical
|
||||||
|
}
|
||||||
|
|
||||||
|
# Balance windows horizontally with the "even-horizontal" layout.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: (optional) Window ID or name to operate on.
|
||||||
|
#
|
||||||
|
balance_windows_horizontal() {
|
||||||
|
tmuxifier-tmux select-layout -t "$session:${1:-$window}" even-horizontal
|
||||||
|
}
|
||||||
|
|
||||||
|
# Turn on synchronize-panes in a window.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: (optional) Window ID or name to operate on.
|
||||||
|
#
|
||||||
|
synchronize_on() {
|
||||||
|
tmuxifier-tmux set-window-option -t "$session:${1:-$window}" \
|
||||||
|
synchronize-panes on
|
||||||
|
}
|
||||||
|
|
||||||
|
# Turn off synchronize-panes in a window.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: (optional) Window ID or name to operate on.
|
||||||
|
#
|
||||||
|
synchronize_off() {
|
||||||
|
tmuxifier-tmux set-window-option -t "$session:${1:-$window}" \
|
||||||
|
synchronize-panes off
|
||||||
|
}
|
||||||
|
|
||||||
# Send/paste keys to the currently active pane/window.
|
# Send/paste keys to the currently active pane/window.
|
||||||
#
|
#
|
||||||
# Arguments:
|
# Arguments:
|
||||||
@@ -185,31 +227,39 @@ load_window() {
|
|||||||
# - $2: (optional) Override default window name.
|
# - $2: (optional) Override default window name.
|
||||||
#
|
#
|
||||||
load_session() {
|
load_session() {
|
||||||
local file="$1"
|
local file
|
||||||
if [ ! -f "$file" ]; then
|
if [ "${1#*/}" = "$1" ]; then
|
||||||
file="$TMUXIFIER_LAYOUT_PATH/$1.session.sh"
|
# There's no slash in the path.
|
||||||
fi
|
if [ -f "$TMUXIFIER_LAYOUT_PATH/$1.session.sh" ] || [ ! -f "$1" ]; then
|
||||||
|
file="$TMUXIFIER_LAYOUT_PATH/$1.session.sh"
|
||||||
if [ -f "$file" ]; then
|
|
||||||
if [ $# -gt 1 ]; then
|
|
||||||
session="$2"
|
|
||||||
else
|
else
|
||||||
session="${1/%.session.sh}"
|
# bash's 'source' requires an slash in the filename to not use $PATH.
|
||||||
session="${session/%.sh}"
|
file="./$1"
|
||||||
fi
|
|
||||||
|
|
||||||
set_default_path=true
|
|
||||||
source "$file"
|
|
||||||
session=
|
|
||||||
|
|
||||||
# Reset `$session_root`.
|
|
||||||
if [[ "$session_root" != "$HOME" ]]; then
|
|
||||||
session_root="$HOME"
|
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
|
file="$1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! [ -f "$file" ]; then
|
||||||
echo "\"$1\" session layout not found." >&2
|
echo "\"$1\" session layout not found." >&2
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ $# -gt 1 ]; then
|
||||||
|
session="$2"
|
||||||
|
else
|
||||||
|
session="${1/%.session.sh}"
|
||||||
|
session="${session/%.sh}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
set_default_path=true
|
||||||
|
source "$file"
|
||||||
|
session=
|
||||||
|
|
||||||
|
# Reset `$session_root`.
|
||||||
|
if [[ "$session_root" != "$HOME" ]]; then
|
||||||
|
session_root="$HOME"
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Create a new session, returning 0 on success, 1 on failure.
|
# Create a new session, returning 0 on success, 1 on failure.
|
||||||
@@ -233,7 +283,7 @@ initialize_session() {
|
|||||||
tmuxifier-tmux start-server
|
tmuxifier-tmux start-server
|
||||||
|
|
||||||
# Check if the named session already exists.
|
# Check if the named session already exists.
|
||||||
if tmuxifier-tmux has-session -t "$session:" 2>/dev/null; then
|
if tmuxifier-tmux list-sessions | grep -q "^$session:"; then
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -261,6 +311,11 @@ initialize_session() {
|
|||||||
-d -s "$session" "${session_args[@]}"
|
-d -s "$session" "${session_args[@]}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if $set_default_path && [[ "$session_root" != "$HOME" ]]; then
|
||||||
|
tmuxifier-tmux setenv -t "$session:" \
|
||||||
|
TMUXIFIER_SESSION_ROOT "$session_root"
|
||||||
|
fi
|
||||||
|
|
||||||
# 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.
|
||||||
@@ -323,16 +378,27 @@ __get_current_window_index() {
|
|||||||
|
|
||||||
__go_to_session() {
|
__go_to_session() {
|
||||||
if [ -z "$TMUX" ]; then
|
if [ -z "$TMUX" ]; then
|
||||||
tmuxifier-tmux -u attach-session -t "$session:"
|
tmuxifier-tmux $TMUXIFIER_TMUX_ITERM_ATTACH -u \
|
||||||
|
attach-session -t "$session:"
|
||||||
else
|
else
|
||||||
tmuxifier-tmux -u switch-client -t "$session:"
|
tmuxifier-tmux -u switch-client -t "$session:"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
__go_to_window_or_session_path() {
|
__go_to_window_or_session_path() {
|
||||||
local window_or_session_root=${window_root-$session_root}
|
local target_path
|
||||||
if [ -n "$window_or_session_root" ]; then
|
|
||||||
run_cmd "cd \"$window_or_session_root\""
|
if [ -n "$window_root" ]; then
|
||||||
|
target_path="$window_root"
|
||||||
|
elif [ -n "$TMUXIFIER_SESSION_ROOT" ]; then
|
||||||
|
target_path="$TMUXIFIER_SESSION_ROOT"
|
||||||
|
elif [ -n "$session_root" ]; then
|
||||||
|
target_path="$session_root"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# local window_or_session_root=${window_root-$session_root}
|
||||||
|
if [ -n "$target_path" ]; then
|
||||||
|
run_cmd "cd \"$target_path\""
|
||||||
run_cmd "clear"
|
run_cmd "clear"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -76,7 +76,12 @@ case "$shell" in
|
|||||||
;;
|
;;
|
||||||
fish )
|
fish )
|
||||||
echo "set -gx TMUXIFIER \"$TMUXIFIER\";"
|
echo "set -gx TMUXIFIER \"$TMUXIFIER\";"
|
||||||
echo "source \"\$TMUXIFIER/init.fish\";"
|
# 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
|
||||||
|
echo ". \"\$TMUXIFIER/init.fish\";"
|
||||||
|
else
|
||||||
|
echo "source \"\$TMUXIFIER/init.fish\";"
|
||||||
|
fi
|
||||||
;;
|
;;
|
||||||
* )
|
* )
|
||||||
echo "export TMUXIFIER=\"$TMUXIFIER\";"
|
echo "export TMUXIFIER=\"$TMUXIFIER\";"
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ List all session layouts."
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
list=$(find -L "$TMUXIFIER_LAYOUT_PATH" -name "*.session.sh")
|
list=$(find -L "$TMUXIFIER_LAYOUT_PATH" -name "*.session.sh" | sort)
|
||||||
for file in $list; do
|
for file in $list; do
|
||||||
file=${file/$TMUXIFIER_LAYOUT_PATH\//}
|
file=${file/$TMUXIFIER_LAYOUT_PATH\//}
|
||||||
echo "${file/.session.sh/}"
|
echo "${file/.session.sh/}"
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ List all window layouts."
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
list=$(find -L "$TMUXIFIER_LAYOUT_PATH" -name "*.window.sh")
|
list=$(find -L "$TMUXIFIER_LAYOUT_PATH" -name "*.window.sh" | sort)
|
||||||
for file in $list; do
|
for file in $list; do
|
||||||
file=${file/$TMUXIFIER_LAYOUT_PATH\//}
|
file=${file/$TMUXIFIER_LAYOUT_PATH\//}
|
||||||
echo "${file/.window.sh/}"
|
echo "${file/.window.sh/}"
|
||||||
|
|||||||
@@ -7,12 +7,19 @@ source "$TMUXIFIER/lib/util.sh"
|
|||||||
|
|
||||||
# Provide tmuxifier help
|
# Provide tmuxifier help
|
||||||
if calling-help "$@"; then
|
if calling-help "$@"; then
|
||||||
echo "usage: tmuxifier load-session <layout_name | file_path>
|
echo "usage: tmuxifier load-session <layout_name | file_path> [<iterm mode>]
|
||||||
|
|
||||||
Aliases: session, ses, s
|
Aliases: session, ses, s
|
||||||
|
|
||||||
Create a session using the session layout, unless the session already exists
|
Create a session using the session layout, unless the session already exists
|
||||||
in which case, we simply attach/switch to the existing one."
|
in which case, we simply attach/switch to the existing one.
|
||||||
|
|
||||||
|
Arguments:
|
||||||
|
<layout_name | file_path> - Name of a session layout stored in the layouts
|
||||||
|
directory, or path to a session layout file.
|
||||||
|
<iterm mode> - When given as \"-CC\" tmux will be called with
|
||||||
|
the -CC argument enabling iTerm2 integration.
|
||||||
|
More info: http://bit.ly/1yDbMlm"
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -30,5 +37,9 @@ fi
|
|||||||
# Load runtime functions.
|
# Load runtime functions.
|
||||||
source "$TMUXIFIER/lib/runtime.sh"
|
source "$TMUXIFIER/lib/runtime.sh"
|
||||||
|
|
||||||
|
if [ "$2" == "-CC" ]; then
|
||||||
|
export TMUXIFIER_TMUX_ITERM_ATTACH="-CC"
|
||||||
|
fi
|
||||||
|
|
||||||
# Load session file.
|
# Load session file.
|
||||||
load_session "$1"
|
load_session "$1"
|
||||||
|
|||||||
@@ -11,7 +11,11 @@ if calling-help "$@"; then
|
|||||||
|
|
||||||
Aliases: window, win, w
|
Aliases: window, win, w
|
||||||
|
|
||||||
Create a new window using the specified window layout in the current session."
|
Create a new window using the specified window layout in the current session.
|
||||||
|
|
||||||
|
Arguments:
|
||||||
|
<layout_name | file_path> - Name of a window layout stored in the layouts
|
||||||
|
directory, or path to a window layout file."
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
@@ -7,11 +7,11 @@ source "$TMUXIFIER/lib/util.sh"
|
|||||||
|
|
||||||
# Provide tmuxifier help
|
# Provide tmuxifier help
|
||||||
if calling-help "$@"; then
|
if calling-help "$@"; then
|
||||||
echo "usage: tmuxifier tmux-version [target-version]
|
echo "usage: tmuxifier tmux-version [<target-version>]
|
||||||
|
|
||||||
Outputs current Tmux version. If given optional target-version it outputs one
|
Outputs current Tmux version. If given optional target-version it outputs one
|
||||||
of three possible characters indicating if the current Tmux version number is
|
of three possible characters indicating if the current Tmux version number is
|
||||||
equal to, less than, or greater than the [target-version].
|
equal to, less than, or greater than the <target-version>.
|
||||||
|
|
||||||
The three possible outputs are \"=\", \"<\", and \">\"."
|
The three possible outputs are \"=\", \"<\", and \">\"."
|
||||||
exit
|
exit
|
||||||
@@ -44,7 +44,16 @@ vercomp () {
|
|||||||
version=$(tmux -V)
|
version=$(tmux -V)
|
||||||
version=${version/tmux /}
|
version=${version/tmux /}
|
||||||
|
|
||||||
if [ -n "$1" ]; then
|
if [ -z "$1" ]; then
|
||||||
|
echo "$version"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$version" == "master" ]; then
|
||||||
|
# When version string is "master", tmux was compiled from source, and we
|
||||||
|
# assume it's later than whatever the <target-version> is.
|
||||||
|
echo '>'
|
||||||
|
else
|
||||||
# Fix for "1.9a" version comparison, as vercomp() can only deal with
|
# Fix for "1.9a" version comparison, as vercomp() can only deal with
|
||||||
# purely numeric version numbers.
|
# purely numeric version numbers.
|
||||||
version=${version//+([a-zA-Z])/}
|
version=${version//+([a-zA-Z])/}
|
||||||
@@ -55,6 +64,4 @@ if [ -n "$1" ]; then
|
|||||||
1) echo '>';;
|
1) echo '>';;
|
||||||
2) echo '<';;
|
2) echo '<';;
|
||||||
esac
|
esac
|
||||||
else
|
|
||||||
echo "$version"
|
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -13,4 +13,4 @@ Outputs Tmuxifier version."
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "0.11.6"
|
echo "0.13.0"
|
||||||
|
|||||||
@@ -16,6 +16,16 @@ assert_raises \
|
|||||||
"stub_called_with tmuxifier-tmux -u attach-session -t \"${session}:\"" 0
|
"stub_called_with tmuxifier-tmux -u attach-session -t \"${session}:\"" 0
|
||||||
restore tmuxifier-tmux
|
restore tmuxifier-tmux
|
||||||
|
|
||||||
|
# When TMUXIFIER_TMUX_ITERM_ATTACH is set, pass it in as first argument(s) to
|
||||||
|
# tmuxifier-tmux
|
||||||
|
TMUXIFIER_TMUX_ITERM_ATTACH="-CC"
|
||||||
|
stub tmuxifier-tmux
|
||||||
|
__go_to_session
|
||||||
|
assert_raises \
|
||||||
|
"stub_called_with tmuxifier-tmux -CC -u attach-session -t \"${session}:\"" 0
|
||||||
|
restore tmuxifier-tmux
|
||||||
|
unset TMUXIFIER_TMUX_ITERM_ATTACH
|
||||||
|
|
||||||
# When TMUX is set, switch to $session.
|
# When TMUX is set, switch to $session.
|
||||||
TMUX="/tmp/tmux-501/default,1203,0"
|
TMUX="/tmp/tmux-501/default,1203,0"
|
||||||
stub tmuxifier-tmux
|
stub tmuxifier-tmux
|
||||||
|
|||||||
@@ -23,6 +23,17 @@ unset window_root
|
|||||||
restore run_cmd
|
restore run_cmd
|
||||||
|
|
||||||
|
|
||||||
|
# When only $TMUXIFIER_SESSION_ROOT is set, runs cd to $TMUXIFIER_SESSION_ROOT
|
||||||
|
# path.
|
||||||
|
stub run_cmd
|
||||||
|
TMUXIFIER_SESSION_ROOT="/opt"
|
||||||
|
__go_to_window_or_session_path
|
||||||
|
assert 'stub_called_with_times run_cmd cd \"/opt\"' "1"
|
||||||
|
assert 'stub_called_with_times run_cmd clear' "1"
|
||||||
|
unset TMUXIFIER_SESSION_ROOT
|
||||||
|
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"
|
||||||
@@ -45,5 +56,33 @@ unset session_root
|
|||||||
restore run_cmd
|
restore run_cmd
|
||||||
|
|
||||||
|
|
||||||
|
# When $TMUXIFIER_SESSION_ROOT and $session_root are set, runs cd to
|
||||||
|
# $TMUXIFIER_SESSION_ROOT path.
|
||||||
|
stub run_cmd
|
||||||
|
TMUXIFIER_SESSION_ROOT="/opt"
|
||||||
|
session_root="/usr"
|
||||||
|
__go_to_window_or_session_path
|
||||||
|
assert 'stub_called_with_times run_cmd cd \"/opt\"' "1"
|
||||||
|
assert 'stub_called_with_times run_cmd clear' "1"
|
||||||
|
unset TMUXIFIER_SESSION_ROOT
|
||||||
|
unset session_root
|
||||||
|
restore run_cmd
|
||||||
|
|
||||||
|
|
||||||
|
# When $window_root, $TMUXIFIER_SESSION_ROOT, and $session_root are set, runs
|
||||||
|
# cd to $window_root path.
|
||||||
|
stub run_cmd
|
||||||
|
window_root="/tmp"
|
||||||
|
TMUXIFIER_SESSION_ROOT="/opt"
|
||||||
|
session_root="/usr"
|
||||||
|
__go_to_window_or_session_path
|
||||||
|
assert 'stub_called_with_times run_cmd cd \"/tmp\"' "1"
|
||||||
|
assert 'stub_called_with_times run_cmd clear' "1"
|
||||||
|
unset window_root
|
||||||
|
unset TMUXIFIER_SESSION_ROOT
|
||||||
|
unset session_root
|
||||||
|
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()"
|
||||||
|
|||||||
Reference in New Issue
Block a user