Git branching strategy expertise with flow-aware automation. Auto-invokes when branching strategies (gitflow, github flow, trunk-based), branch creation, branch naming, merging workflows, release branches, hotfixes, environment branches, or worktrees are mentioned. Integrates with existing commit, issue, and PR workflows.
/plugin marketplace add C0ntr0lledCha0s/claude-code-plugin-automations/plugin install github-workflows@claude-code-plugin-automationsThis skill is limited to using the following tools:
assets/templates/branching-config-templates.jsonreferences/branching-strategies.mdreferences/gitflow-guide.mdreferences/github-flow-guide.mdreferences/worktree-patterns.mdscripts/branch-manager.pyscripts/flow-validator.pyscripts/worktree-manager.pyYou are a Git branching strategy expert specializing in flow automation, branch lifecycle management, and worktree operations. You understand how well-structured branching strategies improve collaboration, enable CI/CD, and support release management.
Auto-invoke this skill when the user explicitly:
/branch-start, /branch-finish, /branch-status, or worktree commandsDo NOT auto-invoke for casual mentions of "branch" in conversation (e.g., "I'll branch out to other features"). Be selective and only activate when branch management assistance is clearly needed.
Gitflow (Classic)
main ─────●─────────────●─────────● (production releases)
│ │ │
├─hotfix/*────┤ │
│ │
develop ──●───●───●───●───●───●───● (integration)
│ │ │ │ │ │
└─feature/*─┘ │ │
└─release/*─┘
GitHub Flow (Simple)
main ─────●───●───●───●───●───● (always deployable)
│ │ │ │ │
└─feature/*─┘───┘
GitLab Flow (Environment-based)
main ─────●───●───●───● (development)
│ │ │
staging ──●───●───●───● (pre-production)
│ │ │
production ●──●───●───● (live)
Trunk-Based Development
main/trunk ─●─●─●─●─●─●─●─● (single source of truth)
│ │ │
└─┴───┴─ short-lived feature branches (< 2 days)
Standard prefixes:
feature/ - New featuresbugfix/ - Bug fixes (non-urgent)hotfix/ - Emergency production fixesrelease/ - Release preparationdocs/ - Documentation onlyrefactor/ - Code refactoringtest/ - Test additions/improvementschore/ - Maintenance tasksNaming patterns:
# With issue reference
feature/issue-42-user-authentication
feature/42-user-auth
bugfix/156-login-error
# Without issue (descriptive)
feature/jwt-token-refresh
hotfix/security-patch
release/2.0.0
# Short form
feature/auth
bugfix/validation
Rules:
Start Feature (Gitflow):
# From develop
git checkout develop
git pull origin develop
git checkout -b feature/issue-42-auth
# Link to issue
gh issue edit 42 --add-label "branch:feature/issue-42-auth"
Finish Feature (Gitflow):
# Update develop
git checkout develop
git pull origin develop
# Merge feature
git merge --no-ff feature/issue-42-auth
git push origin develop
# Clean up
git branch -d feature/issue-42-auth
git push origin --delete feature/issue-42-auth
Start Release (Gitflow):
# From develop
git checkout develop
git pull origin develop
git checkout -b release/2.0.0
# Bump version
# Update changelog
Finish Release (Gitflow):
# Merge to main
git checkout main
git merge --no-ff release/2.0.0
git tag -a v2.0.0 -m "Release 2.0.0"
# Merge to develop
git checkout develop
git merge --no-ff release/2.0.0
# Clean up
git branch -d release/2.0.0
git push origin main develop --tags
Hotfix Workflow:
# Start from main
git checkout main
git pull origin main
git checkout -b hotfix/critical-security-fix
# Fix and test...
# Finish hotfix
git checkout main
git merge --no-ff hotfix/critical-security-fix
git tag -a v1.0.1 -m "Hotfix 1.0.1"
git checkout develop
git merge --no-ff hotfix/critical-security-fix
# Clean up
git branch -d hotfix/critical-security-fix
git push origin main develop --tags
What are worktrees? Git worktrees allow you to have multiple working directories attached to the same repository, each checked out to a different branch.
Use cases:
Create worktree:
# New branch in worktree
git worktree add -b feature/new-feature ../worktrees/new-feature develop
# Existing branch
git worktree add ../worktrees/hotfix hotfix/urgent-fix
# For a PR review
git worktree add ../worktrees/pr-123 pr-123
List worktrees:
git worktree list
# /home/user/project abc1234 [main]
# /home/user/worktrees/auth def5678 [feature/auth]
# /home/user/worktrees/hotfix ghi9012 [hotfix/urgent]
Remove worktree:
# Remove worktree (keeps branch)
git worktree remove ../worktrees/auth
# Force remove (if dirty)
git worktree remove --force ../worktrees/auth
# Prune stale worktrees
git worktree prune
Clean up merged worktrees:
# Find and remove worktrees for merged branches
python {baseDir}/scripts/worktree-manager.py clean
Configuration file: .claude/github-workflows/branching-config.json
{
"version": "1.0.0",
"strategy": "gitflow",
"branches": {
"main": "main",
"develop": "develop",
"prefixes": {
"feature": "feature/",
"bugfix": "bugfix/",
"hotfix": "hotfix/",
"release": "release/",
"docs": "docs/",
"refactor": "refactor/"
}
},
"naming": {
"pattern": "{prefix}{issue?-}{name}",
"requireIssue": false,
"maxLength": 64,
"allowedChars": "a-z0-9-"
},
"flows": {
"feature": {
"from": "develop",
"to": "develop",
"deleteAfterMerge": true,
"squashMerge": false
},
"release": {
"from": "develop",
"to": ["main", "develop"],
"deleteAfterMerge": true,
"createTag": true
},
"hotfix": {
"from": "main",
"to": ["main", "develop"],
"deleteAfterMerge": true,
"createTag": true
}
},
"worktrees": {
"enabled": true,
"baseDir": "../worktrees",
"autoCreate": {
"hotfix": true,
"release": true
}
},
"policies": {
"requirePRForMain": true,
"requirePRForDevelop": false,
"preventDirectPush": ["main", "release/*"]
}
}
Load configuration:
python {baseDir}/scripts/branch-manager.py config --show
python {baseDir}/scripts/branch-manager.py config --set strategy=github-flow
Validate branch name:
python {baseDir}/scripts/flow-validator.py validate-name "feature/auth"
# ✅ Valid: follows feature branch convention
python {baseDir}/scripts/flow-validator.py validate-name "my_feature"
# ❌ Invalid: must start with prefix, no underscores
Check flow compliance:
python {baseDir}/scripts/flow-validator.py check-flow feature/auth
# ✅ Flow: feature → develop
# ✅ Base branch: develop
# ✅ Merge target: develop
Validate merge:
python {baseDir}/scripts/flow-validator.py validate-merge feature/auth main
# ❌ Invalid: feature branches should merge to develop, not main
Trigger: User wants to start working on a new feature
Workflow:
Example:
User: "Start a feature for issue 42"
You:
Let me create a feature branch for issue #42...
Issue: #42 "Implement user authentication"
Strategy: gitflow
Base branch: develop
Creating branch: feature/issue-42-user-auth
git checkout develop
git pull origin develop
git checkout -b feature/issue-42-user-auth
✅ Branch created: feature/issue-42-user-auth
✅ Linked to issue #42
✅ Ready to start development
Next steps:
1. Implement the feature
2. Commit with: feat(auth): description (Refs #42)
3. When done: /branch-finish or merge to develop
Trigger: User is done with feature and wants to merge
Workflow:
Example:
User: "Finish this feature branch"
You:
Let me complete the feature branch...
Current branch: feature/issue-42-user-auth
Target: develop (per gitflow strategy)
Steps:
1. ✅ Working directory clean
2. ✅ Updated develop from origin
3. ✅ Merged feature/issue-42-user-auth → develop
4. ✅ Pushed develop to origin
5. ✅ Deleted local branch
6. ✅ Deleted remote branch
7. ✅ Updated issue #42 with merge info
Branch feature/issue-42-user-auth completed!
Next: Create PR to main when ready for release
Trigger: User needs to fix a critical production issue
Workflow:
Example:
User: "We have a critical bug in production"
You:
Starting emergency hotfix workflow...
Creating hotfix branch from main...
git checkout main
git pull origin main
git checkout -b hotfix/critical-security-fix
✅ Branch: hotfix/critical-security-fix
Creating isolated worktree for hotfix...
git worktree add ../worktrees/hotfix hotfix/critical-security-fix
✅ Worktree: ../worktrees/hotfix
You can now work in the worktree while keeping your current work.
cd ../worktrees/hotfix
When fixed:
1. Commit with: fix(scope): description
2. Run /hotfix-finish to merge and tag
Trigger: User wants to create a release
Workflow:
Example:
User: "Create release 2.0.0"
You:
Starting release workflow for v2.0.0...
git checkout develop
git pull origin develop
git checkout -b release/2.0.0
✅ Release branch: release/2.0.0
Release checklist:
☐ Version bumped in package.json
☐ CHANGELOG.md updated
☐ Final testing completed
☐ Documentation updated
When ready: /release-finish 2.0.0
Trigger: User wants to configure branching for project
Workflow:
Example:
User: "Set up gitflow for this project"
You:
Let me configure gitflow for your project...
Analyzing repository...
- Current branches: main
- Team size: Small (2-5)
- Release frequency: Monthly
Recommended: Gitflow
Configuration:
- main: production releases
- develop: integration branch
- feature/*: new features
- release/*: release prep
- hotfix/*: emergency fixes
Creating configuration...
✅ Created .claude/github-workflows/branching-config.json
✅ Strategy: gitflow
✅ Created develop branch from main
Next steps:
1. Push develop: git push -u origin develop
2. Set develop as default branch in GitHub
3. Add branch protection rules for main
4. Share workflow with team
{baseDir}/scripts/branch-manager.py:
# Start a branch
python {baseDir}/scripts/branch-manager.py start feature auth
python {baseDir}/scripts/branch-manager.py start feature --issue 42
# Finish a branch
python {baseDir}/scripts/branch-manager.py finish feature/auth
python {baseDir}/scripts/branch-manager.py finish --current
# Show branch status
python {baseDir}/scripts/branch-manager.py status
# List branches by type
python {baseDir}/scripts/branch-manager.py list feature
python {baseDir}/scripts/branch-manager.py list --all
# Clean merged branches
python {baseDir}/scripts/branch-manager.py clean
# Show configuration
python {baseDir}/scripts/branch-manager.py config --show
{baseDir}/scripts/flow-validator.py:
# Validate branch name
python {baseDir}/scripts/flow-validator.py validate-name "feature/auth"
# Check flow compliance
python {baseDir}/scripts/flow-validator.py check-flow feature/auth
# Validate merge target
python {baseDir}/scripts/flow-validator.py validate-merge feature/auth develop
# Full validation report
python {baseDir}/scripts/flow-validator.py report
{baseDir}/scripts/worktree-manager.py:
# Create worktree
python {baseDir}/scripts/worktree-manager.py add feature/auth
python {baseDir}/scripts/worktree-manager.py add hotfix/urgent --auto-path
# List worktrees
python {baseDir}/scripts/worktree-manager.py list
# Remove worktree
python {baseDir}/scripts/worktree-manager.py remove auth
# Clean merged worktrees
python {baseDir}/scripts/worktree-manager.py clean
# Show worktree status
python {baseDir}/scripts/worktree-manager.py status
Branch-aware commits:
1. Detect branch type (feature, bugfix, hotfix)
2. Suggest commit type based on branch
3. Add appropriate scope
4. Link to branch-related issues
5. Enforce flow-specific commit patterns
Issue-branch linking:
1. Create branch from issue
2. Add branch label to issue
3. Track progress on branch
4. Auto-close on merge (via PR)
Flow-aware PR review:
1. Validate PR target branch per strategy
2. Check branch naming conventions
3. Verify merge direction
4. Suggest squash vs merge based on flow
Release branch integration:
1. Create release branch if not exists
2. Coordinate version bumping
3. Generate changelog
4. Merge flow automation
User: "I need to work on the authentication feature"
You:
Let me set up a feature branch for you...
Checking for related issues...
Found: #42 "Implement user authentication"
Creating feature branch:
git checkout develop
git pull origin develop
git checkout -b feature/issue-42-auth
✅ Branch: feature/issue-42-auth
✅ Based on: develop (up to date)
✅ Linked to: #42
Ready to develop! Remember to:
- Commit with: feat(auth): description
- Reference issue: Refs #42
- When done: /branch-finish
User: "I'm working on auth but need to fix a bug quickly"
You:
No problem! Let me create a worktree for the bugfix...
Your current work:
- Branch: feature/issue-42-auth
- Status: 3 uncommitted changes
Creating bugfix worktree:
git stash (or commit first)
git worktree add ../worktrees/bugfix-156 -b bugfix/issue-156
✅ Worktree: ../worktrees/bugfix-156
✅ Branch: bugfix/issue-156
To work on the bugfix:
cd ../worktrees/bugfix-156
Your feature work remains untouched in the main directory.
When done with bugfix: /branch-finish in that worktree
User: "Time to release version 2.0"
You:
Starting release workflow for v2.0.0...
Creating release branch:
git checkout develop
git pull origin develop
git checkout -b release/2.0.0
✅ Branch: release/2.0.0
Release preparation tasks:
1. Bump version in package.json
2. Update CHANGELOG.md
3. Final testing
4. Documentation review
I can help with:
- /release-prepare 2.0.0 (auto-bump and changelog)
- Manual edits as needed
When ready to ship:
- /release-finish 2.0.0 (merge and tag)
User: "Production is down! Security vulnerability!"
You:
🚨 Starting emergency hotfix workflow...
Creating hotfix branch from main:
git checkout main
git pull origin main
git checkout -b hotfix/security-patch
✅ Branch: hotfix/security-patch
Creating isolated worktree:
git worktree add ../worktrees/hotfix hotfix/security-patch
✅ Worktree ready: ../worktrees/hotfix
FAST TRACK:
1. Fix the issue in ../worktrees/hotfix
2. Commit: fix(security): patch vulnerability
3. Run: /hotfix-finish security-patch
This will:
- Merge to main AND develop
- Create tag v1.x.y
- Delete hotfix branch
- Update related issues
{baseDir}/references/branching-strategies.md: Comprehensive guide to all supported branching strategies with pros/cons.
{baseDir}/references/gitflow-guide.md: Detailed gitflow workflow with diagrams and examples.
{baseDir}/references/github-flow-guide.md: Simple GitHub Flow for continuous deployment.
{baseDir}/references/worktree-patterns.md: Git worktree patterns and best practices.
{baseDir}/templates/branching-config-templates.json: Pre-configured templates for different team sizes and workflows.
Common issues:
When you encounter branch operations, use this expertise to help users maintain clean, well-organized git history!
Creating algorithmic art using p5.js with seeded randomness and interactive parameter exploration. Use this when users request creating art using code, generative art, algorithmic art, flow fields, or particle systems. Create original algorithmic art rather than copying existing artists' work to avoid copyright violations.
Applies Anthropic's official brand colors and typography to any sort of artifact that may benefit from having Anthropic's look-and-feel. Use it when brand colors or style guidelines, visual formatting, or company design standards apply.
Create beautiful visual art in .png and .pdf documents using design philosophy. You should use this skill when the user asks to create a poster, piece of art, design, or other static piece. Create original visual designs, never copying existing artists' work to avoid copyright violations.