iTerm2 has a collection of shell scripts that help you take advantage of some of its unique features. When you install Shell Integration from the iTerm2 > Install Shell Integration menu, you're asked if you'd like to install the Utilities Package as well. This page describes these utilities.
If you prefer to install only the utilities (without also installing Shell Integration) you can find them here. Most of the utilities work without Shell Integration.
The Utilities Package contains the following programs:
imgcat program displays images inline in your terminal.
It supports all standard image formats, including animated GIFs.
imgcat filename [filename...]
cat image | imgcat
Lists the files in a directory with thumbnail previews for images.
Requests attention. Can bounce the dock icon or show a fireworks animation at the application cursor position.
- `it2attention start`
Begin bouncing the dock icon if another app is active
- `it2attention stop`
Stop bouncing the dock icon if another app is active
Show an explosion animation at the cursor
Checks if the terminal emulator is iTerm2.
it2check && echo This is iTerm2 || echo This is not iTerm2
Copies text to the pasteboard. Works over ssh. Accepts either standard input or a named file.
cat file.txt | it2copy it2copy file.txt
For this to work you must enable Prefs > General > Applications in terminal may access clipboard.
it2dl program downloads files. This is useful when you are ssh'ed to a remote host. The downloaded files are placed in your Downloads folder.
Fetches a session variable. For information about variables, see Scripting Fundamentals.
Configures iTerm2's colors.
- To set a specific color to an RGB value:
it2setcolor name color [name color...]For example:
it2setcolor fg fff
name is one of:
color is of the format:
RGB(three hex digits, like fff)
RRGGBB(six hex digits, like f0f0f0)
cs:RGB(cs is a color space name)
cs:RRGGBB(cs is a color space name)
The color space names accepted in the color are:
srgb(sRGB, the default if none is specified)
rgb(Apple's old device-independent colorspace)
p3(Apple's fancy large-gamut colorspace)
- To switch to a named color preset:
it2setcolor preset name
it2setcolor preset 'Light Background'
- To reset the current tab's color to the system default:
it2setcolor tab default
Configures touch bar function key labels.
it2setkeylabel set Fn Label
Where n is a value from 1 to 20
it2setkeylabel set status Label
Sets the Touch Bar "status" button's label
it2setkeylabel push [name]
Saves the current labels with an optional name. Resets labels to their default value, unless name begins with a . character.
it2setkeylabel pop [name]
If name is given, all key labels up to and including the one with the matching name are popped.
Recommended usage for customizing an application is to set key labels and then push with a name of a concatenation of the app's name (e.g., "emacs") and a random number. When the app exists, pop to that same name.
Uploads a file. Works over ssh.
it2ul [destination [tar flags]]
If given, the
destination specifies the directory to place downloaded files.
Further options are passed through to tar. See your system's manpage for tar for details.
If used without arguments, the file goes to the current directory. When you run this, you'll be prompted to select one or more files. Next, iTerm2 creates a
tar.gz file containing those files and base-64 encodes them. The it2ul script receives it, decodes it, and untars it with
-xzfC. Any arguments you provide go after a lone
Sets the unicode version for the current session. The key difference is that unicode 8 and unicode 9 use different width tables for emoji. Most apps aren't updated to use the unicode 9 tables, but Unicode 9 produces nicer results with fewer overlapping characters.
it2universion set 8
it2universion set 9
it2universion push [name]
Saves the current version with an optional
it2universion pop [name]
nameis given, all versions up to and including the one with the matching name are popped.
The Utilities Package places shell scripts in
$HOME/.iterm2/ and creates aliases to them at the bottom of