--- name: "gsd-ingest-docs" description: "Scan a repo for mixed ADRs, PRDs, SPECs, and DOCs and bootstrap or merge the full .planning/ setup from them. Classifies each doc in parallel, synthesizes a consolidated context with a conflicts report, and routes to new-project or merge-milestone depending on whether .planning/ already exists." metadata: short-description: "Scan a repo for mixed ADRs, PRDs, SPECs, and DOCs and bootstrap or merge the full .planning/ setup from them. Classifies each doc in parallel, synthesizes a consolidated context..." --- ## A. Skill Invocation - This skill is invoked by mentioning `$gsd-ingest-docs`. - Treat all user text after `$gsd-ingest-docs` 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 `` 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 Build the full `.planning/` setup (or merge into an existing one) from multiple pre-existing planning documents — ADRs, PRDs, SPECs, DOCs — in one pass. - **Net-new bootstrap** (`--mode new`, default when `.planning/` is absent): produces PROJECT.md + REQUIREMENTS.md + ROADMAP.md + STATE.md from synthesized doc content, delegating final generation to `gsd-roadmapper`. - **Merge into existing** (`--mode merge`, default when `.planning/` is present): appends phases and requirements derived from the ingested docs; hard-blocks any contradiction with existing locked decisions. Auto-synthesizes most conflicts using the precedence rule `ADR > SPEC > PRD > DOC` (overridable via manifest). Surfaces unresolved cases in `.planning/INGEST-CONFLICTS.md` with three buckets: auto-resolved, competing-variants, unresolved-blockers. The BLOCKER gate from the shared conflict engine prevents any destination file from being written when unresolved contradictions exist. **Inputs:** directory-convention discovery (`docs/adr/`, `docs/prd/`, `docs/specs/`, `docs/rfc/`, root-level `{ADR,PRD,SPEC,RFC}-*.md`), or an explicit `--manifest ` YAML listing `{path, type, precedence?}` per doc. **v1 constraints:** hard cap of 50 docs per invocation; `--resolve interactive` is reserved for a future release. @/Users/sasikumar/Documents/n8n/.codex/get-shit-done/workflows/ingest-docs.md @/Users/sasikumar/Documents/n8n/.codex/get-shit-done/references/ui-brand.md @/Users/sasikumar/Documents/n8n/.codex/get-shit-done/references/gate-prompts.md @/Users/sasikumar/Documents/n8n/.codex/get-shit-done/references/doc-conflict-engine.md {{GSD_ARGS}} Execute the ingest-docs workflow end-to-end. Preserve all approval gates (discovery, conflict report, routing) and the BLOCKER safety rule.