Development Status
- 3 - Alpha
Intended Audience
- Developers
Operating System
- OS Independent
Programming Language
- Python
- Python :: 3 :: Only
- Python :: 3.7
- Python :: 3.8
- Python :: 3.9
- Python :: 3.10
- Python :: 3.11
- Python :: 3.12
rich-codex โก๏ธ๐โก๏ธ
A GitHub Action / command-line tool which generates screengrab images of a terminal window, containing command outputs or code snippets.
๐ Documentation: https://ewels.github.io/rich-codex/ ๐
Introduction
Having code examples in your documentation is a fantastic way to help users understand what to expect from your tool.
Using terminal screenshots is a good way to do this because:
- ๐ Coloured terminal output is supported
- โ๏ธ You can fit in long lines without scrolling or cropping (images are auto-resized)
- ๐ They look cool
However, manually generating these screenshots is a pain ๐๐ป Remembering to update them every time you make a minor change means that they can easily get out of date.
Rich-codex automates this process for you. It searches markdown code for images with shell commands or code snippets. It runs these commands and saves a terminal screen-grab at the embedded path.
Typical use cases:
- ๐ท Example CLI tool outputs that automatically stay in sync with your package
- โป๏ธ Syntax-highlighted code snippets that are always up to date with your
examples/
- ๐คฉ Fast and simple images for your docs with minimal setup
Quickstart
-
๐ Write some markdown docs, use an image tag with a backtick command inside:

-
๐ค Add a GitHub Action to automatically run the command, generate the image and commit to the repo:
on: [push] jobs: rich_codex: runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 - name: Install your custom tools run: pip install lolcat - name: Generate terminal images with rich-codex uses: ewels/rich-codex@v1 with: commit_changes: "true"
-
๐ Enjoy reading your documentation
How it works
Rich-codex is a command-line tool that you can run via a GitHub action or as a command line tool. It works with any markdown (including GitHub READMEs).
It collects either commands or code snippets, together with output filenames and configuration options. Commands are run in a subprocess and the standard output & standard error collected. These are then rendered as an image using Textualize/rich.
Rich-codex creates the images that your markdown docs expect. It doesn't require a HTML build-step and doesn't make any changes to your markdown or its output. As such, it's compatible with any documentation engine, including rendering markdown on github.com.
Rich-codex needs inputs (commands / snippets) and output filenames to work. These can be configured in four different ways:
- ๐ผ Markdown images
- Search markdown files for image tags with command alt text. eg:

- Search markdown files for image tags with command alt text. eg:
- ๐ฌ Markdown comments
- Search markdown files for special HTML comments.
- โก๏ธ Command-line / action inputs
- Specify a command or snippet using the action
with
inputs.
- Specify a command or snippet using the action
- โ๏ธ Config files
- Use one or more YAML config files for multiple images and more complex customisation.
Images can be generated as SVG, PNG or PDF (detected by filename extension).
Keep reading! ๐ https://ewels.github.io/rich-codex/