Instructs the orchestrator to read subagent notepad files
(.sisyphus/notepads/{planName}/) after task completion, ensuring
learnings, issues, and problems are propagated to subsequent delegations.
114 lines
3.6 KiB
TypeScript
114 lines
3.6 KiB
TypeScript
import { VERIFICATION_REMINDER } from "./system-reminder-templates"
|
|
|
|
function buildVerificationReminder(sessionId: string): string {
|
|
return `${VERIFICATION_REMINDER}
|
|
|
|
---
|
|
|
|
**If ANY verification fails, use this immediately:**
|
|
\`\`\`
|
|
task(session_id="${sessionId}", prompt="fix: [describe the specific failure]")
|
|
\`\`\``
|
|
}
|
|
|
|
export function buildOrchestratorReminder(
|
|
planName: string,
|
|
progress: { total: number; completed: number },
|
|
sessionId: string
|
|
): string {
|
|
const remaining = progress.total - progress.completed
|
|
return `
|
|
---
|
|
|
|
**BOULDER STATE:** Plan: \`${planName}\` | ${progress.completed}/${progress.total} done | ${remaining} remaining
|
|
|
|
---
|
|
|
|
${buildVerificationReminder(sessionId)}
|
|
|
|
**STEP 5: READ SUBAGENT NOTEPAD (LEARNINGS, ISSUES, PROBLEMS)**
|
|
|
|
The subagent was instructed to record findings in notepad files. Read them NOW:
|
|
\`\`\`
|
|
Glob(".sisyphus/notepads/${planName}/*.md")
|
|
\`\`\`
|
|
Then \`Read\` each file found — especially:
|
|
- **learnings.md**: Patterns, conventions, successful approaches discovered
|
|
- **issues.md**: Problems, blockers, gotchas encountered during work
|
|
- **problems.md**: Unresolved issues, technical debt flagged
|
|
|
|
**USE this information to:**
|
|
- Inform your next delegation (avoid known pitfalls)
|
|
- Adjust your plan if blockers were discovered
|
|
- Propagate learnings to subsequent subagents
|
|
|
|
**STEP 6: CHECK BOULDER STATE DIRECTLY (EVERY TIME — NO EXCEPTIONS)**
|
|
|
|
Do NOT rely on cached progress. Read the plan file NOW:
|
|
\`\`\`
|
|
Read(".sisyphus/plans/${planName}.md")
|
|
\`\`\`
|
|
Count exactly: how many \`- [ ]\` remain? How many \`- [x]\` completed?
|
|
This is YOUR ground truth. Use it to decide what comes next.
|
|
|
|
**STEP 7: MARK COMPLETION IN PLAN FILE (IMMEDIATELY)**
|
|
|
|
RIGHT NOW - Do not delay. Verification passed → Mark IMMEDIATELY.
|
|
|
|
Update the plan file \`.sisyphus/plans/${planName}.md\`:
|
|
- Change \`- [ ]\` to \`- [x]\` for the completed task
|
|
- Use \`Edit\` tool to modify the checkbox
|
|
|
|
**DO THIS BEFORE ANYTHING ELSE. Unmarked = Untracked = Lost progress.**
|
|
|
|
**STEP 8: COMMIT ATOMIC UNIT**
|
|
|
|
- Stage ONLY the verified changes
|
|
- Commit with clear message describing what was done
|
|
|
|
**STEP 9: PROCEED TO NEXT TASK**
|
|
|
|
- Read the plan file AGAIN to identify the next \`- [ ]\` task
|
|
- Start immediately - DO NOT STOP
|
|
|
|
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
|
|
**${remaining} tasks remain. Keep bouldering.**`
|
|
}
|
|
|
|
export function buildStandaloneVerificationReminder(sessionId: string): string {
|
|
return `
|
|
---
|
|
|
|
${buildVerificationReminder(sessionId)}
|
|
|
|
**STEP 5: CHECK YOUR PROGRESS DIRECTLY (EVERY TIME — NO EXCEPTIONS)**
|
|
|
|
Do NOT rely on memory or cached state. Run \`todoread\` NOW to see exact current state.
|
|
Count pending vs completed tasks. This is your ground truth for what comes next.
|
|
|
|
**STEP 6: UPDATE TODO STATUS (IMMEDIATELY)**
|
|
|
|
RIGHT NOW - Do not delay. Verification passed → Mark IMMEDIATELY.
|
|
|
|
1. Run \`todoread\` to see your todo list
|
|
2. Mark the completed task as \`completed\` using \`todowrite\`
|
|
|
|
**DO THIS BEFORE ANYTHING ELSE. Unmarked = Untracked = Lost progress.**
|
|
|
|
**STEP 7: EXECUTE QA TASKS (IF ANY)**
|
|
|
|
If QA tasks exist in your todo list:
|
|
- Execute them BEFORE proceeding
|
|
- Mark each QA task complete after successful verification
|
|
|
|
**STEP 8: PROCEED TO NEXT PENDING TASK**
|
|
|
|
- Run \`todoread\` AGAIN to identify the next \`pending\` task
|
|
- Start immediately - DO NOT STOP
|
|
|
|
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
|
|
**NO TODO = NO TRACKING = INCOMPLETE WORK. Use todowrite aggressively.**`
|
|
}
|