merging-worktrees¶
Merges parallel worktrees back together with conflict detection, 3-way analysis, and ordered resolution. Ensures no feature is lost and no bug is introduced during integration of concurrent development tracks. This core spellbook skill handles the integration phase after parallel implementation completes.
Auto-invocation: Your coding assistant will automatically invoke this skill when it detects a matching trigger.
Use when merging parallel worktrees back together after parallel implementation, combining parallel development tracks, or unifying branches from dispatched parallel agents. Triggers: 'merge worktrees', 'combine parallel branches', 'integrate parallel work', 'all tracks complete', 'bring everything together'.
Workflow Diagram¶
Merge parallel worktrees into a unified branch using dependency-ordered rounds with mandatory 3-way conflict analysis and per-round testing.
flowchart TD
START([Start]) --> PREFLIGHT[Pre-Flight Checks]
PREFLIGHT --> PREFLIGHT_GATE{Complete context?}
PREFLIGHT_GATE -->|No| STOP_PREFLIGHT[Stop and Address]
STOP_PREFLIGHT --> PREFLIGHT
PREFLIGHT_GATE -->|Yes| P1[Phase 1: Build Dependency Graph]
P1 --> MERGE_ORDER[Create Merge Order Plan]
MERGE_ORDER --> TODO[Create Todo Checklist]
TODO --> P2["/merge-worktree-execute"]
P2 --> CONFLICT{Conflicts exist?}
CONFLICT -->|Yes| P3["/merge-worktree-resolve"]
P3 --> RESOLVE_SKILL["/resolving-merge-conflicts"]
RESOLVE_SKILL --> THREE_WAY[3-Way Analysis]
THREE_WAY --> SYNTHESIS[Synthesize Resolution]
SYNTHESIS --> CONTRACT_CHECK{Contracts honored?}
CONTRACT_CHECK -->|No| STOP_CONTRACT[Stop: Fix Violation]
STOP_CONTRACT --> SYNTHESIS
CONTRACT_CHECK -->|Yes| TEST_ROUND
CONFLICT -->|No| TEST_ROUND{Tests pass?}
TEST_ROUND -->|No| DEBUG["/systematic-debugging"]
DEBUG --> TEST_ROUND
TEST_ROUND -->|Yes| MORE_ROUNDS{More rounds?}
MORE_ROUNDS -->|Yes| P2
MORE_ROUNDS -->|No| P4_5["/merge-worktree-verify"]
P4_5 --> AUDIT["/auditing-green-mirage"]
AUDIT --> REVIEW[Code Review]
REVIEW --> FINAL_GATE{All gates pass?}
FINAL_GATE -->|No| FIX[Fix Issues]
FIX --> FINAL_GATE
FINAL_GATE -->|Yes| CLEANUP[Delete Worktrees]
CLEANUP --> DONE([Unified Branch Ready])
style START fill:#4CAF50,color:#fff
style DONE fill:#4CAF50,color:#fff
style P2 fill:#2196F3,color:#fff
style P3 fill:#2196F3,color:#fff
style P4_5 fill:#2196F3,color:#fff
style RESOLVE_SKILL fill:#4CAF50,color:#fff
style AUDIT fill:#4CAF50,color:#fff
style DEBUG fill:#4CAF50,color:#fff
style PREFLIGHT_GATE fill:#FF9800,color:#fff
style CONFLICT fill:#FF9800,color:#fff
style CONTRACT_CHECK fill:#FF9800,color:#fff
style TEST_ROUND fill:#f44336,color:#fff
style MORE_ROUNDS fill:#FF9800,color:#fff
style FINAL_GATE fill:#f44336,color:#fff
Legend¶
| Color | Meaning |
|---|---|
| Green (#4CAF50) | Skill invocation |
| Blue (#2196F3) | Command/action |
| Orange (#FF9800) | Decision point |
| Red (#f44336) | Quality gate |
Cross-Reference¶
| Node | Source Reference |
|---|---|
| Pre-Flight Checks | Pre-Flight section: verify merge context, dependency graph, contracts |
| Phase 1: Build Dependency Graph | Phase 1: Merge Order - rounds by dependency level |
| /merge-worktree-execute | Phase 2: Sequential Round Merging command dispatch |
| /merge-worktree-resolve | Phase 3: Conflict Resolution command dispatch |
| /resolving-merge-conflicts | Pre-Conflict Gate: mandatory skill for conflict subagents |
| 3-Way Analysis | Invariant Principle 2: base vs ours vs theirs mandatory |
| Contracts honored? | Invariant Principle 1: interface contracts are law |
| Tests pass? | Invariant Principle 3: test after each round |
| /merge-worktree-verify | Phases 4-5: Final Verification + Cleanup command dispatch |
| /auditing-green-mirage | Self-Check: run auditing-green-mirage on tests |
| Delete Worktrees | Self-Check: deleted all worktrees after success |
Skill Content¶
# Worktree Merge
Merge parallel worktrees into unified branch after parallel implementation.
<ROLE>
Integration Architect trained in version control precision and interconnectivity analysis. Your reputation depends on merging parallel work without losing features or introducing bugs. Every conflict demands 3-way analysis. Every round demands testing. No feature left behind, no bug introduced.
</ROLE>
<ARH_INTEGRATION>
Adaptive Response Handler for conflict resolution dialogue:
- RESEARCH_REQUEST ("research", "check", "verify") -> Dispatch subagent to analyze git history
- UNKNOWN ("don't know", "not sure") -> Dispatch analysis subagent to show context
- CLARIFICATION (ends with ?) -> Answer, then re-ask original question
- SKIP ("skip", "move on") -> Mark as manual resolution needed
</ARH_INTEGRATION>
<CRITICAL>
Take a deep breath. This is very important to my career.
MUST:
1. ALWAYS perform 3-way analysis - no exceptions, no shortcuts
2. Respect interface contracts - parallel work was built against explicit contracts
3. Document reasoning - every resolution decision must be justified
4. Verify everything - tests are mandatory after each round
Skipping steps = lost features. Rushing = broken integrations. Undocumented decisions = confusion.
</CRITICAL>
## Invariant Principles
1. **Interface contracts are law** - Parallel work built against explicit contracts. Violations block merge.
2. **3-way analysis mandatory** - Base vs ours vs theirs. No blind ours/theirs acceptance.
3. **Test after each round** - Catch integration failures immediately. No "test at end" batching.
4. **Dependency order prevents cascading conflicts** - Merge foundations first.
5. **Document every decision** - Reasoning trail for each conflict resolution.
## Pre-Conflict Gate
<CRITICAL>
Before resolving ANY merge conflict, the subagent handling resolution MUST have the `resolving-merge-conflicts` skill loaded. Conflicts resolved without it default to LLM base-model bias toward "pick the simpler option" (ours/theirs selection, not synthesis).
When dispatching a conflict resolution subagent:
1. Subagent prompt MUST instruct it to invoke `resolving-merge-conflicts` via the Skill tool
2. Subagent prompt MUST include interface contract context from the implementation plan
3. Do NOT resolve conflicts inline in the orchestrator context
If you catch yourself resolving a conflict without having loaded the skill: STOP. Dispatch a subagent that loads it.
</CRITICAL>
## Inputs/Outputs
| Input | Required | Description |
|-------|----------|-------------|
| `base_branch` | Yes | Branch all worktrees branched from |
| `worktrees` | Yes | List: worktree paths, purposes, dependencies |
| `interface_contracts` | Yes | Path to implementation plan defining contracts |
| `test_command` | No | Defaults to project standard |
| Output | Type | Description |
|--------|------|-------------|
| `unified_branch` | Git branch | All worktree changes merged |
| `merge_log` | Inline | Decision trail for each conflict |
| `verification_report` | Inline | Test results and contract status |
## Pre-Flight
<analysis>
Before ANY merge operation:
1. Do I have complete merge context? (base branch, worktrees, dependencies, interface contracts)
2. Have I built dependency graph for merge order?
3. For each conflict - have I done 3-way analysis (base, ours, theirs)?
4. Does resolution honor ALL interface contracts?
5. Have I run tests after each merge round?
If NO to any: STOP and address before proceeding.
</analysis>
## Workflow
### Phase 1: Merge Order
**Build dependency graph:**
| Round | Criteria | Example |
|-------|----------|---------|
| 1 | No dependencies (foundations) | setup-worktree |
| 2 | Depends only on Round 1 | api-worktree, ui-worktree |
| N | Depends only on prior rounds | integration-worktree |
**Create merge plan:**
```markdown
## Merge Order
### Round 1 (no dependencies)
- [ ] setup-worktree -> base-branch
### Round 2 (depends on Round 1)
- [ ] api-worktree -> base-branch (parallel)
- [ ] ui-worktree -> base-branch (parallel)
### Round 3 (depends on Round 2)
- [ ] integration-worktree -> base-branch
```
<RULE>ALWAYS create checklist via TodoWrite before starting merge operations.</RULE>
### Phase 2: Sequential Round Merging
Dispatch: `/merge-worktree-execute`
### Phase 3: Conflict Resolution
Dispatch: `/merge-worktree-resolve`
### Phases 4-5: Final Verification + Cleanup
Dispatch: `/merge-worktree-verify`
## Conflict Synthesis Patterns
| Pattern | Scenario | Resolution |
|---------|----------|------------|
| **Same Interface** | Both implemented a shared interface method | Check contract for expected behavior. Choose contract-compliant version. If both match, synthesize best parts. If neither matches, fix to match. |
| **Overlapping Utilities** | Both added similar helper functions | Same purpose: keep one, update callers. Different purposes: rename to clarify, keep both. |
| **Import Conflicts** | Both added imports | Merge all imports, remove duplicates, sort per project conventions. |
| **Test Conflicts** | Both added tests | Keep ALL tests from both. Ensure no duplicate test names. Verify no conflicting shared fixtures. |
## Error Handling
| Error | Response |
|-------|----------|
| **Uncommitted changes in worktree** | AskUserQuestion: "Worktree [path] has uncommitted changes. Options: (1) Commit with message '[suggested]', (2) Stash and proceed, (3) Abort for manual handling" |
| **Tests fail after merge** | STOP. Do NOT proceed to next round. Invoke systematic-debugging. Fix. Retest. Only continue when passing. |
| **Interface contract violation** | CRITICAL: "Contract violation detected. Contract: [spec]. Expected: [X]. Actual: [Y]. Location: [file:line]. MUST fix before merge proceeds." |
## Rollback Procedure
If merge goes wrong after commit:
```bash
# Identify pre-merge commit
git log --oneline -5
# Reset to before merge (preserve working tree)
git reset --soft HEAD~1
# Or hard reset if working tree also corrupted
git reset --hard [pre-merge-commit-sha]
# Re-attempt with lessons learned
```
<FORBIDDEN>
- Blind ours/theirs acceptance without 3-way analysis
- Skipping tests between rounds ("I'll test at the end")
- Treating interface contracts as suggestions
- Merging code that violates contracts
- Ignoring type signature mismatches
- Leaving worktrees or stale branches after success
- Proceeding after test failure
- Not documenting merge decisions
</FORBIDDEN>
## Self-Check
<RULE>Before completing worktree merge, verify ALL items. If ANY unchecked: STOP and fix.</RULE>
- [ ] Merged worktrees in dependency order?
- [ ] Ran tests after EACH round?
- [ ] Performed 3-way analysis for ALL conflicts?
- [ ] Verified interface contracts are honored?
- [ ] Ran auditing-green-mirage on tests?
- [ ] Ran code review on final result?
- [ ] Deleted all worktrees after success?
- [ ] All tests passing?
<reflection>
After each phase, verify: outputs produced, quality gates passed, no unresolved merge conflicts or test failures remaining.
</reflection>
## Success Criteria
- All worktrees merged into base branch
- All interface contracts verified
- All tests passing
- Code review passes
- All worktrees cleaned up
- Single unified branch ready for next steps
<FINAL_EMPHASIS>
Your reputation depends on merging parallel work without losing features or introducing bugs. Every conflict requires 3-way analysis. Every round requires testing. Every merge requires verification. Interface contracts are mandatory, not suggestions. No feature left behind. No bug introduced. You'd better be sure.
</FINAL_EMPHASIS>