ospec
Health Gecti
- License — License: MIT
- Description — Repository has a description
- Active repo — Last push 0 days ago
- Community trust — 549 GitHub stars
Code Basarisiz
- rm -rf — Recursive force deletion command in assets/hooks/claude/ospec-claude-hook.cjs
- fs module — File system access in assets/hooks/claude/ospec-claude-hook.cjs
Permissions Gecti
- Permissions — No dangerous permissions requested
Bu listing icin henuz AI raporu yok.
Spec-driven, agentic workflow framework for AI coding agents. Turn a request into a verifiable goal loop — plan, act, verify — with durable specs and evidence in your repo. Works with Claude Code, Codex, Gemini, OpenCode, and plain CLI.
OSpec.ai
The official OSpec CLI package is @clawplays/ospec-cli, and the official command is ospec. OSpec supports spec-driven development (SDD) and document-driven development for AI coding agents and CLI workflows.
Prompt Guide | Usage | Overview | Installation | External Plugins | Plugin Release | Issues
Why OSpec?
AI coding assistants are powerful, but requirements that live only in chat history are hard to inspect, review, and close out cleanly. OSpec adds a lightweight workflow layer so the repository can hold the change context before code is written and after the work ships.
- Spec-driven work, saved to your repo — OSpec turns a request into files (proposal, design, plan, tasks, reviews, verification evidence) that live in your repo instead of in chat history, so any assistant (Codex/GPT, Claude Code, Gemini, OpenCode, or plain CLI) can pick up exactly where the last one stopped.
ospec change— the everyday fast flow — one requirement becomes one active change on a shortinit -> change -> verify/finalizepath, kept lightweight and easy to review.ospec goal— engineering-grade discipline — brainstorm and lock the design before any code, split the work into a task graph, dispatch parallel sub-agents, enforce TDD and code review by a separate reviewer, and require durable test/verification evidence before anything counts as done.ospec goalruns as a loop — it plans, acts, and verifies in rounds until tests prove the work, at a safety level you choose (--level L1|L2|L3: report-only → assisted → unattended); drive it withospec loop …and surface findings to a triage inbox withospec triage ….
Install With npm
npm install -g @clawplays/ospec-cli
Official package: @clawplays/ospec-cli
Command: ospec
Verify install: ospec --help
Quick Start
OSpec only takes 3 steps:
- initialize OSpec in your project directory
- create and advance one change for a requirement, document update, or bug fix
- archive the accepted change after deployment and validation are complete
1. Initialize OSpec In Your Project Directory
Recommended prompt:
OSpec, initialize this project.
Claude / Codex skill mode:
/ospec initialize this project.
Command line
ospec init .
ospec init . --summary "Internal admin portal for operations"
ospec init . --summary "Internal admin portal for operations" --tech-stack node,react,postgres
ospec init . --architecture "Single web app with API and shared auth" --document-language en-US
CLI notes:
--summary: project overview text written into the generated docs--tech-stack: comma-separated stack list such asnode,react,postgres--architecture: short architecture description--document-language: generated doc language, choose fromen-US,zh-CN,ja-JP, orar- AI-first language resolution order: explicit language request in the conversation -> current conversation language -> persisted project language in
.skillrc - CLI language resolution order: explicit
--document-language-> persisted project language in.skillrc-> existing project docs / managedfor-ai/*guidance / asset manifest -> fallbacken-US - OSpec persists the chosen project document language in
.skillrcand reuses it forfor-aiguidance,ospec new, andospec update - new projects initialized by
ospec initdefault to the nested layout: root.skillrcandREADME.md, with OSpec-managed files under.ospec/ - plain init does not create optional knowledge maps such as
.ospec/knowledge/src/or.ospec/knowledge/tests/; those appear only when a project already has legacy knowledge content to migrate or when future explicit knowledge-generation flows create them - CLI commands still accept shorthand like
changes/active/<change-name>, but the physical path in nested projects is.ospec/changes/active/<change-name> - if you pass these values, OSpec uses them directly when generating project docs
- if you do not pass them, OSpec reuses existing docs when possible and otherwise creates placeholder docs first
2. Create And Advance A Change
Use this for requirement delivery, documentation updates, refactors, and bug fixes.
Recommended prompt:
OSpec, create and advance a change for this requirement.
Claude / Codex skill mode:
/ospec-change create and advance a change for this requirement.
/ospec-goal create and advance a full goal for this requirement.
Command line
ospec new docs-homepage-refresh .
ospec new fix-login-timeout .
ospec new update-billing-copy .
Agent Execution (Goal Workflow)
The classic change flow above stays simple: proposal.md → tasks.md → implement → verification.md → review.md, with no controller layer. The agent controller layer — parallel worker dispatch, reviewer gates, and durable evidence — belongs to the full goal workflow. Use it with ospec goal, or on a single change only when you explicitly opt into agent/worker execution. OSpec keeps the controller state in repo artifacts, and the current AI harness starts native worker agents when available.
ospec session .
ospec execute bootstrap changes/active/<goal-name>
ospec execute workspace changes/active/<goal-name>
ospec execute status changes/active/<goal-name>
ospec execute dispatch changes/active/<goal-name> --limit 2
ospec execute launch changes/active/<goal-name> --task <task-id> --target codex
ospec execute complete <task-id> changes/active/<goal-name> --status DONE --summary "..."
ospec execute review changes/active/<goal-name> --task <task-id> --stage spec
ospec execute review changes/active/<goal-name> --task <task-id> --stage quality
ospec execute verify changes/active/<goal-name> --command "npm test" --status PASSED --exit-code 0
launch writes artifacts/agents/launch-plan.md; it does not start workers by itself. Codex/GPT use spawn_agent / wait_agent / close_agent, Claude Code uses Task, Gemini uses @generalist, and OpenCode uses @mention. Use launch --run --command or orchestrate --command only when the current harness cannot start native subagents.
3. Archive After Acceptance
After the requirement has passed deployment, testing, QA, or other acceptance checks, archive the validated change.
Recommended prompt:
OSpec, archive this accepted change.
Claude / Codex skill mode:
/ospec archive this accepted change.
Command line
ospec verify changes/active/<change-name>
ospec finalize changes/active/<change-name>
Archive notes:
- run your project-specific deploy, test, and QA flow first
- use
ospec verifyto confirm the active change is ready - use
ospec finalizeto rebuild indexes and archive the accepted change - new nested projects archive under
.ospec/changes/archived/YYYY-MM/YYYY-MM-DD/<change-name>; CLI shorthand underchanges/archived/...still works - existing flat archives are reorganized by
ospec update
Goal Workflow — Full Flow & Hard Enforcement
Use ospec goal <goal-name> (or just say "OSpec, create and advance a full goal for this requirement") for complex, cross-cutting, or high-risk work that needs the full OSpec workflow: design doc, implementation plan, task graph, parallel worker dispatch, document and code review, and durable TDD / debug / verification evidence.
You only start a goal and describe the requirement. The AI runs every ospec command itself; you just answer questions in chat (Zero-Setup).
A goal runs as a session-bound loop: it plans, acts, and verifies in rounds until the work is done and proven by tests. You choose a safety level when you start it (--level L1|L2|L3, default L1):
- L1 — report only: findings go to a triage inbox, nothing is changed.
- L2 — makes changes but pauses at key decisions for your approval.
- L3 — runs unattended within an allowlist you set.
Drive and watch it with ospec loop run/watch/status/pause/resume/level, review findings with ospec triage list/claim/promote, and stop it by pausing, dropping a STOP file, or closing your session. When the harness has a native /goal (Claude, Codex) the loop uses it; otherwise it falls back automatically. ospec change stays the classic fast flow. See docs/loop-engineering.md.
Experience contracts the AI follows on every goal:
- Announce-Before-Act — the AI states which skill and stage it is in, which
ospec execute …command it is about to run and the artifact it writes, and how many subagents it dispatches — so you always see what is happening. - Brainstorm-First — before locking design it surfaces the open decisions (direction, architecture, API, data, UI, risk, scope) and asks you one at a time through the harness-native question UI (Claude Code: AskUserQuestion) instead of silently assuming.
- Durable decision gates — open choices are recorded with
ospec execute decision …; required decisions block worker dispatch until you answer.
Claude Code hard enforcement (one-time; the AI runs this for you automatically in a Claude Code harness):
ospec session hook --target claude --apply
This writes a hook bundle under .ospec/hooks/claude/ and merges it into .claude/settings.json (idempotent and reversible). The hooks:
- announce every subagent dispatch and every
ospeccommand at the tool level, - hard-block subagent dispatch while a required decision is still pending,
- re-affirm the Announce-Before-Act / Brainstorm-First contract on every turn.
Hooks load at session start, so they take effect from the next Claude Code session.
Update With npm
For an existing OSpec project, after upgrading the CLI with npm, run this in the project directory to refresh the project's OSpec files:
ospec update
ospec update also migrates legacy root-level build-index-auto.cjs / build-index-auto.js tooling into .ospec/tools/build-index-auto.cjs and refreshes OSpec-managed hook entrypoints to use the new location.
It also repairs older OSpec projects that still have an OSpec footprint but are missing newer core runtime directories, refreshes managed skills and archive layout metadata, and syncs project assets for already-enabled plugins.
For nested projects that still carry legacy knowledge under .ospec/src/ or .ospec/tests/, ospec update migrates those paths into .ospec/knowledge/src/ and .ospec/knowledge/tests/.
When an already-enabled plugin has a newer compatible npm package version available, ospec update upgrades that global plugin package automatically and prints the version transition.
It does not upgrade the CLI itself, and it does not enable plugins or migrate active / queued changes automatically.
It also does not switch a classic project layout to nested automatically.
If you want to convert an older classic project to the new layout, run ospec layout migrate --to nested explicitly.
How The OSpec Workflow Works
┌─────────────────────────────────────────────────────────────────┐
│ 1. USER REQUEST │
│ "OSpec, create and advance a change for this task." │
└─────────────────────────────────────────────────────────────────┘
│
▼
┌─────────────────────────────────────────────────────────────────┐
│ 2. INIT TO CHANGE-READY │
│ ospec init │
│ - .skillrc │
│ - README.md │
│ - .ospec/ │
│ - .ospec/changes/active + .ospec/changes/archived │
│ - .ospec/SKILL.md + .ospec/SKILL.index.json + .ospec/for-ai│
│ - .ospec/docs/project/* baseline knowledge docs │
│ - reuse docs or fall back to placeholders │
└─────────────────────────────────────────────────────────────────┘
│
▼
┌─────────────────────────────────────────────────────────────────┐
│ 3. EXECUTION │
│ ospec new <change-name> # classic fast change │
│ ospec goal <goal-name> # full goal workflow │
│ ospec brainstorm / plan (optional pre-change aids) │
│ ospec session │
│ ospec session hook │
│ ospec progress │
│ ospec execute bootstrap / handoff / doc-review / status │
│ ospec execute next │
│ ospec execute workspace / worktree / worktree --create │
│ ospec execute worktree --cleanup / finish │
│ ospec execute dispatch / launch / collect / retry / review │
│ ospec execute debug │
│ ospec execute tdd │
│ ospec execute verify │
│ ospec execute sync │
└─────────────────────────────────────────────────────────────────┘
│
▼
┌─────────────────────────────────────────────────────────────────┐
│ 4. DEPLOY + VALIDATE │
│ project deploy / test / QA │
│ ospec verify │
└─────────────────────────────────────────────────────────────────┘
│
▼
┌─────────────────────────────────────────────────────────────────┐
│ 5. ARCHIVE │
│ ospec finalize │
│ rebuild index + archive │
└─────────────────────────────────────────────────────────────────┘
Core Concepts
| Concept | What It Means |
|---|---|
| Protocol Shell | The minimum collaboration skeleton: root .skillrc and README.md, plus managed OSpec files under .ospec/ for change state, SKILL docs, index state, for-ai/ guidance, and project docs. |
| Project Knowledge Layer | Explicit project context such as docs/project/*, layered skill files, and index state that AI can read consistently. |
| Active Change | A dedicated execution container for one small or routine requirement, using the classic fast files: proposal.md, tasks.md, state.json, verification.md, and review.md, plus plugin artifacts when activated. |
| Active Goal | A full-workflow execution container created with ospec goal, adding design.md, implementation-plan.md, artifacts/agents/task-graph.json, handoff artifacts, document-review artifacts, launch-plan artifacts, worker-run artifacts, reviewer-run artifacts, retry artifacts, review artifacts, artifacts/agents/worker-status.md, and evidence artifacts. |
Features
- Change-ready initialization:
ospec initcreates the protocol shell and baseline project knowledge docs in one pass. - Guided initialization: AI-assisted init can ask once for missing summary or tech stack; direct CLI init falls back to placeholder docs when context is missing.
- Stable project language: the chosen document language is stored in
.skillrcso later guidance and generated change docs stay consistent unless you explicitly change it. - Docs maintenance:
ospec docs generaterefreshes or repairs project knowledge docs when you need it later. - Tracked requirement execution: small changes keep proposal, tasks, state, verification, and review files aligned; full goals also keep design, implementation plan, task graph, handoff, review, worker status, and evidence artifacts aligned.
- Goal experience contracts: every goal runs with
Announce-Before-Act(the AI announces its skill and stage, theospec execute …command and the artifact it writes, and each subagent dispatch),Brainstorm-First(open direction, architecture, API, UI, risk, and scope decisions are asked one at a time through the native question UI before design is locked), andZero-Setup(you only start a goal and describe the requirement — the AI runs everyospeccommand itself). In Claude Code,ospec session hook --target claude --applyadds hooks that announce every dispatch and hard-block subagent dispatch while a required decision is still pending. - Optional pre-change aids:
ospec brainstormwrites durable exploration artifacts under.ospec/brainstorms/, with an optional static visual companion;ospec planwrites plan drafts under.ospec/plans/and only updatesimplementation-plan.mdwhen--applyis passed. The default small-change flow starts withospec new; the full workflow starts withospec goal. - Session brief and hooks:
ospec sessionwrites.ospec/session-brief.jsonand.ospec/session-brief.mdso agents or humans entering an existing project can see active changes, queued changes, queue-run state, a cache fingerprint, and the next safe command before touching a change;ospec session hook --target claudewrites opt-in harness startup artifacts plus a Claude Code hook bundle under.ospec/hooks/, and--applyidempotently merges it into.claude/settings.json. - Task graph controller:
ospec execute bootstrapwrites a one-change startup/resume snapshot with the project session brief snapshot and next safe action;handoffwrites a cross-tool worker handoff guide with the project session brief snapshot;doc-reviewcreates design and implementation-plan reviewer packets before task execution;statusandnextreport controller state and safe next task candidates;workspacerecords git workspace safety before worker handoff;worktreerecords an isolated-worktree preparation plan by default, while explicit--createor--cleanupruns the matching git worktree command and capturesartifacts/agents/worktree-runs/;finishrecords closeout readiness before finalize, archive, push, merge, or worktree cleanup;dispatchandcompletecreate parallel-safe worker packets with worker profiles and target tool mapping, then record task results as OSpec artifacts;review --taskcreates per-task spec and quality review packets that block dependent tasks until approved, while finalreviewcreates whole-change reviewer packets;launchwrites the native agent launch plan for the current AI harness, including Codex/GPTspawn_agent, Claude Code Task, Gemini@generalist, and OpenCode@mentionguidance;orchestrateis the final CLI fallback for harnesses without native subagents and runs explicit command templates only;launch --run --commandis the single-worker CLI fallback;collectturns a fallback worker run into task completion state;retryreopens blocked, needs-context, or failed task work; explicit review--run --commandcapturesartifacts/agents/review-runs/;debug,tdd, andverifyrecord durable evidence;syncrebuildsworker-status.mdfrom execution and review artifacts. - Queue helpers:
queueandrunsupport explicit multi-change execution when one active change is not enough. - Plugin workflow gates: plugin commands support Stitch design review and Checkpoint automation through npm-installed official plugins.
- Skill management: install and inspect OSpec skills for Codex and Claude Code.
- Standard closeout:
finalizeverifies, rebuilds indexes, and archives the change before manual Git commit.
Plugin Installation
OSpec supports plugins for UI review and runtime validation.
Keep the public flow simple:
/ospec open Stitch for this project.
/ospec open Checkpoint for this project.
In AI / /ospec flows, requests like "open Stitch" or "open Checkpoint" should be handled as: check whether the plugin is already installed globally, install only when missing, then enable it in the current project.
Command line fallback:
ospec plugins list
ospec plugins install stitch
ospec plugins enable stitch .
ospec plugins install checkpoint
ospec plugins enable checkpoint . --base-url http://127.0.0.1:3000
Official npm plugin packages:
@clawplays/ospec-plugin-stitch@clawplays/ospec-plugin-checkpoint
After a plugin is enabled, its detailed setup docs are synced into .ospec/plugins/<plugin>/docs/.
Maintainers can find plugin publishing and automation details in docs/plugin-release.md.
Documentation
Core Docs
- Prompt Guide
- Usage
- Project Overview
- Installation
- Skills Installation
- External Plugins
- Plugin Release
Repository Structure
dist/ Compiled CLI runtime
assets/ Managed protocol assets, hooks, and skill payloads
docs/ Public documentation
scripts/ Release and installation helpers
.ospec/templates/hooks/ Hook templates shipped with the package
License
This project is licensed under the MIT License.
Yorumlar (0)
Yorum birakmak icin giris yap.
Yorum birakSonuc bulunamadi