简体中文 | English
AI-native PRD workspace and lifecycle CLI for requirement clarification, HTML-first review surfaces, diagram confirmation, and handoff.
OpenPrd is a lightweight PRD harness for teams and agents that need more than “write a document”. It gives you a local workspace, a clarification-first workflow, policy-based review gates, diagram artifacts, and a structured change/spec/task workflow.
Instead of hiding key decisions in prompts or terminal logs, OpenPrd keeps people and agents aligned around stable HTML artifacts such as review.html, learning readers, and quality reports.
OpenPrd is designed for the gap between:
- vague product ideas that need clarification
- agent-assisted requirement drafting
- human confirmation at the right decision points before implementation
- structured handoff into execution systems
It is especially useful when you want:
- clarify before drafting instead of jumping straight to implementation
- source-aware capture so user-confirmed facts stay separate from repo-derived, agent-inferred, or agent-normalized context
- policy-based review gates that keep stable artifacts without forcing the same stop every time
- agent-facing skills shipped with the tool, not hidden in a local environment
OpenPrd lives in a different spot than tools that are centered only on spec files or only on coding execution.
| Tool | Center of gravity | Main user-facing artifacts | Best fit |
|---|---|---|---|
| OpenPrd | Requirement clarification, HTML-first collaboration, and delivery gates | review.html, learning readers, quality reports, diagrams, structured change/task state |
Teams that need humans and agents to stay aligned through planning, review, execution, and ship decisions |
| OpenSpec | Spec and change lifecycle | Markdown proposals, specs, design docs, tasks | Teams that want disciplined spec deltas and a clean change-management workflow |
| Superpowers | Skill-driven coding execution | Skills, plans, worktree/subagent flows, code-review checkpoints | Engineering-heavy teams optimizing how AI agents plan, code, review, and finish branches |
OpenPrd is strongest when the hard part is not just "what code should be written," but "what should people confirm, what should stay visible, and what evidence is enough to move forward."
Recent Codex project usage kept clustering around the same kinds of work: fuzzy product requests, existing-product redesigns, release/publish flows, production incident closure, and reusable learning handoff.
| Scenario | Why OpenPrd stands out here | Main artifacts |
|---|---|---|
| Fuzzy product request before anyone codes | Clarify first, separate user-confirmed facts from agent inference, then turn the result into a stable review surface. | clarify, capture, synthesize, review.html |
| Existing flow or auth-entry redesign | Reconstruct current behavior from repo and runtime evidence before proposing the next change. | discovery, diagram, review.html, change |
| Visual or product-flow confirmation | Keep architecture, product flow, or UI replication reviewable instead of burying decisions in chat. | diagram, visual-compare, side-by-side JPG reviews |
| Long-running agent implementation chain | Turn accepted work into dependency-ready tasks and run one focused agent session per task with verify gates. | tasks, loop, prompts, progress logs, verification reports |
| Release, publish, or handoff readiness | Make "ready to ship" a visible decision with standards, regression evidence, abuse/cost guardrails, and workspace health. | quality, run --verify, doctor, handoff |
| Learning handoff after a fix or project | Package the final requirement, reasoning, and outcome into something new collaborators can actually study. | learning reader, .openprd/knowledge/skills/, docs sync |
OpenPrd produces stable, shareable HTML surfaces so product owners, engineers, and agents can look at the same artifact before work moves forward.
Use a review-ready PRD surface instead of asking teammates to reconstruct the
latest requirement state from chat history.
If the optional release ledger is enabled, the review header also shows the
current project version.
Turn a finished requirement, fix, or workflow into a readable learning package that new collaborators can study without replaying the whole thread.
Summarize readiness, required gates, evidence coverage, and manual decisions in one human-readable quality surface before handoff, release, or publish.
Put the reference and implementation into one side-by-side artifact for staged UI review, especially for auth-entry redesign, localized legal pages, and modal replication work.
OpenPrd gets easier to work with over time through two visible loops. One loop
keeps proven team habits as reusable Project-Level Skills. The other keeps
Dynamic Parameter Config adaptive, so different project situations start with
different collaboration defaults instead of the same generic checklist.
When a team reaches the same conclusion in real work more than once, OpenPrd can keep that conclusion close to the project instead of leaving it buried in chat.
- Example: a login-entry redesign confirms that log in, sign up, and password reset should all stay on the official site.
- What gets reused next time: related page checks, release review points, and the preferred path through similar requests.
- Why it matters: the next similar request starts from a shared playbook, and new teammates can follow the same steps without retelling the whole history.
Not every project should start the same way. OpenPrd can keep different collaboration defaults for different situations and bring them back automatically.
- Example: a greenfield request starts with goal clarification and scope alignment, while an inherited project starts with current-state reconstruction and boundary mapping.
- What changes automatically: what to ask first, what to inspect first, and what proof to gather before handoff.
- Why it matters: teams spend less time re-explaining how this kind of project should run and more time moving with the right setup from the start.
- Clarification-first workflow:
clarify -> capture -> classify -> interview -> synthesize -> diagram -> freeze -> handoff - Scenario-aware collaboration: distinguish greenfield cold start, existing-project cold start, and continuing workspaces
- Self-evolving collaboration: turn confirmed project habits into reusable
Project-Level Skills and adaptDynamic Parameter Configby scenario - Source-aware capture: mark inputs as
user-confirmed,project-derived,agent-inferred, oragent-normalized - Diagram review artifacts: generate both architecture and product-flow diagrams
- UI visual comparison artifacts: combine reference images and implementation screenshots into side-by-side JPG reviews for visual replication work
- Contract-driven diagrams: render from validated JSON contracts
- Review status tracking: use
pending-confirmation,confirmed, andneeds-revision - Project release/version ledger: optionally track project versions such as
0.1.23, version-scoped change items, and local git tag coordination without mixing them with internal PRDv000xversions - OpenPrd discovery mode: initialize durable coverage runs for existing projects, reference projects, or unclear requirements
- Project standards: initialize and verify
docs/basic/, file manual templates, and folder README templates as part of execution quality gates - Quality Regression Reports: review overall regression status, per-requirement module status, test-block results, observability, business cost and abuse guardrails, smoke coverage, performance baselines, and project knowledge through HTML reports
- Project knowledge skills: turn verified fixes and recurring diagnosis patterns into reusable
.openprd/knowledge/skills/experience skills - OpenPrd change and task execution: materialize PRD snapshots into change files, validate them, apply accepted specs, archive changes, and advance structured tasks by dependency order
- Long-running agent loop: turn accepted change tasks into one-task-per-session Codex or Claude execution prompts with verification, progress logs, and optional task commits
- Default agent integration: generate Codex, Claude, and Cursor guidance from one OpenPrd source, including Codex hooks with
codex_hooks = true - Agent harness skills: repo-local skills for shared rules, workflow control, and diagram review
- First-round project framing:
clarifyand intake now summarize product shape, target users, first-cut scope, non-goals, and guardrails before the workflow narrows into a local request. - Review presentation gate:
review-presentationvalidates the user-facing review summary beforereview.htmlbecomes the stable confirmation surface. - Test strategy plus execution strategy: task metadata now supports
test-layer,test-size,evidence-plan,execution-mode,write-scope,local-verify, andintegration-ownerfor main-agent/worker coordination. - Safer historical session continuation: a global session registry helps restore tool-agnostic session IDs such as
continue: <session-id>across workspaces. - Richer benchmark and knowledge capture: this round adds
benchmark observe, knowledge candidate / draft-skill review flow, and explicit Codex repair entry points throughdoctor --tools codex --fixandloop --run --agent codex --repair-agent. - Before/after visual review:
visual-comparenow supports--before/--afterso UI changes can still leave visual evidence even without a design reference.
| Layer | Technology |
|---|---|
| Runtime | Node.js 20+ |
| CLI | Native Node ESM |
| Config / state | JSON + YAML |
| Diagram renderer | Self-contained HTML + inline SVG |
| Image processing | sharp for JPG / PNG / WebP visual comparison artifacts |
| Testing | node --test |
| Agent guidance | Repo-local skills/ + AGENTS.md + Codex / Claude / Cursor generated adapters |
Install from npm:
npm install -g @openprd/cliIf you want a zero-PATH first run, or you are on Windows and openprd is not available yet, use npx directly:
npx @openprd/cli@latest --help
npx @openprd/cli@latest init . --template-pack agentThen verify:
openprd --helpIf the global install succeeds but openprd is still not found, check:
where openprd
npm config get prefixIf where openprd returns nothing, add the npm global prefix to PATH and reopen the terminal. On Windows that directory is usually %AppData%\npm, not the Unix-style {prefix}/bin.
Update the installed CLI later with a dry-run first:
openprd self-update --dry-run
openprd self-updateopenprd init /path/to/project --template-pack agentIf openprd is not on PATH yet, run the same init command through npx:
npx @openprd/cli@latest init /path/to/project --template-pack agentinit creates .openprd/, docs/basic/, AGENTS.md, and generated Codex / Claude / Cursor guidance. Codex projects also get .codex/config.toml, .codex/hooks.json, .codex/hooks/openprd-hook.mjs, and user-level Codex codex_hooks = true.
Codex hooks default to lite: UserPromptSubmit, a lightweight PreToolUse
write gate, and a lightweight Stop end-of-turn review. Context is injected for prompts that explicitly mention OpenPrd,
PRD, deep research/benchmarking, replication, standards, fleet, documentation
standards, or look like new product/module/workflow requirements. The lite write
gate only matches direct editing tools so read-only shell exploration stays
quiet, while Stop reviews whether the current turn produced a reusable project
pattern; use guarded when shell commands should also pass through the write gate,
and full only for temporary deep diagnostics.
Concrete bugfix prompts with diagnostic evidence such as errors, logs, repro
steps, or root-cause investigation skip requirement intake when the user asks to
fix directly; confirmation wording also accepts phrases like "confirm the fix".
init also performs a non-blocking optional capability check and records the
result in .openprd/harness/install-manifest.json under optionalCapabilities.
Examples:
Context7: helps the agent retrieve current third-party technical docs, config, version differences, migration paths, and high-quality implementation guidanceDeepWiki: helps the agent understand public GitHub repositories through conversational architecture and implementation lookup
If these capabilities are not configured yet, initialization still succeeds. OpenPrd records them as follow-up suggestions and includes the official docs, GitHub repo, and MCP endpoint so the current client can be configured later.
openprd status /path/to/project
openprd next /path/to/projectWhen the project-level release track is enabled, status also shows the current project version and how many change items are currently accumulated under it.
openprd release /path/to/project --set 0.1.23
openprd release /path/to/project --notes "Add a release-note entry point"
openprd release /path/to/projectrelease manages the project-level version ledger, not the internal OpenPrd PRD version such as v0004. Once enabled, handoff exports, release-note snippets, and local tag coordination in loop --finish --commit will reuse that version state.
When OpenPrd itself publishes a new version to GitHub, the release should also include a matching version tag and GitHub Release. You can preview the body with node scripts/openprd-github-release-notes.mjs /path/to/project --version 0.1.23 --tag v0.1.23 --out /tmp/openprd-release.md; the repo github-release workflow will create or update the GitHub Release from the same release-ledger on tag push or manual dispatch.
openprd clarify /path/to/projectClarification stays in the conversation as an inline outline or short checklist. The formal HTML review surface is review.html after synthesis.
Single field:
openprd capture /path/to/project \
--field problem.problemStatement \
--value "Mobile users cannot efficiently manage agent sessions on the go" \
--source user-confirmedBatch capture:
openprd capture /path/to/project --json-file answers.jsonUse --source agent-normalized only for semantic-neutral wording cleanup after
capture; it should not reopen the current review.html decision.
openprd synthesize /path/to/project \
--title "Moticlaw Mobile" \
--owner "Moticlaw" \
--problem "Mobile users lack a direct-first client for node selection and agent interaction." \
--why-now "The control plane already exists and the missing piece is a mobile entry point."
openprd review-presentation /path/to/project --template
openprd review-presentation /path/to/project \
--presentation review-presentation.json \
--write \
--fail-on-violation
openprd diagram /path/to/project --type architecture --open
openprd diagram /path/to/project --type product-flow --open
openprd review /path/to/project --open
openprd review /path/to/project --mark confirmed --version <id> --digest <sha256> --work-unit <id>review.html is the stable review artifact for the current PRD, but the default
approval policy is decision-points, not “always stop here”. In a normal lane,
the user reviews that stable artifact first and then the exact copied
--version, --digest, and --work-unit tuple is recorded. In a
silent-record lane, OpenPrd can record the exact current artifact without an
extra stop only when the user already made direct execution intent explicit and
explicitly opted out of additional review confirmation. Do not treat
implementation approval as permission to mark a different review artifact, and
do not treat review recording as execution authorization. After the current
artifact is recorded, generate the OpenPrd change and task breakdown. If the
user originally asked to implement, execution can continue once tasks are ready;
otherwise wait for an explicit execution request:
openprd change /path/to/project --generate --change <change-id>
openprd tasks /path/to/project --change <change-id>openprd freeze /path/to/project
openprd handoff /path/to/project --target openprdIf the optional release ledger is enabled, handoff exports prefer the change items accumulated under the current project version and also include a human-readable Project version: 0.1.23 field.
Users can ask in natural language:
Use OpenPrd to deeply complete this project.
Use OpenPrd to comprehensively mine this reference project into the new project.
Keep digging into this requirement until OpenPrd coverage is complete.
Discovery and loop execution require explicit depth or execution intent. For planning, architecture review, impact analysis, or "which files would change?" questions, agents should inspect state and answer read-only instead of advancing coverage or launching loop tasks.
Agents route those requests internally. The underlying command is:
openprd discovery /path/to/project --mode brownfield
openprd discovery /path/to/project --resume
openprd discovery /path/to/project --advance --claim "Users can start a session from the dashboard" --evidence src/app.ts
openprd discovery /path/to/project --verify
openprd change /path/to/project --generate --change <change-id>
openprd change /path/to/project --validate --change <change-id>
openprd standards /path/to/project --verify
openprd tasks /path/to/project --change <change-id>
openprd tasks /path/to/project --change <change-id> --advance --verify --item T001.01
openprd change /path/to/project --apply --change <change-id>
openprd change /path/to/project --archive --change <change-id>
openprd specs /path/to/project
openprd changes /path/to/projectDiscovery verification also checks the active OpenPrd change structure, spec deltas,
docs/basic/ standards, and long-running task files. Keep tasks.md as the first
entry, cap each task file at 25 substantive checkbox tasks, and continue with
tasks-002.md, tasks-003.md, etc. The final checkbox in every non-final file
should hand off to the next file so agents can resume in order. A project can use
a stricter local cap with .openprd/discovery/config.json at
taskSharding.maxItemsPerFile.
That 25-item limit is only a sharding cap, not a decomposition target. Prefer task titles that describe concrete implementation units, wiring boundaries, entry surfaces, integration closures, and regression passes instead of mirroring PRD section labels like "primary flow", "requirement", or "acceptance goal".
When a task needs a stable id for long-running execution, keep the metadata small:
- [ ] T009.07 Port legacy database import preview
- type: implementation
- deps: T001.14, T007.06
- done: preview shows counts, conflicts, skipped items, warnings
- verify: npm run test -- migration
- test-layer: unit, integration
- test-size: medium
- test-scope: cli-contract
- evidence-plan: unit tests for import parsing plus CLI contract output evidence
- oracle: compare sample import output against the legacy preview and record mismatchesUse type to distinguish implementation, verification, documentation, and
governance work. deps is only needed when the task depends on earlier task ids.
done is the completion condition, and verify is the command or review step
that proves it. For implementation and verification tasks, generated tasks
default to openprd tasks . --change <id> --item <task-id> --evidence-required:
the agent must run the smallest useful task-level test or review, then pass
--evidence <path-or-summary> or record evidence: / waiver-reason: in the
task metadata. Documentation tasks still use standards checks. Reserve
openprd run . --verify for phase/final gates instead of every task; do not use
openprd change . --validate as the only proof. Legacy generated tasks that
still say verify: openprd run . --verify are treated as task evidence checks
when run through openprd tasks --verify, so old task files do not keep
regenerating workspace quality reports. Use oracle when the task must compare against a reference
implementation, golden data set, screenshot baseline, or other explicit source
of truth; openprd loop --finish then requires --notes or --evidence so the
comparison result is recorded.
Tasks may also include test strategy metadata. test-layer, test-size,
test-scope, and evidence-plan help OpenPrd choose the smallest useful
verification evidence: unit tests for isolated logic, integration or contract
tests for CLI/API/agent boundaries, and e2e/visual/weapp/performance/security
checks when a task touches user flows or higher-risk runtime behavior. These
fields route evidence by risk; they are not a fixed 70/20/10 quota.
tasks lists the next dependency-ready task by default. --advance marks
one task complete, and --verify runs that task's verify command before marking
it complete. Execution events are stored outside the task files so the task metadata
stays small.
openprd init creates a project standards contract:
docs/basic/file-structure.mddocs/basic/app-flow.mddocs/basic/prd.mddocs/basic/frontend-guidelines.mddocs/basic/backend-structure.mddocs/basic/tech-stack.md.openprd/standards/file-manual-template.md.openprd/standards/folder-readme-template.md
Use:
openprd standards /path/to/project --verifyOpenPrd generated changes include standards maintenance tasks, and change validation
checks the standards contract. The canonical project docs path is only
docs/basic/.
During implementation, standards maintenance is an explicit impact check, not a
best-effort cleanup. For every added or modified source file, agents should check
whether docs/basic/, the file manual, or the containing folder README is missing
or stale. Missing docs must be created; existing docs should be updated whenever
the change affects responsibilities, flows, structure, dependencies, or product
behavior. If no documentation update is needed, agents should say the check was
performed and why the existing docs still match the code.
When UI work already has a reference effect image, design image, user-provided screenshot, or agent-generated mock, the agent should capture the implemented UI and generate a side-by-side review image before claiming visual completion:
openprd visual-compare /path/to/project \
--reference effect-image.png \
--actual implementation-screenshot.jpgThe default output is a compact JPG under
.openprd/harness/visual-reviews/. The left panel is labeled 效果图; the
right panel is labeled 实现截图. Inputs can be common image formats supported
by sharp.
When UI work has no reference image, capture the current screen before editing, apply the change, then capture the same entry, viewport, account, and data state after editing:
openprd visual-compare /path/to/project \
--before before-screenshot.png \
--after after-screenshot.jpgThe before/after mode labels the panels 修改前 and 修改后, giving the agent a
visual self-check for expected changes and unintended drift. The output can be
adjusted when needed:
openprd visual-compare /path/to/project \
--reference effect-image.png \
--actual implementation-screenshot.jpg \
--out review.webp \
--format webp \
--quality 82 \
--max-panel-width 1180Agents should inspect the generated image and keep iterating until there are no obvious visual differences. The final response for reference-driven UI work should include the generated review image path and note whether differences remain.
openprd init also creates a quality contract:
.openprd/quality/config.json.openprd/quality/reports/.openprd/knowledge/
Use:
openprd quality /path/to/project --verifyThe command writes both JSON and HTML reports under .openprd/quality/reports/.
The HTML regression report is the human-readable quality surface: overall
regression status, per-requirement module status, test-block pass/fail results,
test strategy matrix, missing items, and the small set of gaps that need a
person to decide whether they are in scope for the current delivery. EVO is
OpenPrd's internal shorthand for the evaluation/verification quality layer; the
visible report does not ask users to know that acronym. A script or fixture
being present only proves capability; required gates need current evidence or an
explicit waiver.
When a requirement involves free users, quotas, AI calls, third-party APIs,
generation, storage, downloads, or other metered costs, quality --verify
also checks for cost drivers, user-level limits, negative abuse-path
verification, usage/cost monitoring, alert thresholds, and stop-loss actions.
openprd quality --verify is blocking by default when required test blocks are
not production-ready. openprd run --verify repeats that quality gate so final
readiness cannot ignore the report. Agents should not claim readiness until
every required test block is either passing with evidence or explicitly out of
scope for the scenario.
For UI work with an existing reference image, visual readiness also requires a
current openprd visual-compare artifact under .openprd/harness/visual-reviews/.
If the combined image still shows obvious differences, the task should return to
implementation instead of treating the gap as ready.
After a fix has been verified and reviewed, promote the abstract pattern into project knowledge:
openprd quality /path/to/project --learn --review --from .openprd/harness/turn-state.json
openprd quality /path/to/project --learn --from <report-id-or-json>
openprd quality /path/to/project --learn --from ./diagnostics/incident-2026-05-24--learn --review first writes a pending knowledge candidate under
.openprd/knowledge/candidates/ plus a draft skill under
.openprd/knowledge/drafts/. Once the draft is worth keeping, --learn --from
promotes it into incident, pattern, and experience skill artifacts under
.openprd/knowledge/ so future tasks can retrieve the lesson instead of
rediscovering it. --from now accepts either a quality report JSON or an
extracted diagnostics directory / evidence file that already contains
diagnostic-report, runtime-events, timeline, or root-cause-candidates
artifacts, so a verified fix can be promoted directly into a reusable
troubleshooting skill.
OpenPrd can install the project harness into the agent environment so users do not need to remember which skill, command, or hook to invoke:
openprd setup /path/to/project
openprd doctor /path/to/project
openprd self-update --dry-run
openprd self-update
openprd update /path/to/project
openprd update /path/to/project --hook-profile lite
openprd upgrade /path/to/project --dry-run
openprd upgrade /path/to/project
openprd upgrade /path/to/projects --fleet --dry-run
openprd fleet /path/to/projects --dry-run
openprd fleet /path/to/projects --sync-registry
openprd fleet /path/to/projects --backfill-work-units
openprd run /path/to/project --context
openprd run /path/to/project --verify
openprd loop /path/to/project --plan --change <change-id>
openprd loop /path/to/project --run --agent codex --dry-runInstalling the CLI alone does not mutate a project or user config. The full
Codex/Claude/Cursor adapter set is installed when the user runs openprd init
or openprd setup inside a project.
setup and init generate:
AGENTS.mdmanaged OpenPrd rules.codex/skills/,.codex/prompts/,.codex/config.toml,.codex/hooks.json, and.codex/hooks/openprd-hook.mjs- user-level Codex config with
features.codex_hooks = true .claude/skills/,.claude/commands/openprd/, andCLAUDE.md.cursor/rules/openprd.mdcand.cursor/commands/.openprd/harness/install-manifest.json,hook-state.json,events.jsonl,drift-report.json, andvisual-reviews/
setup, init, update, and doctor also maintain
optionalCapabilities inside .openprd/harness/install-manifest.json. These
entries are only “better when configured” recommendations and never turn
initialization, diagnostics, or the current task into a failure.
doctor verifies that the generated rules, Codex hooks feature flag, standards,
and workspace validation are healthy, and also surfaces optional enhancement
recommendations such as Context7 or DeepWiki. update refreshes the generated
adapter files from the canonical OpenPrd source while preserving unrelated user
hook groups.
self-update updates the OpenPrd CLI itself from the public npm package.
upgrade composes the two update layers: it first runs self-update, then
re-resolves the installed openprd executable and runs either update <project>
or, with --fleet, fleet <root> --update-openprd. Both commands support
--dry-run; dry-run prints the planned install and refresh commands without
modifying the CLI, project, registry, or harness state.
The harness is stateful, but hooks are proportional to the chosen profile.
Default lite keeps a lightweight PreToolUse write gate for requirement
intake and limits it to direct editing tools, while Stop performs a lightweight
end-of-turn knowledge review instead of full telemetry. This avoids read-only shell hook
noise while still nudging the agent to capture reusable project patterns. guarded also gates shell tools, while
full restores SessionStart/PreToolUse/PostToolUse/Stop telemetry for temporary
diagnostics. High-risk actions such as freeze, handoff, accepted spec
apply/archive, commit, push, release, or publish are gated by
openprd run . --verify, which covers standards, workspace validation, active
change validation, and active discovery verification.
openprd run . --context is the Ralph-style loop surface for agents. It selects
the next executable unit from active change tasks, discovery coverage, or normal
OpenPrd workflow state, and records hook turns in .openprd/harness/iterations.jsonl.
For implementation work that should behave like the harness pattern described by
Anthropic's long-running agent guidance, use openprd loop. The loop is stricter
than run --context: it creates a durable feature list, writes a single-task
prompt, starts a fresh Codex or Claude session for exactly one task, verifies the
task, and can commit that task before moving on.
For UI tasks, the loop prompt and generated guidance require the agent to run
openprd visual-compare before finishing: use --reference/--actual when a
reference image exists, or --before/--after when the agent must verify a UI
change without an explicit reference image.
openprd run --context may surface loop commands as execution commands, but they
are not automatic instructions. Agents should run openprd loop --run,
openprd tasks --advance, openprd discovery --advance, or commit commands only
when the current user message explicitly asks for development, implementation,
task continuation, deep research/benchmarking, replication, or commit. Read-only
planning and review turns should stop at the module/file plan.
Loop is recommended from the substantive implementation task count, not from every
checkbox. When a change has 10 or more pending/total implementation tasks,
run --context recommends an isolated worktree or equivalent environment plus a
single-task Loop session.
openprd loop . --init
openprd loop . --plan --change <change-id>
openprd loop . --next
openprd loop . --prompt --agent codex
openprd loop . --run --agent codex --dry-run
openprd loop . --run --agent claude --dry-run
openprd loop . --verify --item T001.01
openprd loop . --finish --item T001.01 --commit --message "Add a release-note entry point"When the project-level release track is enabled, loop --finish --commit records the task's short user-facing summary under the current project version and then tries to move the same-name local tag (for example 0.1.23) to the latest commit. If a remote tag with the same name already exists, OpenPrd warns and skips the local retag instead of silently rewriting remote history.
The loop writes its durable state under .openprd/harness/:
feature-list.jsonis the ordered implementation task list.- Each loop task carries a human-readable
taskHandlesuch aschange-id:T001.01:task-title, so another conversation can continue the same task without relying on a chat-specific UUID. progress.mdis the human-readable progress log.failed-approaches.mdis the dead-end ledger for mismatches, rejected fixes, and why they failed, so the next session does not retry the same path.agent-sessions.jsonlrecords each prompt/run/finish event, including the task handle and task title for cross-session lookup.bootstrap.shis the startup check each fresh agent session runs.loop-state.jsonstores the current task id, task handle, task title, and the last agent session metadata.loop-prompts/stores generated single-task prompts for audit and reuse.
Use --dry-run first when you want OpenPrd to prepare the prompt and exact command
without launching an agent. Use --agent codex or --agent claude for the default
CLI integrations. Use --agent-command "<custom command>" only when you want to
pipe the OpenPrd prompt into a project-specific wrapper.
For historical projects, use fleet instead of hand-writing shell loops. By
default it scans and reports only, while also telling you how many known
OpenPrd workspaces already exist in the global registry and how many are outside
the current root. --sync-registry backfills initialized .openprd/
workspaces into ~/.openprd/registry/workspaces.jsonl. --update-openprd
refreshes projects that already contain .openprd/ and also backfills
historical PRD work unit bindings. Project standards or validation gaps are
reported as health items, but they do not block generated guidance updates. Use
--backfill-work-units when you only want to refresh versioned review artifacts
and identity bindings, while agent-only or plain projects stay untouched unless
explicitly selected with --setup-missing.
OpenPrd is not just a command runner. It exposes collaboration state.
Use it to understand:
- current scenario
- user participation mode
- current gate
- upcoming gate
- current project version, if the release track is enabled
Example signals:
Scenario: Cold start (existing project)User participation mode: context-plus-confirmationCurrent gate: clarify-userUpcoming gate: architecture diagram review
Use it to understand:
- what should happen next
- why that step is recommended
- which questions should be asked now
OpenPrd supports:
architectureproduct-flow
You can let the tool infer a draft from the current workspace, or supply an explicit contract:
openprd diagram /path/to/project \
--type product-flow \
--input ./product-flow-contract.jsonThe diagram contract is validated against built-in schema files in .openprd/schema/.
This repository ships a repo-local skills/ directory modeled after the lark-shared + domain skills pattern used by larksuite/cli.
skills/openprd-shared/— shared guardrails and language/review rulesskills/openprd-harness/— main OpenPrd workflow sequencingskills/openprd-standards/— project docs, file manual, and folder README standardsskills/openprd-diagram-review/— diagram generation and review loop guidanceskills/openprd-discovery-loop/— sustained OpenPrd coverage discovery
Agents entering this repository should read:
AGENTS.md
.
├── AGENTS.md
├── bin/
├── src/
├── skills/
├── test/
├── docs/
│ └── basic/
├── openprd/
│ ├── changes/
│ ├── specs/
│ └── archive/
└── .openprd/
├── schema/
├── templates/
├── engagements/
├── state/
└── exports/
Key directories:
src/— CLI logic, PRD core, diagram renderingdocs/basic/— project-level baseline docs maintained by OpenPrd standardsskills/— repo-local agent skill system.openprd/— shipped workspace seedtest/— regression coverage for clarify / capture / diagram / gate logic
You can steer agents with prompts like:
Use $openprd-harness to initialize and advance an OpenPrd workspace for this product idea.
Use $openprd-diagram-review to generate a product-flow review artifact before freeze.
See CONTRIBUTING.md.
See SECURITY.md.
MIT — see LICENSE.





