sales-frontend-gemini-cli 0.4.0 → 0.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/dist/common/helper.cjs +234 -20
  2. package/dist/common/helper.cjs.map +1 -1
  3. package/dist/common/helper.d.cts +23 -3
  4. package/dist/common/helper.d.ts +23 -3
  5. package/dist/common/helper.js +228 -21
  6. package/dist/common/helper.js.map +1 -1
  7. package/dist/pr-review/claude/claude-commander.cjs +142 -28
  8. package/dist/pr-review/claude/claude-commander.cjs.map +1 -1
  9. package/dist/pr-review/claude/claude-commander.d.cts +7 -8
  10. package/dist/pr-review/claude/claude-commander.d.ts +7 -8
  11. package/dist/pr-review/claude/claude-commander.js +142 -28
  12. package/dist/pr-review/claude/claude-commander.js.map +1 -1
  13. package/dist/pr-review/claude/installation-claude.cjs +178 -8
  14. package/dist/pr-review/claude/installation-claude.cjs.map +1 -1
  15. package/dist/pr-review/claude/installation-claude.js +177 -8
  16. package/dist/pr-review/claude/installation-claude.js.map +1 -1
  17. package/dist/pr-review/codex/codex-commander.cjs +64 -21
  18. package/dist/pr-review/codex/codex-commander.cjs.map +1 -1
  19. package/dist/pr-review/codex/codex-commander.d.cts +8 -3
  20. package/dist/pr-review/codex/codex-commander.d.ts +8 -3
  21. package/dist/pr-review/codex/codex-commander.js +64 -21
  22. package/dist/pr-review/codex/codex-commander.js.map +1 -1
  23. package/dist/pr-review/codex/installation-codex.cjs +178 -8
  24. package/dist/pr-review/codex/installation-codex.cjs.map +1 -1
  25. package/dist/pr-review/codex/installation-codex.js +177 -8
  26. package/dist/pr-review/codex/installation-codex.js.map +1 -1
  27. package/dist/pr-review/gemini/gemini-commander.cjs +122 -21
  28. package/dist/pr-review/gemini/gemini-commander.cjs.map +1 -1
  29. package/dist/pr-review/gemini/gemini-commander.d.cts +10 -13
  30. package/dist/pr-review/gemini/gemini-commander.d.ts +10 -13
  31. package/dist/pr-review/gemini/gemini-commander.js +122 -21
  32. package/dist/pr-review/gemini/gemini-commander.js.map +1 -1
  33. package/dist/pr-review/gemini/installation-gemini.cjs +178 -8
  34. package/dist/pr-review/gemini/installation-gemini.cjs.map +1 -1
  35. package/dist/pr-review/gemini/installation-gemini.js +177 -8
  36. package/dist/pr-review/gemini/installation-gemini.js.map +1 -1
  37. package/dist/pr-review/review-one-by-one.cjs +679 -157
  38. package/dist/pr-review/review-one-by-one.cjs.map +1 -1
  39. package/dist/pr-review/review-one-by-one.js +679 -157
  40. package/dist/pr-review/review-one-by-one.js.map +1 -1
  41. package/dist/pr-review/review.cjs +630 -132
  42. package/dist/pr-review/review.cjs.map +1 -1
  43. package/dist/pr-review/review.js +630 -132
  44. package/dist/pr-review/review.js.map +1 -1
  45. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/common/helper.ts","../../src/pr-review/claude/claude-commander.ts","../../src/pr-review/claude/installation-claude.ts","../../src/pr-review/codex/codex-commander.ts","../../src/pr-review/codex/installation-codex.ts","../../src/pr-review/gemini/gemini-commander.ts","../../src/pr-review/gemini/installation-gemini.ts","../../src/pr-review/review-one-by-one.ts"],"names":["args","fs","tempDiffPath","reviewFormPath","trace","execSync"],"mappings":"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","file":"review-one-by-one.js","sourcesContent":["import { execSync } from 'child_process';\nimport fs from 'fs';\nimport path from 'path';\nimport readline from 'readline';\nimport { fileURLToPath } from 'url';\n\nimport { AIServiceType } from './types';\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\n\n// 설치된 위치에 맞게 규칙/양식 파일 경로를 계산 (dist에서 src로 이동 등 고려)\n// dist/common/helper.js 가 실행되므로 __dirname은 .../dist/common 입니다.\n// 따라서 ../../src/common/rules 로 이동해야 원본 소스의 규칙 파일을 찾을 수 있습니다.\nexport const rulesPath = path.resolve(__dirname, '../../src/common/rules/review-rules.md');\nexport const namingRulesPath = path.resolve(__dirname, '../../src/common/rules/naming-rule.md');\nexport const codingConventionRulesPath = path.resolve(__dirname, '../../src/common/rules/coding-convention.md');\nexport const reviewFormPath = path.resolve(__dirname, '../../src/common/form/review-form.md');\nexport const reviewFormOneByOnePath = path.resolve(__dirname, '../../src/common/form/review-form-one-by-one.md');\nexport const REPORT_DIR = '.review-report';\nexport const tempDiffPath = 'temp_diff.txt';\nexport const AIServices: AIServiceType[] = ['gemini', 'claude', 'codex'];\nexport const ignoreList = [\n 'package.json',\n '*.yml',\n '*.md',\n '*.lock',\n 'dist/',\n 'node_modules/',\n 'assets/',\n 'public/',\n '*.json',\n '*.yaml',\n '.review-report/' // 생성되는 리포트 폴더도 제외\n];\n\nexport function isTestMode(args: string[] = process.argv.slice(2)) {\n return args.includes('--test');\n}\n\nexport function createTraceLogger(scope: string, args: string[] = process.argv.slice(2)) {\n const enabled = isTestMode(args);\n\n return (step: string, detail?: string) => {\n if (!enabled) {\n return;\n }\n\n console.log(`[TRACE][${scope}] ${step}${detail ? ` | ${detail}` : ''}`);\n };\n}\n\nexport function getNextFilePath(dir: string, baseName: string, extension: string) {\n let counter = 1;\n // eslint-disable-next-line no-constant-condition\n while (true) {\n const filePath = path.join(dir, `${baseName}-${counter}${extension}`);\n if (!fs.existsSync(filePath)) {\n return filePath;\n }\n counter++;\n }\n}\n\nexport function deleteFile(filePath: string) {\n if (fs.existsSync(filePath)) {\n fs.unlinkSync(filePath);\n }\n}\n\n/**\n * 임시파일 삭제\n */\nexport function deleteTempDiff() {\n deleteFile(tempDiffPath);\n}\n\n/**\n * 리뷰 결과 폴더 생성\n */\nexport function createReportDirectory() {\n if (!fs.existsSync(REPORT_DIR)) {\n fs.mkdirSync(REPORT_DIR, { recursive: true });\n }\n}\n\n/**\n * 현재 시간 문자열 생성\n */\nexport function getNowString() {\n const now = new Date();\n const YYYY = now.getFullYear();\n const MM = String(now.getMonth() + 1).padStart(2, '0');\n const DD = String(now.getDate()).padStart(2, '0');\n const HH = String(now.getHours()).padStart(2, '0');\n const mm = String(now.getMinutes()).padStart(2, '0');\n const ss = String(now.getSeconds()).padStart(2, '0');\n\n return `${YYYY}-${MM}-${DD}_${HH}-${mm}-${ss}`;\n}\n\nexport function getGitDiffFilter() {\n // 1. 리뷰 대상 파일 확장자 정의\n const includeExtensions = ['*.ts', '*.tsx', '*.js', '*.jsx'];\n\n // ignoreList 를 import 하여 재사용하여 작성한다.\n const excludePatterns = ignoreList.map((item) => `:(exclude)${item}`);\n\n // const excludePatterns = [':(exclude)*.lock', ':(exclude)dist/', ':(exclude)*.md'];\n\n // 2. 변경된 파일 목록 가져오기 (각 패턴을 따옴표로 감싸서 쉘 에러 방지)\n const quote = (pattern: string) => `\"${pattern}\"`;\n const includeParams = includeExtensions.map(quote).join(' ');\n const excludeParams = excludePatterns.map(quote).join(' ');\n\n return { includeParams, excludeParams };\n}\n\n/**\n * openReport를 OS별로 동작하도록 변경\n * 우선순위:\n * 1. Chrome 시도\n * - macOS: open -a \"Google Chrome\" \"<path>\"\n * - Ubuntu/Linux: google-chrome \"<path>\"\n * 2. 실패 시 기본 브라우저로 폴백\n * - macOS: open \"<path>\"\n * - Ubuntu/Linux: xdg-open \"<path>\"\n * 3. 둘 다 실패하면 에러 출력\n * 4. 미지원 플랫폼이면 플랫폼 경고 출력\n */\nexport function openReport(reportPath: string) {\n const resolvedPath = path.resolve(reportPath);\n const { platform } = process;\n\n const openWithChrome = () => {\n if (platform === 'darwin') {\n execSync(`open -a \"Google Chrome\" \"${resolvedPath}\"`, { stdio: 'ignore' });\n\n return true;\n }\n\n if (platform === 'linux') {\n execSync(`google-chrome \"${resolvedPath}\"`, { stdio: 'ignore' });\n\n return true;\n }\n\n return false;\n };\n\n const openWithDefaultBrowser = () => {\n if (platform === 'darwin') {\n execSync(`open \"${resolvedPath}\"`, { stdio: 'ignore' });\n\n return true;\n }\n\n if (platform === 'linux') {\n execSync(`xdg-open \"${resolvedPath}\"`, { stdio: 'ignore' });\n\n return true;\n }\n\n return false;\n };\n\n try {\n if (openWithChrome()) {\n console.log('🚀 Google Chrome에서 리포트를 열었습니다.');\n\n return;\n }\n } catch {\n // Chrome 실행 실패 시 기본 브라우저로 폴백\n }\n\n try {\n if (openWithDefaultBrowser()) {\n console.log('🚀 기본 브라우저에서 리포트를 열었습니다.');\n\n return;\n }\n } catch (e) {\n console.error('⚠️ 브라우저 열기 실패:', e);\n\n return;\n }\n\n console.error(`⚠️ 지원하지 않는 플랫폼입니다: ${platform}`);\n}\n\nexport function getDiffArgs() {\n const args = process.argv.slice(2);\n const commitIndex = args.indexOf('--commit');\n const { includeParams, excludeParams } = getGitDiffFilter();\n\n let diffArgs = '';\n\n if (commitIndex !== -1) {\n // 특정 커밋 (및 이전 n개) 리뷰\n const commitHash = args[commitIndex + 1];\n if (!commitHash) {\n console.error('❌ 커밋 해시가 제공되지 않았습니다.');\n process.exit(1);\n }\n\n // n값 확인 (optional)\n const nextArg = args[commitIndex + 2];\n let n = 0;\n if (nextArg && !nextArg.startsWith('--')) {\n n = parseInt(nextArg, 10);\n if (isNaN(n)) {\n n = 0;\n }\n }\n\n console.log(`ℹ️ 커밋 '${commitHash}' ${n > 0 ? ` 포함 총 ${n + 1}개의 커밋` : ''}을 리뷰합니다...`);\n diffArgs = `${commitHash}~${n + 1} ${commitHash}`;\n } else {\n // 기본 모드:\n // 1. Unstaged 변경사항 확인\n try {\n const check = execSync(`git diff --name-only -- ${includeParams} ${excludeParams}`).toString();\n if (!check.trim()) {\n console.log('ℹ️ Unstaged 변경사항이 없습니다. 마지막 커밋(HEAD)을 리뷰합니다...');\n diffArgs = 'HEAD~1 HEAD';\n }\n } catch {\n // git diff 실패시 무시\n }\n }\n\n return diffArgs;\n}\n\n// export const ServiceType = {\n// GEMINI: 'gemini',\n// CLAUDE: 'claude',\n// CODEX: 'codex'\n\n// }\n\n/**\n * AI 서비스 선택\n */\nexport function selectAIService() {\n const args = process.argv.slice(2);\n const serviceIndex = args.indexOf('--service');\n const service = args[serviceIndex + 1];\n if (!service) {\n console.error('❌ 서비스가 선택되지 않았습니다.');\n process.exit(1);\n }\n\n return service;\n}\n\n/**\n * 터미널에서 라디오 버튼 형태로 AI 서비스를 선택합니다.\n */\nexport async function showSelectionAIService(): Promise<AIServiceType> {\n let selectedIndex = 0;\n\n // Use readline to handle keypresses\n // 키 입력을 처리하기 위해 readline 인터페이스 사용\n const rl = readline.createInterface({\n input: process.stdin,\n output: process.stdout,\n terminal: true\n });\n\n let firstRender = true;\n\n // Hide cursor\n process.stdout.write('\\u001b[?25l');\n\n const render = () => {\n if (!firstRender) {\n // Move cursor back to the starting line of the selection UI\n // We print (1 question line + services.length lines)\n // 선택 UI의 시작 라인으로 커서 이동 (질문 1줄 + 서비스 목록 N줄)\n readline.moveCursor(process.stdout, 0, -(AIServices.length + 1));\n }\n firstRender = false;\n\n // Clear everything from cursor down to avoid ghosting/overlaps\n // 잔상이나 겹침을 방지하기 위해 커서 위치부터 아래쪽 모두 지움\n readline.clearScreenDown(process.stdout);\n\n process.stdout.write(\n '🤖 AI 서비스를 선택해주세요 (\\u001b[33m↑↓ 방향키\\u001b[0m 이동, \\u001b[33mEnter\\u001b[0m 선택):\\n'\n );\n AIServices.forEach((service, index) => {\n if (index === selectedIndex) {\n process.stdout.write(` \\u001b[36m>\\u001b[0m \\u001b[36m◉\\u001b[0m \\u001b[1m${service}\\u001b[0m\\n`);\n } else {\n process.stdout.write(` ◯ ${service}\\n`);\n }\n });\n };\n\n render();\n\n return new Promise((resolve) => {\n const onData = (data: Buffer) => {\n const key = data.toString();\n if (key === '\\u0003') {\n // Ctrl+C\n process.stdout.write('\\u001b[?25h'); // Show cursor\n process.exit(0);\n }\n if (key === '\\x1b[A') {\n // Up arrow\n selectedIndex = (selectedIndex - 1 + AIServices.length) % AIServices.length;\n render();\n } else if (key === '\\x1b[B') {\n // Down arrow\n selectedIndex = (selectedIndex + 1) % AIServices.length;\n render();\n } else if (key === '\\r' || key === '\\n') {\n // Enter\n process.stdin.removeListener('data', onData);\n process.stdin.setRawMode(false);\n process.stdin.pause();\n rl.close();\n\n // Show cursor\n process.stdout.write('\\u001b[?25h');\n\n console.log(`\\n✅ \\u001b[32m${AIServices[selectedIndex]}\\u001b[0m 서비스가 선택되었습니다.\\n`);\n const result = AIServices[selectedIndex];\n if (result) {\n resolve(result);\n }\n }\n };\n\n process.stdin.setRawMode(true);\n process.stdin.resume();\n process.stdin.on('data', onData);\n });\n}\n","import fs from 'fs';\n\nimport { codingConventionRulesPath, createTraceLogger, namingRulesPath, rulesPath } from '../../common/helper';\n\nconst args = process.argv.slice(2);\nconst trace = createTraceLogger('claude-commander', args);\n\n/**\n * @description\n * Claude Code CLI를 활용한 코드 리뷰 명령어를 생성합니다.\n *\n * 모델 별칭(Alias):\n * 1. sonnet (기본값, 균형 잡힌 성능) - 일반적인 코드 리뷰에 적합\n * 2. opus (최고 성능) - 복잡한 분석, 긴 컨텍스트 처리에 강점\n * 3. haiku (빠른 속도) - 오타 수정, 간단한 리뷰에 적합\n *\n * Claude CLI 기능 활용:\n * - `-p`: 비대화형 모드(print mode)로 실행하여 결과를 stdout으로 출력\n * - `--append-system-prompt-file`: 룰셋/리뷰양식 파일을 시스템 프롬프트에 추가 (Claude가 \"지침\"으로 인식)\n * - `cat diff | claude`: diff 내용을 stdin으로 파이프하여 \"리뷰 대상\"으로 전달\n */\nexport const createClaudeCommand = (tempDiffPath: string, reviewFormPath: string) => {\n trace('createClaudeCommand:start', `tempDiffPath=${tempDiffPath}, reviewFormPath=${reviewFormPath}`);\n\n let modelOption = '';\n\n if (args.includes('--review')) {\n // 최고 성능 모델 (opus)\n // 복잡한 코드 분석, 긴 컨텍스트 처리에 강점\n modelOption = '--model opus';\n trace('model:review', modelOption);\n } else if (args.includes('--flash')) {\n // 속도 우선 모델 (haiku)\n // 오타 수정, 간단한 리뷰에 적합\n modelOption = '--model haiku';\n trace('model:flash', modelOption);\n } else {\n // 사용자 직접 지정\n const modelIndex = args.indexOf('--model');\n // args[modelIndex + 1] 에는 사용자가 지정한 모델명이 들어갑니다.\n // 예: sonnet, opus, haiku, claude-sonnet-4-5-20250929 등\n if (modelIndex !== -1 && args[modelIndex + 1]) {\n console.warn('⚠️ 지정한 모델이 없는 경우, 에러가 발생하니 주의하세요.');\n modelOption = `--model ${args[modelIndex + 1]}`;\n trace('model:custom', modelOption);\n } else {\n console.warn('⚠️ 모델이 지정되지 않았습니다. 기본 모델인 sonnet을 사용합니다.');\n modelOption = '--model sonnet';\n trace('model:default', modelOption);\n }\n }\n\n // 룰셋 파일들을 --append-system-prompt-file 로 시스템 프롬프트에 추가\n // Claude가 \"지침/규칙\"으로 인식하도록 시스템 프롬프트 레벨에 주입\n const rules = [\n { path: rulesPath, display: '룰셋' },\n { path: namingRulesPath, display: '네이밍 규칙' },\n { path: codingConventionRulesPath, display: '코딩 컨벤션' }\n ];\n\n const systemPromptFiles = rules\n .filter((rule) => fs.existsSync(rule.path))\n .map((rule) => `--append-system-prompt-file ${rule.path}`)\n .join(' ');\n trace(\n 'rules:loaded',\n `count=${systemPromptFiles ? systemPromptFiles.split('--append-system-prompt-file').length - 1 : 0}`\n );\n\n // 리뷰 양식도 시스템 프롬프트에 추가 (출력 포맷 지침)\n const reviewFormOption = fs.existsSync(reviewFormPath) ? `--append-system-prompt-file ${reviewFormPath}` : '';\n trace('reviewForm:status', reviewFormOption ? 'exists' : 'missing');\n\n // Claude CLI 명령어 생성\n // cat으로 diff 내용을 stdin 파이프 → Claude가 \"리뷰 대상 데이터\"로 인식\n // -p: 비대화형 모드로 실행\n const command = `cat ${tempDiffPath} | claude ${modelOption} ${systemPromptFiles} ${reviewFormOption} -p \"위 규칙들을 참고하여 이 diff를 코드리뷰해줘. 리뷰양식에 맞춰서 작성해줘.\"`;\n trace('command:created');\n\n // test mode\n if (args.includes('--test')) {\n const safeCommand = command.replace(/\"/g, '\\\\\"');\n trace('test-mode:return-preview');\n\n return `echo \"[TEST MODE] Claude 명령어가 실행되지 않았습니다.\\n\\n생성될 명령어 미리보기:\\n${safeCommand}\"`;\n }\n\n trace('createClaudeCommand:end');\n\n return command;\n};\n","import { execSync } from 'child_process';\n\nimport { createTraceLogger } from '../../common/helper';\n\nconst trace = createTraceLogger('installation-claude');\n\n// claude-cli 설치 확인 및 설치\nexport function checkClaudeCliInstalled() {\n trace('checkClaudeCliInstalled:start');\n try {\n trace('version-check:run', 'claude --version');\n execSync('claude --version', { stdio: 'ignore' });\n trace('version-check:ok');\n } catch {\n trace('version-check:failed', 'install-start');\n console.log(\n 'ℹ️ claude-cli가 설치되어 있지 않습니다. 설치를 진행합니다... npm install -g @anthropic-ai/claude-code'\n );\n try {\n execSync('npm install -g @anthropic-ai/claude-code', { stdio: 'inherit' });\n trace('install:ok', 'exit(1) for login');\n console.log('✅ claude-cli 설치가 완료되었습니다.');\n console.log('⚠️ claude-cli 사용을 위해 인증이 필요합니다.');\n console.log(' 터미널에서 \"claude\" 를 입력하여 브라우저 로그인을 완료한 후, 다시 시도해주세요.');\n process.exit(1);\n } catch (installError) {\n trace('install:failed');\n console.error('❌ claude-cli 설치 중 오류가 발생했습니다. 권한 문제일 수 있습니다 (sudo 필요).');\n console.error(installError);\n process.exit(1);\n }\n }\n trace('checkClaudeCliInstalled:end');\n}\n","import fs from 'fs';\n\nimport { codingConventionRulesPath, createTraceLogger, namingRulesPath, rulesPath } from '../../common/helper';\n\nconst args = process.argv.slice(2);\nconst trace = createTraceLogger('codex-commander', args);\n\n/**\n * @description\n * Codex CLI를 활용한 코드 리뷰 명령어를 생성합니다.\n *\n * 모델 기본값:\n * - --review: gpt-5 (정밀 리뷰)\n * - --flash: gpt-5-mini (빠른 리뷰)\n * - 미지정: gpt-5-mini\n */\nexport const createCodexCommand = (tempDiffPath: string, reviewFormPath: string) => {\n trace('createCodexCommand:start', `tempDiffPath=${tempDiffPath}, reviewFormPath=${reviewFormPath}`);\n let modelOption = '';\n\n if (args.includes('--review')) {\n modelOption = '--model gpt-5';\n trace('model:review', modelOption);\n } else if (args.includes('--flash')) {\n modelOption = '--model gpt-5-mini';\n trace('model:flash', modelOption);\n } else {\n const modelIndex = args.indexOf('--model');\n if (modelIndex !== -1 && args[modelIndex + 1]) {\n console.warn('⚠️ 지정한 모델이 없는 경우, 에러가 발생하니 주의하세요.');\n modelOption = `--model ${args[modelIndex + 1]}`;\n trace('model:custom', modelOption);\n } else {\n console.warn('⚠️ 모델이 지정되지 않았습니다. 기본 모델인 gpt-5-mini를 사용합니다.');\n modelOption = '--model gpt-5-mini';\n trace('model:default', modelOption);\n }\n }\n\n const rules = [rulesPath, namingRulesPath, codingConventionRulesPath]\n .filter((filePath) => fs.existsSync(filePath))\n .map((filePath) => `- ${filePath}`)\n .join('\\n');\n const rulesCount = rules ? rules.split('\\n').length : 0;\n trace('rules:loaded', `count=${rulesCount}`);\n\n const hasReviewForm = fs.existsSync(reviewFormPath);\n const reviewFormLine = hasReviewForm ? `- ${reviewFormPath}` : '';\n trace('reviewForm:status', reviewFormLine ? 'exists' : 'missing');\n\n const prompt = `아래 파일들을 참고해서 코드 리뷰를 진행해줘.\n규칙 파일: \n${rules || '- (없음)'}\n리뷰 양식 파일:\n${reviewFormLine || '- (없음)'}\n리뷰 대상 diff 파일:\n- ${tempDiffPath}\n\n반드시 리뷰 양식에 맞춰 작성해줘.`;\n\n const command = `codex exec ${modelOption} \"${prompt.replace(/\"/g, '\\\\\"')}\"`;\n trace('command:created');\n\n if (args.includes('--test')) {\n const safeCommand = command.replace(/\"/g, '\\\\\"');\n trace('test-mode:return-preview');\n\n return `echo \"[TEST MODE] Codex 명령어가 실행되지 않았습니다.\\n\\n생성될 명령어 미리보기:\\n${safeCommand}\"`;\n }\n\n trace('createCodexCommand:end');\n\n return command;\n};\n","import { execSync } from 'child_process';\n\nimport { createTraceLogger } from '../../common/helper';\n\nconst trace = createTraceLogger('installation-codex');\n\n// codex-cli 설치 확인 및 설치\nexport function checkCodexCliInstalled() {\n trace('checkCodexCliInstalled:start');\n try {\n trace('version-check:run', 'codex --version');\n execSync('codex --version', { stdio: 'ignore' });\n trace('version-check:ok');\n } catch {\n trace('version-check:failed', 'install-start');\n console.log('ℹ️ codex-cli가 설치되어 있지 않습니다. 설치를 진행합니다... npm install -g @openai/codex');\n try {\n execSync('npm install -g @openai/codex', { stdio: 'inherit' });\n trace('install:ok', 'exit(1) for login');\n console.log('✅ codex-cli 설치가 완료되었습니다.');\n console.log('⚠️ codex-cli 사용을 위해 인증이 필요합니다.');\n console.log(' 터미널에서 \"codex login\" 을 입력하여 로그인을 완료한 후, 다시 시도해주세요.');\n process.exit(1);\n } catch (installError) {\n trace('install:failed');\n console.error('❌ codex-cli 설치 중 오류가 발생했습니다. 권한 문제일 수 있습니다 (sudo 필요).');\n console.error(installError);\n process.exit(1);\n }\n }\n trace('checkCodexCliInstalled:end');\n}\n","import fs from 'fs';\n\nimport { codingConventionRulesPath, createTraceLogger, namingRulesPath, rulesPath } from '../../common/helper';\n// gemini 실행 및 결과 캡처\nconst args = process.argv.slice(2);\nconst trace = createTraceLogger('gemini-commander', args);\n\n/**\n * @description\n * Google AI Studio / Vertex AI에서 제공하는 추상적 모델 식별자 (Alias) 목록입니다. 이들은 특정 버전에 고정되지 않고,\n * 구글이 최신이라고 판단하는 모델로 자동 연결됩니다.\n * 1. Pro 계열 (고성능, 밸런스)\n * gemini-pro: 현재 기준 가장 안정적인 최신 Pro 모델 (보통 1.0 Pro 또는 1.5 Pro 중 설정된 기본값)\n * 2. Flash 계열 (빠른 속도, 가성비)\n * gemini-flash: 현재 기준 가장 최신 Flash 모델 (보통 1.5 Flash)\n * 3. Experimental (실험적 기능, 최신 기술)\n * gemini-exp: 가장 실험적인 최신 모델 (가변적)\n * gemini-flash-thinking-exp: 최신의 \"Thinking\" 모델 (사고력 강화)\n * 주의사항\n * gemini-ultra (가장 강력한 모델)는 현재 CLI에서 바로 접근 가능한 공개 Alias가 제한적일 수 있습니다. (주로 pro와 flash 위주로 제공)\n * 추상적인 이름(gemini-pro)을 쓰면 구글 마음대로 모델이 업데이트될 수 있어서,\n * 운영 환경에서는 gemini-1.5-pro-001 처럼 고정된 버전을 쓰는 것이 안전하지만, 개발/테스트용으로는 위 Alias들이 편리합니다.\n */\nexport const createGeminiCommand = (tempDiffPath: string, reviewFormPath: string) => {\n trace('createGeminiCommand:start', `tempDiffPath=${tempDiffPath}, reviewFormPath=${reviewFormPath}`);\n\n let modelOption = '';\n\n if (args.includes('--review')) {\n // 안정적인 고성능 모델\n // 긴 컨텍스트 처리에 강점\n modelOption = '--model pro';\n trace('model:review', modelOption);\n } else if (args.includes('--flash')) {\n // 속도 우선\n // 오타 수정, 간단한 리뷰에 적합\n modelOption = '--model flash';\n trace('model:flash', modelOption);\n } else {\n // 사용자 직접 지정\n const modelIndex = args.indexOf('--model');\n // args[modelIndex + 1] 에는 사용자가 지정한 모델명이 들어갑니다.\n // 예: gemini-pro, gemini-1.5-pro-latest, gemini-1.5-flash, gemini-2.0-flash-exp 등\n if (modelIndex !== -1 && args[modelIndex + 1]) {\n console.warn('⚠️ 지정한 모델이 없는 경우, 에러가 발생하니 주의하세요.');\n modelOption = `--model ${args[modelIndex + 1]}`;\n trace('model:custom', modelOption);\n } else {\n console.warn('⚠️ 모델이 지정되지 않았습니다. 기본 모델인 gemini-flash를 사용합니다.');\n modelOption = '--model flash';\n trace('model:default', modelOption);\n }\n }\n\n // 존재하지 않는 파일은 제외하여 명령어 생성\n const rules = [\n { path: rulesPath, display: '룰셋' },\n { path: namingRulesPath, display: '네이밍 규칙' },\n { path: codingConventionRulesPath, display: '코딩 컨벤션' }\n ];\n\n const validRules = rules\n .filter((rule) => fs.existsSync(rule.path))\n .map((rule) => `@${rule.path}`)\n .join(', ');\n const rulesCount = validRules ? validRules.split(',').length : 0;\n trace('rules:loaded', `count=${rulesCount}`);\n\n // gemini 실행 및 결과 캡처\n // 주의: gemini CLI가 non-interactive 모드로 실행되려면 프롬프트 전달 방식이 중요합니다.\n // 보통 \"query\" 형태로 전달하면 동작하지만, 확실히 하기 위해 필요한 경우 -p 옵션 사용 고려\n const command = `gemini ${modelOption} -p \"다음 규칙들을 참고해서(${validRules}) 이 diff(@${tempDiffPath})를 리뷰해줘. 리뷰양식은 @${reviewFormPath} 에 맞춰서 작성해줘. \"`;\n trace('command:created');\n\n // test mode\n if (args.includes('--test')) {\n const safeCommand = command.replace(/\"/g, '\\\\\"');\n trace('test-mode:return-preview');\n\n return `echo \"[TEST MODE] Gemini 명령어가 실행되지 않았습니다.\\n\\n생성될 명령어 미리보기:\\n${safeCommand}\"`;\n }\n\n trace('createGeminiCommand:end');\n\n return command;\n};\n","import { execSync } from 'child_process';\n\nimport { createTraceLogger } from '../../common/helper';\n\nconst trace = createTraceLogger('installation-gemini');\n\n// gemini-cli 설치 확인 및 설치\nexport function checkGeminiCliInstalled() {\n trace('checkGeminiCliInstalled:start');\n try {\n trace('version-check:run', 'gemini --version');\n execSync('gemini --version', { stdio: 'ignore' });\n trace('version-check:ok');\n } catch {\n trace('version-check:failed', 'install-start');\n console.log('ℹ️ gemini-cli가 설치되어 있지 않습니다. 설치를 진행합니다... npm install -g @google/gemini-cli');\n try {\n execSync('npm install -g @google/gemini-cli', { stdio: 'inherit' });\n trace('install:ok', 'exit(1) for login');\n console.log('✅ gemini-cli 설치가 완료되었습니다.');\n console.log('⚠️ Gemini API 사용을 위해 인증이 필요합니다.');\n console.log(' 터미널에서 \"gemini\" 를 입력하여 브라우저 로그인을 완료한 후, 다시 시도해주세요.');\n process.exit(1);\n } catch (installError) {\n trace('install:failed');\n console.error('❌ gemini-cli 설치 중 오류가 발생했습니다. 권한 문제일 수 있습니다 (sudo 필요).');\n console.error(installError);\n process.exit(1);\n }\n }\n trace('checkGeminiCliInstalled:end');\n}\n","#!/usr/bin/env node\nimport { execSync, exec } from 'child_process';\nimport fs from 'fs';\nimport util from 'util';\n\nconst execAsync = util.promisify(exec);\n\nimport {\n tempDiffPath,\n createTraceLogger,\n getNextFilePath,\n deleteTempDiff,\n deleteFile,\n createReportDirectory,\n REPORT_DIR,\n getNowString,\n getGitDiffFilter,\n reviewFormOneByOnePath,\n getDiffArgs,\n isTestMode,\n openReport,\n showSelectionAIService\n} from '../common/helper';\n\nimport { createClaudeCommand } from './claude/claude-commander';\nimport { checkClaudeCliInstalled } from './claude/installation-claude';\nimport { createCodexCommand } from './codex/codex-commander';\nimport { checkCodexCliInstalled } from './codex/installation-codex';\nimport { createGeminiCommand } from './gemini/gemini-commander';\nimport { checkGeminiCliInstalled } from './gemini/installation-gemini';\n\nasync function main() {\n const args = process.argv.slice(2);\n const isTest = isTestMode(args);\n const trace = createTraceLogger('review-one-by-one', args);\n trace('main:start', `args=${JSON.stringify(args)}`);\n // AI 서비스 선택\n trace('service-selection:start');\n const service = await showSelectionAIService();\n trace('service-selection:done', `service=${service}`);\n\n switch (service) {\n case 'gemini':\n // gemini-cli 설치 확인 및 설치\n trace('install-check:start', 'service=gemini');\n checkGeminiCliInstalled();\n trace('install-check:done', 'service=gemini');\n break;\n case 'claude':\n // claude-cli 설치 확인 및 설치\n trace('install-check:start', 'service=claude');\n checkClaudeCliInstalled();\n trace('install-check:done', 'service=claude');\n break;\n case 'codex':\n // codex-cli 설치 확인 및 설치\n trace('install-check:start', 'service=codex');\n checkCodexCliInstalled();\n trace('install-check:done', 'service=codex');\n break;\n }\n\n try {\n trace('review-flow:start');\n console.log('🚀 AI Code Review를 시작합니다...');\n\n // 리뷰 결과 폴더 생성\n trace('report-dir:create:start');\n createReportDirectory();\n trace('report-dir:create:done');\n\n const { includeParams, excludeParams } = getGitDiffFilter();\n trace('diff-filter:loaded', `include=${includeParams} | exclude=${excludeParams}`);\n\n const diffArgs = getDiffArgs();\n trace('diff-args:build:done', `diffArgs=${diffArgs || '(default)'}`);\n\n const filesCommand = `git diff --name-only ${diffArgs} -- ${includeParams} ${excludeParams}`;\n trace('files-command:run', filesCommand);\n const fileList = execSync(filesCommand).toString().split('\\n').filter(Boolean);\n trace('files-command:done', `fileCount=${fileList.length}`);\n\n if (fileList.length === 0) {\n trace('empty-file-list:exit');\n console.log('ℹ️ 변경 사항이 없습니다.');\n deleteTempDiff();\n\n process.exit(0);\n }\n\n const fullDiffCommand = `git diff ${diffArgs} -- ${includeParams} ${excludeParams}`;\n trace('full-diff:run');\n const fullDiff = execSync(fullDiffCommand).toString();\n const nowStr = getNowString();\n trace('full-diff:done', `length=${fullDiff.length}`);\n trace('timestamp:created', nowStr);\n\n trace('temp-diff:write:start', tempDiffPath);\n fs.writeFileSync(tempDiffPath, fullDiff);\n trace('temp-diff:write:done');\n\n // diff 파일 저장 (.review-report 안으로 복사)\n trace('saved-diff:copy:start');\n const savedDiffPath = getNextFilePath(REPORT_DIR, `${nowStr}-diff`, '.txt');\n fs.copyFileSync(tempDiffPath, savedDiffPath);\n trace('saved-diff:copy:done', savedDiffPath);\n\n // 리뷰 결과 저장\n const savedReportPath = getNextFilePath(REPORT_DIR, nowStr, '.md');\n trace('saved-report:path', savedReportPath);\n\n // let fullReport = '';\n // 병렬 처리를 위해 Promise.all 사용\n const promises = fileList.map(async (file) => {\n try {\n trace('file-review:start', file);\n console.log(`🔍 Reviewing: ${file}...`);\n\n // 3. 개별 파일에 대한 diff 생성\n trace('file-diff:run', file);\n const fileDiff = execSync(`git diff ${diffArgs} -- \"${file}\"`).toString();\n trace('file-diff:done', `${file} | length=${fileDiff.length}`);\n\n const tempOneFileDiffPath = `temp_diff_${file.replace(/\\//g, '_')}.txt`;\n trace('file-temp-diff:write:start', tempOneFileDiffPath);\n fs.writeFileSync(tempOneFileDiffPath, fileDiff);\n trace('file-temp-diff:write:done', tempOneFileDiffPath);\n\n // 4. 명령어 생성\n let command = '';\n trace('file-command:create:start', file);\n switch (service) {\n case 'gemini':\n // gemini-cli 에 맞게 프롬프트 명령어 생성\n command = createGeminiCommand(tempOneFileDiffPath, reviewFormOneByOnePath);\n break;\n case 'claude':\n // claude-cli 에 맞게 프롬프트 명령어 생성\n command = createClaudeCommand(tempOneFileDiffPath, reviewFormOneByOnePath);\n break;\n case 'codex':\n // codex-cli 에 맞게 프롬프트 명령어 생성\n command = createCodexCommand(tempOneFileDiffPath, reviewFormOneByOnePath);\n break;\n }\n trace('file-command:create:done', file);\n\n // 5. AI에게 해당 파일만 리뷰 요청 (비동기 실행)\n // execSync 대신 execAsync 사용. maxBuffer를 넉넉하게 설정\n trace('file-command:exec:start', file);\n const { stdout } = await execAsync(command, { maxBuffer: 1024 * 1024 * 20 });\n const result = stdout.toString();\n trace('file-command:exec:done', `${file} | resultLength=${result.length}`);\n\n // 6. 리뷰 마친후 해당 파일 삭제\n trace('file-temp-diff:delete:start', tempOneFileDiffPath);\n deleteFile(tempOneFileDiffPath);\n trace('file-temp-diff:delete:done', tempOneFileDiffPath);\n\n const tempReport = `### File: ${file}\\n${result}\\n\\n`;\n\n // 콘솔 출력\n console.log(tempReport);\n\n trace('file-report:append:start', file);\n fs.appendFileSync(savedReportPath, tempReport);\n trace('file-report:append:done', file);\n\n // 사용한 명령어도 저장(디버깅용)\n if (isTest) {\n trace('file-test-command:append:start', file);\n fs.appendFileSync(savedReportPath, `\\n\\n## 사용된 명령어\\n\\n${command}`);\n trace('file-test-command:append:done', file);\n }\n trace('file-review:end', file);\n } catch (err) {\n trace('file-review:catch', file);\n console.error(`❌ Error reviewing file ${file}:`, err);\n // 에러 내용도 리포트에 포함\n const errorReport = `### File: ${file}\\n❌ Review Failed\\n\\`\\`\\`\\n${err}\\n\\`\\`\\`\\n\\n`;\n fs.appendFileSync(savedReportPath, errorReport);\n\n // 임시 파일 정리 시도\n try {\n const tempOneFileDiffPath = `temp_diff_${file.replace(/\\//g, '_')}.txt`;\n if (fs.existsSync(tempOneFileDiffPath)) {\n trace('file-temp-diff:delete:start(catch)', tempOneFileDiffPath);\n deleteFile(tempOneFileDiffPath);\n trace('file-temp-diff:delete:done(catch)', tempOneFileDiffPath);\n }\n } catch (e) {\n trace('file-temp-diff:delete:failed(catch)', file);\n console.error(`❌ Error deleting temp file for ${file}:`, e);\n }\n }\n });\n\n trace('parallel-review:await-start');\n await Promise.all(promises);\n trace('parallel-review:await-done');\n\n console.log(`\\n✅ 리뷰가 완료되었습니다.`);\n console.log(`📄 리포트 저장 위치: ${savedReportPath}`);\n console.log(`diff 저장 위치: ${savedDiffPath}`);\n\n // 브라우저 열기\n trace('open-report:start');\n openReport(savedReportPath);\n trace('open-report:done');\n\n trace('cleanup-temp-diff:start');\n deleteTempDiff();\n trace('cleanup-temp-diff:done');\n trace('review-flow:end');\n } catch (error) {\n trace('review-flow:catch');\n console.error('❌ 리뷰 도중 오류가 발생했습니다.');\n console.error(error);\n\n // 임시 파일 삭제\n trace('cleanup-temp-diff:start(catch)');\n deleteTempDiff();\n trace('cleanup-temp-diff:done(catch)');\n\n process.exit(1);\n }\n}\n\nmain();\n"]}
