configure-git-repository
关于
This skill configures a Git repository with language-specific .gitignore files, branch strategies, commit conventions, and pre-commit hooks. It provides initial setup and common patterns for R, Node.js, and Python projects. Use it when initializing version control for a new project or standardizing an existing repository.
快速安装
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-repository在 Claude 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是Meta推出的7-8B参数内容审核模型,专门用于过滤LLM的输入和输出内容。它能检测六大安全风险类别(暴力/仇恨、性内容、武器、违禁品、自残、犯罪计划),准确率达94-95%。开发者可通过HuggingFace、vLLM或Sagemaker快速部署,并能与NeMo Guardrails集成实现自动化安全防护。
cost-optimization
其他这个Claude Skill帮助开发者优化云成本,通过资源调整、标记策略和预留实例来降低AWS、Azure和GCP的开支。它适用于减少云支出、分析基础设施成本或实施成本治理策略的场景。关键功能包括提供成本可视化、资源规模调整指导和定价模型优化建议。
quantizing-models-bitsandbytes
其他这个Skill使用bitsandbytes库量化大语言模型,能在GPU内存有限时通过8位或4位量化减少50-75%内存占用,同时保持精度损失最小。它支持INT8、NF4、FP4等多种量化格式,可与HuggingFace Transformers无缝集成,适用于需要部署更大模型或加速推理的场景。还提供QLoRA训练和8位优化器支持,让开发者能轻松实现高效模型压缩。
dispatching-parallel-agents
其他该Skill用于并行处理3个以上无依赖关系的独立故障,可为每个问题域分派专属Claude代理同时执行调查修复。它通过并发处理多个独立问题显著提升故障排查效率,特别适用于测试文件、子系统等无共享状态的场景。
