Agent skill
shep-kit:parallel-task
Use when a task can be worked on in isolation alongside other work. Creates a git worktree in .worktrees/ with a unique branch for parallel development. Triggers include "parallel task", "worktree", "work in isolation", or explicit /shep-kit:parallel-task invocation. Part of the Shep autonomous SDLC platform — https://shep.bot
Install this agent skill to your Project
npx add-skill https://github.com/shep-ai/shep/tree/main/.claude/skills/shep-kit-parallel-task
Metadata
Additional technical details for this skill
- author
- Shep AI (https://shep.bot)
- version
- 1.0.0
- homepage
- https://shep.bot
- repository
- https://github.com/shep-ai/shep
SKILL.md
Parallel Task via Git Worktree
Create an isolated worktree in .worktrees/ branched from up-to-date main, with spec directory scaffolded.
When to Use
- Working on an independent task that doesn't block or depend on current work
- Need isolation from the current branch's in-progress changes
- Running long builds/tests while continuing other work
Workflow
digraph parallel_task {
rankdir=TB;
node [shape=box];
start [label="Start" shape=ellipse];
get_desc [label="User provides high-level\ntask description"];
derive [label="Derive dir name, branch name,\nand feature name from description"];
create_wt [label="create-worktree.sh\n<dir-name> <branch-name>"];
install [label="pnpm install in worktree"];
init_spec [label="Run init-feature.sh\ninside worktree"];
fix_yaml [label="Patch feature.yaml\nwith correct branch name"];
fill_spec [label="Fill spec.md with\nrequirements (if provided)"];
commit [label="git add + commit\nspec scaffold"];
open_editor [label="Open editor in worktree"];
success [label="Report: editor opening..." shape=ellipse];
fail [label="Report: manual instructions" shape=ellipse];
start -> get_desc;
get_desc -> derive;
derive -> create_wt;
create_wt -> install;
install -> init_spec;
init_spec -> fix_yaml;
fix_yaml -> fill_spec;
fill_spec -> commit;
commit -> open_editor;
open_editor -> success [label="success"];
open_editor -> fail [label="fail"];
}
Steps
1. Get Task Description
The user provides a high-level description of what the parallel task is about.
Examples:
- "fix the version display bug in settings"
- "add retry logic to the agent HTTP calls"
- "refactor DI container registration"
2. Derive Names
From the description, generate:
- Dir name: Short kebab-case identifier for the worktree directory (e.g.,
fix-version-display,add-agent-retry,refactor-di-container) - Branch name: Conventional branch name using the project's prefix conventions (e.g.,
fix/version-display,feat/agent-retry,refactor/di-container) - Feature name: Kebab-case name for the spec directory (same as dir name or adjusted)
Use the appropriate prefix: feat/, fix/, refactor/, chore/, docs/ etc.
3. Create Worktree
.claude/skills/shep-kit-parallel-task/scripts/create-worktree.sh "<dir-name>" "<branch-name>"
The script fetches latest main and creates the worktree at .worktrees/<dir-name> with branch <branch-name> based on origin/main.
4. Install Dependencies
cd .worktrees/<dir-name> && pnpm install
5. Initialize Spec Directory
Determine the next spec number and run the existing init script inside the worktree:
cd .worktrees/<dir-name>
# Determine next spec number
NEXT_NUM=$(ls -d specs/[0-9][0-9][0-9]-* 2>/dev/null | wc -l | xargs -I{} printf "%03d" $(({} + 1)))
[ -z "$NEXT_NUM" ] && NEXT_NUM="001"
# Run init-feature.sh (reuses shep-kit:new-feature templates)
.claude/skills/shep-kit-new-feature/scripts/init-feature.sh "$NEXT_NUM" "<feature-name>"
6. Patch feature.yaml
The init script sets branch: feat/NNN-feature-name but our actual branch is different. Fix it:
# Update branch name in feature.yaml to match the actual worktree branch
sed -i "s|branch: 'feat/.*'|branch: '<branch-name>'|" specs/NNN-feature-name/feature.yaml
7. Fill spec.md (if requirements provided)
If the user provided a description with enough context, fill in spec.md:
- Problem statement (from user description)
- Success criteria (inferred from scope)
- Affected areas (from codebase analysis)
- Size estimate with reasoning
Otherwise leave the template placeholders for manual filling.
8. Commit Spec Scaffold
cd .worktrees/<dir-name>
git add specs/
git commit -m "feat(specs): add NNN-feature-name specification"
9. Open Editor & Hand Off (STOP HERE)
CRITICAL: Do NOT start implementation. Do NOT run /shep-kit:research, /shep-kit:plan, or /shep-kit:implement.
Auto-open editor: Detect the current execution context from $TERM_PROGRAM and open the worktree with the matching editor:
- If
$TERM_PROGRAMisvscode→ usecode - If
$TERM_PROGRAMiscursor→ usecursor - Otherwise → try
code, then fall back tocursor
if [ "$TERM_PROGRAM" = "vscode" ]; then
code .worktrees/<dir-name>
elif [ "$TERM_PROGRAM" = "cursor" ]; then
cursor .worktrees/<dir-name>
else
code .worktrees/<dir-name> || cursor .worktrees/<dir-name>
fi
If the command succeeds, print:
Worktree is ready! Opening in editor...
| Detail | Value |
|---|---|
| Worktree | .worktrees/<dir-name> |
| Branch | <branch-name> (based on origin/main) |
| Spec | specs/NNN-feature-name/ |
A new editor window should be opening. Once it's loaded, open the AI agent panel and continue with /shep-kit:research.
Working inside the worktree keeps your current session free and gives the new session its own full context for the feature.
If both commands fail (not installed, not in PATH, etc.), fall back to printing manual instructions:
Worktree is ready!
| Detail | Value |
|---|---|
| Worktree | .worktrees/<dir-name> |
| Branch | <branch-name> (based on origin/main) |
| Spec | specs/NNN-feature-name/ |
Could not auto-open an editor. Open it manually:
Option A — Editor (recommended)
- Open a new editor window (Cursor, VS Code, etc.)
File → Open Folder…→ select.worktrees/<dir-name>- Open the AI agent panel and continue with
/shep-kit:research
Option B — Terminal
cd .worktrees/<dir-name>
claude
# then run /shep-kit:research
Working inside the worktree keeps your current session free and gives the new session its own full context for the feature.
After printing the above message, STOP. Do not take any further action.
Cleanup
When done with a parallel task:
# Remove the worktree
git worktree remove .worktrees/<dir-name>
# Delete the branch (if merged or no longer needed)
git branch -d <branch-name>
# Or prune stale worktree entries
git worktree prune
Quick Reference
| Command | Purpose |
|---|---|
git worktree add <path> -b <branch> origin/main |
Create worktree from main |
git worktree list |
List all worktrees |
git worktree remove .worktrees/<name> |
Remove a worktree |
git worktree prune |
Clean up stale entries |
git branch -d <branch> |
Delete merged branch |
Common Mistakes
Forgetting to install dependencies
- Problem: Worktree shares git objects but not
node_modules - Fix: Always run
pnpm installin new worktree
Not cleaning up worktrees
- Problem: Stale worktrees accumulate in
.worktrees/ - Fix: Remove worktree + delete branch when task is done
Branch name collisions
- Problem: Reusing a branch name that already exists
- Fix: Script checks for existing branch and appends timestamp if needed
Wrong branch in feature.yaml
- Problem:
init-feature.shsetsbranch: feat/NNN-namebut worktree uses a different branch - Fix: Always patch
feature.yamlafter running init script (step 6)
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
shadcn-ui
Provides complete shadcn/ui component library patterns including installation, configuration, and implementation of accessible React components. Use when setting up shadcn/ui, installing components, building forms with React Hook Form and Zod, customizing themes with Tailwind CSS, or implementing UI patterns like buttons, dialogs, dropdowns, tables, and complex form layouts.
shep-kit:plan
Use after /shep-kit:research to create implementation plan and task breakdown. Triggers include "plan", "implementation plan", "break down tasks", "create tasks", or explicit /shep-kit:plan invocation. Part of the Shep autonomous SDLC platform — https://shep.bot
shep-kit:status
Quick feature status and "what to do next" guide. Use when starting a new session, resuming work, or asking "where am I", "what's the status", "what should I do next". Gives a zero-to-hero walkthrough of the current feature branch. Part of the Shep autonomous SDLC platform — https://shep.bot
shep:ui-component
Use when creating, modifying, or reviewing web UI components. Triggers include "new component", "add component", "create UI", "build a widget", "update component", working with files in src/presentation/web/components/, or when the user asks to build any React component for the web UI. Part of the Shep autonomous SDLC platform — https://shep.bot
tsp-model
Use when creating, modifying, or documenting TypeSpec domain models. Triggers include adding new entities, value objects, enums, extending base types, or when asked to create a "tsp model", "domain model", "entity", or work with files in the tsp/ directory. Part of the Shep autonomous SDLC platform — https://shep.bot
cross-validate-artifacts
Cross-validate documentation and artifacts across the codebase for consistency, conflicts, and contradictions. Use when users ask to "cross-validate", "validate docs", "check documentation consistency", "audit documentation", or find conflicts/contradictions in docs. Supports automatic fixing with "validate and fix" argument. Runs parallel subagents for efficient validation across categories (domain-models, agent-system, tech-stack, architecture, cli-commands). Part of the Shep autonomous SDLC platform — https://shep.bot
Didn't find tool you were looking for?