Skip to content

halfline/git-stage-batch

Repository files navigation

git-stage-batch banner

git-stage-batch

PyPI version Python 3.10+ CI License: MIT

Hunk-by-hunk and line-by-line staging for git, designed for building clean commit history.

Writing code is messy. Git history doesn't have to be.

git-stage-batch demo

During development we experiment, refactor, backtrack, and fix mistakes. If every step ends up as a commit, the history becomes noise. A curated history turns that process into a clear sequence of logical changes.

git-stage-batch helps you build that history incrementally by letting you stage changes hunk-by-hunk or line-by-line, shaping commits around meaning instead of the order the edits happened.

Features

  • Command-based workflow - Perfect for automation and AI coding assistants
  • Line-level control - Stage specific lines within a hunk for maximum granularity
  • Interactive mode - Menu-driven hunk-by-hunk workflow inspired by git add -p
  • State persistence - Resume staging across multiple invocations
  • Batch operations - Save hunks for later, organize complex changes
  • Machine-readable output - --porcelain flag for scripting
  • No dependencies - Pure Python standard library

Quick Start

# Start reviewing hunks
git-stage-batch start

# Include the selected hunk (stage it)
git-stage-batch include

# Skip it for now
git-stage-batch skip

# Discard it (remove from working tree)
git-stage-batch discard

# Stage specific lines within a hunk
git-stage-batch include --line 1,3,5-7
git-stage-batch skip --line 2,4
git-stage-batch discard --line 8-10

# Check what's been processed
git-stage-batch status

# Start fresh after committing
git-stage-batch again

Example Workflow

# You have changes in multiple files
git status
# modified:   auth.py
# modified:   config.py

# Start staging
git-stage-batch start
# auth.py :: @@ -10,5 +10,5 @@
# [#1] - old_hash_function()
# [#2] + new_hash_function()

# Include this for first commit
git-stage-batch i

# Create first commit
git commit -m "auth: Upgrade to new hash function"

# Continue with remaining changes
git-stage-batch a

Why git-stage-batch?

Similar to git add -p but more granular and flexible:

  • Line-by-line staging - Stage specific lines within a hunk
  • Interactive mode - Continuous hunk-by-hunk workflow with menus
  • Batch operations - Save hunks for later processing
  • Colored output - Clear visual distinction in your terminal
  • File operations - Stage/skip entire files at once

Interactive Mode

For a continuous hunk-by-hunk workflow:

# Launch interactive mode
git-stage-batch -i

# Navigate with single-key commands
# [i]nclude, [s]kip, [d]iscard, [l]ines, [f]ile, [a]gain, [q]uit

Machine-Readable Output

For scripting and automation, use the --porcelain flag:

# Get status as JSON
git-stage-batch status --porcelain

# Check if a hunk exists (exit code 0/1)
git-stage-batch show --porcelain

Batch Operations

Save hunks for later processing with named batches:

# Create a new batch
git-stage-batch new feature-work --note "Refactoring work"

# List all batches
git-stage-batch list

# Annotate a batch
git-stage-batch annotate feature-work "Updated description"

# Drop a batch when done
git-stage-batch drop feature-work

Installation

# Using uv (recommended)
uv tool install git-stage-batch

# Using pipx
pipx install git-stage-batch

# Using pip
pip install git-stage-batch

Requirements

  • Python 3.10+
  • No other dependencies (pure stdlib!)

Documentation

Contributing

Contributions are welcome! Please see CONTRIBUTING.md for:

  • Development setup instructions
  • Commit message guidelines
  • Code style conventions

License

MIT License

Links

About

Hunk-by-hunk and line-by-line staging for git

Resources

Contributing

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages