.claude/skills/fork-join/SKILL.md
Runs multiple specialist subagents in parallel then merges their outputs into a unified result. Use when a task can be split into independent parallel workstreams that need to be recombined.
npx skillsauth add tranhieutt/software_development_department fork-joinInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
You are the Fork-Join Coordinator. Your job is to:
$ARGUMENTS into fully independent work unitsYou do NOT implement anything yourself. You fork, coordinate, verify, and join.
Read CLAUDE.md for project context. Then analyze $ARGUMENTS and extract N independent work units — tasks that can proceed with zero knowledge of each other's changes.
Dependency test (apply to every pair):
List each unit with:
If fewer than 2 units are parallelizable, stop and say:
"This task has sequential dependencies. Use
/orchestrateinstead of/fork-join."
Present to the user:
## Fork-Join Plan: [task description]
Base branch: [current branch]
| Fork | Branch Name | Agent | Scope | Files |
|------|-------------|-------|-------|-------|
| fork-01 | fj/[slug]-01 | @agent | [description] | [files] |
| fork-02 | fj/[slug]-02 | @agent | [description] | [files] |
...
Estimated: N parallel workers × ~[time] → merge in sequence
Proceed? Type y to fork all worktrees and launch agents.
Wait for y.
For each work unit, run:
bash .claude/hooks/fork-join.sh fork fj/<slug>-<N> .worktrees/fj-<slug>-<N>
After forking, display the worktree map:
Worktrees ready:
fork-01 → .worktrees/fj-slug-01 (branch: fj/slug-01)
fork-02 → .worktrees/fj-slug-02 (branch: fj/slug-02)
...
CRITICAL: Launch ALL subagents in a single message. Do not chain them — call the Task tool multiple times IN THE SAME RESPONSE. This is the only way they run in parallel.
Each subagent receives this exact prompt (substitute values):
You are @<AGENT_NAME>, working as a Fork-Join subagent for: <TASK_DESCRIPTION>
## Your Assignment
Unit: <FORK_ID>
Working directory: <WORKTREE_PATH>
Branch: <BRANCH_NAME>
## Your Specific Scope
<PRECISE DESCRIPTION OF WHAT THIS UNIT DOES>
Files to work on:
<FILE LIST>
## Rules
- Work ONLY in <WORKTREE_PATH> — never touch the parent repo directly
- Commit your work when done using: git -C <WORKTREE_PATH> commit -am "feat: <description>"
- Do NOT merge — the coordinator will merge after all units complete
- If you encounter a dependency on another unit's output, STOP and report back instead of guessing
## Success Criteria
<CLEAR DEFINITION OF DONE FOR THIS UNIT>
Follow all CLAUDE.md conventions. Report completion status at the end.
After all subagents complete, check each worktree:
bash .claude/hooks/fork-join.sh status .worktrees/fj-<slug>-<N>
For each worktree, verify:
If any worktree fails status check, report:
⚠️ fork-0N: [issue description]
Options:
1. Retry this unit with additional context
2. Skip this unit and continue joining the rest
3. Purge all — cancel the fork-join
What would you like to do?
Wait for user direction before proceeding.
Merge each branch one at a time into the base branch:
# For each fork that passed status check:
bash .claude/hooks/fork-join.sh join .worktrees/fj-<slug>-<N>
If a merge conflict occurs, stop and report:
⚠️ Merge conflict on fork-0N (branch: fj/slug-0N)
Conflicting files:
- [file list]
Resolve manually, then run:
git merge --continue
bash .claude/hooks/fork-join.sh purge .worktrees/fj-slug-0N
Then I can continue joining the remaining forks.
## Fork-Join Complete: [task description]
### Results
| Fork | Branch | Status | Files Changed | Commits |
|------|--------|--------|---------------|---------|
| fork-01 | fj/slug-01 | ✅ Merged | N files | N commits |
| fork-02 | fj/slug-02 | ✅ Merged | N files | N commits |
| fork-03 | fj/slug-03 | ⚠️ Skipped | — | — |
### Current branch: [base branch]
All successful forks have been merged. Worktrees cleaned up.
### Skipped units (if any)
- fork-03: [reason] — recommended follow-up: [action]
### Next steps
- Run tests: [test command from CLAUDE.md]
- Review combined diff: git diff HEAD~N
- Open PR: git push origin [base branch]
main directly — always fork from a feature branch.worktrees/ directory fully on completion (join handles this)bash .claude/hooks/fork-join.sh list and purge each manuallytesting
Generates high-fidelity architecture diagrams, sequence flows, and component maps for SDD projects. Use when finalizing a design phase, documenting system architecture, or visualizing agentic workflows. Default style: Style 6 (Claude Official).
data-ai
Provides vector database and semantic search patterns for Pinecone, Weaviate, Qdrant, Milvus, and pgvector in RAG and recommendation systems. Use when implementing vector search or when the user mentions vector database, semantic search, embeddings, or similarity search.
development
Updates docs/technical/CODEMAP.md by scanning the current codebase structure. Run after a significant feature merge, refactor, or when CODEMAP feels stale.
development
Unlocks the codebase after a release freeze or incident freeze period to resume normal development. Use when a freeze period ends or when the user mentions unfreezing or lifting the code freeze.