Skip to main content

A tool to generate a heatmap of your git commits

Project description

git-heatmap

Shows a heatmap for your Git repositories.

Screenshot

Install

$ pip install git-heatmap

Usage

Usage: git-heatmap [OPTIONS]

Options:
  -r, --repo TEXT       Path to git repository (can be relative)
  -a, --author TEXT     Author email (default all authors)
  -b, --branch TEXT     Branch (default all branches)
  -s, --start TEXT      Start date (YYYY-MM-DD, defaults to current year
                        start)
  -e, --end TEXT        End date (YYYY-MM-DD, defaults to current year end)
  -c, --character TEXT  Character to use for heatmap (defaults to ▧)
  -sh, --shade TEXT     Color to use for heatmap (defaults to 0;255;0)
  --help                Show this message and exit.

Examples

Run git-heatmap ...

# in a directory that's already a git repository
$ git-heatmap

# on a repository elsewhere
$ git-heatmap -r /path/to/repo

# on multiple repositories!
$ git-heatmap -r /path/to/repo -r /path/to/other

# limit by author email
$ git-heatmap -a me@myself.com

# limit by multiple authors email
$ git-heatmap -a me@myself.com -a him@himself.com

# pick a specific branch
$ git-heatmap -b main

# pick multiple branches
$ git-heatmap -b main -b develop

# start from date
$ git-heatmap -s 2023-02-01

# end on date
$ git-heatmap -e 2023-02-28

How about some character and color change as well?

Screenshot

You can do this via:

# change characters
$ git-heatmap -c '⊚'

# change colors
$ git-heatmap -sh "255;255;0"

FAQ

Why?

Mostly fun, I like things cli. It's also rather annoying that github's heatmap only targets the primary branch of a repository.

Does this count any contribution other than commits?

No, this is purely commits, including merge commits (I think! :-))

What branch does it pick if I didn't specify one?

All branches!

But commits are the same in more than one branch!

Yes, that's why it only counts unique commit hashes.

The months labels aren't in line with the github heatmap

Github got it wrong, check any month's start date and notice how they push the label one column further. If you still feel they got it right, create an issue and show a screenshot, I'll fix it.

This will be slow on large repositories!

No, this internally uses git-rev-list.

Why not make this a git extension?

That was the original plan, but we are where we are...

Can I...

Yes you can. Remember this is meant as tiny fun project.

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

git-heatmap-0.0.6.tar.gz (4.9 kB view details)

Uploaded Source

Built Distribution

git_heatmap-0.0.6-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file git-heatmap-0.0.6.tar.gz.

File metadata

  • Download URL: git-heatmap-0.0.6.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for git-heatmap-0.0.6.tar.gz
Algorithm Hash digest
SHA256 4f606e9380a43d9b5f31bbb0e32ecd133686dcce409a845b16017ce8742c604e
MD5 5113db26fd3a3b79ef6d83bec6a09d4f
BLAKE2b-256 8af9abb5b3222905005a2b4a5f46d4975114d66951ca63ac88ee5fb0f3dd9db9

See more details on using hashes here.

File details

Details for the file git_heatmap-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: git_heatmap-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 5.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for git_heatmap-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 5745228d1d534bd9560f4682312d4df9da232e9201b3a956e264691e5b711ef9
MD5 6021cc4889be07c3c16955a628c59b0b
BLAKE2b-256 435e7a5d986363ebb1df1d6355a94ba013798e5624dc31866d6a746da01808ed

See more details on using hashes here.

Supported by

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