← ClaudeAtlas

configuring-git-hygienelisted

Configure safe git workflow hygiene: pre-commit/pre-push hooks, Gitleaks secret scanning, .gitignore rules, local git config, and guardrails. Use when setting up git hooks, gitleaks/git leaks, staged pre-commit checks, pre-push validation, core.hooksPath, .gitignore, or git config best practices. NOT for creating commits (use committing-code), cleaning branches/worktrees (use cleanup-git), or creating worktrees (use using-git-worktrees).
alexei-led/cc-thingz · ★ 33 · Code & Development · score 81
Install: claude install-skill alexei-led/cc-thingz
# Configure Git Hygiene Set up project-local git hygiene. Keep hooks fast enough to stay enabled. Do not overwrite hooks, change global config, remove tracked files, or install tools without user approval. ## Scope Use this skill for: - Git hook setup or migration to a project hooks directory. - Staged-file pre-commit checks. - Full pre-push validation. - Gitleaks secret scanning. - `.gitignore` rules and tracked-file cleanup. - Local git config such as `core.hooksPath`, `includeIf`, signing, pull behavior, and pruning. Do not use this skill for: - Commit grouping or commit messages — use `committing-code`. - Worktree creation — use `using-git-worktrees`. - Branch/worktree cleanup — use `cleanup-git`. ## Step 1: Inspect Current State Run read-only checks first: ```bash git rev-parse --show-toplevel git status --short git config --show-origin --get core.hooksPath || true git config --show-origin --list | rg '^(file:.*\s+)?(user\.|commit\.|tag\.|pull\.|fetch\.|rerere\.|core\.hooksPath|includeIf\.)' || true git ls-files .gitignore .pre-commit-config.yaml .gitleaks.toml 2>/dev/null || true ls -la .git/hooks .githooks scripts/git-hooks 2>/dev/null || true ``` If a hook framework already exists, extend it. Do not replace it. ## Step 2: Load Focused References - Hook files or `core.hooksPath` changes: read [hooks.md](references/hooks.md). - Gitleaks setup or secret scanning: read [gitleaks.md](references/gitleaks.md). - `.gitignore` or `git rm --cached`: read [gitignore.