From openhands-skills
Distills GitHub PR review comments into reusable skills and AGENTS.md guidelines. Filters noise, categorizes feedback on security, performance, style, architecture, and generates actionable patterns.
npx claudepluginhub openhands/extensionsThis skill uses the workspace's default tool permissions.
Analyze code review comments from GitHub pull requests and distill them into reusable skills or repository guidelines that improve future code quality.
Analyzes merged GitHub PR review comments to extract lessons learned, identify skill gaps and patterns, then applies fixes to skill files.
Builds personalized PR review skill from GitHub review history: extracts comment patterns, communication style, priorities, blind spots; generates review-as-me persona for inline PR comments.
Provides code review guidelines on checks to perform, constructive feedback techniques, and comment standards for PRs and critiques.
Share bugs, ideas, or general feedback.
Analyze code review comments from GitHub pull requests and distill them into reusable skills or repository guidelines that improve future code quality.
Code review feedback contains valuable institutional knowledge that often gets buried across hundreds of PRs. This skill extracts meaningful patterns from review comments and transforms them into:
.openhands/skills/ for domain-specific patternsGITHUB_TOKEN environment variable must be setgh) should be availableDetermine the repository to analyze:
# Get current repo info
gh repo view --json nameWithOwner -q '.nameWithOwner'
If not in a repository, ask the user which repository to analyze.
Retrieve PR review comments from the repository:
# Fetch merged PRs from the last 30 days (adjustable)
gh pr list --repo {owner}/{repo} \
--state merged \
--limit 50 \
--json number,title,mergedAt
# For each PR, fetch review comments
gh api repos/{owner}/{repo}/pulls/{pr_number}/comments \
--jq '.[] | {body: .body, path: .path, user: .user.login, created_at: .created_at}'
# Also fetch review-level comments (not tied to specific lines)
gh api repos/{owner}/{repo}/pulls/{pr_number}/reviews \
--jq '.[] | select(.body != "") | {body: .body, user: .user.login, state: .state}'
Apply noise filtering to keep only meaningful feedback:
Exclude:
Categorize remaining comments by:
For each category with sufficient examples (3+ similar comments), identify:
If clear, actionable patterns emerge, generate focused skill files. If no clear patterns emerge, report this to the user—it's fine to produce no output when the codebase already has strong conventions or when review comments don't cluster into recurring themes.
When creating skills, place them in .openhands/skills/{domain-name}/SKILL.md:
---
name: database-queries
description: Database query patterns and best practices for this repository.
---
# Database Query Guidelines
### Always Use Parameterized Queries
[Pattern description with examples]
### Connection Pool Management
[Pattern description with examples]
Prefer skills over AGENTS.md updates, since AGENTS.md typically already contains general coding guidelines.
Use the create_pr tool to open a draft PR with the proposed changes. The PR description should include:
---
name: api-error-handling
description: API error handling patterns for this repository.
---
# API Error Handling
## Always Return Structured Errors
❌ Avoid:
```python
return {"error": str(e)}
✅ Prefer:
return {
"error": {
"code": "VALIDATION_ERROR",
"message": "Invalid input",
"details": {"field": "email", "reason": "Invalid format"}
}
}
logger.error(f"API error in {endpoint}: {e}", exc_info=True)
return error_response(e)
## Defaults
This workflow analyzes PRs from the past 30 days by default.
## Best Practices
1. **Run periodically** - Schedule monthly or quarterly to capture evolving patterns
2. **Review before merging** - Generated content is a draft; human review is essential
3. **Iterate** - Refine patterns based on team feedback
4. **Avoid duplication** - Check existing AGENTS.md and skills before adding
5. **Cite sources** - Reference PR numbers when documenting patterns
## Error Handling
Handle these common edge cases gracefully:
- **Repository has few PRs**: If fewer than 10 merged PRs exist in the timeframe, inform the user that there may not be enough data to identify patterns. Proceed with analysis but note the limited sample size.
- **No patterns emerge**: When comments don't cluster into recurring themes (common for well-established codebases), report this to the user and suggest either expanding the time range or that the codebase may already have strong conventions.
- **Token lacks repository access**: If the GitHub API returns 403/404, explain that the token may not have access to the repository and suggest checking token permissions.
- **`gh` CLI unavailable**: Fall back to direct GitHub API calls using `curl` with `$GITHUB_TOKEN`, or inform the user that `gh` needs to be installed.
## Limitations
- Only analyzes accessible repositories (requires appropriate permissions)
- Cannot capture verbal feedback from pair programming or meetings
- Patterns may reflect individual reviewer preferences vs. team consensus
- Historical comments may reference outdated code patterns
## Additional Resources
For posting structured code reviews, see the `github-pr-review` skill.
For creating new skills, see the `skill-creator` skill.