commit-jira
4
总安装量
4
周安装量
#52904
全站排名
安装命令
npx skills add https://github.com/bohdan-shulha/skills --skill commit-jira
Agent 安装分布
amp
4
github-copilot
4
codex
4
kimi-cli
4
gemini-cli
4
cursor
4
Skill 文档
Commit Jira
Overview
Create safe, structured commits with deterministic checks and consistent message quality. Run a guard before staging, then commit using a required JIRA-style subject and required body bullets.
Path Resolution (Mandatory)
- Resolve any relative path in this skill from this skill directory, not from the caller’s current working directory.
- For this skill, set
skill_dirto the directory that contains this file (commit-jira/SKILL.md), then useskill_dir/scripts/precommit_guard.py. - Do not search for
scripts/precommit_guard.pyat repo root.
Workflow
- Run safety guard:
python3 <skill_dir>/scripts/precommit_guard.py
- Abort immediately if the guard exits non-zero.
- Do not run
git addorgit commitwhen blocked.
- Do not run
- Stage all changes only after guard passes:
git add . -A
- Review staged changes:
git diff --cached --name-onlygit diff --cached --stat
- Ensure the user provided a ticket number (example:
JIRA-123).- If missing, stop and ask the user for the ticket number.
- Compose commit subject and body using the format rules below.
- Execute commit:
git commit -m "<subject>" -m "<body>"
Safety Guard Rules
Abort when any path matches one of these conditions:
- Log-like files:
*.log,*.out,*.errnpm-debug.log*,yarn-debug.log*,yarn-error.log*,pnpm-debug.log*- any file under a
logs/directory
- Untracked high-risk binary extensions:
.exe,.dll,.so,.dylib,.bin,.class.zip,.tar,.gz,.bz2,.xz,.7z,.rar,.jar.iso,.dmg,.db,.sqlite,.sqlite3
If blocked, list offending files grouped by reason and request user action. Do not auto-delete files.
Commit Message Format
Use JIRA subject format:
<ticket>: <description>- Ticket must be provided by the user (example:
JIRA-123). - If no ticket is provided, return an error and ask the user for the ticket number before committing.
- Subject must describe what changed (not only intent), be imperative, and avoid trailing period.
- Keep subject concise (prefer <= 72 chars).
Require commit body:
- Provide bullet lines summarizing key changes and impact.
- Mention migration/risk notes when relevant.
- Use concise, factual bullets.
Example:
Subject:
JIRA-123: my important changes
Body:
- Serialize refresh attempts per user session to prevent duplicate refresh calls.- Add timeout handling so failed refresh does not block subsequent requests.- Update session middleware tests for concurrent request scenarios.
Execution Notes
- Prefer one logical commit for the current request.
- If changes are unrelated, split into separate commits and repeat the guard + staging flow for each.
- If message quality is uncertain, summarize staged diff first, then derive subject/body.