configure-git-repository
Acerca de
Esta habilidad configura repositorios Git con archivos .gitignore específicos por lenguaje, estrategias de ramas, convenciones de commits y hooks para proyectos de R, Node.js y Python. Úsela al inicializar el control de versiones para nuevos proyectos o al configurar la protección de ramas y estándares de commits. Maneja tanto la configuración inicial como los patrones comunes de flujo de trabajo en Git.
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/configure-git-repositoryCopia y pega este comando en Claude Code para instalar esta habilidad
Documentación
Configure Git Repository
Set up Git repo with appropriate config for project type.
When Use
- Initialize version control for new project
- Add
.gitignorefor specific language/framework - Set up branch protection, conventions
- Configure commit hooks
Inputs
- Required: Project directory
- Required: Project type (R package, Node.js, Python, general)
- Optional: Remote repo URL
- Optional: Branch strategy (trunk-based, Git Flow)
- Optional: Commit message convention
Steps
Step 1: Initialize Repository
cd /path/to/project
git init
git branch -M main
Got: .git/ directory created. Default branch named main.
If fail: git init fails? Ensure Git installed (git --version). Directory already has .git/? Repo already initialized — skip.
Step 2: Create .gitignore
R Package:
# R artifacts
.Rhistory
.RData
.Rproj.user/
*.Rproj
# Environment (sensitive)
.Renviron
# renv library (machine-specific)
renv/library/
renv/staging/
renv/cache/
# Build artifacts
*.tar.gz
src/*.o
src/*.so
src/*.dll
# Documentation build
docs/
inst/doc/
# IDE
.vscode/
.idea/
# OS
.DS_Store
Thumbs.db
Node.js/TypeScript:
node_modules/
dist/
build/
.next/
.env
.env.local
.env.*.local
*.log
npm-debug.log*
.DS_Store
Thumbs.db
.vscode/
.idea/
coverage/
Python:
__pycache__/
*.py[cod]
*.egg-info/
dist/
build/
.eggs/
.venv/
venv/
.env
*.log
.mypy_cache/
.pytest_cache/
htmlcov/
.coverage
.DS_Store
.idea/
.vscode/
Got: .gitignore created with entries appropriate for project type. Sensitive files (.Renviron, .env) and generated artifacts excluded.
If fail: Unsure which entries to include? Use gitignore.io or GitHub .gitignore templates as starting point, customize for project.
Step 3: Create Initial Commit
git add .gitignore
git add . # Review what's being added first with git status
git commit -m "Initial project setup"
Got: First commit created containing .gitignore and initial project files. git log shows one commit.
If fail: git commit fails with "nothing to commit"? Ensure files staged with git add. Fails with author identity error? Set git config user.name and git config user.email.
Step 4: Connect Remote
# Add remote
git remote add origin [email protected]:username/repo.git
# Push
git push -u origin main
Got: Remote origin configured. git remote -v shows fetch and push URLs. Initial commit pushed to remote.
If fail: Push fails with "Permission denied (publickey)"? Configure SSH keys (see setup-wsl-dev-environment). Remote already exists? Update with git remote set-url origin <url>.
Step 5: Set Up Branch Conventions
Trunk-based (recommended for small teams):
main: production-ready code- Feature branches:
feature/description - Bug fixes:
fix/description
# Create feature branch
git checkout -b feature/add-authentication
# After work is done, merge or create PR
git checkout main
git merge feature/add-authentication
Got: Branch naming convention established, documented. Team members know which prefix to use for each type of work.
If fail: Branches already named inconsistently? Rename with git branch -m old-name new-name, update any open PRs.
Step 6: Configure Commit Conventions
Conventional Commits format:
type(scope): description
feat: add user authentication
fix: correct calculation in weighted_mean
docs: update README installation section
test: add edge case tests for parser
refactor: extract helper function
chore: update dependencies
Got: Commit message convention documented, agreed by team. Future commits follow type: description format.
If fail: Team members not following convention? Enforce with commit-msg hook that validates format (see Step 7).
Step 7: Set Up Pre-Commit Hooks (Optional)
Create .githooks/pre-commit:
#!/bin/bash
# Run linter before commit
# For R packages
if [ -f "DESCRIPTION" ]; then
Rscript -e "lintr::lint_package()" || exit 1
fi
# For Node.js
if [ -f "package.json" ]; then
npm run lint || exit 1
fi
chmod +x .githooks/pre-commit
git config core.hooksPath .githooks
Got: Pre-commit hook runs automatically on each git commit. Linting errors block commit until fixed.
If fail: Hook does not run? Verify core.hooksPath set (git config core.hooksPath), hook file executable (chmod +x).
Step 8: Create README
# Minimal README
echo "# Project Name" > README.md
echo "" >> README.md
echo "Brief description of the project." >> README.md
git add README.md
git commit -m "Add README"
Got: README.md committed to repo. Project has minimal but informative landing page on GitHub.
If fail: README.md already exists? Update rather than overwrite. Use usethis::use_readme_md() in R projects for template with badges.
Checks
-
.gitignoreexcludes sensitive and generated files - No sensitive data (tokens, passwords) in tracked files
- Remote repo connected, accessible
- Branch naming conventions documented
- Initial commit created cleanly
Pitfalls
- Committing before .gitignore: Add
.gitignorefirst. Files already tracked aren't affected by later.gitignoreentries. - Sensitive data in history: Secrets committed remain in history even after deletion. Use
git filter-repoor BFG to clean. - Large binary files: Don't commit large binaries. Use Git LFS for files > 1MB.
- Line endings: Set
core.autocrlf=inputon Windows/WSL to prevent CRLF/LF issues.
See Also
commit-changes- staging and committing workflowmanage-git-branches- branch creation and conventionscreate-r-package- Git setup as part of R package creationsetup-wsl-dev-environment- Git installation and SSH keyscreate-github-release- creating releases from reposecurity-audit-codebase- check for committed secrets
Repositorio GitHub
Habilidades relacionadas
llamaguard
OtroLlamaGuard es el modelo de Meta de 7-8B parámetros para moderar las entradas y salidas de LLM en seis categorías de seguridad como violencia y discurso de odio. Ofrece una precisión del 94-95% y puede implementarse usando vLLM, Hugging Face o Amazon SageMaker. Utiliza esta skill para integrar fácilmente filtrado de contenido y barreras de seguridad en tus aplicaciones de IA.
cost-optimization
OtroEsta Skill de Claude ayuda a los desarrolladores a optimizar los costes en la nube mediante el ajuste de tamaño de recursos, estrategias de etiquetado y análisis de gastos. Proporciona un marco para reducir los gastos en la nube e implementar una gobernanza de costes en AWS, Azure y GCP. Úsala cuando necesites analizar los costes de infraestructura, ajustar el tamaño de los recursos o cumplir con restricciones presupuestarias.
quantizing-models-bitsandbytes
OtroEsta habilidad cuantiza LLMs a precisión de 8 o 4 bits utilizando bitsandbytes, logrando una reducción de memoria del 50-75% con pérdida mínima de precisión. Es ideal para ejecutar modelos más grandes en memoria GPU limitada o para acelerar la inferencia, admitiendo formatos como INT8, NF4 y FP4. La habilidad se integra con HuggingFace Transformers y permite entrenamiento QLoRA y optimizadores de 8 bits.
dispatching-parallel-agents
OtroEsta Skill de Claude despliega múltiples agentes para investigar y solucionar 3 o más problemas independientes de forma concurrente. Está diseñada para escenarios que involucran fallos no relacionados que pueden resolverse sin estado compartido o dependencias. Su capacidad principal es la resolución paralela de problemas, asignando un agente por cada dominio problemático independiente para maximizar la eficiencia.
