Skip to main content

Static treemap bitmaps for directory trees, displayed as inline terminal images

Project description

dirplot

CI PyPI Python Downloads License Buy Me a Coffee

dirplot creates static nested treemap images for directory trees. It can display them in the system image viewer (default, works everywhere) or inline inside the terminal using the iTerm2 inline image protocol or the Kitty graphics protocol — detected automatically at runtime.

Each rectangle represents a file; its area is proportional to the file size and its colour is determined by the file extension. Directories are shown as labelled, nested containers, mirroring the actual hierarchy.

dirplot output

Installation

# As a standalone tool (recommended)
uv tool install dirplot

# Into the current environment
pip install dirplot

From GitHub

# As a standalone tool
uv tool install git+https://github.com/deeplook/dirplot

# Into the current environment
pip install git+https://github.com/deeplook/dirplot

Usage

# Use it before installing it
uvx dirplot --help

# Show dirplot for the current directory (opens image in system viewer)
dirplot .

# Save to a file without displaying
dirplot . --output dirplot.png --no-show

# Display inline (protocol auto-detected: iTerm2, Kitty, Ghostty)
dirplot . --inline

# Exclude directories
dirplot . --exclude .venv --exclude .git

# Use a different colormap and larger directory labels
dirplot . --colormap Set2 --font-size 18

# Render at a fixed resolution instead of terminal size
dirplot . --size 1920x1080 --output dirplot.png --no-show

# Don't apply cushion shading — makes tiles look flat
dirplot . --no-cushion

Options

Flag Short Default Description
--output -o Save PNG to this path
--show/--no-show --show Display the image after rendering
--inline off Display in terminal (protocol auto-detected)
--legend/--no-legend --no-legend Show file-extension colour legend
--font-size -s 12 Directory label font size in pixels
--colormap -c tab20 Matplotlib colormap for unknown extensions
--exclude -e Path to exclude (repeatable)
--size terminal size Output dimensions as WIDTHxHEIGHT (e.g. 1920x1080)
--header/--no-header --header Print info lines before rendering
--cushion/--no-cushion --cushion Apply van Wijk cushion shading for a raised 3-D look

Inline Display

The --inline flag renders the image directly in the terminal. The protocol is auto-detected at runtime: terminals that support the Kitty graphics protocol use APC chunks (ESC_G…); all others fall back to the iTerm2 inline image protocol (ESC]1337;File=…).

Terminal Platform Protocol
iTerm2 macOS iTerm2
WezTerm macOS, Linux, Windows iTerm2
Warp macOS, Linux iTerm2
Hyper macOS, Linux, Windows iTerm2
Kitty macOS, Linux Kitty
Ghostty macOS, Linux Kitty

The default mode (--show, no --inline) opens the PNG in the system viewer (open on macOS, xdg-open on Linux) and works in any terminal.

Note: --inline does not work in AI coding assistants such as Claude Code, Cursor, or GitHub Copilot Chat. These tools intercept terminal output as plain text and do not implement any graphics protocol, so the escape sequences are either stripped or displayed as garbage. Use the default --show mode (system viewer) or --output to save the PNG to a file instead.

How It Works

  1. Scans the directory tree, collecting each file's path, extension, and size in bytes.
  2. Computes a squarified dirplot layout recursively — directories allocate space for their children.
  3. Renders to a PNG via Pillow (PIL) at the exact pixel dimensions of the current terminal window (detected via TIOCGWINSZ), or at a custom size when --size is given.
  4. Displays via the system image viewer (open / xdg-open) or inline via an auto-detected terminal graphics protocol (iTerm2 or Kitty).

Extension colours come from the GitHub Linguist language colour table (~500 known extensions). Unknown extensions fall back to an MD5-stable colour derived from the chosen --colormap. File label text is automatically black or white depending on the background luminance.

Development

git clone https://github.com/deeplook/dirplot
cd dirplot
make test

See CONTRIBUTING.md for full details.

Platform Support

This tool has been developed and tested on macOS. Linux should work, and Windows support is untested. Feedback and bug reports from Linux and Windows users are very welcome — please open an issue on GitHub.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dirplot-0.1.2.tar.gz (921.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dirplot-0.1.2-py3-none-any.whl (551.3 kB view details)

Uploaded Python 3

File details

Details for the file dirplot-0.1.2.tar.gz.

File metadata

  • Download URL: dirplot-0.1.2.tar.gz
  • Upload date:
  • Size: 921.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.8 {"installer":{"name":"uv","version":"0.10.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for dirplot-0.1.2.tar.gz
Algorithm Hash digest
SHA256 510b63c19f6d34ac1ee8d25503b7818d25d87cc89299e939251134ddbb1d799b
MD5 5245b9f8bab04367ae4a5cc18788b7a2
BLAKE2b-256 3c9bf9bb98186993473e3df66b0666a144ec1463c48f6f018b6c91035ebadc57

See more details on using hashes here.

File details

Details for the file dirplot-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: dirplot-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 551.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.8 {"installer":{"name":"uv","version":"0.10.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for dirplot-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 661438e9e42ebfbfe0b39d04bc8c4c1426839a69d1691c7eda2bb240dee16abe
MD5 2e8deb6237ea6ac4adf3dbe27c9a564c
BLAKE2b-256 d15b0f2f2a7677fa3e582a81d5802fbc8369c5247342c39360170c676a704655

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page