gh
GitHub operations using gh CLI for any repository. Use when the user asks to "create pr", "create pull request", "view pr", "check ci", "pr status", "list prs", "create issue", "view issue", "search code", or any other GitHub-related operations. Handles PR creation with proper base branch detection, template support, and project conventions.
install
source · Clone the upstream repo
git clone https://github.com/salemove/android-sdk-widgets
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/salemove/android-sdk-widgets "$T" && mkdir -p ~/.claude/skills && cp -r "$T/.claude/skills/gh" ~/.claude/skills/salemove-android-sdk-widgets-gh && rm -rf "$T"
manifest:
.claude/skills/gh/SKILL.mdsource content
GitHub Operations
Manage GitHub workflows using the
gh CLI.
When to Use This Skill
Use this skill when the user asks to:
- Create a pull request
- View PR details or status
- Check CI/CD pipeline status
- Manage issues
- Review PR comments
- Search repository code or issues
Commands
Create Pull Request
When creating a PR:
-
Verify current branch and changes:
git branch --show-current git status -
Check if branch is pushed:
git log @{u}.. 2>/dev/null || echo "Branch not pushed" -
Push if needed:
git push -u origin $(git branch --show-current) -
Detect parent branch (if base not specified):
Find the parent branch from which the current branch was created:
PARENT_BRANCH=$(git show-branch -a 2>/dev/null | grep '\*' | grep -v "$(git rev-parse --abbrev-ref HEAD)" | head -n1 | sed 's/.*\[\(.*\)\].*/\1/' | sed 's/[\^~].*//' | sed 's/remotes\/origin\///') # Fall back to common default branches if detection fails if [ -z "$PARENT_BRANCH" ]; then for branch in development develop main master; do if git show-ref --verify --quiet refs/remotes/origin/$branch; then PARENT_BRANCH=$branch break fi done fi -
Create PR:
Check if a PR template exists and use it, otherwise open in browser:
if [ -f .github/PULL_REQUEST_TEMPLATE.md ]; then gh pr create --title "Brief title (under 70 chars)" --base "$PARENT_BRANCH" --template .github/PULL_REQUEST_TEMPLATE.md else gh pr create --title "Brief title (under 70 chars)" --base "$PARENT_BRANCH" --web fiBase branch logic:
- Auto-detect: Use the parent branch from which current branch was created
- Fallback: Use common default branches if detection fails
- Override: Use explicitly specified base branch if provided by user
Template handling:
- If
exists: Use.github/PULL_REQUEST_TEMPLATE.md
flag to fill it via CLI--template - If no template: Use
flag to open browser for manual description--web
- Display PR URL to user
View Pull Request
# View specific PR gh pr view 123 # View PR in browser gh pr view 123 --web # List open PRs gh pr list # List PRs by author gh pr list --author @me
Check PR Status
# Check CI/CD status gh pr checks 123 # View PR status gh pr status
PR Comments
# View comments on PR gh pr view 123 --comments # Add comment to PR gh pr comment 123 --body "Your comment here"
Issue Management
# Create issue gh issue create --title "Issue title" --body "Issue description" # View issue gh issue view 456 # List open issues gh issue list # Search issues gh issue list --search "keyword"
Code Search
# Search code in current repository gh search code "search term" # Search code in specific repository gh search code --repo owner/repo "search term"
View Commits
# List recent commits on current branch git log --oneline -10 # View specific commit gh pr view <commit-sha>
PR Best Practices
Title Format
- Keep under 70 characters
- Use imperative mood: "Add feature" not "Added feature"
- Be specific but concise
Examples:
- ✅ "Optimize CLAUDE.md by removing general knowledge"
- ✅ "Fix memory leak in ChatController disposal"
- ✅ "Add snapshot tests for CallVisualizer UI"
- ❌ "Update files" (too vague)
- ❌ "This PR adds a new feature to handle user authentication and also fixes some bugs" (too long)
Description Format
- If the repository has a PR template at
, use the.github/PULL_REQUEST_TEMPLATE.md
flag--template - If no template exists, use the
flag to open browser for manual description--web - Never create custom descriptions with
- always use template or browser--body
Base Branch Selection
- Auto-detect: Automatically use the parent branch from which the current branch was created
- Fallback: Use common default branches (
,development
,develop
, ormain
) if parent branch detection failsmaster - Override: Use explicitly specified base branch if the user requests it (e.g., "create PR against master")
Error Handling
If
gh is not authenticated:
Run: gh auth login Follow browser-based OAuth flow
If
gh is not installed:
macOS: brew install gh Or download from: https://cli.github.com/
Important Notes
- Check for PR template first: Use
if--template
exists, otherwise use.github/PULL_REQUEST_TEMPLATE.md--web - Never use
parameter: Always use template or browser for PR descriptions--body - Always verify branch is pushed before creating PR
- Check CI status before requesting review