pr-writing-review

Extract editorial feedback from GitHub PRs to learn from review improvements.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "pr-writing-review" with this command: npx skills add evalstate/fast-agent/evalstate-fast-agent-pr-writing-review

PR Writing Review

Extract editorial feedback from GitHub PRs to learn from review improvements.

Prerequisites

  • GitHub CLI: gh installed

  • Authenticated gh session: gh auth status should show you’re logged in

  • For private repos, your token needs appropriate scopes (typically repo ).

  • Python: 3.12+

  • uv (recommended): https://github.com/astral-sh/uv

Division of Labor

Tool Responsibility

Python script API calls, parsing, file tracking across renames, structured extraction

LLM analysis Pattern recognition, paragraph comparison, style lesson synthesis

Quick Start

All paths are relative to the directory containing this SKILL.md file. Before running any script, first cd to that directory or use the full path.

Get suggestions and feedback

uv run scripts/extract_pr_reviews.py <pr_url>

Get full first→final comparison for deep analysis

uv run scripts/extract_pr_reviews.py <pr_url> --diff

Same as above, but cap each FIRST/FINAL dump to 2k chars for LLM prompting

uv run scripts/extract_pr_reviews.py <pr_url> --diff --max-file-chars 2000

Workflow

Step 1: Extract with --diff

uv run scripts/extract_pr_reviews.py https://github.com/org/repo/pull/123 --diff

This outputs:

  • Explicit Suggestions — exact before/after text from suggestion blocks (supports multiple suggestion blocks per comment)

  • Reviewer Feedback — plain text comments (the "why" behind changes)

  • File Evolution — first draft and final version of each text file

Tip: add --max-file-chars 2000 to keep each FIRST/FINAL dump lightweight, or pair --diff with --no-files if you only need the suggestion/feedback summaries.

Step 2: Analyze the Output

With the script output, perform this analysis:

A. Catalog the Explicit Suggestions

Create a table of mechanical fixes:

Pattern Original Fixed

Grammar "Its easier" "It's easier"

Filler removal "using this way" "this way"

Capitalization "Image Generation" "image generation"

B. Map Feedback to Changes

For each reviewer feedback comment:

  • Find the relevant section in FIRST DRAFT

  • Find the same section in FINAL VERSION

  • Document what changed and why

Example:

Feedback: "would be nice to end more enthusiastically"

First draft: "...it's simple to add new tools to Claude and use them straight away."

Final: "...Let us know what you find and create in the comments below!"

Lesson: End blog posts with a call-to-action

C. Paragraph-by-Paragraph Comparison

Compare FIRST DRAFT to FINAL VERSION section by section:

  • What was added?

  • What was removed?

  • What was reworded?

  • What structural changes were made?

D. Synthesize Style Patterns

Group findings into categories:

Category Patterns Found

Clarity Passive→active, shorter sentences, remove filler

Precision Vague→specific, "Create"→"Generate"

Tone Added enthusiasm, call-to-action endings

Structure Added transitions, better section flow

Grammar its/it's, subject-verb agreement

Content Added links, examples, context

Script Options

📁 All paths are relative to the directory containing this SKILL.md file.

Flag Output Use Case

(none) Suggestions + feedback Quick review of what reviewers said

--diff

Adds FIRST/FINAL file dumps to the default output Deep analysis of how the author responded

--max-file-chars N

Truncates each FIRST/FINAL block to N chars (appends ...[truncated X chars] ) Keep prompts within LLM token limits

--no-files

Suppresses FIRST/FINAL dumps even when --diff is set When you only need explicit suggestions + reviewer feedback

--json

Raw JSON (includes file_evolutions when --diff without --no-files ) Programmatic processing

Input formats: pass either a full PR URL, owner/repo PR_NUMBER , or owner repo PR_NUMBER .

Output Structure

Default Output

  • Writing Suggestions: Grouped by reviewer, shows original→suggested text (fenced blocks) along with any reviewer note and a permalink back to GitHub

  • Reviewer Feedback: Plain comments without code suggestions, each tagged with its GitHub link

With --diff

  • Explicit Suggestions: Compact before/after pairs, reviewer notes, and GitHub permalinks in one place

  • Reviewer Feedback: Numbered list of requests (same as default view)

  • File Evolution: FIRST DRAFT and FINAL VERSION for each .md /.txt /.rst /.mdx file; add --max-file-chars to truncate each block with a visible ...[truncated X chars] indicator

Handling File Renames

The script traces files through renames by:

  • Checking each commit for rename operations

  • Building a path history (e.g., claudeimages.md → claude-images.md → claude-and-mcp.md )

  • Fetching content using the correct path for each commit

Example Analysis Output

After running the script and performing LLM analysis, produce a summary like:

Style Lessons from PR #123

Mechanical Fixes

  • Fix grammar: "Its" → "It's" (contraction)
  • Lowercase generic terms: "Image Generation" → "image generation"
  • Remove filler: "the output quality of" → "the quality of"

Reviewer-Driven Changes

  • "end more enthusiastically" → Added call-to-action in conclusion
  • "emphasize these are SoTA" → Changed "latest" to "state-of-the-art"
  • "add blurb about MCP Server" → Added explanatory paragraph

Structural Improvements

  • Added transition sentence between sections
  • Simplified setup instructions (3 sentences → 1)
  • Added new bullet point for model flexibility

Limitations

  • Only extracts inline PR review comments (not issue comments or the PR description)

  • Extremely long files can still be heavy; when that happens, lower --max-file-chars or pass --no-files to keep outputs prompt-friendly

{{currentDate}} {{env}}

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Automation

session-investigator

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

github-tools

Interact with GitHub using the `gh` CLI. Use `gh issue`, `gh pr`, `gh run`, and `gh api` for issues, PRs, CI runs, and advanced queries.

Archived SourceRecently Updated
Coding

openclaw-version-monitor

监控 OpenClaw GitHub 版本更新,获取最新版本发布说明,翻译成中文, 并推送到 Telegram 和 Feishu。用于:(1) 定时检查版本更新 (2) 推送版本更新通知 (3) 生成中文版发布说明

Archived SourceRecently Updated
Coding

ask-claude

Delegate a task to Claude Code CLI and immediately report the result back in chat. Supports persistent sessions with full context memory. Safe execution: no data exfiltration, no external calls, file operations confined to workspace. Use when the user asks to run Claude, delegate a coding task, continue a previous Claude session, or any task benefiting from Claude Code's tools (file editing, code analysis, bash, etc.).

Archived SourceRecently Updated