plugins/coordinator/skills/shape/SKILL.md
Converge with the PM on the SHAPE of a problem (the PRD half) before any solutioning. Strategic, not tactical. Exit gate chains into coordinator:plan.
npx skillsauth add oduffy-delphi/coordinator-claude shapeInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Converge with the PM on what the problem actually is before the EM goes solo on how to solve it. Plans fuse a PM-owned PRD half (the problem, what "solved" means) with an EM-owned SDD half (architecture, fix-locus, sequencing); the pipeline has rigor for the SDD half and almost none for the PRD half. /shape is that missing front-half: a short, collaborative problem-convergence beat whose only exit is a ratified problem-set that chains into coordinator:plan.
/shape is a strategic ceremony, not a tactical clarification round. It operates at the altitude of product intent, scope boundaries, and success criteria — the questions only the PM can resolve. Tactical uncertainties (naming, file structure, which test framework, commit shape, refactor mechanics) are EM remit and do NOT belong in a /shape exchange, no matter how genuinely unsure the EM is — resolving them is the EM's job (global CLAUDE.md § PM Altitude).
Announce at start: "Using /shape to converge on the problem before we plan a solution."
coordinator:brainstorming. The discriminating test: if the PM HAS a problem and wants confirmation you understood it (vs. not knowing what to build at all) → coordinator:shape, not coordinator:brainstorming./shape, an existing approved spec, a known next-step on a live workstream) → straight to coordinator:plan./shape and coordinator:brainstorming are siblings, not twins: brainstorming turns vague intent into a design spec (a solution artifact in docs/specs/); /shape converges on the problem (a problem-set in docs/problems/) and defers solutioning entirely. Both terminate in coordinator:plan.
This gate is about finishing what you started. If the problem was already converged (prior /shape, existing spec, known workstream next-step), skip /shape entirely and go straight to coordinator:plan. But once /shape starts, see it through.
</HARD-GATE>
coordinator:plan's job.coordinator:plan — the only valid exit.A yes/no "do I have the shape? ✓" is a banned response shape — EM confidence is coupled with helpfulness, so it self-reports green every time and reveals nothing (the same failure mode that made plan-coverage-checker no-opt-out). Step 2 must instead produce the thing that reveals a misunderstanding:
global CLAUDE.md § PM Altitude. Resolving them is your job; surfacing them is noise.This does not make the mechanism un-gameable in absolute terms (no self-report is), but it raises the cost of the dodge above the cost of honest articulation — the right bar for an offer-shaped mechanism, per eager-agent-calibration.md § offer-shape.
Save to: docs/problems/YYYY-MM-DD-<slug>.md (project directory; create docs/problems/ if absent). Tiny by design — a bulleted problem list, not a design doc.
---
title: <one-line problem title>
date: YYYY-MM-DD
ratified_by: <PM name>
ratified_date: YYYY-MM-DD
status: ratified
kind: problem-set
---
# <Problem title>
> Ratified by PM <name> <date>. Frozen before any solution. This is the external coverage oracle for plans that cite it.
## Problems
- **P1 — <short name>.** <The problem, stated falsifiably. What's wrong / missing / needed and why.>
- **P2 — …**
## Out of scope (architectural reasons)
- **<Thing we're explicitly NOT solving>** — <hard architectural reason, not "later".>
Integrity marker: status: ratified plus the > Ratified by PM … blockquote are what make this a real PM oracle rather than EM self-talk. A problem-set without ratification is status: draft and does NOT count as an oracle. Plans link it via the problem_set: frontmatter key.
Once the PM ratifies the problem-set:
REQUIRED SUB-SKILL: Invoke coordinator:plan. The ratified problem-set is the input and becomes the plan's coverage oracle (plan-coverage-checker consumes it). Do NOT invoke any other skill — coordinator:plan is the only valid next step.
Ceremony placement: /shape is the third vertex beside coordinator:brainstorming (vague what) and straight-to-coordinator:plan (converged shape), per ceremony-calibration.md. <!-- code-reviewer F2: dropped dangling § anchor (vague-vs-concrete framing section does not exist in ceremony-calibration.md); keeping file reference, dropping dead section cite -->
tools
Orient session — preflight, load context, choose work
documentation
Wrap up finished work — capture lessons, update docs
development
Triangulate plan-claim / code-reality / review oracles to classify each plan into DELIVERED+REVIEWED / DELIVERED-UNREVIEWED / PARTIAL / IN-FLIGHT / ABANDONED. Run after any crash or 'did we actually finish what we think we finished?' moment.
testing
Check for a published coordinator update and advise a preserve-by-default migration path — never a blind overwrite.