configure-git-repository
정보
이 스킬은 언어별 .gitignore 파일, 브랜치 전략, 커밋 규칙, 그리고 pre-commit 훅을 사용하여 Git 저장소를 구성합니다. R, Node.js, Python 프로젝트를 위한 초기 설정과 일반적인 패턴을 제공합니다. 새 프로젝트의 버전 관리를 초기화하거나 기존 저장소를 표준화할 때 사용하세요.
빠른 설치
Claude Code
추천npx 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-repositoryClaude Code에서 이 명령을 복사하여 붙여넣어 스킬을 설치하세요
문서
Configure Git Repository
Set up a Git repository with appropriate configuration for the project type.
When to Use
- Initializing version control for a new project
- Adding
.gitignorefor a specific language/framework - Setting up branch protection and conventions
- Configuring commit hooks
Inputs
- Required: Project directory
- Required: Project type (R package, Node.js, Python, general)
- Optional: Remote repository URL
- Optional: Branch strategy (trunk-based, Git Flow)
- Optional: Commit message convention
Procedure
Step 1: Initialize Repository
cd /path/to/project
git init
git branch -M main
Got: .git/ directory created. Default branch is named main.
If fail: If git init fails, ensure Git is installed (git --version). If the directory already has a .git/, the repository is already initialized — skip this step.
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 file created with entries appropriate for the project type. Sensitive files (.Renviron, .env) and generated artifacts are excluded.
If fail: If unsure which entries to include, use gitignore.io or GitHub's .gitignore templates as a starting point and customize for the 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: If git commit fails with "nothing to commit," ensure files were staged with git add. If it fails with an 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 is configured. git remote -v shows fetch and push URLs. Initial commit is pushed to the remote.
If fail: If push fails with "Permission denied (publickey)," configure SSH keys (see setup-wsl-dev-environment). If the remote already exists, update it 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 is established and documented. Team members know which prefix to use for each type of work.
If fail: If branches are already named inconsistently, rename them with git branch -m old-name new-name and 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 is documented and agreed upon by the team. Future commits follow the type: description format.
If fail: If team members are not following the convention, enforce it with a commit-msg hook that validates the 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 the commit until fixed.
If fail: If the hook does not run, verify core.hooksPath is set (git config core.hooksPath) and the hook file is 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 the repository. The project has a minimal but informative landing page on GitHub.
If fail: If README.md already exists, update it rather than overwriting. Use usethis::use_readme_md() in R projects for a template with badges.
Validation
-
.gitignoreexcludes sensitive and generated files - No sensitive data (tokens, passwords) in tracked files
- Remote repository connected and 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: If secrets are committed, they 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.
Related Skills
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 the repositorysecurity-audit-codebase- check for committed secrets
GitHub 저장소
연관 스킬
llamaguard
기타LlamaGuard는 폭력 및 혐오 발언 등 6가지 안전 범주에서 LLM 입력과 출력을 조정하기 위한 Meta의 70-80억 파라미터 모델입니다. 94-95% 정확도를 제공하며 vLLM, Hugging Face 또는 Amazon SageMaker를 사용해 배포할 수 있습니다. 이 기술을 사용하여 AI 애플리케이션에 콘텐츠 필터링 및 안전 가드레일을 손쉽게 통합하세요.
cost-optimization
기타이 Claude Skill은 리소스 적정화, 태깅 전략, 지출 분석을 통해 개발자들이 클라우드 비용을 최적화할 수 있도록 지원합니다. AWS, Azure, GCP에서 클라우드 비용을 절감하고 비용 거버넌스를 구현하기 위한 프레임워크를 제공합니다. 인프라 비용을 분석하거나, 리소스를 적정화하거나, 예산 제약을 충족해야 할 때 사용하세요.
quantizing-models-bitsandbytes
기타이 스킬은 bitsandbytes를 사용하여 LLM을 8비트 또는 4비트 정밀도로 양자화하며, 최소한의 정확도 손실로 50-75%의 메모리 감소를 달성합니다. 제한된 GPU 메모리에서 더 큰 모델을 실행하거나 추론을 가속화하는 데 이상적이며, INT8, NF4, FP4와 같은 형식을 지원합니다. 이 스킬은 HuggingFace Transformers와 통합되어 QLoRA 학습 및 8비트 옵티마이저를 가능하게 합니다.
dispatching-parallel-agents
기타이 Claude Skill은 3개 이상의 독립적인 문제를 동시에 조사하고 해결하기 위해 다중 에이전트를 배치합니다. 공유 상태나 의존성 없이 해결 가능한 무관련 장애 시나리오에 맞게 설계되었습니다. 핵심 기능은 병렬 문제 해결로, 각 독립 문제 영역마다 하나의 에이전트를 할당하여 효율성을 극대화합니다.
