Generate a Conventional Commits message from your staged diff using the Cursor Agent, then open your Git editor for review before committing.
Works on macOS, Linux, and Windows (via Git for Windows Bash, MSYS2, or WSL).
- Summarizes staged changes only (lockfiles excluded)
- Conventional Commits format (subject + body + optional footers)
- Wraps body lines to 100 characters
- Optional issue reference on the subject line (
AB#12345) - Always opens your editor (
git commit -ve) — nothing is committed without your approval
| Platform | Supported terminal | Install location |
|---|---|---|
| macOS | Terminal, iTerm, etc. | $(brew --prefix)/bin/git-ai-commit (Homebrew) |
| Linux | Any POSIX shell | $(brew --prefix)/bin/git-ai-commit (Homebrew) |
| Windows | Git Bash, MSYS2, or WSL (not plain cmd.exe / PowerShell alone) |
%USERPROFILE%\.config\git\git-ai-commit (manual) |
git-ai-commit is a POSIX sh script. On Windows, run git ai-commit from Git Bash or WSL so Git can invoke sh and the script's utilities (mktemp, fold, etc.).
| Requirement | Notes |
|---|---|
| Git 2.x+ | Alias support required |
| POSIX shell | Provided by macOS/Linux natively; on Windows use Git Bash or WSL |
| Cursor CLI | cursor on PATH; cursor agent must work (logged in) |
| Staged changes | Run git add before git ai-commit |
Verify the CLI (same on all platforms):
cursor --version
cursor agent --helpThis repository is a Homebrew tap. Add it once, then install with the standard command:
brew tap henriquecarv/git-ai-commit https://github.com/henriquecarv/git-ai-commit.git
brew install git-ai-commit
git-ai-commit setupgit-ai-commit setup interactively asks for your default Git editor and issue tracker prefix, and configures ~/.gitconfig:
core.editor— e.g.vim,nano,code --wait,cursor --waitai-commit.issue-prefix— e.g.AB#,JIRA-,GH-(optional; leave blank for none)alias.ai-commit—!git-ai-commit
After setup, use git ai-commit in any repository.
Upgrade
brew upgrade git-ai-commitRe-run git-ai-commit setup only if you want to change your editor, issue prefix, or refresh the alias.
See TAP.md for local tap development and maintainer release notes.
Use this path if you do not use Homebrew (required on Windows).
| OS | Script directory |
|---|---|
| macOS, Linux | ~/.config/git/git-ai-commit/ |
| Windows | %USERPROFILE%\.config\git\git-ai-commit\ |
Global Git config file:
| OS | File |
|---|---|
| macOS, Linux | ~/.gitconfig |
| Windows | %USERPROFILE%\.gitconfig |
macOS / Linux / Git Bash
mkdir -p ~/.config/git
git clone https://github.com/henriquecarv/git-ai-commit.git ~/.config/git/git-ai-commitSSH alternative:
git clone git@github.com:henriquecarv/git-ai-commit.git ~/.config/git/git-ai-commitWindows (PowerShell — clone only)
New-Item -ItemType Directory -Force -Path "$env:USERPROFILE\.config\git"
git clone https://github.com/henriquecarv/git-ai-commit.git "$env:USERPROFILE\.config\git\git-ai-commit"Continue setup from Git Bash (see below).
Run from Git Bash on Windows, or any terminal on macOS/Linux:
chmod +x ~/.config/git/git-ai-commit/git-ai-commit
chmod +x ~/.config/git/git-ai-commit/setupRun either command:
~/.config/git/git-ai-commit/git-ai-commit setupOr invoke the setup script directly:
~/.config/git/git-ai-commit/setupThis interactively sets core.editor, ai-commit.issue-prefix, and alias.ai-commit in ~/.gitconfig. The alias uses the full path to git-ai-commit when it is not on PATH.
After setup, use git ai-commit in any repository.
Edit ~/.gitconfig (or %USERPROFILE%\.gitconfig on Windows) and add:
macOS / Linux / Git Bash
[core]
editor = vim
[ai-commit]
issue-prefix = AB#
[alias]
ai-commit = "!$HOME/.config/git/git-ai-commit/git-ai-commit"Replace editor with your preferred editor, for example:
vimornanocode --wait(VS Code)cursor --wait(Cursor)notepad(Windows Git Bash)
The ai-commit alias must point at the cloned git-ai-commit script. Adjust the path if you installed elsewhere.
cd ~/.config/git/git-ai-commit && git pull- Run
git ai-commitfrom Git Bash or WSL, not plaincmd.exe/ PowerShell. $HOMEinside Git Bash is your Windows user profile (same as%USERPROFILE%).- WSL: treat as Linux — use Homebrew inside WSL, or follow the manual steps above under the WSL home directory.
- Install the Cursor CLI in the same environment where you run Git.
[commit]
verbose = trueThe script already passes -v to git commit; this setting keeps verbose commits consistent for manual commits too.
Run from a repository terminal that supports the alias (Git Bash on Windows):
# Stage your changes
git add -p
# Generate message and open editor
git ai-commit
# Append issue ref to subject: "fix: foo (AB#12345)"
git ai-commit 12345
git ai-commit AB#12345Workflow
git ai-commitruns the agent (spinner on stderr:Loading commit message...)- Your configured editor opens with the proposed message and staged diff
- Edit, save, and quit to commit; close without saving to abort
Excluded from the diff sent to the agent
package-lock.jsonyarn.lockpnpm-lock.yaml
Edit git-ai-commit locally or fork this repository:
| Setting / variable | Default | Purpose |
|---|---|---|
ai-commit.issue-prefix (git config) |
(empty) | Tracker prefix for git ai-commit <id>; set via git-ai-commit setup |
BODY_LINE_LENGTH |
100 |
Max width for body lines (fold) |
AGENT_PROMPT |
(built-in) | Instructions passed to the Cursor agent |
The agent is invoked as:
cursor agent -p --trust --mode ask --model auto "$prompt"| Symptom | What to do |
|---|---|
git: 'ai-commit' is not a git command |
Run git-ai-commit setup, or confirm [alias] in global config |
git-ai-commit: command not found |
Run brew install git-ai-commit, or confirm Homebrew bin is on PATH |
Permission denied (macOS/Linux/Git Bash) |
chmod +x on git-ai-commit and setup |
sh: ...: not found (Windows) |
Use Git Bash or WSL; avoid cmd.exe / PowerShell for git ai-commit |
cursor: command not found |
Install Cursor CLI; restart terminal; ensure cursor is on PATH in the same shell you use for Git |
no staged changes to summarize |
Stage files with git add; lockfiles alone are ignored |
cursor agent failed |
Log in to Cursor CLI; run cursor agent manually in the repo |
empty message from agent |
Retry or reduce diff size |
| Editor does not open | Run git-ai-commit setup, or set core.editor (e.g. vim, code --wait, notepad) |
| Script errors after clone on Windows | Run git config --global core.autocrlf input in Git Bash, or re-clone with git clone --config core.autocrlf=input |
Debug (macOS / Linux / Git Bash)
git config --global alias.ai-commit
git config --global core.editor
git config --global ai-commit.issue-prefix
which git-ai-commit sh cursor
git-ai-commit --helpDebug (Windows PowerShell — paths only)
git config --global alias.ai-commit
git config --global core.editor
git config --global ai-commit.issue-prefix
Test-Path "$env:USERPROFILE\.config\git\git-ai-commit\git-ai-commit"- The full staged diff is sent to Cursor's agent. Do not stage secrets (
.env, keys, tokens). --trustis used so the agent can run in your repo; use only in repositories you trust.- Always review the generated message in your editor before committing.
- Cursor CLI installed;
cursor agentworks in your terminal - macOS/Linux:
brew install git-ai-commitandgit-ai-commit setup - Windows: repository cloned;
chmod +xon both scripts;git-ai-commit setuprun from Git Bash -
ai-commitalias,core.editor, andai-commit.issue-prefixin global.gitconfig - Test: stage a small change →
git ai-commit
| File | Description |
|---|---|
git-ai-commit |
Commit CLI (git ai-commit target) |
setup |
Git config setup (via git-ai-commit setup) |
Formula/git-ai-commit.rb |
Homebrew formula |
TAP.md |
Tap and release notes |
README.md |
This document |
LICENSE |
MIT license |
MIT. Review all AI-generated commit messages before pushing.