Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jamesottaway/tmux-up
Bootstrap new `tmux` sessions without complex tools, DSLs, or dependencies
https://github.com/jamesottaway/tmux-up
Last synced: 2 months ago
JSON representation
Bootstrap new `tmux` sessions without complex tools, DSLs, or dependencies
- Host: GitHub
- URL: https://github.com/jamesottaway/tmux-up
- Owner: jamesottaway
- License: mit
- Created: 2014-12-20T14:02:55.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2018-01-15T22:05:02.000Z (almost 7 years ago)
- Last Synced: 2024-08-01T16:43:46.502Z (5 months ago)
- Language: Shell
- Homepage:
- Size: 17.6 KB
- Stars: 112
- Watchers: 4
- Forks: 8
- Open Issues: 6
-
Metadata Files:
- Readme: README.markdown
- License: LICENSE.markdown
Awesome Lists containing this project
- my-awesome-github-stars - jamesottaway/tmux-up - Bootstrap new `tmux` sessions without complex tools, DSLs, or dependencies (Shell)
- awesome-tmux - tmux-up
README
# tmux-up
Bootstrap new `tmux` sessions without complex tools, DSLs, or dependencies.
## Install
If you use [fresh](http://freshshell.com/) to manage your dotfiles, just run:
```
fresh jamesottaway/tmux-up tmux-up --bin
```If not, you might want to try [bpkg](http://www.bpkg.io/):
```
bpkg install jamesottaway/tmux-up
```Alternatively just fetch the script with either `curl` or `wget`, and make sure it's executable:
```
curl -L https://git.io/tmux-up -o /usr/local/bin/tmux-up
wget https://git.io/tmux-up -O /usr/local/bin/tmux-up
chmod u+x /usr/local/bin/tmux-up
```## Usage
Define the desired initial state of your `tmux` session in a file, using the standard `tmux` commands.
For example, here is `dev.conf` for a fictional Rails application development environment:
```
send-keys 'git up' C-m
send-keys 'git checkout develop' C-m
send-keys 'bundle install' C-m
new-window
send-keys 'vim' C-m
new-window -n server
send-keys 'rails server' C-m
new-window -n console
send-keys 'rails console' C-m
new-window -n db
send-keys 'psql -d example_development' C-m
```To create a new `tmux` session using the above configuration just run:
```
~/example ❯ tmux-up dev.conf
```Under the hood `tmux-up` will:
- Create a `tmux` session named `example/dev`
- Invoke each line in `dev.conf`
- Switch to the first `tmux` window
- Attach to the `example/dev` sessionIf you detach from the `example/dev` session, simply re-run `tmux-up dev.conf` which will reattach you to the session.
## Alternatives
There are quite a lot of other approaches to this problem already floating around.
### tmuxinator, teamocil, etc.
These tools are very popular, but having a dependency on a working Ruby environment (or similar) for a simple tool like this seems like overkill.
As a contrast, `tmux-up` is a simple shell script, meaning it will run anywhere `tmux` will.
In addition to this, these tools commonly use abstracted formats to define your session configuration, which increases the difficulty of adopting such a tool.
In the case of `tmux-up`, you use native `tmux` commands like `new-window` and `send-keys`.
### Plain ol' tmux
The other end of the spectrum would be to invoke `tmux` directly, but override the configuration using the `-f` flag.
I don't like this approach, for two reasons:
- you need to add `source-file ~/.tmux.conf` (or wherever your default config lives) to ensure your top-level configuration is respected
- you need to remember to append the `attach` command, since `tmux` always calls `new-session` when it starts
To avoid these pitfalls, `tmux-up dev.conf` is functionally identical to `tmux -f dev.conf attach`.