/tmux-paste

Tmux plugin for pasting from system clipboard. Works on macOS, Linux, Cygwin, and WSL (Windows Subsystem For Linux).

Primary LanguageShellMIT LicenseMIT

tmux-paste

Tmux plugin for pasting from the system clipboard. Works on macOS, Linux, Cygwin, and WSL (Windows Subsystem For Linux).

Overview

The yang to tmux-yank's yin. Copy from the system clipboard into tmux.

Supports

  • Linux
  • macOS
  • Cygwin
  • Windows Subsystem for Linux (WSL)

Installing

Via TPM (recommended)

The easiest way to install tmux-paste is via the Tmux Plugin Manager.

  1. Add plugin to the list of TPM plugins in .tmux.conf:

    set -g @plugin 'brennanfee/tmux-paste'
  2. Use prefix-I install tmux-paste. You should now be able to tmux-paste immediately.

  3. When you want to update tmux-paste use prefix-U.

Manual Installation

  1. Clone the repository. Change the destination path ~/clone/path to wherever you would like.

    $ git clone https://github.com/brennanfee/tmux-paste ~/clone/path
  2. Add this line to the bottom of .tmux.conf. Change the path to the one you used in Step 1.

    run-shell ~/clone/path/paste.tmux
  3. Reload the tmux environment

    # type this inside tmux
    $ tmux source-file ~/.tmux.conf

You should now be able to use tmux-paste immediately.

Requirements

In order for tmux-paste to work, there must be a program that can get data from the system clipboard.

macOS

Note: Some versions of macOS (aka OS X) have been reported to work without reattach-to-user-namespace. It doesn't hurt to have it installed.

  • OS X 10.8: Mountain Lion – required
  • OS X 10.9: Mavericks – required
  • OS X 10.10: Yosemite – not required
  • OS X 10.11: El Capitan – not required
  • macOS 10.12: Sierra – required

The easiest way to use reattach-to-user-namespace with tmux is to use the tmux-sensible plugin.

To use it manually, use:

# ~/.tmux.conf
set-option -g default-command "reattach-to-user-namespace -l $SHELL"

HomeBrew (recommended)

$ brew install reattach-to-user-namespace

MacPorts

$ sudo port install tmux-pasteboard

Linux

  • xsel (recommended) or xclip.

Debian & Ubuntu

$ sudo apt-get install xsel # or xclip

RedHat & CentOS

$ sudo yum install xsel # or xclip

Arch Based Distros

$ sudo pacman -S xsel # or xclip

Cygwin

  • (optional) getclip which is part of the cygutils-extra package.

Windows Subsystem for Linux (WSL)

Microsoft helpfully provides clip.exe as part of the Windows installation. However, they do not include the counterpart as clip.exe is only one-way. However, PowerShell version 5 and above do provide a Get-Clipboard command which works well. PowerShell 5 comes pre-installed on Windows 10 and is available for older versions of Windows as a separate install.

Configuration

Key bindings

By default, this overrides the default prefix-] and maps the MouseUp2Pane mouse action (middle button or mouse-wheel click) to perform the paste. In essence, what happens is that BEFORE the standard tmux paste-buffer command is executed, we first execute the OS specific clipboard command to read the system clipboard into the paste buffer.

If you wish to override the key or mouse action you can set @paste_key or @paste_mouse_key respectively. To prevent a mapping entirely just set the value to a blank string.

NOTE: If you are not using tmux-yank along with tmux-paste you may experience some surprising behavior as your tmux buffer (which is usually just internal to tmux) will get overridden with the system clipboard data. However, if you are already using tmux-yank than the system clipboard will already have whatever you last copied to the tmux buffer and we will simply be copying it back here.

Default and Preferred Clipboard Programs

tmux-paste does its best to detect a reasonable choice for a clipboard program on your OS.

If tmux-paste can't detect a known clipboard program then it uses the @custom_paste_command tmux option as your clipboard program if set.

If you need to always override tmux-paste's choice for a clipboard program, then you can set @override_paste_command to force tmux-paste to use whatever you want.

Note that both programs must output to STDOUT for the text to be imported correctly.

An example of setting @override_paste_command:

# ~/.tmux.conf

set -g @override_paste_command 'my-clipboard-paste --some-arg'

Linux Clipboards

Linux has several cut-and-paste clipboards: primary, secondary, and clipboard (default in tmux-paste is clipboard).

You can change this by setting @paste_selection:

# ~/.tmux.conf

set -g @paste_selection 'primary' # or 'secondary' or 'clipboard'

There is a separate option for a mouse paste, @paste_selection_mouse, it's default is 'primary'.

Other great tmux plugins

  • tmux-copycat - a plugin for regular expression searches in tmux and fast match selection
  • tmux-open - a plugin for quickly opening highlighted file or a URL
  • tmux-continuum - automatic restoring and continuous saving of tmux environment.

A Thank You

I want to express my personal thanks to the folks behind tmux-plugins. I patterned this plugin and its structure heavily off tmux-yank. Your example led my way and I am grateful for your plugins and your example.

License

MIT © 2019 Brennan Fee