Ferramentas e automação Fonte oficial
Commits Git com Conventional Commits
Analise diffs, agrupe arquivos e crie commits Git com mensagens Conventional Commits coerentes com as alterações reais do repositório.
Ver código no GitHub Instala diretamente do repositório-fonte.
O que esta skill faz
Esta skill automatiza a preparação de commits sem perder o vínculo com o diff. Ela detecta tipo e escopo, permite ajustes interativos e organiza o staging em grupos lógicos antes de gerar a mensagem semântica.
Quando usar
- Criar um commit a partir de alterações locais
- Gerar mensagem Conventional Commits
- Separar mudanças em grupos lógicos
- Marcar breaking changes
- Definir tipo e escopo manualmente
Como usar
- Revise o repositório com `git status` e examine o diff
- Use `git diff --staged` quando já houver arquivos preparados
- Agrupe e adicione apenas arquivos relacionados
- Escolha tipo, escopo e descrição com base nas mudanças reais
- Crie o commit e confira o resultado
O que revisar antes de instalar
- A detecção automática ainda exige revisão humana
- Mudanças sem relação devem ser divididas em commits separados
- Breaking changes precisam ser sinalizadas explicitamente
- Arquivos sensíveis não devem entrar no staging
SKILL.md
--- name: git-commit description: 'Execute git commit with conventional commit message analysis, intelligent staging, and message generation. Use when user asks to commit changes, create a git commit, or mentions "/commit". Supports: (1) Auto-detecting type and scope from changes, (2) Generating conventional commit messages from diff, (3) Interactive commit with optional type/scope/description overrides, (4) Intelligent file staging for logical grouping' license: MIT allowed-tools: Bash --- # Git Commit with Conventional Commits ## Overview Create standardized, semantic git commits using the Conventional Commits specification. Analyze the actual diff to determine appropriate type, scope, and message. ## Conventional Commit Format ``` <type>[optional scope]: <description> [optional body] [optional footer(s)] ``` ## Commit Types | Type | Purpose | | ---------- | ------------------------------ | | `feat` | New feature | | `fix` | Bug fix | | `docs` | Documentation only | | `style` | Formatting/style (no logic) | | `refactor` | Code refactor (no feature/fix) | | `perf` | Performance improvement | | `test` | Add/update tests | | `build` | Build system/dependencies | | `ci` | CI/config changes | | `chore` | Maintenance/misc | | `revert` | Revert commit | ## Breaking Changes ``` # Exclamation mark after type/scope feat!: remove deprecated endpoint # BREAKING CHANGE footer feat: allow config to extend other configs BREAKING CHANGE: `extends` key behavior changed ``` ## Workflow ### 1. Analyze Diff ```bash # If files are staged, use staged diff git diff --staged # If nothing staged, use working tree diff git diff # Also check status git status --porcelain ``` ### 2. Stage Files (if needed) If nothing is staged or you want to group changes differently: ```bash # Stage specific files git add path/to/file1 path/to/file2 # Stage by pattern git add *.test.* git add src/components/* # Interactive staging git add -p ``` **Never commit secrets** (.env, credentials.json, private keys). ### 3. Generate Commit Message Analyze the diff to determine: - **Type**: What kind of change is this? - **Scope**: What area/module is affected? - **Description**: One-line summary of what changed (present tense, imperative mood, <72 chars) ### 4. Execute Commit ```bash # Single line git commit -m "<type>[scope]: <description>" # Multi-line with body/footer git commit -m "$(cat <<'EOF' <type>[scope]: <description> <optional body> <optional footer> EOF )" ``` ## Best Practices - One logical change per commit - Present tense: "add" not "added" - Imperative mood: "fix bug" not "fixes bug" - Reference issues: `Closes #123`, `Refs #456` - Keep description under 72 characters ## Git Safety Protocol - NEVER update git config - NEVER run destructive commands (--force, hard reset) without explicit request - NEVER skip hooks (--no-verify) unless user asks - NEVER force push to main/master - If commit fails due to hooks, fix and create NEW commit (don't amend)