12 releases

0.3.4 Nov 27, 2024
0.3.3 Oct 12, 2024
0.2.1 Aug 18, 2024
0.1.4 Aug 15, 2024

#368 in Command-line interface

Download history 172/week @ 2024-08-17 3/week @ 2024-08-24 4/week @ 2024-09-14 18/week @ 2024-09-21 288/week @ 2024-09-28 443/week @ 2024-10-05 251/week @ 2024-10-12 12/week @ 2024-10-19 2/week @ 2024-10-26 188/week @ 2024-11-23 101/week @ 2024-11-30

289 downloads per month

MIT/Apache

1MB
1K SLoC

ttysvr

Screensavers for your terminal. Start immediately or after a period of inactivity within a shell.

Uses bevy_ratatui_render, my bevy plugin that allows you to render a bevy application to the terminal using ratatui and ratatui-image.

Triggering the screensaver immediately works in any shell, triggering after a set period of inactivity is currently Zsh only.

installation

# cargo
cargo install --locked ttysvr
# homebrew
brew install cxreiff/tap/ttysvr
# arch linux
pacman -S ttysvr

[!IMPORTANT] If you are on Linux and install using the cargo method, or otherwise build from source, you will first need to refer to docs/linux_dependencies.md in the bevy repo for your distro's instructions on making sure bevy's required linux dependencies are installed.

usage

Starts the screensaver immediately. If no variant is specified, one is randomly selected.

ttysvr [VARIANT]

Some variants have subvariants.

ttysvr [VARIANT] [SUBVARIANT]

Sets up the screensaver to activate after DELAY seconds of inactivity in your current shell session.

eval `ttysvr [VARIANT] --init [DELAY]`

Cancels the screensaver in your current shell session.

eval `ttysvr --cancel`

[!NOTE] Note that the --init and --cancel options require being wrapped in eval and backticks. This is because activating the screensaver after a set period of inactivity relies on setting the TMOUT environment variable in your current shell, instead of the child shell created by the ttysvr process. Issues/PRs are greatly appreciated if somebody is aware of a better way of doing this!

variants

variant subvariants? description
bubbles Colorful bubbles bounce around the screen.
logo dvd, tty DVD player style bouncing logo.
maze brick, hedge 3D randomly generated maze.

compatibility

zsh only

The screensaver delay works based on setting a session timeout and catching the ALRM signal in a way only compatible with ZSH. If you know a way to achieve something similar in another shell, please open an issue!

terminal

This requires that your terminal:

  1. Supports 24bit color.
  2. Has reasonably efficient rendering.

This includes a decent variety of terminals, but I have personally confirmed good results in the following:

  • Alacritty (macOS, linux)
  • Kitty (macOS)
  • WezTerm (macOS)
  • iTerm2 (macOS)

ssh

I have recently added a change that has allowed me to run the screensavers over SSH. This is not very well tested however, so please open an issue if you run into problems!

Dependencies

~33–65MB
~1M SLoC