emamux
emamux copied to clipboard
tmux manipulation from Emacs
emamux.el

Interact with tmux from Emacs.
Screenshot

Introduction
emamux.el let emacs interact with tmux. emamux.el is inspired by tslime.vim and vimux.
Installation
emamux is available on MELPA and MELPA stable
You can install emamux with the following command.
M-x package-install [RET] emamux [RET]
Requirements
- Emacs 24 or higher.
- tmux 1.5
Basic Usage
emamux:send-command
Send command to specified target-session(session:window.pane).
Following is emamux:send-command demo with ido completion.

target-session is set as default at first emamux:send-command called.
You can change default target-session with C-u prefix.
emamux:yank-from-list-buffers
Yank from tmux buffer.
emamux:copy-kill-ring
Copy content of (car kill-ring) to tmux buffer
You can change buffer index with Numerical Prefix.
Following commands can be executed only within tmux
emamux:run-command
Run command in a small split pane(runner pane) where emacs is in.
emamux:run-last-command
Run last command in runner pane.
emamux:zoom-runner
Zoom runner runner pane. This command requires tmux 1.8 or higher.
emamux:inspect-runner
Move into the runner pane and enter the copy mode.
emamux:close-runner-pane
Close runner pane.
emamux:close-panes
Close all other panes in current window.
emamux:interrupt-runner
Interrupt command which is running in runner-pane.
emamux:clear-runner-history
Clear tmux history in runner-pane
Customize
emamux:completing-read-type
Completing read function type. You can choice from 'normal or 'ido, or 'helm.
emamux:default-orientation
Orientation of split pane, 'vertical or 'horizonal(Default is 'vertical).
emamux:runner-pane-height
Height of runner-pane(Default is 20).
emamux:use-nearest-pane
Use nearest pane as runner pane instead of splitting pane(Default is nil).
tmux configuration
It is useful for using emamux to show session name, window index and
pane index in tmux status bar.
# '#S' is session name, '#I' is window index, '#P' is pane index
set-option -g status-right '[#h###S:#I:#P]'
Default keymap
emamux defines default keymap. You can use it by following configuration.
;; Bind keymap prefix to Ctrl-z
(global-set-key (kbd "C-z") emamux:keymap)
Default keymap is as below.
| Key | Command |
|---|---|
| Prefix C-s | emamux:send-command |
| Prefix C-y | emamux:yank-from-list-buffers |
| Prefix M-! | emamux:run-command |
| Prefix M-r | emamux:run-last-command |
| Prefix M-s | emamux:run-region |
| Prefix C-i | emamux:inspect-runner |
| Prefix C-k | emamux:close-panes |
| Prefix C-c | emamux:interrupt-runner |
| Prefix M-k | emamux:clear-runner-history |
| Prefix c | emamux:new-window |
| Prefix C | emamux:clone-current-frame |
| Prefix 2 | emamux:split-window |
| Prefix 3 | emamux:split-window-horizontally |
Sample configuration
(custom-set-variables
'(emamux:completing-read-type 'helm))
Emamux Applications
- emamux-perl-test a set of commands to easily run perl tests
- emamux-ruby-test a set of commands to easily run ruby tests