An open API service indexing awesome lists of open source software.

https://github.com/dinoDanic/diny

generate git commit messages
https://github.com/dinoDanic/diny

ai-tool automation cli cobra-cli commit commit-message developer-tools generated git git-commit-messages git-diff go messages ollama opensource plug-and-play

Last synced: 7 days ago
JSON representation

generate git commit messages

Awesome Lists containing this project

README

          

diny logo

# diny

### from git diff to clean commits

diny is a tiny dinosaur that writes your git commit messages for you.
It looks at your staged changes and generates clear, conventional-friendly messages.

πŸ”“ **No API key required** β€’ πŸ”Œ Plug and play β€’ ⚑ Fast and reliable β€’ 🌟 Open source




diny showcase


diny showcase
diny showcase
diny showcase
diny showcase
diny showcase

---

## Features

- πŸ” Reads staged changes with `git diff`
- 🧹 Filters out noise (lockfiles, binaries, build artifacts)
- ⚑ Generates commit messages via Ollama
- πŸ“ Produces concise, consistent messages
- πŸ”„ Interactive workflow with multiple options
- 🧠 Smart regeneration that learns from previous attempts
- ✍️ Custom feedback system for precise message refinement
- 🧷 Save to file (stash the generated message for later)
- πŸ“ Draft mode (prepare a commit message without committing)
- ✏️ Edit in your editor before committing
- πŸ“Š Timeline analysis of commit history and message patterns
- 🎨 Customizable UI themes (10+ dark and light themes)

## Install

### macOS / Linux

```bash
brew install dinoDanic/tap/diny
```

### Windows

#### Scoop (Recommended)

```powershell
scoop bucket add dinodanic https://github.com/dinoDanic/scoop-bucket
scoop install diny
```

### Manual Installation

Download pre-built binaries from [GitHub Releases](https://github.com/dinoDanic/diny/releases)

## Usage

Stage your changes, then run:

git add # Stage files
diny commit

### Auto Command (Git Alias)

Set up a git alias that creates a `git auto` command for diny-generated commit messages.

diny auto # Set up the git auto alias
diny auto remove # Remove the git auto alias

After setup, you can run:

git auto # uses diny to generate commit message

### LazyGit Integration

Integrate diny directly into [LazyGit](https://github.com/jesseduffield/lazygit) for seamless commit message generation from the LazyGit UI.

diny link lazygit

This adds a custom command to LazyGit's configuration, allowing you to generate commit messages with diny without leaving LazyGit.

## Commands

diny comes with a handful of simple commands. Each one is designed to fit naturally into your git workflow:

diny auto # Set up a git alias so you can run `git auto`

diny commit # Generate a commit message from your staged changes
diny commit --print # Print generated message to stdout only
diny commit --print | git commit -F - # Generated message and commit

diny config # Show your current diny configuration
diny init # Initialize diny with an interactive setup wizard
diny link lazygit # Integrate diny with LazyGit
diny theme # Select from 10+ dark and light UI themes
diny theme list # List all available themes with previews
diny timeline # Summarize and analyze your commit history
diny update # Update diny to the latest version

## Update

### Built-in update command

```bash
diny update
```

### Manual update

**macOS/Linux:**
```bash
brew update && brew upgrade dinoDanic/tap/diny
```

**Windows (Scoop):**
```powershell
scoop update diny
```

## Why diny exists

I'm terrible at commit messages. I type fast, make mistakes, and my history ends up full of gems like "fix stuff" and "ui thing." Not great when you need to remember what you actually did.

I built **diny** because I wanted my commits to be useful without thinking about them. It reads your changes, writes a decent message, and has a timeline feature that summarizes your day. Super handy for client updates or just remembering what you worked on when your brain already moved on.

It's AI doing what it's actually good atβ€”handling the repetitive stuff I'd rather not think about.

## TODO
[X] - Add lazygit integratio