Human-readable ANSI sequences.
Sequin is a small utility that can help you debug your CLIs and TUIs. It's also great for describing escape sequences you might not understand, and exploring what TUIs are doing under the hood.
There are lots more use cases too, like inspecting golden files such as the
ones used by teatest
to crystalize Bubble Tea output.
Are you using Sequin in an interesting way? We’d love to hear about it.
Use a package manager:
# macOS or Linux
brew install charmbracelet/tap/sequin
# Arch Linux (btw)
yay -S sequin-bin
# Nix
nix-shell -p nur.repos.charmbracelet.sequin
Debian/Ubuntu
sudo mkdir -p /etc/apt/keyrings
curl -fsSL https://repo.charm.sh/apt/gpg.key | sudo gpg --dearmor -o /etc/apt/keyrings/charm.gpg
echo "deb [signed-by=/etc/apt/keyrings/charm.gpg] https://repo.charm.sh/apt/ * *" | sudo tee /etc/apt/sources.list.d/charm.list
sudo apt update && sudo apt install sequin
Fedora/RHEL
echo '[charm]
name=Charm
baseurl=https://repo.charm.sh/yum/
enabled=1
gpgcheck=1
gpgkey=https://repo.charm.sh/yum/gpg.key' | sudo tee /etc/yum.repos.d/charm.repo
sudo yum install sequin
Or, download it:
- Packages are available in Debian and RPM formats
- Binaries are available for Linux, macOS, Windows, FreeBSD, OpenBSD, and NetBSD
Or, just install it with go
:
go install github.com/charmbracelet/sequin@latest
Shell Completions
All the packages and archives come with pre-generated completion files for Bash, ZSH, Fish, and PowerShell.
If you built it from source, you can generate them with:
sequin completion bash -h
sequin completion zsh -h
sequin completion fish -h
sequin completion powershell -h
If you use a package (like Homebrew, Debs, etc), the completions should be set up automatically, given your shell is configured properly.
Just use printf
to send some sequences to sequin
for an explanation.
printf "\x1b[38;5;4mCiao, \x1b[1;7mBaby.\x1b[0m\n" | sequin
You can also use it to check the output of any program, for instance, ls
or git
.
ls -1 --color=always | sequin
git -c status.color=always status -sb | sequin
So yeah, it’s great for debugging applications, and of course, learning about ANSI!
Note
Many programs render their output as plain text when output isn't a terminal
(i.e. when redirecting to a file or piping to a program, like sequin
). This
is a good thing, except in this case when we actually want ANSI sequences so
we can inspect them. Thankfully there are usually ways to force colors, like
by setting CLICOLOR_FORCE=1
or with flags to force ANSI output. If you're
not seeing sequences be sure to to check what works in the case of your
specific program.
Golden file for TUIs contain ANSI, which can be easily inspected with sequin
:
cat ./testdata/MyCuteApp.golden | sequin
To generate golden files for your TUIs have a look at golden
and teatest
from the /x
project.
You can also execute commands directly in sequin:
sequin -- ls -1 go.*
One of the pain points that we find when reading raw ANSI output is
that it’s hard to visually separate sequences from regular text. For situations
like this you can use the --raw
/-r
flag to simply highlight sequences inline:
git -c status.color=always status -sb | sequin -r && echo
Sequin relies heavily on our glorious ansi
package, currently in the
elusive /x
project. Whilst traversing the strings, Sequin pretty prints
what the sequences are and what they’re doing.
No! Common sequences are implemented, but there is still plenty of work to do. For instance, APC sequences are not supported yet. If you notice one of such missing sequences, or want to work on any other area of the project, feel free to open a PR. 💘
Why isn't sequin using my terminal's background color? (with multiplexer)
related: #28This could be a few things depending on your environment. First thing to
consider: are you using a terminal multiplexer (e.g. tmux)? If so, check your
tmux version is 3.4 or higher. (Tmux added support for OSC10/11 queries in 3.4 see
/~https://github.com/tmux/tmux/blob/master/CHANGES#L152). Not sure which version of tmux you're using? tmux -V
If you're a GNU screen user, check that your version is 4.99.0 or higher to
ensure OSC10/11 can be used. Not sure which version of screen you're using? screen --version
Make sure your multiplexer config has your default terminal and COLORTERM
set.
set -g default-terminal "xterm-ghostty" setenv -g COLORTERM "truecolor"
term xterm-256color setenv COLORTERM truecolor defbce on
Note: if you don't set defbce on
, you will get a different background color on cells
cleared with an erase/insert/scroll/clear operation in the regular background
color.
We love contributions. We recommend checking out our contribution guidelines for faster responses on our end.
We’d love to hear your thoughts on this project. Feel free to drop us a note.
Part of Charm.
Charm热爱开源 • Charm loves open source