Intelligent Git Commit Tool with LLM Integration
Project description
🤖 Intelligent Git Commit Tool
An AI-powered command-line tool that automatically generates meaningful commit messages and manages project documentation using Large Language Models (LLMs) from multiple providers including OpenRouter, OpenAI, Anthropic, and Google Gemini.
✨ Features
🎯 Smart Commit Messages
- AI-Generated: Creates contextual, descriptive commit messages by analyzing your code changes
- Conventional Commits: Follows best practices with proper type prefixes (
feat:,fix:,docs:, etc.) - Customizable: Override generated messages or use different AI models
🔍 Interactive Staging
- Hunk-by-Hunk: Stage individual changes within files, similar to
git add -p - Visual Diff: Colored output showing additions, deletions, and context
- Flexible Options: Auto-stage all changes, select specific files, or choose individual hunks
🧠 Intelligent Staging
- Automatic Commit Planning: Let the LLM analyze all your changes and group them into logical, separate commits.
- Multi-Commit Workflow: Automatically generates multiple focused commit messages for the planned commits.
- Interactive Confirmation: Review and approve each proposed commit before it's made.
📚 Documentation Management
- Smart Analysis: Automatically suggests documentation updates based on code changes
- CRUD Operations: Create, update, and manage documentation files
- Simple Patch Format: Uses an LLM-friendly patch system for precise updates
- Multi-Format Support: Works with Markdown, reStructuredText, and plain text files
🚀 Quick Start
Prerequisites
- Python 3.10+
- Git repository
- API keys for OpenRouter, OpenAI, Anthropic, or Google Gemini
Installation
-
Install from PyPI:
pip install llm-git-commits
-
Configure the tool: Run the interactive configuration wizard to set up your provider, API key, and default model.
llm-git-commits config
Basic Usage
# Interactive mode - stage changes selectively
llm-git-commits -i
# Auto-commit all changes
llm-git-commits -a
# Manage documentation
llm-git-commits --docs-dir ./docs --docs-only
# Let the AI create multiple commits automatically
llm-git-commits --intelligent
📖 Detailed Usage
Command Line Options
| Option | Short | Description |
|---|---|---|
config |
Run the interactive configuration wizard. | |
--interactive |
-i |
Interactive hunk staging mode. |
--auto-stage |
-a |
Automatically stage all changes. |
--intelligent |
Use LLM to group changes into multiple commits. | |
--docs-dir |
Path to documentation directory. | |
--docs-only |
Only perform documentation management. | |
--commit-message |
-m |
Override generated commit message. |
Usage Examples
1. Interactive Staging (Recommended)
llm-git-commits -i
This mode lets you:
- Review each change individually
- Stage only the changes you want to commit
- Generate focused commit messages for specific changes
2. Quick Commit All Changes
llm-git-commits -a
Perfect for when you want to commit all your changes with an AI-generated message.
3. Documentation Management
llm-git-commits --docs-dir ./docs --docs-only
The tool will:
- Analyze your recent changes
- Suggest documentation updates
- Help create or update documentation files
- Use a simple patch system for precise edits
4. Intelligent Staging
llm-git-commits --intelligent
This mode analyzes all modified files and uses the LLM to group related changes into separate, logical commits. It will then propose each commit for your approval.
🛠️ How It Works
Commit Message Generation
The tool analyzes your staged changes and generates commit messages following these principles:
- Conventional Commits: Uses standard prefixes (
feat:,fix:,docs:,refactor:, etc.) - Imperative Mood: "Add feature" not "Added feature"
- Descriptive: Explains what and why, not just what
- Concise: First line under 50 characters
Example generated messages:
feat(auth): add OAuth2 login support
fix(api): handle null response in user endpoint
docs: update installation instructions for Docker
refactor: simplify database connection logic
Interactive Staging
When you use --interactive, the tool:
- Parses Diffs: Breaks down file changes into individual "hunks"
- Shows Previews: Displays colored diffs for each change
- Prompts for Action: Ask whether to stage each hunk
- Applies Changes: Uses
git apply --cachedto stage selected hunks
Documentation Updates
The documentation system:
- Analyzes Context: Reviews recent commits, modified files, and project structure
- Suggests Changes: Recommends documentation updates based on code changes
- Provides Templates: Generates new documentation from scratch
- Applies Patches: Uses a simple patch format for precise updates
Patch Format
The tool uses a simple, LLM-friendly patch format:
PATCH_START
SECTION: Installation
ACTION: REPLACE
CONTENT:
## Installation
1. Install Python 3.8+
2. Run: `pip install -r requirements.txt`
3. Set up your config file
PATCH_END
🎨 Interactive Mode Demo
📝 File: src/auth.py
==================================================
Hunk 1/3:
@@ -45,6 +45,12 @@ def authenticate(username, password):
if not username or not password:
return False
+ # Add rate limiting
+ if check_rate_limit(username):
+ raise RateLimitError("Too many attempts")
+
user = get_user(username)
return verify_password(user, password)
Stage this hunk? [y/n/q/d]: y
🤖 Generating commit message...
📝 Proposed commit message:
--------------------------------------------------
feat(auth): add rate limiting to authentication
Prevents brute force attacks by limiting login attempts
per username. Raises RateLimitError when threshold exceeded.
--------------------------------------------------
Proceed with commit? [Y/n]:
🔧 Configuration
Configuration File
The first time you run llm-git-commits config, it will create a configuration file at ~/.config/git-commit-tool/config.ini. This file stores your API keys, default model, and other preferences.
You can edit this file manually or re-run llm-git-commits config at any time.
Model Selection
During the interactive configuration, you can search for and select from all models available from your chosen provider.
Popular models include:
| Provider | Model Name |
|---|---|
| OpenRouter | google/gemini-2.5-flash-preview-05-20 (Default) |
anthropic/claude-sonnet-4-20250514 |
|
openai/gpt-4o-mini |
|
| OpenAI | gpt-4o-mini |
| Anthropic | claude-sonnet-4-20250514 |
🤝 Contributing
Contributions are welcome! Here are some ways to help:
- Bug Reports: Found an issue? Please open an issue with details
- Feature Requests: Have an idea? We'd love to hear it
- Code Contributions: Submit pull requests for improvements
- Documentation: Help improve these docs
Development Setup
# Clone the repository
git clone https://github.com/Slipstreamm/llm-git-commits.git
cd llm-git-commits
# Install in editable mode
pip install -e .
# Run tests (if you add them)
python -m pytest tests/
📝 License
This project is licensed under the MIT License - see the LICENSE file for details.
🙏 Acknowledgments
- OpenRouter for providing easy access to multiple LLM providers
- Conventional Commits for the commit message format specification
- Git for the amazing version control system that makes this all possible
🆘 Troubleshooting
Common Issues
"Not in a git repository"
- Make sure you're running the tool from within a git repository
- Initialize a repo with
git initif needed
"LLM API call failed"
- Check your API key is correct and has credits
- Verify network connectivity
- Try a different model
"Failed to stage changes"
- Ensure files aren't locked or in use by other processes
- Check git status for any conflicts
"No changes staged for commit"
- Make sure you have modified files
- Try
git statusto see what's changed - Use
--auto-stageto stage everything
Getting Help
- Issues: Open an issue on GitHub
- Discussions: Use GitHub Discussions for questions
- Documentation: Check this README and inline help (
--help)
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file llm_git_commits-1.1.1.tar.gz.
File metadata
- Download URL: llm_git_commits-1.1.1.tar.gz
- Upload date:
- Size: 22.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c35722edf502e1a134bb83af157b5bdebd0d39a97370738fae634e4f01eccfde
|
|
| MD5 |
e260bd035e4b99f274a3e62ebadee8e1
|
|
| BLAKE2b-256 |
175d7bc264685ccc380314fdc5463507ca5e9ed439127257c763530548868df3
|
File details
Details for the file llm_git_commits-1.1.1-py3-none-any.whl.
File metadata
- Download URL: llm_git_commits-1.1.1-py3-none-any.whl
- Upload date:
- Size: 19.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b9d9c5f5c954bd52af154f72059aed07aba1dadfdc2b6387a6fb8bc26d3cd19d
|
|
| MD5 |
d9b18c64a5a6eaf2604f6e070b31530f
|
|
| BLAKE2b-256 |
b2b4461d817cca86078feccc5ad12e01db70e1e8b7ec0a3a9dccd64047c65942
|