| name | git-workflow-manager |
| version | 5.0.0 |
| description | Manages git operations: worktree creation, branch management, commits, PRs, semantic versioning, and daily rebase workflow. Use when: Creating branches/worktrees, committing, pushing, versioning Triggers: create worktree, commit, push, rebase, version, PR |
Git Workflow Manager
Purpose
Handles all git operations following git-flow + GitHub-flow hybrid model.
Branch Structure
main ← Production (tagged vX.Y.Z)
↑
release/vX.Y.Z ← Release candidate
↑
develop ← Integration branch
↑
contrib/<gh-user> ← Personal contribution branch
↑
feature/<timestamp>_<slug> ← Isolated feature (worktree)
hotfix/vX.Y.Z-hotfix.N ← Production hotfix (worktree)
Protected Branch Policy
CRITICAL: This skill manages git operations and MUST enforce branch protection rules.
Protected branches (NEVER delete, NEVER commit directly):
main- Production branch (tagged releases only)develop- Integration branch (PR merges only)
All scripts in this skill comply with:
- No direct commits to
main(except tag operations) - No direct commits to
develop(except backmerge_release.py - documented exception) - All merges via pull requests (user merges in GitHub/Azure DevOps UI)
Exception documented:
backmerge_release.pycommits todevelopduring Phase 5.5 back-merge- This is safe: merges from release branch only, no code changes, maintains history
Script validation:
- All scripts in
scripts/directory are validated for compliance - Test:
tests/test_branch_protection.pyverifies no unintended main/develop commits - See WORKFLOW.md "Branch Protection Policy" for complete rules
Scripts
create_worktree.py
Creates feature/release/hotfix worktree with TODO file.
python .claude/skills/git-workflow-manager/scripts/create_worktree.py \
<feature|release|hotfix> <slug> <base_branch>
Arguments:
workflow_type: feature, release, or hotfixslug: Short descriptive name (e.g., 'json-validator')base_branch: Branch to create from (e.g., 'contrib/username')
Output:
- Creates worktree directory
- Creates new branch
- Generates TODO file in main repo
daily_rebase.py
Performs daily rebase of contrib branch onto develop.
python .claude/skills/git-workflow-manager/scripts/daily_rebase.py \
<contrib_branch>
Steps:
- Checkout contrib branch
- Fetch origin
- Rebase onto origin/develop
- Force push with lease
semantic_version.py
Calculates semantic version based on component changes.
python .claude/skills/git-workflow-manager/scripts/semantic_version.py \
<base_branch> <current_version>
Version bump logic:
- MAJOR: Breaking changes (API changes, removed features)
- MINOR: New features (new files, new functions)
- PATCH: Bug fixes, refactoring, docs
create_release.py
Creates release branch from develop with TODO file generation.
python .claude/skills/git-workflow-manager/scripts/create_release.py \
<version> <base_branch>
Arguments:
version: Semantic version (e.g., v1.1.0, v2.0.0)base_branch: Branch to release from (typically 'develop')
Steps:
- Validates version format and inputs
- Checks semantic version recommendation
- Creates release branch (release/vX.Y.Z)
- Generates TODO_release_*.md file
- Pushes branch to origin
Output:
✓ Created release branch: release/v1.1.0
✓ Base: develop (commit abc123)
✓ TODO file: TODO_release_20251023T143000Z_v1-1-0.md
✓ Ready for final QA and documentation updates
tag_release.py
Creates annotated tag on main branch after release merge.
python .claude/skills/git-workflow-manager/scripts/tag_release.py \
<version> <branch>
Arguments:
version: Semantic version to tag (e.g., v1.1.0)branch: Branch to tag (typically 'main')
Steps:
- Validates version format and inputs
- Checks out and pulls latest from branch
- Creates annotated tag with release message
- Pushes tag to origin
- Optionally creates GitHub release via gh CLI
Output:
✓ Checked out main branch
✓ Pulled latest changes (commit def456)
✓ Created annotated tag: v1.1.0
Message: "Release v1.1.0: Production release with vocabulary modules"
✓ Pushed tag to origin
✓ GitHub release created: https://github.com/user/german/releases/tag/v1.1.0
backmerge_release.py
Merges release branch back to develop after main merge.
python .claude/skills/git-workflow-manager/scripts/backmerge_release.py \
<version> <target_branch>
Arguments:
version: Release version (e.g., v1.1.0)target_branch: Branch to merge into (typically 'develop')
Steps:
- Validates version and verifies tag exists
- Checks out and pulls target branch
- Attempts merge with --no-ff strategy
- On success: pushes to remote
- On conflicts: creates PR for manual resolution
Output (no conflicts):
✓ Checked out develop
✓ Pulled latest changes
✓ Merged release/v1.1.0 into develop (no conflicts)
✓ Pushed to origin/develop
✓ Back-merge complete
Output (with conflicts):
⚠ Merge conflicts detected
✓ Created PR: https://github.com/user/german/pull/46
Title: "chore(release): back-merge v1.1.0 to develop"
Please resolve conflicts in GitHub UI and merge.
cleanup_release.py
Deletes release branch after successful release and back-merge.
python .claude/skills/git-workflow-manager/scripts/cleanup_release.py \
<version>
Arguments:
version: Release version (e.g., v1.1.0)
Safety Checks (all must pass):
- Tag exists
- Tag is on main branch
- Release commits are in develop
- Branch is fully merged
Steps:
- Runs comprehensive safety checks
- Deletes local release branch (git branch -d)
- Deletes remote release branch
- Archives TODO file
Output:
✓ Verified tag v1.1.0 exists
✓ Verified tag on main branch
✓ Verified back-merge to develop complete
✓ Deleted local branch: release/v1.1.0
✓ Deleted remote branch: origin/release/v1.1.0
✓ Archived: TODO_release_20251023T143000Z_v1-1-0.md
✓ Release workflow complete for v1.1.0
Release Workflow
The release workflow implements Phase 5 from WORKFLOW.md, providing a complete automation of git-flow release process.
When to Use Release Workflow
Use release workflow when:
- Ready to create production release from develop
- All features for version are integrated and tested
- Quality gates pass on develop branch
- Following semantic versioning for the release
Use hotfix workflow when:
- Critical production bug needs immediate fix
- Cannot wait for regular release cycle
- Fix targets specific production version
Typical Release Sequence
# Step 1: Create release branch from develop
python .claude/skills/git-workflow-manager/scripts/create_release.py \
v1.1.0 develop
# Step 2: Perform QA on release branch
# - Run quality gates
# - Update documentation
# - Update version in pyproject.toml
# Step 3: Create PR: release/v1.1.0 → main
gh pr create --base main --title "Release v1.1.0"
# Step 4: User merges PR in GitHub UI
# (Manual step - review and merge)
# Step 5: Tag release on main
python .claude/skills/git-workflow-manager/scripts/tag_release.py \
v1.1.0 main
# Step 6: Back-merge to develop
python .claude/skills/git-workflow-manager/scripts/backmerge_release.py \
v1.1.0 develop
# Step 7: Cleanup release branch
python .claude/skills/git-workflow-manager/scripts/cleanup_release.py \
v1.1.0
# Step 8: Update contrib branch
python .claude/skills/git-workflow-manager/scripts/daily_rebase.py \
contrib/<gh-user>
Integration with Phase 5
The release scripts implement the 8-step process documented in WORKFLOW.md Phase 5:
| Step | Script | Description |
|---|---|---|
| 5.1 | create_release.py | Create release branch |
| 5.2 | Manual | QA and documentation updates |
| 5.3 | gh pr create | Create PR to main |
| 5.4 | Manual | User merges in GitHub UI |
| 5.5 | tag_release.py | Tag release on main |
| 5.6 | backmerge_release.py | Back-merge to develop |
| 5.7 | cleanup_release.py | Delete release branch |
| 5.8 | daily_rebase.py | Update contrib branch |
Error Recovery
If a release workflow step fails:
- create_release.py fails: Branch and TODO file are cleaned up automatically
- tag_release.py fails: Local tag is cleaned up on push failure
- backmerge_release.py conflicts: PR is created for manual resolution
- cleanup_release.py safety checks fail: Branch is NOT deleted, manual cleanup required
All scripts include comprehensive error messages with recovery instructions.
Commit Message Format
<type>(<scope>): <subject>
<body>
<footer>
Types: feat, fix, docs, style, refactor, test, chore
Example:
feat(validator): add JSON schema validation endpoint
Implements REST API endpoint for validating JSON against schemas.
Uses jsonschema library for validation logic.
Implements: impl_003
Spec: specs/json-validator/spec.md
Tests: tests/test_validator.py
Coverage: 85%
Refs: TODO_feature_20251022T143022Z_json-validator.md
PR Creation
# Feature → contrib/<gh-user>
gh pr create \
--base "contrib/<gh-user>" \
--head "<feature-branch>" \
--title "feat: <description>" \
--body "See TODO_feature_*.md for details"
# After user merges in GitHub UI:
# Contrib → develop
gh pr create \
--base "develop" \
--head "contrib/<gh-user>" \
--title "feat: <description>" \
--body "Completed feature: <name>"
Integration with Other Skills
Other skills call these scripts:
import subprocess
# Create worktree
result = subprocess.run([
'python',
'.claude/skills/git-workflow-manager/scripts/create_worktree.py',
'feature', 'my-feature', 'contrib/user'
], capture_output=True, text=True)
# Calculate version
result = subprocess.run([
'python',
'.claude/skills/git-workflow-manager/scripts/semantic_version.py',
'develop', 'v1.0.0'
], capture_output=True, text=True)
new_version = result.stdout.strip()