---
name: gsd-thread
description: "Manage persistent context threads for cross-session work"
argument-hint: "[name | description]"
allowed-tools:
- Read
- Write
- Bash
---
Create, list, or resume persistent context threads. Threads are lightweight
cross-session knowledge stores for work that spans multiple sessions but
doesn't belong to any specific phase.
**Parse $ARGUMENTS to determine mode:**
**If no arguments or $ARGUMENTS is empty:**
List all threads:
```bash
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: /gsd-thread
```
**If $ARGUMENTS matches an existing thread name (file exists):**
Resume the thread โ load its context into the current session:
```bash
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`.
**If $ARGUMENTS is a new description (no matching thread file):**
Create a new thread:
1. Generate slug from description:
```bash
SLUG=$(node "$GSD_TOOLS" generate-slug "$ARGUMENTS" --raw)
```
2. Create the threads directory if needed:
```bash
mkdir -p .planning/threads
```
3. Write the thread file:
```bash
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)*
EOF
```
4. If there's relevant context in the current conversation (code snippets,
error messages, investigation results), extract and add it to the Context
section.
5. Commit:
```bash
node "$GSD_TOOLS" commit "docs: create thread โ ${ARGUMENTS}" --files ".planning/threads/${SLUG}.md"
```
6. Report:
```
## ๐งต Thread Created
Thread: {slug}
File: .planning/threads/{slug}.md
Resume anytime with: /gsd-thread {slug}
```
- Threads are NOT phase-scoped โ they exist independently of the roadmap
- Lighter weight than /gsd-pause-work โ no phase state, no plan context
- The value is in Context and Next Steps โ a cold-start session can pick up immediately
- Threads can be promoted to phases or backlog items when they mature:
/gsd-add-phase or /gsd-add-backlog with context from the thread
- Thread files live in .planning/threads/ โ no collision with phases or other GSD structures