with one click
sdd-apply
// Use when implementing tasks from a change's tasks.md. Triggers: "apply tasks", "implement the change", "work through tasks", "start implementing", "continue implementing", "apply the change".
// Use when implementing tasks from a change's tasks.md. Triggers: "apply tasks", "implement the change", "work through tasks", "start implementing", "continue implementing", "apply the change".
[HINT] Download the complete skill directory including SKILL.md and all related files
| name | sdd-apply |
| description | Use when implementing tasks from a change's tasks.md. Triggers: "apply tasks", "implement the change", "work through tasks", "start implementing", "continue implementing", "apply the change". |
Implement tasks from SPECS_ROOT/changes/<name>/tasks.md.
Check off each task as it completes.
SPECS_ROOTis resolved by thesddrouter before this skill runs. Replace.specs/with your project's actual specs root in all paths below.
sdd-apply.If tasks.md does not exist for the active change: STOP.
"No tasks to implement. Run
sdd-proposefirst to create the change artifacts."
Do not proceed without tasks.md.
Never reference ephemeral scaffolding in any persisted artifact.
Ephemeral scaffolding includes:
Task 7.4, T12)Group 8, G3)D12, design ยง4.2)These must not appear in:
Tasks, groups, and design-section IDs are scaffolding for the current change.
Once archived, only the spec name persists โ references to ephemeral IDs become meaningless noise to future readers.
Name things after what they do, not where they came from in tasks.md or design.md.
If you catch yourself writing "D12 wiring" or "Task 7.4 implementation," restate it in terms of the behavior or component being changed.
This applies whether or not the commit-message skill is available.
When drafting a commit message during apply:
commit-message if it is loadable in this environment.type(scope): subject) that describes what changed and why, and apply the constraints above.tasks.md and implementation should begin or continuetasks.md exists โ run sdd-propose firstsdd-verify, then sdd-sync, then sdd-archive.specs/changes/<name>/tasks.md โ full task list.specs/changes/<name>/design.md โ architectural decisions to follow.specs/changes/<name>/specs/ โ delta specs for behavioral requirements.specs/specs/ โ baseline specs for full context.specs/.sdd/schema-config.yaml exists, identify tasks that define schema contracts (endpoint definitions, model schemas, DDL changes) and check that they are sequenced before any tasks that consume them in tasks.md.
Surface any ordering gaps to the user before implementing.Check tasks.md for already-completed tasks (- [x]).
Start from the first unchecked task.
If all tasks are complete:
"All tasks are already complete. Run
sdd-verifyto confirm the implementation, thensdd-syncandsdd-archive."
Stop.
For each unchecked task:
pytest with no --ignore / --deselect / -m filters).
Inner-loop iteration may use a narrower scope, but the verification you act on โ and any pass/fail count you report โ must come from a broad-scope run.
If you exclude any path, marker, or file, name the exclusion and justify it in the same message.
"Not part of this change" is not a valid justification for a class or module rewrite โ every test that imports the rewritten symbol is part of the change by definition.
If a test fails, stop and resolve the failure before proceeding to the next step.tasks.md: - [ ] โ - [x]Follow design decisions in design.md โ don't diverge without reason.
Follow behavioral requirements in delta specs โ these define what "correct" means.
Apply the Critical Constraints above to every artifact you produce โ code, comments, and commit messages alike.
If .specs/.sdd/schema-config.yaml exists and a task consumes a schema contract that is not yet defined, pause before implementing it.
Surface the dependency gap and confirm with the user whether to reorder tasks in tasks.md first.
A SHALL requirement may end up with multiple code paths that produce or modify the contract-asserted value during implementation โ not just the canonical path. Common examples: deduplication shortcuts, cache fast-paths, retry/fallback branches, idempotency early-returns, merge or composition steps that write the same fields.
When implementing a task introduces such a path for an existing SHALL:
tasks.md that exercises the contract through the new path.
The new test task must produce runnable evidence (test, schema check, or captured output) โ same standard as the original SHALL coverage rule.A test exercising only the canonical path does not stand in for evidence on a shortcut, retry, or composition path.
This rule is what sdd-verify's write-site enumeration is checking; cover it at apply time and verify has nothing to flag.
When unsure whether a path is contract-relevant, surface it to the user rather than skipping the test task silently.
Before checking off the final task (hard gate):
rg/grep for tests that import any symbol you changed and confirm they ran in step 1.
The blast-radius check is what catches tests pinned to rewritten classes or modules that a marker filter would silently skip.When the gate passes and all tasks are checked off:
"All tasks complete. Recommended next steps:
- Run
sdd-verifyto confirm implementation matches the change artifacts- Run
sdd-syncto merge delta specs into main specs- Run
sdd-archiveto complete the change"
This skill can be invoked at any point after tasks.md exists โ not only when all artifacts are complete.
design.md or delta specs before continuing.proposal.md and tasks.md.D12) โ in code, comments, commit messages, or PR descriptions (see Critical Constraints)commit-message when it is available, or without applying the Critical Constraints when it is notreferences/sdd-schema.md โ schema config format (ยง 3) and lifecycle policy (ยง 4)