mirror of
https://github.com/jimeh/tmuxifier.git
synced 2026-02-19 09:56:39 +00:00
Compare commits
124 Commits
v0.8.1
...
9941b28063
| Author | SHA1 | Date | |
|---|---|---|---|
| 9941b28063 | |||
|
|
68b02f07b0 | ||
| 895dace853 | |||
| 2b6239c6f0 | |||
| de509d8a08 | |||
|
|
67ee31d783 | ||
|
|
2e4d5197ae | ||
|
|
c2cbd5d7ea | ||
|
fe1f6c4734
|
|||
|
d147958750
|
|||
| 957229a1e8 | |||
|
|
ea4a7aa57c | ||
| 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 | |||
| 6f98020309 | |||
| a96b5a1d44 | |||
| fe3beeac29 | |||
| ef0f25591c | |||
| 0ae0bc84e3 | |||
|
|
2249cf8d1b | ||
| 4bf105eebc | |||
| 71236afccf | |||
| 6e5794a2b4 | |||
| f8f0054c99 | |||
| 6a1e9e4de7 | |||
| 77ccb5d532 | |||
| 48b5150b0d | |||
| 38932bf33e | |||
| d8b8dff61f | |||
| d47838ca1f | |||
| 87d767d1c5 | |||
| 1b0b3b8ba8 | |||
| 94b9559bfa | |||
| 636e92b118 | |||
| 8a06ad149e | |||
| 7e63149c26 | |||
| 36add22637 | |||
| 3aa151b865 | |||
| f977850ea9 | |||
| 47219d2d40 | |||
| 6e634ecba9 | |||
| 396120cf53 | |||
| a875b63033 | |||
| 0d0106e7ba | |||
| ed52353bba | |||
| 57b4f303f2 | |||
| 359f1a9a94 | |||
| 41218e3072 | |||
| 5602bf650e | |||
| 54f6f890bb | |||
| e5ffdc6f16 | |||
| 1fb80660b8 | |||
| a700770757 | |||
| c927126cb3 | |||
| 279e68f7c5 | |||
| 1bf087faa3 | |||
| 2aa549ff70 | |||
| 6f0fdba121 | |||
| a1e6972434 | |||
| 7443dd74f8 | |||
| e08ee38927 | |||
| 8416e63094 | |||
|
|
fe1ac9d2f9 | ||
| 87c38ae818 | |||
| 3a74ff3a60 | |||
| 7df4a33a7d | |||
| 255fe78572 | |||
| a5426d4e12 | |||
| 5850c15d87 | |||
| 4ccf61f692 | |||
|
|
44c443efe4 | ||
| 72cfab20a0 | |||
| 33f26bca56 | |||
| 90caa0d362 | |||
| 0aa0e43949 | |||
| 2a09683851 | |||
| 5b3f4d8488 | |||
| 36c702cb88 | |||
| 50f84b1586 | |||
| feed17581a | |||
| 91722a4895 | |||
| cd7ae2ebce | |||
|
|
a9479df7c1 | ||
|
|
84de3da9ac | ||
| 7f8840eac9 | |||
| 0653074570 | |||
| 5047f596af | |||
|
|
f2c5e9bb66 | ||
| ae96c17580 | |||
|
|
f5c4361268 | ||
|
|
8a9174c1c5 | ||
| 3dfa166041 | |||
| e231f2d642 |
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
test-runner.sh
|
||||
test/assert.sh
|
||||
test/stub.sh
|
||||
16
.travis.yml
Normal file
16
.travis.yml
Normal file
@@ -0,0 +1,16 @@
|
||||
language: c
|
||||
env:
|
||||
- TMUX_VERSION="1.6"
|
||||
- TMUX_VERSION="1.7"
|
||||
- TMUX_VERSION="1.8"
|
||||
- TMUX_VERSION="1.9a"
|
||||
- TMUX_VERSION="2.0"
|
||||
before_install:
|
||||
- sudo apt-get update
|
||||
- sudo apt-get install -y bc build-essential libevent-dev libncurses5-dev
|
||||
- wget https://github.com/tmux/tmux/releases/download/${TMUX_VERSION}/tmux-${TMUX_VERSION}.tar.gz
|
||||
- tar -zxf tmux-${TMUX_VERSION}.tar.gz
|
||||
- cd tmux-${TMUX_VERSION}
|
||||
- ./configure && make && sudo make install
|
||||
- cd ..
|
||||
script: make test
|
||||
2
LICENSE
2
LICENSE
@@ -1,4 +1,4 @@
|
||||
Copyright (c) 2013 Jim Myhrberg.
|
||||
Copyright (c) 2014 Jim Myhrberg.
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
|
||||
50
Makefile
Normal file
50
Makefile
Normal file
@@ -0,0 +1,50 @@
|
||||
test: bootstrap
|
||||
./test-runner.sh
|
||||
|
||||
bootstrap: test-runner.sh test/assert.sh test/stub.sh
|
||||
clean: remove_test-runner.sh remove_test/assert.sh remove_test/stub.sh
|
||||
update: update_test-runner.sh update_test/assert.sh update_test/stub.sh
|
||||
|
||||
test-runner.sh:
|
||||
echo "fetching test-runner.sh..." && \
|
||||
curl -s -L -o test-runner.sh \
|
||||
https://github.com/jimeh/test-runner.sh/raw/v0.2.0/test-runner.sh && \
|
||||
chmod +x test-runner.sh
|
||||
|
||||
remove_test-runner.sh:
|
||||
( \
|
||||
test -f "test-runner.sh" && rm "test-runner.sh" && \
|
||||
echo "removed test-runner.sh"\
|
||||
) || exit 0
|
||||
|
||||
update_test-runner.sh: remove_test-runner.sh test-runner.sh
|
||||
|
||||
test/assert.sh:
|
||||
echo "fetching test/assert.sh..." && \
|
||||
curl -s -L -o test/assert.sh \
|
||||
https://raw.github.com/lehmannro/assert.sh/v1.0.2/assert.sh
|
||||
|
||||
remove_test/assert.sh:
|
||||
test -f "test/assert.sh" && \
|
||||
rm "test/assert.sh" && \
|
||||
echo "removed test/assert.sh"
|
||||
|
||||
update_test/assert.sh: remove_test/assert.sh test/assert.sh
|
||||
|
||||
test/stub.sh:
|
||||
echo "fetching test/stub.sh..." && \
|
||||
curl -s -L -o test/stub.sh \
|
||||
https://raw.github.com/jimeh/stub.sh/v1.0.1/stub.sh
|
||||
|
||||
remove_test/stub.sh:
|
||||
test -f "test/stub.sh" && \
|
||||
rm "test/stub.sh" && \
|
||||
echo "removed test/stub.sh"
|
||||
|
||||
update_test/stub.sh: remove_test/stub.sh test/stub.sh
|
||||
|
||||
.SILENT:
|
||||
.PHONY: test bootstrap clean \
|
||||
remove_test-runner.sh update_test-runner.sh \
|
||||
remove_test/assert.sh update_test/assert.sh \
|
||||
remove_test/stub.sh update_test/stub.sh
|
||||
181
README.md
181
README.md
@@ -1,20 +1,20 @@
|
||||
# Tmuxifier
|
||||
# Tmuxifier [](https://travis-ci.org/jimeh/tmuxifier)
|
||||
|
||||
Tmuxify your Tmux. Create, edit, manage and load complex Tmux session, window
|
||||
and pane configurations with ease.
|
||||
|
||||
In short, Tmuxifier allows you to easily create, edit, and load "layout"
|
||||
files, which are simple shell scripts where you use the `tmux` command and
|
||||
helper commands provided by tmuxifier to manage Tmux sessions and windows
|
||||
In short, Tmuxifier allows you to easily create, edit, and load "layout" files,
|
||||
which are simple shell scripts where you use the `tmux` command and helper
|
||||
commands provided by `tmuxifier` to manage Tmux sessions and windows
|
||||
|
||||
### Window Layouts
|
||||
|
||||
Window layouts create a new Tmux window, optionally setting the window title
|
||||
and root path where all shells are cd'd to by default. It allows you to easily
|
||||
split a window into specifically sized panes and more as you wish.
|
||||
Window layouts create a new Tmux window, optionally setting the window title and
|
||||
root path where all shells are cd'd to by default. It allows you to easily split
|
||||
a window into specifically sized panes and more as you wish.
|
||||
|
||||
You can load a window layout directly into your current Tmux session, or into
|
||||
a session layout to have the window created along with the session.
|
||||
You can load a window layout directly into your current Tmux session, or into a
|
||||
session layout to have the window created along with the session.
|
||||
|
||||
### Session Layouts
|
||||
|
||||
@@ -25,10 +25,11 @@ defined directly within the session layout file.
|
||||
|
||||
## Example
|
||||
|
||||
Given we have a window layout file called [example.window.sh][] which
|
||||
looks like:
|
||||
Given we have a window layout file called [example.window.sh][] which looks
|
||||
like:
|
||||
|
||||
[example.window.sh]: https://github.com/jimeh/tmuxifier/blob/master/examples/example.window.sh
|
||||
[example.window.sh]:
|
||||
https://github.com/jimeh/tmuxifier/blob/master/examples/example.window.sh
|
||||
|
||||
```bash
|
||||
window_root "~/Desktop"
|
||||
@@ -39,8 +40,8 @@ split_h 60
|
||||
select_pane 0
|
||||
```
|
||||
|
||||
You can then load that window layout into a new window in the
|
||||
current tmux session using:
|
||||
You can then load that window layout into a new window in the current tmux
|
||||
session using:
|
||||
|
||||
tmuxifier load-window example
|
||||
|
||||
@@ -50,34 +51,58 @@ Which will yield a Tmux window looking like this:
|
||||
|
||||
## Installation
|
||||
|
||||
### Manual
|
||||
|
||||
Clone the repo to your machine:
|
||||
|
||||
git clone https://github.com/jimeh/tmuxifier.git ~/.tmuxifier
|
||||
|
||||
Then add `~/.tmuxifier/bin` to your PATH to make the `tmuxifier` executable
|
||||
Then add `$HOME/.tmuxifier/bin` to your PATH to make the `tmuxifier` executable
|
||||
available to you:
|
||||
|
||||
__In bash & zsh:__
|
||||
**In bash & zsh:**
|
||||
|
||||
```bash
|
||||
export PATH="~/.tmuxifier/bin:$PATH"
|
||||
export PATH="$HOME/.tmuxifier/bin:$PATH"
|
||||
```
|
||||
|
||||
__In tcsh:__
|
||||
**In tcsh:**
|
||||
|
||||
```tcsh
|
||||
set path = ( "~/.tmuxifier/bin" $path )
|
||||
```
|
||||
|
||||
### Custom Installation Path
|
||||
**In fish:**
|
||||
|
||||
```bash
|
||||
set -gx PATH "~/.tmuxifier/bin" $PATH
|
||||
```
|
||||
|
||||
#### Custom Installation Path
|
||||
|
||||
To install Tmuxifier somewhere else than the suggested `~/.tmuxifier`, simply
|
||||
clone the repository to your custom location, and ensure the `bin` folder is
|
||||
added to your PATH making the `tmuxifier` executable available to you.
|
||||
|
||||
### TPM
|
||||
|
||||
You can also install and update Tmuxifier with
|
||||
[TPM](https://github.com/tmux-plugins/tpm):
|
||||
|
||||
```bash
|
||||
set -g @plugin 'jimeh/tmuxifier'
|
||||
```
|
||||
|
||||
Trigger TPM's install command with `prefix` + `I` to install Tmuxifier to TPM's
|
||||
plugin directory (default is `$HOME/.tmux/plugins`).
|
||||
|
||||
To use the `tmuxifier` command, you will need to add the `bin` directory to your
|
||||
PATH. If you are using the default TPM plugin directory, the `bin` directory
|
||||
will be `$HOME/.tmux/plugins/tmuxifier/bin`.
|
||||
|
||||
## Setup
|
||||
|
||||
__In bash & zsh:__
|
||||
**In bash & zsh:**
|
||||
|
||||
And add the following to your `~/.profile`, `~/.bash_profile`, `~/.zshrc` or
|
||||
equivalent:
|
||||
@@ -86,7 +111,7 @@ equivalent:
|
||||
eval "$(tmuxifier init -)"
|
||||
```
|
||||
|
||||
__In tcsh:__
|
||||
**In tcsh:**
|
||||
|
||||
Add the following to your `~/.cshrc`, `~/.tcshrc` or equivalent:
|
||||
|
||||
@@ -94,14 +119,41 @@ Add the following to your `~/.cshrc`, `~/.tcshrc` or equivalent:
|
||||
eval `tmuxifier init -`
|
||||
```
|
||||
|
||||
**In fish:**
|
||||
|
||||
And add the following to your `~/.config/fish/config.fish` or equivalent:
|
||||
|
||||
```bash
|
||||
eval (tmuxifier init - fish)
|
||||
```
|
||||
|
||||
### Custom Tmux Arguments
|
||||
|
||||
If you need to pass custom arguments to `tmux` itself, you can do so by setting
|
||||
the `TMUXIFIER_TMUX_OPTS` environment variable. For example to set custom
|
||||
arguments globally:
|
||||
|
||||
```bash
|
||||
export TMUXIFIER_TMUX_OPTS="-L my-awesome-socket-name"
|
||||
eval "$(tmuxifier init -)"
|
||||
```
|
||||
|
||||
And/or specify dynamically when calling `tmuxifier`:
|
||||
|
||||
```bash
|
||||
TMUXIFIER_TMUX_OPTS="-L other-socket" tmuxifier load-session welcome
|
||||
```
|
||||
|
||||
## Updating
|
||||
|
||||
cd ~/.tmuxifier
|
||||
git pull
|
||||
```bash
|
||||
cd ~/.tmuxifier # or where you've cloned tmuxifier to
|
||||
git pull
|
||||
```
|
||||
|
||||
## Usage
|
||||
|
||||
*__Note:__ This section needs expanding upon.*
|
||||
_**Note:** This section needs expanding upon._
|
||||
|
||||
For a quick reference on available commands and their aliases, please run:
|
||||
|
||||
@@ -109,8 +161,8 @@ For a quick reference on available commands and their aliases, please run:
|
||||
|
||||
Tmuxifier doesn't come with any layouts, so you'll want to create your own
|
||||
window and session layout files. New layout files are populated with examples
|
||||
and comments explaining what things do. Also, having a look at the
|
||||
[examples][] directory will also give you a good idea.
|
||||
and comments explaining what things do. Also, having a look at the [examples][]
|
||||
directory will also give you a good idea.
|
||||
|
||||
### Window Layouts
|
||||
|
||||
@@ -118,16 +170,16 @@ First off you'll want to define a window layout:
|
||||
|
||||
tmuxifier new-window my-awesome-window
|
||||
|
||||
This will create a new layout file called `my-awesome-window.window.sh` in
|
||||
your `$TMUXIFIER_LAYOUT_PATH`, and open it with the editor defined in
|
||||
`$EDITOR`. Customize it as you wish, and save.
|
||||
This will create a new layout file called `my-awesome-window.window.sh` in your
|
||||
`$TMUXIFIER_LAYOUT_PATH`, and open it with the editor defined in `$EDITOR`.
|
||||
Customize it as you wish, and save.
|
||||
|
||||
You can now load *my-awesome-window* with the following command:
|
||||
You can now load _my-awesome-window_ with the following command:
|
||||
|
||||
tmuxifier load-window my-awesome-window
|
||||
|
||||
You should now have a new Tmux window open created from your custom and
|
||||
awesome window layout.
|
||||
You should now have a new Tmux window open created from your custom and awesome
|
||||
window layout.
|
||||
|
||||
### Session Layouts
|
||||
|
||||
@@ -137,8 +189,9 @@ To create your first session layout, run:
|
||||
|
||||
Same deal as with creating a new window, except the filename ends with
|
||||
`.session.sh` instead of `.window.sh`, and the file's pre-populated content
|
||||
looks different. To have your awesome window loaded, add `load_window
|
||||
"my-awesome-window"` to the session layout next to existing examples.
|
||||
looks different. To have your awesome window loaded, add
|
||||
`load_window "my-awesome-window"` to the session layout next to existing
|
||||
examples.
|
||||
|
||||
To load the session layout simply run:
|
||||
|
||||
@@ -162,13 +215,28 @@ export TMUXIFIER_LAYOUT_PATH="$HOME/.tmux-layouts"
|
||||
|
||||
### Disable Shell-Completion
|
||||
|
||||
Tmuxifier comes with shell-completion for bash, zsh and tcsh. If for any
|
||||
Tmuxifier comes with shell-completion for bash, zsh, tcsh, and fish. If for any
|
||||
reason you need to disable it, just set `$TMUXIFIER_NO_COMPLETE`.
|
||||
|
||||
```bash
|
||||
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
|
||||
|
||||
- Tmuxifier is largely inspired by [Tmuxinator][].
|
||||
@@ -177,16 +245,16 @@ export TMUXIFIER_NO_COMPLETE=1
|
||||
|
||||
## Tmuxifier vs. Tmuxinator
|
||||
|
||||
Though Tmuxifier is largely inspired by the excellent [Tmuxinator][] project,
|
||||
it does set itself apart in a number of ways:
|
||||
Though Tmuxifier is largely inspired by the excellent [Tmuxinator][] project, it
|
||||
does set itself apart in a number of ways:
|
||||
|
||||
- Uses shell scripts to define Tmux sessions and windows instead of YAML
|
||||
files. The benefit is total control over Tmux, but the definition files are
|
||||
more complicated to work with.
|
||||
- Uses shell scripts to define Tmux sessions and windows instead of YAML files.
|
||||
The benefit is total control over Tmux, but the definition files are more
|
||||
complicated to work with.
|
||||
- Instead of using a "project" concept, Tmuxifier uses a concept of "sessions"
|
||||
and "windows" just like Tmux itself. This allows you to load a whole session
|
||||
with multiple pre-defined window configurations, or just load a single
|
||||
window configuration into your existing session.
|
||||
with multiple pre-defined window configurations, or just load a single window
|
||||
configuration into your existing session.
|
||||
- Tmuxifier is a set of shell scripts, meaning it doesn't require Ruby to be
|
||||
installed on the machine.
|
||||
|
||||
@@ -195,29 +263,28 @@ it does set itself apart in a number of ways:
|
||||
|
||||
## Todos
|
||||
|
||||
* Improve Readme, specially Usage section.
|
||||
* Write up a detailed reference for all available layout helper functions.
|
||||
- Improve Readme, specially Usage section.
|
||||
- Write up a detailed reference for all available layout helper functions.
|
||||
|
||||
## License
|
||||
|
||||
(The MIT license)
|
||||
|
||||
Copyright (c) 2013 Jim Myhrberg.
|
||||
Copyright (c) 2014 Jim Myhrberg.
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
this software and associated documentation files (the "Software"), to deal in
|
||||
the Software without restriction, including without limitation the rights to
|
||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
@@ -21,16 +21,28 @@ abs_dirname() {
|
||||
}
|
||||
|
||||
if [ -z "${TMUXIFIER}" ]; then
|
||||
# Set TMUXIFIER relative to the "tmuxifier" executable.
|
||||
export TMUXIFIER="$(dirname "$(abs_dirname "$0")")"
|
||||
else
|
||||
# Strip any trailing slash (/) characters from TMUXIFIER variable.
|
||||
export TMUXIFIER="${TMUXIFIER%/}"
|
||||
fi
|
||||
|
||||
# Load tmuxifier environment variables.
|
||||
source "$TMUXIFIER/lib/env.sh"
|
||||
|
||||
# Add tmuxifier's internal commands to PATH.
|
||||
export PATH="$TMUXIFIER/libexec:$PATH"
|
||||
|
||||
# Check Tmux version.
|
||||
export TMUXIFIER_MIN_TMUX_VERSION="1.6"
|
||||
if [ "$(tmuxifier-tmux-version "$TMUXIFIER_MIN_TMUX_VERSION")" == "<" ]; then
|
||||
echo -e "ERROR: Tmuxifier requires Tmux v${TMUXIFIER_MIN_TMUX_VERSION}" \
|
||||
"or newer. You have v$(tmuxifier-tmux-version)." >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Parse given command
|
||||
command="$1"
|
||||
case "$command" in
|
||||
"" | "-h" | "--help" )
|
||||
|
||||
36
completion/tmuxifier.fish
Normal file
36
completion/tmuxifier.fish
Normal file
@@ -0,0 +1,36 @@
|
||||
|
||||
set -l cmd_load_session 'load-session s'
|
||||
set -l cmd_load_window 'load-window w'
|
||||
set -l cmd_list 'list l'
|
||||
set -l cmd_list_sessions 'list-sessions ls'
|
||||
set -l cmd_list_windows 'list-windows lw'
|
||||
set -l cmd_new_session 'new-session ns'
|
||||
set -l cmd_new_window 'new-window nw'
|
||||
set -l cmd_edit_session 'edit-session es'
|
||||
set -l cmd_edit_window 'edit-window ew'
|
||||
set -l cmd_commands 'commands'
|
||||
set -l cmd_version 'version'
|
||||
set -l cmd_help 'help'
|
||||
|
||||
complete -c tmuxifier -x
|
||||
|
||||
# Commands
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_load_session -d 'Load the specified session layout.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_load_window -d 'Load the specified window layout into current session.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_list -d 'List all session and window layouts.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_list_sessions -d 'List session layouts.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_list_windows -d 'List window layouts.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_new_session -d 'Create new session layout and open it with $EDITOR.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_new_window -d 'Create new window layout and open it with $EDITOR.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_edit_session -d 'Edit specified session layout with $EDITOR.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_edit_window -d 'Edit specified window layout with $EDITOR.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_commands -d 'List all tmuxifier commands.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_version -d 'Print Tmuxifier version.'
|
||||
complete -c tmuxifier -n '__fish_use_subcommand' -a $cmd_help -d 'Show this message.'
|
||||
|
||||
# Complete subcommands
|
||||
complete -c tmuxifier -x -n "__fish_seen_subcommand_from $cmd_load_session" -a '(tmuxifier list-sessions)' -d 'session-template'
|
||||
complete -c tmuxifier -x -n "__fish_seen_subcommand_from $cmd_load_window" -a '(tmuxifier list-windows)' -d 'window-template'
|
||||
complete -c tmuxifier -x -n "__fish_seen_subcommand_from $cmd_edit_session" -a '(tmuxifier list-sessions)' -d 'session-template'
|
||||
complete -c tmuxifier -x -n "__fish_seen_subcommand_from $cmd_edit_window" -a '(tmuxifier list-windows)' -d 'window-template'
|
||||
|
||||
20
init.fish
Normal file
20
init.fish
Normal file
@@ -0,0 +1,20 @@
|
||||
# Set/fix Tmuxifier root path if needed.
|
||||
if test -z $TMUXIFIER
|
||||
set -gx TMUXIFIER "$HOME/.tmuxifier"
|
||||
end
|
||||
|
||||
# Add `bin` directroy to `$PATH`.
|
||||
if not contains "$TMUXIFIER/bin" $PATH
|
||||
set -gx PATH "$TMUXIFIER/bin" $PATH
|
||||
end
|
||||
|
||||
# If `tmuxifier` is available, and `$TMUXIFIER_NO_COMPLETE` is not set, then
|
||||
# load Tmuxifier shell completion.
|
||||
if test -n (which tmuxifier); and test -z $TMUXIFIER_NO_COMPLETE
|
||||
# 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
|
||||
@@ -6,6 +6,11 @@
|
||||
# otherwise more complex means.
|
||||
#
|
||||
|
||||
# Alias tmux to tmuxifier-tmux wrapper.
|
||||
tmux() {
|
||||
tmuxifier-tmux "$@"
|
||||
}
|
||||
|
||||
# Create a new window.
|
||||
#
|
||||
# Arguments:
|
||||
@@ -13,11 +18,15 @@
|
||||
# - $2: (optional) Shell command to execute when window is created.
|
||||
#
|
||||
new_window() {
|
||||
if [ -n "$1" ]; then window="$1"; fi
|
||||
if [ -n "$1" ]; then local winarg=(-n "$1"); fi
|
||||
if [ -n "$2" ]; then local command=("$2"); fi
|
||||
if [ -n "$window" ]; then local winarg=(-n "$window"); fi
|
||||
|
||||
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)"
|
||||
__go_to_window_or_session_path
|
||||
}
|
||||
|
||||
@@ -28,8 +37,13 @@ new_window() {
|
||||
# - $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[@]}"
|
||||
if [ "$(tmuxifier-tmux-version "3.0")" == ">" ]; then
|
||||
# Tmux 3.1 and later.
|
||||
if [ -n "$1" ]; then local percentage=(-l "$1"'%'); fi
|
||||
else
|
||||
if [ -n "$1" ]; then local percentage=(-p "$1"); fi
|
||||
fi
|
||||
tmuxifier-tmux split-window -t "$session:$window.$2" -v "${percentage[@]}"
|
||||
__go_to_window_or_session_path
|
||||
}
|
||||
|
||||
@@ -40,8 +54,13 @@ split_v() {
|
||||
# - $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[@]}"
|
||||
if [ "$(tmuxifier-tmux-version "3.0")" == ">" ]; then
|
||||
# Tmux 3.1 and later.
|
||||
if [ -n "$1" ]; then local percentage=(-l "$1"'%'); fi
|
||||
else
|
||||
if [ -n "$1" ]; then local percentage=(-p "$1"); fi
|
||||
fi
|
||||
tmuxifier-tmux split-window -t "$session:$window.$2" -h "${percentage[@]}"
|
||||
__go_to_window_or_session_path
|
||||
}
|
||||
|
||||
@@ -53,7 +72,7 @@ split_h() {
|
||||
#
|
||||
split_vl() {
|
||||
if [ -n "$1" ]; then local count=(-l "$1"); fi
|
||||
tmux split-window -t "$session:$window.$2" -v "${count[@]}"
|
||||
tmuxifier-tmux split-window -t "$session:$window.$2" -v "${count[@]}"
|
||||
__go_to_window_or_session_path
|
||||
}
|
||||
|
||||
@@ -65,7 +84,7 @@ split_vl() {
|
||||
#
|
||||
split_hl() {
|
||||
if [ -n "$1" ]; then local count=(-l "$1"); fi
|
||||
tmux split-window -t "$session:$window.$2" -h "${count[@]}"
|
||||
tmuxifier-tmux split-window -t "$session:$window.$2" -h "${count[@]}"
|
||||
__go_to_window_or_session_path
|
||||
}
|
||||
|
||||
@@ -74,7 +93,7 @@ split_hl() {
|
||||
# Arguments:
|
||||
# - $1: (optional) Target pane ID in which to run
|
||||
clock() {
|
||||
tmux clock-mode -t "$session:$window.$1"
|
||||
tmuxifier-tmux clock-mode -t "$session:$window.$1"
|
||||
}
|
||||
|
||||
# Select a specific window.
|
||||
@@ -83,7 +102,8 @@ clock() {
|
||||
# - $1: Window ID or name to select.
|
||||
#
|
||||
select_window() {
|
||||
tmux select-window -t "$session:$1"
|
||||
tmuxifier-tmux select-window -t "$session:$1"
|
||||
window="$(__get_current_window_index)"
|
||||
}
|
||||
|
||||
# Select a specific pane in the current window.
|
||||
@@ -92,7 +112,45 @@ select_window() {
|
||||
# - $1: Pane ID to select.
|
||||
#
|
||||
select_pane() {
|
||||
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.
|
||||
@@ -102,7 +160,7 @@ select_pane() {
|
||||
# - $2: (optional) Target pane ID to send input to.
|
||||
#
|
||||
send_keys() {
|
||||
tmux send-keys -t "$session:$window.$2" "$1"
|
||||
tmuxifier-tmux send-keys -t "$session:$window.$2" "$1"
|
||||
}
|
||||
|
||||
# Runs a shell command in the currently active pane/window.
|
||||
@@ -179,31 +237,39 @@ load_window() {
|
||||
# - $2: (optional) Override default window name.
|
||||
#
|
||||
load_session() {
|
||||
local file="$1"
|
||||
if [ ! -f "$file" ]; then
|
||||
file="$TMUXIFIER_LAYOUT_PATH/$1.session.sh"
|
||||
fi
|
||||
|
||||
if [ -f "$file" ]; then
|
||||
if [ $# -gt 1 ]; then
|
||||
session="$2"
|
||||
local file
|
||||
if [ "${1#*/}" = "$1" ]; then
|
||||
# There's no slash in the path.
|
||||
if [ -f "$TMUXIFIER_LAYOUT_PATH/$1.session.sh" ] || [ ! -f "$1" ]; then
|
||||
file="$TMUXIFIER_LAYOUT_PATH/$1.session.sh"
|
||||
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"
|
||||
# bash's 'source' requires an slash in the filename to not use $PATH.
|
||||
file="./$1"
|
||||
fi
|
||||
else
|
||||
file="$1"
|
||||
fi
|
||||
|
||||
if ! [ -f "$file" ]; then
|
||||
echo "\"$1\" session layout not found." >&2
|
||||
return 1
|
||||
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.
|
||||
@@ -224,45 +290,61 @@ initialize_session() {
|
||||
fi
|
||||
|
||||
# Ensure tmux server is running for has-session check.
|
||||
tmux start-server
|
||||
tmuxifier-tmux start-server
|
||||
|
||||
# Check if the named session already exists.
|
||||
if ! tmux has-session -t "$session:" 2>/dev/null; then
|
||||
if tmuxifier-tmux list-sessions | grep -q "^$session:"; then
|
||||
return 1
|
||||
fi
|
||||
|
||||
# Tmux 1.8 and earlier.
|
||||
if [ "$(tmuxifier-tmux-version "1.9")" == "<" ]; then
|
||||
# Create the new session.
|
||||
env TMUX="" tmux new-session -d -s "$session"
|
||||
env TMUX="" tmuxifier-tmux new-session -d -s "$session"
|
||||
|
||||
# Set default-path for session
|
||||
if [ -n "$session_root" ] && [ -d "$session_root" ]; then
|
||||
cd "$session_root"
|
||||
|
||||
$set_default_path && tmux set-option -t "$session:" default-path "$session_root" 1>/dev/null
|
||||
$set_default_path && tmuxifier-tmux \
|
||||
set-option -t "$session:" \
|
||||
default-path "$session_root" 1>/dev/null
|
||||
fi
|
||||
|
||||
# In order to ensure only specified windows are created, we move the
|
||||
# default window to position 999, and later remove it with the
|
||||
# `finalize_and_go_to_session` function.
|
||||
local first_window_index=$(__get_first_window_index)
|
||||
tmux move-window -s "$session:$first_window_index" -t "$session:999"
|
||||
# Tmux 1.9 and later.
|
||||
else
|
||||
if $set_default_path; then
|
||||
local session_args=(-c "$session_root")
|
||||
fi
|
||||
|
||||
# Session created, return ok exit status.
|
||||
return 0
|
||||
env TMUX="" tmuxifier-tmux new-session \
|
||||
-d -s "$session" "${session_args[@]}"
|
||||
fi
|
||||
# Session already existed, return error exit status.
|
||||
return 1
|
||||
|
||||
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
|
||||
# default window to position 999, and later remove it with the
|
||||
# `finalize_and_go_to_session` function.
|
||||
local first_window_index=$(__get_first_window_index)
|
||||
tmuxifier-tmux move-window \
|
||||
-s "$session:$first_window_index" -t "$session:999"
|
||||
}
|
||||
|
||||
# Finalize session creation and then switch to it if needed.
|
||||
#
|
||||
# When the session is created, it leaves a unused window in position #99, this
|
||||
# is the default window which was created with the session, but it's also a
|
||||
# window that was not explicitly created. Hence we kill it.
|
||||
# When the session is created, it leaves a unused window in position #999,
|
||||
# this is the default window which was created with the session, but it's also
|
||||
# a window that was not explicitly created. Hence we kill it.
|
||||
#
|
||||
# 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
|
||||
# to it here.
|
||||
# created, but already existed, then we'll need to specifically switch to it.
|
||||
#
|
||||
finalize_and_go_to_session() {
|
||||
! 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
|
||||
__go_to_session
|
||||
fi
|
||||
@@ -285,8 +367,9 @@ __expand_path() {
|
||||
}
|
||||
|
||||
__get_first_window_index() {
|
||||
local index
|
||||
index=$(tmux list-windows -t "$session:" -F "#{window_index}" 2>/dev/null)
|
||||
local index=$(tmuxifier-tmux list-windows -t "$session:" \
|
||||
-F "#{window_index}" 2>/dev/null)
|
||||
|
||||
if [ -n "$index" ]; then
|
||||
echo "$index" | head -1
|
||||
else
|
||||
@@ -294,18 +377,38 @@ __get_first_window_index() {
|
||||
fi
|
||||
}
|
||||
|
||||
__get_current_window_index() {
|
||||
local lookup=$(tmuxifier-tmux list-windows -t "$session:" \
|
||||
-F "#{window_active}:#{window_index}" 2>/dev/null | grep "^1:")
|
||||
|
||||
if [ -n "$lookup" ]; then
|
||||
echo "${lookup/1:}"
|
||||
fi
|
||||
}
|
||||
|
||||
__go_to_session() {
|
||||
if [ -z "$TMUX" ]; then
|
||||
tmux -u attach-session -t "$session:"
|
||||
tmuxifier-tmux $TMUXIFIER_TMUX_ITERM_ATTACH -u \
|
||||
attach-session -t "$session:"
|
||||
else
|
||||
tmux -u switch-client -t "$session:"
|
||||
tmuxifier-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\""
|
||||
run_cmd "clear"
|
||||
local target_path
|
||||
|
||||
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"
|
||||
fi
|
||||
}
|
||||
|
||||
@@ -14,7 +14,7 @@ Outputs the name of the current Tmux session."
|
||||
fi
|
||||
|
||||
if [ -n "$TMUX" ]; then
|
||||
for item in $(tmux list-pane -F "#{session_name}");do
|
||||
for item in $(tmuxifier-tmux list-pane -F "#{session_name}");do
|
||||
echo $item
|
||||
exit 0
|
||||
done
|
||||
|
||||
@@ -38,7 +38,7 @@ if [ ! -f "$layout_file" ]; then
|
||||
fi
|
||||
|
||||
if [ -n "$EDITOR" ]; then
|
||||
exec "$EDITOR" "$layout_file"
|
||||
exec $EDITOR "$layout_file"
|
||||
else
|
||||
echo "'\$EDITOR' is not set. Please manually open the layout for editing:"
|
||||
echo "$layout_file"
|
||||
|
||||
@@ -38,7 +38,7 @@ if [ ! -f "$layout_file" ]; then
|
||||
fi
|
||||
|
||||
if [ -n "$EDITOR" ]; then
|
||||
exec "$EDITOR" "$layout_file"
|
||||
exec $EDITOR "$layout_file"
|
||||
else
|
||||
echo "'\$EDITOR' is not set. Please manually open the layout for editing:"
|
||||
echo "$layout_file"
|
||||
|
||||
@@ -35,7 +35,7 @@ Some useful tmuxifier commands are:
|
||||
new-window nw Create new window layout and open it with \$EDITOR.
|
||||
edit-session es Edit specified session layout with \$EDITOR.
|
||||
edit-window ew Edit specified window layout with \$EDITOR.
|
||||
commands List all tmuxifier commands.
|
||||
commands List all tmuxifier commands (including internal).
|
||||
version Print Tmuxifier version.
|
||||
help Show this message.
|
||||
|
||||
|
||||
@@ -29,6 +29,9 @@ case "$shell" in
|
||||
tcsh )
|
||||
profile='~/.tcshrc'
|
||||
;;
|
||||
fish )
|
||||
profile='~/.config/fish/config.fish'
|
||||
;;
|
||||
* )
|
||||
profile='shell init file'
|
||||
;;
|
||||
@@ -44,6 +47,10 @@ Load Tmuxifier by adding the following to your ${profile}:
|
||||
case "$shell" in
|
||||
csh | tcsh )
|
||||
echo " eval \`tmuxifier init -\`
|
||||
"
|
||||
;;
|
||||
fish )
|
||||
echo " eval (tmuxifier init -)
|
||||
"
|
||||
;;
|
||||
* )
|
||||
@@ -67,6 +74,15 @@ case "$shell" in
|
||||
echo "setenv TMUXIFIER \"$TMUXIFIER\";"
|
||||
echo "source \"\$TMUXIFIER/init.tcsh\";"
|
||||
;;
|
||||
fish )
|
||||
echo "set -gx TMUXIFIER \"$TMUXIFIER\";"
|
||||
# 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 "source \"\$TMUXIFIER/init.sh\";"
|
||||
|
||||
@@ -15,7 +15,7 @@ List all session layouts."
|
||||
exit
|
||||
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
|
||||
file=${file/$TMUXIFIER_LAYOUT_PATH\//}
|
||||
echo "${file/.session.sh/}"
|
||||
|
||||
@@ -15,7 +15,7 @@ List all window layouts."
|
||||
exit
|
||||
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
|
||||
file=${file/$TMUXIFIER_LAYOUT_PATH\//}
|
||||
echo "${file/.window.sh/}"
|
||||
|
||||
@@ -7,12 +7,19 @@ source "$TMUXIFIER/lib/util.sh"
|
||||
|
||||
# Provide tmuxifier help
|
||||
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
|
||||
|
||||
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: https://iterm2.com"
|
||||
exit
|
||||
fi
|
||||
|
||||
@@ -30,5 +37,9 @@ fi
|
||||
# Load runtime functions.
|
||||
source "$TMUXIFIER/lib/runtime.sh"
|
||||
|
||||
if [ "$2" == "-CC" ]; then
|
||||
export TMUXIFIER_TMUX_ITERM_ATTACH="-CC"
|
||||
fi
|
||||
|
||||
# Load session file.
|
||||
load_session "$1"
|
||||
|
||||
@@ -11,7 +11,11 @@ if calling-help "$@"; then
|
||||
|
||||
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
|
||||
fi
|
||||
|
||||
|
||||
@@ -47,7 +47,7 @@ content="$(cat "$template")"
|
||||
echo "${content//\{\{SESSION_NAME\}\}/$layout_name}" > "$layout_file"
|
||||
|
||||
if [ -n "$EDITOR" ]; then
|
||||
exec "$EDITOR" "$layout_file"
|
||||
exec $EDITOR "$layout_file"
|
||||
else
|
||||
echo "Layout file has been created, but '\$EDITOR' is not set. Please "
|
||||
echo "manually open the layout for editing:"
|
||||
|
||||
@@ -47,7 +47,7 @@ content="$(cat "$template")"
|
||||
echo "${content//\{\{WINDOW_NAME\}\}/$layout_name}" > "$layout_file"
|
||||
|
||||
if [ -n "$EDITOR" ]; then
|
||||
exec "$EDITOR" "$layout_file"
|
||||
exec $EDITOR "$layout_file"
|
||||
else
|
||||
echo "Layout file has been created, but '\$EDITOR' is not set. Please "
|
||||
echo "manually open the layout for editing:"
|
||||
|
||||
5
libexec/tmuxifier-tmux
Executable file
5
libexec/tmuxifier-tmux
Executable file
@@ -0,0 +1,5 @@
|
||||
#! /usr/bin/env bash
|
||||
set -e
|
||||
[ -n "$TMUXIFIER_DEBUG" ] && set -x
|
||||
|
||||
tmux $TMUXIFIER_TMUX_OPTS "$@"
|
||||
70
libexec/tmuxifier-tmux-version
Executable file
70
libexec/tmuxifier-tmux-version
Executable file
@@ -0,0 +1,70 @@
|
||||
#! /usr/bin/env bash
|
||||
shopt -s extglob
|
||||
[ -n "$TMUXIFIER_DEBUG" ] && set -x
|
||||
|
||||
# Load internal utility functions.
|
||||
source "$TMUXIFIER/lib/util.sh"
|
||||
|
||||
# Provide tmuxifier help
|
||||
if calling-help "$@"; then
|
||||
echo "usage: tmuxifier tmux-version [<target-version>]
|
||||
|
||||
Outputs current Tmux version. If given optional target-version it outputs one
|
||||
of three possible characters indicating if the current Tmux version number is
|
||||
equal to, less than, or greater than the <target-version>.
|
||||
|
||||
The three possible outputs are \"=\", \"<\", and \">\"."
|
||||
exit
|
||||
fi
|
||||
|
||||
# The vercomp() function is shamelessly ripped/borrowed from the following
|
||||
# StackOverflow answer: http://stackoverflow.com/a/4025065/42146
|
||||
vercomp () {
|
||||
if [[ $1 == $2 ]]; then return 0; fi
|
||||
|
||||
local IFS=.
|
||||
local i ver1=($1) ver2=($2)
|
||||
|
||||
# fill empty fields in ver1 with zeros
|
||||
for ((i=${#ver1[@]}; i<${#ver2[@]}; i++)); do ver1[i]=0; done
|
||||
|
||||
for ((i=0; i<${#ver1[@]}; i++)); do
|
||||
# fill empty fields in ver2 with zeros
|
||||
if [[ -z ${ver2[i]} ]]; then ver2[i]=0; fi
|
||||
|
||||
if ((10#${ver1[i]} > 10#${ver2[i]})); then
|
||||
return 1
|
||||
elif ((10#${ver1[i]} < 10#${ver2[i]})); then
|
||||
return 2
|
||||
fi
|
||||
done
|
||||
return 0
|
||||
}
|
||||
|
||||
version=$(tmux -V)
|
||||
version=${version/tmux /}
|
||||
|
||||
# Fix for tmux next-* versions
|
||||
version=${version/next-/}
|
||||
|
||||
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
|
||||
# purely numeric version numbers.
|
||||
version=${version//+([a-zA-Z])/}
|
||||
|
||||
vercomp "$version" "$1"
|
||||
case $? in
|
||||
0) echo '=';;
|
||||
1) echo '>';;
|
||||
2) echo '<';;
|
||||
esac
|
||||
fi
|
||||
@@ -13,4 +13,4 @@ Outputs Tmuxifier version."
|
||||
exit
|
||||
fi
|
||||
|
||||
echo "0.8.1"
|
||||
echo "0.13.0"
|
||||
|
||||
@@ -16,7 +16,7 @@ new_window "{{WINDOW_NAME}}"
|
||||
|
||||
# Paste text
|
||||
#send_keys "top" # paste into active pane
|
||||
#send_keys "date" 1 # paste into active pane
|
||||
#send_keys "date" 1 # paste into pane 1
|
||||
|
||||
# Set active pane.
|
||||
#select_pane 0
|
||||
|
||||
33
test/lib/env.test.sh
Executable file
33
test/lib/env.test.sh
Executable file
@@ -0,0 +1,33 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../test-helper.sh"
|
||||
|
||||
#
|
||||
# env.sh tests.
|
||||
#
|
||||
|
||||
# Setup.
|
||||
realTMUXIFIER="$TMUXIFIER"
|
||||
TMUXIFER="/path/to/tmuxifier"
|
||||
|
||||
# When TMUXIFIER_LAYOUT_PATH is not set.
|
||||
source "${root}/lib/env.sh"
|
||||
assert 'echo $TMUXIFIER_LAYOUT_PATH' "${TMUXIFIER}/layouts"
|
||||
|
||||
# When TMUXIFIER_LAYOUT_PATH is set and has a trailing slash.
|
||||
TMUXIFIER_LAYOUT_PATH="/path/to/layouts/"
|
||||
source "${root}/lib/env.sh"
|
||||
assert 'echo $TMUXIFIER_LAYOUT_PATH' "/path/to/layouts"
|
||||
unset TMUXIFIER_LAYOUT_PATH
|
||||
|
||||
# When TMUXIFIER_LAYOUT_PATH is set and does not have a trailing slash.
|
||||
TMUXIFIER_LAYOUT_PATH="/path/to/layouts"
|
||||
source "${root}/lib/env.sh"
|
||||
assert 'echo $TMUXIFIER_LAYOUT_PATH' "/path/to/layouts"
|
||||
unset TMUXIFIER_LAYOUT_PATH
|
||||
|
||||
# Tear down.
|
||||
TMUXIFER="$realTMUXIFIER"
|
||||
unset realTMUXIFIER
|
||||
|
||||
# End of tests.
|
||||
assert_end "env.sh"
|
||||
27
test/lib/layout-helpers/__expand_path.test.sh
Executable file
27
test/lib/layout-helpers/__expand_path.test.sh
Executable file
@@ -0,0 +1,27 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../../test-helper.sh"
|
||||
source "${root}/lib/layout-helpers.sh"
|
||||
|
||||
#
|
||||
# __expand_path() tests.
|
||||
#
|
||||
|
||||
# Setup.
|
||||
realHOME="$HOME"
|
||||
HOME="/home/test-user"
|
||||
|
||||
# When given a path containing "~", it expands "~" to "$HOME".
|
||||
assert '__expand_path "~/Foo/Bar"' "${HOME}/Foo/Bar"
|
||||
|
||||
# When given a path without "~", it returns path as is.
|
||||
assert '__expand_path "/path/to/file"' "/path/to/file"
|
||||
|
||||
# When given a path containing spaces, it returns path correctly.
|
||||
assert '__expand_path "~/Path To/File"' "${HOME}/Path To/File"
|
||||
|
||||
# Tear down.
|
||||
HOME="$realHOME"
|
||||
unset realHOME
|
||||
|
||||
# End of tests.
|
||||
assert_end "__expand_path()"
|
||||
48
test/lib/layout-helpers/__get_current_window_index.test.sh
Executable file
48
test/lib/layout-helpers/__get_current_window_index.test.sh
Executable file
@@ -0,0 +1,48 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../../test-helper.sh"
|
||||
source "${root}/lib/layout-helpers.sh"
|
||||
|
||||
#
|
||||
# __get_current_window_index() tests.
|
||||
#
|
||||
|
||||
# When current window is the first and only window.
|
||||
create-test-session
|
||||
assert "__get_current_window_index" "0"
|
||||
kill-test-session
|
||||
|
||||
# When creating a second window.
|
||||
create-test-session
|
||||
test-socket-tmux new-window -t "$session:1"
|
||||
assert "__get_current_window_index" "1"
|
||||
kill-test-session
|
||||
|
||||
# When creating a second window and then switching back to the first window.
|
||||
create-test-session
|
||||
test-socket-tmux new-window -t "$session:1"
|
||||
test-socket-tmux select-window -t "$session:0"
|
||||
assert "__get_current_window_index" "0"
|
||||
kill-test-session
|
||||
|
||||
# When creating multiples windows and switching between them randomly.
|
||||
create-test-session
|
||||
assert "__get_current_window_index" "0"
|
||||
test-socket-tmux new-window -t "$session:1"
|
||||
assert "__get_current_window_index" "1"
|
||||
test-socket-tmux new-window -t "$session:2"
|
||||
assert "__get_current_window_index" "2"
|
||||
test-socket-tmux new-window -t "$session:3"
|
||||
assert "__get_current_window_index" "3"
|
||||
test-socket-tmux select-window -t "$session:1"
|
||||
assert "__get_current_window_index" "1"
|
||||
test-socket-tmux select-window -t "$session:0"
|
||||
assert "__get_current_window_index" "0"
|
||||
test-socket-tmux select-window -t "$session:3"
|
||||
assert "__get_current_window_index" "3"
|
||||
test-socket-tmux select-window -t "$session:2"
|
||||
assert "__get_current_window_index" "2"
|
||||
kill-test-session
|
||||
|
||||
|
||||
# End of tests.
|
||||
assert_end "__get_current_window_index()"
|
||||
30
test/lib/layout-helpers/__get_first_window_index.test.sh
Executable file
30
test/lib/layout-helpers/__get_first_window_index.test.sh
Executable file
@@ -0,0 +1,30 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../../test-helper.sh"
|
||||
source "${root}/lib/layout-helpers.sh"
|
||||
|
||||
#
|
||||
# __get_first_window_index() tests.
|
||||
#
|
||||
|
||||
# When first window has a index of 0.
|
||||
create-test-session
|
||||
assert "__get_first_window_index" "0"
|
||||
kill-test-session
|
||||
|
||||
# When first window has a index of 1.
|
||||
create-test-session
|
||||
test-socket-tmux new-window -t "$session:1"
|
||||
test-socket-tmux kill-window -t "$session:0"
|
||||
assert "__get_first_window_index" "1"
|
||||
kill-test-session
|
||||
|
||||
# When first window has a index of 2.
|
||||
create-test-session
|
||||
test-socket-tmux new-window -t "$session:2"
|
||||
test-socket-tmux kill-window -t "$session:0"
|
||||
assert "__get_first_window_index" "2"
|
||||
kill-test-session
|
||||
|
||||
|
||||
# End of tests.
|
||||
assert_end "__get_first_window_index()"
|
||||
42
test/lib/layout-helpers/__go_to_session.test.sh
Executable file
42
test/lib/layout-helpers/__go_to_session.test.sh
Executable file
@@ -0,0 +1,42 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../../test-helper.sh"
|
||||
source "${root}/lib/layout-helpers.sh"
|
||||
|
||||
#
|
||||
# __go_to_session() tests.
|
||||
#
|
||||
|
||||
# Setup.
|
||||
session="tmuxifier-test-session"
|
||||
|
||||
# When TMUX is not set, attach to $session.
|
||||
stub tmuxifier-tmux
|
||||
__go_to_session
|
||||
assert_raises \
|
||||
"stub_called_with tmuxifier-tmux -u attach-session -t \"${session}:\"" 0
|
||||
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.
|
||||
TMUX="/tmp/tmux-501/default,1203,0"
|
||||
stub tmuxifier-tmux
|
||||
__go_to_session
|
||||
assert_raises \
|
||||
"stub_called_with tmuxifier-tmux -u switch-client -t \"${session}:\"" 0
|
||||
restore tmuxifier-tmux
|
||||
unset TMUX
|
||||
|
||||
# Tear down.
|
||||
unset session
|
||||
|
||||
# End of tests.
|
||||
assert_end "__go_to_session()"
|
||||
88
test/lib/layout-helpers/__go_to_window_or_session_path.test.sh
Executable file
88
test/lib/layout-helpers/__go_to_window_or_session_path.test.sh
Executable file
@@ -0,0 +1,88 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../../test-helper.sh"
|
||||
source "${root}/lib/layout-helpers.sh"
|
||||
|
||||
#
|
||||
# __go_to_window_or_session_path() tests.
|
||||
#
|
||||
|
||||
# When neither $window_root or $session_root are set, does nothing.
|
||||
stub run_cmd
|
||||
__go_to_window_or_session_path
|
||||
assert "stub_called_times run_cmd" "0"
|
||||
restore run_cmd
|
||||
|
||||
|
||||
# When only $window_root is set, runs cd to $window_root path.
|
||||
stub run_cmd
|
||||
window_root="/tmp"
|
||||
__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
|
||||
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.
|
||||
stub run_cmd
|
||||
session_root="/usr"
|
||||
__go_to_window_or_session_path
|
||||
assert 'stub_called_with_times run_cmd cd \"/usr\"' "1"
|
||||
assert 'stub_called_with_times run_cmd clear' "1"
|
||||
unset session_root
|
||||
restore run_cmd
|
||||
|
||||
|
||||
# When $window_root and $session_root are set, runs cd to $window_root path.
|
||||
stub run_cmd
|
||||
window_root="/tmp"
|
||||
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 session_root
|
||||
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.
|
||||
assert_end "__go_to_window_or_session_path()"
|
||||
59
test/lib/layout-helpers/new_window.test.sh
Executable file
59
test/lib/layout-helpers/new_window.test.sh
Executable file
@@ -0,0 +1,59 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../../test-helper.sh"
|
||||
source "${root}/lib/layout-helpers.sh"
|
||||
|
||||
#
|
||||
# new_window() tests.
|
||||
#
|
||||
|
||||
# When called without arguments, creates new window.
|
||||
create-test-session
|
||||
stub __go_to_window_or_session_path
|
||||
assert "test-socket-window-count" "1"
|
||||
new_window
|
||||
assert "test-socket-window-count" "2"
|
||||
assert "stub_called_times __go_to_window_or_session_path" "1"
|
||||
restore __go_to_window_or_session_path
|
||||
kill-test-session
|
||||
|
||||
# When called with name argument, creates new window with specified name.
|
||||
create-test-session
|
||||
stub __go_to_window_or_session_path
|
||||
assert "test-socket-window-count yippieezzz" "0"
|
||||
new_window "yippieezzz"
|
||||
assert "test-socket-window-count" "2"
|
||||
assert "test-socket-window-count yippieezzz" "1"
|
||||
restore __go_to_window_or_session_path
|
||||
kill-test-session
|
||||
|
||||
# When called with name and command argument, creates new window with
|
||||
# specified name and executes given command.
|
||||
rm "/tmp/tmuxifier-new_window-test" &> /dev/null
|
||||
create-test-session
|
||||
stub __go_to_window_or_session_path
|
||||
new_window "foobardoo" "touch /tmp/tmuxifier-new_window-test; bash"
|
||||
assert "test-socket-window-count" "2"
|
||||
assert "test-socket-window-count foobardoo" "1"
|
||||
sleep 0.1 # attempt to avoid timing issue causing flicker
|
||||
assert_raises 'test -f "/tmp/tmuxifier-new_window-test"' 0
|
||||
restore __go_to_window_or_session_path
|
||||
kill-test-session
|
||||
rm "/tmp/tmuxifier-new_window-test" &> /dev/null
|
||||
|
||||
# When called ensure it sets the $window variable to the index of the newly
|
||||
# created window.
|
||||
unset window
|
||||
create-test-session
|
||||
stub __go_to_window_or_session_path
|
||||
new_window "foo"
|
||||
assert "echo $window" "1"
|
||||
new_window
|
||||
assert "echo $window" "2"
|
||||
new_window "bar"
|
||||
assert "echo $window" "3"
|
||||
restore __go_to_window_or_session_path
|
||||
kill-test-session
|
||||
unset window
|
||||
|
||||
# End of tests.
|
||||
assert_end "new_window()"
|
||||
55
test/lib/layout-helpers/select_window.test.sh
Executable file
55
test/lib/layout-helpers/select_window.test.sh
Executable file
@@ -0,0 +1,55 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../../test-helper.sh"
|
||||
source "${root}/lib/layout-helpers.sh"
|
||||
|
||||
#
|
||||
# select_window() tests.
|
||||
#
|
||||
|
||||
window_list() {
|
||||
test-socket-tmux list-windows -t "$session:" \
|
||||
-F "#{window_active}:#{window_index}" 2>/dev/null
|
||||
}
|
||||
|
||||
# Selects given window when passed a window index
|
||||
create-test-session
|
||||
test-socket-tmux new-window -t "$session:1"
|
||||
test-socket-tmux new-window -t "$session:2"
|
||||
select_window 0
|
||||
assert "window_list | grep '^1:'" "1:0"
|
||||
select_window 1
|
||||
assert "window_list | grep '^1:'" "1:1"
|
||||
select_window 2
|
||||
assert "window_list | grep '^1:'" "1:2"
|
||||
kill-test-session
|
||||
|
||||
# Selects given window when passed a window name
|
||||
create-test-session
|
||||
test-socket-tmux new-window -t "$session:1" -n "foo"
|
||||
test-socket-tmux new-window -t "$session:2" -n "bar"
|
||||
select_window foo
|
||||
assert "window_list | grep '^1:'" "1:1"
|
||||
select_window bar
|
||||
assert "window_list | grep '^1:'" "1:2"
|
||||
kill-test-session
|
||||
|
||||
|
||||
# When called ensure it sets the $window variable to the index of the newly
|
||||
# created window.
|
||||
unset window
|
||||
create-test-session
|
||||
test-socket-tmux new-window -t "$session:1" -n "foo"
|
||||
test-socket-tmux new-window -t "$session:2" -n "bar"
|
||||
select_window "foo"
|
||||
assert "echo $window" "1"
|
||||
select_window "bar"
|
||||
assert "echo $window" "2"
|
||||
select_window 1
|
||||
assert "echo $window" "1"
|
||||
select_window 2
|
||||
assert "echo $window" "2"
|
||||
kill-test-session
|
||||
unset window
|
||||
|
||||
# End of tests.
|
||||
assert_end "select_window()"
|
||||
20
test/lib/layout-helpers/tmux.test.sh
Executable file
20
test/lib/layout-helpers/tmux.test.sh
Executable file
@@ -0,0 +1,20 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../../test-helper.sh"
|
||||
source "${root}/lib/layout-helpers.sh"
|
||||
|
||||
#
|
||||
# tmux() tests.
|
||||
#
|
||||
|
||||
# Passes all arguments to tmuxifier-tmux.
|
||||
stub tmuxifier-tmux
|
||||
tmux -V
|
||||
tmux --help
|
||||
tmux new -s dude
|
||||
assert_raises "stub_called_with tmuxifier-tmux -V" 0
|
||||
assert_raises "stub_called_with tmuxifier-tmux --help" 0
|
||||
assert_raises "stub_called_with tmuxifier-tmux new -s dude" 0
|
||||
restore tmuxifier-tmux
|
||||
|
||||
# End of tests.
|
||||
assert_end "tmux()"
|
||||
23
test/lib/runtime.test.sh
Executable file
23
test/lib/runtime.test.sh
Executable file
@@ -0,0 +1,23 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../test-helper.sh"
|
||||
|
||||
#
|
||||
# runtime.sh tests.
|
||||
#
|
||||
|
||||
source "${root}/lib/runtime.sh"
|
||||
|
||||
# We assume env.sh has been sourced if $TMUXIFIER_LAYOUT_PATH has been set.
|
||||
assert 'echo $TMUXIFIER_LAYOUT_PATH' "${TMUXIFIER}/layouts"
|
||||
|
||||
# We ensure $session_root is set to $HOME by default.
|
||||
assert 'echo $session_root' "$HOME"
|
||||
|
||||
# We assume layout-helpers.sh has been sourced if a few of them are available.
|
||||
for helper in new_window split_v split_h select_window select_pane; do
|
||||
assert "type $helper | head -1" "$helper is a function"
|
||||
done
|
||||
|
||||
|
||||
# End of tests.
|
||||
assert_end "runtime.sh"
|
||||
58
test/lib/util.test.sh
Executable file
58
test/lib/util.test.sh
Executable file
@@ -0,0 +1,58 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../test-helper.sh"
|
||||
source "${root}/lib/util.sh"
|
||||
|
||||
#
|
||||
# calling-help() tests.
|
||||
#
|
||||
|
||||
# Returns 0 when "--help" is part of passed arguments.
|
||||
assert_raises 'calling-help --help' 0
|
||||
assert_raises 'calling-help foo --help' 0
|
||||
assert_raises 'calling-help --help bar' 0
|
||||
assert_raises 'calling-help foo --help bar' 0
|
||||
|
||||
# Returns 0 when "-h" is part of passed arguments.
|
||||
assert_raises 'calling-help -h' 0
|
||||
assert_raises 'calling-help foo -h' 0
|
||||
assert_raises 'calling-help -h bar' 0
|
||||
assert_raises 'calling-help foo -h bar' 0
|
||||
|
||||
# Returns 1 when neither "--help" or "-h" is not part of passed arguments.
|
||||
assert_raises 'calling-help' 1
|
||||
assert_raises 'calling-help foo' 1
|
||||
assert_raises 'calling-help foo bar' 1
|
||||
|
||||
# Returns 1 when "--help" is part of passed arguments, but not free-standing.
|
||||
assert_raises 'calling-help --help-me' 1
|
||||
assert_raises 'calling-help foo--help' 1
|
||||
|
||||
# Returns 1 when "-h" is part of passed arguments, but not free-standing.
|
||||
assert_raises 'calling-help -hj' 1
|
||||
assert_raises 'calling-help welcome-home' 1
|
||||
|
||||
# End of tests.
|
||||
assert_end "calling-help()"
|
||||
|
||||
|
||||
#
|
||||
# calling-complete() tests.
|
||||
#
|
||||
|
||||
# Returns 0 when "--complete" is part of passed arguments.
|
||||
assert_raises 'calling-complete --complete' 0
|
||||
assert_raises 'calling-complete foo --complete' 0
|
||||
assert_raises 'calling-complete --complete bar' 0
|
||||
assert_raises 'calling-complete foo --complete bar' 0
|
||||
|
||||
# Returns 1 when "--complete" is not part of passed arguments.
|
||||
assert_raises 'calling-complete' 1
|
||||
assert_raises 'calling-complete foo' 1
|
||||
assert_raises 'calling-complete foo bar' 1
|
||||
|
||||
# Returns 1 when "--complete" is part of passed arguments, but not free-standing.
|
||||
assert_raises 'calling-complete --complete-me' 1
|
||||
assert_raises 'calling-complete foo--complete' 1
|
||||
|
||||
# End of tests.
|
||||
assert_end "calling-complete()"
|
||||
22
test/libexec/tmuxifier-tmux.test.sh
Executable file
22
test/libexec/tmuxifier-tmux.test.sh
Executable file
@@ -0,0 +1,22 @@
|
||||
#! /usr/bin/env bash
|
||||
source "../test-helper.sh"
|
||||
source "${root}/lib/util.sh"
|
||||
|
||||
#
|
||||
# tmuxifier-tmux tests.
|
||||
#
|
||||
|
||||
# Setup.
|
||||
libexec="${root}/libexec"
|
||||
test-socket-tmux new-session -d -s foobar
|
||||
test-socket-tmux new-session -d -s dude
|
||||
|
||||
# Passes all arguments to Tmux.
|
||||
assert "${libexec}/tmuxifier-tmux list-sessions -F \"- #{session_name}\"" \
|
||||
"- dude\n- foobar"
|
||||
|
||||
# Tear down.
|
||||
kill-test-server
|
||||
|
||||
# End of tests.
|
||||
assert_end "tmuxifier-tmux"
|
||||
87
test/test-helper.sh
Normal file
87
test/test-helper.sh
Normal file
@@ -0,0 +1,87 @@
|
||||
[ -n "$TEST_DEBUG" ] && set -x
|
||||
|
||||
resolve_link() {
|
||||
$(type -p greadlink readlink | head -1) $1
|
||||
}
|
||||
|
||||
abs_dirname() {
|
||||
local cwd="$(pwd)"
|
||||
local path="$1"
|
||||
|
||||
while [ -n "$path" ]; do
|
||||
cd "${path%/*}"
|
||||
local name="${path##*/}"
|
||||
path="$(resolve_link "$name" || true)"
|
||||
done
|
||||
|
||||
pwd
|
||||
cd "$cwd"
|
||||
}
|
||||
|
||||
# Find and store path to Tmux binary.
|
||||
TMUX_BIN="$(command -v tmux)"
|
||||
|
||||
# Set testroot variable.
|
||||
testroot="$(abs_dirname "$BASH_SOURCE")"
|
||||
|
||||
# Set root variable.
|
||||
root="$(abs_dirname "$testroot/../..")"
|
||||
|
||||
# Set TMUXIFIER environment variable.
|
||||
TMUXIFIER="$root"
|
||||
|
||||
# Setup PATH environment variable.
|
||||
PATH="$root/bin:$root/libexec:$PATH"
|
||||
|
||||
# Unset TMUX environment variable, tests assume they're not running within
|
||||
# Tmux.
|
||||
unset TMUX
|
||||
|
||||
# Unset various Tmuxifier environment variables to prevent a local install of
|
||||
# Tmuxifier interfering with tests.
|
||||
unset TMUXIFIER_LAYOUT_PATH
|
||||
unset TMUXIFIER_TMUX_OPTS
|
||||
unset TMUXIFIER_NO_COMPLETE
|
||||
|
||||
# Include assert.sh and stub.sh libraries.
|
||||
source "${testroot}/assert.sh"
|
||||
source "${testroot}/stub.sh"
|
||||
|
||||
|
||||
#
|
||||
# Test Helpers
|
||||
#
|
||||
|
||||
test-socket-tmux() {
|
||||
export TMUXIFIER_TMUX_OPTS="-L tmuxifier-tests"
|
||||
"$TMUX_BIN" $TMUXIFIER_TMUX_OPTS $@
|
||||
}
|
||||
|
||||
create-test-session() {
|
||||
session="$1"
|
||||
if [ -z "$session" ]; then session="test"; fi
|
||||
|
||||
test-socket-tmux new-session -d -s "$session"
|
||||
}
|
||||
|
||||
kill-test-session() {
|
||||
local target="$1"
|
||||
if [ -z "$target" ]; then target="$session"; fi
|
||||
|
||||
test-socket-tmux kill-session -t "$target"
|
||||
}
|
||||
|
||||
kill-test-server() {
|
||||
test-socket-tmux kill-server
|
||||
unset TMUXIFIER_TMUX_OPTS
|
||||
unset session
|
||||
}
|
||||
|
||||
test-socket-window-count() {
|
||||
local list="$(test-socket-tmux list-windows)"
|
||||
if [ -n "$1" ]; then
|
||||
echo "$list" | grep $1 | wc -l | awk '{print $1}'
|
||||
else
|
||||
echo "$list" | wc -l | awk '{print $1}'
|
||||
fi
|
||||
}
|
||||
1
tmuxifier.tmux
Executable file
1
tmuxifier.tmux
Executable file
@@ -0,0 +1 @@
|
||||
#!/usr/bin/env bash
|
||||
Reference in New Issue
Block a user