Productivity

setup-pre-commit

mattpocock/skills · updated Apr 8, 2026

$npx skills add https://github.com/mattpocock/skills --skill setup-pre-commit
summary

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.

skill.md

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-commit exists and is executable
  • .lintstagedrc exists
  • prepare script in package.json is "husky"
  • prettier config exists
  • Run npx lint-staged to 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-unknown skips files Prettier can't parse (images, etc.)
  • The pre-commit runs lint-staged first (fast, staged-only), then full typecheck and tests
general reviews

Ratings

4.845 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

1 / 5