ralph-merge-worktrees
Ralph Merge Worktrees
Analyze completed Ralph worktree PRDs, build a dependency-aware merge queue, and sequentially squash-merge each branch into main — removing the worktree after each successful merge.
Overview
Ralph worktrees live at .claude/worktrees/ralph/<feature>/ with PRDs at scripts/ralph/prd.json inside each worktree. A worktree is "completed" when every user story in its PRD has passes: true. This skill finds all completed worktrees, determines the safest merge order, presents the plan for approval, and then executes it one branch at a time.
Step 1: Scan and Identify Completed Worktrees
Read every .claude/worktrees/ralph/*/scripts/ralph/prd.json file. For each PRD:
- Parse the JSON — extract
branchName,description, anduserStories[] - A worktree is completed when ALL stories have
passes: true - Skip any worktree whose PRD has at least one story with
passes: false - Also skip worktrees that don't have a
prd.json(malformed or empty)
If no completed worktrees are found, tell the user and stop.
Step 2: Analyze Each Completed Branch
For each completed worktree, gather merge intelligence:
# From the main repo root, diff the branch against main
git diff main...<branchName> --stat
git diff main...<branchName> --name-only
git log main..<branchName> --oneline
Collect for each branch:
- Files changed — the full list of modified/added/deleted files
- Change categories — classify files into buckets:
terraform— anything underterraform/(infra, resolvers, functions, lambda)types— anything undertypes/graphql— anything underapp/graphql/services— anything underservices/composables— anything underapp/composables/components— anything underapp/components/pages— anything underapp/pages/layouts— anything underapp/layouts/content— anything undercontent/config— root config files (nuxt.config.ts,terraform-scaffold.config.ts, etc.)other— everything else
- Commit count — number of commits on the branch
- Story count — total user stories in the PRD
- File count — total files changed
- Overlap matrix — which files are touched by multiple branches (potential conflict zones)
Step 3: Build the Priority Queue
Rank branches for merge order using these heuristics (most important first):
3a. Dependency Layer Ordering
Merge bottom-up through the stack so downstream features inherit upstream changes:
- Infrastructure first — branches that primarily touch
terraform/,types/,services/,config(schema, tables, resolvers, types) - Data/API layer — branches focused on
app/graphql/,app/composables/(client-side data plumbing) - UI layer last — branches primarily touching
app/components/,app/pages/,app/layouts/,content/
Determine the "primary layer" by whichever category has the most changed files. If a branch spans multiple layers, it belongs to the lowest layer it touches (infra > api > ui).
3b. Within the Same Layer
When two branches are in the same layer, break ties using:
- Less file overlap first — branches that share fewer files with other pending branches get merged first (lower conflict risk after merge)
- Smaller changeset first — fewer files changed = less risk, gets quick wins merged early, and the larger branch can rebase more easily if needed
- Fewer commits first — proxy for scope/complexity
3c. Special Cases
- If a branch only touches
content/files (e.g., legal pages, markdown), it's very low-risk — can go anywhere in the queue, but default to early since it won't conflict with code changes - If a branch touches
terraform-scaffold.config.tsorterraform/envs/staging/main.tf, prefer merging it early — other branches may have stale copies of these high-contention files
Step 4: Present the Merge Plan
Show the user the proposed merge queue in a clear table format:
Ralph Merge Queue — N completed branches ready
Priority | Branch | Stories | Files | Layer | Reason
---------|--------------------------------|---------|-------|--------------|------------------
1 | ralph/legal-pages | 6/6 | 8 | content | Content-only, low risk
2 | ralph/post-creation | 12/12 | 34 | infra+ui | Core data model, merge early
3 | ralph/like-thread-post-comment | 8/8 | 15 | infra+ui | Depends on thread model
...
File overlap warnings:
- terraform/envs/staging/main.tf: touched by 3 branches (post-creation, chat-and-messaging, like-thread-post-comment)
- terraform/envs/staging/schema.graphql: touched by 4 branches
Proceed with merge queue? (y/n)
Wait for user confirmation before proceeding. If the user wants to reorder or skip branches, adjust the queue accordingly.
Step 5: Execute the Merge Queue
For each branch in the queue, in order:
5a. Pre-merge Check
# Ensure main is clean and up to date
git checkout main
git status --porcelain
If there are uncommitted changes on main, stop and alert the user.
5b. Squash-Merge via /squash
Invoke the /squash skill with the branch name. This handles:
- Pre-flight checks (branch exists, has diverged from main)
git merge --squash <branchName>- Delegates commit to
/commit(Conventional Commits, Co-Authored-By trailer) - Post-merge verification
- Local branch cleanup (
git branch -d/-D)
If the squash-merge fails due to conflicts:
git merge --abort- Report which files conflicted
- Skip this branch — move it to the end of the queue or remove it
- Ask the user: "Branch X has conflicts. Skip it and continue with the next branch, or stop the queue?"
- Continue or stop based on the user's answer
5c. Remove the Worktree
After a successful merge and branch deletion:
# Remove the git worktree
git worktree remove .claude/worktrees/ralph/<feature-name>
# If worktree remove fails (dirty), force it since we already merged
git worktree remove --force .claude/worktrees/ralph/<feature-name>
Verify the worktree directory is gone. If the directory still exists after git worktree remove, it may need manual cleanup — warn the user but continue.
5d. Prune and Report
git worktree prune
Log the result:
[1/N] ralph/legal-pages — merged and worktree removed
[2/N] ralph/post-creation — merged and worktree removed
[3/N] ralph/chat-and-messaging — SKIPPED (merge conflict in schema.graphql)
...
5e. Continue to Next Branch
Move to the next branch in the queue. Each subsequent merge benefits from the prior merges already being on main, which reduces drift.
Step 6: Final Summary
After processing the entire queue:
Ralph Merge Complete
--------------------
Merged: 5 branches
Skipped: 1 branch (conflicts)
Remaining worktrees: 3 (incomplete PRDs)
Skipped branches (need manual resolution):
- ralph/chat-and-messaging: conflict in terraform/envs/staging/schema.graphql
Remaining incomplete worktrees:
- ralph/follow-and-unfollow (4/10 stories)
- ralph/test-coverage (0/8 stories)
- ralph/implement-reporting (2/6 stories)
If any branches were skipped due to conflicts, suggest next steps:
- Go into the skipped worktree
git rebase mainto incorporate the newly merged changes- Resolve conflicts
- Re-run
/ralph-merge-worktreesto merge the remaining completed branches
Important Notes
- Always get user confirmation before starting the merge queue — this is a destructive operation (worktree removal)
- Each merge builds on the last — if branch 2 conflicts, branches 3+ might have different conflict profiles than predicted. Re-check is automatic since we run
/squashwhich does pre-flight - The skill reads PRD files from the worktree directories, not from main — each worktree has its own copy
- Worktree paths use the feature name without the
ralph/prefix:.claude/worktrees/ralph/post-creation/for branchralph/post-creation - After all merges complete, run
bun run linton main to verify the combined codebase is healthy - Quote file paths with spaces in all git/bash commands (the project path contains spaces)
More from ralphcrisostomo/nuxt-development-skills
ralph
Convert PRDs to prd.json format for the Ralph autonomous agent system. Use when you have an existing PRD and need to convert it to Ralph's JSON format. Triggers on: convert this prd, turn this into ralph format, create prd.json from this, ralph json.
52prd
Generate a Product Requirements Document (PRD) for a new feature. Use when planning a feature, starting a new project, or when asked to create a PRD. Triggers on: create a prd, write prd for, plan this feature, requirements for, spec out.
39optimise-claude
Use when auditing, trimming, or restructuring AI instruction files (CLAUDE.md, SKILL.md, AGENTS.md) to reduce context-window consumption. Trigger whenever CLAUDE.md is bloated or Claude ignores instructions, a SKILL.md exceeds 120 lines, skills share duplicated content, AGENTS.md has large inline blocks, or the user asks to optimize, slim down, or reduce token usage.
37nuxt-init
Use when scaffolding a new Nuxt 4 project with standard config files (prettier, eslint, gitignore, husky, vitest, tsconfig, sops) and bun scripts.
33nuxt-terraform
Scaffold Nuxt + AWS Terraform infrastructure. Use when adding GraphQL resolvers, Lambda functions, initializing a new project with AppSync, DynamoDB, Cognito, writing Terraform tests, or generating/reviewing Terraform code style. Triggers on: add graphql resolver, create lambda, scaffold terraform, init terraform, add appsync resolver, add mutation, add query, add terraform test, write tftest, terraform style.
32todo
Use when scanning a codebase for incomplete work and maintaining a living TODO.md grouped by feature. Triggers on: scan for todos, find incomplete work, update todo, what needs doing, create todo list.
30