README.md

May 6, 2026 ยท View on GitHub

gitlogue

crates.io release CI codecov license Terminal Trove Tool of The Week

A cinematic Git commit replay tool for the terminal.
Turn your Git history into a living, animated story โ€” typing, syntax highlighting, file tree transitions.

Watch commits unfold with realistic typing animations, syntax highlighting, and file tree transitions, transforming code changes into a visual experience.

Installation

curl -fsSL https://raw.githubusercontent.com/unhappychoice/gitlogue/main/install.sh | bash

Using Homebrew

brew install gitlogue

Using Cargo

cargo install gitlogue

On Arch Linux

pacman -S gitlogue

Using Nix

# Run directly without installation
nix run github:unhappychoice/gitlogue

# Or install to your profile
nix profile install github:unhappychoice/gitlogue

# For flake-based configurations, add to your inputs:
# inputs.gitlogue.url = "github:unhappychoice/gitlogue";
# Then use: inputs.gitlogue.packages.${system}.default

From Source

git clone https://github.com/unhappychoice/gitlogue.git
cd gitlogue
cargo install --path .

See the Installation Guide for more options and troubleshooting.

Features

๐ŸŽฌ Commit Replay as Animation โ€” Realistic typing, cursor movement, deletions, and file operations ๐Ÿ” Working Tree Diff View โ€” Visualize staged/unstaged changes before committing ๐ŸŽจ Tree-sitter Syntax Highlighting โ€” 29 languages supported ๐ŸŒณ Project File Tree โ€” Directory structure with change statistics ๐Ÿ–ฅ๏ธ Screensaver Mode โ€” Endless random commit playback ๐ŸŽญ Themes โ€” 9 built-in themes + full customization support โšก Fast & Lightweight โ€” Built with Rust for performance

Usage

๐Ÿ–ฅ๏ธ Screensaver โ€” Ambient coding display for your workspace
๐ŸŽ“ Education โ€” Visualize how code evolved over time
๐Ÿ“บ Presentations โ€” Replay real commit histories live
๐ŸŽฌ Content Creation โ€” Record demos with VHS or asciinema
๐ŸŽจ Desktop Ricing โ€” A living decoration for your terminal
๐Ÿ’ผ Look Busy Mode โ€” Appear productive during meetings

Warning

Not a True Screensaver โ€” gitlogue does not include traditional screensaver functions like power management or screen blanking. It's purely a visual display tool.

OLED Burn-in Risk โ€” Static elements (like the editor background and border lines) may cause burn-in on OLED displays over extended periods. LCD displays are generally safe from this issue.

Quick Start

# Start the cinematic screensaver
gitlogue

# View a specific commit
gitlogue --commit abc123

# Replay a range of commits
gitlogue --commit HEAD~5..HEAD

# Replay commits in chronological order (oldest first)
gitlogue --order asc

# Loop a specific commit continuously
gitlogue --commit abc123 --loop

# Loop through a commit range
gitlogue --commit HEAD~10..HEAD --loop

# View staged changes (default)
gitlogue diff

# View unstaged changes instead
gitlogue diff --unstaged

# Filter commits by author or email (case-insensitive partial match)
gitlogue --author "john"

# Filter commits by date
gitlogue --after "2024-01-01"
gitlogue --before "1 week ago"
gitlogue --after "2024-06-01" --before "2024-07-01"

# Use a different theme
gitlogue --theme dracula

# Adjust typing speed (ms per character)
gitlogue --speed 20

# Set different speeds for different file types
gitlogue --speed-rule "*.java:50" --speed-rule "*.xml:5"

# Ignore specific file patterns (e.g., notebooks, lock files)
gitlogue --ignore "*.ipynb" --ignore "poetry.lock"

# Use an ignore file
gitlogue --ignore-file .gitlogue-ignore

# List available themes
gitlogue theme list

# Set default theme
gitlogue theme set dracula

# Combine options
gitlogue --commit HEAD~5 --author "john" --theme nord --speed 15 --ignore "*.ipynb"

Key Bindings

Playback

KeyAction
SpaceToggle play / pause
hStep one line backward
lStep one line forward
H (Shift+h)Step one change backward
L (Shift+l)Step one change forward
pPrevious commit
nNext commit
EscOpen menu
q / Ctrl+cQuit
KeyAction
j / โ†“Move selection down
k / โ†‘Move selection up
EnterSelect item
EscClose menu

Configuration

gitlogue can be configured via ~/.config/gitlogue/config.toml.
You can set the default theme, typing speed, and background preferences.

See the Configuration Guide for full options and examples.

Supported Languages

Astro, Bash, C, C#, C++, Clojure, CSS, Dart, Elixir, Erlang, Go, Haskell, HTML, Java, JavaScript, JSON, Kotlin, Lua, Markdown, Nix, PHP, Python, Ruby, Rust, Scala, Svelte, Swift, TypeScript, XML, YAML, Zig

Documentation

Installation Guide
Usage Guide
Configuration Guide
Theme Customization
Contributing Guidelines
Architecture Overview

Git Visualization & Coding

  • GitType - A CLI code-typing game that turns your source code into typing challenges

Terminal Screensavers

  • tarts - Collection of terminal screensavers in Rust (Matrix, Game of Life, Boids, 3D effects, and more)
  • cbonsai - Grow beautiful bonsai trees in your terminal
  • asciiquarium - Enjoy the mysteries of the sea from your terminal
  • cmatrix - The Matrix screensaver effect for your terminal
  • pipes.sh - Animated pipes flowing through your terminal

Contributing

Contributions are welcome.
See the Contributing Guidelines for details.

License

ISC License. See LICENSE for details.

Author

@unhappychoice