1
+ {"version":3,"sources":["../../src/common/helper.ts","../../src/pr-review/claude/claude-commander.ts","../../src/pr-review/claude/installation-claude.ts","../../src/pr-review/codex/codex-commander.ts","../../src/pr-review/codex/installation-codex.ts","../../src/pr-review/gemini/gemini-commander.ts","../../src/pr-review/gemini/installation-gemini.ts","../../src/pr-review/review-one-by-one.ts"],"names":["args","tempDiffPath","path","reviewFormPath","fs","trace","execSync","ALLOWED_REASONING_EFFORTS","shellQuote","getArgValue","resolveReasoningEffort","toUnique","resolvePrimaryAlias","getAliasFallbacks"],"mappings":"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","file":"review-one-by-one.js","sourcesContent":["import { execSync } from 'child_process';\nimport fs from 'fs';\nimport path from 'path';\nimport readline from 'readline';\nimport { fileURLToPath } from 'url';\nimport { inspect } from 'util';\n\nimport { AIServiceType } from './types';\n\ntype ErrorReportSection = {\n heading: string;\n markdown: string;\n};\n\ntype WriteErrorReportOptions = {\n title?: string;\n scope?: string;\n args?: string[];\n traceMessages?: string[];\n extraSections?: ErrorReportSection[];\n};\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\nconst traceMessages: string[] = [];\n\n// 설치된 위치에 맞게 규칙/양식 파일 경로를 계산 (dist에서 src로 이동 등 고려)\n// dist/common/helper.js 가 실행되므로 __dirname은 .../dist/common 입니다.\n// 따라서 ../../src/common/rules 로 이동해야 원본 소스의 규칙 파일을 찾을 수 있습니다.\nexport const rulesPath = path.resolve(__dirname, '../../src/common/rules/review-rules.md');\nexport const namingRulesPath = path.resolve(__dirname, '../../src/common/rules/naming-rule.md');\nexport const codingConventionRulesPath = path.resolve(__dirname, '../../src/common/rules/coding-convention.md');\nexport const reviewFormPath = path.resolve(__dirname, '../../src/common/form/review-form.md');\nexport const reviewFormOneByOnePath = path.resolve(__dirname, '../../src/common/form/review-form-one-by-one.md');\nexport const REPORT_DIR = '.review-report';\nexport const tempDiffPath = 'temp_diff.txt';\nexport const AIServices: AIServiceType[] = ['gemini', 'claude', 'codex'];\nexport const ignoreList = [\n 'package.json',\n '*.yml',\n '*.md',\n '*.lock',\n 'dist/',\n 'node_modules/',\n 'assets/',\n 'public/',\n '*.json',\n '*.yaml',\n '.review-report/' // 생성되는 리포트 폴더도 제외\n];\n\nexport function isTestMode(args: string[] = process.argv.slice(2)) {\n return args.includes('--test');\n}\n\nexport function clearTraceMessages() {\n traceMessages.length = 0;\n}\n\nexport function getTraceMessages() {\n return [...traceMessages];\n}\n\nexport function createTraceLogger(scope: string, args: string[] = process.argv.slice(2)) {\n const enabled = isTestMode(args);\n\n return (step: string, detail?: string) => {\n const timestamp = new Date().toISOString();\n const message = `[${timestamp}][TRACE][${scope}] ${step}${detail ? ` | ${detail}` : ''}`;\n traceMessages.push(message);\n\n if (!enabled) {\n return;\n }\n\n console.log(message);\n };\n}\n\nconst helperTrace = createTraceLogger('helper');\n\nfunction getTimestampParts(now = new Date()) {\n return {\n YYYY: now.getFullYear(),\n MM: String(now.getMonth() + 1).padStart(2, '0'),\n DD: String(now.getDate()).padStart(2, '0'),\n HH: String(now.getHours()).padStart(2, '0'),\n mm: String(now.getMinutes()).padStart(2, '0'),\n ss: String(now.getSeconds()).padStart(2, '0')\n };\n}\n\nfunction getHumanReadableNowString(now = new Date()) {\n const { YYYY, MM, DD, HH, mm, ss } = getTimestampParts(now);\n\n return `${YYYY}-${MM}-${DD} ${HH}:${mm}:${ss}`;\n}\n\nfunction stringifyUnknown(value: unknown) {\n if (value === undefined || value === null) {\n return '';\n }\n\n if (typeof value === 'string') {\n return value;\n }\n\n if (Buffer.isBuffer(value)) {\n return value.toString();\n }\n\n if (value instanceof Error) {\n return value.stack || value.message;\n }\n\n return inspect(value, { depth: 5, breakLength: 120 });\n}\n\nexport function getErrorSummary(error: unknown) {\n if (error instanceof Error) {\n return `${error.name}: ${error.message}`;\n }\n\n return stringifyUnknown(error) || 'Unknown error';\n}\n\nfunction serializeError(error: unknown) {\n const serialized: Record<string, unknown> = {\n summary: getErrorSummary(error)\n };\n\n if (error instanceof Error) {\n serialized.name = error.name;\n serialized.message = error.message;\n serialized.stack = error.stack;\n } else {\n serialized.value = stringifyUnknown(error);\n }\n\n if (error && typeof error === 'object') {\n const errorLike = error as Record<string, unknown>;\n const extraKeys = ['code', 'errno', 'syscall', 'path', 'cmd', 'status', 'signal', 'spawnargs'];\n\n extraKeys.forEach((key) => {\n if (errorLike[key] !== undefined) {\n serialized[key] = errorLike[key];\n }\n });\n\n const stdout = stringifyUnknown(errorLike.stdout);\n if (stdout) {\n serialized.stdout = stdout;\n }\n\n const stderr = stringifyUnknown(errorLike.stderr);\n if (stderr) {\n serialized.stderr = stderr;\n }\n\n const cause = stringifyUnknown(errorLike.cause);\n if (cause) {\n serialized.cause = cause;\n }\n }\n\n return serialized;\n}\n\nexport function getNextFilePath(dir: string, baseName: string, extension: string) {\n let counter = 1;\n // eslint-disable-next-line no-constant-condition\n while (true) {\n const filePath = path.join(dir, `${baseName}-${counter}${extension}`);\n if (!fs.existsSync(filePath)) {\n return filePath;\n }\n counter++;\n }\n}\n\nexport function getAvailableFilePath(dir: string, baseName: string, extension: string) {\n const firstFilePath = path.join(dir, `${baseName}${extension}`);\n if (!fs.existsSync(firstFilePath)) {\n return firstFilePath;\n }\n\n return getNextFilePath(dir, baseName, extension);\n}\n\nexport function deleteFile(filePath: string) {\n if (fs.existsSync(filePath)) {\n fs.unlinkSync(filePath);\n }\n}\n\n/**\n * 임시파일 삭제\n */\nexport function deleteTempDiff() {\n deleteFile(tempDiffPath);\n}\n\n/**\n * 리뷰 결과 폴더 생성\n */\nexport function createReportDirectory() {\n if (!fs.existsSync(REPORT_DIR)) {\n fs.mkdirSync(REPORT_DIR, { recursive: true });\n }\n}\n\n/**\n * 현재 시간 문자열 생성\n */\nexport function getNowString(now = new Date()) {\n const { YYYY, MM, DD, HH, mm, ss } = getTimestampParts(now);\n\n return `${YYYY}-${MM}-${DD}_${HH}-${mm}-${ss}`;\n}\n\nexport function getErrorLogTimestamp(now = new Date()) {\n const { YYYY, MM, DD, HH, mm, ss } = getTimestampParts(now);\n\n return `${YYYY}-${MM}-${DD}-${HH}시-${mm}분-${ss}초`;\n}\n\nexport function writeErrorReport(error: unknown, options: WriteErrorReportOptions = {}) {\n try {\n const now = new Date();\n helperTrace('error-report:write:start', options.scope || 'unknown');\n createReportDirectory();\n\n const reportPath = getAvailableFilePath(REPORT_DIR, `error-log-${getErrorLogTimestamp(now)}`, '.md');\n const serializedError = serializeError(error);\n const traceSnapshot = options.traceMessages ?? getTraceMessages();\n const extraSections = options.extraSections || [];\n\n const report = `# Error Log\n\n- 발생 시각: ${getHumanReadableNowString(now)}\n- Scope: \\`${options.scope || 'unknown'}\\`\n- 작업 경로: \\`${process.cwd()}\\`\n- 실행 인자: \\`${JSON.stringify(options.args ?? process.argv.slice(2))}\\`\n- 실행 환경: \\`${process.platform} ${process.arch} / Node ${process.version}\\`\n\n## Summary\n\n${options.title || serializedError.summary || 'Unknown error'}\n\n## Error\n\n\\`\\`\\`json\n${JSON.stringify(serializedError, null, 2)}\n\\`\\`\\`\n\n## Trace\n\n\\`\\`\\`json\n${JSON.stringify(traceSnapshot, null, 2)}\n\\`\\`\\`${extraSections.length ? `\\n${extraSections.map((section) => `\\n## ${section.heading}\\n\\n${section.markdown}`).join('\\n')}\\n` : '\\n'}\n`;\n\n fs.writeFileSync(reportPath, report);\n helperTrace('error-report:write:done', reportPath);\n\n return reportPath;\n } catch (writeError) {\n console.error('⚠️ 에러 로그 파일 생성에 실패했습니다.');\n console.error(writeError);\n\n return '';\n }\n}\n\nexport function exitWithError(\n message: string,\n options: Omit<WriteErrorReportOptions, 'title'> & { error?: unknown } = {}\n): never {\n const reportPath = writeErrorReport(options.error || new Error(message), {\n ...options,\n title: message\n });\n\n console.error(message);\n\n if (options.error) {\n console.error(options.error);\n }\n\n if (reportPath) {\n console.error(`📄 에러 로그 저장 위치: ${reportPath}`);\n }\n\n process.exit(1);\n}\n\nfunction parseServiceFromArgs(args: string[] = process.argv.slice(2)): AIServiceType | '' {\n helperTrace('parse-service:start', `args=${JSON.stringify(args)}`);\n const serviceIndex = args.indexOf('--service');\n const rawService = serviceIndex !== -1 ? args[serviceIndex + 1] : '';\n\n if (!rawService) {\n helperTrace('parse-service:empty');\n\n return '';\n }\n\n const normalizedService = rawService.toLowerCase();\n\n if (AIServices.includes(normalizedService as AIServiceType)) {\n helperTrace('parse-service:resolved', normalizedService);\n\n return normalizedService as AIServiceType;\n }\n\n helperTrace('parse-service:invalid', rawService);\n exitWithError(\n `❌ 지원하지 않는 서비스입니다: ${rawService}. 사용 가능 값: ${AIServices.join(', ')} (예: --service codex)`,\n {\n scope: 'helper:parseServiceFromArgs',\n args,\n extraSections: [\n {\n heading: 'Allowed Services',\n markdown: `\\`\\`\\`json\\n${JSON.stringify(AIServices, null, 2)}\\n\\`\\`\\``\n }\n ]\n }\n );\n}\n\nexport function getGitDiffFilter() {\n // 1. 리뷰 대상 파일 확장자 정의\n const includeExtensions = ['*.ts', '*.tsx', '*.js', '*.jsx'];\n\n // ignoreList 를 import 하여 재사용하여 작성한다.\n const excludePatterns = ignoreList.map((item) => `:(exclude)${item}`);\n\n // const excludePatterns = [':(exclude)*.lock', ':(exclude)dist/', ':(exclude)*.md'];\n\n // 2. 변경된 파일 목록 가져오기 (각 패턴을 따옴표로 감싸서 쉘 에러 방지)\n const quote = (pattern: string) => `\"${pattern}\"`;\n const includeParams = includeExtensions.map(quote).join(' ');\n const excludeParams = excludePatterns.map(quote).join(' ');\n\n return { includeParams, excludeParams };\n}\n\n/**\n * openReport를 OS별로 동작하도록 변경\n * 우선순위:\n * 1. Chrome 시도\n * - macOS: open -a \"Google Chrome\" \"<path>\"\n * - Ubuntu/Linux: google-chrome \"<path>\"\n * 2. 실패 시 기본 브라우저로 폴백\n * - macOS: open \"<path>\"\n * - Ubuntu/Linux: xdg-open \"<path>\"\n * 3. 둘 다 실패하면 에러 출력\n * 4. 미지원 플랫폼이면 플랫폼 경고 출력\n */\nexport function openReport(reportPath: string) {\n const resolvedPath = path.resolve(reportPath);\n const { platform } = process;\n helperTrace('open-report:start', resolvedPath);\n\n const openWithChrome = () => {\n if (platform === 'darwin') {\n execSync(`open -a \"Google Chrome\" \"${resolvedPath}\"`, { stdio: 'ignore' });\n\n return true;\n }\n\n if (platform === 'linux') {\n execSync(`google-chrome \"${resolvedPath}\"`, { stdio: 'ignore' });\n\n return true;\n }\n\n return false;\n };\n\n const openWithDefaultBrowser = () => {\n if (platform === 'darwin') {\n execSync(`open \"${resolvedPath}\"`, { stdio: 'ignore' });\n\n return true;\n }\n\n if (platform === 'linux') {\n execSync(`xdg-open \"${resolvedPath}\"`, { stdio: 'ignore' });\n\n return true;\n }\n\n return false;\n };\n\n try {\n if (openWithChrome()) {\n helperTrace('open-report:chrome:success', platform);\n console.log('🚀 Google Chrome에서 리포트를 열었습니다.');\n\n return;\n }\n } catch (error) {\n helperTrace('open-report:chrome:failed', getErrorSummary(error));\n // Chrome 실행 실패 시 기본 브라우저로 폴백\n }\n\n try {\n if (openWithDefaultBrowser()) {\n helperTrace('open-report:default-browser:success', platform);\n console.log('🚀 기본 브라우저에서 리포트를 열었습니다.');\n\n return;\n }\n } catch (error) {\n helperTrace('open-report:default-browser:failed', getErrorSummary(error));\n console.error('⚠️ 브라우저 열기 실패:', error);\n\n return;\n }\n\n helperTrace('open-report:unsupported-platform', platform);\n console.error(`⚠️ 지원하지 않는 플랫폼입니다: ${platform}`);\n}\n\nexport function getDiffArgs() {\n const args = process.argv.slice(2);\n const commitIndex = args.indexOf('--commit');\n const { includeParams, excludeParams } = getGitDiffFilter();\n helperTrace('diff-args:resolve:start', `args=${JSON.stringify(args)}`);\n\n let diffArgs = '';\n\n if (commitIndex !== -1) {\n // 특정 커밋 (및 이전 n개) 리뷰\n const commitHash = args[commitIndex + 1];\n if (!commitHash) {\n helperTrace('diff-args:commit-hash-missing');\n exitWithError('❌ 커밋 해시가 제공되지 않았습니다.', {\n scope: 'helper:getDiffArgs',\n args\n });\n }\n\n // n값 확인 (optional)\n const nextArg = args[commitIndex + 2];\n let n = 0;\n if (nextArg && !nextArg.startsWith('--')) {\n n = parseInt(nextArg, 10);\n if (isNaN(n)) {\n n = 0;\n }\n }\n\n helperTrace('diff-args:commit-mode', `${commitHash}~${n + 1} ${commitHash}`);\n console.log(`ℹ️ 커밋 '${commitHash}' ${n > 0 ? ` 포함 총 ${n + 1}개의 커밋` : ''}을 리뷰합니다...`);\n diffArgs = `${commitHash}~${n + 1} ${commitHash}`;\n } else {\n // 기본 모드:\n // 1. Unstaged 변경사항 확인\n try {\n helperTrace('diff-args:unstaged-check:start');\n const check = execSync(`git diff --name-only -- ${includeParams} ${excludeParams}`).toString();\n if (!check.trim()) {\n helperTrace('diff-args:unstaged-check:empty', 'use HEAD~1 HEAD');\n console.log('ℹ️ Unstaged 변경사항이 없습니다. 마지막 커밋(HEAD)을 리뷰합니다...');\n diffArgs = 'HEAD~1 HEAD';\n } else {\n helperTrace('diff-args:unstaged-check:has-changes', `length=${check.length}`);\n }\n } catch (error) {\n helperTrace('diff-args:unstaged-check:failed', getErrorSummary(error));\n // git diff 실패시 무시\n }\n }\n\n helperTrace('diff-args:resolve:done', diffArgs || '(default)');\n\n return diffArgs;\n}\n\n/**\n * AI 서비스 선택\n */\nexport function selectAIService() {\n const service = parseServiceFromArgs();\n\n if (!service) {\n helperTrace('select-service:missing');\n exitWithError('❌ 서비스가 선택되지 않았습니다.', {\n scope: 'helper:selectAIService'\n });\n }\n\n helperTrace('select-service:done', service);\n\n return service;\n}\n\n/**\n * 터미널에서 라디오 버튼 형태로 AI 서비스를 선택합니다.\n */\nexport async function showSelectionAIService(): Promise<AIServiceType> {\n const selectedServiceFromArgs = parseServiceFromArgs();\n\n if (selectedServiceFromArgs) {\n helperTrace('show-selection:from-args', selectedServiceFromArgs);\n console.log(`\\n✅ \\u001b[32m${selectedServiceFromArgs}\\u001b[0m 서비스가 선택되었습니다. (--service)\\n`);\n\n return selectedServiceFromArgs;\n }\n\n helperTrace('show-selection:interactive:start');\n let selectedIndex = 0;\n\n // Use readline to handle keypresses\n // 키 입력을 처리하기 위해 readline 인터페이스 사용\n const rl = readline.createInterface({\n input: process.stdin,\n output: process.stdout,\n terminal: true\n });\n\n let firstRender = true;\n\n // Hide cursor\n process.stdout.write('\\u001b[?25l');\n\n const render = () => {\n if (!firstRender) {\n // Move cursor back to the starting line of the selection UI\n // We print (1 question line + services.length lines)\n // 선택 UI의 시작 라인으로 커서 이동 (질문 1줄 + 서비스 목록 N줄)\n readline.moveCursor(process.stdout, 0, -(AIServices.length + 1));\n }\n firstRender = false;\n helperTrace('show-selection:interactive:render', AIServices[selectedIndex] || 'unknown');\n\n // Clear everything from cursor down to avoid ghosting/overlaps\n // 잔상이나 겹침을 방지하기 위해 커서 위치부터 아래쪽 모두 지움\n readline.clearScreenDown(process.stdout);\n\n process.stdout.write(\n '🤖 AI 서비스를 선택해주세요 (\\u001b[33m↑↓ 방향키\\u001b[0m 이동, \\u001b[33mEnter\\u001b[0m 선택):\\n'\n );\n AIServices.forEach((service, index) => {\n if (index === selectedIndex) {\n process.stdout.write(` \\u001b[36m>\\u001b[0m \\u001b[36m◉\\u001b[0m \\u001b[1m${service}\\u001b[0m\\n`);\n } else {\n process.stdout.write(` ◯ ${service}\\n`);\n }\n });\n };\n\n render();\n\n return new Promise((resolve) => {\n const onData = (data: Buffer) => {\n const key = data.toString();\n if (key === '\\u0003') {\n // Ctrl+C\n helperTrace('show-selection:interactive:ctrl-c');\n process.stdout.write('\\u001b[?25h'); // Show cursor\n process.exit(0);\n }\n if (key === '\\x1b[A') {\n // Up arrow\n selectedIndex = (selectedIndex - 1 + AIServices.length) % AIServices.length;\n render();\n } else if (key === '\\x1b[B') {\n // Down arrow\n selectedIndex = (selectedIndex + 1) % AIServices.length;\n render();\n } else if (key === '\\r' || key === '\\n') {\n // Enter\n process.stdin.removeListener('data', onData);\n process.stdin.setRawMode(false);\n process.stdin.pause();\n rl.close();\n\n // Show cursor\n process.stdout.write('\\u001b[?25h');\n\n console.log(`\\n✅ \\u001b[32m${AIServices[selectedIndex]}\\u001b[0m 서비스가 선택되었습니다.\\n`);\n const result = AIServices[selectedIndex];\n if (result) {\n helperTrace('show-selection:interactive:confirmed', result);\n resolve(result);\n }\n }\n };\n\n process.stdin.setRawMode(true);\n process.stdin.resume();\n process.stdin.on('data', onData);\n });\n}\n","import fs from 'fs';\n\nimport { codingConventionRulesPath, createTraceLogger, namingRulesPath, rulesPath } from '../../common/helper';\n\nconst args = process.argv.slice(2);\nconst trace = createTraceLogger('claude-commander', args);\nconst ALLOWED_REASONING_EFFORTS = ['minimal', 'low', 'medium', 'high'] as const;\n\ntype ReasoningEffort = (typeof ALLOWED_REASONING_EFFORTS)[number];\ntype ClaudeEffort = 'low' | 'medium' | 'high';\n\nfunction shellQuote(value: string) {\n return `'${value.replace(/'/g, `'\\\\''`)}'`;\n}\n\nfunction getArgValue(flag: string) {\n const index = args.indexOf(flag);\n\n if (index === -1 || !args[index + 1]) {\n return '';\n }\n\n return args[index + 1];\n}\n\nfunction toUnique(values: string[]) {\n const seen = new Set<string>();\n\n return values.filter((value) => {\n if (!value || seen.has(value)) {\n return false;\n }\n seen.add(value);\n\n return true;\n });\n}\n\nfunction normalizeEffort(level: ReasoningEffort): ClaudeEffort {\n if (level === 'minimal') {\n return 'low';\n }\n\n return level;\n}\n\nfunction resolveReasoningEffort(): ClaudeEffort {\n const customReasoningEffort = getArgValue('--reasoning-effort') || getArgValue('--effort');\n\n if (customReasoningEffort) {\n if (ALLOWED_REASONING_EFFORTS.includes(customReasoningEffort as ReasoningEffort)) {\n const normalized = normalizeEffort(customReasoningEffort as ReasoningEffort);\n trace('reasoning:custom', `${customReasoningEffort} -> ${normalized}`);\n\n if (customReasoningEffort === 'minimal') {\n console.warn('⚠️ Claude는 minimal을 직접 지원하지 않아 low로 매핑합니다.');\n }\n\n return normalized;\n }\n\n console.warn(\n `⚠️ 지원되지 않는 reasoning effort(${customReasoningEffort})입니다. allowed: ${ALLOWED_REASONING_EFFORTS.join(\n ', '\n )}`\n );\n }\n\n if (args.includes('--flash')) {\n trace('reasoning:flash-default', 'low');\n\n return 'low';\n }\n\n if (args.includes('--review')) {\n trace('reasoning:review-default', 'high');\n\n return 'high';\n }\n\n trace('reasoning:default', 'medium');\n\n return 'medium';\n}\n\nfunction resolvePrimaryAlias() {\n if (args.includes('--review')) {\n trace('model:mode-alias', 'opus');\n\n return 'opus';\n }\n\n if (args.includes('--flash')) {\n trace('model:mode-alias', 'haiku');\n\n return 'haiku';\n }\n\n trace('model:default-alias', 'sonnet');\n\n return 'sonnet';\n}\n\nfunction getAliasFallbacks(primaryAlias: string) {\n if (primaryAlias === 'opus') {\n return ['opus', 'sonnet', 'haiku'];\n }\n\n if (primaryAlias === 'haiku') {\n return ['haiku', 'sonnet'];\n }\n\n return [primaryAlias, 'sonnet', 'haiku'];\n}\n\nfunction buildClaudeExecCommand(options: {\n tempDiffPath: string;\n prompt: string;\n systemPromptFiles: string[];\n effort: ClaudeEffort;\n model?: string;\n fallbackModel?: string;\n}) {\n const { tempDiffPath, prompt, systemPromptFiles, effort, model, fallbackModel } = options;\n const modelOption = model ? `--model ${shellQuote(model)}` : '';\n const fallbackOption = model && fallbackModel ? `--fallback-model ${shellQuote(fallbackModel)}` : '';\n const effortOption = `--effort ${shellQuote(effort)}`;\n\n const appendedPromptFiles = systemPromptFiles\n .map((path) => `--append-system-prompt-file ${shellQuote(path)}`)\n .join(' ');\n\n return `cat ${shellQuote(tempDiffPath)} | claude ${[\n modelOption,\n fallbackOption,\n effortOption,\n appendedPromptFiles,\n '-p',\n shellQuote(prompt)\n ]\n .filter(Boolean)\n .join(' ')}`;\n}\n\n/**\n * @description\n * Claude Code CLI를 활용한 코드 리뷰 명령어를 생성합니다.\n *\n * 모델 전략:\n * 1) --model 커스텀 모델 우선 시도\n * 2) 서비스 alias 순차 폴백 (opus/sonnet/haiku 조합)\n * 3) 마지막에 --model 없이 계정/CLI 기본 모델로 폴백\n *\n * reasoning 전략:\n * - --effort(low|medium|high)를 사용\n * - --reasoning-effort(minimal|low|medium|high) 입력 시 Claude 호환 값으로 매핑\n */\nexport const createClaudeCommand = (tempDiffPath: string, reviewFormPath: string) => {\n trace('createClaudeCommand:start', `tempDiffPath=${tempDiffPath}, reviewFormPath=${reviewFormPath}`);\n const customModel = getArgValue('--model');\n const effort = resolveReasoningEffort();\n const primaryAlias = resolvePrimaryAlias();\n const aliasFallbacks = toUnique(getAliasFallbacks(primaryAlias));\n\n // 룰셋 파일들을 --append-system-prompt-file 로 시스템 프롬프트에 추가\n // Claude가 \"지침/규칙\"으로 인식하도록 시스템 프롬프트 레벨에 주입\n const rules = [\n { path: rulesPath, display: '룰셋' },\n { path: namingRulesPath, display: '네이밍 규칙' },\n { path: codingConventionRulesPath, display: '코딩 컨벤션' }\n ];\n const existingRuleFiles = rules.filter((rule) => fs.existsSync(rule.path)).map((rule) => rule.path);\n\n trace('rules:loaded', `count=${existingRuleFiles.length}`);\n\n // 리뷰 양식도 시스템 프롬프트에 추가 (출력 포맷 지침)\n const reviewFormExists = fs.existsSync(reviewFormPath);\n trace('reviewForm:status', reviewFormExists ? 'exists' : 'missing');\n const systemPromptFiles = reviewFormExists ? [...existingRuleFiles, reviewFormPath] : existingRuleFiles;\n\n const prompt = '위 규칙들을 참고하여 이 diff를 코드리뷰해줘. 리뷰양식에 맞춰서 작성해줘.';\n trace('prompt:prepared', `length=${prompt.length}`);\n trace('system-prompt-files', `count=${systemPromptFiles.length}`);\n const modelCandidates = toUnique(customModel ? [customModel, ...aliasFallbacks] : aliasFallbacks);\n trace('model:candidates', modelCandidates.join(', '));\n trace('command:candidates:count', String(modelCandidates.length + 1));\n\n if (customModel) {\n console.warn(\n `⚠️ 커스텀 모델(${customModel})을 우선 시도하고 실패하면 alias(${aliasFallbacks.join(\n ' -> '\n )}) 및 기본 모델 순으로 폴백합니다.`\n );\n } else {\n console.warn(\n `⚠️ 모델이 지정되지 않았습니다. alias(${aliasFallbacks.join(' -> ')})를 순차 시도하고 마지막에 기본 모델로 폴백합니다.`\n );\n }\n\n const commandCandidates = modelCandidates.map((model, index) => {\n const fallbackModel = modelCandidates[index + 1];\n\n return buildClaudeExecCommand({\n tempDiffPath,\n prompt,\n systemPromptFiles,\n effort,\n model,\n fallbackModel\n });\n });\n\n const command = [\n ...commandCandidates,\n buildClaudeExecCommand({\n tempDiffPath,\n prompt,\n systemPromptFiles,\n effort\n })\n ].join(' || ');\n\n trace('command:created');\n\n // test mode\n if (args.includes('--test')) {\n const safeCommand = command.replace(/\"/g, '\\\\\"');\n trace('test-mode:return-preview');\n\n return `echo \"[TEST MODE] Claude 명령어가 실행되지 않았습니다.\\n\\n생성될 명령어 미리보기:\\n${safeCommand}\"`;\n }\n\n trace('command:mode', 'execute');\n trace('createClaudeCommand:end');\n\n return command;\n};\n","import { execSync } from 'child_process';\n\nimport { createTraceLogger, exitWithError, getErrorSummary } from '../../common/helper';\n\nconst trace = createTraceLogger('installation-claude');\n\n// claude-cli 설치 확인 및 설치\nexport function checkClaudeCliInstalled() {\n trace('checkClaudeCliInstalled:start');\n try {\n trace('version-check:run', 'claude --version');\n execSync('claude --version', { stdio: 'ignore' });\n trace('version-check:ok');\n } catch (error) {\n trace('version-check:failed', getErrorSummary(error));\n trace('install:start', '@anthropic-ai/claude-code');\n console.log(\n 'ℹ️ claude-cli가 설치되어 있지 않습니다. 설치를 진행합니다... npm install -g @anthropic-ai/claude-code'\n );\n try {\n execSync('npm install -g @anthropic-ai/claude-code', { stdio: 'inherit' });\n trace('install:ok', 'login-required');\n console.log('✅ claude-cli 설치가 완료되었습니다.');\n console.log('⚠️ claude-cli 사용을 위해 인증이 필요합니다.');\n console.log(' 터미널에서 \"claude\" 를 입력하여 브라우저 로그인을 완료한 후, 다시 시도해주세요.');\n process.exit(1);\n } catch (installError) {\n trace('install:failed', getErrorSummary(installError));\n exitWithError('❌ claude-cli 설치 중 오류가 발생했습니다. 권한 문제일 수 있습니다 (sudo 필요).', {\n scope: 'installation-claude',\n error: installError\n });\n }\n }\n trace('checkClaudeCliInstalled:end');\n}\n","import fs from 'fs';\n\nimport { codingConventionRulesPath, createTraceLogger, namingRulesPath, rulesPath } from '../../common/helper';\n\nconst args = process.argv.slice(2);\nconst trace = createTraceLogger('codex-commander', args);\nconst ALLOWED_REASONING_EFFORTS = ['minimal', 'low', 'medium', 'high'] as const;\n\ntype ReasoningEffort = (typeof ALLOWED_REASONING_EFFORTS)[number];\n\nfunction shellQuote(value: string) {\n return `'${value.replace(/'/g, `'\\\\''`)}'`;\n}\n\nfunction getArgValue(flag: string) {\n const index = args.indexOf(flag);\n\n if (index === -1 || !args[index + 1]) {\n return '';\n }\n\n return args[index + 1];\n}\n\nfunction resolveReasoningEffort(): ReasoningEffort {\n const customReasoningEffort = getArgValue('--reasoning-effort');\n\n if (customReasoningEffort) {\n if (ALLOWED_REASONING_EFFORTS.includes(customReasoningEffort as ReasoningEffort)) {\n trace('reasoning:custom', customReasoningEffort);\n\n return customReasoningEffort as ReasoningEffort;\n }\n\n console.warn(\n `⚠️ 지원되지 않는 reasoning effort(${customReasoningEffort})입니다. allowed: ${ALLOWED_REASONING_EFFORTS.join(\n ', '\n )}`\n );\n }\n\n if (args.includes('--flash')) {\n trace('reasoning:flash-default', 'minimal');\n\n return 'minimal';\n }\n\n if (args.includes('--review')) {\n trace('reasoning:review-default', 'high');\n\n return 'high';\n }\n\n trace('reasoning:default', 'medium');\n\n return 'medium';\n}\n\nfunction buildCodexExecCommand(prompt: string, reasoningEffort: ReasoningEffort, model?: string) {\n const modelOption = model ? `--model ${shellQuote(model)}` : '';\n const reasoningOption = `-c ${shellQuote(`model_reasoning_effort=\"${reasoningEffort}\"`)}`;\n\n return `codex exec ${[modelOption, reasoningOption, shellQuote(prompt)].filter(Boolean).join(' ')}`;\n}\n\n/**\n * @description\n * Codex CLI를 활용한 코드 리뷰 명령어를 생성합니다.\n *\n * 모델 기본값:\n * - --review: gpt-5 alias 우선 시도 후 계정 기본 모델로 자동 폴백\n * - --flash: gpt-5 alias 우선 시도 후 계정 기본 모델로 자동 폴백\n * - 미지정: gpt-5 alias 우선 시도 후 계정 기본 모델로 자동 폴백\n *\n * 추론 강도 기본값:\n * - --review: high\n * - --flash: minimal\n * - 미지정: medium\n */\nexport const createCodexCommand = (tempDiffPath: string, reviewFormPath: string) => {\n trace('createCodexCommand:start', `tempDiffPath=${tempDiffPath}, reviewFormPath=${reviewFormPath}`);\n const customModel = getArgValue('--model');\n const reasoningEffort = resolveReasoningEffort();\n\n const rules = [rulesPath, namingRulesPath, codingConventionRulesPath]\n .filter((filePath) => fs.existsSync(filePath))\n .map((filePath) => `- ${filePath}`)\n .join('\\n');\n const rulesCount = rules ? rules.split('\\n').length : 0;\n trace('rules:loaded', `count=${rulesCount}`);\n\n const hasReviewForm = fs.existsSync(reviewFormPath);\n const reviewFormLine = hasReviewForm ? `- ${reviewFormPath}` : '';\n trace('reviewForm:status', reviewFormLine ? 'exists' : 'missing');\n\n const prompt = `아래 파일들을 참고해서 코드 리뷰를 진행해줘.\n규칙 파일: \n${rules || '- (없음)'}\n리뷰 양식 파일:\n${reviewFormLine || '- (없음)'}\n리뷰 대상 diff 파일:\n- ${tempDiffPath}\n\n반드시 리뷰 양식에 맞춰 작성해줘.`;\n trace('prompt:prepared', `length=${prompt.length}`);\n\n let command = '';\n\n if (customModel) {\n console.warn('⚠️ 지정한 모델이 없는 경우, 에러가 발생하니 주의하세요.');\n trace('model:custom', customModel);\n command = buildCodexExecCommand(prompt, reasoningEffort, customModel);\n } else {\n const preferredModelAlias = 'gpt-5';\n const aliasCommand = buildCodexExecCommand(prompt, reasoningEffort, preferredModelAlias);\n const fallbackCommand = buildCodexExecCommand(prompt, reasoningEffort);\n\n console.warn(\n `⚠️ 모델이 지정되지 않았습니다. alias(${preferredModelAlias})를 우선 시도하고 실패하면 계정 기본 모델로 자동 폴백합니다.`\n );\n trace('model:alias-first', preferredModelAlias);\n trace('model:fallback', 'account-default');\n command = `${aliasCommand} || ${fallbackCommand}`;\n }\n\n trace('command:created');\n\n if (args.includes('--test')) {\n const safeCommand = command.replace(/\"/g, '\\\\\"');\n trace('test-mode:return-preview');\n\n return `echo \"[TEST MODE] Codex 명령어가 실행되지 않았습니다.\\n\\n생성될 명령어 미리보기:\\n${safeCommand}\"`;\n }\n\n trace('command:mode', 'execute');\n trace('createCodexCommand:end');\n\n return command;\n};\n","import { execSync } from 'child_process';\n\nimport { createTraceLogger, exitWithError, getErrorSummary } from '../../common/helper';\n\nconst trace = createTraceLogger('installation-codex');\n\n// codex-cli 설치 확인 및 설치\nexport function checkCodexCliInstalled() {\n trace('checkCodexCliInstalled:start');\n try {\n trace('version-check:run', 'codex --version');\n execSync('codex --version', { stdio: 'ignore' });\n trace('version-check:ok');\n } catch (error) {\n trace('version-check:failed', getErrorSummary(error));\n trace('install:start', '@openai/codex');\n console.log('ℹ️ codex-cli가 설치되어 있지 않습니다. 설치를 진행합니다... npm install -g @openai/codex');\n try {\n execSync('npm install -g @openai/codex', { stdio: 'inherit' });\n trace('install:ok', 'login-required');\n console.log('✅ codex-cli 설치가 완료되었습니다.');\n console.log('⚠️ codex-cli 사용을 위해 인증이 필요합니다.');\n console.log(' 터미널에서 \"codex login\" 을 입력하여 로그인을 완료한 후, 다시 시도해주세요.');\n process.exit(1);\n } catch (installError) {\n trace('install:failed', getErrorSummary(installError));\n exitWithError('❌ codex-cli 설치 중 오류가 발생했습니다. 권한 문제일 수 있습니다 (sudo 필요).', {\n scope: 'installation-codex',\n error: installError\n });\n }\n }\n trace('checkCodexCliInstalled:end');\n}\n","import fs from 'fs';\n\nimport { codingConventionRulesPath, createTraceLogger, namingRulesPath, rulesPath } from '../../common/helper';\n// gemini 실행 및 결과 캡처\nconst args = process.argv.slice(2);\nconst trace = createTraceLogger('gemini-commander', args);\nconst ALLOWED_REASONING_EFFORTS = ['minimal', 'low', 'medium', 'high'] as const;\n\ntype ReasoningEffort = (typeof ALLOWED_REASONING_EFFORTS)[number];\n\nfunction shellQuote(value: string) {\n return `'${value.replace(/'/g, `'\\\\''`)}'`;\n}\n\nfunction getArgValue(flag: string) {\n const index = args.indexOf(flag);\n\n if (index === -1 || !args[index + 1]) {\n return '';\n }\n\n return args[index + 1];\n}\n\nfunction toUnique(values: string[]) {\n const seen = new Set<string>();\n\n return values.filter((value) => {\n if (!value || seen.has(value)) {\n return false;\n }\n seen.add(value);\n\n return true;\n });\n}\n\nfunction resolveReasoningEffort(): ReasoningEffort {\n const customReasoningEffort = getArgValue('--reasoning-effort');\n\n if (customReasoningEffort) {\n if (ALLOWED_REASONING_EFFORTS.includes(customReasoningEffort as ReasoningEffort)) {\n trace('reasoning:custom', customReasoningEffort);\n\n return customReasoningEffort as ReasoningEffort;\n }\n\n console.warn(\n `⚠️ 지원되지 않는 reasoning effort(${customReasoningEffort})입니다. allowed: ${ALLOWED_REASONING_EFFORTS.join(\n ', '\n )}`\n );\n }\n\n if (args.includes('--flash')) {\n trace('reasoning:flash-default', 'minimal');\n\n return 'minimal';\n }\n\n if (args.includes('--review')) {\n trace('reasoning:review-default', 'high');\n\n return 'high';\n }\n\n trace('reasoning:default', 'medium');\n\n return 'medium';\n}\n\nfunction resolvePrimaryAlias(reasoningEffort: ReasoningEffort) {\n if (args.includes('--review')) {\n trace('model:mode-alias', 'pro');\n\n return 'pro';\n }\n\n if (args.includes('--flash')) {\n trace('model:mode-alias', 'flash');\n\n return 'flash';\n }\n\n // 일반 모드에서는 추론 강도 기준으로 alias를 선택합니다.\n if (reasoningEffort === 'high') {\n trace('model:reasoning-alias', 'pro');\n\n return 'pro';\n }\n\n if (reasoningEffort === 'minimal' || reasoningEffort === 'low') {\n trace('model:reasoning-alias', 'flash');\n\n return 'flash';\n }\n\n trace('model:default-alias', 'auto');\n\n return 'auto';\n}\n\nfunction getAliasFallbacks(primaryAlias: string) {\n if (primaryAlias === 'pro') {\n return ['pro', 'flash', 'auto'];\n }\n\n if (primaryAlias === 'flash') {\n return ['flash', 'auto', 'pro'];\n }\n\n return [primaryAlias, 'auto', 'flash', 'pro'];\n}\n\nfunction getReasoningInstruction(reasoningEffort: ReasoningEffort) {\n if (reasoningEffort === 'high') {\n return 'high (깊이 있는 분석, 잠재적 리스크까지 점검)';\n }\n\n if (reasoningEffort === 'medium') {\n return 'medium (균형 잡힌 분석과 핵심 이슈 중심)';\n }\n\n if (reasoningEffort === 'low') {\n return 'low (핵심 결함 위주로 간결하게 분석)';\n }\n\n return 'minimal (치명도 높은 이슈만 매우 간결하게 분석)';\n}\n\nfunction buildGeminiExecCommand(prompt: string, model?: string) {\n const modelOption = model ? `--model ${shellQuote(model)}` : '';\n\n return `gemini ${[modelOption, '-p', shellQuote(prompt)].filter(Boolean).join(' ')}`;\n}\n\n/**\n * @description\n * Gemini CLI를 활용한 코드 리뷰 명령어를 생성합니다.\n *\n * 모델 전략:\n * 1) --model 커스텀 모델 우선 시도\n * 2) 서비스 alias 순차 폴백 (pro/flash/auto 조합)\n * 3) 마지막에 --model 없이 계정/CLI 기본 모델로 폴백\n *\n * reasoning 전략:\n * - Gemini CLI는 현재 reasoning effort 전용 플래그가 없어 프롬프트 지시문으로 반영\n * - --reasoning-effort(minimal|low|medium|high) 지원\n */\nexport const createGeminiCommand = (tempDiffPath: string, reviewFormPath: string) => {\n trace('createGeminiCommand:start', `tempDiffPath=${tempDiffPath}, reviewFormPath=${reviewFormPath}`);\n const customModel = getArgValue('--model');\n const reasoningEffort = resolveReasoningEffort();\n const primaryAlias = resolvePrimaryAlias(reasoningEffort);\n const aliasFallbacks = toUnique(getAliasFallbacks(primaryAlias));\n\n // 존재하지 않는 파일은 제외하여 명령어 생성\n const rules = [\n { path: rulesPath, display: '룰셋' },\n { path: namingRulesPath, display: '네이밍 규칙' },\n { path: codingConventionRulesPath, display: '코딩 컨벤션' }\n ];\n\n const validRules = rules\n .filter((rule) => fs.existsSync(rule.path))\n .map((rule) => `@${rule.path}`)\n .join(', ');\n const rulesCount = validRules ? validRules.split(',').length : 0;\n trace('rules:loaded', `count=${rulesCount}`);\n\n const reviewFormRef = fs.existsSync(reviewFormPath) ? `@${reviewFormPath}` : '(없음)';\n trace('reviewForm:status', reviewFormRef === '(없음)' ? 'missing' : 'exists');\n\n const reasoningInstruction = getReasoningInstruction(reasoningEffort);\n const prompt = `다음 규칙들을 참고해서(${validRules || '(없음)'}) 이 diff(@${tempDiffPath})를 리뷰해줘.\n리뷰 양식은 ${reviewFormRef} 에 맞춰서 작성해줘.\n추론 강도 지침: ${reasoningInstruction}`;\n trace('prompt:prepared', `length=${prompt.length}`);\n\n const modelCandidates = toUnique(customModel ? [customModel, ...aliasFallbacks] : aliasFallbacks);\n trace('model:candidates', modelCandidates.join(', '));\n trace('command:candidates:count', String(modelCandidates.length + 1));\n\n if (customModel) {\n console.warn(\n `⚠️ 커스텀 모델(${customModel})을 우선 시도하고 실패하면 alias(${aliasFallbacks.join(\n ' -> '\n )}) 및 기본 모델 순으로 폴백합니다.`\n );\n } else {\n console.warn(\n `⚠️ 모델이 지정되지 않았습니다. alias(${aliasFallbacks.join(' -> ')})를 순차 시도하고 마지막에 기본 모델로 폴백합니다.`\n );\n }\n\n const commandCandidates = modelCandidates.map((model) => buildGeminiExecCommand(prompt, model));\n const command = [...commandCandidates, buildGeminiExecCommand(prompt)].join(' || ');\n\n // gemini 실행 및 결과 캡처\n trace('command:created');\n\n // test mode\n if (args.includes('--test')) {\n const safeCommand = command.replace(/\"/g, '\\\\\"');\n trace('test-mode:return-preview');\n\n return `echo \"[TEST MODE] Gemini 명령어가 실행되지 않았습니다.\\n\\n생성될 명령어 미리보기:\\n${safeCommand}\"`;\n }\n\n trace('command:mode', 'execute');\n trace('createGeminiCommand:end');\n\n return command;\n};\n","import { execSync } from 'child_process';\n\nimport { createTraceLogger, exitWithError, getErrorSummary } from '../../common/helper';\n\nconst trace = createTraceLogger('installation-gemini');\n\n// gemini-cli 설치 확인 및 설치\nexport function checkGeminiCliInstalled() {\n trace('checkGeminiCliInstalled:start');\n try {\n trace('version-check:run', 'gemini --version');\n execSync('gemini --version', { stdio: 'ignore' });\n trace('version-check:ok');\n } catch (error) {\n trace('version-check:failed', getErrorSummary(error));\n trace('install:start', '@google/gemini-cli');\n console.log('ℹ️ gemini-cli가 설치되어 있지 않습니다. 설치를 진행합니다... npm install -g @google/gemini-cli');\n try {\n execSync('npm install -g @google/gemini-cli', { stdio: 'inherit' });\n trace('install:ok', 'login-required');\n console.log('✅ gemini-cli 설치가 완료되었습니다.');\n console.log('⚠️ Gemini API 사용을 위해 인증이 필요합니다.');\n console.log(' 터미널에서 \"gemini\" 를 입력하여 브라우저 로그인을 완료한 후, 다시 시도해주세요.');\n process.exit(1);\n } catch (installError) {\n trace('install:failed', getErrorSummary(installError));\n exitWithError('❌ gemini-cli 설치 중 오류가 발생했습니다. 권한 문제일 수 있습니다 (sudo 필요).', {\n scope: 'installation-gemini',\n error: installError\n });\n }\n }\n trace('checkGeminiCliInstalled:end');\n}\n","#!/usr/bin/env node\nimport { execSync, exec } from 'child_process';\nimport fs from 'fs';\nimport util from 'util';\n\nconst execAsync = util.promisify(exec);\n\nimport {\n tempDiffPath,\n clearTraceMessages,\n createTraceLogger,\n getNextFilePath,\n deleteTempDiff,\n deleteFile,\n createReportDirectory,\n REPORT_DIR,\n getNowString,\n getErrorSummary,\n getGitDiffFilter,\n reviewFormOneByOnePath,\n getDiffArgs,\n isTestMode,\n openReport,\n writeErrorReport,\n showSelectionAIService\n} from '../common/helper';\n\nimport { createClaudeCommand } from './claude/claude-commander';\nimport { checkClaudeCliInstalled } from './claude/installation-claude';\nimport { createCodexCommand } from './codex/codex-commander';\nimport { checkCodexCliInstalled } from './codex/installation-codex';\nimport { createGeminiCommand } from './gemini/gemini-commander';\nimport { checkGeminiCliInstalled } from './gemini/installation-gemini';\n\nasync function main() {\n const args = process.argv.slice(2);\n clearTraceMessages();\n const isTest = isTestMode(args);\n const trace = createTraceLogger('review-one-by-one', args);\n trace('main:start', `args=${JSON.stringify(args)}`);\n let service = '';\n let savedDiffPath = '';\n let savedReportPath = '';\n\n try {\n // AI 서비스 선택\n trace('service-selection:start');\n service = await showSelectionAIService();\n trace('service-selection:done', `service=${service}`);\n\n switch (service) {\n case 'gemini':\n // gemini-cli 설치 확인 및 설치\n trace('install-check:start', 'service=gemini');\n checkGeminiCliInstalled();\n trace('install-check:done', 'service=gemini');\n break;\n case 'claude':\n // claude-cli 설치 확인 및 설치\n trace('install-check:start', 'service=claude');\n checkClaudeCliInstalled();\n trace('install-check:done', 'service=claude');\n break;\n case 'codex':\n // codex-cli 설치 확인 및 설치\n trace('install-check:start', 'service=codex');\n checkCodexCliInstalled();\n trace('install-check:done', 'service=codex');\n break;\n }\n\n trace('review-flow:start');\n console.log('🚀 AI Code Review를 시작합니다...');\n\n // 리뷰 결과 폴더 생성\n trace('report-dir:create:start');\n createReportDirectory();\n trace('report-dir:create:done');\n\n const { includeParams, excludeParams } = getGitDiffFilter();\n trace('diff-filter:loaded', `include=${includeParams} | exclude=${excludeParams}`);\n\n trace('diff-args:build:start');\n const diffArgs = getDiffArgs();\n trace('diff-args:build:done', `diffArgs=${diffArgs || '(default)'}`);\n\n const filesCommand = `git diff --name-only ${diffArgs} -- ${includeParams} ${excludeParams}`;\n trace('files-command:run', filesCommand);\n const fileList = execSync(filesCommand).toString().split('\\n').filter(Boolean);\n trace('files-command:done', `fileCount=${fileList.length}`);\n\n if (fileList.length === 0) {\n trace('empty-file-list:exit');\n console.log('ℹ️ 변경 사항이 없습니다.');\n deleteTempDiff();\n\n process.exit(0);\n }\n\n const fullDiffCommand = `git diff ${diffArgs} -- ${includeParams} ${excludeParams}`;\n trace('full-diff:run');\n const fullDiff = execSync(fullDiffCommand).toString();\n const nowStr = getNowString();\n trace('full-diff:done', `length=${fullDiff.length}`);\n trace('timestamp:created', nowStr);\n\n trace('temp-diff:write:start', tempDiffPath);\n fs.writeFileSync(tempDiffPath, fullDiff);\n trace('temp-diff:write:done');\n\n // diff 파일 저장 (.review-report 안으로 복사)\n trace('saved-diff:copy:start');\n savedDiffPath = getNextFilePath(REPORT_DIR, `${nowStr}-diff`, '.txt');\n fs.copyFileSync(tempDiffPath, savedDiffPath);\n trace('saved-diff:copy:done', savedDiffPath);\n\n // 리뷰 결과 저장\n savedReportPath = getNextFilePath(REPORT_DIR, nowStr, '.md');\n trace('saved-report:path', savedReportPath);\n\n // let fullReport = '';\n // 병렬 처리를 위해 Promise.all 사용\n const promises = fileList.map(async (file) => {\n const tempOneFileDiffPath = `temp_diff_${file.replace(/\\//g, '_')}.txt`;\n let command = '';\n\n try {\n trace('file-review:start', file);\n console.log(`🔍 Reviewing: ${file}...`);\n\n // 3. 개별 파일에 대한 diff 생성\n trace('file-diff:run', file);\n const fileDiff = execSync(`git diff ${diffArgs} -- \"${file}\"`).toString();\n trace('file-diff:done', `${file} | length=${fileDiff.length}`);\n\n trace('file-temp-diff:write:start', tempOneFileDiffPath);\n fs.writeFileSync(tempOneFileDiffPath, fileDiff);\n trace('file-temp-diff:write:done', tempOneFileDiffPath);\n\n // 4. 명령어 생성\n trace('file-command:create:start', file);\n switch (service) {\n case 'gemini':\n // gemini-cli 에 맞게 프롬프트 명령어 생성\n command = createGeminiCommand(tempOneFileDiffPath, reviewFormOneByOnePath);\n break;\n case 'claude':\n // claude-cli 에 맞게 프롬프트 명령어 생성\n command = createClaudeCommand(tempOneFileDiffPath, reviewFormOneByOnePath);\n break;\n case 'codex':\n // codex-cli 에 맞게 프롬프트 명령어 생성\n command = createCodexCommand(tempOneFileDiffPath, reviewFormOneByOnePath);\n break;\n }\n trace('file-command:create:done', `${file} | commandLength=${command.length}`);\n\n // 5. AI에게 해당 파일만 리뷰 요청 (비동기 실행)\n // execSync 대신 execAsync 사용. maxBuffer를 넉넉하게 설정\n trace('file-command:exec:start', file);\n const { stdout } = await execAsync(command, { maxBuffer: 1024 * 1024 * 20 });\n const result = stdout.toString();\n trace('file-command:exec:done', `${file} | resultLength=${result.length}`);\n\n // 6. 리뷰 마친후 해당 파일 삭제\n trace('file-temp-diff:delete:start', tempOneFileDiffPath);\n deleteFile(tempOneFileDiffPath);\n trace('file-temp-diff:delete:done', tempOneFileDiffPath);\n\n const tempReport = `### File: ${file}\\n${result}\\n\\n`;\n\n // 콘솔 출력\n console.log(tempReport);\n\n trace('file-report:append:start', file);\n fs.appendFileSync(savedReportPath, tempReport);\n trace('file-report:append:done', file);\n\n // 사용한 명령어도 저장(디버깅용)\n if (isTest) {\n trace('file-test-command:append:start', file);\n fs.appendFileSync(savedReportPath, `\\n\\n## 사용된 명령어\\n\\n${command}`);\n trace('file-test-command:append:done', file);\n }\n trace('file-review:end', file);\n } catch (err) {\n trace('file-review:catch', `${file} | ${getErrorSummary(err)}`);\n const errorLogPath = writeErrorReport(err, {\n scope: 'review-one-by-one:file',\n args,\n extraSections: [\n {\n heading: 'Execution Context',\n markdown: `\\`\\`\\`json\\n${JSON.stringify(\n {\n service,\n file,\n command: command || null,\n tempOneFileDiffPath,\n savedDiffPath: savedDiffPath || null,\n savedReportPath: savedReportPath || null\n },\n null,\n 2\n )}\\n\\`\\`\\``\n }\n ]\n });\n console.error(`❌ Error reviewing file ${file}:`, err);\n if (errorLogPath) {\n console.error(`📄 에러 로그 저장 위치: ${errorLogPath}`);\n }\n // 에러 내용도 리포트에 포함\n const errorReport = `### File: ${file}\\n❌ Review Failed\\n\\`\\`\\`\\n${getErrorSummary(err)}\\n\\`\\`\\`\\n\\n`;\n fs.appendFileSync(savedReportPath, errorReport);\n\n // 임시 파일 정리 시도\n try {\n if (fs.existsSync(tempOneFileDiffPath)) {\n trace('file-temp-diff:delete:start(catch)', tempOneFileDiffPath);\n deleteFile(tempOneFileDiffPath);\n trace('file-temp-diff:delete:done(catch)', tempOneFileDiffPath);\n }\n } catch (cleanupError) {\n trace('file-temp-diff:delete:failed(catch)', `${file} | ${getErrorSummary(cleanupError)}`);\n console.error(`❌ Error deleting temp file for ${file}:`, cleanupError);\n }\n }\n });\n\n trace('parallel-review:await-start');\n await Promise.all(promises);\n trace('parallel-review:await-done');\n\n console.log(`\\n✅ 리뷰가 완료되었습니다.`);\n console.log(`📄 리포트 저장 위치: ${savedReportPath}`);\n console.log(`diff 저장 위치: ${savedDiffPath}`);\n\n // 브라우저 열기\n trace('open-report:start');\n openReport(savedReportPath);\n trace('open-report:done');\n\n trace('cleanup-temp-diff:start');\n deleteTempDiff();\n trace('cleanup-temp-diff:done');\n trace('review-flow:end');\n } catch (error) {\n trace('review-flow:catch', getErrorSummary(error));\n let errorReportPath = '';\n\n trace('cleanup-temp-diff:start(catch)');\n try {\n deleteTempDiff();\n trace('cleanup-temp-diff:done(catch)');\n } catch (cleanupError) {\n trace('cleanup-temp-diff:failed(catch)', getErrorSummary(cleanupError));\n console.error('⚠️ 임시 diff 정리 중 오류가 발생했습니다.');\n console.error(cleanupError);\n }\n\n trace('error-report:prepare', `service=${service || 'unknown'}`);\n errorReportPath = writeErrorReport(error, {\n scope: 'review-one-by-one',\n args,\n extraSections: [\n {\n heading: 'Execution Context',\n markdown: `\\`\\`\\`json\\n${JSON.stringify(\n {\n service: service || null,\n tempDiffPath,\n savedDiffPath: savedDiffPath || null,\n savedReportPath: savedReportPath || null\n },\n null,\n 2\n )}\\n\\`\\`\\``\n }\n ]\n });\n\n console.error('❌ 리뷰 도중 오류가 발생했습니다.');\n console.error(error);\n\n if (errorReportPath) {\n console.error(`📄 에러 로그 저장 위치: ${errorReportPath}`);\n }\n\n process.exit(1);\n }\n}\n\nmain();\n"]}