openspec-ff-change
npx machina-cli add skill azzgo/agent-skills/openspec-ff-change --openclawFast-forward through artifact creation - generate everything needed to start implementation in one go.
Input: The user's request should include a change name (kebab-case) OR a description of what they want to build.
Steps
-
If no clear input provided, ask what they want to build
Use the AskUserQuestion tool (open-ended, no preset options) to ask:
"What change do you want to work on? Describe what you want to build or fix."
From their description, derive a kebab-case name (e.g., "add user authentication" →
add-user-auth).IMPORTANT: Do NOT proceed without understanding what the user wants to build.
-
Create the change directory
openspec new change "<name>"This creates a scaffolded change at
openspec/changes/<name>/. -
Get the artifact build order
openspec status --change "<name>" --jsonParse the JSON to get:
applyRequires: array of artifact IDs needed before implementation (e.g.,["tasks"])artifacts: list of all artifacts with their status and dependencies
-
Create artifacts in sequence until apply-ready
Use the TodoWrite tool to track progress through the artifacts.
Loop through artifacts in dependency order (artifacts with no pending dependencies first):
a. For each artifact that is
ready(dependencies satisfied):- Get instructions:
openspec instructions <artifact-id> --change "<name>" --json - The instructions JSON includes:
context: Project background (constraints for you - do NOT include in output)rules: Artifact-specific rules (constraints for you - do NOT include in output)template: The structure to use for your output fileinstruction: Schema-specific guidance for this artifact typeoutputPath: Where to write the artifactdependencies: Completed artifacts to read for context
- Read any completed dependency files for context
- Create the artifact file using
templateas the structure - Apply
contextandrulesas constraints - but do NOT copy them into the file - Show brief progress: "✓ Created <artifact-id>"
b. Continue until all
applyRequiresartifacts are complete- After creating each artifact, re-run
openspec status --change "<name>" --json - Check if every artifact ID in
applyRequireshasstatus: "done"in the artifacts array - Stop when all
applyRequiresartifacts are done
c. If an artifact requires user input (unclear context):
- Use AskUserQuestion tool to clarify
- Then continue with creation
- Get instructions:
-
Show final status
openspec status --change "<name>"
Output
After completing all artifacts, summarize:
- Change name and location
- List of artifacts created with brief descriptions
- What's ready: "All artifacts created! Ready for implementation."
- Prompt: "Run
/opsx-applyor ask me to implement to start working on the tasks."
Artifact Creation Guidelines
- Follow the
instructionfield fromopenspec instructionsfor each artifact type - The schema defines what each artifact should contain - follow it
- Read dependency artifacts for context before creating new ones
- Use
templateas the structure for your output file - fill in its sections - IMPORTANT:
contextandrulesare constraints for YOU, not content for the file- Do NOT copy
<context>,<rules>,<project_context>blocks into the artifact - These guide what you write, but should never appear in the output
- Do NOT copy
Guardrails
- Create ALL artifacts needed for implementation (as defined by schema's
apply.requires) - Always read dependency artifacts before creating a new one
- If context is critically unclear, ask the user - but prefer making reasonable decisions to keep momentum
- If a change with that name already exists, suggest continuing that change instead
- Verify each artifact file exists after writing before proceeding to next
Source
git clone https://github.com/azzgo/agent-skills/blob/main/.opencode/skills/openspec-ff-change/SKILL.mdView on GitHub Overview
Automates the quick creation of all OpenSpec artifacts for an implementation change. It derives a kebab-case name from your description, scaffolds the change, and builds artifacts in dependency order using the openspec CLI. The process uses templates and constraints to generate ready-to-implement files without manual step-by-step creation.
How This Skill Works
You describe the change, and the system derives a kebab-case name. It creates the change with openspec new change, then reads the build order via openspec status --change "<name>" --json. Artifacts are created in dependency order; for each ready artifact, it fetches openspec instructions, reads completed dependencies for context, renders the output from the provided template, applies contextual constraints (without copying them into files), and reports progress. It loops until all applyRequires artifacts are done, prompting for input only when necessary, and finishes by showing the final status with a summary.
When to Use It
- You want to bootstrap an entire change quickly without creating each artifact manually.
- You have a well-defined change and need dependencies resolved in the correct order.
- You want to generate all necessary artifacts for implementation and move faster to coding.
- You aim to have all artifacts ready for a quick handoff to implementation teams.
- You need to re-create a change after a design revision and prefer automated artifact generation.
Quick Start
- Step 1: Provide a clear description of what you want to build so the system can derive a kebab-case name.
- Step 2: Scaffold and begin artifact generation with: openspec new change "<name>"
- Step 3: Monitor progress with: openspec status --change "<name>" and complete the flow; then run openspec status --change "<name>" to verify final state
Best Practices
- Provide a clear, descriptive change description to derive an accurate kebab-case name.
- Review the generated artifact list and the applyRequires dependencies before implementation.
- Ensure the OpenSpec CLI is installed and accessible in your environment.
- After each artifact, re-run status to confirm remaining dependencies are satisfied.
- If any artifact requires user input, use AskUserQuestion to clarify before proceeding.
Example Use Cases
- add-user-authentication: bootstrap all artifacts to implement a new authentication flow.
- update-payment-workflow: generate artifacts for a revised checkout and payment path.
- improve-logging-and-monitoring: scaffold artifacts to enhance observability across services.
- refactor-database-schema: create artifacts to apply a schema change with dependencies.
- optimize-api-rate-limits: produce artifacts to adjust throttling and usage policies.