Skip to main content

Assists with git workflows using LLMs.

Project description

DiffWeave AI

DiffWeave is a tool that automatically generates meaningful Git commit messages and pull request descriptions using large language models (LLMs). It analyzes your staged changes and creates descriptive commit messages, saving you time and ensuring consistent documentation.

Documentation available here

Demo

Installation & Quick Start

You can run DiffWeave via uvx diffweave-ai or from a local checkout using uv run diffweave-ai while developing this repo.

DiffWeave is installed as an isolated tool using uv:

# Make sure you have uv installed first
# https://docs.astral.sh/uv/getting-started/installation/

uvx diffweave-ai

Usage

Configure a model

Before generating commit messages, configure your model. DiffWeave supports two authentication types:

Token-based (OpenAI-compatible endpoints):

uvx diffweave-ai set-token-model "your-model-name" \
  --token "$YOUR_API_TOKEN" \
  --endpoint "https://your-endpoint-url"

The --endpoint flag defaults to https://api.openai.com/v1/responses if omitted.

Databricks (browser-based authentication):

uvx diffweave-ai set-databricks-browser-model "your-model-name" \
  --account "your-databricks-account"

This opens a browser window for authentication and caches the resulting token automatically.

Generate a commit message

Once you have a model configured and some changes staged in your current Git repository, run:

uvx diffweave-ai

This will:

  • Show the current git status.
  • Prompt you to stage files interactively.
  • Generate a commit message using your configured model.
  • Let you review and refine the message before committing.
  • Run git commit, then prompt whether to git push.
  • Optionally open the repository in a browser (requires --open-browser).

If you prefer a simpler, natural-language style instead of Conventional Commits, pass --simple:

uvx diffweave-ai --simple

To preview a message without committing:

uvx diffweave-ai --dry-run

For scripted or automated workflows (skips all prompts, commits, and pushes automatically):

uvx diffweave-ai --non-interactive

Generate a pull request description

To generate a PR title and body based on the diff between your branch and main:

uvx diffweave-ai pr

The result is copied to your clipboard automatically. Use --branch to diff against a branch other than main:

uvx diffweave-ai pr --branch my-base-branch

Features

  • AI-powered commit message generation based on staged diffs
  • Pull request description generation with automatic clipboard copy
  • Interactive or non-interactive workflows
  • Token-based (OpenAI-compatible) and Databricks browser authentication
  • Optional simpler commit style via --simple
  • Optional push and browser-open flow after committing

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

diffweave_ai-2.0.0.tar.gz (555.9 kB view details)

Uploaded Source

Built Distribution

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

diffweave_ai-2.0.0-py3-none-any.whl (21.0 kB view details)

Uploaded Python 3

File details

Details for the file diffweave_ai-2.0.0.tar.gz.

File metadata

  • Download URL: diffweave_ai-2.0.0.tar.gz
  • Upload date:
  • Size: 555.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for diffweave_ai-2.0.0.tar.gz
Algorithm Hash digest
SHA256 a6d4ff60813e5a973a14dca12442d10b39be57dc55b68977873bf9cc35c83c26
MD5 f16804fd326ec9e4f87f2f9d31473238
BLAKE2b-256 5a1404f0370c14f4ada6def721e2317cd4a2ab148570e5222d63a37b52ef9962

See more details on using hashes here.

Provenance

The following attestation bundles were made for diffweave_ai-2.0.0.tar.gz:

Publisher: release.yml on block/diffweave-ai

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

File details

Details for the file diffweave_ai-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: diffweave_ai-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 21.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for diffweave_ai-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c3ccb526328c7eefce5d178b734bc0f6eb0f38938614419a09622295c8913fbf
MD5 80de21fac9a561c3714d40b01fd88a73
BLAKE2b-256 0fed65850586a21d4038318b727f97b753502d8d718085d64c88d9b74045d4a2

See more details on using hashes here.

Provenance

The following attestation bundles were made for diffweave_ai-2.0.0-py3-none-any.whl:

Publisher: release.yml on block/diffweave-ai

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