getgloss 0.7.0 → 0.7.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.
package/dist/cli/index.js CHANGED
@@ -12,7 +12,7 @@ import path from "path";
12
12
  // package.json
13
13
  var package_default = {
14
14
  name: "getgloss",
15
- version: "0.7.0",
15
+ version: "0.7.2",
16
16
  description: "Local browser-based diff review for coding-agent loops.",
17
17
  type: "module",
18
18
  packageManager: "pnpm@10.33.2",
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/cli/index.ts","../../src/shared/paths.ts","../../package.json","../../src/cli/git.ts","../../src/shared/language.ts","../../src/cli/diff-parser.ts","../../src/cli/lifecycle.ts","../../src/shared/server-info.ts","../../src/shared/json.ts","../../src/shared/validation.ts","../../src/cli/server-client.ts","../../src/server/store.ts","../../src/shared/comments.ts","../../src/shared/markdown.ts","../../src/shared/reviews.ts","../../src/cli/status.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from 'commander';\nimport openBrowser from 'open';\nimport {\n globalReviewDir,\n globalReviewFeedbackFile,\n globalReviewMarkdownFile,\n packageVersion\n} from '../shared/paths';\nimport { assertGitAvailable, captureDiff, getRepoRoot } from './git';\nimport {\n ensureServer,\n isServerResponsive,\n readServerInfo,\n serverUrl,\n startServer,\n stopServer\n} from './lifecycle';\nimport { ServerClient } from './server-client';\nimport { listReviewsForStatus } from './status';\n\ninterface GlobalOptions {\n json?: boolean;\n noColor?: boolean;\n}\n\nfunction printJson(value: object): void {\n process.stdout.write(`${JSON.stringify(value, null, 2)}\\n`);\n}\n\nfunction printPlain(value: string): void {\n process.stdout.write(`${value}\\n`);\n}\n\nconst program = new Command();\n\nprogram\n .name('gloss')\n .description('Local browser-based diff review for coding-agent loops.')\n .version(packageVersion)\n .option('--json', 'print JSON for supported commands')\n .option('--no-color', 'disable color output');\n\nprogram\n .command('open')\n .description('Capture local changes and open them for review')\n .option('--base <ref>', 'explicit base git ref')\n .option('--print-url', 'print review URL')\n .option('--no-open', 'do not open a browser')\n .option('--no-watch', 'return immediately after registering the review')\n .option('--timeout <seconds>', 'watch timeout in seconds', Number)\n .action(\n async (options: {\n base?: string;\n printUrl?: boolean;\n open?: boolean;\n watch?: boolean;\n timeout?: number;\n }) => {\n const globals = program.opts<GlobalOptions>();\n const info = await ensureServer();\n const client = new ServerClient(serverUrl(info));\n const diff = await captureDiff(options.base);\n const { meta, url } = await client.createReview(diff);\n\n if (options.printUrl) {\n printPlain(url);\n }\n if (options.open !== false) {\n await openBrowser(url);\n }\n\n if (options.watch === false) {\n const result = {\n reviewId: meta.id,\n url,\n files: diff.files.length,\n scope: diff.scope.mode,\n artifactDir: meta.artifactDir\n };\n globals.json ? printJson(result) : printPlain(`Review ${meta.id}: ${url}`);\n return;\n }\n\n const event = await client.watchReview(meta.id, options.timeout);\n if (event.type === 'review.cancelled') {\n process.exitCode = 2;\n globals.json ? printJson(event) : printPlain(`Review ${meta.id} cancelled`);\n return;\n }\n if (event.type !== 'review.submitted') {\n throw new Error(`Unexpected review event ${event.type}`);\n }\n\n const feedback = await client.getFeedback(meta.id);\n const result = {\n reviewId: meta.id,\n url,\n files: event.counts.files,\n comments: event.counts.comments,\n feedbackPath: globalReviewFeedbackFile(meta.id),\n markdownPath: globalReviewMarkdownFile(meta.id),\n artifactDir: globalReviewDir(meta.id),\n feedback\n };\n globals.json\n ? printJson(result)\n : printPlain(`Review ${meta.id} submitted with ${event.counts.comments} comments`);\n }\n );\n\nprogram\n .command('watch')\n .argument('<reviewId>', 'review id')\n .description('Wait for review.submitted for an existing review')\n .option('--timeout <seconds>', 'watch timeout in seconds', Number)\n .action(async (reviewId: string, options: { timeout?: number }) => {\n const globals = program.opts<GlobalOptions>();\n const info = await ensureServer();\n const client = new ServerClient(serverUrl(info));\n const event = await client.watchReview(reviewId, options.timeout);\n globals.json ? printJson(event) : printPlain(`${event.type} ${event.reviewId}`);\n });\n\nprogram\n .command('start')\n .description('Start or reuse the background server')\n .option('--port <port>', 'port to bind', Number)\n .action(async (options: { port?: number }) => {\n const globals = program.opts<GlobalOptions>();\n const info = await startServer({ port: options.port });\n globals.json\n ? printJson(info)\n : printPlain(`Gloss server running at ${serverUrl(info)} (pid ${info.pid})`);\n });\n\nprogram\n .command('status')\n .description('Show server and active reviews')\n .action(async () => {\n const globals = program.opts<GlobalOptions>();\n const info = await readServerInfo();\n const responsive = info ? await isServerResponsive(info) : false;\n const reviews = await listReviewsForStatus({ responsive, server: info });\n const status = { running: responsive, server: info, reviews };\n globals.json\n ? printJson(status)\n : printPlain(\n responsive && info\n ? `Gloss server running at ${serverUrl(info)} with ${reviews.length} active review(s)`\n : 'Gloss server is not running'\n );\n });\n\nprogram\n .command('stop')\n .description('Stop the managed background server')\n .action(async () => {\n const globals = program.opts<GlobalOptions>();\n const result = await stopServer();\n globals.json\n ? printJson(result)\n : printPlain(result.stopped ? 'Gloss server stopped' : 'Gloss server was not running');\n });\n\nprogram\n .command('resolve')\n .argument('<reviewId>', 'review id')\n .description('Mark a submitted review or one feedback comment as resolved')\n .option('--comment <commentId>', 'resolve one submitted feedback comment')\n .option('--summary <text>', 'brief summary of the fixes applied')\n .action(async (reviewId: string, options: { comment?: string; summary?: string }) => {\n const globals = program.opts<GlobalOptions>();\n const info = await ensureServer();\n const client = new ServerClient(serverUrl(info));\n const result = options.comment\n ? await client.resolveComment(reviewId, options.comment, options.summary)\n : await client.markResolved(reviewId, options.summary);\n if (globals.json) {\n printJson({\n commentId: options.comment ?? null,\n summary: options.summary ?? null,\n ...result\n });\n return;\n }\n printPlain(\n options.comment\n ? `Comment ${options.comment} resolved in review ${reviewId}`\n : `Review ${reviewId} resolved`\n );\n });\n\nprogram\n .command('doctor')\n .description('Diagnose setup and validate git/state')\n .action(async () => {\n const globals = program.opts<GlobalOptions>();\n const checks: Array<{ name: string; ok: boolean; detail?: string }> = [];\n try {\n await assertGitAvailable();\n checks.push({ name: 'git', ok: true });\n } catch (error) {\n checks.push({\n name: 'git',\n ok: false,\n detail: error instanceof Error ? error.message : String(error)\n });\n }\n try {\n const root = await getRepoRoot();\n checks.push({ name: 'repo', ok: true, detail: root });\n } catch (error) {\n checks.push({\n name: 'repo',\n ok: false,\n detail: error instanceof Error ? error.message : String(error)\n });\n }\n const info = await readServerInfo();\n checks.push({\n name: 'server',\n ok: info ? await isServerResponsive(info) : false,\n detail: info ? serverUrl(info) : 'not started'\n });\n if (globals.json) {\n printJson({ checks });\n } else {\n for (const check of checks) {\n printPlain(\n `${check.ok ? 'ok' : 'fail'} ${check.name}${check.detail ? ` - ${check.detail}` : ''}`\n );\n }\n }\n });\n\nprogram.parseAsync(process.argv).catch((error: unknown) => {\n process.stderr.write(`${error instanceof Error ? error.message : String(error)}\\n`);\n process.exitCode = 1;\n});\n","import { mkdir } from 'node:fs/promises';\nimport { homedir } from 'node:os';\nimport path from 'node:path';\nimport packageJson from '../../package.json';\n\nexport const packageVersion = packageJson.version;\n\nexport function expandHome(input: string): string {\n if (input === '~') {\n return homedir();\n }\n if (input.startsWith('~/')) {\n return path.join(homedir(), input.slice(2));\n }\n return input;\n}\n\nexport function globalStateDir(): string {\n return expandHome(process.env.GLOSS_STATE_DIR ?? '~/.gloss');\n}\n\nexport function globalServerFile(): string {\n return path.join(globalStateDir(), 'server.json');\n}\n\nexport function globalLogDir(): string {\n return path.join(globalStateDir(), 'logs');\n}\n\nexport function globalServerLogFile(): string {\n return path.join(globalLogDir(), 'server.log');\n}\n\nexport function globalReviewsDir(): string {\n return path.join(globalStateDir(), 'reviews');\n}\n\nexport function globalReviewDir(reviewId: string): string {\n return path.join(globalReviewsDir(), reviewId);\n}\n\nexport function globalReviewMetaFile(reviewId: string): string {\n return path.join(globalReviewDir(reviewId), 'meta.json');\n}\n\nexport function globalReviewDiffFile(reviewId: string): string {\n return path.join(globalReviewDir(reviewId), 'diff.json');\n}\n\nexport function globalReviewFeedbackFile(reviewId: string): string {\n return path.join(globalReviewDir(reviewId), 'feedback.json');\n}\n\nexport function globalReviewMarkdownFile(reviewId: string): string {\n return path.join(globalReviewDir(reviewId), 'feedback.md');\n}\n\nexport function globalReviewResolvedFile(reviewId: string): string {\n return path.join(globalReviewDir(reviewId), 'resolved.json');\n}\n\nexport async function ensureDir(dir: string): Promise<void> {\n await mkdir(dir, { recursive: true });\n}\n","{\n \"name\": \"getgloss\",\n \"version\": \"0.7.0\",\n \"description\": \"Local browser-based diff review for coding-agent loops.\",\n \"type\": \"module\",\n \"packageManager\": \"pnpm@10.33.2\",\n \"bin\": {\n \"getgloss\": \"./dist/cli/index.js\",\n \"gloss\": \"./dist/cli/index.js\"\n },\n \"files\": [\n \"dist\",\n \"skill\",\n \"README.md\",\n \"LICENSE\"\n ],\n \"scripts\": {\n \"build\": \"pnpm build:web && pnpm build:node\",\n \"build:web\": \"vite build\",\n \"build:node\": \"tsup\",\n \"check\": \"biome check .\",\n \"format\": \"biome format --write .\",\n \"prepack\": \"pnpm build\",\n \"dev:web\": \"vite --host 127.0.0.1\",\n \"setup\": \"tsx scripts/dev-cli.ts\",\n \"test\": \"vitest run\",\n \"test:watch\": \"vitest\"\n },\n \"engines\": {\n \"node\": \">=20\"\n },\n \"dependencies\": {\n \"@hono/node-server\": \"1.19.14\",\n \"@tailwindcss/vite\": \"4.3.0\",\n \"commander\": \"14.0.3\",\n \"execa\": \"9.6.1\",\n \"get-port\": \"7.2.0\",\n \"hono\": \"4.12.21\",\n \"lucide-react\": \"1.16.0\",\n \"open\": \"10.2.0\",\n \"react\": \"19.2.6\",\n \"react-dom\": \"19.2.6\",\n \"ulid\": \"3.0.2\",\n \"zustand\": \"5.0.13\"\n },\n \"devDependencies\": {\n \"@biomejs/biome\": \"2.4.15\",\n \"@types/node\": \"24.12.4\",\n \"@types/react\": \"19.2.15\",\n \"@types/react-dom\": \"19.2.3\",\n \"@vitejs/plugin-react\": \"4.7.0\",\n \"tailwindcss\": \"4.3.0\",\n \"tsup\": \"8.5.1\",\n \"tsx\": \"4.22.3\",\n \"typescript\": \"5.9.3\",\n \"vite\": \"6.4.2\",\n \"vitest\": \"3.2.4\"\n },\n \"keywords\": [\n \"diff\",\n \"review\",\n \"coding-agents\"\n ],\n \"author\": \"Raj Joshi\",\n \"license\": \"MIT\",\n \"homepage\": \"https://getgloss.dev\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/iamrajjoshi/gloss.git\"\n },\n \"bugs\": {\n \"url\": \"https://github.com/iamrajjoshi/gloss/issues\"\n },\n \"publishConfig\": {\n \"access\": \"public\"\n }\n}\n","import { execa } from 'execa';\nimport type {\n DiffFallbackReason,\n DiffFile,\n DiffPayload,\n DiffScopeMode,\n DiffStats\n} from '../shared/types';\nimport { parseUnifiedDiff } from './diff-parser';\n\nconst DIFF_ARGS = ['diff', '--no-color', '--find-renames', '--find-copies'];\n\nasync function git(args: string[], cwd = process.cwd()): Promise<string> {\n const result = await execa('git', args, { cwd });\n return result.stdout.trimEnd();\n}\n\nasync function gitMaybe(args: string[], cwd: string): Promise<string | null> {\n const result = await execa('git', args, { cwd, reject: false });\n return result.exitCode === 0 ? result.stdout.trimEnd() : null;\n}\n\nasync function gitLenient(args: string[], cwd: string): Promise<string> {\n const result = await execa('git', args, { cwd, reject: false });\n if (result.exitCode !== 0 && result.stdout.length === 0) {\n throw new Error(result.stderr || `git ${args.join(' ')} failed`);\n }\n return result.stdout.trimEnd();\n}\n\nexport async function getRepoRoot(cwd = process.cwd()): Promise<string> {\n return git(['rev-parse', '--show-toplevel'], cwd);\n}\n\ninterface ResolvedBranchBase {\n sourceRef: string;\n mergeBaseSha: string;\n}\n\ninterface PayloadOptions {\n repoRoot: string;\n branch: string | null;\n rawDiff: string;\n base: { ref: string; sha: string };\n mode: DiffScopeMode;\n requestedBase: string | null;\n comparison: { ref: string; sha: string | null };\n fallbackReason: DiffFallbackReason;\n}\n\nfunction summarize(files: DiffFile[]): DiffStats {\n return files.reduce(\n (stats, file) => ({\n files: stats.files + 1,\n additions: stats.additions + file.additions,\n deletions: stats.deletions + file.deletions\n }),\n { files: 0, additions: 0, deletions: 0 }\n );\n}\n\nfunction buildPayload({\n repoRoot,\n branch,\n rawDiff,\n base,\n mode,\n requestedBase,\n comparison,\n fallbackReason\n}: PayloadOptions): DiffPayload {\n const files = parseUnifiedDiff(rawDiff);\n return {\n base,\n branch,\n cwd: repoRoot,\n scope: {\n mode,\n requestedBase,\n base,\n comparison,\n fallbackReason\n },\n stats: summarize(files),\n rawDiff,\n files,\n capturedAt: new Date().toISOString()\n };\n}\n\nasync function currentBranch(repoRoot: string): Promise<string | null> {\n const branch = await gitMaybe(['rev-parse', '--abbrev-ref', 'HEAD'], repoRoot);\n return branch && branch !== 'HEAD' ? branch : null;\n}\n\nasync function captureUntrackedDiff(repoRoot: string): Promise<string[]> {\n const untrackedFilesRaw = await git(\n ['ls-files', '--others', '--exclude-standard', '-z'],\n repoRoot\n );\n const untrackedFiles = untrackedFilesRaw.split('\\0').filter(Boolean);\n return Promise.all(\n untrackedFiles.map((filePath) =>\n gitLenient(['diff', '--no-color', '--no-index', '--', '/dev/null', filePath], repoRoot)\n )\n );\n}\n\nasync function captureWorkingDiff(baseRef: string, repoRoot: string): Promise<string> {\n const [trackedDiff, untrackedDiffs] = await Promise.all([\n git([...DIFF_ARGS, baseRef, '--'], repoRoot),\n captureUntrackedDiff(repoRoot)\n ]);\n return [trackedDiff, ...untrackedDiffs].filter(Boolean).join('\\n');\n}\n\nasync function resolveCommit(ref: string, repoRoot: string): Promise<string | null> {\n return gitMaybe(['rev-parse', '--verify', `${ref}^{commit}`], repoRoot);\n}\n\nasync function resolveBranchBase(repoRoot: string): Promise<ResolvedBranchBase | null> {\n const candidates: string[] = [];\n const upstream = await gitMaybe(\n ['rev-parse', '--abbrev-ref', '--symbolic-full-name', '@{upstream}'],\n repoRoot\n );\n const originHead = await gitMaybe(\n ['symbolic-ref', '--quiet', '--short', 'refs/remotes/origin/HEAD'],\n repoRoot\n );\n\n for (const ref of [upstream, originHead, 'origin/main', 'origin/master']) {\n if (ref && !candidates.includes(ref)) {\n candidates.push(ref);\n }\n }\n\n for (const sourceRef of candidates) {\n const [sourceSha, mergeBaseSha] = await Promise.all([\n resolveCommit(sourceRef, repoRoot),\n gitMaybe(['merge-base', 'HEAD', sourceRef], repoRoot)\n ]);\n if (sourceSha && mergeBaseSha) {\n return { sourceRef, mergeBaseSha };\n }\n }\n\n return null;\n}\n\nexport async function captureDiff(baseRef?: string, cwd = process.cwd()): Promise<DiffPayload> {\n const repoRoot = await getRepoRoot(cwd);\n const [headSha, branch] = await Promise.all([\n git(['rev-parse', 'HEAD'], repoRoot),\n currentBranch(repoRoot)\n ]);\n\n if (baseRef) {\n const [baseSha, rawDiff] = await Promise.all([\n git(['rev-parse', baseRef], repoRoot),\n captureWorkingDiff(baseRef, repoRoot)\n ]);\n return buildPayload({\n repoRoot,\n branch,\n rawDiff,\n base: { ref: baseRef, sha: baseSha },\n mode: 'explicit',\n requestedBase: baseRef,\n comparison: { ref: 'working tree', sha: null },\n fallbackReason: null\n });\n }\n\n const workingDiff = await captureWorkingDiff('HEAD', repoRoot);\n if (workingDiff.trim().length > 0) {\n return buildPayload({\n repoRoot,\n branch,\n rawDiff: workingDiff,\n base: { ref: 'HEAD', sha: headSha },\n mode: 'working',\n requestedBase: null,\n comparison: { ref: 'working tree', sha: null },\n fallbackReason: null\n });\n }\n\n const branchBase = await resolveBranchBase(repoRoot);\n if (!branchBase) {\n return buildPayload({\n repoRoot,\n branch,\n rawDiff: '',\n base: { ref: 'HEAD', sha: headSha },\n mode: 'working',\n requestedBase: null,\n comparison: { ref: 'working tree', sha: null },\n fallbackReason: 'missing-branch-base'\n });\n }\n\n const rawDiff = await git([...DIFF_ARGS, branchBase.mergeBaseSha, 'HEAD', '--'], repoRoot);\n return buildPayload({\n repoRoot,\n branch,\n rawDiff,\n base: { ref: `merge-base(${branchBase.sourceRef})`, sha: branchBase.mergeBaseSha },\n mode: 'branch',\n requestedBase: null,\n comparison: { ref: 'HEAD', sha: headSha },\n fallbackReason: 'working-tree-clean'\n });\n}\n\nexport async function assertGitAvailable(): Promise<void> {\n await execa('git', ['--version']);\n}\n","import path from 'node:path';\n\nconst languageByExtension: Record<string, string> = {\n cjs: 'js',\n css: 'css',\n go: 'go',\n html: 'html',\n js: 'js',\n json: 'json',\n jsx: 'jsx',\n md: 'markdown',\n mjs: 'js',\n py: 'python',\n rb: 'ruby',\n rs: 'rust',\n sh: 'bash',\n swift: 'swift',\n ts: 'ts',\n tsx: 'tsx',\n yaml: 'yaml',\n yml: 'yaml'\n};\n\nexport function languageForPath(filePath: string): string | null {\n const ext = path.extname(filePath).slice(1).toLowerCase();\n if (!ext) {\n return null;\n }\n return languageByExtension[ext] ?? ext;\n}\n","import { languageForPath } from '../shared/language';\nimport type { DiffFile, DiffHunk, DiffLine } from '../shared/types';\n\nconst hunkHeaderPattern = /^@@ -(\\d+)(?:,(\\d+))? \\+(\\d+)(?:,(\\d+))? @@(.*)$/;\n\nfunction stripGitPath(input: string): string {\n return input.replace(/^[ab]\\//, '');\n}\n\nfunction emptyFile(): DiffFile {\n return {\n path: '',\n oldPath: null,\n additions: 0,\n deletions: 0,\n isBinary: false,\n isDeleted: false,\n isNew: false,\n isRenamed: false,\n language: null,\n hunks: []\n };\n}\n\nexport function parseUnifiedDiff(diffText: string): DiffFile[] {\n const files: DiffFile[] = [];\n let current: DiffFile | null = null;\n let currentHunk: DiffHunk | null = null;\n let oldCursor = 0;\n let newCursor = 0;\n\n const finalizeFile = () => {\n if (current?.path) {\n current.language = languageForPath(current.path);\n files.push(current);\n }\n };\n\n for (const line of diffText.split('\\n')) {\n if (line.startsWith('diff --git ')) {\n finalizeFile();\n current = emptyFile();\n currentHunk = null;\n oldCursor = 0;\n newCursor = 0;\n const match = /^diff --git a\\/(.+) b\\/(.+)$/.exec(line);\n if (match) {\n current.oldPath = match[1];\n current.path = match[2];\n }\n continue;\n }\n\n if (!current) {\n continue;\n }\n\n if (line.startsWith('new file mode')) {\n current.isNew = true;\n continue;\n }\n\n if (line.startsWith('deleted file mode')) {\n current.isDeleted = true;\n continue;\n }\n\n if (line.startsWith('rename from ')) {\n current.oldPath = line.slice('rename from '.length);\n current.isRenamed = true;\n continue;\n }\n\n if (line.startsWith('rename to ')) {\n current.path = line.slice('rename to '.length);\n current.isRenamed = true;\n continue;\n }\n\n if (line.startsWith('Binary files ') || line.startsWith('GIT binary patch')) {\n current.isBinary = true;\n continue;\n }\n\n if (line.startsWith('--- ')) {\n const oldPath = line.slice(4).trim();\n current.oldPath = oldPath === '/dev/null' ? null : stripGitPath(oldPath);\n continue;\n }\n\n if (line.startsWith('+++ ')) {\n const newPath = line.slice(4).trim();\n current.path =\n newPath === '/dev/null' ? (current.oldPath ?? current.path) : stripGitPath(newPath);\n continue;\n }\n\n const hunkMatch = hunkHeaderPattern.exec(line);\n if (hunkMatch) {\n const oldStart = Number(hunkMatch[1]);\n const oldLines = Number(hunkMatch[2] ?? '1');\n const newStart = Number(hunkMatch[3]);\n const newLines = Number(hunkMatch[4] ?? '1');\n currentHunk = {\n oldStart,\n oldLines,\n newStart,\n newLines,\n header: hunkMatch[5]?.trim() ?? '',\n lines: []\n };\n current.hunks.push(currentHunk);\n oldCursor = oldStart;\n newCursor = newStart;\n continue;\n }\n\n if (!currentHunk) {\n continue;\n }\n\n const marker = line[0];\n const content = line.slice(1);\n let diffLine: DiffLine | null = null;\n\n if (marker === '+') {\n diffLine = { type: 'add', oldLine: null, newLine: newCursor, content };\n current.additions += 1;\n newCursor += 1;\n } else if (marker === '-') {\n diffLine = { type: 'delete', oldLine: oldCursor, newLine: null, content };\n current.deletions += 1;\n oldCursor += 1;\n } else if (marker === ' ') {\n diffLine = { type: 'context', oldLine: oldCursor, newLine: newCursor, content };\n oldCursor += 1;\n newCursor += 1;\n } else if (line.startsWith('\\\')) {\n continue;\n }\n\n if (diffLine) {\n currentHunk.lines.push(diffLine);\n }\n }\n\n finalizeFile();\n return files;\n}\n","import { spawn } from 'node:child_process';\nimport { existsSync, openSync } from 'node:fs';\nimport { rm } from 'node:fs/promises';\nimport { fileURLToPath } from 'node:url';\nimport getPort from 'get-port';\nimport {\n ensureDir,\n globalLogDir,\n globalServerFile,\n globalServerLogFile,\n globalStateDir,\n packageVersion\n} from '../shared/paths';\nimport { readServerInfo, writeServerInfo } from '../shared/server-info';\nimport type { ServerInfo } from '../shared/types';\nimport { ServerClient } from './server-client';\n\nexport { readServerInfo } from '../shared/server-info';\n\nexport function serverUrl(info: Pick<ServerInfo, 'port'>): string {\n return `http://localhost:${info.port}`;\n}\n\nexport async function isServerResponsive(info: ServerInfo): Promise<boolean> {\n if (!isPidAlive(info.pid)) {\n return false;\n }\n try {\n const health = await new ServerClient(serverUrl(info)).health();\n return health.ok === true && health.version === packageVersion;\n } catch {\n return false;\n }\n}\n\nexport async function ensureServer(options: { port?: number } = {}): Promise<ServerInfo> {\n const existing = await readServerInfo();\n if (existing && (await isServerResponsive(existing))) {\n return existing;\n }\n return startServer(options);\n}\n\nexport async function startServer(options: { port?: number } = {}): Promise<ServerInfo> {\n const existing = await readServerInfo();\n if (existing && (await isServerResponsive(existing))) {\n return existing;\n }\n\n await ensureDir(globalStateDir());\n await ensureDir(globalLogDir());\n const port = options.port ?? (await getPort());\n const daemonPath = fileURLToPath(new URL('../server/daemon.js', import.meta.url));\n if (!existsSync(daemonPath)) {\n throw new Error(`Cannot find server daemon at ${daemonPath}. Run pnpm build first.`);\n }\n\n const logFd = openSync(globalServerLogFile(), 'a');\n const child = spawn(process.execPath, [daemonPath], {\n detached: true,\n env: {\n ...process.env,\n GLOSS_PORT: String(port),\n GLOSS_STATE_DIR: globalStateDir()\n },\n stdio: ['ignore', logFd, logFd]\n });\n child.unref();\n\n const info: ServerInfo = {\n pid: child.pid ?? -1,\n port,\n version: packageVersion,\n startedAt: new Date().toISOString(),\n stateDir: globalStateDir()\n };\n await writeServerInfo(info);\n\n const deadline = Date.now() + 8000;\n while (Date.now() < deadline) {\n if (await isServerResponsive(info)) {\n return info;\n }\n await new Promise((resolve) => setTimeout(resolve, 150));\n }\n\n throw new Error(`Server did not become responsive. See ${globalServerLogFile()}`);\n}\n\nexport async function stopServer(): Promise<{ stopped: boolean; info: ServerInfo | null }> {\n const info = await readServerInfo();\n if (!info) {\n return { stopped: false, info: null };\n }\n\n if (isPidAlive(info.pid)) {\n process.kill(info.pid, 'SIGTERM');\n }\n await rm(globalServerFile(), { force: true });\n return { stopped: true, info };\n}\n\nfunction isPidAlive(pid: number): boolean {\n if (pid <= 0) {\n return false;\n }\n try {\n process.kill(pid, 0);\n return true;\n } catch {\n return false;\n }\n}\n","import { readFile } from 'node:fs/promises';\nimport { writeJsonFile } from './json';\nimport { ensureDir, globalServerFile, globalStateDir } from './paths';\nimport type { ServerInfo } from './types';\nimport { isServerInfo, parseJson } from './validation';\n\nexport async function readServerInfo(): Promise<ServerInfo | null> {\n let raw: string;\n try {\n raw = await readFile(globalServerFile(), 'utf8');\n } catch (error) {\n if (isFileNotFound(error)) {\n return null;\n }\n throw new Error(`Could not read server info at ${globalServerFile()}: ${formatError(error)}`, {\n cause: error\n });\n }\n\n try {\n return parseJson(raw, isServerInfo, 'server info');\n } catch (error) {\n throw new Error(`Invalid server info at ${globalServerFile()}: ${formatError(error)}`, {\n cause: error\n });\n }\n}\n\nexport async function writeServerInfo(info: ServerInfo): Promise<void> {\n await ensureDir(globalStateDir());\n await writeJsonFile(globalServerFile(), info);\n}\n\nfunction isFileNotFound(error: unknown): boolean {\n return error instanceof Error && 'code' in error && error.code === 'ENOENT';\n}\n\nfunction formatError(error: unknown): string {\n return error instanceof Error ? error.message : String(error);\n}\n","import { writeFile } from 'node:fs/promises';\n\nfunction serializeJson(value: object): string {\n return `${JSON.stringify(value, null, 2)}\\n`;\n}\n\nexport async function writeJsonFile(filePath: string, value: object): Promise<void> {\n await writeFile(filePath, serializeJson(value));\n}\n","import type {\n Comment,\n CreateReviewResponse,\n DiffFile,\n DiffHunk,\n DiffLine,\n DiffPayload,\n DiffStats,\n FeedbackBundle,\n HealthResponse,\n ListReviewsResponse,\n OpenResult,\n ResolutionBundle,\n ResolutionRequest,\n ResolvedComment,\n ResolveResult,\n ReviewEvent,\n ReviewMeta,\n ReviewRecord,\n ServerInfo,\n SubmitReviewRequest\n} from './types';\n\nexport type JsonGuard<T> = (value: unknown) => value is T;\n\nexport type StoredReviewMeta = Omit<ReviewMeta, 'artifactDir'> &\n Partial<Pick<ReviewMeta, 'artifactDir' | 'feedbackPath' | 'markdownPath'>>;\n\nconst reviewStatuses = ['pending', 'submitted', 'cancelled', 'resolved'] as const;\nconst resolutionStatuses = ['partial', 'resolved'] as const;\nconst reviewUpdateReasons = ['review-resolved', 'comment-resolved', 'comment-reopened'] as const;\nconst sides = ['L', 'R'] as const;\nconst diffLineTypes = ['context', 'add', 'delete'] as const;\nconst diffScopeModes = ['working', 'branch', 'explicit'] as const;\nconst diffFallbackReasons = ['working-tree-clean', 'missing-branch-base'] as const;\n\nexport function parseJson<T>(raw: string, guard: JsonGuard<T>, label: string): T {\n const parsed: unknown = JSON.parse(raw);\n return parseJsonValue(parsed, guard, label);\n}\n\nexport function parseJsonValue<T>(value: unknown, guard: JsonGuard<T>, label: string): T {\n if (!guard(value)) {\n throw new Error(`Invalid ${label}`);\n }\n return value;\n}\n\nexport function isServerInfo(value: unknown): value is ServerInfo {\n return (\n isRecord(value) &&\n isNumber(value.pid) &&\n isNumber(value.port) &&\n isString(value.version) &&\n isString(value.startedAt) &&\n isString(value.stateDir)\n );\n}\n\nexport function isHealthResponse(value: unknown): value is HealthResponse {\n return (\n isRecord(value) &&\n isBoolean(value.ok) &&\n isString(value.version) &&\n isNumber(value.activeReviews)\n );\n}\n\nexport function isCreateReviewResponse(value: unknown): value is CreateReviewResponse {\n return isRecord(value) && isReviewMeta(value.meta) && isString(value.url);\n}\n\nexport function isListReviewsResponse(value: unknown): value is ListReviewsResponse {\n return isRecord(value) && isArrayOf(value.reviews, isReviewMeta);\n}\n\nexport function isOpenResult(value: unknown): value is OpenResult {\n return (\n isRecord(value) &&\n isString(value.reviewId) &&\n isString(value.url) &&\n isNumber(value.files) &&\n isOptionalNumber(value.comments) &&\n isOptionalString(value.feedbackPath) &&\n isOptionalString(value.markdownPath) &&\n isOptionalString(value.artifactDir)\n );\n}\n\nexport function isResolveResult(value: unknown): value is ResolveResult {\n return (\n isRecord(value) &&\n value.ok === true &&\n isString(value.reviewId) &&\n isReviewStatus(value.status) &&\n isResolutionStatus(value.resolutionStatus) &&\n isResolutionCounts(value.comments) &&\n isString(value.path) &&\n isResolutionBundle(value.resolution)\n );\n}\n\nexport function isSubmitReviewRequest(value: unknown): value is SubmitReviewRequest {\n return isRecord(value) && isArrayOf(value.comments, isComment);\n}\n\nexport function isResolutionRequest(value: unknown): value is ResolutionRequest {\n return isRecord(value) && isOptionalString(value.summary);\n}\n\nexport function isReviewRecord(value: unknown): value is ReviewRecord {\n return (\n isRecord(value) &&\n isReviewMeta(value.meta) &&\n isDiffPayload(value.diff) &&\n isOptional(value.feedback, isFeedbackBundle) &&\n isOptional(value.resolution, isResolutionBundle)\n );\n}\n\nexport function isStoredReviewMeta(value: unknown): value is StoredReviewMeta {\n return (\n isRecord(value) &&\n isString(value.id) &&\n isString(value.cwd) &&\n isBaseRef(value.base) &&\n isNullableString(value.branch) &&\n isReviewStatus(value.status) &&\n isString(value.createdAt) &&\n isOptionalString(value.submittedAt) &&\n isOptionalString(value.resolvedAt) &&\n isOptionalString(value.artifactDir) &&\n isOptionalString(value.feedbackPath) &&\n isOptionalString(value.markdownPath)\n );\n}\n\nfunction isReviewMeta(value: unknown): value is ReviewMeta {\n return isStoredReviewMeta(value) && isString(value.artifactDir);\n}\n\nexport function isDiffPayload(value: unknown): value is DiffPayload {\n return (\n isRecord(value) &&\n isBaseRef(value.base) &&\n isNullableString(value.branch) &&\n isString(value.cwd) &&\n isDiffScope(value.scope) &&\n isDiffStats(value.stats) &&\n isString(value.rawDiff) &&\n isArrayOf(value.files, isDiffFile) &&\n isString(value.capturedAt)\n );\n}\n\nexport function isFeedbackBundle(value: unknown): value is FeedbackBundle {\n return (\n isRecord(value) &&\n value.version === 1 &&\n isString(value.reviewId) &&\n isString(value.timestamp) &&\n isBaseRef(value.base) &&\n isNullableString(value.branch) &&\n isArrayOf(value.comments, isComment)\n );\n}\n\nexport function isResolutionBundle(value: unknown): value is ResolutionBundle {\n return (\n isRecord(value) &&\n isString(value.reviewId) &&\n isResolutionStatus(value.status) &&\n isNullableString(value.summary) &&\n isNullableString(value.resolvedAt) &&\n isArrayOf(value.comments, isResolvedComment)\n );\n}\n\nexport function isReviewEvent(value: unknown): value is ReviewEvent {\n if (!isRecord(value) || !isString(value.reviewId) || !isString(value.type)) {\n return false;\n }\n switch (value.type) {\n case 'review.opened':\n case 'review.cancelled':\n return true;\n case 'review.submitted':\n return (\n isRecord(value.counts) && isNumber(value.counts.files) && isNumber(value.counts.comments)\n );\n case 'review.updated':\n return (\n isReviewUpdateReason(value.reason) &&\n isReviewStatus(value.status) &&\n isResolutionStatus(value.resolutionStatus) &&\n isResolutionCounts(value.counts)\n );\n default:\n return false;\n }\n}\n\nfunction isDiffScope(value: unknown): value is DiffPayload['scope'] {\n return (\n isRecord(value) &&\n isOneOf(value.mode, diffScopeModes) &&\n isNullableString(value.requestedBase) &&\n isBaseRef(value.base) &&\n isDiffRef(value.comparison) &&\n (value.fallbackReason === null || isOneOf(value.fallbackReason, diffFallbackReasons))\n );\n}\n\nfunction isDiffRef(value: unknown): value is DiffPayload['scope']['comparison'] {\n return isRecord(value) && isString(value.ref) && isNullableString(value.sha);\n}\n\nfunction isBaseRef(value: unknown): value is { ref: string; sha: string } {\n return isRecord(value) && isString(value.ref) && isString(value.sha);\n}\n\nfunction isDiffStats(value: unknown): value is DiffStats {\n return (\n isRecord(value) &&\n isNumber(value.files) &&\n isNumber(value.additions) &&\n isNumber(value.deletions)\n );\n}\n\nfunction isDiffFile(value: unknown): value is DiffFile {\n return (\n isRecord(value) &&\n isString(value.path) &&\n isNullableString(value.oldPath) &&\n isNumber(value.additions) &&\n isNumber(value.deletions) &&\n isBoolean(value.isBinary) &&\n isBoolean(value.isDeleted) &&\n isBoolean(value.isNew) &&\n isBoolean(value.isRenamed) &&\n isNullableString(value.language) &&\n isArrayOf(value.hunks, isDiffHunk)\n );\n}\n\nfunction isDiffHunk(value: unknown): value is DiffHunk {\n return (\n isRecord(value) &&\n isNumber(value.oldStart) &&\n isNumber(value.oldLines) &&\n isNumber(value.newStart) &&\n isNumber(value.newLines) &&\n isString(value.header) &&\n isArrayOf(value.lines, isDiffLine)\n );\n}\n\nfunction isDiffLine(value: unknown): value is DiffLine {\n return (\n isRecord(value) &&\n isOneOf(value.type, diffLineTypes) &&\n isNullableNumber(value.oldLine) &&\n isNullableNumber(value.newLine) &&\n isString(value.content)\n );\n}\n\nfunction isComment(value: unknown): value is Comment {\n return (\n isRecord(value) &&\n isString(value.id) &&\n isString(value.filePath) &&\n isNumber(value.startLine) &&\n isNumber(value.endLine) &&\n isOneOf(value.side, sides) &&\n isString(value.body) &&\n isString(value.originalSnippet) &&\n isString(value.createdAt)\n );\n}\n\nfunction isResolvedComment(value: unknown): value is ResolvedComment {\n return (\n isRecord(value) &&\n isString(value.commentId) &&\n value.status === 'resolved' &&\n isOptionalString(value.summary) &&\n isString(value.resolvedAt)\n );\n}\n\nfunction isResolutionCounts(value: unknown): value is ResolveResult['comments'] {\n return (\n isRecord(value) && isNumber(value.total) && isNumber(value.resolved) && isNumber(value.open)\n );\n}\n\nfunction isReviewStatus(value: unknown): value is ReviewMeta['status'] {\n return isOneOf(value, reviewStatuses);\n}\n\nfunction isResolutionStatus(value: unknown): value is ResolutionBundle['status'] {\n return isOneOf(value, resolutionStatuses);\n}\n\nfunction isReviewUpdateReason(\n value: unknown\n): value is Extract<ReviewEvent, { type: 'review.updated' }>['reason'] {\n return isOneOf(value, reviewUpdateReasons);\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' && value !== null && !Array.isArray(value);\n}\n\nfunction isArrayOf<T>(value: unknown, guard: JsonGuard<T>): value is T[] {\n return Array.isArray(value) && value.every(guard);\n}\n\nfunction isOptional<T>(value: unknown, guard: JsonGuard<T>): value is T | undefined {\n return value === undefined || guard(value);\n}\n\nfunction isString(value: unknown): value is string {\n return typeof value === 'string';\n}\n\nfunction isOptionalString(value: unknown): value is string | undefined {\n return value === undefined || isString(value);\n}\n\nfunction isNullableString(value: unknown): value is string | null {\n return value === null || isString(value);\n}\n\nfunction isNumber(value: unknown): value is number {\n return typeof value === 'number' && Number.isFinite(value);\n}\n\nfunction isOptionalNumber(value: unknown): value is number | undefined {\n return value === undefined || isNumber(value);\n}\n\nfunction isNullableNumber(value: unknown): value is number | null {\n return value === null || isNumber(value);\n}\n\nfunction isBoolean(value: unknown): value is boolean {\n return typeof value === 'boolean';\n}\n\nfunction isOneOf<const T extends readonly string[]>(\n value: unknown,\n options: T\n): value is T[number] {\n return typeof value === 'string' && options.includes(value);\n}\n","import type {\n Comment,\n CreateReviewResponse,\n DiffPayload,\n FeedbackBundle,\n HealthResponse,\n ListReviewsResponse,\n OpenResult,\n ResolutionRequest,\n ResolveResult,\n ReviewEvent,\n ReviewRecord,\n SubmitReviewRequest\n} from '../shared/types';\nimport {\n isCreateReviewResponse,\n isFeedbackBundle,\n isHealthResponse,\n isListReviewsResponse,\n isOpenResult,\n isResolveResult,\n isReviewEvent,\n isReviewRecord,\n type JsonGuard,\n parseJson,\n parseJsonValue\n} from '../shared/validation';\n\nexport class ServerClient {\n constructor(private readonly baseUrl: string) {}\n\n async health(): Promise<HealthResponse> {\n return this.get('/api/health', isHealthResponse, 'health response');\n }\n\n async createReview(diff: DiffPayload): Promise<CreateReviewResponse> {\n return this.post('/api/reviews', diff, isCreateReviewResponse, 'create review response');\n }\n\n async getReview(reviewId: string): Promise<ReviewRecord> {\n return this.get(`/api/reviews/${reviewId}`, isReviewRecord, 'review response');\n }\n\n async listReviews(): Promise<ListReviewsResponse> {\n return this.get('/api/reviews', isListReviewsResponse, 'review list response');\n }\n\n async getFeedback(reviewId: string): Promise<FeedbackBundle> {\n return this.get(`/api/reviews/${reviewId}/feedback`, isFeedbackBundle, 'feedback response');\n }\n\n async markResolved(reviewId: string, summary?: string): Promise<ResolveResult> {\n const request: ResolutionRequest = { summary };\n return this.post(\n `/api/reviews/${reviewId}/resolved`,\n request,\n isResolveResult,\n 'resolve response'\n );\n }\n\n async resolveComment(\n reviewId: string,\n commentId: string,\n summary?: string\n ): Promise<ResolveResult> {\n const request: ResolutionRequest = { summary };\n return this.post(\n `/api/reviews/${reviewId}/comments/${commentId}/resolved`,\n request,\n isResolveResult,\n 'resolve comment response'\n );\n }\n\n async reopenComment(reviewId: string, commentId: string): Promise<ResolveResult> {\n return this.delete(\n `/api/reviews/${reviewId}/comments/${commentId}/resolved`,\n isResolveResult,\n 'reopen comment response'\n );\n }\n\n async submitReview(reviewId: string, comments: Comment[]): Promise<OpenResult> {\n const request: SubmitReviewRequest = { comments };\n return this.post(\n `/api/reviews/${reviewId}/submit`,\n request,\n isOpenResult,\n 'submit review response'\n );\n }\n\n async watchReview(reviewId: string, timeoutSeconds?: number): Promise<ReviewEvent> {\n const deadline =\n timeoutSeconds && timeoutSeconds > 0 ? Date.now() + timeoutSeconds * 1000 : null;\n\n while (true) {\n const remainingMs = deadline ? deadline - Date.now() : null;\n if (remainingMs !== null && remainingMs <= 0) {\n throw new Error(`watch timed out after ${timeoutSeconds} seconds`);\n }\n\n const controller = new AbortController();\n const timeout = remainingMs ? setTimeout(() => controller.abort(), remainingMs) : null;\n try {\n return await this.readReviewEvents(reviewId, controller.signal);\n } catch (error) {\n if (isAbortError(error)) {\n throw new Error(`watch timed out after ${timeoutSeconds} seconds`);\n }\n if (!isPrematureWatchEnd(error)) {\n throw error;\n }\n await sleep(500);\n } finally {\n if (timeout) {\n clearTimeout(timeout);\n }\n }\n }\n }\n\n private async readReviewEvents(reviewId: string, signal: AbortSignal): Promise<ReviewEvent> {\n const response = await fetch(`${this.baseUrl}/api/reviews/${reviewId}/events`, {\n signal\n });\n if (!response.ok || !response.body) {\n throw new Error(`watch failed: ${response.status} ${await response.text()}`);\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n let buffer = '';\n\n while (true) {\n const { value, done } = await reader.read();\n if (done) {\n throw new Error('watch stream ended before completion');\n }\n buffer += decoder.decode(value, { stream: true });\n const events = buffer.split('\\n\\n');\n buffer = events.pop() ?? '';\n for (const eventChunk of events) {\n const dataLine = eventChunk.split('\\n').find((line) => line.startsWith('data:'));\n if (!dataLine) {\n continue;\n }\n const event = parseJson(dataLine.slice(5).trim(), isReviewEvent, 'review event');\n if (event.type === 'review.submitted' || event.type === 'review.cancelled') {\n await reader.cancel().catch(() => undefined);\n return event;\n }\n }\n }\n }\n\n private async get<T>(path: string, guard: JsonGuard<T>, label: string): Promise<T> {\n const response = await fetch(`${this.baseUrl}${path}`);\n return parseResponse(response, guard, label);\n }\n\n private async post<T>(\n path: string,\n body: object,\n guard: JsonGuard<T>,\n label: string\n ): Promise<T> {\n const response = await fetch(`${this.baseUrl}${path}`, {\n method: 'POST',\n headers: { 'content-type': 'application/json' },\n body: JSON.stringify(body)\n });\n return parseResponse(response, guard, label);\n }\n\n private async delete<T>(path: string, guard: JsonGuard<T>, label: string): Promise<T> {\n const response = await fetch(`${this.baseUrl}${path}`, { method: 'DELETE' });\n return parseResponse(response, guard, label);\n }\n}\n\nasync function parseResponse<T>(\n response: Response,\n guard: JsonGuard<T>,\n label: string\n): Promise<T> {\n if (!response.ok) {\n throw new Error(`${response.status} ${response.statusText}: ${await response.text()}`);\n }\n const value: unknown = await response.json();\n return parseJsonValue(value, guard, label);\n}\n\nfunction isPrematureWatchEnd(error: unknown): boolean {\n return error instanceof Error && error.message === 'watch stream ended before completion';\n}\n\nfunction isAbortError(error: unknown): boolean {\n return (\n typeof error === 'object' && error !== null && 'name' in error && error.name === 'AbortError'\n );\n}\n\nasync function sleep(milliseconds: number): Promise<void> {\n await new Promise((resolve) => setTimeout(resolve, milliseconds));\n}\n","import type { Dirent } from 'node:fs';\nimport { readdir, readFile, writeFile } from 'node:fs/promises';\nimport { ulid } from 'ulid';\nimport { compareCommentsByLocation, countCommentFiles, resolutionCounts } from '../shared/comments';\nimport { writeJsonFile } from '../shared/json';\nimport { serializeFeedbackMarkdown } from '../shared/markdown';\nimport {\n ensureDir,\n globalReviewDiffFile,\n globalReviewDir,\n globalReviewFeedbackFile,\n globalReviewMarkdownFile,\n globalReviewMetaFile,\n globalReviewResolvedFile,\n globalReviewsDir\n} from '../shared/paths';\nimport { isResolvableReviewStatus } from '../shared/reviews';\nimport type {\n Comment,\n DiffPayload,\n FeedbackBundle,\n ResolutionBundle,\n ResolvedComment,\n ResolveResult,\n ReviewEvent,\n ReviewMeta,\n ReviewRecord,\n ReviewUpdateReason\n} from '../shared/types';\nimport {\n isDiffPayload,\n isFeedbackBundle,\n isResolutionBundle,\n isStoredReviewMeta,\n type JsonGuard,\n parseJson\n} from '../shared/validation';\n\ntype Listener = (event: ReviewEvent) => void;\n\nexport class ReviewStore {\n private readonly reviews = new Map<string, ReviewRecord>();\n private readonly listeners = new Map<string, Set<Listener>>();\n\n async create(diff: DiffPayload): Promise<ReviewRecord> {\n const id = ulid();\n const createdAt = new Date().toISOString();\n const meta: ReviewMeta = {\n id,\n cwd: diff.cwd,\n base: diff.base,\n branch: diff.branch,\n status: 'pending',\n createdAt,\n artifactDir: globalReviewDir(id)\n };\n const record: ReviewRecord = { meta, diff };\n this.reviews.set(id, record);\n await this.persistInitial(record);\n this.emit({ type: 'review.opened', reviewId: id });\n return record;\n }\n\n async list(): Promise<ReviewMeta[]> {\n await this.loadAllReviews();\n return [...this.reviews.values()]\n .map((record) => record.meta)\n .sort((a, b) => a.createdAt.localeCompare(b.createdAt));\n }\n\n async get(id: string): Promise<ReviewRecord | null> {\n return this.reviews.get(id) ?? (await this.loadKnownReview(id));\n }\n\n async submit(\n id: string,\n comments: Comment[]\n ): Promise<{ record: ReviewRecord; feedbackPath: string; markdownPath: string }> {\n const record = await this.get(id);\n if (!record) {\n throw new Error(`Review ${id} not found`);\n }\n if (record.meta.status !== 'pending') {\n throw new Error(`Review ${id} is ${record.meta.status} and cannot be submitted`);\n }\n const timestamp = new Date().toISOString();\n const feedback: FeedbackBundle = {\n version: 1,\n reviewId: id,\n timestamp,\n base: record.diff.base,\n branch: record.diff.branch,\n comments: [...comments].sort(compareCommentsByLocation)\n };\n record.feedback = feedback;\n record.meta = { ...record.meta, status: 'submitted', submittedAt: timestamp };\n this.reviews.set(id, record);\n\n const artifactDir = globalReviewDir(id);\n const feedbackPath = globalReviewFeedbackFile(id);\n const markdownPath = globalReviewMarkdownFile(id);\n record.meta = {\n ...record.meta,\n artifactDir,\n feedbackPath,\n markdownPath\n };\n await ensureDir(artifactDir);\n await Promise.all([\n writeJsonFile(globalReviewMetaFile(id), record.meta),\n writeJsonFile(feedbackPath, feedback),\n writeFile(markdownPath, serializeFeedbackMarkdown(feedback))\n ]);\n\n this.emit({\n type: 'review.submitted',\n reviewId: id,\n counts: {\n files: countCommentFiles(feedback.comments),\n comments: feedback.comments.length\n }\n });\n return { record, feedbackPath, markdownPath };\n }\n\n async feedback(id: string): Promise<FeedbackBundle | null> {\n const record = await this.get(id);\n return record?.feedback ?? null;\n }\n\n async markResolved(id: string, summary?: string): Promise<ResolveResult> {\n const record = await this.get(id);\n if (!record) {\n throw new Error(`Review ${id} not found`);\n }\n this.assertResolvable(record, id);\n const resolvedAt = new Date().toISOString();\n const existingById = new Map(\n (record.resolution?.comments ?? []).map((comment) => [comment.commentId, comment])\n );\n const comments = this.sortResolvedComments(\n (record.feedback?.comments ?? []).map((comment) => ({\n ...existingById.get(comment.id),\n commentId: comment.id,\n status: 'resolved' as const,\n resolvedAt: existingById.get(comment.id)?.resolvedAt ?? resolvedAt\n })),\n record\n );\n const resolution: ResolutionBundle = {\n reviewId: id,\n status: 'resolved',\n summary: summary ?? record.resolution?.summary ?? null,\n resolvedAt,\n comments\n };\n record.meta = { ...record.meta, status: 'resolved', resolvedAt };\n return this.persistResolution(record, resolution, 'review-resolved');\n }\n\n async resolveComment(id: string, commentId: string, summary?: string): Promise<ResolveResult> {\n const record = await this.get(id);\n if (!record) {\n throw new Error(`Review ${id} not found`);\n }\n this.assertResolvable(record, id);\n this.assertCommentExists(record, commentId);\n\n const resolvedAt = new Date().toISOString();\n const previous = record.resolution?.comments.find((comment) => comment.commentId === commentId);\n const nextSummary = summary ?? previous?.summary;\n const nextComment: ResolvedComment = {\n commentId,\n status: 'resolved',\n ...(nextSummary ? { summary: nextSummary } : {}),\n resolvedAt\n };\n const comments = this.sortResolvedComments(\n [\n ...(record.resolution?.comments ?? []).filter((comment) => comment.commentId !== commentId),\n nextComment\n ],\n record\n );\n const counts = resolutionCounts(record.feedback, comments);\n const fullyResolved = counts.total === counts.resolved;\n const resolution: ResolutionBundle = {\n reviewId: id,\n status: fullyResolved ? 'resolved' : 'partial',\n summary: fullyResolved ? (record.resolution?.summary ?? null) : null,\n resolvedAt: fullyResolved ? resolvedAt : null,\n comments\n };\n record.meta = fullyResolved\n ? { ...record.meta, status: 'resolved', resolvedAt }\n : { ...record.meta, status: 'submitted', resolvedAt: undefined };\n return this.persistResolution(record, resolution, 'comment-resolved');\n }\n\n async reopenComment(id: string, commentId: string): Promise<ResolveResult> {\n const record = await this.get(id);\n if (!record) {\n throw new Error(`Review ${id} not found`);\n }\n this.assertResolvable(record, id);\n this.assertCommentExists(record, commentId);\n\n const comments = this.sortResolvedComments(\n (record.resolution?.comments ?? []).filter((comment) => comment.commentId !== commentId),\n record\n );\n const counts = resolutionCounts(record.feedback, comments);\n const fullyResolved = counts.total > 0 && counts.total === counts.resolved;\n const resolvedAt = fullyResolved ? new Date().toISOString() : null;\n const resolution: ResolutionBundle = {\n reviewId: id,\n status: fullyResolved ? 'resolved' : 'partial',\n summary: fullyResolved ? (record.resolution?.summary ?? null) : null,\n resolvedAt,\n comments\n };\n record.meta = fullyResolved\n ? { ...record.meta, status: 'resolved', resolvedAt: resolvedAt ?? undefined }\n : { ...record.meta, status: 'submitted', resolvedAt: undefined };\n return this.persistResolution(record, resolution, 'comment-reopened');\n }\n\n subscribe(reviewId: string, listener: Listener): () => void {\n const listeners = this.listeners.get(reviewId) ?? new Set<Listener>();\n listeners.add(listener);\n this.listeners.set(reviewId, listeners);\n return () => {\n listeners.delete(listener);\n if (listeners.size === 0) {\n this.listeners.delete(reviewId);\n }\n };\n }\n\n private emit(event: ReviewEvent): void {\n for (const listener of this.listeners.get(event.reviewId) ?? []) {\n listener(event);\n }\n }\n\n private async persistInitial(record: ReviewRecord): Promise<void> {\n const dir = globalReviewDir(record.meta.id);\n await ensureDir(dir);\n await Promise.all([\n writeJsonFile(globalReviewMetaFile(record.meta.id), record.meta),\n writeJsonFile(globalReviewDiffFile(record.meta.id), record.diff)\n ]);\n }\n\n private async loadKnownReview(id: string): Promise<ReviewRecord | null> {\n const existing = this.reviews.get(id);\n if (existing) {\n return existing;\n }\n\n return this.loadReview(id);\n }\n\n private async loadAllReviews(): Promise<void> {\n let entries: Dirent[];\n try {\n entries = await readdir(globalReviewsDir(), { withFileTypes: true });\n } catch (error) {\n if (isFileNotFound(error)) {\n return;\n }\n throw new Error(\n `Could not read reviews directory at ${globalReviewsDir()}: ${formatError(error)}`,\n {\n cause: error\n }\n );\n }\n\n await Promise.all(\n entries.filter((entry) => entry.isDirectory()).map((entry) => this.loadReview(entry.name))\n );\n }\n\n private async loadReview(id: string): Promise<ReviewRecord | null> {\n const metaPath = globalReviewMetaFile(id);\n const diffPath = globalReviewDiffFile(id);\n let metaRaw: string;\n let diffRaw: string;\n\n try {\n [metaRaw, diffRaw] = await Promise.all([\n readFile(metaPath, 'utf8'),\n readFile(diffPath, 'utf8')\n ]);\n } catch (error) {\n if (isFileNotFound(error)) {\n return null;\n }\n throw new Error(`Could not load review ${id}: ${formatError(error)}`, { cause: error });\n }\n\n const meta = parseJsonFile(metaRaw, isStoredReviewMeta, 'review metadata', metaPath);\n const diff = parseJsonFile(diffRaw, isDiffPayload, 'review diff', diffPath);\n const feedback = await readOptionalJsonFile(\n globalReviewFeedbackFile(id),\n isFeedbackBundle,\n 'review feedback'\n );\n const resolution = await readOptionalJsonFile(\n globalReviewResolvedFile(id),\n isResolutionBundle,\n 'review resolution'\n );\n\n const record: ReviewRecord = {\n meta: {\n ...meta,\n artifactDir: meta.artifactDir ?? globalReviewDir(id),\n feedbackPath: meta.feedbackPath ?? (feedback ? globalReviewFeedbackFile(id) : undefined),\n markdownPath: meta.markdownPath ?? (feedback ? globalReviewMarkdownFile(id) : undefined)\n },\n diff,\n feedback,\n resolution\n };\n this.reviews.set(id, record);\n return record;\n }\n\n private assertResolvable(\n record: ReviewRecord,\n id: string\n ): asserts record is ReviewRecord & {\n feedback: FeedbackBundle;\n } {\n if (!isResolvableReviewStatus(record.meta.status)) {\n throw new Error(`Review ${id} is ${record.meta.status} and cannot be resolved`);\n }\n if (!record.feedback) {\n throw new Error(`Review ${id} has no submitted feedback`);\n }\n }\n\n private assertCommentExists(\n record: ReviewRecord & { feedback: FeedbackBundle },\n commentId: string\n ): void {\n if (!record.feedback.comments.some((comment) => comment.id === commentId)) {\n throw new Error(`Comment ${commentId} not found`);\n }\n }\n\n private async persistResolution(\n record: ReviewRecord & { feedback: FeedbackBundle },\n resolution: ResolutionBundle,\n reason: ReviewUpdateReason\n ): Promise<ResolveResult> {\n record.resolution = resolution;\n this.reviews.set(record.meta.id, record);\n const resolvedPath = globalReviewResolvedFile(record.meta.id);\n await ensureDir(globalReviewDir(record.meta.id));\n await Promise.all([\n writeJsonFile(resolvedPath, resolution),\n writeJsonFile(globalReviewMetaFile(record.meta.id), record.meta)\n ]);\n const result: ResolveResult = {\n ok: true,\n reviewId: record.meta.id,\n status: record.meta.status,\n resolutionStatus: resolution.status,\n comments: resolutionCounts(record.feedback, resolution.comments),\n path: resolvedPath,\n resolution\n };\n this.emit({\n type: 'review.updated',\n reviewId: record.meta.id,\n reason,\n status: result.status,\n resolutionStatus: result.resolutionStatus,\n counts: result.comments\n });\n return result;\n }\n\n private sortResolvedComments(\n comments: ResolvedComment[],\n record: ReviewRecord & { feedback: FeedbackBundle }\n ): ResolvedComment[] {\n const feedbackIndex = new Map(\n record.feedback.comments.map((comment, index) => [comment.id, index] as const)\n );\n return comments\n .filter((comment) => feedbackIndex.has(comment.commentId))\n .sort(\n (a, b) =>\n (feedbackIndex.get(a.commentId) ?? Number.MAX_SAFE_INTEGER) -\n (feedbackIndex.get(b.commentId) ?? Number.MAX_SAFE_INTEGER)\n );\n }\n}\n\nasync function readOptionalJsonFile<T>(\n filePath: string,\n guard: JsonGuard<T>,\n label: string\n): Promise<T | undefined> {\n let raw: string;\n try {\n raw = await readFile(filePath, 'utf8');\n } catch (error) {\n if (isFileNotFound(error)) {\n return undefined;\n }\n throw new Error(`Could not read ${label} at ${filePath}: ${formatError(error)}`, {\n cause: error\n });\n }\n\n return parseJsonFile(raw, guard, label, filePath);\n}\n\nfunction parseJsonFile<T>(raw: string, guard: JsonGuard<T>, label: string, filePath: string): T {\n try {\n return parseJson(raw, guard, label);\n } catch (error) {\n throw new Error(`Invalid ${label} at ${filePath}: ${formatError(error)}`, { cause: error });\n }\n}\n\nfunction isFileNotFound(error: unknown): boolean {\n return error instanceof Error && 'code' in error && error.code === 'ENOENT';\n}\n\nfunction formatError(error: unknown): string {\n return error instanceof Error ? error.message : String(error);\n}\n\nexport const reviewStore = new ReviewStore();\n","import type {\n Comment,\n FeedbackBundle,\n ResolutionBundle,\n ResolutionCounts,\n ResolvedComment,\n Side\n} from './types';\n\nexport interface LineRange {\n side: Side;\n startLine: number;\n endLine: number;\n}\n\nexport function compareCommentsByLocation(a: Comment, b: Comment): number {\n return (\n a.filePath.localeCompare(b.filePath) ||\n a.startLine - b.startLine ||\n a.endLine - b.endLine ||\n a.side.localeCompare(b.side)\n );\n}\n\nexport function countCommentFiles(comments: Pick<Comment, 'filePath'>[]): number {\n return new Set(comments.map((comment) => comment.filePath)).size;\n}\n\nexport function formatLineRange(\n range: LineRange,\n options: { repeatSideOnEnd?: boolean } = {}\n): string {\n const startLine = Math.min(range.startLine, range.endLine);\n const endLine = Math.max(range.startLine, range.endLine);\n if (startLine === endLine) {\n return `${range.side}${startLine}`;\n }\n const endPrefix = options.repeatSideOnEnd === false ? '' : range.side;\n return `${range.side}${startLine}-${endPrefix}${endLine}`;\n}\n\nexport function resolutionCounts(\n feedback: FeedbackBundle | undefined,\n resolvedComments: ResolvedComment[] = []\n): ResolutionCounts {\n const comments = feedback?.comments ?? [];\n const resolvedIds = new Set(resolvedComments.map((comment) => comment.commentId));\n const resolved = comments.filter((comment) => resolvedIds.has(comment.id)).length;\n return {\n total: comments.length,\n resolved,\n open: comments.length - resolved\n };\n}\n\nexport function reviewResolutionCounts(record: {\n feedback?: FeedbackBundle;\n resolution?: ResolutionBundle;\n}): ResolutionCounts {\n return resolutionCounts(record.feedback, record.resolution?.comments ?? []);\n}\n","import { compareCommentsByLocation, formatLineRange } from './comments';\nimport { languageForPath } from './language';\nimport type { FeedbackBundle } from './types';\n\nfunction fenceFor(snippet: string): string {\n let fence = '```';\n while (snippet.includes(fence)) {\n fence += '`';\n }\n return fence;\n}\n\nfunction languageForSnippet(filePath: string, snippet: string): string {\n const lines = snippet.split('\\n').filter((line) => line.length > 0);\n const looksLikeUnifiedDiff =\n lines.length > 0 &&\n lines.some((line) => line.startsWith('+') || line.startsWith('-')) &&\n lines.every((line) => line.startsWith('+') || line.startsWith('-') || line.startsWith(' '));\n return looksLikeUnifiedDiff ? 'diff' : (languageForPath(filePath) ?? '');\n}\n\nexport function serializeFeedbackMarkdown(bundle: FeedbackBundle): string {\n const comments = [...bundle.comments].sort(compareCommentsByLocation);\n const files = [...new Set(comments.map((comment) => comment.filePath))];\n const lines: string[] = [\n `# Gloss feedback - ${bundle.timestamp}`,\n `Review: ${bundle.reviewId}`,\n `Base: ${bundle.base.ref} (${bundle.base.sha.slice(0, 7)}) Branch: ${bundle.branch ?? '(detached)'}`,\n `Files: ${files.length} Comments: ${comments.length}`,\n ''\n ];\n\n for (const filePath of files) {\n lines.push(`## ${filePath}`, '');\n for (const comment of comments.filter((item) => item.filePath === filePath)) {\n const snippet = comment.originalSnippet.trimEnd();\n const firstSnippetLine = snippet.split('\\n').find((line) => line.trim().length > 0);\n const heading =\n comment.startLine === comment.endLine && firstSnippetLine\n ? `### ${formatLineRange(comment)} - \\`${firstSnippetLine.trim().slice(0, 80)}\\``\n : `### ${formatLineRange(comment)}`;\n lines.push(heading, comment.body.trim(), '');\n if (snippet) {\n const fence = fenceFor(snippet);\n lines.push(`${fence}${languageForSnippet(comment.filePath, snippet)}`, snippet, fence, '');\n }\n }\n }\n\n return `${lines.join('\\n').trimEnd()}\\n`;\n}\n","import type { ReviewStatus } from './types';\n\nexport function isResolvableReviewStatus(status: ReviewStatus): boolean {\n return status === 'submitted' || status === 'resolved';\n}\n","import { ReviewStore } from '../server/store';\nimport type { ReviewMeta, ServerInfo } from '../shared/types';\nimport { serverUrl } from './lifecycle';\nimport { ServerClient } from './server-client';\n\nexport async function listReviewsForStatus({\n responsive,\n server\n}: {\n responsive: boolean;\n server: ServerInfo | null;\n}): Promise<ReviewMeta[]> {\n if (server && responsive) {\n try {\n return (await new ServerClient(serverUrl(server)).listReviews()).reviews;\n } catch {\n // Fall through to durable state if the daemon disappears between health and list.\n }\n }\n\n return new ReviewStore().list();\n}\n"],"mappings":"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","names":["path","rawDiff","path","readFile","writeFile","writeFile","isFileNotFound","formatError","readFile","result"]}
1
+ {"version":3,"sources":["../../src/cli/index.ts","../../src/shared/paths.ts","../../package.json","../../src/cli/git.ts","../../src/shared/language.ts","../../src/cli/diff-parser.ts","../../src/cli/lifecycle.ts","../../src/shared/server-info.ts","../../src/shared/json.ts","../../src/shared/validation.ts","../../src/cli/server-client.ts","../../src/server/store.ts","../../src/shared/comments.ts","../../src/shared/markdown.ts","../../src/shared/reviews.ts","../../src/cli/status.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from 'commander';\nimport openBrowser from 'open';\nimport {\n globalReviewDir,\n globalReviewFeedbackFile,\n globalReviewMarkdownFile,\n packageVersion\n} from '../shared/paths';\nimport { assertGitAvailable, captureDiff, getRepoRoot } from './git';\nimport {\n ensureServer,\n isServerResponsive,\n readServerInfo,\n serverUrl,\n startServer,\n stopServer\n} from './lifecycle';\nimport { ServerClient } from './server-client';\nimport { listReviewsForStatus } from './status';\n\ninterface GlobalOptions {\n json?: boolean;\n noColor?: boolean;\n}\n\nfunction printJson(value: object): void {\n process.stdout.write(`${JSON.stringify(value, null, 2)}\\n`);\n}\n\nfunction printPlain(value: string): void {\n process.stdout.write(`${value}\\n`);\n}\n\nconst program = new Command();\n\nprogram\n .name('gloss')\n .description('Local browser-based diff review for coding-agent loops.')\n .version(packageVersion)\n .option('--json', 'print JSON for supported commands')\n .option('--no-color', 'disable color output');\n\nprogram\n .command('open')\n .description('Capture local changes and open them for review')\n .option('--base <ref>', 'explicit base git ref')\n .option('--print-url', 'print review URL')\n .option('--no-open', 'do not open a browser')\n .option('--no-watch', 'return immediately after registering the review')\n .option('--timeout <seconds>', 'watch timeout in seconds', Number)\n .action(\n async (options: {\n base?: string;\n printUrl?: boolean;\n open?: boolean;\n watch?: boolean;\n timeout?: number;\n }) => {\n const globals = program.opts<GlobalOptions>();\n const info = await ensureServer();\n const client = new ServerClient(serverUrl(info));\n const diff = await captureDiff(options.base);\n const { meta, url } = await client.createReview(diff);\n\n if (options.printUrl) {\n printPlain(url);\n }\n if (options.open !== false) {\n await openBrowser(url);\n }\n\n if (options.watch === false) {\n const result = {\n reviewId: meta.id,\n url,\n files: diff.files.length,\n scope: diff.scope.mode,\n artifactDir: meta.artifactDir\n };\n globals.json ? printJson(result) : printPlain(`Review ${meta.id}: ${url}`);\n return;\n }\n\n const event = await client.watchReview(meta.id, options.timeout);\n if (event.type === 'review.cancelled') {\n process.exitCode = 2;\n globals.json ? printJson(event) : printPlain(`Review ${meta.id} cancelled`);\n return;\n }\n if (event.type !== 'review.submitted') {\n throw new Error(`Unexpected review event ${event.type}`);\n }\n\n const feedback = await client.getFeedback(meta.id);\n const result = {\n reviewId: meta.id,\n url,\n files: event.counts.files,\n comments: event.counts.comments,\n feedbackPath: globalReviewFeedbackFile(meta.id),\n markdownPath: globalReviewMarkdownFile(meta.id),\n artifactDir: globalReviewDir(meta.id),\n feedback\n };\n globals.json\n ? printJson(result)\n : printPlain(`Review ${meta.id} submitted with ${event.counts.comments} comments`);\n }\n );\n\nprogram\n .command('watch')\n .argument('<reviewId>', 'review id')\n .description('Wait for review.submitted for an existing review')\n .option('--timeout <seconds>', 'watch timeout in seconds', Number)\n .action(async (reviewId: string, options: { timeout?: number }) => {\n const globals = program.opts<GlobalOptions>();\n const info = await ensureServer();\n const client = new ServerClient(serverUrl(info));\n const event = await client.watchReview(reviewId, options.timeout);\n globals.json ? printJson(event) : printPlain(`${event.type} ${event.reviewId}`);\n });\n\nprogram\n .command('start')\n .description('Start or reuse the background server')\n .option('--port <port>', 'port to bind', Number)\n .action(async (options: { port?: number }) => {\n const globals = program.opts<GlobalOptions>();\n const info = await startServer({ port: options.port });\n globals.json\n ? printJson(info)\n : printPlain(`Gloss server running at ${serverUrl(info)} (pid ${info.pid})`);\n });\n\nprogram\n .command('status')\n .description('Show server and active reviews')\n .action(async () => {\n const globals = program.opts<GlobalOptions>();\n const info = await readServerInfo();\n const responsive = info ? await isServerResponsive(info) : false;\n const reviews = await listReviewsForStatus({ responsive, server: info });\n const status = { running: responsive, server: info, reviews };\n globals.json\n ? printJson(status)\n : printPlain(\n responsive && info\n ? `Gloss server running at ${serverUrl(info)} with ${reviews.length} active review(s)`\n : 'Gloss server is not running'\n );\n });\n\nprogram\n .command('stop')\n .description('Stop the managed background server')\n .action(async () => {\n const globals = program.opts<GlobalOptions>();\n const result = await stopServer();\n globals.json\n ? printJson(result)\n : printPlain(result.stopped ? 'Gloss server stopped' : 'Gloss server was not running');\n });\n\nprogram\n .command('resolve')\n .argument('<reviewId>', 'review id')\n .description('Mark a submitted review or one feedback comment as resolved')\n .option('--comment <commentId>', 'resolve one submitted feedback comment')\n .option('--summary <text>', 'brief summary of the fixes applied')\n .action(async (reviewId: string, options: { comment?: string; summary?: string }) => {\n const globals = program.opts<GlobalOptions>();\n const info = await ensureServer();\n const client = new ServerClient(serverUrl(info));\n const result = options.comment\n ? await client.resolveComment(reviewId, options.comment, options.summary)\n : await client.markResolved(reviewId, options.summary);\n if (globals.json) {\n printJson({\n commentId: options.comment ?? null,\n summary: options.summary ?? null,\n ...result\n });\n return;\n }\n printPlain(\n options.comment\n ? `Comment ${options.comment} resolved in review ${reviewId}`\n : `Review ${reviewId} resolved`\n );\n });\n\nprogram\n .command('doctor')\n .description('Diagnose setup and validate git/state')\n .action(async () => {\n const globals = program.opts<GlobalOptions>();\n const checks: Array<{ name: string; ok: boolean; detail?: string }> = [];\n try {\n await assertGitAvailable();\n checks.push({ name: 'git', ok: true });\n } catch (error) {\n checks.push({\n name: 'git',\n ok: false,\n detail: error instanceof Error ? error.message : String(error)\n });\n }\n try {\n const root = await getRepoRoot();\n checks.push({ name: 'repo', ok: true, detail: root });\n } catch (error) {\n checks.push({\n name: 'repo',\n ok: false,\n detail: error instanceof Error ? error.message : String(error)\n });\n }\n const info = await readServerInfo();\n checks.push({\n name: 'server',\n ok: info ? await isServerResponsive(info) : false,\n detail: info ? serverUrl(info) : 'not started'\n });\n if (globals.json) {\n printJson({ checks });\n } else {\n for (const check of checks) {\n printPlain(\n `${check.ok ? 'ok' : 'fail'} ${check.name}${check.detail ? ` - ${check.detail}` : ''}`\n );\n }\n }\n });\n\nprogram.parseAsync(process.argv).catch((error: unknown) => {\n process.stderr.write(`${error instanceof Error ? error.message : String(error)}\\n`);\n process.exitCode = 1;\n});\n","import { mkdir } from 'node:fs/promises';\nimport { homedir } from 'node:os';\nimport path from 'node:path';\nimport packageJson from '../../package.json';\n\nexport const packageVersion = packageJson.version;\n\nexport function expandHome(input: string): string {\n if (input === '~') {\n return homedir();\n }\n if (input.startsWith('~/')) {\n return path.join(homedir(), input.slice(2));\n }\n return input;\n}\n\nexport function globalStateDir(): string {\n return expandHome(process.env.GLOSS_STATE_DIR ?? '~/.gloss');\n}\n\nexport function globalServerFile(): string {\n return path.join(globalStateDir(), 'server.json');\n}\n\nexport function globalLogDir(): string {\n return path.join(globalStateDir(), 'logs');\n}\n\nexport function globalServerLogFile(): string {\n return path.join(globalLogDir(), 'server.log');\n}\n\nexport function globalReviewsDir(): string {\n return path.join(globalStateDir(), 'reviews');\n}\n\nexport function globalReviewDir(reviewId: string): string {\n return path.join(globalReviewsDir(), reviewId);\n}\n\nexport function globalReviewMetaFile(reviewId: string): string {\n return path.join(globalReviewDir(reviewId), 'meta.json');\n}\n\nexport function globalReviewDiffFile(reviewId: string): string {\n return path.join(globalReviewDir(reviewId), 'diff.json');\n}\n\nexport function globalReviewFeedbackFile(reviewId: string): string {\n return path.join(globalReviewDir(reviewId), 'feedback.json');\n}\n\nexport function globalReviewMarkdownFile(reviewId: string): string {\n return path.join(globalReviewDir(reviewId), 'feedback.md');\n}\n\nexport function globalReviewResolvedFile(reviewId: string): string {\n return path.join(globalReviewDir(reviewId), 'resolved.json');\n}\n\nexport async function ensureDir(dir: string): Promise<void> {\n await mkdir(dir, { recursive: true });\n}\n","{\n \"name\": \"getgloss\",\n \"version\": \"0.7.2\",\n \"description\": \"Local browser-based diff review for coding-agent loops.\",\n \"type\": \"module\",\n \"packageManager\": \"pnpm@10.33.2\",\n \"bin\": {\n \"getgloss\": \"./dist/cli/index.js\",\n \"gloss\": \"./dist/cli/index.js\"\n },\n \"files\": [\n \"dist\",\n \"skill\",\n \"README.md\",\n \"LICENSE\"\n ],\n \"scripts\": {\n \"build\": \"pnpm build:web && pnpm build:node\",\n \"build:web\": \"vite build\",\n \"build:node\": \"tsup\",\n \"check\": \"biome check .\",\n \"format\": \"biome format --write .\",\n \"prepack\": \"pnpm build\",\n \"dev:web\": \"vite --host 127.0.0.1\",\n \"setup\": \"tsx scripts/dev-cli.ts\",\n \"test\": \"vitest run\",\n \"test:watch\": \"vitest\"\n },\n \"engines\": {\n \"node\": \">=20\"\n },\n \"dependencies\": {\n \"@hono/node-server\": \"1.19.14\",\n \"@tailwindcss/vite\": \"4.3.0\",\n \"commander\": \"14.0.3\",\n \"execa\": \"9.6.1\",\n \"get-port\": \"7.2.0\",\n \"hono\": \"4.12.21\",\n \"lucide-react\": \"1.16.0\",\n \"open\": \"10.2.0\",\n \"react\": \"19.2.6\",\n \"react-dom\": \"19.2.6\",\n \"ulid\": \"3.0.2\",\n \"zustand\": \"5.0.13\"\n },\n \"devDependencies\": {\n \"@biomejs/biome\": \"2.4.15\",\n \"@types/node\": \"24.12.4\",\n \"@types/react\": \"19.2.15\",\n \"@types/react-dom\": \"19.2.3\",\n \"@vitejs/plugin-react\": \"4.7.0\",\n \"tailwindcss\": \"4.3.0\",\n \"tsup\": \"8.5.1\",\n \"tsx\": \"4.22.3\",\n \"typescript\": \"5.9.3\",\n \"vite\": \"6.4.2\",\n \"vitest\": \"3.2.4\"\n },\n \"keywords\": [\n \"diff\",\n \"review\",\n \"coding-agents\"\n ],\n \"author\": \"Raj Joshi\",\n \"license\": \"MIT\",\n \"homepage\": \"https://getgloss.dev\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/iamrajjoshi/gloss.git\"\n },\n \"bugs\": {\n \"url\": \"https://github.com/iamrajjoshi/gloss/issues\"\n },\n \"publishConfig\": {\n \"access\": \"public\"\n }\n}\n","import { execa } from 'execa';\nimport type {\n DiffFallbackReason,\n DiffFile,\n DiffPayload,\n DiffScopeMode,\n DiffStats\n} from '../shared/types';\nimport { parseUnifiedDiff } from './diff-parser';\n\nconst DIFF_ARGS = ['diff', '--no-color', '--find-renames', '--find-copies'];\n\nasync function git(args: string[], cwd = process.cwd()): Promise<string> {\n const result = await execa('git', args, { cwd });\n return result.stdout.trimEnd();\n}\n\nasync function gitMaybe(args: string[], cwd: string): Promise<string | null> {\n const result = await execa('git', args, { cwd, reject: false });\n return result.exitCode === 0 ? result.stdout.trimEnd() : null;\n}\n\nasync function gitLenient(args: string[], cwd: string): Promise<string> {\n const result = await execa('git', args, { cwd, reject: false });\n if (result.exitCode !== 0 && result.stdout.length === 0) {\n throw new Error(result.stderr || `git ${args.join(' ')} failed`);\n }\n return result.stdout.trimEnd();\n}\n\nexport async function getRepoRoot(cwd = process.cwd()): Promise<string> {\n return git(['rev-parse', '--show-toplevel'], cwd);\n}\n\ninterface ResolvedBranchBase {\n sourceRef: string;\n mergeBaseSha: string;\n}\n\ninterface PayloadOptions {\n repoRoot: string;\n branch: string | null;\n rawDiff: string;\n base: { ref: string; sha: string };\n mode: DiffScopeMode;\n requestedBase: string | null;\n comparison: { ref: string; sha: string | null };\n fallbackReason: DiffFallbackReason;\n}\n\nfunction summarize(files: DiffFile[]): DiffStats {\n return files.reduce(\n (stats, file) => ({\n files: stats.files + 1,\n additions: stats.additions + file.additions,\n deletions: stats.deletions + file.deletions\n }),\n { files: 0, additions: 0, deletions: 0 }\n );\n}\n\nfunction buildPayload({\n repoRoot,\n branch,\n rawDiff,\n base,\n mode,\n requestedBase,\n comparison,\n fallbackReason\n}: PayloadOptions): DiffPayload {\n const files = parseUnifiedDiff(rawDiff);\n return {\n base,\n branch,\n cwd: repoRoot,\n scope: {\n mode,\n requestedBase,\n base,\n comparison,\n fallbackReason\n },\n stats: summarize(files),\n rawDiff,\n files,\n capturedAt: new Date().toISOString()\n };\n}\n\nasync function currentBranch(repoRoot: string): Promise<string | null> {\n const branch = await gitMaybe(['rev-parse', '--abbrev-ref', 'HEAD'], repoRoot);\n return branch && branch !== 'HEAD' ? branch : null;\n}\n\nasync function captureUntrackedDiff(repoRoot: string): Promise<string[]> {\n const untrackedFilesRaw = await git(\n ['ls-files', '--others', '--exclude-standard', '-z'],\n repoRoot\n );\n const untrackedFiles = untrackedFilesRaw.split('\\0').filter(Boolean);\n return Promise.all(\n untrackedFiles.map((filePath) =>\n gitLenient(['diff', '--no-color', '--no-index', '--', '/dev/null', filePath], repoRoot)\n )\n );\n}\n\nasync function captureWorkingDiff(baseRef: string, repoRoot: string): Promise<string> {\n const [trackedDiff, untrackedDiffs] = await Promise.all([\n git([...DIFF_ARGS, baseRef, '--'], repoRoot),\n captureUntrackedDiff(repoRoot)\n ]);\n return [trackedDiff, ...untrackedDiffs].filter(Boolean).join('\\n');\n}\n\nasync function resolveCommit(ref: string, repoRoot: string): Promise<string | null> {\n return gitMaybe(['rev-parse', '--verify', `${ref}^{commit}`], repoRoot);\n}\n\nasync function resolveBranchBase(repoRoot: string): Promise<ResolvedBranchBase | null> {\n const candidates: string[] = [];\n const upstream = await gitMaybe(\n ['rev-parse', '--abbrev-ref', '--symbolic-full-name', '@{upstream}'],\n repoRoot\n );\n const originHead = await gitMaybe(\n ['symbolic-ref', '--quiet', '--short', 'refs/remotes/origin/HEAD'],\n repoRoot\n );\n\n for (const ref of [upstream, originHead, 'origin/main', 'origin/master']) {\n if (ref && !candidates.includes(ref)) {\n candidates.push(ref);\n }\n }\n\n for (const sourceRef of candidates) {\n const [sourceSha, mergeBaseSha] = await Promise.all([\n resolveCommit(sourceRef, repoRoot),\n gitMaybe(['merge-base', 'HEAD', sourceRef], repoRoot)\n ]);\n if (sourceSha && mergeBaseSha) {\n return { sourceRef, mergeBaseSha };\n }\n }\n\n return null;\n}\n\nexport async function captureDiff(baseRef?: string, cwd = process.cwd()): Promise<DiffPayload> {\n const repoRoot = await getRepoRoot(cwd);\n const [headSha, branch] = await Promise.all([\n git(['rev-parse', 'HEAD'], repoRoot),\n currentBranch(repoRoot)\n ]);\n\n if (baseRef) {\n const [baseSha, rawDiff] = await Promise.all([\n git(['rev-parse', baseRef], repoRoot),\n captureWorkingDiff(baseRef, repoRoot)\n ]);\n return buildPayload({\n repoRoot,\n branch,\n rawDiff,\n base: { ref: baseRef, sha: baseSha },\n mode: 'explicit',\n requestedBase: baseRef,\n comparison: { ref: 'working tree', sha: null },\n fallbackReason: null\n });\n }\n\n const workingDiff = await captureWorkingDiff('HEAD', repoRoot);\n if (workingDiff.trim().length > 0) {\n return buildPayload({\n repoRoot,\n branch,\n rawDiff: workingDiff,\n base: { ref: 'HEAD', sha: headSha },\n mode: 'working',\n requestedBase: null,\n comparison: { ref: 'working tree', sha: null },\n fallbackReason: null\n });\n }\n\n const branchBase = await resolveBranchBase(repoRoot);\n if (!branchBase) {\n return buildPayload({\n repoRoot,\n branch,\n rawDiff: '',\n base: { ref: 'HEAD', sha: headSha },\n mode: 'working',\n requestedBase: null,\n comparison: { ref: 'working tree', sha: null },\n fallbackReason: 'missing-branch-base'\n });\n }\n\n const rawDiff = await git([...DIFF_ARGS, branchBase.mergeBaseSha, 'HEAD', '--'], repoRoot);\n return buildPayload({\n repoRoot,\n branch,\n rawDiff,\n base: { ref: `merge-base(${branchBase.sourceRef})`, sha: branchBase.mergeBaseSha },\n mode: 'branch',\n requestedBase: null,\n comparison: { ref: 'HEAD', sha: headSha },\n fallbackReason: 'working-tree-clean'\n });\n}\n\nexport async function assertGitAvailable(): Promise<void> {\n await execa('git', ['--version']);\n}\n","import path from 'node:path';\n\nconst languageByExtension: Record<string, string> = {\n cjs: 'js',\n css: 'css',\n go: 'go',\n html: 'html',\n js: 'js',\n json: 'json',\n jsx: 'jsx',\n md: 'markdown',\n mjs: 'js',\n py: 'python',\n rb: 'ruby',\n rs: 'rust',\n sh: 'bash',\n swift: 'swift',\n ts: 'ts',\n tsx: 'tsx',\n yaml: 'yaml',\n yml: 'yaml'\n};\n\nexport function languageForPath(filePath: string): string | null {\n const ext = path.extname(filePath).slice(1).toLowerCase();\n if (!ext) {\n return null;\n }\n return languageByExtension[ext] ?? ext;\n}\n","import { languageForPath } from '../shared/language';\nimport type { DiffFile, DiffHunk, DiffLine } from '../shared/types';\n\nconst hunkHeaderPattern = /^@@ -(\\d+)(?:,(\\d+))? \\+(\\d+)(?:,(\\d+))? @@(.*)$/;\n\nfunction stripGitPath(input: string): string {\n return input.replace(/^[ab]\\//, '');\n}\n\nfunction emptyFile(): DiffFile {\n return {\n path: '',\n oldPath: null,\n additions: 0,\n deletions: 0,\n isBinary: false,\n isDeleted: false,\n isNew: false,\n isRenamed: false,\n language: null,\n hunks: []\n };\n}\n\nexport function parseUnifiedDiff(diffText: string): DiffFile[] {\n const files: DiffFile[] = [];\n let current: DiffFile | null = null;\n let currentHunk: DiffHunk | null = null;\n let oldCursor = 0;\n let newCursor = 0;\n\n const finalizeFile = () => {\n if (current?.path) {\n current.language = languageForPath(current.path);\n files.push(current);\n }\n };\n\n for (const line of diffText.split('\\n')) {\n if (line.startsWith('diff --git ')) {\n finalizeFile();\n current = emptyFile();\n currentHunk = null;\n oldCursor = 0;\n newCursor = 0;\n const match = /^diff --git a\\/(.+) b\\/(.+)$/.exec(line);\n if (match) {\n current.oldPath = match[1];\n current.path = match[2];\n }\n continue;\n }\n\n if (!current) {\n continue;\n }\n\n if (line.startsWith('new file mode')) {\n current.isNew = true;\n continue;\n }\n\n if (line.startsWith('deleted file mode')) {\n current.isDeleted = true;\n continue;\n }\n\n if (line.startsWith('rename from ')) {\n current.oldPath = line.slice('rename from '.length);\n current.isRenamed = true;\n continue;\n }\n\n if (line.startsWith('rename to ')) {\n current.path = line.slice('rename to '.length);\n current.isRenamed = true;\n continue;\n }\n\n if (line.startsWith('Binary files ') || line.startsWith('GIT binary patch')) {\n current.isBinary = true;\n continue;\n }\n\n if (line.startsWith('--- ')) {\n const oldPath = line.slice(4).trim();\n current.oldPath = oldPath === '/dev/null' ? null : stripGitPath(oldPath);\n continue;\n }\n\n if (line.startsWith('+++ ')) {\n const newPath = line.slice(4).trim();\n current.path =\n newPath === '/dev/null' ? (current.oldPath ?? current.path) : stripGitPath(newPath);\n continue;\n }\n\n const hunkMatch = hunkHeaderPattern.exec(line);\n if (hunkMatch) {\n const oldStart = Number(hunkMatch[1]);\n const oldLines = Number(hunkMatch[2] ?? '1');\n const newStart = Number(hunkMatch[3]);\n const newLines = Number(hunkMatch[4] ?? '1');\n currentHunk = {\n oldStart,\n oldLines,\n newStart,\n newLines,\n header: hunkMatch[5]?.trim() ?? '',\n lines: []\n };\n current.hunks.push(currentHunk);\n oldCursor = oldStart;\n newCursor = newStart;\n continue;\n }\n\n if (!currentHunk) {\n continue;\n }\n\n const marker = line[0];\n const content = line.slice(1);\n let diffLine: DiffLine | null = null;\n\n if (marker === '+') {\n diffLine = { type: 'add', oldLine: null, newLine: newCursor, content };\n current.additions += 1;\n newCursor += 1;\n } else if (marker === '-') {\n diffLine = { type: 'delete', oldLine: oldCursor, newLine: null, content };\n current.deletions += 1;\n oldCursor += 1;\n } else if (marker === ' ') {\n diffLine = { type: 'context', oldLine: oldCursor, newLine: newCursor, content };\n oldCursor += 1;\n newCursor += 1;\n } else if (line.startsWith('\\\')) {\n continue;\n }\n\n if (diffLine) {\n currentHunk.lines.push(diffLine);\n }\n }\n\n finalizeFile();\n return files;\n}\n","import { spawn } from 'node:child_process';\nimport { existsSync, openSync } from 'node:fs';\nimport { rm } from 'node:fs/promises';\nimport { fileURLToPath } from 'node:url';\nimport getPort from 'get-port';\nimport {\n ensureDir,\n globalLogDir,\n globalServerFile,\n globalServerLogFile,\n globalStateDir,\n packageVersion\n} from '../shared/paths';\nimport { readServerInfo, writeServerInfo } from '../shared/server-info';\nimport type { ServerInfo } from '../shared/types';\nimport { ServerClient } from './server-client';\n\nexport { readServerInfo } from '../shared/server-info';\n\nexport function serverUrl(info: Pick<ServerInfo, 'port'>): string {\n return `http://localhost:${info.port}`;\n}\n\nexport async function isServerResponsive(info: ServerInfo): Promise<boolean> {\n if (!isPidAlive(info.pid)) {\n return false;\n }\n try {\n const health = await new ServerClient(serverUrl(info)).health();\n return health.ok === true && health.version === packageVersion;\n } catch {\n return false;\n }\n}\n\nexport async function ensureServer(options: { port?: number } = {}): Promise<ServerInfo> {\n const existing = await readServerInfo();\n if (existing && (await isServerResponsive(existing))) {\n return existing;\n }\n return startServer(options);\n}\n\nexport async function startServer(options: { port?: number } = {}): Promise<ServerInfo> {\n const existing = await readServerInfo();\n if (existing && (await isServerResponsive(existing))) {\n return existing;\n }\n\n await ensureDir(globalStateDir());\n await ensureDir(globalLogDir());\n const port = options.port ?? (await getPort());\n const daemonPath = fileURLToPath(new URL('../server/daemon.js', import.meta.url));\n if (!existsSync(daemonPath)) {\n throw new Error(`Cannot find server daemon at ${daemonPath}. Run pnpm build first.`);\n }\n\n const logFd = openSync(globalServerLogFile(), 'a');\n const child = spawn(process.execPath, [daemonPath], {\n detached: true,\n env: {\n ...process.env,\n GLOSS_PORT: String(port),\n GLOSS_STATE_DIR: globalStateDir()\n },\n stdio: ['ignore', logFd, logFd]\n });\n child.unref();\n\n const info: ServerInfo = {\n pid: child.pid ?? -1,\n port,\n version: packageVersion,\n startedAt: new Date().toISOString(),\n stateDir: globalStateDir()\n };\n await writeServerInfo(info);\n\n const deadline = Date.now() + 8000;\n while (Date.now() < deadline) {\n if (await isServerResponsive(info)) {\n return info;\n }\n await new Promise((resolve) => setTimeout(resolve, 150));\n }\n\n throw new Error(`Server did not become responsive. See ${globalServerLogFile()}`);\n}\n\nexport async function stopServer(): Promise<{ stopped: boolean; info: ServerInfo | null }> {\n const info = await readServerInfo();\n if (!info) {\n return { stopped: false, info: null };\n }\n\n if (isPidAlive(info.pid)) {\n process.kill(info.pid, 'SIGTERM');\n }\n await rm(globalServerFile(), { force: true });\n return { stopped: true, info };\n}\n\nfunction isPidAlive(pid: number): boolean {\n if (pid <= 0) {\n return false;\n }\n try {\n process.kill(pid, 0);\n return true;\n } catch {\n return false;\n }\n}\n","import { readFile } from 'node:fs/promises';\nimport { writeJsonFile } from './json';\nimport { ensureDir, globalServerFile, globalStateDir } from './paths';\nimport type { ServerInfo } from './types';\nimport { isServerInfo, parseJson } from './validation';\n\nexport async function readServerInfo(): Promise<ServerInfo | null> {\n let raw: string;\n try {\n raw = await readFile(globalServerFile(), 'utf8');\n } catch (error) {\n if (isFileNotFound(error)) {\n return null;\n }\n throw new Error(`Could not read server info at ${globalServerFile()}: ${formatError(error)}`, {\n cause: error\n });\n }\n\n try {\n return parseJson(raw, isServerInfo, 'server info');\n } catch (error) {\n throw new Error(`Invalid server info at ${globalServerFile()}: ${formatError(error)}`, {\n cause: error\n });\n }\n}\n\nexport async function writeServerInfo(info: ServerInfo): Promise<void> {\n await ensureDir(globalStateDir());\n await writeJsonFile(globalServerFile(), info);\n}\n\nfunction isFileNotFound(error: unknown): boolean {\n return error instanceof Error && 'code' in error && error.code === 'ENOENT';\n}\n\nfunction formatError(error: unknown): string {\n return error instanceof Error ? error.message : String(error);\n}\n","import { writeFile } from 'node:fs/promises';\n\nfunction serializeJson(value: object): string {\n return `${JSON.stringify(value, null, 2)}\\n`;\n}\n\nexport async function writeJsonFile(filePath: string, value: object): Promise<void> {\n await writeFile(filePath, serializeJson(value));\n}\n","import type {\n Comment,\n CreateReviewResponse,\n DiffFile,\n DiffHunk,\n DiffLine,\n DiffPayload,\n DiffStats,\n FeedbackBundle,\n HealthResponse,\n ListReviewsResponse,\n OpenResult,\n ResolutionBundle,\n ResolutionRequest,\n ResolvedComment,\n ResolveResult,\n ReviewEvent,\n ReviewMeta,\n ReviewRecord,\n ServerInfo,\n SubmitReviewRequest\n} from './types';\n\nexport type JsonGuard<T> = (value: unknown) => value is T;\n\nexport type StoredReviewMeta = Omit<ReviewMeta, 'artifactDir'> &\n Partial<Pick<ReviewMeta, 'artifactDir' | 'feedbackPath' | 'markdownPath'>>;\n\nconst reviewStatuses = ['pending', 'submitted', 'cancelled', 'resolved'] as const;\nconst resolutionStatuses = ['partial', 'resolved'] as const;\nconst reviewUpdateReasons = ['review-resolved', 'comment-resolved', 'comment-reopened'] as const;\nconst sides = ['L', 'R'] as const;\nconst diffLineTypes = ['context', 'add', 'delete'] as const;\nconst diffScopeModes = ['working', 'branch', 'explicit'] as const;\nconst diffFallbackReasons = ['working-tree-clean', 'missing-branch-base'] as const;\n\nexport function parseJson<T>(raw: string, guard: JsonGuard<T>, label: string): T {\n const parsed: unknown = JSON.parse(raw);\n return parseJsonValue(parsed, guard, label);\n}\n\nexport function parseJsonValue<T>(value: unknown, guard: JsonGuard<T>, label: string): T {\n if (!guard(value)) {\n throw new Error(`Invalid ${label}`);\n }\n return value;\n}\n\nexport function isServerInfo(value: unknown): value is ServerInfo {\n return (\n isRecord(value) &&\n isNumber(value.pid) &&\n isNumber(value.port) &&\n isString(value.version) &&\n isString(value.startedAt) &&\n isString(value.stateDir)\n );\n}\n\nexport function isHealthResponse(value: unknown): value is HealthResponse {\n return (\n isRecord(value) &&\n isBoolean(value.ok) &&\n isString(value.version) &&\n isNumber(value.activeReviews)\n );\n}\n\nexport function isCreateReviewResponse(value: unknown): value is CreateReviewResponse {\n return isRecord(value) && isReviewMeta(value.meta) && isString(value.url);\n}\n\nexport function isListReviewsResponse(value: unknown): value is ListReviewsResponse {\n return isRecord(value) && isArrayOf(value.reviews, isReviewMeta);\n}\n\nexport function isOpenResult(value: unknown): value is OpenResult {\n return (\n isRecord(value) &&\n isString(value.reviewId) &&\n isString(value.url) &&\n isNumber(value.files) &&\n isOptionalNumber(value.comments) &&\n isOptionalString(value.feedbackPath) &&\n isOptionalString(value.markdownPath) &&\n isOptionalString(value.artifactDir)\n );\n}\n\nexport function isResolveResult(value: unknown): value is ResolveResult {\n return (\n isRecord(value) &&\n value.ok === true &&\n isString(value.reviewId) &&\n isReviewStatus(value.status) &&\n isResolutionStatus(value.resolutionStatus) &&\n isResolutionCounts(value.comments) &&\n isString(value.path) &&\n isResolutionBundle(value.resolution)\n );\n}\n\nexport function isSubmitReviewRequest(value: unknown): value is SubmitReviewRequest {\n return isRecord(value) && isArrayOf(value.comments, isComment);\n}\n\nexport function isResolutionRequest(value: unknown): value is ResolutionRequest {\n return isRecord(value) && isOptionalString(value.summary);\n}\n\nexport function isReviewRecord(value: unknown): value is ReviewRecord {\n return (\n isRecord(value) &&\n isReviewMeta(value.meta) &&\n isDiffPayload(value.diff) &&\n isOptional(value.feedback, isFeedbackBundle) &&\n isOptional(value.resolution, isResolutionBundle)\n );\n}\n\nexport function isStoredReviewMeta(value: unknown): value is StoredReviewMeta {\n return (\n isRecord(value) &&\n isString(value.id) &&\n isString(value.cwd) &&\n isBaseRef(value.base) &&\n isNullableString(value.branch) &&\n isReviewStatus(value.status) &&\n isString(value.createdAt) &&\n isOptionalString(value.submittedAt) &&\n isOptionalString(value.resolvedAt) &&\n isOptionalString(value.artifactDir) &&\n isOptionalString(value.feedbackPath) &&\n isOptionalString(value.markdownPath)\n );\n}\n\nfunction isReviewMeta(value: unknown): value is ReviewMeta {\n return isStoredReviewMeta(value) && isString(value.artifactDir);\n}\n\nexport function isDiffPayload(value: unknown): value is DiffPayload {\n return (\n isRecord(value) &&\n isBaseRef(value.base) &&\n isNullableString(value.branch) &&\n isString(value.cwd) &&\n isDiffScope(value.scope) &&\n isDiffStats(value.stats) &&\n isString(value.rawDiff) &&\n isArrayOf(value.files, isDiffFile) &&\n isString(value.capturedAt)\n );\n}\n\nexport function isFeedbackBundle(value: unknown): value is FeedbackBundle {\n return (\n isRecord(value) &&\n value.version === 1 &&\n isString(value.reviewId) &&\n isString(value.timestamp) &&\n isBaseRef(value.base) &&\n isNullableString(value.branch) &&\n isArrayOf(value.comments, isComment)\n );\n}\n\nexport function isResolutionBundle(value: unknown): value is ResolutionBundle {\n return (\n isRecord(value) &&\n isString(value.reviewId) &&\n isResolutionStatus(value.status) &&\n isNullableString(value.summary) &&\n isNullableString(value.resolvedAt) &&\n isArrayOf(value.comments, isResolvedComment)\n );\n}\n\nexport function isReviewEvent(value: unknown): value is ReviewEvent {\n if (!isRecord(value) || !isString(value.reviewId) || !isString(value.type)) {\n return false;\n }\n switch (value.type) {\n case 'review.opened':\n case 'review.cancelled':\n return true;\n case 'review.submitted':\n return (\n isRecord(value.counts) && isNumber(value.counts.files) && isNumber(value.counts.comments)\n );\n case 'review.updated':\n return (\n isReviewUpdateReason(value.reason) &&\n isReviewStatus(value.status) &&\n isResolutionStatus(value.resolutionStatus) &&\n isResolutionCounts(value.counts)\n );\n default:\n return false;\n }\n}\n\nfunction isDiffScope(value: unknown): value is DiffPayload['scope'] {\n return (\n isRecord(value) &&\n isOneOf(value.mode, diffScopeModes) &&\n isNullableString(value.requestedBase) &&\n isBaseRef(value.base) &&\n isDiffRef(value.comparison) &&\n (value.fallbackReason === null || isOneOf(value.fallbackReason, diffFallbackReasons))\n );\n}\n\nfunction isDiffRef(value: unknown): value is DiffPayload['scope']['comparison'] {\n return isRecord(value) && isString(value.ref) && isNullableString(value.sha);\n}\n\nfunction isBaseRef(value: unknown): value is { ref: string; sha: string } {\n return isRecord(value) && isString(value.ref) && isString(value.sha);\n}\n\nfunction isDiffStats(value: unknown): value is DiffStats {\n return (\n isRecord(value) &&\n isNumber(value.files) &&\n isNumber(value.additions) &&\n isNumber(value.deletions)\n );\n}\n\nfunction isDiffFile(value: unknown): value is DiffFile {\n return (\n isRecord(value) &&\n isString(value.path) &&\n isNullableString(value.oldPath) &&\n isNumber(value.additions) &&\n isNumber(value.deletions) &&\n isBoolean(value.isBinary) &&\n isBoolean(value.isDeleted) &&\n isBoolean(value.isNew) &&\n isBoolean(value.isRenamed) &&\n isNullableString(value.language) &&\n isArrayOf(value.hunks, isDiffHunk)\n );\n}\n\nfunction isDiffHunk(value: unknown): value is DiffHunk {\n return (\n isRecord(value) &&\n isNumber(value.oldStart) &&\n isNumber(value.oldLines) &&\n isNumber(value.newStart) &&\n isNumber(value.newLines) &&\n isString(value.header) &&\n isArrayOf(value.lines, isDiffLine)\n );\n}\n\nfunction isDiffLine(value: unknown): value is DiffLine {\n return (\n isRecord(value) &&\n isOneOf(value.type, diffLineTypes) &&\n isNullableNumber(value.oldLine) &&\n isNullableNumber(value.newLine) &&\n isString(value.content)\n );\n}\n\nfunction isComment(value: unknown): value is Comment {\n return (\n isRecord(value) &&\n isString(value.id) &&\n isString(value.filePath) &&\n isNumber(value.startLine) &&\n isNumber(value.endLine) &&\n isOneOf(value.side, sides) &&\n isString(value.body) &&\n isString(value.originalSnippet) &&\n isString(value.createdAt)\n );\n}\n\nfunction isResolvedComment(value: unknown): value is ResolvedComment {\n return (\n isRecord(value) &&\n isString(value.commentId) &&\n value.status === 'resolved' &&\n isOptionalString(value.summary) &&\n isString(value.resolvedAt)\n );\n}\n\nfunction isResolutionCounts(value: unknown): value is ResolveResult['comments'] {\n return (\n isRecord(value) && isNumber(value.total) && isNumber(value.resolved) && isNumber(value.open)\n );\n}\n\nfunction isReviewStatus(value: unknown): value is ReviewMeta['status'] {\n return isOneOf(value, reviewStatuses);\n}\n\nfunction isResolutionStatus(value: unknown): value is ResolutionBundle['status'] {\n return isOneOf(value, resolutionStatuses);\n}\n\nfunction isReviewUpdateReason(\n value: unknown\n): value is Extract<ReviewEvent, { type: 'review.updated' }>['reason'] {\n return isOneOf(value, reviewUpdateReasons);\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' && value !== null && !Array.isArray(value);\n}\n\nfunction isArrayOf<T>(value: unknown, guard: JsonGuard<T>): value is T[] {\n return Array.isArray(value) && value.every(guard);\n}\n\nfunction isOptional<T>(value: unknown, guard: JsonGuard<T>): value is T | undefined {\n return value === undefined || guard(value);\n}\n\nfunction isString(value: unknown): value is string {\n return typeof value === 'string';\n}\n\nfunction isOptionalString(value: unknown): value is string | undefined {\n return value === undefined || isString(value);\n}\n\nfunction isNullableString(value: unknown): value is string | null {\n return value === null || isString(value);\n}\n\nfunction isNumber(value: unknown): value is number {\n return typeof value === 'number' && Number.isFinite(value);\n}\n\nfunction isOptionalNumber(value: unknown): value is number | undefined {\n return value === undefined || isNumber(value);\n}\n\nfunction isNullableNumber(value: unknown): value is number | null {\n return value === null || isNumber(value);\n}\n\nfunction isBoolean(value: unknown): value is boolean {\n return typeof value === 'boolean';\n}\n\nfunction isOneOf<const T extends readonly string[]>(\n value: unknown,\n options: T\n): value is T[number] {\n return typeof value === 'string' && options.includes(value);\n}\n","import type {\n Comment,\n CreateReviewResponse,\n DiffPayload,\n FeedbackBundle,\n HealthResponse,\n ListReviewsResponse,\n OpenResult,\n ResolutionRequest,\n ResolveResult,\n ReviewEvent,\n ReviewRecord,\n SubmitReviewRequest\n} from '../shared/types';\nimport {\n isCreateReviewResponse,\n isFeedbackBundle,\n isHealthResponse,\n isListReviewsResponse,\n isOpenResult,\n isResolveResult,\n isReviewEvent,\n isReviewRecord,\n type JsonGuard,\n parseJson,\n parseJsonValue\n} from '../shared/validation';\n\nexport class ServerClient {\n constructor(private readonly baseUrl: string) {}\n\n async health(): Promise<HealthResponse> {\n return this.get('/api/health', isHealthResponse, 'health response');\n }\n\n async createReview(diff: DiffPayload): Promise<CreateReviewResponse> {\n return this.post('/api/reviews', diff, isCreateReviewResponse, 'create review response');\n }\n\n async getReview(reviewId: string): Promise<ReviewRecord> {\n return this.get(`/api/reviews/${reviewId}`, isReviewRecord, 'review response');\n }\n\n async listReviews(): Promise<ListReviewsResponse> {\n return this.get('/api/reviews', isListReviewsResponse, 'review list response');\n }\n\n async getFeedback(reviewId: string): Promise<FeedbackBundle> {\n return this.get(`/api/reviews/${reviewId}/feedback`, isFeedbackBundle, 'feedback response');\n }\n\n async markResolved(reviewId: string, summary?: string): Promise<ResolveResult> {\n const request: ResolutionRequest = { summary };\n return this.post(\n `/api/reviews/${reviewId}/resolved`,\n request,\n isResolveResult,\n 'resolve response'\n );\n }\n\n async resolveComment(\n reviewId: string,\n commentId: string,\n summary?: string\n ): Promise<ResolveResult> {\n const request: ResolutionRequest = { summary };\n return this.post(\n `/api/reviews/${reviewId}/comments/${commentId}/resolved`,\n request,\n isResolveResult,\n 'resolve comment response'\n );\n }\n\n async reopenComment(reviewId: string, commentId: string): Promise<ResolveResult> {\n return this.delete(\n `/api/reviews/${reviewId}/comments/${commentId}/resolved`,\n isResolveResult,\n 'reopen comment response'\n );\n }\n\n async submitReview(reviewId: string, comments: Comment[]): Promise<OpenResult> {\n const request: SubmitReviewRequest = { comments };\n return this.post(\n `/api/reviews/${reviewId}/submit`,\n request,\n isOpenResult,\n 'submit review response'\n );\n }\n\n async watchReview(reviewId: string, timeoutSeconds?: number): Promise<ReviewEvent> {\n const deadline =\n timeoutSeconds && timeoutSeconds > 0 ? Date.now() + timeoutSeconds * 1000 : null;\n\n while (true) {\n const remainingMs = deadline ? deadline - Date.now() : null;\n if (remainingMs !== null && remainingMs <= 0) {\n throw new Error(`watch timed out after ${timeoutSeconds} seconds`);\n }\n\n const controller = new AbortController();\n const timeout = remainingMs ? setTimeout(() => controller.abort(), remainingMs) : null;\n try {\n return await this.readReviewEvents(reviewId, controller.signal);\n } catch (error) {\n if (isAbortError(error)) {\n throw new Error(`watch timed out after ${timeoutSeconds} seconds`);\n }\n if (!isPrematureWatchEnd(error)) {\n throw error;\n }\n await sleep(500);\n } finally {\n if (timeout) {\n clearTimeout(timeout);\n }\n }\n }\n }\n\n private async readReviewEvents(reviewId: string, signal: AbortSignal): Promise<ReviewEvent> {\n const response = await fetch(`${this.baseUrl}/api/reviews/${reviewId}/events`, {\n signal\n });\n if (!response.ok || !response.body) {\n throw new Error(`watch failed: ${response.status} ${await response.text()}`);\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n let buffer = '';\n\n while (true) {\n const { value, done } = await reader.read();\n if (done) {\n throw new Error('watch stream ended before completion');\n }\n buffer += decoder.decode(value, { stream: true });\n const events = buffer.split('\\n\\n');\n buffer = events.pop() ?? '';\n for (const eventChunk of events) {\n const dataLine = eventChunk.split('\\n').find((line) => line.startsWith('data:'));\n if (!dataLine) {\n continue;\n }\n const event = parseJson(dataLine.slice(5).trim(), isReviewEvent, 'review event');\n if (event.type === 'review.submitted' || event.type === 'review.cancelled') {\n await reader.cancel().catch(() => undefined);\n return event;\n }\n }\n }\n }\n\n private async get<T>(path: string, guard: JsonGuard<T>, label: string): Promise<T> {\n const response = await fetch(`${this.baseUrl}${path}`);\n return parseResponse(response, guard, label);\n }\n\n private async post<T>(\n path: string,\n body: object,\n guard: JsonGuard<T>,\n label: string\n ): Promise<T> {\n const response = await fetch(`${this.baseUrl}${path}`, {\n method: 'POST',\n headers: { 'content-type': 'application/json' },\n body: JSON.stringify(body)\n });\n return parseResponse(response, guard, label);\n }\n\n private async delete<T>(path: string, guard: JsonGuard<T>, label: string): Promise<T> {\n const response = await fetch(`${this.baseUrl}${path}`, { method: 'DELETE' });\n return parseResponse(response, guard, label);\n }\n}\n\nasync function parseResponse<T>(\n response: Response,\n guard: JsonGuard<T>,\n label: string\n): Promise<T> {\n if (!response.ok) {\n throw new Error(`${response.status} ${response.statusText}: ${await response.text()}`);\n }\n const value: unknown = await response.json();\n return parseJsonValue(value, guard, label);\n}\n\nfunction isPrematureWatchEnd(error: unknown): boolean {\n return error instanceof Error && error.message === 'watch stream ended before completion';\n}\n\nfunction isAbortError(error: unknown): boolean {\n return (\n typeof error === 'object' && error !== null && 'name' in error && error.name === 'AbortError'\n );\n}\n\nasync function sleep(milliseconds: number): Promise<void> {\n await new Promise((resolve) => setTimeout(resolve, milliseconds));\n}\n","import type { Dirent } from 'node:fs';\nimport { readdir, readFile, writeFile } from 'node:fs/promises';\nimport { ulid } from 'ulid';\nimport { compareCommentsByLocation, countCommentFiles, resolutionCounts } from '../shared/comments';\nimport { writeJsonFile } from '../shared/json';\nimport { serializeFeedbackMarkdown } from '../shared/markdown';\nimport {\n ensureDir,\n globalReviewDiffFile,\n globalReviewDir,\n globalReviewFeedbackFile,\n globalReviewMarkdownFile,\n globalReviewMetaFile,\n globalReviewResolvedFile,\n globalReviewsDir\n} from '../shared/paths';\nimport { isResolvableReviewStatus } from '../shared/reviews';\nimport type {\n Comment,\n DiffPayload,\n FeedbackBundle,\n ResolutionBundle,\n ResolvedComment,\n ResolveResult,\n ReviewEvent,\n ReviewMeta,\n ReviewRecord,\n ReviewUpdateReason\n} from '../shared/types';\nimport {\n isDiffPayload,\n isFeedbackBundle,\n isResolutionBundle,\n isStoredReviewMeta,\n type JsonGuard,\n parseJson\n} from '../shared/validation';\n\ntype Listener = (event: ReviewEvent) => void;\n\nexport class ReviewStore {\n private readonly reviews = new Map<string, ReviewRecord>();\n private readonly listeners = new Map<string, Set<Listener>>();\n\n async create(diff: DiffPayload): Promise<ReviewRecord> {\n const id = ulid();\n const createdAt = new Date().toISOString();\n const meta: ReviewMeta = {\n id,\n cwd: diff.cwd,\n base: diff.base,\n branch: diff.branch,\n status: 'pending',\n createdAt,\n artifactDir: globalReviewDir(id)\n };\n const record: ReviewRecord = { meta, diff };\n this.reviews.set(id, record);\n await this.persistInitial(record);\n this.emit({ type: 'review.opened', reviewId: id });\n return record;\n }\n\n async list(): Promise<ReviewMeta[]> {\n await this.loadAllReviews();\n return [...this.reviews.values()]\n .map((record) => record.meta)\n .sort((a, b) => a.createdAt.localeCompare(b.createdAt));\n }\n\n async get(id: string): Promise<ReviewRecord | null> {\n return this.reviews.get(id) ?? (await this.loadKnownReview(id));\n }\n\n async submit(\n id: string,\n comments: Comment[]\n ): Promise<{ record: ReviewRecord; feedbackPath: string; markdownPath: string }> {\n const record = await this.get(id);\n if (!record) {\n throw new Error(`Review ${id} not found`);\n }\n if (record.meta.status !== 'pending') {\n throw new Error(`Review ${id} is ${record.meta.status} and cannot be submitted`);\n }\n const timestamp = new Date().toISOString();\n const feedback: FeedbackBundle = {\n version: 1,\n reviewId: id,\n timestamp,\n base: record.diff.base,\n branch: record.diff.branch,\n comments: [...comments].sort(compareCommentsByLocation)\n };\n record.feedback = feedback;\n record.meta = { ...record.meta, status: 'submitted', submittedAt: timestamp };\n this.reviews.set(id, record);\n\n const artifactDir = globalReviewDir(id);\n const feedbackPath = globalReviewFeedbackFile(id);\n const markdownPath = globalReviewMarkdownFile(id);\n record.meta = {\n ...record.meta,\n artifactDir,\n feedbackPath,\n markdownPath\n };\n await ensureDir(artifactDir);\n await Promise.all([\n writeJsonFile(globalReviewMetaFile(id), record.meta),\n writeJsonFile(feedbackPath, feedback),\n writeFile(markdownPath, serializeFeedbackMarkdown(feedback))\n ]);\n\n this.emit({\n type: 'review.submitted',\n reviewId: id,\n counts: {\n files: countCommentFiles(feedback.comments),\n comments: feedback.comments.length\n }\n });\n return { record, feedbackPath, markdownPath };\n }\n\n async feedback(id: string): Promise<FeedbackBundle | null> {\n const record = await this.get(id);\n return record?.feedback ?? null;\n }\n\n async markResolved(id: string, summary?: string): Promise<ResolveResult> {\n const record = await this.get(id);\n if (!record) {\n throw new Error(`Review ${id} not found`);\n }\n this.assertResolvable(record, id);\n const resolvedAt = new Date().toISOString();\n const existingById = new Map(\n (record.resolution?.comments ?? []).map((comment) => [comment.commentId, comment])\n );\n const comments = this.sortResolvedComments(\n (record.feedback?.comments ?? []).map((comment) => ({\n ...existingById.get(comment.id),\n commentId: comment.id,\n status: 'resolved' as const,\n resolvedAt: existingById.get(comment.id)?.resolvedAt ?? resolvedAt\n })),\n record\n );\n const resolution: ResolutionBundle = {\n reviewId: id,\n status: 'resolved',\n summary: summary ?? record.resolution?.summary ?? null,\n resolvedAt,\n comments\n };\n record.meta = { ...record.meta, status: 'resolved', resolvedAt };\n return this.persistResolution(record, resolution, 'review-resolved');\n }\n\n async resolveComment(id: string, commentId: string, summary?: string): Promise<ResolveResult> {\n const record = await this.get(id);\n if (!record) {\n throw new Error(`Review ${id} not found`);\n }\n this.assertResolvable(record, id);\n this.assertCommentExists(record, commentId);\n\n const resolvedAt = new Date().toISOString();\n const previous = record.resolution?.comments.find((comment) => comment.commentId === commentId);\n const nextSummary = summary ?? previous?.summary;\n const nextComment: ResolvedComment = {\n commentId,\n status: 'resolved',\n ...(nextSummary ? { summary: nextSummary } : {}),\n resolvedAt\n };\n const comments = this.sortResolvedComments(\n [\n ...(record.resolution?.comments ?? []).filter((comment) => comment.commentId !== commentId),\n nextComment\n ],\n record\n );\n const counts = resolutionCounts(record.feedback, comments);\n const fullyResolved = counts.total === counts.resolved;\n const resolution: ResolutionBundle = {\n reviewId: id,\n status: fullyResolved ? 'resolved' : 'partial',\n summary: fullyResolved ? (record.resolution?.summary ?? null) : null,\n resolvedAt: fullyResolved ? resolvedAt : null,\n comments\n };\n record.meta = fullyResolved\n ? { ...record.meta, status: 'resolved', resolvedAt }\n : { ...record.meta, status: 'submitted', resolvedAt: undefined };\n return this.persistResolution(record, resolution, 'comment-resolved');\n }\n\n async reopenComment(id: string, commentId: string): Promise<ResolveResult> {\n const record = await this.get(id);\n if (!record) {\n throw new Error(`Review ${id} not found`);\n }\n this.assertResolvable(record, id);\n this.assertCommentExists(record, commentId);\n\n const comments = this.sortResolvedComments(\n (record.resolution?.comments ?? []).filter((comment) => comment.commentId !== commentId),\n record\n );\n const counts = resolutionCounts(record.feedback, comments);\n const fullyResolved = counts.total > 0 && counts.total === counts.resolved;\n const resolvedAt = fullyResolved ? new Date().toISOString() : null;\n const resolution: ResolutionBundle = {\n reviewId: id,\n status: fullyResolved ? 'resolved' : 'partial',\n summary: fullyResolved ? (record.resolution?.summary ?? null) : null,\n resolvedAt,\n comments\n };\n record.meta = fullyResolved\n ? { ...record.meta, status: 'resolved', resolvedAt: resolvedAt ?? undefined }\n : { ...record.meta, status: 'submitted', resolvedAt: undefined };\n return this.persistResolution(record, resolution, 'comment-reopened');\n }\n\n subscribe(reviewId: string, listener: Listener): () => void {\n const listeners = this.listeners.get(reviewId) ?? new Set<Listener>();\n listeners.add(listener);\n this.listeners.set(reviewId, listeners);\n return () => {\n listeners.delete(listener);\n if (listeners.size === 0) {\n this.listeners.delete(reviewId);\n }\n };\n }\n\n private emit(event: ReviewEvent): void {\n for (const listener of this.listeners.get(event.reviewId) ?? []) {\n listener(event);\n }\n }\n\n private async persistInitial(record: ReviewRecord): Promise<void> {\n const dir = globalReviewDir(record.meta.id);\n await ensureDir(dir);\n await Promise.all([\n writeJsonFile(globalReviewMetaFile(record.meta.id), record.meta),\n writeJsonFile(globalReviewDiffFile(record.meta.id), record.diff)\n ]);\n }\n\n private async loadKnownReview(id: string): Promise<ReviewRecord | null> {\n const existing = this.reviews.get(id);\n if (existing) {\n return existing;\n }\n\n return this.loadReview(id);\n }\n\n private async loadAllReviews(): Promise<void> {\n let entries: Dirent[];\n try {\n entries = await readdir(globalReviewsDir(), { withFileTypes: true });\n } catch (error) {\n if (isFileNotFound(error)) {\n return;\n }\n throw new Error(\n `Could not read reviews directory at ${globalReviewsDir()}: ${formatError(error)}`,\n {\n cause: error\n }\n );\n }\n\n await Promise.all(\n entries.filter((entry) => entry.isDirectory()).map((entry) => this.loadReview(entry.name))\n );\n }\n\n private async loadReview(id: string): Promise<ReviewRecord | null> {\n const metaPath = globalReviewMetaFile(id);\n const diffPath = globalReviewDiffFile(id);\n let metaRaw: string;\n let diffRaw: string;\n\n try {\n [metaRaw, diffRaw] = await Promise.all([\n readFile(metaPath, 'utf8'),\n readFile(diffPath, 'utf8')\n ]);\n } catch (error) {\n if (isFileNotFound(error)) {\n return null;\n }\n throw new Error(`Could not load review ${id}: ${formatError(error)}`, { cause: error });\n }\n\n const meta = parseJsonFile(metaRaw, isStoredReviewMeta, 'review metadata', metaPath);\n const diff = parseJsonFile(diffRaw, isDiffPayload, 'review diff', diffPath);\n const feedback = await readOptionalJsonFile(\n globalReviewFeedbackFile(id),\n isFeedbackBundle,\n 'review feedback'\n );\n const resolution = await readOptionalJsonFile(\n globalReviewResolvedFile(id),\n isResolutionBundle,\n 'review resolution'\n );\n\n const record: ReviewRecord = {\n meta: {\n ...meta,\n artifactDir: meta.artifactDir ?? globalReviewDir(id),\n feedbackPath: meta.feedbackPath ?? (feedback ? globalReviewFeedbackFile(id) : undefined),\n markdownPath: meta.markdownPath ?? (feedback ? globalReviewMarkdownFile(id) : undefined)\n },\n diff,\n feedback,\n resolution\n };\n this.reviews.set(id, record);\n return record;\n }\n\n private assertResolvable(\n record: ReviewRecord,\n id: string\n ): asserts record is ReviewRecord & {\n feedback: FeedbackBundle;\n } {\n if (!isResolvableReviewStatus(record.meta.status)) {\n throw new Error(`Review ${id} is ${record.meta.status} and cannot be resolved`);\n }\n if (!record.feedback) {\n throw new Error(`Review ${id} has no submitted feedback`);\n }\n }\n\n private assertCommentExists(\n record: ReviewRecord & { feedback: FeedbackBundle },\n commentId: string\n ): void {\n if (!record.feedback.comments.some((comment) => comment.id === commentId)) {\n throw new Error(`Comment ${commentId} not found`);\n }\n }\n\n private async persistResolution(\n record: ReviewRecord & { feedback: FeedbackBundle },\n resolution: ResolutionBundle,\n reason: ReviewUpdateReason\n ): Promise<ResolveResult> {\n record.resolution = resolution;\n this.reviews.set(record.meta.id, record);\n const resolvedPath = globalReviewResolvedFile(record.meta.id);\n await ensureDir(globalReviewDir(record.meta.id));\n await Promise.all([\n writeJsonFile(resolvedPath, resolution),\n writeJsonFile(globalReviewMetaFile(record.meta.id), record.meta)\n ]);\n const result: ResolveResult = {\n ok: true,\n reviewId: record.meta.id,\n status: record.meta.status,\n resolutionStatus: resolution.status,\n comments: resolutionCounts(record.feedback, resolution.comments),\n path: resolvedPath,\n resolution\n };\n this.emit({\n type: 'review.updated',\n reviewId: record.meta.id,\n reason,\n status: result.status,\n resolutionStatus: result.resolutionStatus,\n counts: result.comments\n });\n return result;\n }\n\n private sortResolvedComments(\n comments: ResolvedComment[],\n record: ReviewRecord & { feedback: FeedbackBundle }\n ): ResolvedComment[] {\n const feedbackIndex = new Map(\n record.feedback.comments.map((comment, index) => [comment.id, index] as const)\n );\n return comments\n .filter((comment) => feedbackIndex.has(comment.commentId))\n .sort(\n (a, b) =>\n (feedbackIndex.get(a.commentId) ?? Number.MAX_SAFE_INTEGER) -\n (feedbackIndex.get(b.commentId) ?? Number.MAX_SAFE_INTEGER)\n );\n }\n}\n\nasync function readOptionalJsonFile<T>(\n filePath: string,\n guard: JsonGuard<T>,\n label: string\n): Promise<T | undefined> {\n let raw: string;\n try {\n raw = await readFile(filePath, 'utf8');\n } catch (error) {\n if (isFileNotFound(error)) {\n return undefined;\n }\n throw new Error(`Could not read ${label} at ${filePath}: ${formatError(error)}`, {\n cause: error\n });\n }\n\n return parseJsonFile(raw, guard, label, filePath);\n}\n\nfunction parseJsonFile<T>(raw: string, guard: JsonGuard<T>, label: string, filePath: string): T {\n try {\n return parseJson(raw, guard, label);\n } catch (error) {\n throw new Error(`Invalid ${label} at ${filePath}: ${formatError(error)}`, { cause: error });\n }\n}\n\nfunction isFileNotFound(error: unknown): boolean {\n return error instanceof Error && 'code' in error && error.code === 'ENOENT';\n}\n\nfunction formatError(error: unknown): string {\n return error instanceof Error ? error.message : String(error);\n}\n\nexport const reviewStore = new ReviewStore();\n","import type {\n Comment,\n FeedbackBundle,\n ResolutionBundle,\n ResolutionCounts,\n ResolvedComment,\n Side\n} from './types';\n\nexport interface LineRange {\n side: Side;\n startLine: number;\n endLine: number;\n}\n\nexport function compareCommentsByLocation(a: Comment, b: Comment): number {\n return (\n a.filePath.localeCompare(b.filePath) ||\n a.startLine - b.startLine ||\n a.endLine - b.endLine ||\n a.side.localeCompare(b.side)\n );\n}\n\nexport function countCommentFiles(comments: Pick<Comment, 'filePath'>[]): number {\n return new Set(comments.map((comment) => comment.filePath)).size;\n}\n\nexport function formatLineRange(\n range: LineRange,\n options: { repeatSideOnEnd?: boolean } = {}\n): string {\n const startLine = Math.min(range.startLine, range.endLine);\n const endLine = Math.max(range.startLine, range.endLine);\n if (startLine === endLine) {\n return `${range.side}${startLine}`;\n }\n const endPrefix = options.repeatSideOnEnd === false ? '' : range.side;\n return `${range.side}${startLine}-${endPrefix}${endLine}`;\n}\n\nexport function resolutionCounts(\n feedback: FeedbackBundle | undefined,\n resolvedComments: ResolvedComment[] = []\n): ResolutionCounts {\n const comments = feedback?.comments ?? [];\n const resolvedIds = new Set(resolvedComments.map((comment) => comment.commentId));\n const resolved = comments.filter((comment) => resolvedIds.has(comment.id)).length;\n return {\n total: comments.length,\n resolved,\n open: comments.length - resolved\n };\n}\n\nexport function reviewResolutionCounts(record: {\n feedback?: FeedbackBundle;\n resolution?: ResolutionBundle;\n}): ResolutionCounts {\n return resolutionCounts(record.feedback, record.resolution?.comments ?? []);\n}\n","import { compareCommentsByLocation, formatLineRange } from './comments';\nimport { languageForPath } from './language';\nimport type { FeedbackBundle } from './types';\n\nfunction fenceFor(snippet: string): string {\n let fence = '```';\n while (snippet.includes(fence)) {\n fence += '`';\n }\n return fence;\n}\n\nfunction languageForSnippet(filePath: string, snippet: string): string {\n const lines = snippet.split('\\n').filter((line) => line.length > 0);\n const looksLikeUnifiedDiff =\n lines.length > 0 &&\n lines.some((line) => line.startsWith('+') || line.startsWith('-')) &&\n lines.every((line) => line.startsWith('+') || line.startsWith('-') || line.startsWith(' '));\n return looksLikeUnifiedDiff ? 'diff' : (languageForPath(filePath) ?? '');\n}\n\nexport function serializeFeedbackMarkdown(bundle: FeedbackBundle): string {\n const comments = [...bundle.comments].sort(compareCommentsByLocation);\n const files = [...new Set(comments.map((comment) => comment.filePath))];\n const lines: string[] = [\n `# Gloss feedback - ${bundle.timestamp}`,\n `Review: ${bundle.reviewId}`,\n `Base: ${bundle.base.ref} (${bundle.base.sha.slice(0, 7)}) Branch: ${bundle.branch ?? '(detached)'}`,\n `Files: ${files.length} Comments: ${comments.length}`,\n ''\n ];\n\n for (const filePath of files) {\n lines.push(`## ${filePath}`, '');\n for (const comment of comments.filter((item) => item.filePath === filePath)) {\n const snippet = comment.originalSnippet.trimEnd();\n const firstSnippetLine = snippet.split('\\n').find((line) => line.trim().length > 0);\n const heading =\n comment.startLine === comment.endLine && firstSnippetLine\n ? `### ${formatLineRange(comment)} - \\`${firstSnippetLine.trim().slice(0, 80)}\\``\n : `### ${formatLineRange(comment)}`;\n lines.push(heading, comment.body.trim(), '');\n if (snippet) {\n const fence = fenceFor(snippet);\n lines.push(`${fence}${languageForSnippet(comment.filePath, snippet)}`, snippet, fence, '');\n }\n }\n }\n\n return `${lines.join('\\n').trimEnd()}\\n`;\n}\n","import type { ReviewStatus } from './types';\n\nexport function isResolvableReviewStatus(status: ReviewStatus): boolean {\n return status === 'submitted' || status === 'resolved';\n}\n","import { ReviewStore } from '../server/store';\nimport type { ReviewMeta, ServerInfo } from '../shared/types';\nimport { serverUrl } from './lifecycle';\nimport { ServerClient } from './server-client';\n\nexport async function listReviewsForStatus({\n responsive,\n server\n}: {\n responsive: boolean;\n server: ServerInfo | null;\n}): Promise<ReviewMeta[]> {\n if (server && responsive) {\n try {\n return (await new ServerClient(serverUrl(server)).listReviews()).reviews;\n } catch {\n // Fall through to durable state if the daemon disappears between health and list.\n }\n }\n\n return new ReviewStore().list();\n}\n"],"mappings":"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","names":["path","rawDiff","path","readFile","writeFile","writeFile","isFileNotFound","formatError","readFile","result"]}
@@ -9,7 +9,7 @@ import path from "path";
9
9
  // package.json
10
10
  var package_default = {
11
11
  name: "getgloss",
12
- version: "0.7.0",
12
+ version: "0.7.2",
13
13
  description: "Local browser-based diff review for coding-agent loops.",
14
14
  type: "module",
15
15
  packageManager: "pnpm@10.33.2",