MCP HubMCP Hub
Retour aux compétences

polish-claw-project

pjt222
Mis à jour 2 days ago
3 vues
17
2
17
Voir sur GitHub
Métaautomation

À propos

Cette compétence Claude propose un processus structuré en 9 étapes pour contribuer aux projets de l'écosystème OpenClaw. Elle se concentre sur l'audit de code, la prévention des faux positifs et le recoupement des découvertes pour sélectionner les corrections à fort impact. Utilisez-la pour explorer systématiquement les bases de code et créer des demandes de tirage (pull requests) conformes aux conventions des projets.

Installation rapide

Claude Code

Recommandé
Principal
npx skills add pjt222/agent-almanac -a claude-code
Commande PluginAlternatif
/plugin add https://github.com/pjt222/agent-almanac
Git CloneAlternatif
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/polish-claw-project

Copiez et collez cette commande dans Claude Code pour installer cette compétence

Documentation

Polish Claw Project

Structured workflow for contributing to OpenClaw ecosystem projects. The novel value is in Steps 5-7: parallel audit, false positive prevention, and cross-referencing findings against open issues to select high-impact contributions. Mechanical steps (fork, PR creation) delegate to existing skills.

When to Use

  • Contributing to NVIDIA/OpenClaw, NVIDIA/NemoClaw, NVIDIA/NanoClaw, or similar Claw ecosystem repos
  • First-time contributions to an unfamiliar open-source project with security-sensitive architecture
  • When you want a repeatable, auditable contribution workflow rather than ad-hoc fixes
  • After identifying a Claw project that accepts external contributions (check CONTRIBUTING.md)

