review-pr | Skill Performance & Reviews | TopRankSkills

TopRank Skills

Home / Skills / tools / review-pr

review-pr

maintained by suitedaces

star 172 account_tree 22 verified_user MIT License
bolt View GitHub

name: review-pr description: "Review GitHub pull requests with structured code analysis. Use when asked to review a PR, check a pull request, or audit code changes." metadata: { "requires": { "bins": ["gh", "jq"] } }

PR Review Skill

Review GitHub pull requests with structured analysis covering correctness, security, performance, and style.

Invocation

Triggered by: /review-pr <url-or-number>, "review this PR", "review PR #123", or a GitHub PR URL.

Parse the input:

  • Full URL: https://github.com/owner/repo/pull/123 -> extract owner, repo, number
  • Number only: #123 or 123 -> use current repo from gh repo view --json nameWithOwner -q .nameWithOwner
  • If ambiguous, ask for the repo.

Step 1: Gather Context

Run these in parallel:

# PR metadata
gh pr view <number> --repo <owner/repo> --json title,body,author,baseRefName,headRefName,createdAt,additions,deletions,changedFiles,labels,reviewRequests,mergeable,state

# Full diff
gh pr diff <number> --repo <owner/repo>

# File list with stats
gh pr view <number> --repo <owner/repo> --json files --jq '.files[] | "\(.additions)+/\(.deletions)- \(.path)"'

# CI status
gh pr checks <number> --repo <owner/repo> 2>/dev/null || echo "No checks"

# Existing review comments (avoid duplicating feedback)
gh api repos/<owner>/<repo>/pulls/<number>/comments --jq '.[] | "[\(.path):\(.line // .original_line)] @\(.user.login): \(.body)"' 2>/dev/null | head -50

Step 2: Analyze the Diff

Read the full diff carefully. For each file, evaluate:

Correctness

  • Logic errors, off-by-one, null/undefined handling
  • Missing error handling or edge cases
  • Broken contracts (function signatures changed without updating callers)
  • Race conditions or concurrency issues

Security

  • User input flowing to SQL, shell commands, file paths, or HTML without sanitization
  • Hardcoded secrets, API keys, or credentials
  • Overly broad permissions or missing auth checks
  • Unsafe deserialization or eval usage

Performance

  • O(n^2) or worse algorithms where O(n) is possible
  • Unnecessary re-renders in React (missing memo/useMemo/useCallback)
  • N+1 queries or unbounded data fetching
  • Large allocations in hot paths

Architecture

  • Does this change belong in this file/module?
  • Are abstractions appropriate (not too much, not too little)?
  • Does it follow existing patterns in the codebase?
  • Will this be maintainable?

Style

  • Naming clarity
  • Dead code or TODOs left behind
  • Missing types (in TypeScript)
  • Inconsistent formatting (only flag if egregious)

Step 3: Write the Review

Output a structured review in this format:

## PR Review: <title>

**Summary**: 1-3 sentence overview of what this PR does and whether it's ready.

**Verdict**: APPROVE | REQUEST_CHANGES | COMMENT

### Findings

#### <severity-emoji> <category>: <short description>
**File**: `path/to/file.ts` L<line>-L<line>
<explanation of the issue and why it matters>

**Suggested fix**:
\`\`\`diff
- old code
+ new code
\`\`\`

---
(repeat for each finding)

Severity emojis:

  • [blocker] - Must fix before merge. Bugs, security issues, data loss risks.
  • [warning] - Should fix. Performance problems, poor patterns, missing edge cases.
  • [nit] - Optional. Style, naming, minor improvements.
  • [praise] - Good stuff. Call out well-written code (do this at least once).

Guidelines

  • Be specific. Quote the code, give line numbers, explain why.
  • Suggest fixes, not just problems. Include diff snippets.
  • Don't nitpick formatting if there's a formatter configured.
  • If the PR is large (>500 lines), focus on the riskiest files first.
  • If the PR description explains a deliberate tradeoff, don't re-litigate it.
  • Check the test coverage: are new code paths tested? Are edge cases covered?

Step 4: Post the Review (Optional)

Only post to GitHub if the user explicitly asks. Use:

# Post a review comment (not individual line comments)
gh pr review <number> --repo <owner/repo> --comment --body "<review body>"

# Or approve/request changes
gh pr review <number> --repo <owner/repo> --approve --body "<review body>"
gh pr review <number> --repo <owner/repo> --request-changes --body "<review body>"

For inline comments on specific lines:

gh api repos/<owner>/<repo>/pulls/<number>/comments \
  -f body="<comment>" \
  -f path="<file>" \
  -f commit_id="$(gh pr view <number> --repo <owner/repo> --json headRefOid -q .headRefOid)" \
  -F line=<line_number> \
  -f side="RIGHT"

Always show the review to the user first and get confirmation before posting to GitHub.

Quick Mode

For small PRs (<100 lines changed), skip the full structure. Give a concise paragraph covering the key points and verdict.

Batch Review

When reviewing multiple PRs (e.g., "review all open PRs"):

gh pr list --repo <owner/repo> --json number,title,author,additions,deletions --jq '.[] | "#\(.number) \(.title) by @\(.author.login) (+\(.additions)/-\(.deletions))"'

Triage by size and risk, review the largest/riskiest first.

chat Comments (0)

chat_bubble_outline

No comments yet. Be the first to share your thoughts!

Skill Details

GitHub Stars 172
GitHub Forks 22
Created Mar 2026
Last Updated 3 months ago
tools tools debugging

Related Skills

fabric
chevron_right
typescript-expert
chevron_right
break-loop
chevron_right
burp-suite
chevron_right
page-behavior-audit
chevron_right

Build your own?

Join 12,000+ developers contributing to the Claude ecosystem.