- Add .claude/ configuration (agents, commands, hooks, get-shit-done workflows) - Add prompts/ directory with development planning documents - Add scripts/setup-tenants/ with tenant configuration - Add docs/screenshots/ - Remove obsolete phase2.2-corrections-report.md - Update pnpm-lock.yaml - Update detect-secrets.sh to ignore setup.sh (env var usage, not secrets) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
8.9 KiB
"Where were we?" should have an immediate, complete answer.
Check if this is an existing project:ls .planning/STATE.md 2>/dev/null && echo "Project exists"
ls .planning/ROADMAP.md 2>/dev/null && echo "Roadmap exists"
ls .planning/PROJECT.md 2>/dev/null && echo "Project file exists"
If STATE.md exists: Proceed to load_state If only ROADMAP.md/PROJECT.md exist: Offer to reconstruct STATE.md If .planning/ doesn't exist: This is a new project - route to /gsd:new-project
Read and parse STATE.md, then PROJECT.md:
cat .planning/STATE.md
cat .planning/PROJECT.md
From STATE.md extract:
- Project Reference: Core value and current focus
- Current Position: Phase X of Y, Plan A of B, Status
- Progress: Visual progress bar
- Recent Decisions: Key decisions affecting current work
- Pending Todos: Ideas captured during sessions
- Blockers/Concerns: Issues carried forward
- Session Continuity: Where we left off, any resume files
From PROJECT.md extract:
- What This Is: Current accurate description
- Requirements: Validated, Active, Out of Scope
- Key Decisions: Full decision log with outcomes
- Constraints: Hard limits on implementation
# Check for continue-here files (mid-plan resumption)
ls .planning/phases/*/.continue-here*.md 2>/dev/null
# Check for plans without summaries (incomplete execution)
for plan in .planning/phases/*/*-PLAN.md; do
summary="${plan/PLAN/SUMMARY}"
[ ! -f "$summary" ] && echo "Incomplete: $plan"
done 2>/dev/null
# Check for interrupted agents
if [ -f .planning/current-agent-id.txt ] && [ -s .planning/current-agent-id.txt ]; then
AGENT_ID=$(cat .planning/current-agent-id.txt | tr -d '\n')
echo "Interrupted agent: $AGENT_ID"
fi
If .continue-here file exists:
- This is a mid-plan resumption point
- Read the file for specific resumption context
- Flag: "Found mid-plan checkpoint"
If PLAN without SUMMARY exists:
- Execution was started but not completed
- Flag: "Found incomplete plan execution"
If interrupted agent found:
- Subagent was spawned but session ended before completion
- Read agent-history.json for task details
- Flag: "Found interrupted agent"
╔══════════════════════════════════════════════════════════════╗
║ PROJECT STATUS ║
╠══════════════════════════════════════════════════════════════╣
║ Building: [one-liner from PROJECT.md "What This Is"] ║
║ ║
║ Phase: [X] of [Y] - [Phase name] ║
║ Plan: [A] of [B] - [Status] ║
║ Progress: [██████░░░░] XX% ║
║ ║
║ Last activity: [date] - [what happened] ║
╚══════════════════════════════════════════════════════════════╝
[If incomplete work found:]
⚠️ Incomplete work detected:
- [.continue-here file or incomplete plan]
[If interrupted agent found:]
⚠️ Interrupted agent detected:
Agent ID: [id]
Task: [task description from agent-history.json]
Interrupted: [timestamp]
Resume with: Task tool (resume parameter with agent ID)
[If pending todos exist:]
📋 [N] pending todos — /gsd:check-todos to review
[If blockers exist:]
⚠️ Carried concerns:
- [blocker 1]
- [blocker 2]
[If alignment is not ✓:]
⚠️ Brief alignment: [status] - [assessment]
Based on project state, determine the most logical next action:
If interrupted agent exists: → Primary: Resume interrupted agent (Task tool with resume parameter) → Option: Start fresh (abandon agent work)
If .continue-here file exists: → Primary: Resume from checkpoint → Option: Start fresh on current plan
If incomplete plan (PLAN without SUMMARY): → Primary: Complete the incomplete plan → Option: Abandon and move on
If phase in progress, all plans complete: → Primary: Transition to next phase → Option: Review completed work
If phase ready to plan: → Check if CONTEXT.md exists for this phase:
- If CONTEXT.md missing: → Primary: Discuss phase vision (how user imagines it working) → Secondary: Plan directly (skip context gathering)
- If CONTEXT.md exists: → Primary: Plan the phase → Option: Review roadmap
If phase ready to execute: → Primary: Execute next plan → Option: Review the plan first
Present contextual options based on project state:What would you like to do?
[Primary action based on state - e.g.:]
1. Resume interrupted agent [if interrupted agent found]
OR
1. Execute phase (/gsd:execute-phase {phase})
OR
1. Discuss Phase 3 context (/gsd:discuss-phase 3) [if CONTEXT.md missing]
OR
1. Plan Phase 3 (/gsd:plan-phase 3) [if CONTEXT.md exists or discuss option declined]
[Secondary options:]
2. Review current phase status
3. Check pending todos ([N] pending)
4. Review brief alignment
5. Something else
Note: When offering phase planning, check for CONTEXT.md existence first:
ls .planning/phases/XX-name/CONTEXT.md 2>/dev/null
If missing, suggest discuss-phase before plan. If exists, offer plan directly.
Wait for user selection.
Based on user selection, route to appropriate workflow:- Execute plan → Show command for user to run after clearing:
--- ## ▶ Next Up **{phase}-{plan}: [Plan Name]** — [objective from PLAN.md] `/gsd:execute-phase {phase}` <sub>`/clear` first → fresh context window</sub> --- - Plan phase → Show command for user to run after clearing:
--- ## ▶ Next Up **Phase [N]: [Name]** — [Goal from ROADMAP.md] `/gsd:plan-phase [phase-number]` <sub>`/clear` first → fresh context window</sub> --- **Also available:** - `/gsd:discuss-phase [N]` — gather context first - `/gsd:research-phase [N]` — investigate unknowns --- - Transition → ./transition.md
- Check todos → Read .planning/todos/pending/, present summary
- Review alignment → Read PROJECT.md, compare to current state
- Something else → Ask what they need
Update STATE.md:
## Session Continuity
Last session: [now]
Stopped at: Session resumed, proceeding to [action]
Resume file: [updated if applicable]
This ensures if session ends unexpectedly, next resume knows the state.
If STATE.md is missing but other artifacts exist:"STATE.md missing. Reconstructing from artifacts..."
- Read PROJECT.md → Extract "What This Is" and Core Value
- Read ROADMAP.md → Determine phases, find current position
- Scan *-SUMMARY.md files → Extract decisions, concerns
- Count pending todos in .planning/todos/pending/
- Check for .continue-here files → Session continuity
Reconstruct and write STATE.md, then proceed normally.
This handles cases where:
- Project predates STATE.md introduction
- File was accidentally deleted
- Cloning repo without full .planning/ state
<quick_resume> For users who want minimal friction:
If user says just "continue" or "go":
- Load state silently
- Determine primary action
- Execute immediately without presenting options
"Continuing from [state]... [action]"
This enables fully autonomous "just keep going" workflow. </quick_resume>
<success_criteria> Resume is complete when:
- STATE.md loaded (or reconstructed)
- Incomplete work detected and flagged
- Clear status presented to user
- Contextual next actions offered
- User knows exactly where project stands
- Session continuity updated </success_criteria>