Claude-skill-registry create-pr-github
Create and (optionally) merge a GitHub pull request (prefer GitHub chat tools; gh/wrappers are fallback), following the repo policy to use rebase and merge for a linear history.
git clone https://github.com/majiayu000/claude-skill-registry
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/create-pr-github" ~/.claude/skills/majiayu000-claude-skill-registry-create-pr-github && rm -rf "$T"
skills/data/create-pr-github/SKILL.mdCreate PR (GitHub)
Purpose
Create a GitHub pull request in a consistent, policy-compliant way, and include the repo’s preferred merge method guidance (rebase and merge).
This skill prefers using GitHub chat tools because they can be permanently allowed in VS Code and avoid terminal pager/editor issues. If chat tools are unavailable (or repo context is unknown), fall back to the repo wrapper script
scripts/pr-github.sh.
Hard Rules
Must
- Work on a non-
branch.main - Ensure the working tree is clean before creating a PR.
- Push the branch to
before creating the PR.origin - Before creating the PR, post the exact Title and Description in chat.
- Use the standard PR body template (Problem / Change / Verification).
- Use Rebase and merge for merging PRs to maintain a linear history (see
).CONTRIBUTING.md
Must Not
- Create PRs from
.main - Use “Squash and merge” or “Create a merge commit”.
- Use
or any heuristic that guesses title/body (not supported by the wrapper).--fill
Actions
0. Title + Description (Required)
Before running any PR creation command, provide in chat:
- PR title (exact)
- PR description (exact), using this template:
## Problem <why is this change needed?> ## Change <what changed?> ## Verification <how was it validated?>
Recommended: One-Command Wrapper
Create a PR:
echo "## Summary\n\nPR description" | scripts/pr-github.sh create --title "<type(scope): summary>" --body-from-stdin
Create and merge (only when explicitly requested):
echo "## Summary\n\nPR description" | scripts/pr-github.sh create-and-merge --title "<type(scope): summary>" --body-from-stdin
1. Pre-flight Checks
git branch --show-current git status --short
2. Push the Branch
git push -u origin HEAD
3. Create the PR
Preferred: GitHub chat tools
Use the GitHub PR creation tool with an explicit title + body (same template as above).
Notes:
- This requires repo context (
+owner
) and your pushed branch name.repo - If you do not know
/owner
reliably, use the wrapper fallback below.repo
Fallback: gh
CLI
ghecho "## Summary\n\nPR description" | PAGER=cat gh pr create \ --base main \ --head "$(git branch --show-current)" \ --title "<type(scope): summary>" \ --body-file -
4. Merge (Only When Explicitly Requested)
This repository requires rebase and merge.
Preferred: GitHub chat tools
Use the GitHub PR merge tool with
merge_method=rebase.
Fallback: gh
CLI
ghPAGER=cat gh pr merge <pr-number> --rebase --delete-branch
5. If Rebase-Merge Is Blocked (Conflicts)
git pull --rebase origin main # resolve conflicts git push --force-with-lease
Then retry the merge.