Get the FREE Ultimate OpenClaw Setup Guide →

openspec-ff-change

npx machina-cli add skill azzgo/agent-skills/openspec-ff-change --openclaw
Files (1)
SKILL.md
4.4 KB

Fast-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

  1. 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.

  2. Create the change directory

    openspec new change "<name>"
    

    This creates a scaffolded change at openspec/changes/<name>/.

  3. Get the artifact build order

    openspec status --change "<name>" --json
    

    Parse 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
  4. 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 file
      • instruction: Schema-specific guidance for this artifact type
      • outputPath: Where to write the artifact
      • dependencies: Completed artifacts to read for context
    • Read any completed dependency files for context
    • Create the artifact file using template as the structure
    • Apply context and rules as constraints - but do NOT copy them into the file
    • Show brief progress: "✓ Created <artifact-id>"

    b. Continue until all applyRequires artifacts are complete

    • After creating each artifact, re-run openspec status --change "<name>" --json
    • Check if every artifact ID in applyRequires has status: "done" in the artifacts array
    • Stop when all applyRequires artifacts are done

    c. If an artifact requires user input (unclear context):

    • Use AskUserQuestion tool to clarify
    • Then continue with creation
  5. 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-apply or ask me to implement to start working on the tasks."

Artifact Creation Guidelines

  • Follow the instruction field from openspec instructions for each artifact type
  • The schema defines what each artifact should contain - follow it
  • Read dependency artifacts for context before creating new ones
  • Use template as the structure for your output file - fill in its sections
  • IMPORTANT: context and rules are 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

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

  1. Step 1: Provide a clear description of what you want to build so the system can derive a kebab-case name.
  2. Step 2: Scaffold and begin artifact generation with: openspec new change "<name>"
  3. 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.

Frequently Asked Questions

Add this skill to your agents
Sponsor this space

Reach thousands of developers