389ac2e460
Apply the no-ai-slop standard (now binding in AGENTS.md): the em-dash character is banned outright (restructured, not blind-replaced), plus the banned word/phrase list (delve, leverage, robust, seamless, truly, unlock, etc.). 0 em-dashes remain in modules + capstone; the only "robust" left is the planted M10 ai-change.patch trap. Module H1 titles use a colon separator. All deliberate teaching devices preserved; labs compile/parse (py/sh/yaml/json); no junk. AGENTS.md updated with the hard no-slop rules. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com> Claude-Session: https://claude.ai/code/session_01TfzV5QvtPDz8LJS3Pu5VLT
2.7 KiB
2.7 KiB
Skill: Safe scoped change
A safe-change playbook (a Module 21 skill) for modifying a codebase you don't fully understand.
Use it only after map-this-repo has produced an architecture summary. The whole bet of this
skill is: small, scoped, tested, reviewable, never a sweeping rewrite.
When to use
When making a concrete change to an unfamiliar repo.
Rules
- One change, one branch. Create a branch first (Module 6). Never work on the default branch.
- Smallest diff that solves it. Touch the fewest files possible. If the change wants to sprawl, stop and re-scope; sprawl in code you don't understand is how you break things invisibly.
- No drive-by edits. Do not reformat, rename, or "clean up" unrelated code. Those bury the real change and make the diff unreviewable (Module 10).
- Match local conventions. Mirror the surrounding code's style, naming, and patterns, not your own defaults.
- Tests are the contract. A change isn't done until it's covered (Module 13) and the existing suite still passes.
Steps
- State the change in one sentence and the acceptance criterion ("done when X").
- Find the blast radius first: search for every caller/usage of what you're about to touch. List them. If you can't enumerate them, you're not ready to change it.
- Install the project's dependencies, then run the existing tests before touching anything; establish a green baseline. Tell two failures apart: if the suite errors with missing imports, "no module named …", or "no tests ran," that's an unconfigured environment, not a baseline. Finish the documented install (and pick a different repo if it still won't go green on a clean clone). A genuine pre-existing failure (install succeeded, but a real test fails) is the other case: note it so it doesn't get blamed on you, and don't build on top of it.
- Make the minimal edit. Keep it to the files identified in step 2.
- Add or extend a test that fails without your change and passes with it.
- Run the full suite. All green, including the baseline tests.
- Self-review the diff as if reviewing someone else's PR (Module 10): is every changed line necessary and explained? Revert anything that isn't.
- Write the PR description: what changed, why, blast radius, how it was tested, what you did NOT touch and why.
Stop conditions (escalate to a human instead of pushing on)
- The change requires touching more than ~3 files or a "core" file from the architecture summary.
- You can't enumerate the callers of what you're changing.
- A test you don't understand starts failing.
- The fix needs a design decision the existing code doesn't settle.