From 78f4bd390ca34b407e0dceca243214e99f6e7e82 Mon Sep 17 00:00:00 2001 From: Bruce Hill Date: Thu, 27 Feb 2025 17:32:18 -0500 Subject: [PATCH] Initial commit --- terminal-escapes.md | 234 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 234 insertions(+) create mode 100755 terminal-escapes.md diff --git a/terminal-escapes.md b/terminal-escapes.md new file mode 100755 index 0000000..9caa541 --- /dev/null +++ b/terminal-escapes.md @@ -0,0 +1,234 @@ +#!/bin/env slides + +# Demystifying Terminal Escapes + +*by Bruce Hill* + +-------------------------------- + +Have you ever wondered how Vim and other +command-line programs manage to do cool +stuff with your terminal? + +Like drawing all over the place without +cluttering your command line history? + +-------------------------------- + +Well, it's not magic, and you can do it too! + +------------------------------- + +There are three main topics I'll cover: + +1. Printing terminal escape sequences +2. Getting and setting terminal information + +------------------------------- + +Most terminal emulators that you use +(iTerm, alacritty, GNOME terminal, etc) +are emulating old-school physical terminals +like the VT100: + +```demo +firefox --new-window https://en.wikipedia.org/wiki/VT100 +``` + +------------------------------- + +The way that terminals used to work is that +you would send bytes from a computer over +a wire to a terminal (the termination point +of the signal). + +## Commonly Sent + +- Text to print +- Escape sequences + +------------------------------- + +# Escape Sequences + +In order to do stuff like move the cursor +around, clear the screen, etc. you could +send an escape sequence to the terminal. + +One common escape sequence you might know +is the newline `\n` and carriage return `\r` +escapes. These moved the carriage on a +teletype to the next line or back to the +start of a line. + +```demo +term +``` + +------------------------------- + +# Operating System Commands + +More advanced escape sequences like +**Operating System Commands** let you +do more fancy stuff like moving the +cursor position to an arbitrary X/Y +position or setting the text color. + +The magic **Operating System Command** is two bytes: + +``` +\033[ +``` + +Also known as `\x1B[` or `\e[`. + +``` +\033[ +``` + +It tells the terminal that the next +thing that follows isn't text to print +but is a command that needs to run. + +------------------------------- + +Here are some fun operating system commands: + +```demo +ansi | less -R +``` + +*You can run these yourself with just a print statement!* + +------------------------------- + +Here's what's actually getting sent to the terminal: + +```demo +ansi | less +``` + +------------------------------- + +# Alternate Screens + +One of the most important operating system commands +is toggling the alternate screen on and off: + +``` +Alternate screen on: +\033[?1049h + +Alternate screen off: +\033[?1049l +``` + +This is what lets you run a terminal program +that doesn't spam the scrollback log! + +------------------------------- + +# Getting and Setting Info + +In C, there are some functions that let you +get information about the terminal + +------------------------------- + +## tcgetattr/tcsetattr + +Useful for reading one keypress at a time! + +```c +int tcgetattr(int fd, struct termios *termios_p); +int tcsetattr(int fd, int optional_actions, + const struct termios *termios_p); +void cfmakeraw(struct termios *termios_p); +``` + +```demo +man tcsetattr +``` + +------------------------------- + +## ioctl + +Useful for getting terminal width/height! + +```c +int ioctl(int fd, int op, ...); +``` + +```demo +man ioctl +``` + +------------------------------- + +# BTUI + +I wrote a library called **BTUI** +to do the bare minimum of this stuff: + +```demo +firefox --new-window https://github.com/bruce-hill/btui +``` + +(I really don't like ncurses, it's very bloated and unwieldy) + + +------------------------------- + +# slides + +This presentation is made using the BTUI library +and its Python bindings. + +Thanks to Michael Rees for the idea +to make a terminal slide presenter! + +```demo +firefox --new-window https://github.com/bruce-hill/slides +``` + +------------------------------- + +# Goodbye! + +Thanks for your time! +I'm **Bruce Hill** if you want to find me on zulip. + +------------------------------- + +# Bonus Demo 1: Conway's Game of Life + +```demo +conway +``` + +------------------------------- + +# Bonus Demo 2: Double Pendulum + +```demo +2pend +``` + +------------------------------- + +# Bonus Demo 3: Space Invaders + +```demo +cd ~/software/btui/Python/invaders +./invaders.py +``` + +------------------------------- + +# Bonus Demo 4: Alternate Character Set + +```demo +alternate-character-set | less -r +```