Free SKILL.md scraped from GitHub. Clone the repo or copy the file directly into your Claude Code skills directory.
npx versuz@latest install teotoplak-tempo-agents-skills-gsd-validate-phasegit clone https://github.com/teotoplak/tempo.gitcp tempo/SKILL.MD ~/.claude/skills/teotoplak-tempo-agents-skills-gsd-validate-phase/SKILL.md---
name: "gsd-validate-phase"
description: "Retroactively audit and fill Nyquist validation gaps for a completed phase"
metadata:
short-description: "Retroactively audit and fill Nyquist validation gaps for a completed phase"
---
<codex_skill_adapter>
## A. Skill Invocation
- This skill is invoked by mentioning `$gsd-validate-phase`.
- Treat all user text after `$gsd-validate-phase` as `{{GSD_ARGS}}`.
- If no arguments are present, treat `{{GSD_ARGS}}` as empty.
## B. AskUserQuestion → request_user_input Mapping
GSD workflows use `AskUserQuestion` (Claude Code syntax). Translate to Codex `request_user_input`:
Parameter mapping:
- `header` → `header`
- `question` → `question`
- Options formatted as `"Label" — description` → `{label: "Label", description: "description"}`
- Generate `id` from header: lowercase, replace spaces with underscores
Batched calls:
- `AskUserQuestion([q1, q2])` → single `request_user_input` with multiple entries in `questions[]`
Multi-select workaround:
- Codex has no `multiSelect`. Use sequential single-selects, or present a numbered freeform list asking the user to enter comma-separated numbers.
Execute mode fallback:
- When `request_user_input` is rejected (Execute mode), present a plain-text numbered list and pick a reasonable default.
## C. Task() → spawn_agent Mapping
GSD workflows use `Task(...)` (Claude Code syntax). Translate to Codex collaboration tools:
Direct mapping:
- `Task(subagent_type="X", prompt="Y")` → `spawn_agent(agent_type="X", message="Y")`
- `Task(model="...")` → omit (Codex uses per-role config, not inline model selection)
- `fork_context: false` by default — GSD agents load their own context via `<files_to_read>` blocks
Parallel fan-out:
- Spawn multiple agents → collect agent IDs → `wait(ids)` for all to complete
Result parsing:
- Look for structured markers in agent output: `CHECKPOINT`, `PLAN COMPLETE`, `SUMMARY`, etc.
- `close_agent(id)` after collecting results from each agent
</codex_skill_adapter>
<objective>
Audit Nyquist validation coverage for a completed phase. Three states:
- (A) VALIDATION.md exists — audit and fill gaps
- (B) No VALIDATION.md, SUMMARY.md exists — reconstruct from artifacts
- (C) Phase not executed — exit with guidance
Output: updated VALIDATION.md + generated test files.
</objective>
<execution_context>
@/Users/teo/src/tempo/.codex/get-shit-done/workflows/validate-phase.md
</execution_context>
<context>
Phase: {{GSD_ARGS}} — optional, defaults to last completed phase.
</context>
<process>
Execute @/Users/teo/src/tempo/.codex/get-shit-done/workflows/validate-phase.md.
Preserve all workflow gates.
</process>