experiment(stores): the plan folder#1286
Conversation
Add a short, plain-language guide for grouping related changes under one shared
plan ("an initiative"), shown in a single repo and across many repos via a store.
Includes a real worked example built from changes already in this repo, and links
it from the docs index. Beta, alongside the existing stores guide.
Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
|
Note Reviews pausedIt looks like this branch is under active development. To avoid overwhelming you with review comments due to an influx of new commits, CodeRabbit has automatically paused this review. You can configure this behavior by changing the Use the following commands to manage reviews:
Use the checkboxes below for quick actions:
📝 WalkthroughWalkthroughThis PR adds initiatives documentation and example materials, introduces store-aware initiative discovery proposals, and wires ChangesInitiatives documentation and examples
Store-aware CLI and initiative listing
Estimated code review effort: 3 (Moderate) | ~25 minutes Possibly related PRs
Suggested reviewers: 🚥 Pre-merge checks | ✅ 4 | ❌ 1❌ Failed checks (1 inconclusive)
✅ Passed checks (4 passed)
✨ Finishing Touches🧪 Generate unit tests (beta)
Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out. Comment |
Expand the example and guide to show that an initiative holds more than changes: personas (who the work serves), decision records (ADRs), and an optional schema that defines your own artifact types (persona -> adr -> spec -> tasks). The schema output shown is real (captured from `openspec schemas`). Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
Add a one-pager (brief) artifact to the example schema, making the graph one-pager -> persona -> adr -> spec -> tasks. Include finished-example/, a change taken fully through that graph (real files), and show the completed run in the guide: status 5/5 complete and `validate --strict` passing. All output captured from a real run; the schema is not added to the repo's active set. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
There was a problem hiding this comment.
🧹 Nitpick comments (5)
docs/stores-beta/initiatives.md (2)
25-31: 📐 Maintainability & Code Quality | 🔵 Trivial | ⚡ Quick winAdd language specifiers to fenced code blocks for syntax highlighting and accessibility.
Twenty code blocks lack language identifiers, triggering MD040 warnings. This hurts readability (no syntax highlighting) and accessibility (screen readers can't announce the code type).
Add these specifiers:
- File trees →
text- Shell commands →
bash- YAML config →
yaml- Command output →
text📝 Suggested fixes (excerpt)
- ``` + ```text openspec/ initiatives/ smoother-setup/ README.md the shared plan: what this is and why these changes go together inventory.md the list of changes, and where each one stands```diff - ``` + ```bash openspec list --changes```diff - ``` + ```yaml references: - team-plans```diff - ``` + ```bash openspec validate example-first-run --type change --strict</details> Also applies to: 43-55, 59-61, 72-78, 99-101, 103-107, 111-114, 118-129, 134-141, 145-147, 169-184, 189-191, 194-200, 206-208, 210-220, 222-224, 226-228 <details> <summary>🤖 Prompt for AI Agents</summary>Verify each finding against current code. Fix only still-valid issues, skip the
rest with a brief reason, keep changes minimal, and validate.In
@docs/stores-beta/initiatives.mdaround lines 25 - 31, Add language
identifiers to all fenced code blocks in the initiatives docs so Markdown lint
MD040 stops flagging them. Update the existing fences in the relevant sections
of docs/stores-beta/initiatives.md to use the right specifier based on content:
file trees with text, shell commands with bash, YAML snippets with yaml, and
command output with text. Make sure the repeated examples in the affected
sections are updated consistently so the markdown stays readable and accessible.</details> <!-- cr-comment:v1:fefae1bd15fd32332c3150a2 --> --- `243-243`: _📐 Maintainability & Code Quality_ | _🔵 Trivial_ | _💤 Low value_ **Strong accuracy claim requires verification.** The statement "Every command and its output above came from a normal OpenSpec install" is a strong claim. If any output was manually edited for clarity or reconstructed from memory, this could become inaccurate as the CLI evolves. Consider softening to "Command output shown is representative of a normal OpenSpec install" or adding a version note, unless you have high confidence every snippet was captured verbatim from a real run. <details> <summary>🤖 Prompt for AI Agents</summary>Verify each finding against current code. Fix only still-valid issues, skip the
rest with a brief reason, keep changes minimal, and validate.In
@docs/stores-beta/initiatives.mdat line 243, The wording in the OpenSpec
install note is making an overly strong provenance claim; update the affected
text in the initiatives documentation to either soften it to representative
output or qualify it with a specific version/capture note. Use the surrounding
install narrative in the same section to locate the sentence, and ensure the
revised phrasing avoids asserting that every command and output was captured
verbatim unless that can be verified.</details> <!-- cr-comment:v1:d943cc4f4728404a2355a2f1 --> </blockquote></details> <details> <summary>openspec/initiatives/smoother-setup/decisions/0002-tool-native-paths.md (1)</summary><blockquote> `1-3`: _📐 Maintainability & Code Quality_ | _🔵 Trivial_ | _💤 Low value_ **Minor format inconsistency with ADR 0001.** ADR 0001 includes an introductory quote block explaining what an ADR is; ADR 0002 omits it. For consistency across the initiative's decision records, consider adding the same intro to 0002, or removing it from 0001 if you prefer brevity. <details> <summary>🤖 Prompt for AI Agents</summary>Verify each finding against current code. Fix only still-valid issues, skip the
rest with a brief reason, keep changes minimal, and validate.In
@openspec/initiatives/smoother-setup/decisions/0002-tool-native-paths.md
around lines 1 - 3, ADR 0002 is missing the same introductory quote block used
in ADR 0001, creating a format inconsistency between decision records. Update
the ADR 0002 document to either add the shared intro near the top or remove the
intro from ADR 0001 for consistency; use the ADR headings and title in 0002 to
place the change cleanly.</details> <!-- cr-comment:v1:e80d3fe6e806ee5a304cd9b2 --> </blockquote></details> <details> <summary>openspec/initiatives/smoother-setup/inventory.md (1)</summary><blockquote> `13-23`: _📐 Maintainability & Code Quality_ | _🔵 Trivial_ | _⚡ Quick win_ **Add language specifiers to fenced code blocks.** The two command examples lack language tags, which hurts syntax highlighting and accessibility. ```diff See live status any time: -``` +```shell openspec list --changesOpen any change to see its full plan:
-
+shell
openspec show simplify-skill-installation🤖 Prompt for AI Agents
Verify each finding against current code. Fix only still-valid issues, skip the rest with a brief reason, keep changes minimal, and validate. In `@openspec/initiatives/smoother-setup/inventory.md` around lines 13 - 23, Add the missing language specifiers to the fenced examples in inventory.md so the command snippets render correctly. Update the two markdown code fences around the openspec list and openspec show examples to use a shell language tag, keeping the content unchanged. Use the existing fenced examples in the setup instructions section as the target location.openspec/initiatives/smoother-setup/example-schema/finished-example/.openspec.yaml (1)
1-2: 📐 Maintainability & Code Quality | 🔵 Trivial | 💤 Low valueConsider adding
versionfield to match schema declaration.The schema.yaml declares
version: 1, but the metadata file only includesschema: initiativewithout a corresponding version. If the metadata validation expects a version field or if future schema versions are anticipated, include it here for consistency.schema: initiative +version: 1 created: 2026-06-30🤖 Prompt for AI Agents
Verify each finding against current code. Fix only still-valid issues, skip the rest with a brief reason, keep changes minimal, and validate. In `@openspec/initiatives/smoother-setup/example-schema/finished-example/.openspec.yaml` around lines 1 - 2, Add the missing version metadata to the initiative definition so it matches the schema declaration. Update the .openspec YAML for the example initiative by including a version field alongside schema: initiative, keeping the metadata consistent with the versioned schema used elsewhere. Use the existing initiative metadata structure in the .openspec file as the place to add it.
🤖 Prompt for all review comments with AI agents
Verify each finding against current code. Fix only still-valid issues, skip the
rest with a brief reason, keep changes minimal, and validate.
Nitpick comments:
In `@docs/stores-beta/initiatives.md`:
- Around line 25-31: Add language identifiers to all fenced code blocks in the
initiatives docs so Markdown lint MD040 stops flagging them. Update the existing
fences in the relevant sections of docs/stores-beta/initiatives.md to use the
right specifier based on content: file trees with text, shell commands with
bash, YAML snippets with yaml, and command output with text. Make sure the
repeated examples in the affected sections are updated consistently so the
markdown stays readable and accessible.
- Line 243: The wording in the OpenSpec install note is making an overly strong
provenance claim; update the affected text in the initiatives documentation to
either soften it to representative output or qualify it with a specific
version/capture note. Use the surrounding install narrative in the same section
to locate the sentence, and ensure the revised phrasing avoids asserting that
every command and output was captured verbatim unless that can be verified.
In `@openspec/initiatives/smoother-setup/decisions/0002-tool-native-paths.md`:
- Around line 1-3: ADR 0002 is missing the same introductory quote block used in
ADR 0001, creating a format inconsistency between decision records. Update the
ADR 0002 document to either add the shared intro near the top or remove the
intro from ADR 0001 for consistency; use the ADR headings and title in 0002 to
place the change cleanly.
In
`@openspec/initiatives/smoother-setup/example-schema/finished-example/.openspec.yaml`:
- Around line 1-2: Add the missing version metadata to the initiative definition
so it matches the schema declaration. Update the .openspec YAML for the example
initiative by including a version field alongside schema: initiative, keeping
the metadata consistent with the versioned schema used elsewhere. Use the
existing initiative metadata structure in the .openspec file as the place to add
it.
In `@openspec/initiatives/smoother-setup/inventory.md`:
- Around line 13-23: Add the missing language specifiers to the fenced examples
in inventory.md so the command snippets render correctly. Update the two
markdown code fences around the openspec list and openspec show examples to use
a shell language tag, keeping the content unchanged. Use the existing fenced
examples in the setup instructions section as the target location.
ℹ️ Review info
⚙️ Run configuration
Configuration used: Path: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
Run ID: 93189cf8-0118-48b8-a5b4-2db11986357e
📒 Files selected for processing (21)
docs/README.mddocs/stores-beta/initiatives.mdopenspec/initiatives/smoother-setup/README.mdopenspec/initiatives/smoother-setup/decisions/0001-aliases-over-rename.mdopenspec/initiatives/smoother-setup/decisions/0002-tool-native-paths.mdopenspec/initiatives/smoother-setup/example-schema/finished-example/.openspec.yamlopenspec/initiatives/smoother-setup/example-schema/finished-example/adr.mdopenspec/initiatives/smoother-setup/example-schema/finished-example/one-pager.mdopenspec/initiatives/smoother-setup/example-schema/finished-example/persona.mdopenspec/initiatives/smoother-setup/example-schema/finished-example/specs/first-run-skills/spec.mdopenspec/initiatives/smoother-setup/example-schema/finished-example/tasks.mdopenspec/initiatives/smoother-setup/example-schema/schema.yamlopenspec/initiatives/smoother-setup/example-schema/templates/adr.mdopenspec/initiatives/smoother-setup/example-schema/templates/one-pager.mdopenspec/initiatives/smoother-setup/example-schema/templates/persona.mdopenspec/initiatives/smoother-setup/example-schema/templates/spec.mdopenspec/initiatives/smoother-setup/example-schema/templates/tasks.mdopenspec/initiatives/smoother-setup/inventory.mdopenspec/initiatives/smoother-setup/personas/coding-agent.mdopenspec/initiatives/smoother-setup/personas/new-user.mdopenspec/initiatives/smoother-setup/personas/team-lead.md
Frame the prototype's rough edges as a short forward plan (an initiative command, cross-repo status rollup, ready-made artifact types), so the guide reads as a plan, not only a how-to. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
…-artifacts superpower Lead on the wedge (define your own artifact types, share them in a store every repo reads), deliver it through the cross-repo happy path, and propose the build (store-aware artifact/schema discovery + initiative precedence) as a validated OpenSpec change. Trim the example from ~20 files to 9 while keeping personas + decision records to show customizability. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
There was a problem hiding this comment.
Actionable comments posted: 1
🤖 Prompt for all review comments with AI agents
Verify each finding against current code. Fix only still-valid issues, skip the
rest with a brief reason, keep changes minimal, and validate.
Inline comments:
In `@openspec/changes/initiatives-in-stores/specs/store-aware-artifacts/spec.md`:
- Around line 3-22: Clarify the `--store` discovery behavior in the store-aware
schema discovery requirement by explicitly stating whether `openspec schemas
--store acme-plans` should merge store schemas with the current repo’s own
schemas or show only the selected store’s schemas. Update the requirement text
and the “Listing a store’s schemas” scenario so the contract is unambiguous, and
align the “Referenced store schemas are visible from a repo” scenario with the
same discovery rules using the store-aware schema discovery language.
🪄 Autofix (Beta)
Fix all unresolved CodeRabbit comments on this PR:
- Push a commit to this branch (recommended)
- Create a new PR with the fixes
ℹ️ Review info
⚙️ Run configuration
Configuration used: Path: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
Run ID: ef8289f3-2a22-46c2-a341-18f2e8ae8c33
📒 Files selected for processing (10)
docs/README.mddocs/stores-beta/initiatives.mdopenspec/changes/initiatives-in-stores/design.mdopenspec/changes/initiatives-in-stores/proposal.mdopenspec/changes/initiatives-in-stores/specs/store-aware-artifacts/spec.mdopenspec/changes/initiatives-in-stores/tasks.mdopenspec/initiatives/smoother-setup/brief.mdopenspec/initiatives/smoother-setup/example-schema/schema.yamlopenspec/initiatives/smoother-setup/example-schema/templates/brief.mdopenspec/initiatives/smoother-setup/example-schema/templates/decision.md
✅ Files skipped from review due to trivial changes (7)
- openspec/initiatives/smoother-setup/example-schema/templates/brief.md
- openspec/initiatives/smoother-setup/brief.md
- openspec/changes/initiatives-in-stores/proposal.md
- openspec/changes/initiatives-in-stores/tasks.md
- openspec/initiatives/smoother-setup/example-schema/templates/decision.md
- docs/README.md
- docs/stores-beta/initiatives.md
| ### Requirement: Store-aware schema discovery | ||
|
|
||
| The system SHALL discover schemas and artifact types from a store when the store | ||
| is selected with `--store` or referenced by the current repo, in addition to the | ||
| current repo's own schemas. | ||
|
|
||
| #### Scenario: Listing a store's schemas | ||
|
|
||
| - **WHEN** a user runs `openspec schemas --store acme-plans` | ||
| - **THEN** the system lists the schemas defined in the `acme-plans` store | ||
| - **AND** each schema shows its name and description | ||
|
|
||
| #### Scenario: Referenced store schemas are visible from a repo | ||
|
|
||
| - **WHEN** a repo references the `acme-plans` store and the user runs | ||
| `openspec context` | ||
| - **THEN** the referenced store's custom artifact types are listed as read-only | ||
| context | ||
| - **AND** each entry includes a one-line summary and a fetch command | ||
|
|
There was a problem hiding this comment.
🎯 Functional Correctness | 🟠 Major | ⚡ Quick win
Clarify the --store discovery contract.
The requirement says store discovery is "in addition to the current repo's own schemas," but the openspec schemas --store acme-plans scenario reads like a store-only listing. Please spell out whether --store merges local and store results or replaces the local view, otherwise implementations and tests can diverge here.
♻️ Proposed spec clarification
- The system SHALL discover schemas and artifact types from a store when the store
- is selected with `--store` or referenced by the current repo, in addition to the
- current repo's own schemas.
+ When a repo references a store, the system SHALL discover that store's schemas
+ and artifact types alongside the current repo's own schemas.
+ When `--store <id>` is used, the system SHALL list that store's schemas and
+ artifact types for the selected store.📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
| ### Requirement: Store-aware schema discovery | |
| The system SHALL discover schemas and artifact types from a store when the store | |
| is selected with `--store` or referenced by the current repo, in addition to the | |
| current repo's own schemas. | |
| #### Scenario: Listing a store's schemas | |
| - **WHEN** a user runs `openspec schemas --store acme-plans` | |
| - **THEN** the system lists the schemas defined in the `acme-plans` store | |
| - **AND** each schema shows its name and description | |
| #### Scenario: Referenced store schemas are visible from a repo | |
| - **WHEN** a repo references the `acme-plans` store and the user runs | |
| `openspec context` | |
| - **THEN** the referenced store's custom artifact types are listed as read-only | |
| context | |
| - **AND** each entry includes a one-line summary and a fetch command | |
| ### Requirement: Store-aware schema discovery | |
| When a repo references a store, the system SHALL discover that store's schemas | |
| and artifact types alongside the current repo's own schemas. | |
| When `--store <id>` is used, the system SHALL list that store's schemas and | |
| artifact types for the selected store. | |
| #### Scenario: Listing a store's schemas | |
| - **WHEN** a user runs `openspec schemas --store acme-plans` | |
| - **THEN** the system lists the schemas defined in the `acme-plans` store | |
| - **AND** each schema shows its name and description | |
| #### Scenario: Referenced store schemas are visible from a repo | |
| - **WHEN** a repo references the `acme-plans` store and the user runs | |
| `openspec context` | |
| - **THEN** the referenced store's custom artifact types are listed as read-only | |
| context | |
| - **AND** each entry includes a one-line summary and a fetch command |
🤖 Prompt for AI Agents
Verify each finding against current code. Fix only still-valid issues, skip the
rest with a brief reason, keep changes minimal, and validate.
In `@openspec/changes/initiatives-in-stores/specs/store-aware-artifacts/spec.md`
around lines 3 - 22, Clarify the `--store` discovery behavior in the store-aware
schema discovery requirement by explicitly stating whether `openspec schemas
--store acme-plans` should merge store schemas with the current repo’s own
schemas or show only the selected store’s schemas. Update the requirement text
and the “Listing a store’s schemas” scenario so the contract is unambiguous, and
align the “Referenced store schemas are visible from a repo” scenario with the
same discovery rules using the store-aware schema discovery language.
Decide Option 1 as the build: the store initiative is canonical, a same-id local one shadows it and is reported (never silently wins, never hard-blocks). Best for orgs — governance + no silent drift + velocity — and reuses schema shadowing. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
…lup + shadow precedence Build the initiatives-in-stores prototype: - openspec schemas --store <id>: store-aware schema discovery. Success keeps the bare-array agent contract; only which root it reads changes. - openspec list --initiatives [--store <id>]: lists initiatives (initiative.yaml manifest) and rolls up the live status of the changes each groups, from the same source as list --changes. - Canonical-vs-shadow precedence: a local initiative colliding with a referenced store's is reported (shadowsStore in JSON, "(shadows: <id>)" in the list), never silently overriding, never blocking local work. Keep the completion registry + store-selection guidance + agent contract in sync (schemas joins the store-aware command set), add unit tests, and flip the guide from proposed to working with real captured output. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
…gent instruction block Extend the referenced-store index so a repo that references a store sees that store's own custom artifact types (project schemas) and initiatives, each with a one-line summary and a fetch command (openspec schemas/list --initiatives --store <id>). Rendered in the <referenced_stores> instruction block and the apply section; keys are omitted when a store defines none, so existing output is unchanged. Also regenerate the skill-templates-parity golden hashes for the store-selection guidance update from the previous commit (schemas joined the store-aware set); the feedback template hash is unchanged, confirming the blast radius. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
There was a problem hiding this comment.
Actionable comments posted: 1
🤖 Prompt for all review comments with AI agents
Verify each finding against current code. Fix only still-valid issues, skip the
rest with a brief reason, keep changes minimal, and validate.
Inline comments:
In `@src/core/initiatives.ts`:
- Around line 59-75: The readManifest function currently only type-asserts
parseYaml output and silently falls back to {}, so invalid initiative.yaml
shapes (especially changes not being an array) can corrupt listInitiatives
counts without any warning. Add structural validation inside readManifest for
the parsed InitiativeManifest fields, especially changes, and treat invalid
shapes as a parse failure instead of returning a misleading object. Also emit a
warning or diagnostic on parse/validation failure, consistent with
readProjectConfig behavior, so callers can detect bad manifests before
listInitiatives iterates over changeId values.
🪄 Autofix (Beta)
Fix all unresolved CodeRabbit comments on this PR:
- Push a commit to this branch (recommended)
- Create a new PR with the fixes
ℹ️ Review info
⚙️ Run configuration
Configuration used: Path: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
Run ID: 4ce4cc06-f780-4f1b-a61c-d5f8c9950f3f
📒 Files selected for processing (12)
docs/agent-contract.mddocs/stores-beta/initiatives.mddocs/stores-beta/user-guide.mdopenspec/changes/initiatives-in-stores/tasks.mdopenspec/initiatives/smoother-setup/initiative.yamlsrc/cli/index.tssrc/commands/workflow/schemas.tssrc/core/completions/command-registry.tssrc/core/initiatives.tssrc/core/templates/workflows/store-selection.tstest/core/completions/command-registry.test.tstest/core/initiatives.test.ts
✅ Files skipped from review due to trivial changes (3)
- src/core/templates/workflows/store-selection.ts
- docs/stores-beta/initiatives.md
- openspec/changes/initiatives-in-stores/tasks.md
…spec context` Enrich available referenced-store members with the store's own custom artifact types (project schema names) and initiative ids, rendered in the human listing and carried in --json (artifactTypes/initiatives, present only when non-empty). Read-only enrichment in the context command; the working-set model and code-workspace builder are unchanged. Completes task 1.3 (both the agent instruction block and context now advertise a store's artifacts). Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
…ow works Guide's "Read by name" bullet now states the agent sees a store's artifact types and initiatives in its context (instruction block + openspec context), each with a summary and fetch command. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
Scaffold an initiative folder (initiative.yaml manifest + brief.md stub) under the existing `new` group — --store-aware and --title-aware, with a duplicate guard and --json. Deliberately thin: a folder and a manifest, not a revived initiative command group. Sync the store-selection guidance (new initiative joins the store-aware set), the completion registry, the registry test, and the skill-templates-parity golden hashes (feedback hash unchanged confirms the blast radius). Add new-initiative command tests + agent-contract entry. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
An initiative.yaml change entry may now be `{ id, store }`, so an initiative in
a planning store aggregates the live task status of changes implemented in the
code repos where they actually live. list --initiatives resolves each change
against its named store's root (or the initiative's own root for plain ids),
sums the rollup, shows a per-change breakdown with each change's home, marks a
missing change/store as not-found, and reports the distinct `stores` span.
Plain-string entries (the solo/local case) are unchanged.
Adds changeStatuses/stores to the JSON, a cross-repo breakdown in the human
output, tests (cross-repo + unregistered-store not-found), an agent-contract
update, a spec scenario, and a "solo vs across repos" section in the guide.
Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
alfred-openspec
left a comment
There was a problem hiding this comment.
Strong direction and the main store/initiative shape looks right, but I found one manifest-integrity blocker before this should merge. new initiative --title 'API: v2' writes invalid YAML, then list --initiatives silently falls back to the id because manifest parse errors are swallowed, so the scaffold needs YAML-safe serialization and/or a visible malformed-manifest diagnostic.
…single change A plan is one folder, openspec/plan/. Numbered subfolders are ordered stages; names and contents are the user's own; unnumbered entries are context. Changes point UP with one metadata line (plan: local | <store-id>) — no manifest. `openspec list --plan [--store <id>]` rolls up the stages plus every change on this machine pointing at the plan, across registered repos, with live task status. Referenced stores' plan stages surface in `openspec context` and the agent instruction block. One explore-style skill (openspec-plan, /opsx:plan) drives translation stage-to-stage and syncs status back up; it is instructed to write less, not more. Solo: plan in your repo, `plan: local`. Team: same folder in a store — the store is the parent/global level, repos are children pointing up. Replaces the manifest-based initiative surfaces from earlier in this PR. Dogfooded: this repo's own openspec/plan/ groups four real changes; the change record openspec/changes/add-plan-folder validates --strict. Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
Lead with the destination artifact (product.md, roadmap — any name or convention; one file is a valid plan) instead of the stage pipeline. list --plan now shows destination/context files first; numbered stages remain the opt-in convention for visible order and "where am I" navigation. The skill gains an explicit map-in-flight-changes move (propose plan: lines for unlinked work, with confirmation) and a where-you-are table keyed to cwd. Drop the dogfood's changes-named inventory stage (redundant with list --plan). Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
A plan with no numbered stages (just product.md) now appears in the referenced-store index and openspec context via its artifact names, so destination-first plans reach the agent the same way staged ones do. Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
The plan skill gains the two moves that complete the interpretation layer, borrowed from mattpocock/skills' to-prd / to-issues discipline: capture the conversation into the destination artifact (synthesize, don't re-interview) and decompose into tracer-bullet slices (end-to-end, demoable, grabbable without reading the rest). The change is named as the handoff artifact: born linked, self-contained, status flowing back with no bookkeeping. Dogfood follows the destination-first convention (goal.md at plan root, two optional stages) and the repo's config context: now points agents at the plan — wiring the local plan into every artifact instruction with zero code. Guide gains "The handoff" (where planning starts, where building starts). Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
Two existing features complete the story: worksets open the plan and code repos together; custom schemas are the path to typed artifacts if ever wanted. One line each — OpenSpec already had both. Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
What this is
An experiment for stores. OpenSpec and stores do the heavy lifting; this
PR adds the thinnest layer that lets them carry planning above a single
change. Everything is cheap to rename or delete — that is the point. All
output below is real.
The idea
The plan is a place, not a document type. It is one folder where
everything above a change lives — your PRD, roadmap, decisions, personas,
meeting notes — without needing to label or catalog any of it. No required
file names, no required shapes: whatever your team already writes is already
valid. A required format can be wrong for someone; a place can't.
Put in your destination. Point changes at it with one line. One command maps
the in-flight work against it, live:
Want a visible workflow? Number the folders (
00_goal/,01_requirements/)— your location then tells the agent what is upstream and what to produce
next ("what's your cwd?", not roles). Without numbers it all still works:
one file is a valid plan.
How it fits what OpenSpec already is
Work flows down (the plan decomposes into changes), truth flows up (archiving
a change updates specs), and status flows back to the plan, live. Specs stay
strict because they hold facts; the plan stays freeform because it holds
intent — the two are opposites on purpose, and the change was already the
bridge between them.
OpenSpec already does the heavy lifting
openspec/rootplan/folder convention.openspec.yaml)plan:line +--planflaglist --changesreadslist --planrollup view--storeroot selectionplan:references:,openspec context, thecontext:config fieldopenspec-planskillThe "—" rows are the story: the store is what makes this work for an org.
The store is the parent; code repos are children pointing up; going solo → org
is moving one folder into a store.
The handoff
Whoever plans starts in
/opsx:plan: talk the idea through and the skillwrites the destination artifact (it synthesizes — it doesn't re-interview
you), then decomposes into self-contained, end-to-end slices, each becoming a
change born linked. Whoever builds picks up any change and works it
normally — the plan travels along via config
context:and store references.The change is the handoff artifact; status flows back with no bookkeeping.
(The synthesize and slice disciplines are borrowed from
mattpocock/skills'
to-prd/to-issues.)Proved end-to-end
One continuous run (commands in the walkthrough below):
This repo dogfoods it too:
openspec/plan/groupsfour real changes, and the repo's
context:config points agents at the plan.CI green; the change record
add-plan-foldervalidates
--strict.Honest limits
What we want a read on
Test it out!
One folder, one line, one command, one skill — and stores carry the rest.