mirror of
https://github.com/jimeh/tmuxifier.git
synced 2026-02-19 09:56:39 +00:00
Compare commits
25 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 307c959b65 | |||
| b79125f55d | |||
| ddc11cc192 | |||
|
|
5c2659c8e7 | ||
|
|
54a4f565c6 | ||
| 6a5bf32991 | |||
| 1f81e98e73 | |||
| 5989b1f516 | |||
| 012526656e | |||
| b2857b7df9 | |||
|
|
8df639ae47 | ||
|
|
75ae3ba142 | ||
| c862df2d82 | |||
|
|
c06df475be | ||
| 10104b7412 | |||
| 3fa749dbf3 | |||
| f8c0c8c749 | |||
| 147db787d5 | |||
| 4477b69f7a | |||
| 71303c8eba | |||
| 89325d0982 | |||
| 8155740ceb | |||
| ae70bae022 | |||
| a8ff37808a | |||
| 12100e7f79 |
@@ -33,9 +33,10 @@ looks like:
|
|||||||
```bash
|
```bash
|
||||||
window_root "~/Desktop"
|
window_root "~/Desktop"
|
||||||
new_window "Example Window"
|
new_window "Example Window"
|
||||||
tmux split-window -t "$session:$window.0" -v -p 20 "watch -t date"
|
split_v 20
|
||||||
tmux split-window -t "$session:$window.1" -h -p 60
|
run_cmd "watch -t date"
|
||||||
tmux select-pane -t "$session:$window.0"
|
split_h 60
|
||||||
|
select_pane 0
|
||||||
```
|
```
|
||||||
|
|
||||||
You can then load that window layout into a new window in the
|
You can then load that window layout into a new window in the
|
||||||
|
|||||||
@@ -7,8 +7,9 @@ window_root "~/Desktop"
|
|||||||
new_window "Example Window"
|
new_window "Example Window"
|
||||||
|
|
||||||
# Split window into panes.
|
# Split window into panes.
|
||||||
tmux split-window -t "$session:$window.0" -v -p 20 "watch -t date"
|
split_v 20
|
||||||
tmux split-window -t "$session:$window.1" -h -p 60
|
run_cmd "watch -t date"
|
||||||
|
split_h 60
|
||||||
|
|
||||||
# Set active pane.
|
# Set active pane.
|
||||||
tmux select-pane -t "$session:$window.0"
|
select_pane 0
|
||||||
|
|||||||
0
layouts/.gitkeep
Normal file
0
layouts/.gitkeep
Normal file
@@ -13,17 +13,36 @@
|
|||||||
# - $2: (optional) Shell command to execute when window is created.
|
# - $2: (optional) Shell command to execute when window is created.
|
||||||
#
|
#
|
||||||
new_window() {
|
new_window() {
|
||||||
if [ -n "$1" ]; then
|
if [ -n "$1" ]; then window="$1"; fi
|
||||||
window="$1"
|
if [ -n "$2" ]; then local command=("$2"); fi
|
||||||
fi
|
if [ -n "$window" ]; then local winarg=(-n "$window"); fi
|
||||||
local command=()
|
|
||||||
if [ -n "$2" ]; then
|
|
||||||
command+=("$2")
|
|
||||||
fi
|
|
||||||
if [ -n "$window" ]; then
|
|
||||||
local winarg=(-n "$window")
|
|
||||||
fi
|
|
||||||
tmux new-window -t "$session:" "${winarg[@]}" "${command[@]}"
|
tmux new-window -t "$session:" "${winarg[@]}" "${command[@]}"
|
||||||
|
__go_to_window_or_session_path
|
||||||
|
}
|
||||||
|
|
||||||
|
# Split current window/pane vertically.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: (optional) Percentage of frame the new pane will use.
|
||||||
|
# - $2: (optional) Target pane ID to split in current window.
|
||||||
|
#
|
||||||
|
split_v() {
|
||||||
|
if [ -n "$1" ]; then local percentage=(-p "$1"); fi
|
||||||
|
tmux split-window -t "$session:$window.$2" -v "${percentage[@]}"
|
||||||
|
__go_to_window_or_session_path
|
||||||
|
}
|
||||||
|
|
||||||
|
# Split current window/pane horizontally.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: (optional) Percentage of frame the new pane will use.
|
||||||
|
# - $2: (optional) Target pane ID to split in current window.
|
||||||
|
#
|
||||||
|
split_h() {
|
||||||
|
if [ -n "$1" ]; then local percentage=(-p "$1"); fi
|
||||||
|
tmux split-window -t "$session:$window.$2" -h "${percentage[@]}"
|
||||||
|
__go_to_window_or_session_path
|
||||||
}
|
}
|
||||||
|
|
||||||
# Select a specific window.
|
# Select a specific window.
|
||||||
@@ -35,6 +54,60 @@ select_window() {
|
|||||||
tmux select-window -t "$session:$1"
|
tmux select-window -t "$session:$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Select a specific pane in the current window.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: Pane ID to select.
|
||||||
|
#
|
||||||
|
select_pane() {
|
||||||
|
tmux select-pane -t "$session:$window.$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Send/paste keys to the currently active pane/window.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: String to paste.
|
||||||
|
# - $2: (optional) Target pane ID to send input to.
|
||||||
|
#
|
||||||
|
send_keys() {
|
||||||
|
tmux send-keys -t "$session:$window.$2" "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Runs a shell command in the currently active pane/window.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: Shell command to run.
|
||||||
|
# - $2: (optional) Target pane ID to run command in.
|
||||||
|
#
|
||||||
|
run_cmd() {
|
||||||
|
send_keys "$1" "$2"
|
||||||
|
send_keys "C-m" "$2"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Cusomize session root path. Default is `$HOME`.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: Directory path to use for session root.
|
||||||
|
#
|
||||||
|
session_root() {
|
||||||
|
local dir="$(__expand_path $@)"
|
||||||
|
if [ -d "$dir" ]; then
|
||||||
|
session_root="$dir"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Customize window root path. Default is `$session_root`.
|
||||||
|
#
|
||||||
|
# Arguments:
|
||||||
|
# - $1: Directory path to use for window root.
|
||||||
|
#
|
||||||
|
window_root() {
|
||||||
|
local dir="$(__expand_path $@)"
|
||||||
|
if [ -d "$dir" ]; then
|
||||||
|
window_root="$dir"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
# Load specified window layout.
|
# Load specified window layout.
|
||||||
#
|
#
|
||||||
# Arguments:
|
# Arguments:
|
||||||
@@ -45,7 +118,7 @@ load_window() {
|
|||||||
if [ -f "$file" ]; then
|
if [ -f "$file" ]; then
|
||||||
window="$1"
|
window="$1"
|
||||||
source "$file"
|
source "$file"
|
||||||
window=""
|
window=
|
||||||
|
|
||||||
# Reset `$window_root`.
|
# Reset `$window_root`.
|
||||||
if [[ "$window_root" != "$session_root" ]]; then
|
if [[ "$window_root" != "$session_root" ]]; then
|
||||||
@@ -77,30 +150,6 @@ load_session() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Cusomize session root path. Default is `$HOME`.
|
|
||||||
#
|
|
||||||
# Arguments:
|
|
||||||
# - $1: Directory path to use for session root.
|
|
||||||
#
|
|
||||||
session_root() {
|
|
||||||
local dir="$(__expand_path $@)"
|
|
||||||
if [ -d "$dir" ]; then
|
|
||||||
session_root="$dir"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Customize window root path. Default is `$session_root`.
|
|
||||||
#
|
|
||||||
# Arguments:
|
|
||||||
# - $1: Directory path to use for window root.
|
|
||||||
#
|
|
||||||
window_root() {
|
|
||||||
local dir="$(__expand_path $@)"
|
|
||||||
if [ -d "$dir" ]; then
|
|
||||||
cd "$dir"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Create a new session, returning 0 on success, 1 on failure.
|
# Create a new session, returning 0 on success, 1 on failure.
|
||||||
#
|
#
|
||||||
# Arguments:
|
# Arguments:
|
||||||
@@ -122,14 +171,14 @@ initialize_session() {
|
|||||||
tmux start-server
|
tmux start-server
|
||||||
|
|
||||||
# Check if the named session already exists.
|
# Check if the named session already exists.
|
||||||
if ! tmux has-session -t "$session" 2>/dev/null; then
|
if ! tmux has-session -t "$session:" 2>/dev/null; then
|
||||||
# Create the new session.
|
# Create the new session.
|
||||||
env TMUX= tmux new-session -d -s "$session"
|
env TMUX="" tmux new-session -d -s "$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"
|
||||||
tmux set-option -t "$session" default-path "$session_root" 1>/dev/null
|
tmux set-option -t "$session:" default-path "$session_root" 1>/dev/null
|
||||||
fi
|
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
|
||||||
@@ -156,6 +205,7 @@ initialize_session() {
|
|||||||
# If the session was created, we've already been switched to it. If it was not
|
# If the session was created, we've already been switched to it. If it was not
|
||||||
# created, the session already exists, and we'll need to specifically switch
|
# created, the session already exists, and we'll need to specifically switch
|
||||||
# to it here.
|
# to it here.
|
||||||
|
#
|
||||||
finalize_and_go_to_session() {
|
finalize_and_go_to_session() {
|
||||||
! tmux kill-window -t "$session:99" 2>/dev/null
|
! tmux kill-window -t "$session:99" 2>/dev/null
|
||||||
if [[ "$(tmuxifier-current-session)" != "$session" ]]; then
|
if [[ "$(tmuxifier-current-session)" != "$session" ]]; then
|
||||||
@@ -181,8 +231,16 @@ __expand_path() {
|
|||||||
|
|
||||||
__go_to_session() {
|
__go_to_session() {
|
||||||
if [ -z "$TMUX" ]; then
|
if [ -z "$TMUX" ]; then
|
||||||
tmux -u attach-session -t "$session"
|
tmux -u attach-session -t "$session:"
|
||||||
else
|
else
|
||||||
tmux -u switch-client -t "$session"
|
tmux -u switch-client -t "$session:"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
__go_to_window_or_session_path() {
|
||||||
|
local window_or_session_root=${window_root-$session_root}
|
||||||
|
if [ -n "$window_or_session_root" ]; then
|
||||||
|
run_cmd "cd \"$window_or_session_root\""
|
||||||
|
send_keys "C-l"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,11 +3,9 @@ set -e
|
|||||||
[ -n "$TMUXIFIER_DEBUG" ] && set -x
|
[ -n "$TMUXIFIER_DEBUG" ] && set -x
|
||||||
|
|
||||||
if [ -n "$TMUX" ]; then
|
if [ -n "$TMUX" ]; then
|
||||||
for item in $(tmux list-sessions -F "#{?session_attached,1,0}:#S"); do
|
for item in $(tmux list-pane -F "#{session_name}");do
|
||||||
if [[ "$item" == "1:"* ]]; then
|
echo $item
|
||||||
echo ${item/1:/}
|
exit 0
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,14 @@
|
|||||||
set -e
|
set -e
|
||||||
[ -n "$TMUXIFIER_DEBUG" ] && set -x
|
[ -n "$TMUXIFIER_DEBUG" ] && set -x
|
||||||
|
|
||||||
|
# Provide tmuxifier completions
|
||||||
|
if [ "$1" == "--complete" ]; then
|
||||||
|
for item in $(tmuxifier-list-sessions); do
|
||||||
|
echo "$item"
|
||||||
|
done
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -z "$1" ]; then
|
if [ -z "$1" ]; then
|
||||||
echo "$(tmuxifier-help new-session)" >&2
|
echo "$(tmuxifier-help new-session)" >&2
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
@@ -2,6 +2,14 @@
|
|||||||
set -e
|
set -e
|
||||||
[ -n "$TMUXIFIER_DEBUG" ] && set -x
|
[ -n "$TMUXIFIER_DEBUG" ] && set -x
|
||||||
|
|
||||||
|
# Provide tmuxifier completions
|
||||||
|
if [ "$1" == "--complete" ]; then
|
||||||
|
for item in $(tmuxifier-list-windows); do
|
||||||
|
echo "$item"
|
||||||
|
done
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -z "$1" ]; then
|
if [ -z "$1" ]; then
|
||||||
echo "$(tmuxifier-help new-window)" >&2
|
echo "$(tmuxifier-help new-window)" >&2
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
@@ -2,4 +2,4 @@
|
|||||||
set -e
|
set -e
|
||||||
[ -n "$TMUXIFIER_DEBUG" ] && set -x
|
[ -n "$TMUXIFIER_DEBUG" ] && set -x
|
||||||
|
|
||||||
echo "0.1.3"
|
echo "0.3.1"
|
||||||
|
|||||||
@@ -7,7 +7,16 @@
|
|||||||
new_window "{{WINDOW_NAME}}"
|
new_window "{{WINDOW_NAME}}"
|
||||||
|
|
||||||
# Split window into panes.
|
# Split window into panes.
|
||||||
#tmux split-window -t "$session:$window.0" -h -p 20
|
#split_v 20
|
||||||
|
#split_h 50
|
||||||
|
|
||||||
|
# Run commands.
|
||||||
|
#run_cmd "top" # runs in active pane
|
||||||
|
#run_cmd "date" 1 # runs in pane 1
|
||||||
|
|
||||||
|
# Paste text
|
||||||
|
#send_keys "top" # paste into active pane
|
||||||
|
#send_keys "date" 1 # paste into active pane
|
||||||
|
|
||||||
# Set active pane.
|
# Set active pane.
|
||||||
#tmux select-pane -t "$session:$window.0"
|
#select_pane 0
|
||||||
|
|||||||
Reference in New Issue
Block a user