Skip to main content

A tool for measuring the activity of a git repo using a variety of single summary statistics

Project description



Regulagity (reh-gew-la-git-ee) is a command-line tool for measuring activity in a git repo, ultimately producing a single number that summarises a repo.

For example, you can ask "how many commits per year does this repo have?" or "what proportion of months does this repo have new commits?". Both of these are good summaries of how active a repo is.



pip install regulagity


Usage: regulagity [OPTIONS] [LOCATION]

  Calculates summary statistics for the git repository located at LOCATION.
  LOCATION must be the path either to a local git repository or to a git
  remote, e.g. `/home/michael/Programming/Regulagity/` or

  --period TEXT              Period of time to summarise commits over. This
                             consists of an optional number followed by a
                             letter code, e.g. `2W` means two weeks, `3M`
                             means 3 months, `Y` means 1 year etc. For a full
                             reference on these string codes, refer to
  --stat [proportion|count]  The way we summarise each commit over the time
                             period. `proportion` indicates that we should
                             calculate what proportion of the time period has
                             any commits (e.g. how many weeks on average have
                             any activity) whereas `count` indicates that we
                             should take the average number of commits in this
                             time period (e.g. how many commits are on average
                             made per week)
  --help                     Show this message and exit.


  • What proportion of months have had any commit activity since this repo was created? regulagity --period M --stat proportion
  • What is the average commits per fortnight in this repo? regulagity --period 2W --stat count /home/michael/Programming/Regulargity


There are numerous other tools that summarise git activity, for example:

However, when comparing repos, perhaps because you want to use the best supported and maintained option, you really only want a single number you can use to easily compare them. For this reason, regulagity only ever outputs a single number for a repo, not a plot or a table.

The reason regulagity supports analyses like "what proportion of months have had any activity" is because it avoids any biases you might get by asking "what is the average number of commits" or "average lines changed". These can be biased by a repo that has a million commits over a single month, because it will still has a high number of commits per month on average, even if it's been abandoned since 2015. The same issue is encountered for lines-of-code. Asking only if there has been any activity of a given period allows you to better compare repos, and allows you to be certain that a high number means a better amount of support. You can even use this same statistic to compare open source repos to commercial products, because you can also ask "what proportion of months have a new update to this software?".


Planned features:

  • Allow calculation of average lines-of-code, not just commit numbers
  • Allow custom date-ranges for the query, e.g. "in the last year" rather than "for the entire commit history"

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

regulagity-0.0.2.tar.gz (4.3 kB view hashes)

Uploaded source

Built Distribution

regulagity-0.0.2-py3-none-any.whl (7.6 kB view hashes)

Uploaded py3

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Huawei Huawei PSF Sponsor Microsoft Microsoft PSF Sponsor NVIDIA NVIDIA PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page