cross-review-project
Acerca de
Esta habilidad permite que dos instancias de Claude Code realicen revisiones de código estructuradas y recíprocas a través de un intermediario MCP dedicado. Garantiza la calidad de la revisión mediante leyes de escalado QSG que exigen umbrales mínimos de evidencia y una progresión por fases controladas. Úsela cuando necesite un análisis sistemático y respaldado por evidencia entre dos bases de código de diferentes proyectos.
Instalación rápida
Claude Code
Recomendadonpx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/cross-review-projectCopia y pega este comando en Claude Code para instalar esta habilidad
Documentación
Cross-Review Project
2 Claude Code instances review each other via cross-review-mcp broker. QSG scaling laws enforce quality: bundles ≥5 findings → selection regime (Γ_h ≈ 1.67), prevents shallow consensus.
Use When
- 2 projects share arch concerns
- Indep review beyond 1 reviewer
- Cross-pollinate: find patterns missing in other
- Structured evidence-backed verdicts (accept/reject/discuss)
In
- Required: 2 project paths, 2 Claude Code instances
- Required:
cross-review-mcpbroker + MCP server in both - Optional: Focus areas (dirs, patterns, concerns)
- Optional: Agent IDs (def: project dir name)
Do
Step 1: Prereqs
Broker running + both instances reach it.
- Broker configured:
claude mcp list | grep cross-review - Call
get_status→ responsive + no stale agents - Read
cross-review://protocol— markdown doc w/ dims + QSG constraints
Got: Broker responds w/ empty agent list. Protocol readable.
If err: Not configured → claude mcp add cross-review-mcp -- npx cross-review-mcp. Stale agents → deregister each first.
Step 2: Register
- Call
register:agentId: short unique ID (project dir name)project: project namecapabilities:["review", "suggest"]
- Verify:
get_status→ agent at phase"registered" - Wait for peer:
wait_for_phasew/ peer ID + phase"registered"
Got: Both registered. get_status → 2 agents @ "registered".
If err: register fails "already registered" → ID taken from prior. deregister first + re-register.
Step 3: Briefing
Read own codebase, send structured briefing → peer.
- Systematic read:
- Entry pts (main, index, CLI)
- Dep graph (package.json, DESCRIPTION, go.mod)
- Arch patterns (dirs, modules)
- Known issues (TODOs, issues, debt)
- Test coverage (tests, CI)
- Compose
Briefing— structured summary → peer navigates efficiently send_task:from: your IDto: peer IDtype:"briefing"payload: JSON briefing
signal_phase→"briefing"
Got: Briefing sent + phase signaled. Broker enforces briefing pre-review.
If err: send_task rejects → from must = registered ID. Self-sends rejected.
Step 4: Review
Wait peer briefing, review their code, send findings.
wait_for_phasepeer ID +"briefing"poll_tasks→ peer's briefingack_tasksw/ task IDs (peek-then-ack req)- Read peer's src, informed by briefing
- Findings, 6 cats:
pattern_transfer— pattern in yours peer could adoptmissing_practice— practice peer lacks (testing, valid., err handling)inconsistency— internal contradiction in peersimplification— unnecessary complexitybug_risk— potential runtime fail / edge casedocumentation_gap— missing / misleading docs
- Each finding:
id: unique ("F-001")category: 1 of 6targetFile: path in peerdescription: what foundevidence: why valid (code refs, patterns)sourceAnalog(rec): equivalent in yours → single mech for genuine cross-pollination
- Bundle ≥5 findings (QSG: m ≥ 5 keeps Γ_h ≈ 1.67 selection regime)
send_tasktype"review_bundle"+ JSON findings arraysignal_phase→"review"
Got: Bundle accepted. <5 → rejected.
If err: Rejected for <5 → review deeper. Constraint prevents shallow dominating. Can't find 5 → reconsider if cross-review fits.
Step 5: Dialogue
Receive findings about yours → respond w/ verdicts.
wait_for_phasepeer +"review"poll_tasks→ findings about yoursack_tasks- Per finding,
FindingResponse:findingId: matches finding's IDverdict:"accept"(valid, will act) /"reject"(invalid + counter-evidence) /"discuss"(needs clarify)evidence: why accept/reject — must be non-emptycounterEvidence(opt): code refs contradicting
- Send all →
send_tasktype"response" signal_phase→"dialogue"
Note: "discuss" not gated → flag for manual follow-up, not auto sub-exchange.
Got: All findings → verdict. Empty → rejected.
If err: Can't form opinion → default "discuss" + evidence explaining what context needed.
Step 6: Synthesis
Produce synth artifact: accepted findings + planned actions.
wait_for_phasepeer +"dialogue"- Poll remaining + ack
- Compile
Synthesis:- Accepted + planned actions (what change + why)
- Rejected + reasons (preserves reasoning)
send_tasktype"synthesis"+ JSON synthsignal_phase→"synthesis"- Optional: create GH issues for accepted
signal_phase→"complete"deregister→ cleanup
Got: Both reach "complete". Broker req ≥2 registered to advance.
If err: Peer already deregistered → complete locally. Compile synth from received.
Check
- Both registered + reached
"complete" - Briefings exchanged pre-review (phase enforced)
- Bundles ≥5 findings each
- All findings → verdict + evidence
-
ack_tasksafter everypoll_tasks - Synth produced + actions mapped
- Deregistered post-complete
Traps
- <5 findings: Broker rejects m<5. Not arbitrary — N=2 agents × 6 cats, m<5 → Γ_h at/below critical → consensus = noise. Review deeper; can't find 5 → projects may not benefit.
- Forgot
ack_tasks: Peek-then-ack delivery. Tasks stay in queue until acked. Forget → dup processing on next poll. - Forgot
fromparam:send_taskneeds explicitfrom= your ID. Self-sends rejected. - Same-model epistemic correlation: 2 Claude share training biases. Temporal ordering prevents reading during review, but priors correlated. Genuine epistemic indep → diff model families.
- Skip
sourceAnalog: Optional but single mech for genuine cross-pollination — shows your impl of pattern. Populate when exists. - Treat
discussas blocking: Protocol doesn't gatecompleteon pending discussions. Flag for manual follow-up post-session. - Skip telemetry: Broker logs all → JSONL. Post-session, validate QSG: estimate α empirical (
α ≈ 1 - reject_rate) + check per-cat accept rates.
→
scaffold-mcp-server— build/extend brokerimplement-a2a-server— A2A patterns broker draws fromreview-codebase— single-agent (this extends → cross-agent structured)build-consensus— swarm consensus (QSG theoretical foundation)configure-mcp-server— broker as MCP in Claude Codeunleash-the-agents— analyze broker itself (battle-tested: 40 agents, 10 hypothesis families)
Repositorio GitHub
Habilidades relacionadas
qmd
Desarrolloqmd es una herramienta CLI de búsqueda e indexación local que permite a los desarrolladores indexar y buscar en archivos locales mediante búsqueda híbrida que combina BM25, embeddings vectoriales y reranking. Es compatible tanto con uso desde la línea de comandos como con modo MCP (Model Context Protocol) para integración con Claude. La herramienta utiliza Ollama para los embeddings y almacena los índices localmente, lo que la hace ideal para buscar documentación o bases de código directamente desde la terminal.
subagent-driven-development
DesarrolloEsta habilidad ejecuta planes de implementación asignando un nuevo subagente para cada tarea independiente, con revisión de código entre tareas. Permite una iteración rápida mientras mantiene controles de calidad a través de este proceso de revisión. Úsala cuando trabajes en tareas mayormente independientes dentro de la misma sesión para garantizar un progreso continuo con verificaciones de calidad integradas.
mcporter
DesarrolloLa habilidad mcporter permite a los desarrolladores gestionar y llamar servidores del Protocolo de Contexto de Modelo (MCP) directamente desde Claude. Proporciona comandos para listar servidores disponibles, llamar a sus herramientas con argumentos, y manejar la autenticación y el ciclo de vida del daemon. Utiliza esta habilidad para integrar y probar la funcionalidad de servidores MCP en tu flujo de trabajo de desarrollo.
adk-deployment-specialist
DesarrolloEsta habilidad despliega y orquesta agentes Vertex AI ADK utilizando el protocolo A2A, gestionando el descubrimiento de AgentCard, el envío de tareas y soportando herramientas como el Sandbox de Ejecución de Código y el Banco de Memoria. Permite construir sistemas multiagente con patrones de orquestación secuencial, paralela o en bucle en Python, Java o Go. Úsela cuando se le solicite desplegar agentes ADK u orquestar flujos de trabajo de agentes en Google Cloud.
