Gsd-skill-creator batch-rewrite-pattern
Cascade the same edit pattern across N files safely. Use when applying the same refactor to multiple files (e.g. swap import paths across 11 scripts, rename a symbol, migrate a call signature). Detects the common-shape-across-files situation and turns an N-file cascade into a planned audit → apply → verify workflow instead of N sequential manual edits.
git clone https://github.com/Tibsfox/gsd-skill-creator
T=$(mktemp -d) && git clone --depth=1 https://github.com/Tibsfox/gsd-skill-creator "$T" && mkdir -p ~/.claude/skills && cp -r "$T/project-claude/skills/batch-rewrite-pattern" ~/.claude/skills/tibsfox-gsd-skill-creator-batch-rewrite-pattern-b573b1 && rm -rf "$T"
project-claude/skills/batch-rewrite-pattern/SKILL.mdBatch Rewrite Pattern
When the same edit needs to land in N files, the worst shape is N sequential manual passes. Each pass collects its own errors; the hook system retriggers; context fills with repetitive diffs. This skill captures the better shape.
Triggers
Activate when any of these apply:
- Renaming a symbol across the tree
- Migrating a function signature (add/remove/reorder args)
- Swapping an import path across modules
- Converting between two patterns (callbacks ↔ promises, v1 ↔ v2 API)
- Any edit where you can describe the transformation as "in every file matching pattern X, replace Y with Z"
Typical count trigger: ≥ 4 files warrant the batch shape.
Workflow
-
Characterize the transformation in one paragraph:
- What's the before pattern? (regex or literal)
- What's the after pattern?
- Are there variants? (single pattern vs family of patterns)
- Any files that should be exempt?
-
Enumerate candidates with Grep/Glob:
Grep pattern=BEFORE output=files_with_matches -
Dry-run the rewrite against 1-2 candidates first. Verify:
- The transformation is correct
- Surrounding context isn't disturbed
- No collateral damage
-
Apply in a batch — prefer a single Bash
/sed
invocation or a small rewrite script over N sequential Edit calls:perlfor f in $(grep -l 'BEFORE' src/**/*.ts); do sed -i -e 's/BEFORE/AFTER/g' "$f" doneOr write a one-shot node script that reads each file, applies the transformation, writes back.
-
Verify with the test suite if one exists, or with a grep that the after-pattern is uniformly present and the before-pattern is gone.
-
Single commit covering the whole cascade, scope line listing files.
Anti-patterns to avoid
- Sequential manual Edit calls when the transformation is deterministic. Each Edit triggers hook re-reads and bloats context.
- Partial cascades — leaving some files on the old pattern because you got
interrupted halfway. Either all or none; use
to revert if the cascade was wrong.git stash - Branching transformations without a plan — when "most files" follow one pattern but a few need a variant, enumerate the variants first and handle each as its own batch.
Example — Config Adapter Cascade (v1.49 release-history work)
Situation: 11 scripts in
tools/release-history/ each had a direct
pg.Client instantiation and hardcoded paths. Needed to convert all 11 to use
loadConfig() + openDb(cfg).
Right shape:
- Wrote the adapter (
) oncedb.mjs - Characterized the transform: replace
block withnew pg.Client({...})
; replace hardcoded paths withawait openDb(cfg)cfg.*_abs - Applied to each file in one Bash loop or parallel sed invocation
- One commit
Wrong shape (what actually happened): 11 sequential Read-plus-Edit cycles, 35+ read-before-edit hook fires, recursive pattern-matching at each step.
The lesson: when you feel yourself about to do the same edit for the fourth time, stop and batch the rest.
Companion Tools
withGrep
to enumerate candidatesoutput_mode: files_with_matches
withBash
or a small rewrite script for the cascadesed -i
again to verify the before-pattern is gone and after-pattern is uniformly presentGrep
Related
— safe bulk file operationsfile-operation-patterns
— use when the batch is irreversibledecision-framework-invoker