setup-pre-commit▌
mattpocock/skills · updated Apr 8, 2026
Check for package-lock.json (npm), pnpm-lock.yaml (pnpm), yarn.lock (yarn), bun.lockb (bun). Use whichever is present. Default to npm if unclear.
Setup Pre-Commit Hooks
What This Sets Up
- Husky pre-commit hook
- lint-staged running Prettier on all staged files
- Prettier config (if missing)
- typecheck and test scripts in the pre-commit hook
Steps
1. Detect package manager
Check for package-lock.json (npm), pnpm-lock.yaml (pnpm), yarn.lock (yarn), bun.lockb (bun). Use whichever is present. Default to npm if unclear.
2. Install dependencies
Install as devDependencies:
husky lint-staged prettier
3. Initialize Husky
npx husky init
This creates .husky/ dir and adds prepare: "husky" to package.json.
4. Create .husky/pre-commit
Write this file (no shebang needed for Husky v9+):
npx lint-staged
npm run typecheck
npm run test
Adapt: Replace npm with detected package manager. If repo has no typecheck or test script in package.json, omit those lines and tell the user.
5. Create .lintstagedrc
{
"*": "prettier --ignore-unknown --write"
}
6. Create .prettierrc (if missing)
Only create if no Prettier config exists. Use these defaults:
{
"useTabs": false,
"tabWidth": 2,
"printWidth": 80,
"singleQuote": false,
"trailingComma": "es5",
"semi": true,
"arrowParens": "always"
}
7. Verify
-
.husky/pre-commitexists and is executable -
.lintstagedrcexists -
preparescript in package.json is"husky" -
prettierconfig exists - Run
npx lint-stagedto verify it works
8. Commit
Stage all changed/created files and commit with message: Add pre-commit hooks (husky + lint-staged + prettier)
This will run through the new pre-commit hooks — a good smoke test that everything works.
Notes
- Husky v9+ doesn't need shebangs in hook files
prettier --ignore-unknownskips files Prettier can't parse (images, etc.)- The pre-commit runs lint-staged first (fast, staged-only), then full typecheck and tests
Ratings
4.8★★★★★45 reviews- ★★★★★Aarav Farah· Dec 16, 2024
setup-pre-commit reduced setup friction for our internal harness; good balance of opinion and flexibility.
- ★★★★★Dev Bhatia· Dec 16, 2024
Keeps context tight: setup-pre-commit is the kind of skill you can hand to a new teammate without a long onboarding doc.
- ★★★★★Pratham Ware· Dec 4, 2024
setup-pre-commit is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.
- ★★★★★Valentina Nasser· Dec 4, 2024
I recommend setup-pre-commit for anyone iterating fast on agent tooling; clear intent and a small, reviewable surface area.
- ★★★★★Hassan Desai· Nov 23, 2024
setup-pre-commit fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.
- ★★★★★Dev Ghosh· Nov 19, 2024
Useful defaults in setup-pre-commit — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.
- ★★★★★Dev Chawla· Nov 7, 2024
Registry listing for setup-pre-commit matched our evaluation — installs cleanly and behaves as described in the markdown.
- ★★★★★Mei Yang· Nov 7, 2024
We added setup-pre-commit from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.
- ★★★★★Yusuf Brown· Oct 26, 2024
setup-pre-commit fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.
- ★★★★★Mei Ramirez· Oct 26, 2024
Solid pick for teams standardizing on skills: setup-pre-commit is focused, and the summary matches what you get after install.
showing 1-10 of 45