From claude-impl-tools
Runs parallel 3-stage multi-AI reviews (opinions → rebuttals → synthesis) via cmux panel splits for Gemini/Codex, orchestrated by Claude. Auto-detects domains like code-review, market analysis, or risk assessment.
npx claudepluginhub insightflo/claude-impl-tools --plugin claude-impl-toolsThis skill uses the workspace's default tool permissions.
> **multi-ai-review와의 차이**: CLI 순차 호출 대신 cmux 패널 분할로 Stage 1을 진짜 동시 실행.
Runs parallel reviews from 6 reviewers (security, UX/DX, external Codex/Gemini CLIs, domain experts) on code, plans, or requirements for quality gates. Invoke via /review --mode code/plan/clarify.
Runs parallel code reviews with Codex, Gemini, and Claude on git diffs or files, generating an integrated report for multi-AI perspectives.
Splits cmux panels for parallel Codex (code), Gemini (design), and Claude (planning) task execution via log streaming and agent teams. Use /cmux-ai-run for multi-AI workflows in cmux.
Share bugs, ideas, or general feedback.
multi-ai-review와의 차이: CLI 순차 호출 대신 cmux 패널 분할로 Stage 1을 진짜 동시 실행.
두 가지 실행 모드:
- 기본 모드: Background Agent(코디네이터)가 CLI 호출 +
tail -f로그 스트리밍. SendMessage로 Stage 전환.--live-mode: Claude Chairman이 cmux 명령어로 패널을 직접 제어. CLI 전송 → Read 결과 확인 → Stage 전환까지 직접 수행.
┌────────────────────────────────────────┐
│ Claude (Chairman) — 현재 패널 │
│ 오케스트레이션 + 최종 합성 │
├───────────────────┬────────────────────┤
│ Gemini 패널 │ Codex 패널 │
│ tail -f │ tail -f │
│ gemini-review.log│ codex-review.log │
└───────────────────┴────────────────────┘
cmux ping || { echo "cmux 필요"; exit 1; }
CONFIG="${PROJECT_ROOT}/.claude/cmux-ai-models.yaml"
[ ! -f "$CONFIG" ] && CONFIG="${CLAUDE_PLUGIN_ROOT}/skills/cmux-ai-review/config/models.yaml"
기본값 (config/models.yaml):
gemini-3-flash-preview (Perspective A)gpt-5.4, effort=high (Perspective B)opus (Chairman)프로젝트별 오버라이드: .claude/cmux-ai-models.yaml
gemini-reviewer 에이전트 ──→ 리뷰 + 로그 기록 ──→ SendMessage(summary="opinion-ready")
codex-reviewer 에이전트 ──→ 리뷰 + 로그 기록 ──→ SendMessage(summary="opinion-ready")
↑ 동시 실행 / 패널에서 tail -f로 실시간 확인
SendMessage 수신 후 즉시 전환
gemini-reviewer ← Codex 의견 전달 → 반론 → SendMessage(summary="rebuttal-ready")
codex-reviewer ← Gemini 의견 전달 → 반론 → SendMessage(summary="rebuttal-ready")
Claude ─── 양쪽 의견 + 반론 분석 ──→ Score Card + 최종 판정
요청 텍스트에서 도메인을 자동 감지:
| 키워드 | 도메인 | Gemini 역할 | Codex 역할 |
|---|---|---|---|
| review, PR, code, merge | code-review | 아키텍처/가독성 | 기술/보안/성능 |
| market, stocks, macro | market-regime | 거시/뉴스 | 퀀트/지표 |
| investment, valuation | investment | 시장/전략 | 재무/리스크 |
| risk, security, danger | risk-assessment | 외부위협 | 내부취약점 |
| gate, milestone, Go/No-Go | project-gate | 이해관계자/범위 | 일정/리소스 |
| plan, PRD, design, architecture, council | planning | CTO (아키텍처/확장성) | Security (위협/규정준수) |
감지 실패 시 default 프리셋 적용.
# 로그 파일 먼저 생성 (tail -f가 즉시 열 수 있도록)
mkdir -p .claude/cmux-ai/review
touch .claude/cmux-ai/review/gemini-reviewer.log
touch .claude/cmux-ai/review/codex-reviewer.log
# Agent Teams 세션 생성
TeamCreate(name="cmux-ai-review-{project}-{timestamp}", description="Parallel AI review pipeline")
TaskCreate(team_name=..., subject="stage1-opinions", description="Collect parallel opinions")
TaskCreate(team_name=..., subject="stage2-rebuttals", description="Cross-rebuttal exchange")
# 패널 생성 + 즉시 tail -f 실행
GEMINI_SURFACE=$(cmux new-split down 2>&1 | awk '{print $2}')
CODEX_SURFACE=$(cmux new-split right --surface $GEMINI_SURFACE 2>&1 | awk '{print $2}')
cmux send --surface $GEMINI_SURFACE \
"tail -f .claude/cmux-ai/review/gemini-reviewer.log
"
cmux send --surface $CODEX_SURFACE \
"tail -f .claude/cmux-ai/review/codex-reviewer.log
"
cmux set-status "review" "Stage 1: collecting opinions" --icon doc --color "#ff9500"
cmux set-progress 0.2 --label "Stage 1: starting reviewers..."
각 에이전트(Claude 서브에이전트)는 코디네이터로서 실제 AI CLI를 호출하고, 진행 로그를 기록하며, Stage 전환 시 SendMessage로 보고:
Agent(
subagent_type="builder",
team_name="cmux-ai-review-{project}-{timestamp}",
name="gemini-reviewer",
run_in_background=true,
prompt="""
너는 Gemini CLI 코디네이터다. 직접 리뷰하지 말고,
실제 gemini CLI를 호출해서 리뷰를 수행하라.
## Stage 1: 초기 의견 수집
1. 리뷰 프롬프트 파일 작성:
Write: .claude/cmux-ai/review/gemini-stage1-prompt.md
내용: "{gemini_role} 관점에서 다음을 리뷰하세요: {review_target}
의견을 마크다운 형식으로 출력하세요."
2. 로그 기록:
Bash: echo "[Stage1][$(date +%H:%M:%S)] ▶ gemini -y -p 실행 — {gemini_role} 리뷰" >> .claude/cmux-ai/review/gemini-reviewer.log
3. gemini CLI 호출:
Bash: gemini -y -p "$(cat .claude/cmux-ai/review/gemini-stage1-prompt.md)" 2>&1 | tee .claude/cmux-ai/review/gemini-opinion.md
4. 결과 확인 + 로그:
Bash: echo "[Stage1][$(date +%H:%M:%S)] ✅ Gemini 의견 수집 완료 ($(wc -l < .claude/cmux-ai/review/gemini-opinion.md) lines)" >> .claude/cmux-ai/review/gemini-reviewer.log
5. SendMessage:
Bash: echo "[Stage1][$(date +%H:%M:%S)] ━━━━━━━━━━━━━━━━━━━━━━━━━" >> .claude/cmux-ai/review/gemini-reviewer.log
Bash: echo "[Stage1][$(date +%H:%M:%S)] 🏁 gemini-reviewer Stage1 DONE" >> .claude/cmux-ai/review/gemini-reviewer.log
SendMessage(to="team-lead", message=Read(.claude/cmux-ai/review/gemini-opinion.md), summary="gemini-reviewer: Stage1 DONE — opinion ready")
## Stage 2: 반론 (SendMessage 수신 대기)
수신 시 {codex_opinion}을 받아:
1. 반론 프롬프트 파일 작성:
Write: .claude/cmux-ai/review/gemini-stage2-prompt.md
내용: "아래는 상대(Codex) 리뷰 의견입니다. 반론을 작성하세요.
{수신한 codex_opinion 전체}"
2. 로그:
Bash: echo "[Stage2][$(date +%H:%M:%S)] ▶ gemini -y -p 실행 — Rebuttal" >> .claude/cmux-ai/review/gemini-reviewer.log
3. gemini CLI 호출:
Bash: gemini -y -p "$(cat .claude/cmux-ai/review/gemini-stage2-prompt.md)" 2>&1 | tee .claude/cmux-ai/review/gemini-rebuttal.md
4. 로그 + SendMessage:
Bash: echo "[Stage2][$(date +%H:%M:%S)] ━━━━━━━━━━━━━━━━━━━━━━━━━" >> .claude/cmux-ai/review/gemini-reviewer.log
Bash: echo "[Stage2][$(date +%H:%M:%S)] 🏁 gemini-reviewer Stage2 DONE" >> .claude/cmux-ai/review/gemini-reviewer.log
SendMessage(to="team-lead", message=Read(.claude/cmux-ai/review/gemini-rebuttal.md), summary="gemini-reviewer: Stage2 DONE — rebuttal ready")
## Fallback
gemini CLI 실행 실패 시 → Claude가 직접 리뷰 수행 후 로그에 "[FALLBACK] Claude 직접 처리" 기록.
"""
)
Agent(
subagent_type="builder",
team_name="cmux-ai-review-{project}-{timestamp}",
name="codex-reviewer",
run_in_background=true,
prompt="""
너는 Codex CLI 코디네이터다. 직접 리뷰하지 말고,
실제 codex CLI를 호출해서 리뷰를 수행하라.
## Stage 1: 초기 의견 수집
1. 리뷰 프롬프트 파일 작성:
Write: .claude/cmux-ai/review/codex-stage1-prompt.md
내용: "{codex_role} 관점에서 다음을 리뷰하세요: {review_target}
의견을 마크다운 형식으로 출력하세요."
2. 로그 기록:
Bash: echo "[Stage1][$(date +%H:%M:%S)] ▶ codex exec 실행 — {codex_role} 리뷰" >> .claude/cmux-ai/review/codex-reviewer.log
3. codex CLI 호출:
Bash: codex exec "$(cat .claude/cmux-ai/review/codex-stage1-prompt.md)" 2>&1 | tee .claude/cmux-ai/review/codex-opinion.md
4. 결과 확인 + 로그:
Bash: echo "[Stage1][$(date +%H:%M:%S)] ✅ Codex 의견 수집 완료 ($(wc -l < .claude/cmux-ai/review/codex-opinion.md) lines)" >> .claude/cmux-ai/review/codex-reviewer.log
5. SendMessage:
Bash: echo "[Stage1][$(date +%H:%M:%S)] ━━━━━━━━━━━━━━━━━━━━━━━━━" >> .claude/cmux-ai/review/codex-reviewer.log
Bash: echo "[Stage1][$(date +%H:%M:%S)] 🏁 codex-reviewer Stage1 DONE" >> .claude/cmux-ai/review/codex-reviewer.log
SendMessage(to="team-lead", message=Read(.claude/cmux-ai/review/codex-opinion.md), summary="codex-reviewer: Stage1 DONE — opinion ready")
## Stage 2: 반론 (SendMessage 수신 대기)
수신 시 {gemini_opinion}을 받아:
1. 반론 프롬프트 파일 작성:
Write: .claude/cmux-ai/review/codex-stage2-prompt.md
내용: "아래는 상대(Gemini) 리뷰 의견입니다. 반론을 작성하세요.
{수신한 gemini_opinion 전체}"
2. 로그:
Bash: echo "[Stage2][$(date +%H:%M:%S)] ▶ codex exec 실행 — Rebuttal" >> .claude/cmux-ai/review/codex-reviewer.log
3. codex CLI 호출:
Bash: codex exec "$(cat .claude/cmux-ai/review/codex-stage2-prompt.md)" 2>&1 | tee .claude/cmux-ai/review/codex-rebuttal.md
4. 로그 + SendMessage:
Bash: echo "[Stage2][$(date +%H:%M:%S)] ━━━━━━━━━━━━━━━━━━━━━━━━━" >> .claude/cmux-ai/review/codex-reviewer.log
Bash: echo "[Stage2][$(date +%H:%M:%S)] 🏁 codex-reviewer Stage2 DONE" >> .claude/cmux-ai/review/codex-reviewer.log
SendMessage(to="team-lead", message=Read(.claude/cmux-ai/review/codex-rebuttal.md), summary="codex-reviewer: Stage2 DONE — rebuttal ready")
## Fallback
codex CLI 실행 실패 시 → Claude가 직접 리뷰 수행 후 로그에 "[FALLBACK] Claude 직접 처리" 기록.
"""
)
cmux set-progress 0.35 --label "Stage 1: opinions in progress (see panels)..."
두 SendMessage(summary="...Stage1 DONE") 수신 후 즉시 Stage 2 시작:
cmux set-status "review" "Stage 2: cross-rebuttal" --icon arrow.2.squarepath --color "#5856d6"
cmux set-progress 0.55 --label "Stage 2: cross-rebuttal (see panels)..."
각 에이전트에 상대 의견 전달 (에이전트는 위 프롬프트에서 대기 중):
SendMessage(
to="gemini-reviewer",
message="{codex_opinion 전체}",
summary="Stage2: here is Codex opinion, write rebuttal"
)
SendMessage(
to="codex-reviewer",
message="{gemini_opinion 전체}",
summary="Stage2: here is Gemini opinion, write rebuttal"
)
두 SendMessage(summary="...Stage2 DONE") 수신 대기.
cmux set-status "review" "Stage 3: chairman synthesis" --icon star --color "#34c759"
cmux set-progress 0.8 --label "Stage 3: synthesis..."
4개 파일 읽어 Score Card 작성:
gemini_opinion = read(".claude/cmux-ai/review/gemini-opinion.md")
codex_opinion = read(".claude/cmux-ai/review/codex-opinion.md")
gemini_rebuttal = read(".claude/cmux-ai/review/gemini-rebuttal.md")
codex_rebuttal = read(".claude/cmux-ai/review/codex-rebuttal.md")
Chairman 합성 규칙:
Score Card 형식:
## Score Card — {domain} Review
- Overall Grade: A/B/C/D/F
- Score: {N}/100
| Dimension | Score | Key Finding |
|-------------|-------|-------------|
| Security | /25 | ... |
| Performance | /20 | ... |
| Correctness | /20 | ... |
| Maintain. | /25 | ... |
| Style | /10 | ... |
## Critical Issues
- [Critical] {issue}
## Recommendations
1. {recommendation}
결과를 .claude/cmux-ai/review/final-scorecard.md에 저장.
cmux set-progress 1.0 --label "Done"
cmux set-status "review" "complete" --icon checkmark --color "#34c759"
cmux log --level success -- "cmux-ai-review: {grade} ({score}/100)"
cmux notify --title "Review Complete" --body "{grade}: {top finding}"
Chairman이 아래 조건 중 하나 해당 시 Step 3부터 재실행:
최대 2회까지 반복.
메인 Claude (Chairman/오케스트레이터)
├── 로그 파일 생성 → cmux 패널에서 tail -f (실시간 가시화)
├── TeamCreate → 통신 채널 수립
│
├── [Stage 1] Agent(gemini-reviewer, bg) = Claude 코디네이터
│ └── gemini -y -p "리뷰 프롬프트" → 진짜 Gemini가 리뷰
│ Agent(codex-reviewer, bg) = Claude 코디네이터
│ └── codex exec "리뷰 프롬프트" → 진짜 Codex가 리뷰
│ 각자 로그 기록 → SendMessage(summary="Stage1 DONE")
│ ↓ 두 SendMessage 수신 후 즉시 Stage 2
│
├── [Stage 2] SendMessage(gemini-reviewer, {codex_opinion})
│ SendMessage(codex-reviewer, {gemini_opinion})
│ └── 각자 CLI 재호출로 반론 수행
│ 각자 로그 기록 → SendMessage(summary="Stage2 DONE")
│ ↓ 두 SendMessage 수신 후 즉시 Stage 3
│
└── [Stage 3] Chairman Claude 합성 → Score Card 출력
| 상황 | 동작 |
|---|---|
gemini CLI 없음 | Gemini 패널 대신 Claude가 Perspective A 담당 |
codex CLI 없음 | Codex 패널 대신 Claude가 Perspective B 담당 |
| cmux 없음 | /multi-ai-review 사용 권장 |
| Agent 무응답 (5분) | Claude가 직접 해당 역할 수행 |
.claude/cmux-ai/review/
├── gemini-reviewer.log # Gemini 실시간 로그 (패널 표시)
├── codex-reviewer.log # Codex 실시간 로그 (패널 표시)
├── gemini-opinion.md # Stage 1 Gemini
├── codex-opinion.md # Stage 1 Codex
├── gemini-rebuttal.md # Stage 2 Gemini
├── codex-rebuttal.md # Stage 2 Codex
└── final-scorecard.md # Stage 3 결과
Claude Chairman이 cmux 패널에서 CLI를 인터랙티브 세션으로 띄우고, 프롬프트를 주입한 뒤, cmux wait-for 시그널로 Stage 전환을 제어한다. 인터랙티브 세션이므로 Stage 1→2 전환 시 이전 분석 컨텍스트가 유지되어 더 깊은 반론이 가능.
상세 실행 순서, CLI별 옵션, 시그널 컨벤션은 references/live-mode.md 참조.