askill
gitbutler-virtual-branches

gitbutler-virtual-branchesSafety 95Repository

This skill should be used when the user asks to "create a virtual branch", "assign file to branch", "work on multiple features simultaneously", "organize commits after coding", "use but commands", or mentions GitButler, virtual branches, parallel development without checkout, post-hoc commit organization, multi-agent concurrent development, or `--gitbutler`/`--but` flags.

21 stars
1.2k downloads
Updated 2/6/2026

Package Files

Loading files...
SKILL.md

GitButler Virtual Branches

Virtual branches → parallel development → post-hoc organization.

<when_to_use>

  • Multiple unrelated features in same workspace simultaneously
  • Multi-agent concurrent development (agents in same repo)
  • Exploratory coding where organization comes after writing
  • Post-hoc commit reorganization needed
  • Visual organization preferred (GUI + CLI)

NOT for: projects using Graphite (incompatible models), simple linear workflows (use plain git)

</when_to_use>

This, Not That

TaskThisNot That
Initialize workspacebut setupmanual setup
Create branchbut branch new namegit checkout -b name
View changesbut statusgit status
Assign file to branchbut rub <file-id> <branch>manual staging
Commit to branchbut commit <branch> -m "msg"git commit -m "msg"
Move commitbut rub <sha> <branch>git cherry-pick
Squash commitsbut squash <branch>git rebase -i
Undo operationbut undogit reset
Switch contextCreate new branchgit checkout

Key difference from Git: All branches visible at once. Organize files to branches after editing. No checkout.

Core Concepts

ConceptDescription
Virtual branchesMultiple branches applied simultaneously to working directory
Integration branchgitbutler/workspace tracks virtual branch state — never touch directly
Target branchBase branch (e.g., origin/main) all work diverges from
File assignmentAssign file hunks to branches with but rub
OplogOperations log for undo/restore — your safety net

Quick Start

# Initialize (one time)
but setup

# Create branch
but branch new feature-auth

# Make changes, check status for file IDs
but status
# ╭┄00 [Unassigned Changes]
# │   m6 A src/auth.ts

# Assign file to branch using ID
but rub m6 feature-auth

# Commit
but commit feature-auth -m "feat: add authentication"

Core Loop

  1. Create: but branch new <name>
  2. Edit: Make changes in working directory
  3. Check: but status to see file IDs
  4. Assign: but rub <file-id> <branch-name>
  5. Commit: but commit <branch> -m "message"
  6. Repeat: Continue with other features in parallel

The Power of but rub

Swiss Army knife — combines entities to perform operations:

SourceTargetOperation
File IDBranchAssign file to branch
File IDCommitAmend commit with file
Commit SHABranchMove commit between branches
Commit SHACommit SHASquash (newer into older)

Essential Commands

CommandPurpose
but setupInitialize GitButler in repository
but statusView changes and file IDs
but branch new <name>Create virtual branch
but branch new <name> --anchor <parent>Create stacked branch
but rub <source> <target>Assign/move/squash/amend
but commit <branch> -m "msg"Commit to branch
but commit <branch> -o -m "msg"Commit only assigned files
but absorbAuto-amend uncommitted changes to appropriate commits
but squash <commits>Squash commits (by IDs, range, or branch)
but show <id>Inspect a commit or branch in detail
but resolve <commit>Enter conflict resolution mode
but pushPush branches to remote
but pr newCreate/update PRs on forge
but config forge authAuthenticate with GitHub (OAuth)
but mark <branch>Auto-assign new changes to branch
but unmarkRemove all mark rules from workspace
but oplogShow operation history
but undoUndo last operation
but oplog snapshot --message "msg"Create manual snapshot
but pullUpdate workspace with latest base
but guiOpen GitButler GUI for current repo

JSON output: Use --json or -j flag on any command: but status --json

Parallel Development

# Create two independent features
but branch new feature-a
but branch new feature-b

# Edit files for both (same workspace!)
echo "Feature A" > feature-a.ts
echo "Feature B" > feature-b.ts

# Assign to respective branches
but rub <id-a> feature-a
but rub <id-b> feature-b

# Commit independently
but commit feature-a -m "feat: implement feature A"
but commit feature-b -m "feat: implement feature B"

# Both branches exist, zero conflicts, same directory

Conflict Handling

GitButler handles conflicts per-commit during rebase/update (unlike Git's all-or-nothing model):

  1. Rebase continues even when some commits conflict
  2. Conflicted commits marked in UI/status
  3. Use but resolve to enter resolution mode per commit
  4. Partial resolution can be saved for later
# Update base (may cause conflicts)
but pull

# Check which commits have conflicts
but status

# Enter resolution mode for a specific commit
but resolve <commit-id>

# Fix conflicts in your editor, then check remaining
but resolve status

# Finalize when done (or cancel to abort)
but resolve finish

For detailed conflict resolution workflows, see references/reference.md#conflict-resolution.

Auto-Assignment with Marks

Set up workspace rules to auto-assign files to branches:

# Auto-assign new changes to auth-feature branch
but mark auth-feature

# Remove all rules
but unmark

Useful for multi-agent workflows where changes should route to a specific branch.

ALWAYS:

  • Use but for all work within virtual branches
  • Use git only for integrating completed work into main
  • Return to gitbutler/workspace after git operations: git checkout gitbutler/workspace
  • Snapshot before risky operations: but oplog snapshot --message "..."
  • Assign files immediately after creating: but rub <id> <branch>
  • Check file IDs with but status before using but rub

NEVER:

  • Use git commit on virtual branches — breaks GitButler state

  • Use git add — GitButler manages index

  • Use git checkout on virtual branches — no checkout needed

  • Push gitbutler/integration to remote — it's local-only

  • Mix Graphite and GitButler in same repo — incompatible models

  • Pipe but status directly — causes panic; capture output first:

    status_output=$(but status)
    echo "$status_output" | head -5
    

Troubleshooting

SymptomSolution
Files not committingAssign first: but rub <file-id> <branch>
Broken pipe panicCapture output: output=$(but status)
Mixed git/but broke statebut pull or but setup
Lost workbut undo or but oplog restore <snapshot-id>

For detailed troubleshooting (branch tracking, conflicts, filename issues), see references/reference.md#troubleshooting-guide.

Recovery

Quick undo: but undo | Full restore: but oplog restore <snapshot-id> | View history: but oplog

For recovery from lost work or corrupted state, see references/reference.md#recovery-scenarios.

Reference Files

  • references/reference.md — Complete CLI reference, JSON schemas, troubleshooting
  • references/examples.md — Real-world workflow patterns with commands
  • references/ai-integration.md — Hooks, MCP server, agent lifecycle

Related Skills

External

Install

Download ZIP
Requires askill CLI v1.0+

AI Quality Score

95/100Analyzed 2/10/2026

An exceptionally well-structured and comprehensive skill for GitButler virtual branches. It provides clear command mappings, safety guardrails, and troubleshooting steps.

95
95
85
95
98

Metadata

Licenseunknown
Version-
Updated2/6/2026
Publisheroutfitter-dev

Tags

githubgithub-actionssecurity