Skip to main content

A CLI tool for generating editable commit messages locally using Ollama.

Project description

4

AutoCommit is a free and open-source AI-powered CLI tool that generates unlimited commit messages locally using Ollama. It works entirely offline, requiring no API keys, providing developers with a private and efficient way to create concise, context-aware commit messages.

Python PyPI version PyPI Downloads

Features

  • Local AI-Powered: Generates commit messages using a small LLM models locally
  • Flexible Editing: Review and edit generated messages before committing
  • Git Integration: Seamlessly works with your existing Git workflow
  • Multiple Language Model Support: Option to choose different local AI models

Setup

Prerequisites

  • Ollama: Download and install ollama from offical website.
  • RAM (minimum):
    • 8GB for smaller models (<=3B parameters)
    • 16GB for optimal performance
  • GPU (Optional): Boosts performance, but not required

Installation

It is recommended to use a virtual environment.

pip install autocommitt

Upgrading

Check the installed version with:

pip list | grep autocommitt

If it's not latest, make sure to upgrade.

pip install -U autocommitt

Basic Usage

  1. Start the Ollama Server

    act start
    

    Note: The Ollama server starts automatically after installation. However, running this command ensures that all configuration files are updated and a default model is properly set up.

  2. Stage Your Changes
    Stage the files you want to commit using Git:

    git add <files...>
    
  3. Generate and Edit Commit Messages
    Generate a commit message based on your staged changes:

    act gen
    
    • The tool generates a message and allows you to review and edit it before committing.

    • To automatically push the commit to the remote repository, use the -p or --push flag:

      act gen -p
      

    Pro Tip: Save time by using the --push flag to combine committing and pushing into a single step.

  4. Stop the Ollama Server
    To free up resources after you're done, stop the Ollama server:

    act stop
    

    Note: This command is supported only on Linux. On Windows and macOS, the Ollama server runs continuously as long as the machine is active.

Pro Tip: You can use the autocommitt alias for act throughout, making commands shorter and quicker to type!

Additional Commands

By default, AutoCommitt uses the llama3.2:3b model to generate commit messages.

1. Using a Custom Model

  • To view the list of available models, run the following command:
    act list
    
  • To select and set a model as active:
    act use <model_name>
    

    Note: If the model is not already downloaded, this command will pull the model by running ollama pull <model_name> and set it as the default.

2. Deleting a Model

act rm <model_name>

Note: Since models require a significant amount of memory (minimum 2GB), it is recommended to use only one model and delete the rest to free up space.

3. Viewing Commit History

Easily view recent commit messages using the his command:

act his -n 5
  • Flag Description:-n or --limit: (Optional) Specify the number of recent commit messages to retrieve. If omitted, all commit messages will be displayed.

Pro Tip: Use this command to quickly review your project's recent changes before generating new commit messages.

How It Works

It runs the git diff --staged command to gather all staged changes and processes them using a local LLM (default: llama3.2:3b provided by Ollama). The model analyzes the changes and generates a concise, context-aware commit message, ensuring privacy and avoiding external API dependencies.

Future Enhancements

  • Cross-Platform Support: Compatibility for MacOS.
  • Git Hooks Integration: Compatible with pre-commit hooks
  • Custom Templates: Support for user-defined commit message templates

Contributing

We welcome contributions! To report bugs, fix issues, or add features, visit the Issues page. Please review our Contribution Guide for setup and contribution instructions.

Acknowledgments

We would like to express our gratitude to the following open-source projects that made AutoCommitt possible:

Special thanks to the maintainers and contributors for their outstanding work!


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

autocommitt-0.3.0.tar.gz (34.3 kB view details)

Uploaded Source

Built Distribution

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

autocommitt-0.3.0-py3-none-any.whl (23.4 kB view details)

Uploaded Python 3

File details

Details for the file autocommitt-0.3.0.tar.gz.

File metadata

  • Download URL: autocommitt-0.3.0.tar.gz
  • Upload date:
  • Size: 34.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for autocommitt-0.3.0.tar.gz
Algorithm Hash digest
SHA256 aea11e91b183743bd73f49891210f27b7427d312302f3be5e9dd241588c1fe8f
MD5 7eefb8d1181fe566e4ddfc0474719222
BLAKE2b-256 b1708de9ff037065fc674ffbe6cf695b0b412072d7dd069e8ee3aee2b32c3bf7

See more details on using hashes here.

Provenance

The following attestation bundles were made for autocommitt-0.3.0.tar.gz:

Publisher: release.yaml on Spartan-71/AutoCommitt

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file autocommitt-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: autocommitt-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 23.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for autocommitt-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 86801c75f33d682cdf09c572ec2561c776bdd2d61977e53ac866010598fde871
MD5 683186142f4beaad114160a73909e5c3
BLAKE2b-256 74dcc1f7c09a3c80417e4dfe18bed29fbc5e12cd7ecb8768ac4ef0c5b4f2a872

See more details on using hashes here.

Provenance

The following attestation bundles were made for autocommitt-0.3.0-py3-none-any.whl:

Publisher: release.yaml on Spartan-71/AutoCommitt

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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