Agent skill

git-safe-workflow

Safely inspect, stage, commit, and (only if asked) push changes made by an AI agent. Use for commit/push requests, end-of-task checkpoints, merge conflict resolution, worktree safety checks, or deciding whether to use git commit --amend.

Stars 37
Forks 4

Install this agent skill to your Project

npx add-skill https://github.com/regenrek/agent-skills/tree/main/skills/git-safe-workflow

SKILL.md

Git Safe Workflow

Core rules (always)

  1. Collect repo context first (non-destructive):

    • git rev-parse --show-toplevel
    • git status --porcelain=v1 -b
    • git log -1 --oneline
  2. Collect worktree context when relevant (also non-destructive):

    • git branch --show-current
    • git worktree list --porcelain

    Run worktree context when:

    • branch name is unexpected
    • you are in a nested folder and not sure which checkout you are in
    • Git refuses checkout because branch is already checked out elsewhere
    • status shows detached HEAD or unusual metadata
  3. Never run destructive or high-risk commands unless explicitly requested:

    • Do NOT use:
      • git reset --hard
      • git clean -fd
      • git push --force or --force-with-lease
      • git worktree prune
      • git worktree remove
      • git rebase (interactive or not) unless explicitly requested
    • If the user requests one:
      • restate the exact command you plan to run
      • explain why it is risky
      • then proceed
  4. Avoid interactive prompts and editors unless the user says it is OK:

    • Prefer non-interactive commands
    • Avoid:
      • git add -p
      • editor-based rebase
      • commit message editor prompts
    • Prefer:
      • git commit -m "..." -m "..."

Worktree safety rules

  1. Confirm you are in the intended worktree and branch before staging or committing:

    • git branch --show-current
    • git worktree list --porcelain
  2. Detached HEAD safety:

    • If 'git branch --show-current' prints nothing, you are likely in detached HEAD.
    • Default behavior: do not commit immediately.
    • Explain the situation and ask whether to create a branch first, for example:
      • git switch -c
    • Only commit in detached HEAD if the user explicitly wants that and understands the risk.
  3. Branch checked out in another worktree:

    • If Git refuses because the branch is already checked out elsewhere, do not use force by default.
    • Safe options:
      • switch that other worktree to a different branch, or
      • create a new branch for this worktree (recommended)
  4. Worktree lifecycle operations:

    • Do not run these unless explicitly requested:
      • git worktree add
      • git worktree remove
      • git worktree move
      • git worktree lock or unlock
      • git worktree prune

Make a checkpoint commit (default)

1) Summarize the change

  • git diff --stat
  • git diff --staged --stat (if anything is staged)

2) Inspect details when needed

  • git diff
  • git diff --staged

Guidance:

  • Always inspect full diff if changes are large, touch security-sensitive code, or involve config or CI.

3) Stage changes safely

Prefer explicit paths when practical:

  • git add path/to/file1 path/to/file2

Otherwise stage tracked modifications and deletions:

  • git add -u

Avoid staging everything blindly unless user explicitly wants it:

  • avoid: git add .

4) Commit message

Use Conventional Commits when reasonable:

  • type(scope): summary

Include:

  • what behavior changed
  • tests run, or explicitly note: tests not run

5) Commit (non-interactive)

  • git commit -m "type(scope): summary" -m "Details... Tests: "

6) Verify

  • git status
  • git show --stat --oneline HEAD

Amend policy (git commit --amend)

Default rule

  • Do not use 'git commit --amend' unless it clearly improves the most recent commit AND the commit has not been pushed.

Safe uses

Use amend when:

  • You just made the last commit locally and immediately noticed:
    • you forgot a file
    • you need a tiny fix
    • the commit message is wrong

Common safe commands:

  • Add changes then amend without changing message:
    • git commit --amend --no-edit
  • Replace message non-interactively:
    • git commit --amend -m "type(scope): summary" -m "Details... Tests: ..."

Avoid

Do not amend when:

  • the commit is already pushed to a shared remote branch
  • amending would require a force push to reconcile the remote

In that case:

  • prefer a new follow-up commit
  • only rewrite history if the user explicitly requests it and accepts the risk

Merge conflicts

  1. Collect context:

    • git status --porcelain=v1 -b
  2. Identify conflicted files:

    • git diff --name-only --diff-filter=U
  3. Resolve conflicts carefully (no automation that discards intent).

    • After resolving:
      • git add
  4. Continue the operation:

    • If merge:
      • git commit -m "merge: resolve conflicts" -m "Details... Tests: ..."
    • If rebase was explicitly requested and is in progress:
      • git rebase --continue
  5. Verify:

    • git status
    • git show --stat --oneline HEAD (if a commit was created)

Push policy

  • Only push if the user explicitly asks.
  • Preferred push:
    • git push -u origin HEAD

Main or master branch rule

  • If currently on main or master, do not push directly by default.
  • Create a branch first (ask user for branch name if not provided), then push that branch.

Force push rule

  • Never force push unless explicitly requested.
  • If requested:
    • restate the exact force push command
    • explain risk (rewriting shared history)
    • then proceed

Expand your agent's capabilities with these related and highly-rated skills.

regenrek/agent-skills

shadcn-vite-iconify-landing-page

Build, critique, and iterate high-converting marketing or product landing pages using React + Vite + TypeScript + Tailwind and shadcn/ui components, with all icons sourced from Iconify. Use when the user asks for a landing page, sales page, signup page, CRO improvements, above-the-fold vs below-the-fold structure, hero + CTA copy, section order, or wants production-ready shadcn + Vite code.

37 4
Explore
regenrek/agent-skills

security-leak-guardrails

Sets up secret-leak prevention guardrails with forbidden path checks, gitleaks config, CI secret scanning, and dependency updates. Use when hardening repos against credential leaks or when adding gitleaks, trufflehog, git hooks, or security checks.

37 4
Explore
regenrek/agent-skills

homebrew-publish

Publish CLIs/TUIs to Homebrew via a personal tap. Use when asked to create or manage a Homebrew tap repo, generate or update formulae, compute sha256, test installs, or ship new releases for Go, Rust, Node/TypeScript, Python, or prebuilt binaries.

37 4
Explore
regenrek/agent-skills

architecture-ownership

Determine runtime owner, first-fix layer, and canonical long-term module or package owner in layered codebases. Use when placing code across UI vs platform shell vs runtime orchestration vs domain or application vs shared core vs adapter or integration layers, debugging ownership issues, removing duplicate policy paths, or answering "where should this live?" architecture questions.

37 4
Explore
regenrek/agent-skills

codex-analysis

Run Codex CLI for deep code analysis and second-opinion reviews. Use when the user explicitly asks for Codex analysis, Codex help, or wants a second opinion from Codex on code, architecture, or debugging questions.

37 4
Explore
regenrek/agent-skills

go-local-health

Run local Go health checks (tests, coverage, lint) in Go repositories that contain go.mod/go.sum. Use when the user asks to run or interpret local Go test/coverage/lint workflows using tools like lazygotest, gocovsh, tparse, and golangci-lint. Do not use for Rust or non-Go projects.

37 4
Explore

Didn't find tool you were looking for?

Be as detailed as possible for better results