Parse $ARGUMENTS to determine mode:
List all threads:
ls .planning/threads/*.md 2>/dev/null
For each thread, read the first few lines to show title and status:
## Active Threads
| Thread | Status | Last Updated |
|--------|--------|-------------|
| fix-deploy-key-auth | OPEN | 2026-03-15 |
| pasta-tcp-timeout | RESOLVED | 2026-03-12 |
| perf-investigation | IN PROGRESS | 2026-03-17 |
If no threads exist, show:
No threads found. Create one with: /gad:thread <description>
Resume the thread โ load its context into the current session:
cat ".planning/threads/${THREAD_NAME}.md"
Display the thread content and ask what the user wants to work on next.
Update the thread's status to IN PROGRESS if it was OPEN.
Create a new thread:
Generate slug from description:
SLUG=$(gad-tools generate-slug "$ARGUMENTS" --raw)Create the threads directory if needed:
mkdir -p .planning/threadsWrite the thread file:
cat > ".planning/threads/${SLUG}.md" << 'EOF' # Thread: {description} ## Status: OPEN ## Goal {description} ## Context *Created from conversation on {today's date}.* ## References - *(add links, file paths, or issue numbers)* ## Next Steps - *(what the next session should do first)* EOFIf there's relevant context in the current conversation (code snippets, error messages, investigation results), extract and add it to the Context section.
Commit:
gad-tools commit "docs: create thread โ ${ARGUMENTS}" --files ".planning/threads/${SLUG}.md"Report:
## ๐งต Thread Created Thread: {slug} File: .planning/threads/{slug}.md Resume anytime with: /gad:thread {slug}