commit-changes
Acerca de
La habilidad commit-changes prepara, confirma y enmienda cambios en Git utilizando mensajes de commit convencionales. Permite la preparación selectiva, mensajes descriptivos con formato HEREDOC y la verificación del historial de commits. Úsala para guardar unidades lógicas de trabajo en el control de versiones con prácticas adecuadas de confirmación.
Instalación rápida
Claude Code
Recomendadonpx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/commit-changesCopia y pega este comando en Claude Code para instalar esta habilidad
Documentación
Commit Changes
Stage files selective. Write clear commit messages. Verify commit history.
When Use
- Save logical unit of work to version control
- Create commit with descriptive, conventional message
- Amend most recent commit (message or content)
- Review what commit before commit
Inputs
- Required: One or more changed files to commit
- Optional: Commit message (drafted if not given)
- Optional: Whether amend previous commit
- Optional: Co-author attribution
Steps
Step 1: Review Current Changes
Check working tree status. Inspect diffs.
# See which files are modified, staged, or untracked
git status
# See unstaged changes
git diff
# See staged changes
git diff --staged
Got: Clear picture of all modified, staged, untracked files.
If fail: git status fail? Verify inside git repo (git rev-parse --is-inside-work-tree).
Step 2: Stage Files Selective
Stage specific files. Avoid git add . or git add -A — may grab sensitive files or unrelated changes.
# Stage specific files by name
git add src/feature.R tests/test-feature.R
# Stage all changes in a specific directory
git add src/
# Stage parts of a file interactively (not supported in non-interactive contexts)
# git add -p filename
Review staged before commit.
git diff --staged
Got: Only intended files and changes staged. No .env, credentials, large binaries.
If fail: Unstage accidental files with git reset HEAD <file>. Sensitive data staged? Unstage now, before commit.
Step 3: Write Commit Message
Use conventional commits format. Always pass message via HEREDOC for proper formatting.
git commit -m "$(cat <<'EOF'
feat: add weighted mean calculation
Implements weighted_mean() with support for NA handling and
zero-weight filtering. Includes input validation for mismatched
vector lengths.
Co-Authored-By: Claude Opus 4.6 <[email protected]>
EOF
)"
Conventional commit types:
| Type | When use |
|---|---|
feat | New feature |
fix | Bug fix |
docs | Documentation only |
test | Add or update tests |
refactor | Code change — no fix, no new feature |
chore | Build, CI, dependency updates |
style | Formatting, whitespace (no logic change) |
Got: Commit created with descriptive message. Explains why, not just what.
If fail: Pre-commit hook fail? Fix issue, re-stage with git add, create new commit. No --amend — failed commit never created.
Step 4: Amend Last Commit (Optional)
Only amend if commit not pushed to shared remote.
# Amend message only
git commit --amend -m "$(cat <<'EOF'
fix: correct weighted mean edge case for empty vectors
EOF
)"
# Amend with additional staged changes
git add forgotten-file.R
git commit --amend --no-edit
Got: Previous commit updated in-place. git log -1 shows amended content.
If fail: Commit already pushed? No amend. Create new commit. Force-push amended commits to shared branches breaks history.
Step 5: Verify Commit
# View the last commit
git log -1 --stat
# View recent commit history
git log --oneline -5
# Verify the commit content
git show HEAD
Got: Commit appears in history with correct message, author, file changes.
If fail: Commit has wrong files? Use git reset --soft HEAD~1 to undo commit, keep changes staged. Re-commit correct.
Checks
- Only intended files in commit
- No sensitive data (tokens, passwords,
.envfiles) committed - Commit message follows conventional commits format
- Message body explains why change made
-
git logshows commit with correct metadata - Pre-commit hooks (if any) passed
Pitfalls
- Commit too much at once: Each commit = one logical change. Split unrelated changes into separate commits.
- Using
git add .blind: Always reviewgit statusfirst. Prefer stage specific files by name. - Amend pushed commits: Never amend commits pushed to shared branch. Rewrites history. Breaks collaborators.
- Vague commit messages: "fix bug" or "update" tells nothing. Describe what changed and why.
- Forget
--no-editon content amends: Adding forgotten files to last commit? Use--no-edit— keeps existing message. - Hook fail leading to
--amend: Pre-commit hook fail → commit never created.--amendwould modify previous commit. Always create new commit after fix hook issues.
See Also
manage-git-branches- branch workflow before commitcreate-pull-request- next step after commitresolve-git-conflicts- handle conflicts during merge/rebaseconfigure-git-repository- repo setup and conventions
Repositorio GitHub
Habilidades relacionadas
content-collections
MetaEsta habilidad proporciona una configuración probada en producción para Content Collections, una herramienta centrada en TypeScript que transforma archivos Markdown/MDX en colecciones de datos con tipado seguro mediante validación Zod. Úsala al construir blogs, sitios de documentación o aplicaciones Vite + React con mucho contenido para garantizar seguridad de tipos y validación automática de contenido. Abarca todo, desde la configuración del plugin de Vite y compilación MDX hasta la optimización de despliegue y validación de esquemas.
polymarket
MetaEsta habilidad permite a los desarrolladores crear aplicaciones con la plataforma de mercados de predicción Polymarket, incluyendo la integración de API para operaciones y datos de mercado. También proporciona transmisión de datos en tiempo real a través de WebSocket para monitorear operaciones en vivo y actividad del mercado. Úsela para implementar estrategias de trading o crear herramientas que procesen actualizaciones de mercado en tiempo real.
creating-opencode-plugins
MetaEsta habilidad ayuda a los desarrolladores a crear complementos de OpenCode que se conectan a más de 25 tipos de eventos, como comandos, archivos y operaciones LSP. Proporciona la estructura del complemento, las especificaciones de la API de eventos y los patrones de implementación para módulos en JavaScript/TypeScript. Úsala cuando necesites interceptar, monitorear o extender el ciclo de vida del asistente de IA de OpenCode con lógica personalizada basada en eventos.
sglang
MetaSGLang es un framework de alto rendimiento para el servicio de LLM que se especializa en generación rápida y estructurada para JSON, expresiones regulares y flujos de trabajo de agentes utilizando su caché de prefijos RadixAttention. Ofrece una inferencia significativamente más rápida, especialmente para tareas con prefijos repetidos, lo que lo hace ideal para salidas complejas y estructuradas, y conversaciones multiturno. Elige SGLang sobre alternativas como vLLM cuando necesites decodificación restringida o estés construyendo aplicaciones con uso extensivo de prefijos compartidos.
