| name | git-github |
| description | React Native (Expo) 项目的 Git 和 GitHub 操作,包括分支管理、提交、推送、创建仓库、Pull Request、合并流程。当用户提到"git"、"github"、"提交"、"推送"、"分支"、"PR"、"合并"、"仓库"、"rebase"时使用此 skill。 |
Git 和 GitHub 操作
提供 React Native/Expo 项目的 Git 版本控制和 GitHub 仓库管理的完整工作流。
快速参考
核心原则
| 原则 | 说明 |
|---|---|
| 禁止直接 push main | main 只能通过 PR 合并 |
| 先 rebase 后 PR | 提交前必须 rebase 到最新远程分支 |
| 使用 rebase merge | PR 合并统一使用 --rebase 保持线性历史 |
| 提交前必须通过质量检查 | 参考 code-quality skill |
⚠️ 提交前必须通过质量检查
每次提交/推送前必须运行并通过:
pnpm tsc --noEmit # 0 type errors
pnpm eslint . # 0 errors, 0 warnings
pnpm prettier --check . # 0 format issues
pnpm jest # All tests passed
详细检查清单见 .claude/skills/code-quality/SKILL.md
分支命名
| 前缀 | 用途 | 示例 |
|---|---|---|
feature/ |
新功能 | feature/user-auth |
fix/ |
Bug 修复 | fix/login-bug |
hotfix/ |
紧急修复 | hotfix/critical-bug |
refactor/ |
重构 | refactor/auth-module |
提交格式(Conventional Commits)
<type>(<scope>): <subject>
类型: feat | fix | docs | style | refactor | perf | test | build | ci | chore
常用命令速查
# 分支
git checkout -b feature/xxx # 创建分支
git branch -d feature/xxx # 删除分支
# Rebase
git fetch origin develop && git rebase origin/develop
# 推送
git push -u origin feature/xxx # 首次推送
git push --force-with-lease # rebase 后推送
# PR
gh pr create --base develop # 创建 PR
gh pr merge <n> --rebase --delete-branch # 合并 PR
子代理执行(强烈推荐)
Git 操作应通过子代理执行:
Task({
subagent_type: 'general-purpose',
description: '提交当前分支变更',
prompt: `执行 Git 提交,遵循 .claude/skills/git-github/SKILL.md`,
});
原因:Git 操作需读取 diff/status/log(消耗大量 token),子代理可隔离处理。
工作流程
Feature 分支流程
# 1. 从 develop 创建分支
git checkout develop && git pull
git checkout -b feature/xxx
# 2. 开发完成后同步 develop
git fetch origin develop
git rebase origin/develop
# 3. ⚠️ 质量检查(必须全部通过!)
pnpm tsc --noEmit # 必须 0 errors
pnpm eslint . # 必须 0 issues
pnpm prettier --check . # 必须 0 issues
pnpm jest # 必须全部通过
# 4. 提交(质量检查通过后)
git add . && git commit -m "feat: xxx"
# 5. ⚠️ 推送前再次 rebase 远程(确保最新)
git fetch origin develop
git rebase origin/develop
git push --force-with-lease origin feature/xxx
# 6. 创建 PR
gh pr create --base develop --title "feat: xxx"
# 7. 合并(使用 rebase merge)
gh pr merge <n> --rebase --delete-branch
发布流程(Develop → Main)
# 1. 确保 develop 最新
git checkout develop && git pull
# 2. 质量检查
pnpm tsc --noEmit && pnpm eslint . && pnpm jest
# 3. 创建发布 PR
gh pr create --base main --head develop --title "release: v1.x.x"
# 4. 合并到 main
gh pr merge <n> --rebase
# 5. 打 tag
git checkout main && git pull
git tag -a v1.x.x -m "Release v1.x.x"
git push origin v1.x.x
Hotfix 流程
# 1. 从 main 创建
git checkout main && git pull
git checkout -b hotfix/xxx
# 2. 修复后创建 PR 到 main
gh pr create --base main
# 3. 合并后同步到 develop
git checkout develop && git merge main && git push
PR 规范
标题格式
<type>(<scope>): <description>
内容模板
## Summary
- 变更点 1
- 变更点 2
## Test plan
- [ ] 验证项 1
- [ ] 验证项 2
🤖 Generated with [Claude Code](https://claude.com/claude-code)
冲突解决
| 文件类型 | 策略 |
|---|---|
package.json |
保留较新版本,重新 pnpm install |
pnpm-lock.yaml |
选择一方后重新 pnpm install |
app.json/app.config.ts |
优先保留 main 结构 |
| 代码文件 | 根据业务逻辑手动合并 |
ios/ / android/ |
谨慎处理,可能需要 npx expo prebuild --clean |
.gitignore 规范
React Native/Expo 项目应忽略:
# Dependencies
node_modules/
.pnpm-store/
# Expo
.expo/
dist/
web-build/
# Native (如果使用 CNG 不提交)
# android/
# ios/
# Environment
.env
.env.*
!.env.example
# IDE
.vscode/
.idea/
# OS
.DS_Store
Thumbs.db
# Build
*.jks
*.p8
*.p12
*.key
*.mobileprovision
*.orig.*
# Metro
.metro-health-check*
# Testing
coverage/
安全提醒
| 禁止 | 替代方案 |
|---|---|
| 直接 push main | 通过 PR 合并 |
| 合并未通过检测的代码 | 先 pnpm tsc --noEmit && pnpm eslint . && pnpm jest |
--force 推送 main |
使用 --force-with-lease(仅 feature 分支) |
提交 .env 等敏感信息 |
使用 .gitignore 排除 |
| 提交 API Keys/Secrets | 使用环境变量 |
附录
A. 完整提交示例
git commit -m "$(cat <<'EOF'
feat(auth): 添加 JWT token 刷新机制
- 添加 token 过期检测
- 实现自动刷新逻辑
Closes #123
🤖 Generated with [Claude Code](https://claude.com/claude-code)
Co-Authored-By: Claude <noreply@anthropic.com>
EOF
)"
B. GitHub CLI 命令
# 认证
gh auth status
# 仓库
gh repo create <name> --private --source=. --push
# PR
gh pr list
gh pr view <n>
gh pr merge <n> --rebase --delete-branch # 统一使用 rebase merge
C. 分支流向图
feature/xxx ─┐
fix/xxx ─────┼──► develop ──► main (发布)
refactor/xxx ┘ ▲
│
hotfix/xxx ───────────┴──► main
D. Expo 特殊注意
- 如果使用 CNG(Continuous Native Generation),
android/和ios/目录可以不提交 - 如果提交原生目录,确保
.gitignore正确配置 - 原生配置改动优先通过 Config Plugin 管理,保持可复现性