AI commit messages that pre-fill your git editor — Claude-powered, conventional-commits aware, learns your repo's style.
Project description
noidea
Because you shouldn't have to think about commit messages.
Stages your diff, sends it to an AI, and pre-fills your commit editor — so you never have to write a commit message again.
Why noidea?
There are plenty of AI commit tools. noidea is the one that fits the way you already work:
- Writes in your repo's voice, not generic AI boilerplate. Before generating, noidea reads how your repo already commits — its scope vocabulary, body habits, subject length, gitmoji or not — and matches it. Your history stays consistent instead of looking like a bot dropped in.
- Spends pennies and milliseconds on trivial commits. Small diffs go to a fast, cheap model; only substantial changes escalate to the strong one — automatically, and it tells you which it chose. No paying premium rates to commit a typo fix.
- Never auto-commits — you always get the last word. It pre-fills your editor on
git commit. No new command to remember, no message committed behind your back. Edit or delete it like any draft. - Terminal-native and private by design. A small, MIT-licensed Python CLI built to a strict safety-first style guide. Your diffs go straight to your chosen model and nowhere else.
Quick Start
pipx install noidea
noidea init
That's it. Every git commit now opens your editor with a suggested message pre-filled.
Requires pipx. Alternatively:
pip install noidea
API Key Setup
noidea needs an Anthropic API key. Three options (checked in order):
| Method | Command |
|---|---|
| Keyring (recommended) | noidea keys add |
| Environment variable | export ANTHROPIC_API_KEY=sk-ant-... |
.env file |
ANTHROPIC_API_KEY=sk-ant-... in a .env file |
Commands
| Command | Description |
|---|---|
noidea init |
Install the prepare-commit-msg hook. Backs up any existing hook. Respects core.hooksPath. |
noidea suggest |
Generate a commit message from the staged diff and print it. |
noidea status |
Show current config, API key status, and hook installation. |
noidea keys |
Manage API keys in the system keyring (show / add / remove). |
noidea test |
Send a test message to Claude to verify connectivity. |
noidea update |
Upgrade noidea via pipx (falls back to pip). |
noidea --version |
Print the current version. |
noidea suggest options
-F, --file TEXT Write message to file instead of stdout (used by the hook)
-M, --model TEXT Override the model used for generation
Config
Two optional config levels — both are config.json files:
- User:
~/.noidea/config.json— applies everywhere - Repo:
<repo>/.noidea/config.json— overrides user config
Precedence: built-in defaults → user config → repo config.
{
"llm": {
"max_tokens": 1024,
"small_model": "claude-haiku-4-5",
"large_model": "claude-sonnet-4-6",
"context_limit": 600000,
"temperature": 1.0,
"learn_commit_style": true,
"system_prompt": "Your custom prompt here"
}
}
Falls back to built-in defaults if no config file exists. The default prompt follows conventional commits style (feat/fix/refactor/etc.) with a 72-character subject line limit. Smaller diffs use small_model (Haiku) for speed; larger diffs automatically switch to large_model (Sonnet). temperature controls output creativity (0.0–1.0); the default of 1.0 maximises variety.
Repo-native style learning
learn_commit_style (on by default) samples your recent git log and matches the repo's own conventions — its scope vocabulary, whether commits carry a body, typical subject length, and gitmoji usage — so suggestions read like your project's existing commits rather than generic boilerplate. It activates automatically once a repo has at least 5 commits; below that it stays out of the way. Set "learn_commit_style": false to disable it.
Contributing
See CONTRIBUTING.md for development setup and guidelines. This project follows TigerStyle for coding standards.
Requirements
- Python 3.10+
- Anthropic API key
Project details
Release history Release notifications | RSS feed
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 noidea-1.1.0.tar.gz.
File metadata
- Download URL: noidea-1.1.0.tar.gz
- Upload date:
- Size: 21.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d163a90b3e55a4f66f312d5b61fef04d2f44d21eb5d2d5aa8a9983d0bd678775
|
|
| MD5 |
07d58b705bf5c95c6e0d2af2bb657d4e
|
|
| BLAKE2b-256 |
7e85cd64ddd0a5c4051098eea450706585b0d8a9cb354f1db062dfdfd8cc591f
|
Provenance
The following attestation bundles were made for noidea-1.1.0.tar.gz:
Publisher:
publish.yml on AccursedGalaxy/noidea
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
noidea-1.1.0.tar.gz -
Subject digest:
d163a90b3e55a4f66f312d5b61fef04d2f44d21eb5d2d5aa8a9983d0bd678775 - Sigstore transparency entry: 1605298825
- Sigstore integration time:
-
Permalink:
AccursedGalaxy/noidea@adaf8c80e10dd61af25f023479dfe6c76b23608c -
Branch / Tag:
refs/tags/v1.1.0 - Owner: https://github.com/AccursedGalaxy
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@adaf8c80e10dd61af25f023479dfe6c76b23608c -
Trigger Event:
push
-
Statement type:
File details
Details for the file noidea-1.1.0-py3-none-any.whl.
File metadata
- Download URL: noidea-1.1.0-py3-none-any.whl
- Upload date:
- Size: 24.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b2ce6d8f05b29552833a3330959b0ae91501bbefaf6dc9d5e8acefb9b24ca211
|
|
| MD5 |
d350d4aa38c2edee56502a73ca6cb134
|
|
| BLAKE2b-256 |
15504bb421c4e71792e7ec6f6843e766f557bda73a2287010a4e04248f7d9630
|
Provenance
The following attestation bundles were made for noidea-1.1.0-py3-none-any.whl:
Publisher:
publish.yml on AccursedGalaxy/noidea
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
noidea-1.1.0-py3-none-any.whl -
Subject digest:
b2ce6d8f05b29552833a3330959b0ae91501bbefaf6dc9d5e8acefb9b24ca211 - Sigstore transparency entry: 1605298960
- Sigstore integration time:
-
Permalink:
AccursedGalaxy/noidea@adaf8c80e10dd61af25f023479dfe6c76b23608c -
Branch / Tag:
refs/tags/v1.1.0 - Owner: https://github.com/AccursedGalaxy
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@adaf8c80e10dd61af25f023479dfe6c76b23608c -
Trigger Event:
push
-
Statement type: