src/bmm-skills/4-implementation/bmad-quick-dev/step-01-clarify-and-route.md
{communication_language}Before listing artifacts or prompting the user, check whether you already know the intent. Check in this order — skip the remaining checks as soon as the intent is clear:
Explicit argument Did the user pass a specific file path, spec name, or clear instruction this message?
status frontmatter with a recognized value: draft, ready-for-dev, in-progress, in-review, or done) → set spec_file. Before exiting, run Story-key resolution (below). Then EARLY EXIT to the appropriate step (step-02 for draft, step-03 for ready/in-progress, step-04 for review). For done, ingest as context and proceed to INSTRUCTIONS — do not resume.Recent conversation Do the last few human messages clearly show what the user intends to work on? Use the same routing as above.
Otherwise — scan artifacts and ask
draft, ready-for-dev, in-progress, in-review) in {implementation_artifacts}? → List them and HALT. Ask user which to resume (or [N] for new).
draft selected: Set spec_file. Run Story-key resolution (below). EARLY EXIT → ./step-02-plan.md (resume planning from the draft)ready-for-dev or in-progress selected: Set spec_file. Run Story-key resolution (below). EARLY EXIT → ./step-03-implement.mdin-review selected: Set spec_file. Run Story-key resolution (below). EARLY EXIT → ./step-04-review.mdstatus frontmatter? → Suggest treating its contents as the starting intent. Do NOT attempt to infer a state and resume it.Never ask extra questions if you already understand what the user intends.
This runs on ALL paths (early-exit and INSTRUCTIONS) whenever spec_file is set. Determine whether the spec is an epic story — use the spec's filename, frontmatter, and any loaded epics file to identify {epic_num} and {story_num}. If the spec is not an epic story, skip silently and leave {story_key} unset.
If the spec is an epic story and {sprint_status} exists: find the development_status key matching {epic_num}-{story_num} by exact numeric equality on the first two segments (so 1-1 never collides with 1-10). Exactly one match → set {story_key} to that full key. Zero or multiple matches → leave {story_key} unset (warn on multiple).
Load context.
List files in {planning_artifacts} and {implementation_artifacts}.
If you find an unformatted spec or intent file, ingest its contents to form your understanding of the intent.
Determine context strategy. Using the intent and the artifact listing, infer whether the current work is a story from an epic. Do not rely on filename patterns or regex — reason about the intent, the listing, and any epics file content together.
A) Epic story path — if the intent is clearly an epic story:
Identify the epic number {epic_num} and (if present) the story number {story_num}. If you can't identify an epic number, use path B.
Check for a valid cached epic context. Look for {implementation_artifacts}/epic-<N>-context.md (where <N> is the epic number). A file is valid when it exists, is non-empty, starts with # Epic <N> Context: (with the correct epic number), and no file in {planning_artifacts} is newer.
Compile epic context. Produce {implementation_artifacts}/epic-<N>-context.md by following ./compile-epic-context.md, in order of preference:
./compile-epic-context.md as its prompt. Pass it the epic number, the epics file path, the {planning_artifacts} directory, and the output path {implementation_artifacts}/epic-<N>-context.md../compile-epic-context.md yourself and follow its instructions to produce the same output file.Verify. After compilation, verify the output file exists, is non-empty, and starts with # Epic <N> Context:. If valid, load it. If verification fails, HALT and report the failure.
Previous story continuity. Regardless of which context source succeeded above, scan {implementation_artifacts} for specs from the same epic with status: done and a lower story number. Load the most recent one (highest story number below current). Extract its Code Map, Design Notes, Spec Change Log, and task list as continuity context for step-02 planning. If no done spec is found but an in-review spec exists for the same epic with a lower story number, note it to the user and ask whether to load it.
Resolve {story_key}. If not already set by an earlier early-exit path, run Story-key resolution (above) now.
B) Freeform path — if the intent is not an epic story:
*prd*) — product requirements and success criteria*architecture*) — technical design decisions and constraints*ux*) — user experience and interaction design*epic*) — feature breakdown into implementable stories*brief*) — project vision and scopeClarify intent. Do not fantasize, do not leave open questions. If you must ask questions, ask them as a numbered list. When the human replies, verify that every single numbered question was answered. If any were ignored, HALT and re-ask only the missing questions before proceeding. Keep looping until intent is clear enough to implement.
Version control sanity check. Is the working tree clean? Does the current branch make sense for this intent — considering its name and recent history? If the tree is dirty or the branch is an obvious mismatch, HALT and ask the human before proceeding. If version control is unavailable, skip this check.
Multi-goal check (see SCOPE STANDARD). If the intent fails the single-goal criteria:
[S] Split — pick first goal, defer the rest | [K] Keep all goals — accept the risks{deferred_work_file}. Narrow scope to the first-mentioned goal. Continue routing.Route — choose exactly one:
Derive a valid kebab-case slug from the clarified intent. If the intent references a tracking identifier (story number, issue number, ticket ID), lead the slug with it (e.g. 3-2-digest-delivery, gh-47-fix-auth). If {implementation_artifacts}/spec-{slug}.md already exists: if its status is draft, treat it as the same work and resume it (set spec_file to that path, EARLY EXIT → ./step-02-plan.md); otherwise append -2, -3, etc. Set spec_file = {implementation_artifacts}/spec-{slug}.md.
a) One-shot — zero blast radius: no plausible path by which this change causes unintended consequences elsewhere. Clear intent, no architectural decisions.
EARLY EXIT → ./step-oneshot.md
b) Plan-code-review — everything else. When uncertain whether blast radius is truly zero, choose this path.
Read fully and follow ./step-02-plan.md