gh-commit

Commit - Automated Git Commit Messages with LLM πŸ€–πŸ“

Artfully create commit messages that reflect the essence of your code changes πŸŽ¨πŸ”. Craftsmanship for your commits πŸ‘¨β€πŸŽ¨. Unleash the power of language models to automate your Git commit messages πŸŒπŸ€–. With Commit, save time ⏰ and generate meaningful commit messages based on your code changes πŸ“œ.

The average person types around 40 words per minute. Imagine an AI has written 573 words in commit messages, a human would have taken approximately 14.32 minutes to write the same quantity of words.

If we calculate the time taken for a human to make an individual commit, assuming it takes around 5 minutes per commit on average, for the 29 commits made by AI, a human would have taken approximately 145 minutes or 2.42 hours.

Hence, in total (commit making and message writing time), a human would have taken approximately 2.62 hours. πŸ•°οΈ Given that all this work was done by an AI, we can say 2.62 hours of human-time was saved.

By extrapolating these numbers, if 1000 commits were made, it would save approximately 90 hours of human-time assuming the ratio of words per commit remains constant. If a software development team consists of 5 people, this time saving allows for roughly 18 additional hours per person, which increases productivity, efficiency, reduces burnout and leaves additional time for creative, challenging tasks or problem solving that AI can’t do.πŸ‘©β€πŸ’»πŸ‘¨β€πŸ’»

This not only displays AI’s potential role in tech automation, but also shows how it helps in giving human employees the bandwidth to focus on work that requires human intelligence and creativity, creating a more balanced and efficient work environment. πŸ’πŸš€πŸ“ˆ

If we take into consideration the larger tech industry where millions of commits are made daily, we’re potentially looking at thousands of hours saved per day by utilising AI in this manner! πŸ’‘+ AI bot saves the day again! πŸš€πŸŒŸ

Fun Fact: Using an AI to write commits and other automations can reduce the risk of Repetitive Strain Injury (RSI), a common condition affecting people who perform repetitive tasks, like typing, for extended periods. πŸ’»πŸŒŸ

Table of Contents πŸ“š

Features 🌟

Prerequisites πŸ“‹

Installation πŸ› οΈ

Environment Variables 🌍

Before running AutoCommit, it’s advisable to set a few environment variables πŸ”‘:

Add these environment variables by appending them to your .bashrc, .zshrc, or other shell configuration files πŸ“„:


#For Models hosted on Azure
export OPENAI_URL=https://apiendpoint.openai.azure.com
export OPENAI_MODEL=llm-large
export OPENAI_API_KEY=your-openai-api-key-here
export FINE_TUNE_PARAMS='{"temperature": 0.7}'

For Models hosted on OpenAI - Get the API Keys from https://platform.openai.com/account/api-keys :footprints: https://medium.sankhe.com/step-by-step-guide-to-obtaining-an-openai-api-token-a1b4cba4d294 :footprints:

export OPENAI_URL=https://api.openai.com/v1/
export OPENAI_API_KEY=your-openai-api-key-here 
export OPENAI_MODEL=gpt-4

Or, you can set them inline before running the AutoCommit command πŸ–±οΈ:

OPENAI_URL=your-openai-api-key-here OPENAI_MODEL=gpt-4 FINE_TUNE_PARAMS='{"temperature": 0.7}' git auto-commit

Complete Install πŸ“¦

For an end-to-end installation experience, execute πŸ‘‡:

bash <(curl -s https://raw.githubusercontent.com/ghcli/gh-commit/main/install.sh)

This comprehensive script accomplishes the following πŸ“‹:

  1. Downloads the latest gh-commit binary ⬇️.
  2. Makes the binary executable πŸƒ.
  3. Sets up a Git alias: auto-commit 🏷️.
  4. Installs the GitHub CLI extension for AutoCommit πŸ”„.

Upgrade πŸ“ˆ

To upgrade to the latest version of AutoCommit, execute πŸ“:

gh extensions upgrade --all

Usage πŸ–±οΈ

Native Git 🌐

To auto-generate a commit message, type ⌨️:

git auto-commit

GitHub CLI Extension πŸ”—

For the same functionality through GitHub CLI, execute πŸ€–:

gh  commit                    #dry-run View the commit message without commit
git commit -m "$(gh commit)"  #git commit with the commit message

Use via Alias

auto-commit

Both commands invoke a Git diff, pass the changes to GPT-4, and craft a commit message based on the model’s output πŸ’¬πŸŽ‰.

Commit Example

gh-commit-in-action

Commit Example

ghcommit2

Markdown Example

ghdemo

Acknowledgements πŸ™