// ๋ฉํฐ AI ์ฝ๋ ๋ฆฌ๋ทฐ ์ค์ผ์คํธ๋ ์ดํฐ. Claude, Codex, Gemini, Droid๋ฅผ ์กฐ์จํ์ฌ ์ข ํฉ์ ์ฝ๋ ๋ฆฌ๋ทฐ ์ํ. "๋ฉํฐ AI ๋ฆฌ๋ทฐ", "์ฝ๋ ๋ฆฌ๋ทฐ", "์ข ํฉ ๋ฆฌ๋ทฐ" ์์ฒญ ์ ํ์ฑํ๋ฉ๋๋ค.
| name | multi-ai-code-review |
| description | ๋ฉํฐ AI ์ฝ๋ ๋ฆฌ๋ทฐ ์ค์ผ์คํธ๋ ์ดํฐ. Claude, Codex, Gemini, Droid๋ฅผ ์กฐ์จํ์ฌ ์ข ํฉ์ ์ฝ๋ ๋ฆฌ๋ทฐ ์ํ. "๋ฉํฐ AI ๋ฆฌ๋ทฐ", "์ฝ๋ ๋ฆฌ๋ทฐ", "์ข ํฉ ๋ฆฌ๋ทฐ" ์์ฒญ ์ ํ์ฑํ๋ฉ๋๋ค. |
์ฌ๋ฌ AI CLI ๋๊ตฌ(Claude Code, Codex, Gemini CLI, Factory.ai Droid)๋ฅผ ์กฐ์จํ์ฌ ์ข ํฉ์ ์ด๊ณ ๋ค๊ฐ์ ์ธ ์ฝ๋ ๋ฆฌ๋ทฐ๋ฅผ ์ํํ๋ ์ค์ผ์คํธ๋ ์ด์ ์์คํ ์ ๋๋ค.
ํต์ฌ ๊ธฐ๋ฅ:
์ด ์คํฌ์ ๋ค์ ์ํฉ์์ ํ์ฑํ๋ฉ๋๋ค:
๋ช ์์ ์์ฒญ:
์๋ ํ์ฑํ:
Your Code
โ
โโโ 4 AI Tools Review in Parallel/Sequential
โ - Claude Code: Architecture & Design
โ - Codex: Correctness & Algorithms
โ - Gemini: Performance & Edge Cases
โ - Droid: Security & Maintainability
โ โ
โ Master Agent Validates
โ - Aggregate reviews
โ - Detect conflicts
โ - Score by priority
โ - Validate feasibility
โ โ
โ Apply Approved Changes
โ - High consensus: auto-apply
โ - Medium: review first
โ - Conflicts: resolve
โ โ
โ Run Tests & Verify
โ โ
โโ Repeat if Improvements Found
Improved Code + Comprehensive Report
Focus: Architecture, design patterns, best practices
Strengths:
Invocation:
Task({
subagent_type: "code-reviewer",
prompt: "Review {files} for architecture and design patterns",
model: "sonnet"
})
Focus: Code correctness, algorithms, logic
Strengths:
Invocation:
codex exec \
"Review {files} for correctness and logic issues"
Focus: Performance optimization, edge cases
Strengths:
Invocation:
gemini code review {files} \
--focus performance \
--output json
Focus: Security, maintainability, CI/CD readiness
Strengths:
Invocation:
droid exec \
"Review {files} for security and maintainability" \
--output-format json
Consistency Check:
Feasibility Check:
Impact Assessment:
Relevance Check:
priorityScore =
(agreementLevel * 0.3) + // How many reviewers agree
(severityRating * 0.4) + // Critical/High/Medium/Low
(1 / complexity * 0.2) + // Implementation difficulty
(impactScope * 0.1) // How many files affected
Agreement Levels:
High Agreement (3+ reviewers, score > 8.0):
Medium Agreement (2 reviewers, score 5.0-8.0):
Low Agreement (1 reviewer, score < 5.0):
Conflicts Detected:
{
"reviewId": "uuid-v4",
"timestamp": "2025-11-19T10:30:00Z",
"target": {
"files": ["src/auth.ts", "src/user.ts"],
"scope": "module"
},
"reviewers": [
{
"name": "claude-code",
"status": "completed",
"duration": "30s",
"issuesFound": 5
},
{
"name": "codex",
"status": "completed",
"duration": "45s",
"issuesFound": 3
},
{
"name": "gemini",
"status": "completed",
"duration": "25s",
"issuesFound": 4
},
{
"name": "droid",
"status": "completed",
"duration": "40s",
"issuesFound": 6
}
],
"issues": [
{
"id": "issue-1",
"severity": "high",
"category": "security",
"location": {
"file": "src/auth.ts",
"line": 42,
"function": "validateToken"
},
"description": "JWT token validation missing expiration check",
"detectedBy": ["codex", "droid"],
"suggestedFix": "Add exp claim validation before accepting token",
"agreementScore": 0.5,
"priorityScore": 8.5
}
],
"conflicts": [
{
"issueIds": ["issue-3", "issue-7"],
"conflictType": "contradictory-solutions",
"description": "Codex suggests async/await, Gemini suggests callbacks for performance",
"resolution": "pending"
}
],
"appliedChanges": [
{
"issueId": "issue-1",
"status": "applied",
"changeType": "code-modification",
"verificationStatus": "passed"
}
],
"iterationSummary": {
"iteration": 1,
"improvementsDelta": 0.35,
"shouldContinue": true,
"nextFocus": ["performance", "edge-cases"]
}
}
Stop When:
Continue When:
Environment Variables (via jelly-dotenv):
CODE_REVIEW_MAX_ITERATIONS=3
CODE_REVIEW_TIMEOUT=600
CODE_REVIEW_PARALLEL=false
CODE_REVIEW_AUTO_APPLY=false
CODE_REVIEW_MIN_AGREEMENT=0.6
Request:
"Review auth.ts using all AI tools"
Workflow:
Request:
"Review authentication module with iterative improvement"
Workflow:
Request:
"Review my uncommitted changes before commit"
Workflow:
git diffRequest:
"Comprehensive review of entire src/ directory"
Workflow:
if (testsFailedAfterChange) {
await rollbackChanges()
await markIssueAsProblematic(issue.id)
await continueWithNextIssue()
}
This skill is invoked by master Claude when users request multi-AI reviews.
Example Workflow:
User: "Review my API with multiple AI perspectives"
Claude Code (Master):
1. Activates jelly-multi-ai-code-review skill
2. Identifies target files (src/api/*)
3. Launches orchestrator
4. Returns comprehensive report to user
Required Skills:
jelly-codex-skill - Codex CLI integrationjelly-gemini - Gemini CLI integrationjelly-droid-skill - Factory.ai Droid integrationjelly-dotenv - Environment configurationOptional Skills:
jelly-taskmaster-parallel - Parallel sub-agent executionManaged by jelly-dotenv:
# AI Model API Keys
ANTHROPIC_API_KEY=sk-ant-...
OPENAI_API_KEY=sk-...
GOOGLE_API_KEY=...
FACTORY_API_KEY=fk-...
# Review Configuration
CODE_REVIEW_MAX_ITERATIONS=3
CODE_REVIEW_TIMEOUT=600
CODE_REVIEW_PARALLEL=false
CODE_REVIEW_AUTO_APPLY=false
CODE_REVIEW_MIN_AGREEMENT=0.6
Sequential (safer, default):
const reviews = []
reviews.push(await launchClaudeReviewer(files))
reviews.push(await launchCodexReviewer(files))
reviews.push(await launchGeminiReviewer(files))
reviews.push(await launchDroidReviewer(files))
Parallel (faster):
const reviews = await Promise.all([
launchClaudeReviewer(files),
launchCodexReviewer(files),
launchGeminiReviewer(files),
launchDroidReviewer(files)
])
โ DO:
โ DON'T:
โ DO:
โ DON'T:
์ฌ์ฉ์: auth.ts ๋ฉํฐ AI๋ก ๋ฆฌ๋ทฐํด์ค
Claude: 4๊ฐ AI๋ก auth.ts๋ฅผ ๋ถ์ํฉ๋๋ค...
## ๋ฆฌ๋ทฐ ๊ฒฐ๊ณผ
### ํฉ์๋ ์ด์ (3๊ฐ AI ์ด์)
1. JWT ๋ง๋ฃ ๊ฒ์ฆ ๋๋ฝ [๋ณด์/์ฌ๊ฐ]
- Claude: โ | Codex: โ | Droid: โ
โ ์๋ ์์ ์ ์ฉ๋จ
### ๋จ์ผ ์๊ฒฌ
- Gemini: async/await ๋์ Promise ์ฒด์ธ ๊ถ์ฅ
โ ์ฌ์ฉ์ ๊ฒฐ์ ํ์
์ฌ์ฉ์: PR ์ฌ๋ฆฌ๊ธฐ ์ ์ src/api/ ์ ์ฒด ๊ฒํ ํด์ค
Claude: src/api/ ๋๋ ํ ๋ฆฌ ์ข
ํฉ ๋ฆฌ๋ทฐ...
## ์ข
ํฉ ๋ฆฌํฌํธ
- ๊ฒํ ํ์ผ: 12๊ฐ
- ๋ฐ๊ฒฌ ์ด์: 8๊ฐ
- ์๋ ์์ : 5๊ฐ
- ์๋ ํ์ธ ํ์: 3๊ฐ
references/architecture.md: ์ํคํ
์ฒ ์์ธreferences/workflow-guide.md: ์ํฌํ๋ก์ฐ ๊ฐ์ด๋