Inputs

  • Required: repo_url — GitHub URL of the target Claw project (e.g., https://github.com/NVIDIA/NemoClaw)
  • Optional:
    • contribution_count — Number of contributions to aim for (default: 1-3)
    • focus — Preferred contribution type: security, tests, docs, bugs, any (default: any)
    • fork_org — GitHub org/user to fork into (default: authenticated user)

Procedure

Step 1: Identify and Verify Target

Confirm the project accepts external contributions and is actively maintained.

  1. Open the repository URL and read CONTRIBUTING.md, CODE_OF_CONDUCT.md, and LICENSE
  2. Check recent commit activity (last 30 days) and open PR merge rate
  3. Verify the project uses a permissive or contribution-friendly license
  4. Read SECURITY.md or security policy if present — note responsible disclosure rules
  5. Identify the primary language, test framework, and CI system

Got: CONTRIBUTING.md exists, commits within last 30 days, clear contribution guidelines.

If fail: If no CONTRIBUTING.md or no recent activity, document why and stop — stale projects rarely merge external PRs.

Step 2: Fork and Clone

Create a working copy of the repository.

  1. Fork: gh repo fork <repo_url> --clone
  2. Set upstream remote: git remote add upstream <repo_url>
  3. Verify: git remote -v shows both origin (fork) and upstream
  4. Sync: git fetch upstream && git checkout main && git merge upstream/main

Got: Local clone with both remotes configured and up to date.

If fail: If fork fails, check GitHub authentication (gh auth status). If clone is slow, try --depth=1 for initial exploration.

Step 3: Explore Codebase

Build a mental model of the project architecture.

  1. Read README.md for architecture overview and project goals
  2. Identify entry points, core modules, and public API surface
  3. Map the test structure: where tests live, what framework, coverage level
  4. Note code style conventions: linter config, naming patterns, import style
  5. Check for Docker/container setup, CI configuration, and deployment patterns

Got: Clear understanding of project structure, conventions, and where contributions would fit.

If fail: If architecture is unclear, focus on a specific subsystem rather than the whole project.

Step 4: Read Open Issues

Survey existing issues to understand project needs and avoid duplicate work.

  1. List open issues: gh issue list --state open --limit 50
  2. Categorize by type: bugs, features, docs, security, good-first-issue
  3. Note issues labeled help wanted, good first issue, or hacktoberfest
  4. Check for stale issues (>90 days open, no recent comments) — these may be abandoned
  5. Read any linked PRs to understand attempted solutions

Got: Categorized list of unclaimed issues with type labels.

If fail: If no open issues exist, proceed to Step 5 — audit may uncover unlisted improvements.

Step 5: Parallel Audit

Run security and code quality audits in parallel. This is where novel findings emerge.

  1. Run security-audit-codebase skill against the project root
  2. Simultaneously run review-codebase skill with scope quality
  3. Critical: verify each finding against the project's threat model and architecture
    • A "hardcoded secret" in a sandbox bootstrap script is not a vulnerability
    • A missing input validation on an internal-only function is low severity
    • A dependency flagged as vulnerable may already be mitigated by the project's architecture
  4. Rate verified findings: CRITICAL, HIGH, MEDIUM, LOW
  5. Document false positives with reasoning — they inform Common Pitfalls for future runs

Got: List of verified findings with severity ratings and false positive annotations.

If fail: If no findings emerge, shift focus to test coverage gaps, documentation improvements, or developer experience enhancements.

Step 6: Cross-Reference Findings

Map verified audit findings to open issues — the core judgment step.

  1. For each verified finding, search open issues for related discussions
  2. Categorize each finding as:
    • Matches open issue — link the finding to the issue
    • New finding — no existing issue covers this
    • Already fixed in PR — check open PRs for in-progress fixes
  3. Prioritize findings that match existing issues (highest merge probability)
  4. For new findings, assess whether the maintainers would welcome the fix based on project priorities

Got: Prioritized list with finding-to-issue mapping and merge probability assessment.

If fail: If all findings are already addressed, return to Step 4 and look for documentation, test, or developer experience contributions.

Step 7: Select Contributions

Pick 1-3 contributions based on impact, effort, and expertise.

  1. Score each candidate on:
    • Impact: How much does this improve the project? (security > bugs > tests > docs)
    • Effort: Can this be done well in a focused session? (prefer small, complete PRs)
    • Expertise: Does the contributor have domain knowledge for this fix?
    • Merge probability: Does this match stated project priorities?
  2. Select the top candidates (default: 1-3)
  3. For each, define: branch name, scope boundary, acceptance criteria, test plan

Got: 1-3 selected contributions with clear scope and acceptance criteria.

If fail: If no contributions score well, consider filing well-written issues instead of PRs.

Step 8: Implement

Create a branch per contribution and implement the fix.

  1. For each contribution: git checkout -b fix/<description>
  2. Follow project conventions exactly (linter, naming, import style)
  3. Add or update tests covering the change
  4. Run the project's test suite: verify all tests pass
  5. Run the project's linter: verify no new warnings
  6. Keep each PR focused — one logical change per branch

Got: Clean implementation with passing tests and no linter warnings.

If fail: If tests fail on pre-existing issues, document them and ensure the PR doesn't introduce new failures.

Step 9: Create Pull Requests

Submit contributions following the project's CONTRIBUTING.md.

  1. Push branch: git push origin fix/<description>
  2. Create PR using the create-pull-request skill
  3. Reference the related issue in the PR body (e.g., "Fixes #123")
  4. Follow the project's PR template if one exists
  5. Be responsive to reviewer feedback — iterate quickly

Got: PRs created, linked to issues, following project conventions.

If fail: If PR creation fails, check branch protection rules and contributor license agreements.

Validation

  1. All selected contributions have been implemented and submitted as PRs
  2. Each PR references the related issue (if one exists)
  3. All project tests pass on each PR branch
  4. No false positive findings were submitted as real issues
  5. PR descriptions follow the project's CONTRIBUTING.md template

Pitfalls

  • False positive overclaim: Claw projects use sandbox architectures — a "vulnerability" inside a sandboxed environment may be by design. Always verify against the project's threat model before reporting.
  • Digest/signature chain disruption: Claw projects often use verification chains for model integrity. Changes must preserve these chains or the PR will be rejected.
  • Convention mismatch: Claw projects enforce strict style. Run the project's own linter, not a generic one. Match import ordering, docstring format, and test patterns exactly.
  • Scope creep: 3 focused PRs merge faster than 1 sprawling PR. Keep each contribution atomic.
  • Stale fork: Always sync with upstream before starting work (git fetch upstream && git merge upstream/main).

Related Skills

Dépôt GitHub

pjt222/agent-almanac
Chemin: i18n/caveman-lite/skills/polish-claw-project
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

Compétences associées

content-collections

Méta

Cette compétence propose une configuration éprouvée en production pour Content Collections, un outil axé sur TypeScript qui transforme des fichiers Markdown/MDX en collections de données typées de manière sûre avec une validation Zod. Utilisez-la lors de la création de blogs, de sites de documentation ou d'applications Vite + React riches en contenu pour garantir la sécurité de typage et la validation automatique du contenu. Elle couvre tout, de la configuration du plugin Vite et de la compilation MDX à l'optimisation des déploiements et la validation des schémas.

Voir la compétence

polymarket

Méta

Cette compétence permet aux développeurs de créer des applications avec la plateforme de marchés prédictifs Polymarket, incluant l'intégration d'API pour le trading et les données de marché. Elle fournit également une diffusion de données en temps réel via WebSocket pour surveiller les transactions en direct et l'activité du marché. Utilisez-la pour mettre en œuvre des stratégies de trading ou pour créer des outils traitant les mises à jour de marché en direct.

Voir la compétence

creating-opencode-plugins

Méta

Cette compétence aide les développeurs à créer des plugins OpenCode qui s'interconnectent avec plus de 25 types d'événements tels que les commandes, les fichiers et les opérations LSP. Elle fournit la structure du plugin, les spécifications de l'API événementielle et les modèles d'implémentation pour les modules JavaScript/TypeScript. Utilisez-la lorsque vous avez besoin d'intercepter, de surveiller ou d'étendre le cycle de vie de l'assistant IA OpenCode avec une logique personnalisée pilotée par les événements.

Voir la compétence

sglang

Méta

SGLang est un framework de service LLM haute performance spécialisé dans la génération rapide et structurée pour les workflows JSON, regex et agentiques grâce à son cache de préfixe RadixAttention. Il offre une inférence nettement plus rapide, particulièrement pour les tâches avec des préfixes répétés, ce qui le rend idéal pour les sorties complexes et structurées ainsi que les conversations multi-tours. Choisissez SGLang plutôt que des alternatives comme vLLM lorsque vous avez besoin d'un décodage contraint ou que vous construisez des applications avec un partage étendu de préfixes.

Voir la compétence