poe-code 3.0.223 → 3.0.224

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/dist/cli/commands/configure-payload.js +52 -12
  2. package/dist/cli/commands/configure-payload.js.map +1 -1
  3. package/dist/cli/commands/configure.js +2 -2
  4. package/dist/cli/commands/configure.js.map +1 -1
  5. package/dist/cli/commands/provider.d.ts +1 -0
  6. package/dist/cli/commands/provider.js +94 -3
  7. package/dist/cli/commands/provider.js.map +1 -1
  8. package/dist/cli/commands/shared.d.ts +4 -1
  9. package/dist/cli/commands/shared.js +55 -5
  10. package/dist/cli/commands/shared.js.map +1 -1
  11. package/dist/cli/constants.d.ts +1 -2
  12. package/dist/cli/constants.js +1 -13
  13. package/dist/cli/constants.js.map +1 -1
  14. package/dist/cli/options.d.ts +1 -1
  15. package/dist/cli/options.js +10 -1
  16. package/dist/cli/options.js.map +1 -1
  17. package/dist/cli/prompt-runner.js +4 -2
  18. package/dist/cli/prompt-runner.js.map +1 -1
  19. package/dist/cli/prompts.d.ts +3 -1
  20. package/dist/cli/prompts.js +13 -0
  21. package/dist/cli/prompts.js.map +1 -1
  22. package/dist/index.js +244 -39
  23. package/dist/index.js.map +3 -3
  24. package/dist/providers/claude-code.js +11 -22
  25. package/dist/providers/claude-code.js.map +2 -2
  26. package/dist/providers/codex.js +19 -29
  27. package/dist/providers/codex.js.map +2 -2
  28. package/dist/providers/goose.js +11 -22
  29. package/dist/providers/goose.js.map +2 -2
  30. package/dist/providers/kimi.js +11 -22
  31. package/dist/providers/kimi.js.map +2 -2
  32. package/dist/providers/opencode.js +11 -22
  33. package/dist/providers/opencode.js.map +2 -2
  34. package/dist/providers/poe-agent.js +11 -22
  35. package/dist/providers/poe-agent.js.map +2 -2
  36. package/package.json +1 -1
  37. package/packages/memory/dist/index.js +10 -8
  38. package/packages/memory/dist/index.js.map +2 -2
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/templates/py-poe-spawn/env.mustache", "../../src/templates/py-poe-spawn/main.py.mustache", "../../src/templates/py-poe-spawn/requirements.txt.mustache", "../../src/templates/codex/config.toml.mustache", "../../packages/agent-spawn/src/register-factories.ts", "../../packages/agent-harness-tools/src/paths.ts", "../../packages/agent-harness-tools/src/plans.ts", "../../packages/task-list/src/open.ts", "../../packages/task-list/src/state-machine.ts", "../../packages/task-list/src/backends/gh-issues-client.ts", "../../packages/process-runner/src/docker/context.ts", "../../packages/process-runner/src/docker/engine.ts", "../../packages/process-runner/src/docker/docker-runner.ts", "../../packages/process-runner/src/docker/args.ts", "../../packages/process-runner/src/docker/docker-execution-env.ts", "../../packages/process-runner/src/host/host-runner.ts", "../../packages/process-runner/src/host/host-execution-env.ts", "../../packages/process-runner/src/testing/mock-runner.ts", "../../packages/task-list/src/backends/utils.ts", "../../packages/task-list/src/backends/markdown-dir.ts", "../../packages/file-lock/src/lock.ts", "../../packages/task-list/src/schema/task.schema.json", "../../packages/task-list/src/state.ts", "../../packages/task-list/src/backends/yaml-file.ts", "../../packages/task-list/src/schema/store.schema.json", "../../packages/agent-defs/src/agents/claude-code.ts", "../../packages/agent-defs/src/agents/claude-desktop.ts", "../../packages/agent-defs/src/agents/codex.ts", "../../packages/agent-defs/src/agents/opencode.ts", "../../packages/agent-defs/src/agents/kimi.ts", "../../packages/agent-defs/src/agents/goose.ts", "../../packages/agent-defs/src/agents/poe-agent.ts", "../../packages/agent-defs/src/registry.ts", "../../packages/agent-harness-tools/src/select-agent.ts", "../../packages/agent-harness-tools/src/run-logs.ts", "../../packages/agent-harness-tools/src/log-stream.ts", "../../packages/agent-harness-tools/src/run-poe-command.ts", "../../packages/agent-harness-tools/src/binary-exists.ts", "../../packages/agent-harness-tools/src/poe-command-execution.ts", "../../packages/poe-code-config/src/runtime.ts", "../../packages/poe-code-config/src/schema.ts", "../../packages/poe-code-config/src/plan-scope.ts", "../../packages/poe-code-config/src/store.ts", "../../packages/config-extends/src/discover.ts", "../../packages/config-extends/src/parse.ts", "../../packages/config-extends/src/merge.ts", "../../packages/config-extends/src/resolve.ts", "../../packages/design-system/src/internal/color-support.ts", "../../packages/design-system/src/components/color.ts", "../../packages/design-system/src/tokens/colors.ts", "../../packages/design-system/src/internal/output-format.ts", "../../packages/design-system/src/internal/theme-detect.ts", "../../packages/design-system/src/components/symbols.ts", "../../packages/design-system/src/internal/strip-ansi.ts", "../../packages/design-system/src/prompts/primitives/log.ts", "../../packages/design-system/src/components/logger.ts", "../../packages/design-system/src/components/table.ts", "../../packages/design-system/src/components/template.ts", "../../packages/design-system/src/components/browser.ts", "../../packages/design-system/src/acp/writer.ts", "../../packages/design-system/src/dashboard/terminal.ts", "../../packages/design-system/src/explorer/state.ts", "../../packages/design-system/src/prompts/index.ts", "../../packages/design-system/src/prompts/primitives/cancel.ts", "../../packages/config-mutations/src/mutations/config-mutation.ts", "../../packages/config-mutations/src/mutations/file-mutation.ts", "../../packages/config-mutations/src/mutations/template-mutation.ts", "../../packages/config-mutations/src/formats/json.ts", "../../packages/config-mutations/src/formats/toml.ts", "../../packages/config-mutations/src/formats/yaml.ts", "../../packages/config-mutations/src/formats/index.ts", "../../packages/config-mutations/src/execution/path-utils.ts", "../../packages/config-mutations/src/fs-utils.ts", "../../packages/config-mutations/src/execution/apply-mutation.ts", "../../packages/config-mutations/src/execution/run-mutations.ts", "../../packages/config-mutations/src/types.ts", "../../packages/poe-code-config/src/resolve.ts", "../../packages/poe-code-config/src/merge.ts", "../../packages/poe-code-config/src/inspect.ts", "../../packages/poe-code-config/src/configured-services.ts", "../../packages/providers/src/auth/api-key.ts", "../../packages/providers/src/compatibility.ts", "../../packages/providers/src/registry.ts", "../../packages/providers/src/providers/poe.ts", "../../packages/providers/src/providers/anthropic.ts", "../../packages/providers/src/providers/cloudflare.ts", "../../packages/poe-code-config/src/state/index.ts", "../../packages/poe-code-config/src/state/jobs.ts", "../../packages/poe-code-config/src/state/fs.ts", "../../packages/poe-code-config/src/state/templates.ts", "../../packages/agent-harness-tools/src/execution-env.ts", "../../packages/agent-harness-tools/src/workspace-transfer.ts", "../../packages/runner-e2b/src/factory.ts", "../../packages/runner-e2b/src/sdk.ts", "../../packages/runner-e2b/src/template-build.ts", "../../packages/runner-e2b/src/opened-env.ts", "../../packages/runner-e2b/src/job-handle.ts", "../../packages/runner-e2b/src/auth-scope.ts", "../../packages/runner-e2b/src/index.ts", "../../packages/agent-spawn/src/observability/otel.ts", "../../packages/agent-spawn/src/run-command.ts", "../../packages/agent-spawn/src/types.ts", "../../packages/agent-spawn/src/configs/mcp.ts", "../../packages/agent-spawn/src/configs/claude-code.ts", "../../packages/agent-spawn/src/configs/codex.ts", "../../packages/agent-spawn/src/configs/opencode.ts", "../../packages/agent-spawn/src/configs/kimi.ts", "../../packages/agent-spawn/src/configs/goose.ts", "../../packages/agent-spawn/src/configs/index.ts", "../../packages/agent-spawn/src/spawn.ts", "../../packages/agent-spawn/src/configs/resolve-config.ts", "../../packages/agent-spawn/src/mcp-args.ts", "../../packages/agent-spawn/src/model-utils.ts", "../../packages/agent-spawn/src/parallel.ts", "../../packages/agent-spawn/src/prompt-transport.ts", "../../packages/agent-spawn/src/retry.ts", "../../packages/agent-spawn/src/skill-bridge.ts", "../../packages/agent-skill-config/src/configs.ts", "../../packages/agent-skill-config/src/templates.ts", "../../packages/agent-skill-config/src/resolve-skill-reference.ts", "../../packages/agent-skill-config/src/git-exclude.ts", "../../packages/agent-skill-config/src/bridge-active-skills.ts", "../../packages/agent-spawn/src/adapters/utils.ts", "../../packages/agent-spawn/src/adapters/claude.ts", "../../packages/agent-spawn/src/adapters/codex.ts", "../../packages/agent-spawn/src/adapters/kimi.ts", "../../packages/agent-spawn/src/adapters/native.ts", "../../packages/agent-spawn/src/adapters/opencode.ts", "../../packages/agent-spawn/src/adapters/index.ts", "../../packages/agent-spawn/src/acp/meta.ts", "../../packages/agent-spawn/src/acp/middleware.ts", "../../packages/agent-spawn/src/acp/spawn.ts", "../../packages/agent-spawn/src/autonomous.ts", "../../packages/agent-spawn/src/acp/replay.ts", "../../packages/poe-acp-client/src/acp-client.ts", "../../packages/poe-acp-client/src/acp-transport.ts", "../../packages/poe-acp-client/src/run-report.ts", "../../packages/agent-spawn/src/acp/middlewares/spawn-log.ts", "../../src/utils/command-checks.ts", "../../src/services/service-install.ts", "../../src/providers/create-provider.ts", "../../src/cli/constants.ts", "../../src/providers/codex.ts"],
4
- "sourcesContent": ["POE_API_KEY={{apiKey}}\nPOE_BASE_URL=https://api.poe.com/v1\nMODEL={{model}}\n", "import os\nfrom openai import OpenAI\nfrom dotenv import load_dotenv\n\nload_dotenv()\n\nclient = OpenAI(\n api_key=os.getenv(\"POE_API_KEY\"),\n base_url=os.getenv(\"POE_BASE_URL\")\n)\n\nresponse = client.chat.completions.create(\n model=os.getenv(\"MODEL\", \"{{model}}\"),\n messages=[{\"role\": \"user\", \"content\": \"Tell me a joke\"}]\n)\n\nprint(response.choices[0].message.content)\n", "openai>=1.0.0\npython-dotenv>=1.0.0\n", "model_provider = \"{{providerId}}\"\n\n[profiles.\"{{{profileName}}}\"]\nmodel = \"{{{model}}}\"\nmodel_provider = \"{{providerId}}\"\nmodel_reasoning_effort = \"{{reasoningEffort}}\"\nmodel_verbosity = \"medium\"\n\n[model_providers.{{providerId}}]\nname = \"{{providerId}}\"\nbase_url = \"{{{baseUrl}}}\"\nwire_api = \"responses\"\nexperimental_bearer_token = \"{{apiKey}}\"\nrequires_openai_auth = false\nsupports_websockets = false\n", "import { spawn as spawnChildProcess } from \"node:child_process\";\nimport { registerExecutionEnvFactory } from \"@poe-code/agent-harness-tools\";\nimport type { ExecutionEnvFactory, OpenedEnv, RunSpec } from \"@poe-code/agent-harness-tools\";\nimport { dockerExecutionEnvFactory, hostExecutionEnvFactory } from \"@poe-code/process-runner\";\nimport { e2bExecutionEnvFactory } from \"@poe-code/runner-e2b\";\n\nregisterExecutionEnvFactory(hostExecutionEnvFactory);\nregisterExecutionEnvFactory(dockerExecutionEnvFactory);\nregisterExecutionEnvFactory(e2bExecutionEnvFactory);\n\nif (isVitest()) {\n registerExecutionEnvFactory(createTestHostExecutionEnvFactory());\n}\n\nfunction isVitest(): boolean {\n return process.env.VITEST !== undefined || process.env.VITEST_POOL_ID !== undefined;\n}\n\nfunction createTestHostExecutionEnvFactory(): ExecutionEnvFactory {\n return {\n type: \"host\",\n supportsDetach: false,\n open: ((openSpec: Parameters<ExecutionEnvFactory[\"open\"]>[0]) => {\n return {\n id: \"host\",\n job: null,\n async uploadWorkspace() {\n return { files: 0, bytes: 0, skipped: [] };\n },\n async downloadWorkspace() {\n return { files: 0, bytes: 0, conflicts: [] };\n },\n exec(spec) {\n return runHost(spawnChildProcess, spec);\n },\n async detach() {\n throw new Error(\n \"host runtime does not support detach because host has no addressable env\"\n );\n },\n shell() {\n return runHost(spawnChildProcess, {\n command: openSpec.shellSpec?.command ?? openSpec.env.SHELL ?? process.env.SHELL ?? \"sh\",\n args: openSpec.shellSpec?.args,\n cwd: openSpec.cwd,\n env:\n openSpec.shellSpec && \"env\" in openSpec.shellSpec\n ? openSpec.shellSpec.env\n : openSpec.env,\n stdin: \"inherit\",\n stdout: \"inherit\",\n stderr: \"inherit\",\n tty: true\n });\n },\n async close() {}\n } as OpenedEnv;\n }) as unknown as ExecutionEnvFactory[\"open\"],\n async attach() {\n throw new Error(\"host runtime does not support reattach\");\n }\n };\n}\n\nfunction runHost(spawnProcess: typeof import(\"node:child_process\").spawn, spec: RunSpec) {\n const stdin = spec.stdin ?? \"ignore\";\n const stdout = spec.stdout ?? \"pipe\";\n const stderr = spec.stderr ?? \"pipe\";\n const stdio =\n stdin === \"inherit\" && stdout === \"inherit\" && stderr === \"inherit\"\n ? \"inherit\"\n : ([stdin, stdout, stderr] as [\n \"pipe\" | \"inherit\" | \"ignore\",\n \"pipe\" | \"inherit\",\n \"pipe\" | \"inherit\"\n ]);\n const child = spawnProcess(spec.command, spec.args ?? [], {\n cwd: spec.cwd,\n env: spec.env,\n stdio\n });\n const result = new Promise<{ exitCode: number }>((resolve) => {\n child.once(\"close\", (code) => {\n resolve({ exitCode: code ?? 1 });\n });\n child.once(\"error\", () => {\n resolve({ exitCode: 1 });\n });\n });\n const kill = (signal?: NodeJS.Signals) => {\n child.kill(signal);\n };\n if (spec.signal?.aborted) {\n kill(\"SIGTERM\");\n } else {\n spec.signal?.addEventListener(\"abort\", () => kill(\"SIGTERM\"), { once: true });\n }\n return {\n pid: child.pid ?? null,\n stdin: child.stdin,\n stdout: child.stdout,\n stderr: child.stderr,\n result,\n kill\n };\n}\n", "import path from \"node:path\";\n\nexport function resolveWorkflowPath(inputPath: string, cwd: string, homeDir: string): string {\n if (inputPath.startsWith(\"~/\")) {\n return path.join(homeDir, inputPath.slice(2));\n }\n\n if (inputPath === \"~\") {\n return homeDir;\n }\n\n return path.isAbsolute(inputPath) ? inputPath : path.resolve(cwd, inputPath);\n}\n\nexport interface DiscoverDocsOptions {\n cwd: string;\n homeDir: string;\n subDirectory: string;\n glob?: string;\n fs: { readdir: (path: string) => Promise<string[]> };\n}\n\nfunction isMissingDirectory(error: unknown): boolean {\n return (\n !!error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n ((error as { code?: unknown }).code === \"ENOENT\" ||\n (error as { code?: unknown }).code === \"ENOTDIR\")\n );\n}\n\nfunction defaultGlobForSubDirectory(subDirectory: string): string {\n return subDirectory.startsWith(\"pipeline/\") ? \"*.yaml\" : \"*.md\";\n}\n\nfunction matchesGlob(fileName: string, glob: string): boolean {\n if (glob === \"*\") {\n return true;\n }\n\n if (glob.startsWith(\"*.\")) {\n const suffix = glob.slice(1).toLowerCase();\n return fileName.toLowerCase().endsWith(suffix);\n }\n\n return fileName === glob;\n}\n\nasync function readDirectory(\n fs: DiscoverDocsOptions[\"fs\"],\n directoryPath: string\n): Promise<string[]> {\n try {\n return await fs.readdir(directoryPath);\n } catch (error) {\n if (isMissingDirectory(error)) {\n return [];\n }\n\n throw error;\n }\n}\n\nasync function discoverFromDirectory(options: {\n fs: DiscoverDocsOptions[\"fs\"];\n directoryPath: string;\n glob: string;\n}): Promise<Array<{ fileName: string; absolutePath: string }>> {\n const entries = await readDirectory(options.fs, options.directoryPath);\n\n return entries\n .filter((entry) => matchesGlob(entry, options.glob))\n .map((entry) => ({\n fileName: entry,\n absolutePath: path.join(options.directoryPath, entry)\n }));\n}\n\nexport async function discoverWorkflowDocs(options: DiscoverDocsOptions): Promise<string[]> {\n const glob = options.glob ?? defaultGlobForSubDirectory(options.subDirectory);\n const projectDirectory = path.join(options.cwd, \".poe-code\", options.subDirectory);\n const globalDirectory = path.join(options.homeDir, \".poe-code\", options.subDirectory);\n\n const [projectDocs, globalDocs] = await Promise.all([\n discoverFromDirectory({\n fs: options.fs,\n directoryPath: projectDirectory,\n glob\n }),\n discoverFromDirectory({\n fs: options.fs,\n directoryPath: globalDirectory,\n glob\n })\n ]);\n\n const docsByFileName = new Map<string, string>();\n\n for (const doc of globalDocs) {\n docsByFileName.set(doc.fileName, doc.absolutePath);\n }\n\n for (const doc of projectDocs) {\n docsByFileName.set(doc.fileName, doc.absolutePath);\n }\n\n return [...docsByFileName.values()].sort((left, right) => left.localeCompare(right));\n}\n", "import * as fsPromises from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { openTaskList, type TaskList, type TaskListFs } from \"@poe-code/task-list\";\nimport { resolveWorkflowPath } from \"./paths.js\";\n\nconst PLAN_LIST_NAME = \"plans\";\nconst MARKDOWN_EXTENSION = \".md\";\n\nexport interface PlanRef {\n id: string;\n absolutePath: string;\n displayPath: string;\n kind: string;\n name: string;\n}\n\nexport interface DiscoverPlansOptions {\n cwd: string;\n homeDir: string;\n planDirectory: string;\n kinds?: readonly string[];\n fs?: TaskListFs;\n}\n\nexport interface ArchivePlanOptions {\n cwd: string;\n homeDir: string;\n planDirectory: string;\n id: string;\n fs?: TaskListFs;\n}\n\nexport interface OpenPlanListOptions {\n cwd: string;\n homeDir: string;\n planDirectory: string;\n fs?: TaskListFs;\n}\n\nfunction defaultFs(): TaskListFs {\n return fsPromises as unknown as TaskListFs;\n}\n\nfunction hasErrorCode(error: unknown, code: string): boolean {\n return (\n !!error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n (error as { code?: unknown }).code === code\n );\n}\n\nasync function directoryExists(fs: TaskListFs, directoryPath: string): Promise<boolean> {\n try {\n return (await fs.stat(directoryPath)).isDirectory();\n } catch (error) {\n if (hasErrorCode(error, \"ENOENT\") || hasErrorCode(error, \"ENOTDIR\")) {\n return false;\n }\n\n throw error;\n }\n}\n\nfunction stripMarkdownExtension(fileName: string): string | undefined {\n if (!fileName.endsWith(MARKDOWN_EXTENSION)) {\n return undefined;\n }\n\n return fileName.slice(0, -MARKDOWN_EXTENSION.length);\n}\n\nfunction idFromPlanFileName(fileName: string): string | undefined {\n const stem = stripMarkdownExtension(fileName);\n if (stem === undefined) {\n return undefined;\n }\n\n let index = 0;\n while (index < stem.length && stem.charCodeAt(index) >= 48 && stem.charCodeAt(index) <= 57) {\n index += 1;\n }\n\n if (index > 0 && stem[index] === \"-\" && index < stem.length - 1) {\n return stem.slice(index + 1);\n }\n\n return stem;\n}\n\nasync function readPlanPaths(fs: TaskListFs, directoryPath: string): Promise<Map<string, string>> {\n const fileNames = await fs.readdir(directoryPath);\n const pathsById = new Map<string, string>();\n\n for (const fileName of fileNames) {\n const id = idFromPlanFileName(fileName);\n if (id === undefined) {\n continue;\n }\n\n const absolutePath = path.join(directoryPath, fileName);\n const stat = await fs.stat(absolutePath);\n if (stat.isFile()) {\n pathsById.set(id, absolutePath);\n }\n }\n\n return pathsById;\n}\n\nfunction isPathWithin(basePath: string, targetPath: string): boolean {\n const relativePath = path.relative(basePath, targetPath);\n\n return relativePath === \"\" || (!relativePath.startsWith(\"..\") && !path.isAbsolute(relativePath));\n}\n\nfunction displayPlanPath(absolutePath: string, cwd: string, homeDir: string): string {\n if (isPathWithin(cwd, absolutePath)) {\n return path.relative(cwd, absolutePath);\n }\n\n if (isPathWithin(homeDir, absolutePath)) {\n const relativeToHome = path.relative(homeDir, absolutePath);\n return relativeToHome.length === 0 ? \"~\" : `~/${relativeToHome}`;\n }\n\n return absolutePath;\n}\n\nfunction resolvePlanDirectory(options: {\n cwd: string;\n homeDir: string;\n planDirectory: string;\n}): string {\n return resolveWorkflowPath(options.planDirectory, options.cwd, options.homeDir);\n}\n\nfunction planKind(metadata: Record<string, unknown>): string {\n return String(metadata.kind ?? \"plan\");\n}\n\nexport async function discoverPlans(options: DiscoverPlansOptions): Promise<PlanRef[]> {\n const resolvedDirectory = resolvePlanDirectory(options);\n const fs = options.fs ?? defaultFs();\n if (!(await directoryExists(fs, resolvedDirectory))) {\n return [];\n }\n\n const [taskList, pathsById] = await Promise.all([\n openPlanList(options),\n readPlanPaths(fs, resolvedDirectory)\n ]);\n const kindFilter = options.kinds === undefined ? undefined : new Set(options.kinds);\n const tasks = await taskList.list(PLAN_LIST_NAME).all();\n\n return tasks\n .map((task) => ({\n id: task.id,\n name: task.name,\n kind: planKind(task.metadata),\n absolutePath: pathsById.get(task.id) ?? path.join(resolvedDirectory, `${task.id}.md`)\n }))\n .filter((plan) => kindFilter === undefined || kindFilter.has(plan.kind))\n .map((plan) => ({\n ...plan,\n displayPath: displayPlanPath(plan.absolutePath, options.cwd, options.homeDir)\n }));\n}\n\nexport const archivePlan = async (options: ArchivePlanOptions): Promise<void> => {\n const taskList = await openPlanList(options);\n const plans = taskList.list(PLAN_LIST_NAME);\n\n await plans.fire(options.id, \"archive\");\n};\n\nexport function openPlanList(options: OpenPlanListOptions): Promise<TaskList> {\n return openTaskList({\n type: \"markdown-dir\",\n path: resolvePlanDirectory(options),\n singleList: PLAN_LIST_NAME,\n frontmatterMode: \"passthrough\",\n fs: options.fs\n });\n}\n", "import * as fsPromises from \"node:fs/promises\";\nimport { ghIssuesBackend } from \"./backends/gh-issues.js\";\nimport { resolveAuth, resolveEndpoint } from \"./backends/gh-issues-client.js\";\nimport { markdownDirBackend } from \"./backends/markdown-dir.js\";\nimport { yamlFileBackend } from \"./backends/yaml-file.js\";\nimport { validateMachine } from \"./state-machine.js\";\nimport { resolveStateMachine } from \"./state.js\";\nimport type {\n BackendFactory,\n BackendDeps,\n OpenGhIssuesOptions,\n OpenMarkdownDirOptions,\n OpenTaskListOptions,\n OpenYamlFileOptions,\n TaskList,\n TaskListFs\n} from \"./types.js\";\n\nconst DEFAULT_LOCK_STALE_MS = 30_000;\nconst DEFAULT_LOCK_RETRIES = 20;\n\ntype FileBackendOptions = OpenMarkdownDirOptions | OpenYamlFileOptions;\n\nexport const backendFactories: Record<FileBackendOptions[\"type\"], BackendFactory> = {\n \"markdown-dir\": markdownDirBackend,\n \"yaml-file\": yamlFileBackend\n};\n\nfunction createDefaultFs(): TaskListFs {\n return fsPromises as unknown as TaskListFs;\n}\n\nexport async function openTaskList(options: OpenTaskListOptions): Promise<TaskList> {\n switch (options.type) {\n case \"markdown-dir\":\n case \"yaml-file\":\n return openFileBackend(options);\n case \"gh-issues\":\n return openGhIssuesBackend(options);\n default:\n throw new Error(`Unknown task list backend type \"${(options as { type: string }).type}\".`);\n }\n}\n\nasync function openFileBackend(options: FileBackendOptions): Promise<TaskList> {\n const factory = backendFactories[options.type];\n const stateMachine = resolveStateMachine(options.stateMachine);\n validateMachine(stateMachine);\n const markdownOptions = options.type === \"markdown-dir\" ? options : undefined;\n\n const deps: BackendDeps = {\n path: options.path,\n defaults: {\n metadata: { ...(options.defaults?.metadata ?? {}) }\n },\n singleList: markdownOptions?.singleList,\n frontmatterMode: markdownOptions?.frontmatterMode ?? \"strict\",\n lockStaleMs: options.lockStaleMs ?? DEFAULT_LOCK_STALE_MS,\n lockRetries: options.lockRetries ?? DEFAULT_LOCK_RETRIES,\n create: options.create ?? false,\n fs: options.fs ?? createDefaultFs(),\n stateMachine\n };\n\n return factory(deps);\n}\n\nasync function openGhIssuesBackend(options: OpenGhIssuesOptions): Promise<TaskList> {\n const token = await resolveAuth({ explicitToken: options.auth?.token });\n const endpoint = resolveEndpoint();\n\n return ghIssuesBackend({\n repo: options.repo,\n project: options.project,\n defaults: {\n metadata: { ...(options.defaults?.metadata ?? {}) }\n },\n token,\n endpoint,\n fetch: options.fetch\n });\n}\n", "import type { Task } from \"./types.js\";\n\nexport interface StateMachineDef<TState extends string = string, TEvent extends string = string> {\n readonly initial: TState;\n readonly states: readonly TState[];\n readonly events: Readonly<Record<TEvent, EventDef<TState>>>;\n}\n\nexport interface EventDef<TState extends string = string> {\n readonly from: readonly TState[] | \"*\";\n readonly to: TState;\n readonly guard?: (task: Task) => true | string;\n readonly onEnter?: (task: Task) => void | Promise<void>;\n readonly onExit?: (task: Task) => void | Promise<void>;\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction isStateList(value: unknown): value is readonly string[] {\n return Array.isArray(value) && value.every((entry) => typeof entry === \"string\");\n}\n\nfunction canFireFromState<TState extends string>(event: EventDef<TState>, fromState: string): boolean {\n if (event.from === \"*\") {\n return event.to !== fromState;\n }\n\n return event.from.includes(fromState as TState);\n}\n\nexport function validateMachine(machine: StateMachineDef): void {\n if (!isRecord(machine)) {\n throw new TypeError(\"State machine must be an object.\");\n }\n\n if (!isStateList(machine.states)) {\n throw new TypeError(\"State machine states must be a string array.\");\n }\n\n const states = new Set(machine.states);\n\n if (typeof machine.initial !== \"string\") {\n throw new TypeError(\"State machine initial must be a string.\");\n }\n\n if (!states.has(machine.initial)) {\n throw new Error(`Initial state \"${machine.initial}\" is not declared.`);\n }\n\n if (!isRecord(machine.events)) {\n throw new TypeError(\"State machine events must be an object.\");\n }\n\n for (const [eventName, event] of Object.entries(machine.events)) {\n if (!isRecord(event)) {\n throw new TypeError(`Event \"${eventName}\" must be an object.`);\n }\n\n if (event.from !== \"*\" && !isStateList(event.from)) {\n throw new TypeError(`Event \"${eventName}\" has an invalid \"from\" definition.`);\n }\n\n if (typeof event.to !== \"string\") {\n throw new TypeError(`Event \"${eventName}\" target state must be a string.`);\n }\n\n if (!states.has(event.to)) {\n throw new Error(`Event \"${eventName}\" references unknown target state \"${event.to}\".`);\n }\n\n if (event.from !== \"*\") {\n for (const fromState of event.from) {\n if (!states.has(fromState)) {\n throw new Error(`Event \"${eventName}\" references unknown source state \"${fromState}\".`);\n }\n }\n }\n }\n}\n\nexport function eventsFromState<TState extends string, TEvent extends string>(\n machine: StateMachineDef<TState, TEvent>,\n fromState: TState\n): readonly TEvent[] {\n const events: TEvent[] = [];\n\n for (const [eventName, event] of Object.entries(machine.events) as Array<[TEvent, EventDef<TState>]>) {\n if (canFireFromState(event, fromState)) {\n events.push(eventName);\n }\n }\n\n return events;\n}\n\nexport function findEvent<TState extends string, TEvent extends string>(\n machine: StateMachineDef<TState, TEvent>,\n fromState: TState,\n eventName: TEvent\n): EventDef<TState> | undefined {\n const event = machine.events[eventName];\n\n if (event === undefined) {\n return undefined;\n }\n\n return canFireFromState(event, fromState) ? event : undefined;\n}\n", "import { text } from \"node:stream/consumers\";\nimport { createHostRunner, type Runner } from \"@poe-code/process-runner\";\n\nconst DEFAULT_ENDPOINT = \"https://api.github.com/graphql\";\nconst USER_AGENT = \"poe-code-task-list/0.0.1\";\nconst AUTH_ERROR = \"gh auth token failed; install gh, run 'gh auth login', or pass auth: { token }\";\n\nexport interface GhClientOptions {\n token: string;\n endpoint?: string;\n fetch?: typeof fetch;\n}\n\nexport interface GhClient {\n graphql<T>(query: string, variables: Record<string, unknown>): Promise<T>;\n}\n\nexport function createGhClient(options: GhClientOptions): GhClient {\n const fetchImpl = options.fetch ?? fetch;\n const endpoint = options.endpoint || DEFAULT_ENDPOINT;\n\n return {\n async graphql<T>(query: string, variables: Record<string, unknown>) {\n const response = await fetchImpl(endpoint, {\n method: \"POST\",\n headers: {\n Authorization: `Bearer ${options.token}`,\n \"Content-Type\": \"application/json\",\n \"User-Agent\": USER_AGENT\n },\n body: JSON.stringify({ query, variables })\n });\n\n const body = await response.text();\n if (response.status !== 200) {\n throw new Error(`GitHub GraphQL request failed with status ${response.status}: ${body}`);\n }\n\n const parsed = JSON.parse(body) as {\n data?: T;\n errors?: { message?: string }[];\n };\n const firstError = parsed.errors?.[0];\n if (firstError !== undefined) {\n throw new Error(firstError.message ?? \"GitHub GraphQL request failed\");\n }\n\n return parsed.data as T;\n }\n };\n}\n\nexport interface ResolveAuthOptions {\n explicitToken?: string;\n runner?: Runner;\n}\n\nexport async function resolveAuth(options: ResolveAuthOptions): Promise<string> {\n if (options.explicitToken !== undefined) {\n return options.explicitToken;\n }\n\n const runner = options.runner ?? createHostRunner();\n const handle = runner.exec({\n command: \"gh\",\n args: [\"auth\", \"token\"],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n\n const [stdout, , result] = await Promise.all([\n handle.stdout === null ? Promise.resolve(\"\") : text(handle.stdout),\n handle.stderr === null ? Promise.resolve(\"\") : text(handle.stderr),\n handle.result\n ]);\n const token = stdout.trim();\n\n if (result.exitCode !== 0 || token.length === 0) {\n throw new Error(AUTH_ERROR);\n }\n\n return token;\n}\n\nexport interface ResolveEndpointOptions {\n env?: Record<string, string | undefined>;\n}\n\nexport function resolveEndpoint(options: ResolveEndpointOptions = {}): string {\n const env = options.env ?? process.env;\n const host = env.GH_HOST;\n\n if (host !== undefined && host !== \"\" && host !== \"github.com\") {\n return `https://${host}/api/graphql`;\n }\n\n return DEFAULT_ENDPOINT;\n}\n", "import { execSync } from \"node:child_process\";\nimport type { Engine } from \"../types.js\";\n\ninterface ColimaProfile {\n name?: string;\n profile?: string;\n status?: string;\n runtime?: string;\n}\n\nexport function detectContext(): string | null {\n try {\n const output = execSync(\"colima list --json\", {\n encoding: \"utf-8\",\n stdio: [\"pipe\", \"pipe\", \"ignore\"]\n });\n const lines = output.trim().split(\"\\n\").filter(Boolean);\n\n for (const line of lines) {\n const profile = JSON.parse(line) as ColimaProfile;\n\n if (profile.status === \"Running\" && profile.runtime === \"docker\") {\n const name = profile.name ?? profile.profile;\n\n if (!name) {\n continue;\n }\n\n return name === \"default\" ? \"colima\" : `colima-${name}`;\n }\n }\n } catch {\n return null;\n }\n\n return null;\n}\n\nexport function buildContextArgs(engine: Engine, context: string | null): string[] {\n if (engine === \"docker\" && context) {\n return [\"--context\", context];\n }\n\n return [];\n}\n", "import { execSync } from \"node:child_process\";\nimport type { Engine } from \"../types.js\";\n\nexport function detectEngine(): Engine {\n if (isEngineAvailable(\"docker\")) {\n return \"docker\";\n }\n\n if (isEngineAvailable(\"podman\")) {\n return \"podman\";\n }\n\n throw new Error(\n \"No container engine found. Please install Docker or Podman:\\n\" +\n \" - Docker Desktop: https://www.docker.com/products/docker-desktop\\n\" +\n \" - Colima (macOS): brew install colima && colima start\\n\" +\n \" - Podman: https://podman.io/docs/installation\"\n );\n}\n\nexport function isEngineAvailable(engine: Engine): boolean {\n try {\n execSync(`${engine} --version`, {\n stdio: \"ignore\"\n });\n return true;\n } catch {\n return false;\n }\n}\n", "import * as childProcess from \"node:child_process\";\nimport { randomBytes } from \"node:crypto\";\nimport { buildDockerRunArgs } from \"./args.js\";\nimport { buildContextArgs, detectContext } from \"./context.js\";\nimport { detectEngine } from \"./engine.js\";\nimport type { DockerRunnerOptions, RunHandle, Runner, RunResult, RunSpec } from \"../types.js\";\n\nexport function createDockerRunner(options: DockerRunnerOptions): Runner {\n const engine = options.engine ?? detectEngine();\n const context = options.context ?? detectContext();\n\n return {\n name: \"docker\",\n exec(spec: RunSpec): RunHandle {\n const stdinMode = spec.stdin ?? \"ignore\";\n const stdoutMode = spec.stdout ?? \"pipe\";\n const stderrMode = spec.stderr ?? \"pipe\";\n const interactiveMode =\n stdinMode === \"inherit\" &&\n stdoutMode === \"inherit\" &&\n stderrMode === \"inherit\" &&\n spec.tty === true;\n const containerName = buildContainerName(options.containerName ?? spec.command);\n const runArgs = buildDockerRunArgs({\n engine,\n context,\n image: options.image,\n command: spec.command,\n args: spec.args ?? [],\n cwd: spec.cwd,\n env: spec.env,\n mounts: options.mounts ?? [],\n ports: options.ports ?? [],\n network: options.network,\n containerName,\n detached: false,\n interactive: stdinMode === \"pipe\" || stdinMode === \"inherit\",\n tty: spec.tty ?? false,\n rm: true,\n extraArgs: options.extraArgs ?? []\n });\n const [command, ...args] = runArgs;\n const child = childProcess.spawn(command, args, {\n stdio: interactiveMode ? \"inherit\" : [stdinMode, stdoutMode, stderrMode]\n });\n let isResultSettled = false;\n let resolveResult: ((value: RunResult) => void) | null = null;\n const result = new Promise<RunResult>((resolve) => {\n resolveResult = resolve;\n });\n const cleanupAbort = bindAbortSignal(spec.signal, () => {\n spawnControlCommand(engine, context, [\"stop\", containerName]);\n });\n const settleResult = (exitCode: number) => {\n if (isResultSettled) {\n return;\n }\n\n isResultSettled = true;\n cleanupAbort();\n resolveResult?.({ exitCode });\n };\n\n child.once(\"error\", () => {\n settleResult(1);\n });\n\n child.once(\"close\", (code) => {\n settleResult(code ?? 1);\n });\n\n return {\n pid: null,\n stdin: interactiveMode ? null : child.stdin,\n stdout: interactiveMode ? null : child.stdout,\n stderr: interactiveMode ? null : child.stderr,\n result,\n kill(signal?: NodeJS.Signals) {\n if (signal === \"SIGKILL\") {\n spawnControlCommand(engine, context, [\"kill\", containerName]);\n return;\n }\n\n if (signal === undefined || signal === \"SIGTERM\") {\n spawnControlCommand(engine, context, [\"stop\", containerName]);\n return;\n }\n\n spawnControlCommand(engine, context, [\"kill\", `--signal=${signal}`, containerName]);\n }\n };\n }\n };\n}\n\nfunction buildContainerName(name: string): string {\n const suffix = randomBytes(3).toString(\"hex\").slice(0, 6);\n const sanitizedName = sanitizeContainerName(name);\n\n return `poe-run-${sanitizedName}-${suffix}`;\n}\n\nfunction sanitizeContainerName(name: string): string {\n let sanitized = \"\";\n\n for (const char of name) {\n if (isContainerNameCharacter(char)) {\n sanitized += char;\n continue;\n }\n\n sanitized += \"-\";\n }\n\n return sanitized.length > 0 ? sanitized : \"command\";\n}\n\nfunction isContainerNameCharacter(char: string): boolean {\n const code = char.charCodeAt(0);\n\n if (code >= 48 && code <= 57) {\n return true;\n }\n\n if (code >= 65 && code <= 90) {\n return true;\n }\n\n if (code >= 97 && code <= 122) {\n return true;\n }\n\n return char === \".\" || char === \"_\" || char === \"-\";\n}\n\nfunction spawnControlCommand(\n engine: DockerRunnerOptions[\"engine\"] extends infer T ? Exclude<T, undefined> : never,\n context: string | null,\n args: string[]\n): void {\n childProcess.spawn(engine, [...buildContextArgs(engine, context), ...args], {\n stdio: \"ignore\"\n });\n}\n\nfunction bindAbortSignal(signal: AbortSignal | undefined, onAbort: () => void): () => void {\n if (signal === undefined) {\n return () => {};\n }\n\n if (signal.aborted) {\n onAbort();\n return () => {};\n }\n\n signal.addEventListener(\"abort\", onAbort, { once: true });\n\n return () => {\n signal.removeEventListener(\"abort\", onAbort);\n };\n}\n", "import path from \"node:path\";\nimport type { DockerRunArgs } from \"../types.js\";\n\nexport function buildDockerRunArgs(input: DockerRunArgs): string[] {\n const args: string[] = [input.engine];\n\n if (input.engine === \"docker\" && input.context) {\n args.push(\"--context\", input.context);\n }\n\n args.push(\"run\");\n\n if (input.rm) {\n args.push(\"--rm\");\n }\n\n if (input.detached) {\n args.push(\"-d\");\n }\n\n if (input.interactive) {\n args.push(\"-i\");\n }\n\n if (input.tty) {\n args.push(\"-t\");\n }\n\n args.push(\"--name\", input.containerName);\n\n if (input.cwd !== undefined) {\n args.push(\"-w\", input.cwd);\n }\n\n for (const [key, value] of Object.entries(input.env ?? {})) {\n args.push(\"-e\", `${key}=${value}`);\n }\n\n for (const mount of input.mounts) {\n const volume = `${path.resolve(mount.source)}:${mount.target}${mount.readonly ? \":ro\" : \"\"}`;\n args.push(\"-v\", volume);\n }\n\n for (const port of input.ports) {\n const mapping = `${port.host}:${port.container}${port.protocol === undefined || port.protocol === \"tcp\" ? \"\" : `/${port.protocol}`}`;\n args.push(\"-p\", mapping);\n }\n\n if (input.network !== undefined) {\n args.push(\"--network\", input.network);\n }\n\n args.push(...input.extraArgs, input.image, input.command, ...input.args);\n\n return args;\n}\n", "import { createHash, randomBytes } from \"node:crypto\";\nimport { mkdtempSync, rmSync } from \"node:fs\";\nimport { readFile } from \"node:fs/promises\";\nimport { tmpdir } from \"node:os\";\nimport path from \"node:path\";\nimport { buildDockerRunArgs } from \"./args.js\";\nimport { buildContextArgs, detectContext } from \"./context.js\";\nimport { detectEngine } from \"./engine.js\";\nimport { createHostRunner } from \"../host/host-runner.js\";\nimport type {\n DockerMount,\n Engine,\n ExecutionState,\n ExecutionEnvFactory,\n OpenSpec,\n OpenedEnv,\n Runner,\n RunSpec\n} from \"../types.js\";\n\ninterface DockerRuntime {\n type: \"docker\";\n image?: string;\n dockerfile?: string;\n build_context?: string;\n build_args?: Record<string, string>;\n mounts?: DockerMount[];\n engine?: Engine;\n network?: string;\n extra_args?: string[];\n}\n\nexport interface BuildDockerRuntimeTemplateInput {\n cwd: string;\n runtime: DockerRuntime;\n state?: ExecutionState;\n runner?: Runner;\n force?: boolean;\n}\n\nexport interface BuildDockerRuntimeTemplateResult {\n backend: \"docker\";\n hash: string;\n image: string;\n cached: boolean;\n}\n\nconst containerCommand = [\"sh\", \"-c\", \"while :; do sleep 3600; done\"] as const;\n\nexport const dockerExecutionEnvFactory: ExecutionEnvFactory = {\n type: \"docker\",\n supportsDetach: true,\n async open(spec): Promise<OpenedEnv> {\n const runtime = parseDockerRuntime(spec.runtime);\n const runner = spec.hostRunner ?? createHostRunner();\n const engine = runtime.engine ?? detectEngine();\n const context = detectContext();\n const image = await resolveImage({\n spec,\n runtime,\n runner,\n engine,\n context\n });\n const containerName = createContainerName();\n const runArgs = buildDockerRunArgs({\n engine,\n context,\n image,\n command: containerCommand[0],\n args: containerCommand.slice(1),\n cwd: undefined,\n env: undefined,\n mounts: runtime.mounts ?? [],\n ports: [],\n network: runtime.network,\n containerName,\n detached: true,\n interactive: true,\n tty: false,\n rm: false,\n extraArgs: runtime.extra_args ?? []\n });\n const [command, ...args] = runArgs;\n const id = (await runAndRead(runner, { command, args, stdout: \"pipe\", stderr: \"pipe\" })).trim();\n\n return createDockerEnv({\n id,\n spec,\n runner,\n engine,\n context\n });\n },\n async attach(envId, context): Promise<OpenedEnv> {\n const engine = detectEngine();\n return createDockerEnv({\n id: envId,\n spec: createAttachedSpec(context?.cwd),\n runner: createHostRunner(),\n engine,\n context: detectContext(),\n attachedJobId: context?.jobId\n });\n }\n};\n\nfunction createDockerEnv(input: {\n id: string;\n spec: OpenSpec;\n runner: Runner;\n engine: Engine;\n context: string | null;\n attachedJobId?: string;\n}): OpenedEnv {\n const containerRef = input.id;\n\n return {\n id: containerRef,\n job:\n input.attachedJobId === undefined\n ? null\n : createContainerJob(containerRef, input.runner, input.engine, input.context, input.attachedJobId),\n async uploadWorkspace() {\n const tempDir = mkdtempSync(path.join(tmpdir(), \"poe-docker-upload-\"));\n const archivePath = path.join(tempDir, \"workspace.tar\");\n try {\n const excludeArgs = input.spec.uploadIgnoreFiles.flatMap((ignored) => [\n \"--exclude\",\n ignored\n ]);\n const tarArgs = [...excludeArgs, \"-cf\", archivePath, \"-C\", input.spec.cwd, \".\"];\n await runOrThrow(input.runner, {\n command: \"tar\",\n args: tarArgs,\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"cp\",\n archivePath,\n `${containerRef}:/tmp/poe-workspace-upload.tar`\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"exec\",\n containerRef,\n \"sh\",\n \"-c\",\n `mkdir -p ${shellQuote(input.spec.cwd)} && tar -xf /tmp/poe-workspace-upload.tar -C ${shellQuote(input.spec.cwd)}`\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n\n return { files: 0, bytes: 0, skipped: [] };\n } finally {\n rmSync(tempDir, { recursive: true, force: true });\n }\n },\n async downloadWorkspace(opts) {\n const tempDir = mkdtempSync(path.join(tmpdir(), \"poe-docker-download-\"));\n const archivePath = path.join(tempDir, \"workspace.tar\");\n try {\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"exec\",\n containerRef,\n \"sh\",\n \"-c\",\n `tar -cf /tmp/poe-workspace-download.tar -C ${shellQuote(input.spec.cwd)} .`\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"cp\",\n `${containerRef}:/tmp/poe-workspace-download.tar`,\n archivePath\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n const extractMode = opts.conflictPolicy === \"refuse\" ? \"-xkf\" : \"-xf\";\n await runOrThrow(input.runner, {\n command: \"tar\",\n args: [extractMode, archivePath, \"-C\", input.spec.cwd],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n\n return { files: 0, bytes: 0, conflicts: [] };\n } finally {\n rmSync(tempDir, { recursive: true, force: true });\n }\n },\n exec(spec) {\n return input.runner.exec({\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"exec\",\n ...(spec.stdin === \"pipe\" || spec.stdin === \"inherit\" ? [\"-i\"] : []),\n ...(spec.tty === true ? [\"-t\"] : []),\n ...(spec.cwd !== undefined ? [\"-w\", spec.cwd] : []),\n ...buildEnvArgs(spec.env),\n containerRef,\n spec.command,\n ...(spec.args ?? [])\n ],\n stdin: spec.stdin,\n stdout: spec.stdout,\n stderr: spec.stderr,\n tty: spec.tty\n });\n },\n async detach() {\n return createContainerJob(containerRef, input.runner, input.engine, input.context);\n },\n shell() {\n const shellSpec = input.spec.shellSpec;\n return this.exec({\n command: shellSpec?.command ?? input.spec.env.SHELL ?? \"sh\",\n ...(shellSpec?.args ? { args: shellSpec.args } : {}),\n cwd: input.spec.cwd,\n env: shellSpec && \"env\" in shellSpec ? shellSpec.env : input.spec.env,\n stdin: \"inherit\",\n stdout: \"inherit\",\n stderr: \"inherit\",\n tty: true\n });\n },\n async close() {\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [...buildContextArgs(input.engine, input.context), \"rm\", \"-f\", containerRef],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n }\n };\n}\n\nasync function resolveImage(input: {\n spec: OpenSpec;\n runtime: DockerRuntime;\n runner: Runner;\n engine: Engine;\n context: string | null;\n}): Promise<string> {\n if (input.runtime.image !== undefined) {\n return input.runtime.image;\n }\n\n const result = await buildDockerRuntimeTemplate({\n cwd: input.spec.cwd,\n runtime: input.runtime,\n state: input.spec.state,\n runner: input.runner\n });\n return result.image;\n}\n\nexport async function buildDockerRuntimeTemplate(\n input: BuildDockerRuntimeTemplateInput\n): Promise<BuildDockerRuntimeTemplateResult> {\n const runner = input.runner ?? createHostRunner();\n const engine = input.runtime.engine ?? detectEngine();\n const context = detectContext();\n const dockerfilePath = path.resolve(\n input.cwd,\n input.runtime.dockerfile ?? path.join(\".poe-code\", \"Dockerfile\")\n );\n const buildContext = path.resolve(input.cwd, input.runtime.build_context ?? \".\");\n const dockerfileBytes = await readFile(dockerfilePath);\n const hash = hashDockerTemplate(dockerfileBytes, input.runtime.build_args ?? {});\n const cached = input.force ? null : await input.state?.templates.get(\"docker\", hash);\n\n if (cached?.image !== undefined) {\n return {\n backend: \"docker\",\n hash,\n image: cached.image,\n cached: true\n };\n }\n\n const image = `poe-code/local:${hash}`;\n await buildImage({\n runner,\n engine,\n context,\n image,\n dockerfilePath,\n buildContext,\n buildArgs: input.runtime.build_args ?? {}\n });\n await input.state?.templates.put(\"docker\", {\n hash,\n image,\n runtime_type: \"docker\",\n dockerfile_path: dockerfilePath,\n built_at: new Date().toISOString()\n });\n\n return {\n backend: \"docker\",\n hash,\n image,\n cached: false\n };\n}\n\nfunction hashDockerTemplate(dockerfileBytes: Buffer, buildArgs: Record<string, string>): string {\n const hash = createHash(\"sha256\");\n hash.update(dockerfileBytes);\n hash.update(\"\\0\");\n for (const [key, value] of sortedBuildArgs(buildArgs)) {\n hash.update(key);\n hash.update(\"=\");\n hash.update(value);\n hash.update(\"\\0\");\n }\n return hash.digest(\"hex\");\n}\n\nasync function buildImage(input: {\n runner: Runner;\n engine: Engine;\n context: string | null;\n image: string;\n dockerfilePath: string;\n buildContext: string;\n buildArgs: Record<string, string>;\n}): Promise<void> {\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"build\",\n \"--tag\",\n input.image,\n \"-f\",\n input.dockerfilePath,\n ...sortedBuildArgs(input.buildArgs).flatMap(([key, value]) => [\n \"--build-arg\",\n `${key}=${value}`\n ]),\n input.buildContext\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n}\n\nfunction parseDockerRuntime(runtime: unknown): DockerRuntime {\n if (!runtime || typeof runtime !== \"object\" || Array.isArray(runtime)) {\n throw new Error(\"docker runtime must be an object\");\n }\n const record = runtime as Record<string, unknown>;\n if (record.type !== \"docker\") {\n throw new Error('docker runtime type must be \"docker\"');\n }\n return record as unknown as DockerRuntime;\n}\n\nasync function runAndRead(runner: Runner, spec: RunSpec): Promise<string> {\n const handle = runner.exec(spec);\n const stdout = readStream(handle.stdout);\n const stderr = readStream(handle.stderr);\n const result = await handle.result;\n const output = await stdout;\n if (result.exitCode !== 0) {\n const errorOutput = await stderr;\n throw new Error(\n `Command failed with exit code ${result.exitCode}: ${spec.command} ${(spec.args ?? []).join(\" \")}${errorOutput ? `\\n${errorOutput}` : \"\"}`\n );\n }\n return output;\n}\n\nasync function runOrThrow(runner: Runner, spec: RunSpec): Promise<void> {\n await runAndRead(runner, spec);\n}\n\nasync function readStream(stream: NodeJS.ReadableStream | null): Promise<string> {\n if (stream === null) {\n return \"\";\n }\n\n stream.setEncoding(\"utf8\");\n const chunks: string[] = [];\n for await (const chunk of stream) {\n chunks.push(String(chunk));\n }\n return chunks.join(\"\");\n}\n\nfunction sortedBuildArgs(buildArgs: Record<string, string>): Array<[string, string]> {\n return Object.entries(buildArgs).sort(([left], [right]) => left.localeCompare(right));\n}\n\nfunction buildEnvArgs(env: RunSpec[\"env\"]): string[] {\n if (env === undefined) {\n return [];\n }\n\n return Object.entries(env).flatMap(([key, value]) => [\"-e\", `${key}=${value}`]);\n}\n\nfunction createContainerName(): string {\n return `poe-env-${randomBytes(6).toString(\"hex\")}`;\n}\n\nfunction createContainerJob(\n containerId: string,\n runner: Runner,\n engine: Engine,\n context: string | null,\n jobId = containerId\n) {\n return {\n id: jobId,\n envId: containerId,\n tool: \"docker\",\n argv: [\"attach\", containerId],\n async status() {\n const handle = runner.exec({\n command: engine,\n args: [\n ...buildContextArgs(engine, context),\n \"inspect\",\n \"-f\",\n \"{{.State.Status}}\",\n containerId\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n const stdout = await readStream(handle.stdout);\n const result = await handle.result;\n if (result.exitCode !== 0) {\n return \"lost\" as const;\n }\n return stdout.trim() === \"running\" ? (\"running\" as const) : (\"exited\" as const);\n },\n async *stream(opts?: { sinceByte?: number }) {\n const handle = runner.exec({\n command: engine,\n args: [\n ...buildContextArgs(engine, context),\n \"exec\",\n containerId,\n \"sh\",\n \"-c\",\n `test -f ${shellQuote(`/tmp/poe-jobs/${jobId}.log`)} && tail -c +${(opts?.sinceByte ?? 0) + 1} ${shellQuote(`/tmp/poe-jobs/${jobId}.log`)} || true`\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n const stdout = await readStream(handle.stdout);\n await handle.result;\n if (stdout.length > 0) {\n yield { byteOffset: opts?.sinceByte ?? 0, data: stdout };\n }\n },\n async wait() {\n const handle = runner.exec({\n command: engine,\n args: [...buildContextArgs(engine, context), \"wait\", containerId],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n const stdout = await readStream(handle.stdout);\n const result = await handle.result;\n return { exitCode: Number.parseInt(stdout.trim(), 10) || result.exitCode };\n },\n async kill(signal?: NodeJS.Signals) {\n const args =\n signal === undefined || signal === \"SIGTERM\"\n ? [\"stop\", containerId]\n : [\"kill\", ...(signal === \"SIGKILL\" ? [] : [`--signal=${signal}`]), containerId];\n await runOrThrow(runner, {\n command: engine,\n args: [...buildContextArgs(engine, context), ...args],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n }\n };\n}\n\nfunction createAttachedSpec(cwd = \"/workspace\"): OpenSpec {\n return {\n cwd,\n runtime: {\n type: \"docker\",\n image: \"attached\",\n build_args: {},\n mounts: []\n },\n env: {},\n uploadIgnoreFiles: [],\n jobLabel: {\n tool: \"docker\",\n argv: []\n }\n };\n}\n\nfunction shellQuote(value: string): string {\n return `'${value.replaceAll(\"'\", \"'\\\\''\")}'`;\n}\n", "import { spawn as spawnChildProcess } from \"node:child_process\";\nimport type { Runner, RunSpec } from \"../types.js\";\nimport type { HostRunnerOptions, RunHandle, RunResult } from \"../types.js\";\n\nexport function createHostRunner(options: HostRunnerOptions = {}): Runner {\n const detached = options.detached === true;\n\n return {\n name: \"host\",\n exec(spec: RunSpec): RunHandle {\n const stdinMode = spec.stdin ?? \"ignore\";\n const stdoutMode = spec.stdout ?? \"pipe\";\n const stderrMode = spec.stderr ?? \"pipe\";\n const stdio =\n stdinMode === \"inherit\" && stdoutMode === \"inherit\" && stderrMode === \"inherit\"\n ? \"inherit\"\n : [stdinMode, stdoutMode, stderrMode];\n const child = spawnChildProcess(spec.command, spec.args ?? [], {\n cwd: spec.cwd,\n env: spec.env,\n stdio,\n ...(detached ? { detached: true } : {})\n });\n\n if (detached) {\n child.unref();\n }\n\n const kill = (signal?: NodeJS.Signals) => {\n if (detached && process.platform !== \"win32\" && child.pid !== undefined) {\n process.kill(-child.pid, signal);\n return;\n }\n\n child.kill(signal);\n };\n\n let settled = false;\n let resolveResult: ((value: RunResult) => void) | null = null;\n const result = new Promise<RunResult>((resolve) => {\n resolveResult = resolve;\n });\n\n const cleanupAbort = bindAbortSignal(spec.signal, () => {\n kill(\"SIGTERM\");\n });\n\n child.once(\"close\", (code) => {\n if (settled) return;\n settled = true;\n cleanupAbort();\n resolveResult?.({ exitCode: code ?? 1 });\n });\n child.once(\"error\", () => {\n if (settled) return;\n settled = true;\n cleanupAbort();\n resolveResult?.({ exitCode: 1 });\n });\n\n return {\n pid: child.pid ?? null,\n stdin: child.stdin,\n stdout: child.stdout,\n stderr: child.stderr,\n result,\n kill\n };\n }\n };\n}\n\nfunction bindAbortSignal(signal: AbortSignal | undefined, onAbort: () => void): () => void {\n if (signal === undefined) {\n return () => {};\n }\n\n if (signal.aborted) {\n onAbort();\n return () => {};\n }\n\n signal.addEventListener(\"abort\", onAbort, { once: true });\n\n return () => {\n signal.removeEventListener(\"abort\", onAbort);\n };\n}\n", "import { createHostRunner } from \"./host-runner.js\";\nimport type { ExecutionEnvFactory, OpenedEnv, RunSpec } from \"../types.js\";\n\nexport const hostExecutionEnvFactory: ExecutionEnvFactory = {\n type: \"host\",\n supportsDetach: false,\n async open(openSpec): Promise<OpenedEnv> {\n return {\n id: \"host\",\n job: null,\n async uploadWorkspace() {\n return {\n files: 0,\n bytes: 0,\n skipped: []\n };\n },\n async downloadWorkspace() {\n return {\n files: 0,\n bytes: 0,\n conflicts: []\n };\n },\n exec(spec: RunSpec) {\n return createHostRunner().exec(spec);\n },\n async detach() {\n throw new Error(\"host runtime does not support detach because host has no addressable env\");\n },\n shell() {\n const shellSpec = openSpec.shellSpec;\n return createHostRunner().exec({\n command: shellSpec?.command ?? openSpec.env.SHELL ?? process.env.SHELL ?? \"sh\",\n ...(shellSpec?.args ? { args: shellSpec.args } : {}),\n cwd: openSpec.cwd,\n env: shellSpec && \"env\" in shellSpec ? shellSpec.env : openSpec.env,\n stdin: \"inherit\",\n stdout: \"inherit\",\n stderr: \"inherit\",\n tty: true\n });\n },\n async close() {}\n };\n },\n async attach() {\n throw new Error(\"host runtime does not support reattach\");\n }\n};\n", "import { Readable, Writable } from \"node:stream\";\nimport type { MockRunBehavior, RunHandle, Runner, RunSpec } from \"../types.js\";\n\nexport function createMockRunner(behaviors: MockRunBehavior[]): Runner {\n const remaining = [...behaviors];\n\n return {\n name: \"mock\",\n exec(spec) {\n const behavior = remaining.shift();\n if (behavior === undefined) {\n throw new Error(\"No mock run behaviors left\");\n }\n\n return createRunHandle(spec, behavior);\n }\n };\n}\n\nexport function createMockRunnerByCommand(\n behaviorsByCommand: Record<string, MockRunBehavior>\n): Runner {\n return {\n name: \"mock\",\n exec(spec) {\n const behavior = behaviorsByCommand[spec.command];\n if (behavior === undefined) {\n throw new Error(\n `No mock run behavior found for command \"${spec.command}\"`\n );\n }\n\n return createRunHandle(spec, behavior);\n }\n };\n}\n\nfunction createRunHandle(spec: RunSpec, behavior: MockRunBehavior): RunHandle {\n const stdoutMode = spec.stdout ?? \"pipe\";\n const stderrMode = spec.stderr ?? \"pipe\";\n const stdinMode = spec.stdin ?? \"ignore\";\n const interval = behavior.stdoutInterval ?? 10;\n\n const stdoutController =\n stdoutMode === \"pipe\" && behavior.stdout !== undefined\n ? createReadableStream(behavior.stdout, interval)\n : null;\n const stderrController =\n stderrMode === \"pipe\" && behavior.stderr !== undefined\n ? createReadableStream(behavior.stderr, interval)\n : null;\n\n let resolveResult: ((value: { exitCode: number }) => void) | null = null;\n const result = new Promise<{ exitCode: number }>((resolve) => {\n resolveResult = resolve;\n });\n\n let finished = false;\n const complete = () => {\n if (finished || resolveResult === null) {\n return;\n }\n\n finished = true;\n resolveResult({ exitCode: behavior.exitCode });\n };\n\n const stopStreams = () => {\n stdoutController?.stop();\n stderrController?.stop();\n };\n\n const exitAfterMs = behavior.exitAfterMs ?? 0;\n const exitTimer =\n exitAfterMs > 0\n ? setTimeout(complete, exitAfterMs)\n : queueMicrotask(complete);\n\n return {\n pid: behavior.pid ?? null,\n stdout: stdoutController?.stream ?? null,\n stderr: stderrController?.stream ?? null,\n stdin: stdinMode === \"pipe\" ? createWritableStream() : null,\n result,\n kill() {\n if (typeof exitTimer === \"object\" && exitTimer !== null && \"hasRef\" in exitTimer) {\n clearTimeout(exitTimer);\n }\n stopStreams();\n complete();\n }\n };\n}\n\nfunction createReadableStream(lines: string[], interval: number) {\n const stream = new Readable({\n read() {}\n });\n\n const timers = new Set<NodeJS.Timeout>();\n let stopped = false;\n\n const stop = () => {\n if (stopped) {\n return;\n }\n\n stopped = true;\n for (const timer of timers) {\n clearTimeout(timer);\n }\n timers.clear();\n stream.push(null);\n };\n\n if (lines.length === 0) {\n queueMicrotask(stop);\n return { stream, stop };\n }\n\n for (const [index, line] of lines.entries()) {\n const timer = setTimeout(() => {\n timers.delete(timer);\n if (stopped) {\n return;\n }\n\n stream.push(line);\n if (index === lines.length - 1) {\n stop();\n }\n }, interval * (index + 1));\n\n timers.add(timer);\n }\n\n return { stream, stop };\n}\n\nfunction createWritableStream(): Writable {\n return new Writable({\n write(_chunk, _encoding, callback) {\n callback();\n }\n });\n}\n", "import path from \"node:path\";\nimport type { ListFilter, Task, TaskListFs } from \"../types.js\";\n\nexport interface OrderedEntry {\n task: Task;\n raw: Record<string, unknown>;\n}\n\nexport function compareCreated(left: OrderedEntry, right: OrderedEntry): number {\n const leftCreated = typeof left.raw.created === \"string\" ? left.raw.created : \"\";\n const rightCreated = typeof right.raw.created === \"string\" ? right.raw.created : \"\";\n\n if (leftCreated === \"\" && rightCreated === \"\") {\n return left.task.qualifiedId.localeCompare(right.task.qualifiedId);\n }\n if (leftCreated === \"\") return 1;\n if (rightCreated === \"\") return -1;\n return leftCreated.localeCompare(rightCreated);\n}\n\nexport function applyOrder(entries: OrderedEntry[], order: ListFilter[\"order\"]): Task[] {\n if (order === \"alphabetical\") {\n return sortTasks(entries.map((entry) => entry.task));\n }\n if (order === \"created\") {\n return [...entries].sort(compareCreated).map((entry) => entry.task);\n }\n return entries.map((entry) => entry.task);\n}\n\nlet tmpFileCounter = 0;\n\nexport function hasErrorCode(error: unknown, code: string): boolean {\n return (\n !!error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n (error as { code?: unknown }).code === code\n );\n}\n\nexport function isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nexport function sortStrings(values: string[]): string[] {\n return [...values].sort((left, right) => left.localeCompare(right));\n}\n\nexport function sortTasks(tasks: Task[]): Task[] {\n return [...tasks].sort((left, right) => left.qualifiedId.localeCompare(right.qualifiedId));\n}\n\nexport function validateTaskId(id: string): string {\n if (\n id.length === 0 ||\n id.startsWith(\".\") ||\n id.includes(\"/\") ||\n id.includes(\"\\\\\") ||\n id.includes(\"..\")\n ) {\n throw new Error(`Invalid task id \"${id}\".`);\n }\n\n return id;\n}\n\nexport async function statIfExists(\n fs: TaskListFs,\n filePath: string\n): Promise<Awaited<ReturnType<TaskListFs[\"stat\"]>> | undefined> {\n try {\n return await fs.stat(filePath);\n } catch (error) {\n if (hasErrorCode(error, \"ENOENT\")) {\n return undefined;\n }\n\n throw error;\n }\n}\n\nexport async function writeAtomically(fs: TaskListFs, filePath: string, content: string): Promise<void> {\n const tempPath = `${filePath}.tmp-${process.pid}-${tmpFileCounter}`;\n tmpFileCounter += 1;\n\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n\n try {\n await fs.writeFile(tempPath, content, { encoding: \"utf8\", flag: \"wx\" });\n await fs.rename(tempPath, filePath);\n } catch (error) {\n try {\n await fs.unlink(tempPath);\n } catch (unlinkError) {\n if (!hasErrorCode(unlinkError, \"ENOENT\")) {\n throw unlinkError;\n }\n }\n\n throw error;\n }\n}\n", "import path from \"node:path\";\nimport { acquireFileLock } from \"@poe-code/file-lock\";\nimport { parseDocument, stringify } from \"yaml\";\nimport taskSchema from \"../schema/task.schema.json\" with { type: \"json\" };\nimport { eventsFromState, findEvent } from \"../state-machine.js\";\nimport { resolveStateMachine } from \"../state.js\";\nimport {\n AnchorNotFoundError,\n InvalidTransitionError,\n MalformedTaskError,\n OrderMismatchError,\n TaskAlreadyExistsError,\n TaskNotFoundError,\n type BackendDeps,\n type ListFilter,\n type MoveAnchor,\n type Task,\n type TaskCreate,\n type TaskFireOptions,\n type TaskList,\n type TaskListFs,\n type Tasks,\n type TaskUpdate\n} from \"../types.js\";\nimport {\n applyOrder,\n hasErrorCode,\n isRecord,\n sortStrings,\n statIfExists,\n validateTaskId,\n writeAtomically,\n type OrderedEntry\n} from \"./utils.js\";\n\nconst ARCHIVE_DIRECTORY_NAME = \"archive\";\nconst MARKDOWN_EXTENSION = \".md\";\nconst TASK_KIND = \"task\";\nconst TASK_VERSION = 1;\nconst TASK_SCHEMA_ID = taskSchema.$id;\nconst ORDER_LOCK_FILENAME = \".order.lock\";\nconst MIN_PREFIX_WIDTH = 2;\nconst RESERVED_FRONTMATTER_KEYS = new Set([\n \"$schema\",\n \"created\",\n \"description\",\n \"kind\",\n \"name\",\n \"state\",\n \"version\"\n]);\nconst PASSTHROUGH_RESERVED_FRONTMATTER_KEYS = new Set([\"description\", \"name\", \"state\"]);\n\ntype TaskRecord = Record<string, unknown>;\n\ntype TaskFile = {\n task: Task;\n frontmatter: TaskRecord;\n path: string;\n};\n\ntype TaskLocation = {\n archived: boolean;\n path: string;\n};\n\ntype ListLayout = { kind: \"multi\" } | { kind: \"single\"; name: string };\n\nfunction resolveListLayout(deps: BackendDeps): ListLayout {\n return deps.singleList ? { kind: \"single\", name: deps.singleList } : { kind: \"multi\" };\n}\n\nfunction validateListName(name: string): string {\n if (\n name.length === 0 ||\n name === ARCHIVE_DIRECTORY_NAME ||\n name.startsWith(\".\") ||\n name.includes(\"/\") ||\n name.includes(\"\\\\\") ||\n name.includes(\"..\")\n ) {\n throw new Error(`Invalid task list name \"${name}\".`);\n }\n\n return name;\n}\n\nfunction parseQualifiedId(qualifiedId: string): {\n id: string;\n list: string;\n} {\n const separatorIndex = qualifiedId.indexOf(\"/\");\n\n if (\n separatorIndex <= 0 ||\n separatorIndex !== qualifiedId.lastIndexOf(\"/\") ||\n separatorIndex === qualifiedId.length - 1\n ) {\n throw new Error(`Invalid qualified task id \"${qualifiedId}\".`);\n }\n\n return {\n list: validateListName(qualifiedId.slice(0, separatorIndex)),\n id: validateTaskId(qualifiedId.slice(separatorIndex + 1))\n };\n}\n\nfunction listPath(rootPath: string, layout: ListLayout, list: string): string {\n return layout.kind === \"single\" ? rootPath : path.join(rootPath, list);\n}\n\nfunction archiveDirectoryPath(rootPath: string, layout: ListLayout, list: string): string {\n return layout.kind === \"single\"\n ? path.join(rootPath, ARCHIVE_DIRECTORY_NAME)\n : path.join(rootPath, list, ARCHIVE_DIRECTORY_NAME);\n}\n\nfunction activeTaskFilename(id: string, order: number, width: number): string {\n return `${String(order).padStart(width, \"0\")}-${id}${MARKDOWN_EXTENSION}`;\n}\n\nfunction archivedTaskPath(rootPath: string, layout: ListLayout, list: string, id: string): string {\n return path.join(archiveDirectoryPath(rootPath, layout, list), `${id}${MARKDOWN_EXTENSION}`);\n}\n\nfunction isMarkdownFile(entryName: string): boolean {\n return entryName.endsWith(MARKDOWN_EXTENSION);\n}\n\nfunction isHiddenEntry(entryName: string): boolean {\n return entryName.startsWith(\".\");\n}\n\nfunction isLockFile(entryName: string): boolean {\n return entryName.endsWith(\".lock\");\n}\n\nfunction isValidTaskIdShape(id: string): boolean {\n return (\n id.length > 0 &&\n !id.startsWith(\".\") &&\n !id.includes(\"/\") &&\n !id.includes(\"\\\\\") &&\n !id.includes(\"..\")\n );\n}\n\nfunction parseActiveFilename(entryName: string): { id: string; order: number | null } | undefined {\n if (!isMarkdownFile(entryName)) return undefined;\n const stem = entryName.slice(0, -MARKDOWN_EXTENSION.length);\n\n const match = /^(\\d+)-(.+)$/.exec(stem);\n if (match) {\n const id = match[2];\n if (isValidTaskIdShape(id)) {\n return { id, order: Number.parseInt(match[1], 10) };\n }\n }\n\n if (isValidTaskIdShape(stem)) {\n return { id: stem, order: null };\n }\n\n return undefined;\n}\n\nfunction padWidthForCount(count: number): number {\n return Math.max(MIN_PREFIX_WIDTH, String(Math.max(count, 1)).length);\n}\n\nfunction malformedTask(filePath: string, field: string): MalformedTaskError {\n return new MalformedTaskError(`Malformed task \"${filePath}\": invalid \"${field}\".`);\n}\n\nfunction stripTrailingCarriageReturn(line: string): string {\n return line.endsWith(\"\\r\") ? line.slice(0, -1) : line;\n}\n\nfunction splitTaskDocument(\n content: string,\n filePath: string,\n mode: BackendDeps[\"frontmatterMode\"]\n): {\n body: string;\n frontmatter: string;\n} {\n const lines = content.split(\"\\n\");\n const hasFrontmatterBlock =\n lines.length > 0 && stripTrailingCarriageReturn(lines[0]) === \"---\";\n\n if (!hasFrontmatterBlock) {\n if (mode === \"passthrough\") {\n return { frontmatter: \"\", body: content };\n }\n throw malformedTask(filePath, \"frontmatter\");\n }\n\n let closingIndex = -1;\n for (let index = 1; index < lines.length; index += 1) {\n if (stripTrailingCarriageReturn(lines[index]) === \"---\") {\n closingIndex = index;\n break;\n }\n }\n\n if (closingIndex === -1) {\n throw malformedTask(filePath, \"frontmatter\");\n }\n\n const bodyLines = lines.slice(closingIndex + 1);\n if (bodyLines.length > 0 && stripTrailingCarriageReturn(bodyLines[0]) === \"\") {\n bodyLines.shift();\n }\n\n return {\n frontmatter: lines.slice(1, closingIndex).join(\"\\n\"),\n body: bodyLines.join(\"\\n\")\n };\n}\n\nfunction readFrontmatter(frontmatterContent: string, filePath: string): TaskRecord {\n const document = parseDocument(frontmatterContent);\n\n if (document.errors.length > 0) {\n throw malformedTask(filePath, \"frontmatter\");\n }\n\n const parsed = document.toJS();\n if (!isRecord(parsed)) {\n throw malformedTask(filePath, \"frontmatter\");\n }\n\n return parsed;\n}\n\nfunction assertValidTaskRecord(\n frontmatter: TaskRecord,\n filePath: string,\n validStates: ReadonlySet<string>\n): void {\n if (\"$schema\" in frontmatter && frontmatter.$schema !== TASK_SCHEMA_ID) {\n throw malformedTask(filePath, \"$schema\");\n }\n\n if (\"kind\" in frontmatter && frontmatter.kind !== TASK_KIND) {\n throw malformedTask(filePath, \"kind\");\n }\n\n if (\"version\" in frontmatter) {\n if (\n typeof frontmatter.version !== \"number\" ||\n !Number.isInteger(frontmatter.version) ||\n frontmatter.version !== TASK_VERSION\n ) {\n throw malformedTask(filePath, \"version\");\n }\n }\n\n if (typeof frontmatter.name !== \"string\" || frontmatter.name.length === 0) {\n throw malformedTask(filePath, \"name\");\n }\n\n if (typeof frontmatter.state !== \"string\" || !validStates.has(frontmatter.state)) {\n throw malformedTask(filePath, \"state\");\n }\n\n if (\"description\" in frontmatter && typeof frontmatter.description !== \"string\") {\n throw malformedTask(filePath, \"description\");\n }\n}\n\nfunction reservedFrontmatterKeys(mode: BackendDeps[\"frontmatterMode\"]): ReadonlySet<string> {\n return mode === \"passthrough\" ? PASSTHROUGH_RESERVED_FRONTMATTER_KEYS : RESERVED_FRONTMATTER_KEYS;\n}\n\nfunction metadataFromFrontmatter(\n frontmatter: TaskRecord,\n mode: BackendDeps[\"frontmatterMode\"]\n): Record<string, unknown> {\n const metadata: Record<string, unknown> = {};\n const reservedKeys = reservedFrontmatterKeys(mode);\n\n for (const [key, value] of Object.entries(frontmatter)) {\n if (!reservedKeys.has(key)) {\n metadata[key] = value;\n }\n }\n\n return metadata;\n}\n\nfunction createTask(\n list: string,\n id: string,\n frontmatter: TaskRecord,\n body: string,\n mode: BackendDeps[\"frontmatterMode\"],\n sourcePath?: string\n): Task {\n return {\n list,\n id,\n qualifiedId: `${list}/${id}`,\n name: frontmatter.name as string,\n state: frontmatter.state as string,\n description: body,\n metadata: metadataFromFrontmatter(frontmatter, mode),\n ...(sourcePath !== undefined && { sourcePath: path.resolve(sourcePath) })\n };\n}\n\nfunction serializeTaskDocument(frontmatter: TaskRecord, description: string): string {\n return `---\\n${stringify(frontmatter)}---\\n\\n${description}`;\n}\n\nasync function readDirectoryNames(fs: TaskListFs, directoryPath: string): Promise<string[]> {\n try {\n return sortStrings(await fs.readdir(directoryPath));\n } catch (error) {\n if (hasErrorCode(error, \"ENOENT\")) {\n return [];\n }\n\n throw error;\n }\n}\n\nasync function ensureRootPath(deps: BackendDeps): Promise<void> {\n if (deps.create) {\n await deps.fs.mkdir(deps.path, { recursive: true });\n return;\n }\n\n await deps.fs.stat(deps.path);\n}\n\nasync function readTaskFile(\n fs: TaskListFs,\n list: string,\n id: string,\n filePath: string,\n validStates: ReadonlySet<string>,\n initialState: string,\n mode: BackendDeps[\"frontmatterMode\"]\n): Promise<TaskFile> {\n const content = await fs.readFile(filePath, \"utf8\");\n const document = splitTaskDocument(content, filePath, mode);\n const frontmatter =\n mode === \"passthrough\" && document.frontmatter.trim().length === 0\n ? {}\n : readFrontmatter(document.frontmatter, filePath);\n\n if (mode !== \"passthrough\") {\n assertValidTaskRecord(frontmatter, filePath, validStates);\n return {\n path: filePath,\n frontmatter,\n task: createTask(list, id, frontmatter, document.body, mode, filePath)\n };\n }\n\n const parsedFilename = parseActiveFilename(path.basename(filePath));\n const defaultName = parsedFilename?.id ?? id;\n const effectiveFrontmatter: TaskRecord = {\n ...frontmatter,\n name: typeof frontmatter.name === \"string\" ? frontmatter.name : defaultName,\n state:\n typeof frontmatter.state === \"string\" && validStates.has(frontmatter.state)\n ? frontmatter.state\n : initialState\n };\n\n return {\n path: filePath,\n frontmatter,\n task: createTask(list, id, effectiveFrontmatter, document.body, mode, filePath)\n };\n}\n\nasync function findActiveTaskFilename(\n fs: TaskListFs,\n listDirectoryPath: string,\n id: string\n): Promise<string | undefined> {\n const entries = await readDirectoryNames(fs, listDirectoryPath);\n for (const entryName of entries) {\n if (isHiddenEntry(entryName) || isLockFile(entryName)) continue;\n const parsed = parseActiveFilename(entryName);\n if (parsed?.id === id) {\n return entryName;\n }\n }\n return undefined;\n}\n\nasync function findTaskLocation(\n fs: TaskListFs,\n rootPath: string,\n layout: ListLayout,\n list: string,\n id: string\n): Promise<TaskLocation | undefined> {\n const listDirectoryPath = listPath(rootPath, layout, list);\n const activeName = await findActiveTaskFilename(fs, listDirectoryPath, id);\n if (activeName) {\n const activePath = path.join(listDirectoryPath, activeName);\n const activeStat = await statIfExists(fs, activePath);\n if (activeStat?.isFile()) {\n return { archived: false, path: activePath };\n }\n }\n\n const archivedPath = archivedTaskPath(rootPath, layout, list, id);\n const archivedStat = await statIfExists(fs, archivedPath);\n if (archivedStat?.isFile()) {\n return { archived: true, path: archivedPath };\n }\n\n return undefined;\n}\n\nasync function readTaskAtLocation(\n fs: TaskListFs,\n rootPath: string,\n layout: ListLayout,\n list: string,\n id: string,\n validStates: ReadonlySet<string>,\n initialState: string,\n mode: BackendDeps[\"frontmatterMode\"]\n): Promise<TaskFile> {\n const location = await findTaskLocation(fs, rootPath, layout, list, id);\n\n if (!location) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n return readTaskFile(fs, list, id, location.path, validStates, initialState, mode);\n}\n\nfunction createdFrontmatter(\n defaults: BackendDeps[\"defaults\"],\n input: TaskCreate,\n initialState: string,\n mode: BackendDeps[\"frontmatterMode\"]\n): TaskRecord {\n const frontmatter: TaskRecord =\n mode !== \"passthrough\"\n ? {\n $schema: TASK_SCHEMA_ID,\n kind: TASK_KIND,\n version: TASK_VERSION,\n name: input.name,\n state: initialState\n }\n : {\n name: input.name,\n state: initialState\n };\n const reservedKeys = reservedFrontmatterKeys(mode);\n\n for (const [key, value] of Object.entries(defaults.metadata)) {\n if (!reservedKeys.has(key)) {\n frontmatter[key] = value;\n }\n }\n\n for (const [key, value] of Object.entries(input.metadata ?? {})) {\n if (!reservedKeys.has(key)) {\n frontmatter[key] = value;\n }\n }\n\n frontmatter.created = new Date().toISOString();\n return frontmatter;\n}\n\nfunction updatedFrontmatter(\n existingFrontmatter: TaskRecord,\n task: Task,\n patch: TaskUpdate,\n mode: BackendDeps[\"frontmatterMode\"]\n): TaskRecord {\n const nextFrontmatter: TaskRecord =\n mode !== \"passthrough\"\n ? {\n ...existingFrontmatter,\n $schema: existingFrontmatter.$schema ?? TASK_SCHEMA_ID,\n kind: existingFrontmatter.kind ?? TASK_KIND,\n version: existingFrontmatter.version ?? TASK_VERSION,\n name: patch.name ?? task.name,\n state: task.state\n }\n : {\n ...existingFrontmatter,\n name: patch.name ?? task.name,\n state: task.state\n };\n const reservedKeys = reservedFrontmatterKeys(mode);\n\n for (const [key, value] of Object.entries(patch.metadata ?? {})) {\n if (!reservedKeys.has(key)) {\n nextFrontmatter[key] = value;\n }\n }\n\n return nextFrontmatter;\n}\n\nfunction transitionedFrontmatter(\n existingFrontmatter: TaskRecord,\n task: Task,\n to: string,\n mode: BackendDeps[\"frontmatterMode\"]\n): TaskRecord {\n return mode !== \"passthrough\"\n ? {\n ...existingFrontmatter,\n $schema: existingFrontmatter.$schema ?? TASK_SCHEMA_ID,\n kind: existingFrontmatter.kind ?? TASK_KIND,\n version: existingFrontmatter.version ?? TASK_VERSION,\n name: task.name,\n state: to\n }\n : {\n ...existingFrontmatter,\n name: task.name,\n state: to\n };\n}\n\nfunction firedFrontmatter(\n existingFrontmatter: TaskRecord,\n task: Task,\n to: string,\n mode: BackendDeps[\"frontmatterMode\"],\n metadataPatch?: Record<string, unknown>\n): TaskRecord {\n const nextFrontmatter = transitionedFrontmatter(existingFrontmatter, task, to, mode);\n const reservedKeys = reservedFrontmatterKeys(mode);\n\n for (const [key, value] of Object.entries(metadataPatch ?? {})) {\n if (!reservedKeys.has(key)) {\n nextFrontmatter[key] = value;\n }\n }\n\n return nextFrontmatter;\n}\n\nfunction assertCreateDoesNotSetState(input: TaskCreate): void {\n if (Object.prototype.hasOwnProperty.call(input, \"state\")) {\n throw new Error(\n 'Tasks.create() does not accept \"state\"; new tasks always start at stateMachine.initial.'\n );\n }\n}\n\nfunction assertCreateHasId(input: TaskCreate): asserts input is TaskCreate & { id: string } {\n if (input.id === undefined) {\n throw new Error(\"id is required for markdown-dir backend\");\n }\n}\n\nfunction assertUpdateDoesNotSetState(patch: TaskUpdate): void {\n if (Object.prototype.hasOwnProperty.call(patch, \"state\")) {\n throw new Error('Tasks.update() does not accept \"state\"; use fire() to change task state.');\n }\n}\n\ninterface ActiveEntry {\n id: string;\n order: number | null;\n filename: string;\n}\n\nfunction createTasksView(deps: BackendDeps, layout: ListLayout, list: string): Tasks {\n const listDirectoryPath = listPath(deps.path, layout, list);\n const stateMachine = resolveStateMachine(deps.stateMachine);\n const validStates = new Set(stateMachine.states);\n\n async function readActiveEntries(): Promise<ActiveEntry[]> {\n const entries = await readDirectoryNames(deps.fs, listDirectoryPath);\n const result: ActiveEntry[] = [];\n\n for (const entryName of entries) {\n if (isHiddenEntry(entryName) || isLockFile(entryName)) continue;\n const parsed = parseActiveFilename(entryName);\n if (!parsed) continue;\n\n const entryPath = path.join(listDirectoryPath, entryName);\n const entryStat = await statIfExists(deps.fs, entryPath);\n if (!entryStat?.isFile()) continue;\n\n result.push({ id: parsed.id, order: parsed.order, filename: entryName });\n }\n\n result.sort((left, right) => {\n const leftOrder = left.order ?? Number.POSITIVE_INFINITY;\n const rightOrder = right.order ?? Number.POSITIVE_INFINITY;\n if (leftOrder !== rightOrder) return leftOrder - rightOrder;\n return left.filename.localeCompare(right.filename);\n });\n\n return result;\n }\n\n async function readActiveTasks(): Promise<{\n entries: ActiveEntry[];\n tasks: Map<string, { task: Task; raw: TaskRecord }>;\n }> {\n const entries = await readActiveEntries();\n const tasks = new Map<string, { task: Task; raw: TaskRecord }>();\n\n for (const entry of entries) {\n const filePath = path.join(listDirectoryPath, entry.filename);\n const file = await readTaskFile(\n deps.fs,\n list,\n entry.id,\n filePath,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n tasks.set(entry.id, { task: file.task, raw: file.frontmatter });\n }\n\n return { entries, tasks };\n }\n\n async function readArchivedTasks(): Promise<{ task: Task; raw: TaskRecord }[]> {\n const archivePath = archiveDirectoryPath(deps.path, layout, list);\n const entries = await readDirectoryNames(deps.fs, archivePath);\n const result: { task: Task; raw: TaskRecord }[] = [];\n\n for (const entryName of entries) {\n if (isHiddenEntry(entryName) || isLockFile(entryName) || !isMarkdownFile(entryName)) continue;\n\n const entryPath = path.join(archivePath, entryName);\n const entryStat = await statIfExists(deps.fs, entryPath);\n if (!entryStat?.isFile()) continue;\n\n const id = entryName.slice(0, -MARKDOWN_EXTENSION.length);\n const file = await readTaskFile(\n deps.fs,\n list,\n id,\n entryPath,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n result.push({ task: file.task, raw: file.frontmatter });\n }\n\n return result.sort((left, right) =>\n left.task.qualifiedId.localeCompare(right.task.qualifiedId)\n );\n }\n\n async function renameActiveEntries(\n entries: ActiveEntry[],\n desiredOrdersById: ReadonlyMap<string, number>\n ): Promise<void> {\n const staged: { from: string; to: string }[] = [];\n const maxOrder = Math.max(...desiredOrdersById.values(), entries.length);\n const width = padWidthForCount(maxOrder);\n\n for (let index = 0; index < entries.length; index += 1) {\n const entry = entries[index];\n const desiredOrder = desiredOrdersById.get(entry.id);\n if (desiredOrder === undefined) continue;\n\n const desiredFilename = activeTaskFilename(entry.id, desiredOrder, width);\n if (entry.filename !== desiredFilename) {\n const fromPath = path.join(listDirectoryPath, entry.filename);\n const stagingPath = path.join(\n listDirectoryPath,\n `${desiredFilename}.staging-${process.pid}-${index}`\n );\n const targetPath = path.join(listDirectoryPath, desiredFilename);\n await deps.fs.rename(fromPath, stagingPath);\n staged.push({ from: stagingPath, to: targetPath });\n }\n }\n\n for (const entry of staged) {\n await deps.fs.rename(entry.from, entry.to);\n }\n }\n\n async function rewriteListPrefixes(orderedIds: readonly string[]): Promise<void> {\n const entries = await readActiveEntries();\n const byId = new Map(entries.map((entry) => [entry.id, entry]));\n const desiredOrdersById = new Map<string, number>();\n\n for (let index = 0; index < orderedIds.length; index += 1) {\n const id = orderedIds[index];\n const entry = byId.get(id);\n if (!entry) continue;\n\n desiredOrdersById.set(id, index + 1);\n }\n\n await renameActiveEntries(entries, desiredOrdersById);\n }\n\n function entryOrder(entry: ActiveEntry, index: number): number {\n return entry.order ?? index + 1;\n }\n\n async function rewriteMovedPrefix(movedId: string, orderedIds: readonly string[]): Promise<void> {\n const entries = await readActiveEntries();\n const byId = new Map(entries.map((entry, index) => [entry.id, { entry, index }]));\n const movedIndex = orderedIds.indexOf(movedId);\n const moved = byId.get(movedId);\n if (movedIndex < 0 || moved === undefined) return;\n\n const desiredOrdersById = new Map<string, number>();\n const previousId = movedIndex > 0 ? orderedIds[movedIndex - 1] : undefined;\n const nextId = movedIndex < orderedIds.length - 1 ? orderedIds[movedIndex + 1] : undefined;\n const previous = previousId === undefined ? undefined : byId.get(previousId);\n const next = nextId === undefined ? undefined : byId.get(nextId);\n\n if (previous !== undefined && next === undefined) {\n desiredOrdersById.set(movedId, entryOrder(previous.entry, previous.index) + 1);\n await renameActiveEntries(entries, desiredOrdersById);\n return;\n }\n\n if (previous === undefined && next !== undefined) {\n const nextOrder = entryOrder(next.entry, next.index);\n if (nextOrder > 1) {\n desiredOrdersById.set(movedId, nextOrder - 1);\n await renameActiveEntries(entries, desiredOrdersById);\n return;\n }\n\n desiredOrdersById.set(movedId, 1);\n let lastOrder = 1;\n for (let index = movedIndex + 1; index < orderedIds.length; index += 1) {\n const candidate = byId.get(orderedIds[index]);\n if (candidate === undefined) continue;\n\n const currentOrder = entryOrder(candidate.entry, candidate.index);\n if (currentOrder > lastOrder) break;\n\n lastOrder += 1;\n desiredOrdersById.set(candidate.entry.id, lastOrder);\n }\n\n await renameActiveEntries(entries, desiredOrdersById);\n return;\n }\n\n if (previous !== undefined && next !== undefined) {\n const previousOrder = entryOrder(previous.entry, previous.index);\n const nextOrder = entryOrder(next.entry, next.index);\n\n if (nextOrder - previousOrder > 1) {\n desiredOrdersById.set(movedId, previousOrder + 1);\n await renameActiveEntries(entries, desiredOrdersById);\n return;\n }\n\n let lastOrder = previousOrder + 1;\n desiredOrdersById.set(movedId, lastOrder);\n for (let index = movedIndex + 1; index < orderedIds.length; index += 1) {\n const candidate = byId.get(orderedIds[index]);\n if (candidate === undefined) continue;\n\n const currentOrder = entryOrder(candidate.entry, candidate.index);\n if (currentOrder > lastOrder) break;\n\n lastOrder += 1;\n desiredOrdersById.set(candidate.entry.id, lastOrder);\n }\n\n await renameActiveEntries(entries, desiredOrdersById);\n }\n }\n\n async function withListLock<T>(action: () => Promise<T>): Promise<T> {\n await deps.fs.mkdir(listDirectoryPath, { recursive: true });\n const release = await acquireFileLock(path.join(listDirectoryPath, ORDER_LOCK_FILENAME), {\n fs: deps.fs,\n staleMs: deps.lockStaleMs,\n retries: deps.lockRetries\n });\n\n try {\n return await action();\n } finally {\n await release();\n }\n }\n\n async function withTaskLock<T>(id: string, action: () => Promise<T>): Promise<T> {\n validateTaskId(id);\n return withListLock(action);\n }\n\n async function withLocatedTaskLock<T>(location: TaskLocation, action: () => Promise<T>) {\n const release = await acquireFileLock(location.path, {\n fs: deps.fs,\n staleMs: deps.lockStaleMs,\n retries: deps.lockRetries\n });\n\n try {\n return await action();\n } finally {\n await release();\n }\n }\n\n async function getTaskFile(id: string): Promise<TaskFile> {\n validateTaskId(id);\n return readTaskAtLocation(\n deps.fs,\n deps.path,\n layout,\n list,\n id,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n }\n\n function assertFireableTaskEvent(task: Task, eventName: string) {\n const event = findEvent(stateMachine, task.state, eventName);\n\n if (event === undefined) {\n throw new InvalidTransitionError({\n task,\n event: eventName,\n to: stateMachine.events[eventName]?.to,\n reason: `Cannot fire event \"${eventName}\" from task state \"${task.state}\".`\n });\n }\n\n return event;\n }\n\n return {\n name: list,\n stateMachine,\n async all(filter?: ListFilter): Promise<Task[]> {\n const { entries: activeEntries, tasks: activeTasks } = await readActiveTasks();\n const archivedEntries = filter?.includeArchived ? await readArchivedTasks() : [];\n\n const orderedActive: OrderedEntry[] = activeEntries\n .map((entry) => activeTasks.get(entry.id)!)\n .filter((entry) => {\n if (filter?.state && entry.task.state !== filter.state) return false;\n return true;\n });\n\n const filteredArchived = archivedEntries.filter((entry) => {\n if (filter?.state && entry.task.state !== filter.state) return false;\n return true;\n });\n\n const orderedActiveTasks = applyOrder(orderedActive, filter?.order);\n return [...orderedActiveTasks, ...filteredArchived.map((entry) => entry.task)];\n },\n async get(id: string): Promise<Task> {\n return (await getTaskFile(id)).task;\n },\n async create(input: TaskCreate): Promise<Task> {\n assertCreateDoesNotSetState(input);\n assertCreateHasId(input);\n validateTaskId(input.id);\n await deps.fs.mkdir(listDirectoryPath, { recursive: true });\n\n return withListLock(async () => {\n const existing = await findTaskLocation(deps.fs, deps.path, layout, list, input.id);\n if (existing) {\n throw new TaskAlreadyExistsError(`Task \"${list}/${input.id}\" already exists.`);\n }\n\n const activeEntries = await readActiveEntries();\n const maxOrder = activeEntries.reduce(\n (max, entry) => (entry.order !== null && entry.order > max ? entry.order : max),\n 0\n );\n const nextOrder = maxOrder + 1;\n const width = padWidthForCount(activeEntries.length + 1);\n const filename = activeTaskFilename(input.id, nextOrder, width);\n const targetPath = path.join(listDirectoryPath, filename);\n\n const frontmatter = createdFrontmatter(\n deps.defaults,\n input,\n stateMachine.initial,\n deps.frontmatterMode\n );\n const description = input.description ?? \"\";\n\n await writeAtomically(deps.fs, targetPath, serializeTaskDocument(frontmatter, description));\n\n return createTask(\n list,\n input.id,\n frontmatter,\n description,\n deps.frontmatterMode,\n targetPath\n );\n });\n },\n async update(id: string, patch: TaskUpdate): Promise<Task> {\n assertUpdateDoesNotSetState(patch);\n\n return withTaskLock(id, async () => {\n const existing = await getTaskFile(id);\n const nextFrontmatter = updatedFrontmatter(\n existing.frontmatter,\n existing.task,\n patch,\n deps.frontmatterMode\n );\n const description = patch.description ?? existing.task.description;\n\n await writeAtomically(\n deps.fs,\n existing.path,\n serializeTaskDocument(nextFrontmatter, description)\n );\n\n return createTask(\n list,\n id,\n nextFrontmatter,\n description,\n deps.frontmatterMode,\n existing.path\n );\n });\n },\n async fire(id: string, eventName: string, opts?: TaskFireOptions): Promise<Task> {\n const fireTask = async (): Promise<Task> => {\n const existing = await getTaskFile(id);\n const event = assertFireableTaskEvent(existing.task, eventName);\n const guardResult = event.guard?.(existing.task) ?? true;\n\n if (guardResult !== true) {\n throw new InvalidTransitionError({\n task: existing.task,\n event: eventName,\n to: event.to,\n reason: guardResult\n });\n }\n\n await event.onExit?.(existing.task);\n\n const nextFrontmatter = firedFrontmatter(\n existing.frontmatter,\n existing.task,\n event.to,\n deps.frontmatterMode,\n opts?.metadataPatch\n );\n const serializedTask = serializeTaskDocument(nextFrontmatter, existing.task.description);\n\n if (event.to === \"archived\") {\n const targetPath = archivedTaskPath(deps.path, layout, list, id);\n const archivedTargetExists = await statIfExists(deps.fs, targetPath);\n if (archivedTargetExists?.isFile()) {\n throw new TaskAlreadyExistsError(`Task \"${list}/${id}\" already exists in archive.`);\n }\n\n await writeAtomically(deps.fs, existing.path, serializedTask);\n await deps.fs.mkdir(archiveDirectoryPath(deps.path, layout, list), { recursive: true });\n await deps.fs.rename(existing.path, targetPath);\n const nextTask = createTask(\n list,\n id,\n nextFrontmatter,\n existing.task.description,\n deps.frontmatterMode,\n targetPath\n );\n await event.onEnter?.(nextTask);\n\n return nextTask;\n }\n\n await writeAtomically(deps.fs, existing.path, serializedTask);\n const nextTask = createTask(\n list,\n id,\n nextFrontmatter,\n existing.task.description,\n deps.frontmatterMode,\n existing.path\n );\n await event.onEnter?.(nextTask);\n\n return nextTask;\n };\n\n if (stateMachine.events[eventName]?.to === \"archived\") {\n validateTaskId(id);\n\n return withListLock(async () => {\n const location = await findTaskLocation(deps.fs, deps.path, layout, list, id);\n if (!location) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n return withLocatedTaskLock(location, fireTask);\n });\n }\n\n return withTaskLock(id, fireTask);\n },\n async canFire(id: string, eventName: string): Promise<boolean> {\n const task = (await getTaskFile(id)).task;\n const event = findEvent(stateMachine, task.state, eventName);\n\n if (event === undefined) {\n return false;\n }\n\n return (event.guard?.(task) ?? true) === true;\n },\n async events(id: string): Promise<readonly string[]> {\n const task = (await getTaskFile(id)).task;\n return eventsFromState(stateMachine, task.state);\n },\n async delete(id: string): Promise<void> {\n await withTaskLock(id, async () => {\n const location = await findTaskLocation(deps.fs, deps.path, layout, list, id);\n if (!location) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n await deps.fs.unlink(location.path);\n });\n },\n async move(id: string, anchor: MoveAnchor): Promise<Task> {\n validateTaskId(id);\n\n return withListLock(async () => {\n const { entries } = await readActiveTasks();\n const fromIndex = entries.findIndex((entry) => entry.id === id);\n if (fromIndex < 0) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n const ordered = entries.map((entry) => entry.id);\n ordered.splice(fromIndex, 1);\n\n let insertIndex: number;\n if (\"position\" in anchor) {\n insertIndex = anchor.position === \"top\" ? 0 : ordered.length;\n } else {\n const anchorId = \"before\" in anchor ? anchor.before : anchor.after;\n const anchorIndex = ordered.indexOf(anchorId);\n if (anchorIndex < 0) {\n throw new AnchorNotFoundError(anchorId);\n }\n insertIndex = \"before\" in anchor ? anchorIndex : anchorIndex + 1;\n }\n\n ordered.splice(insertIndex, 0, id);\n await rewriteMovedPrefix(id, ordered);\n\n return (await getTaskFile(id)).task;\n });\n },\n async reorder(ids: readonly string[]): Promise<readonly Task[]> {\n for (const id of ids) {\n validateTaskId(id);\n }\n\n return withListLock(async () => {\n const { entries } = await readActiveTasks();\n const currentIds = entries.map((entry) => entry.id);\n const currentSet = new Set(currentIds);\n const inputSet = new Set(ids);\n const missing = currentIds.filter((id) => !inputSet.has(id));\n const extra = ids.filter((id) => !currentSet.has(id));\n\n if (missing.length > 0 || extra.length > 0) {\n throw new OrderMismatchError({ missing, extra });\n }\n\n await rewriteListPrefixes(ids);\n\n return Promise.all(ids.map(async (id) => (await getTaskFile(id)).task));\n });\n }\n };\n}\n\nexport async function markdownDirBackend(deps: BackendDeps): Promise<TaskList> {\n await ensureRootPath(deps);\n const layout = resolveListLayout(deps);\n const stateMachine = resolveStateMachine(deps.stateMachine);\n const validStates = new Set(stateMachine.states);\n\n const list = (name: string): Tasks => {\n if (layout.kind === \"single\") {\n if (name !== layout.name) {\n throw new Error(`Task list \"${name}\" not found.`);\n }\n\n return createTasksView(deps, layout, name);\n }\n\n const listName = validateListName(name);\n return createTasksView(deps, layout, listName);\n };\n\n const lists = async (): Promise<string[]> => {\n if (layout.kind === \"single\") {\n return [layout.name];\n }\n\n const entries = await readDirectoryNames(deps.fs, deps.path);\n const result: string[] = [];\n\n for (const entryName of entries) {\n if (\n entryName === ARCHIVE_DIRECTORY_NAME ||\n isHiddenEntry(entryName) ||\n isLockFile(entryName)\n ) {\n continue;\n }\n\n const entryPath = path.join(deps.path, entryName);\n const entryStat = await statIfExists(deps.fs, entryPath);\n if (entryStat?.isDirectory()) {\n result.push(entryName);\n }\n }\n\n return sortStrings(result);\n };\n\n const allTasks = async (filter?: ListFilter): Promise<Task[]> => {\n const allLists = await lists();\n const tasks: Task[] = [];\n\n for (const taskListName of allLists) {\n tasks.push(...(await list(taskListName).all(filter)));\n }\n\n return tasks;\n };\n\n const get = async (qualifiedId: string): Promise<Task> => {\n const { list: listName, id } = parseQualifiedId(qualifiedId);\n return list(listName).get(id);\n };\n\n const moveBetweenLists = async (qualifiedId: string, targetList: string): Promise<Task> => {\n if (layout.kind === \"single\") {\n throw new Error(\"moveBetweenLists is unsupported in single-list mode.\");\n }\n\n const { list: sourceListName, id } = parseQualifiedId(qualifiedId);\n const targetListName = validateListName(targetList);\n\n if (sourceListName === targetListName) {\n const file = await readTaskAtLocation(\n deps.fs,\n deps.path,\n layout,\n sourceListName,\n id,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n return file.task;\n }\n\n const targetExisting = await findTaskLocation(deps.fs, deps.path, layout, targetListName, id);\n if (targetExisting) {\n throw new TaskAlreadyExistsError(`Task \"${targetListName}/${id}\" already exists.`);\n }\n\n const sourceLocation = await findTaskLocation(deps.fs, deps.path, layout, sourceListName, id);\n if (!sourceLocation) {\n throw new TaskNotFoundError(`Task \"${sourceListName}/${id}\" not found.`);\n }\n\n const targetListDir = listPath(deps.path, layout, targetListName);\n await deps.fs.mkdir(targetListDir, { recursive: true });\n\n const targetEntries = await (async () => {\n const out: ActiveEntry[] = [];\n const names = await readDirectoryNames(deps.fs, targetListDir);\n for (const entryName of names) {\n if (isHiddenEntry(entryName) || isLockFile(entryName)) continue;\n const parsed = parseActiveFilename(entryName);\n if (!parsed) continue;\n out.push({ id: parsed.id, order: parsed.order, filename: entryName });\n }\n return out;\n })();\n\n if (sourceLocation.archived) {\n const archivedTargetDir = archiveDirectoryPath(deps.path, layout, targetListName);\n await deps.fs.mkdir(archivedTargetDir, { recursive: true });\n const archivedTargetPath = archivedTaskPath(deps.path, layout, targetListName, id);\n await deps.fs.rename(sourceLocation.path, archivedTargetPath);\n const file = await readTaskFile(\n deps.fs,\n targetListName,\n id,\n archivedTargetPath,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n return file.task;\n }\n\n const maxOrder = targetEntries.reduce(\n (max, entry) => (entry.order !== null && entry.order > max ? entry.order : max),\n 0\n );\n const width = padWidthForCount(targetEntries.length + 1);\n const targetFilename = activeTaskFilename(id, maxOrder + 1, width);\n const targetPath = path.join(targetListDir, targetFilename);\n\n await deps.fs.rename(sourceLocation.path, targetPath);\n const file = await readTaskFile(\n deps.fs,\n targetListName,\n id,\n targetPath,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n return file.task;\n };\n\n return {\n list,\n lists,\n allTasks,\n get,\n moveBetweenLists\n };\n}\n", "import * as fsPromises from \"node:fs/promises\";\nimport * as os from \"node:os\";\n\nexport interface FileLockFs {\n open(path: string, flags: string): Promise<{\n close(): Promise<void>;\n writeFile(\n data: string,\n options?: BufferEncoding | { encoding?: BufferEncoding }\n ): Promise<void>;\n }>;\n stat(path: string): Promise<{\n mtimeMs: number;\n }>;\n readFile?(path: string, encoding: BufferEncoding): Promise<string>;\n unlink(path: string): Promise<void>;\n}\n\nexport interface FileLockOptions {\n staleMs?: number;\n retries?: number;\n minTimeout?: number;\n maxTimeout?: number;\n fs?: FileLockFs;\n isPidRunning?: (pid: number) => boolean;\n signal?: AbortSignal;\n}\n\nexport type ReleaseLock = () => Promise<void>;\n\nexport class LockTimeoutError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"LockTimeoutError\";\n }\n}\n\nfunction createAbortError(): Error {\n const error = new Error(\"The operation was aborted.\");\n error.name = \"AbortError\";\n return error;\n}\n\nfunction throwIfAborted(signal?: AbortSignal): void {\n if (signal?.aborted) {\n throw createAbortError();\n }\n}\n\nfunction sleep(ms: number, signal?: AbortSignal): Promise<void> {\n if (!signal) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n\n if (signal.aborted) {\n return Promise.reject(createAbortError());\n }\n\n return new Promise((resolve, reject) => {\n const timeoutId = setTimeout(() => {\n signal.removeEventListener(\"abort\", onAbort);\n resolve();\n }, ms);\n\n const onAbort = () => {\n clearTimeout(timeoutId);\n signal.removeEventListener(\"abort\", onAbort);\n reject(createAbortError());\n };\n\n signal.addEventListener(\"abort\", onAbort, { once: true });\n });\n}\n\nfunction backoff(attempt: number, minTimeout: number, maxTimeout: number): number {\n const delay = Math.min(maxTimeout, minTimeout * 2 ** attempt);\n return delay + Math.random() * delay * 0.1;\n}\n\nfunction hasErrorCode(error: unknown, code: string): boolean {\n return (\n !!error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n (error as { code?: unknown }).code === code\n );\n}\n\nfunction hasAnyErrorCode(error: unknown, codes: readonly string[]): boolean {\n return codes.some((code) => hasErrorCode(error, code));\n}\n\nfunction isPidRunning(pid: number): boolean {\n try {\n process.kill(pid, 0);\n return true;\n } catch (error) {\n return !hasErrorCode(error, \"ESRCH\");\n }\n}\n\nfunction createDefaultFs(): FileLockFs {\n return {\n open: (path, flags) => fsPromises.open(path, flags),\n readFile: (path, encoding) => fsPromises.readFile(path, encoding),\n stat: fsPromises.stat,\n unlink: fsPromises.unlink\n };\n}\n\nasync function removeLockFile(\n fs: FileLockFs,\n lockPath: string,\n signal?: AbortSignal\n): Promise<void> {\n for (let attempt = 0; attempt <= 4; attempt += 1) {\n throwIfAborted(signal);\n\n try {\n await fs.unlink(lockPath);\n return;\n } catch (error) {\n if (hasErrorCode(error, \"ENOENT\")) {\n return;\n }\n\n if (!hasAnyErrorCode(error, [\"EPERM\", \"EBUSY\"]) || attempt === 4) {\n throw error;\n }\n }\n\n await sleep(25 * 2 ** attempt, signal);\n }\n}\n\ntype LockMetadata = {\n host: string;\n pid: number;\n};\n\nfunction parseLockMetadata(content: string): LockMetadata | undefined {\n try {\n const parsed = JSON.parse(content) as unknown;\n if (!parsed || typeof parsed !== \"object\" || !(\"host\" in parsed) || !(\"pid\" in parsed)) {\n return undefined;\n }\n\n const { host, pid } = parsed;\n if (typeof host === \"string\" && typeof pid === \"number\" && Number.isSafeInteger(pid) && pid > 0) {\n return {\n host,\n pid\n };\n }\n } catch (ignoredError) {\n void ignoredError;\n }\n\n return undefined;\n}\n\nasync function readLockMetadata(\n fs: FileLockFs,\n lockPath: string\n): Promise<LockMetadata | undefined | null> {\n if (!fs.readFile) {\n return undefined;\n }\n\n try {\n return parseLockMetadata(await fs.readFile(lockPath, \"utf8\"));\n } catch (error) {\n if (hasErrorCode(error, \"ENOENT\")) {\n return null;\n }\n\n return undefined;\n }\n}\n\nasync function shouldReclaimLock(options: {\n fs: FileLockFs;\n isPidRunning: (pid: number) => boolean;\n lockPath: string;\n staleMs: number;\n stat: Awaited<ReturnType<FileLockFs[\"stat\"]>>;\n}): Promise<boolean | \"missing\"> {\n const metadata = await readLockMetadata(options.fs, options.lockPath);\n if (metadata === null) {\n return \"missing\";\n }\n\n if (metadata?.host === os.hostname()) {\n return !options.isPidRunning(metadata.pid);\n }\n\n return Date.now() - options.stat.mtimeMs > options.staleMs;\n}\n\nasync function writeLockMetadata(handle: Awaited<ReturnType<FileLockFs[\"open\"]>>): Promise<void> {\n try {\n await handle.writeFile(\n JSON.stringify({ pid: process.pid, host: os.hostname(), acquiredAt: new Date().toISOString() }),\n { encoding: \"utf8\" }\n );\n } catch (ignoredError) {\n void ignoredError;\n }\n try {\n await handle.close();\n } catch (ignoredError) {\n void ignoredError;\n }\n}\n\nexport async function acquireFileLock(\n filePath: string,\n options: FileLockOptions = {}\n): Promise<ReleaseLock> {\n const fs = options.fs ?? createDefaultFs();\n const retries = options.retries ?? 20;\n const minTimeout = options.minTimeout ?? 25;\n const maxTimeout = options.maxTimeout ?? 250;\n const staleMs = options.staleMs ?? 1_000;\n const pidIsRunning = options.isPidRunning ?? isPidRunning;\n const lockPath = `${filePath}.lock`;\n\n let attempt = 0;\n\n while (attempt <= retries) {\n throwIfAborted(options.signal);\n\n try {\n const handle = await fs.open(lockPath, \"wx\");\n await writeLockMetadata(handle);\n let released = false;\n\n return async () => {\n if (released) {\n return;\n }\n\n released = true;\n await removeLockFile(fs, lockPath, options.signal);\n };\n } catch (error) {\n if (!hasErrorCode(error, \"EEXIST\")) {\n throw error;\n }\n }\n\n let stat: Awaited<ReturnType<FileLockFs[\"stat\"]>>;\n try {\n stat = await fs.stat(lockPath);\n } catch (statError) {\n if (hasErrorCode(statError, \"ENOENT\")) {\n continue;\n }\n\n throw statError;\n }\n\n const reclaimLock = await shouldReclaimLock({\n fs,\n isPidRunning: pidIsRunning,\n lockPath,\n staleMs,\n stat\n });\n if (reclaimLock === \"missing\") {\n continue;\n }\n\n if (reclaimLock) {\n await removeLockFile(fs, lockPath, options.signal);\n continue;\n }\n\n if (attempt >= retries) {\n break;\n }\n\n await sleep(backoff(attempt, minTimeout, maxTimeout), options.signal);\n attempt += 1;\n }\n\n throw new LockTimeoutError(`Failed to acquire lock on \"${filePath}\".`);\n}\n", "{\n \"$schema\": \"https://json-schema.org/draft/2020-12/schema\",\n \"$id\": \"https://poe-platform.github.io/poe-code/schemas/task-list/task.schema.json\",\n \"title\": \"Task\",\n \"description\": \"Persisted task payload used by task-list backends.\",\n \"type\": \"object\",\n \"properties\": {\n \"$schema\": {\n \"type\": \"string\",\n \"const\": \"https://poe-platform.github.io/poe-code/schemas/task-list/task.schema.json\"\n },\n \"kind\": {\n \"type\": \"string\",\n \"const\": \"task\"\n },\n \"version\": {\n \"type\": \"integer\",\n \"const\": 1\n },\n \"name\": {\n \"type\": \"string\",\n \"minLength\": 1\n },\n \"state\": {\n \"type\": \"string\"\n },\n \"description\": {\n \"type\": \"string\"\n }\n },\n \"required\": [\"name\", \"state\"],\n \"additionalProperties\": true\n}\n", "import {\n findEvent,\n type EventDef,\n type StateMachineDef\n} from \"./state-machine.js\";\nimport { InvalidTransitionError, type TaskState } from \"./types.js\";\n\nexport type TaskEvent = \"plan\" | \"start\" | \"complete\" | \"archive\";\n\nexport const defaultStateMachine = {\n initial: \"draft\",\n states: [\"draft\", \"planned\", \"in-progress\", \"done\", \"archived\"],\n events: {\n plan: { from: [\"draft\"], to: \"planned\" },\n start: { from: [\"planned\"], to: \"in-progress\" },\n complete: { from: [\"in-progress\"], to: \"done\" },\n archive: { from: \"*\", to: \"archived\" }\n }\n} as const satisfies StateMachineDef<TaskState, TaskEvent>;\n\nfunction deriveLegacyTransitions(\n machine: typeof defaultStateMachine\n): Readonly<Record<TaskState, ReadonlySet<TaskState>>> {\n const transitions = Object.fromEntries(\n machine.states.map((state) => [state, new Set<TaskState>()])\n ) as Record<TaskState, Set<TaskState>>;\n\n for (const fromState of machine.states) {\n for (const eventName of Object.keys(machine.events) as TaskEvent[]) {\n const event = findEvent(machine, fromState, eventName);\n\n if (event !== undefined) {\n transitions[fromState].add(event.to);\n }\n }\n }\n\n const terminalState = machine.events.archive.to;\n const activeStates = machine.states.filter((state) => state !== terminalState);\n\n for (let index = 1; index < activeStates.length; index += 1) {\n transitions[activeStates[index]].add(activeStates[index - 1]);\n }\n\n return transitions;\n}\n\nconst defaultTransitions = deriveLegacyTransitions(defaultStateMachine);\n\nexport function resolveStateMachine(\n stateMachine?: StateMachineDef\n): StateMachineDef {\n return stateMachine ?? defaultStateMachine;\n}\n\nexport function assertEvent<TState extends string, TEvent extends string>(\n machine: StateMachineDef<TState, TEvent>,\n fromState: TState,\n eventName: TEvent\n): EventDef<TState> {\n const event = findEvent(machine, fromState, eventName);\n\n if (event === undefined) {\n throw new InvalidTransitionError(\n `Cannot fire event \"${eventName}\" from task state \"${fromState}\".`\n );\n }\n\n return event;\n}\n\nfunction canTransition(\n machine: StateMachineDef,\n fromState: string,\n toState: string\n): boolean {\n if (Object.is(machine, defaultStateMachine)) {\n return defaultTransitions[fromState as TaskState]?.has(toState as TaskState) ?? false;\n }\n\n for (const eventName of Object.keys(machine.events)) {\n if (findEvent(machine, fromState, eventName)?.to === toState) {\n return true;\n }\n }\n\n return false;\n}\n\nexport function assertTransition(from: TaskState, to: TaskState): void;\nexport function assertTransition<TState extends string, TEvent extends string>(\n machine: StateMachineDef<TState, TEvent>,\n from: TState,\n to: TState\n): void;\nexport function assertTransition<TState extends string, TEvent extends string>(\n machineOrFrom: StateMachineDef<TState, TEvent> | TaskState,\n fromOrTo: TState | TaskState,\n maybeTo?: TState\n): void {\n const machine =\n maybeTo === undefined\n ? defaultStateMachine\n : (machineOrFrom as StateMachineDef<TState, TEvent>);\n const fromState = maybeTo === undefined ? (machineOrFrom as TaskState) : (fromOrTo as TState);\n const toState = maybeTo === undefined ? (fromOrTo as TaskState) : maybeTo;\n\n if (!canTransition(machine, fromState, toState)) {\n throw new InvalidTransitionError(\n `Cannot transition task from \"${fromState}\" to \"${toState}\".`\n );\n }\n}\n", "import path from \"node:path\";\nimport { acquireFileLock } from \"@poe-code/file-lock\";\nimport { isMap, parseDocument, type Document, type YAMLMap } from \"yaml\";\nimport storeSchema from \"../schema/store.schema.json\" with { type: \"json\" };\nimport taskSchema from \"../schema/task.schema.json\" with { type: \"json\" };\nimport { eventsFromState, findEvent } from \"../state-machine.js\";\nimport { resolveStateMachine } from \"../state.js\";\nimport {\n AnchorNotFoundError,\n InvalidTransitionError,\n MalformedTaskError,\n OrderMismatchError,\n TaskAlreadyExistsError,\n TaskNotFoundError,\n type BackendDeps,\n type ListFilter,\n type MoveAnchor,\n type Task,\n type TaskCreate,\n type TaskFireOptions,\n type TaskList,\n type TaskListFs,\n type Tasks,\n type TaskUpdate\n} from \"../types.js\";\nimport {\n applyOrder,\n isRecord,\n sortStrings,\n statIfExists,\n validateTaskId,\n writeAtomically,\n type OrderedEntry\n} from \"./utils.js\";\n\nconst STORE_KIND = \"task-store\";\nconst STORE_SCHEMA_ID = storeSchema.$id;\nconst STORE_VERSION = 1;\nconst TASK_KIND = \"task\";\nconst TASK_SCHEMA_ID = taskSchema.$id;\nconst TASK_VERSION = 1;\nconst RESERVED_TASK_KEYS = new Set([\n \"$schema\",\n \"created\",\n \"description\",\n \"kind\",\n \"name\",\n \"state\",\n \"version\"\n]);\n\ntype StoreRecord = Record<string, unknown>;\ntype TaskRecord = Record<string, unknown>;\n\nfunction malformedStore(filePath: string, field: string): MalformedTaskError {\n return new MalformedTaskError(`Malformed task store \"${filePath}\": invalid \"${field}\".`);\n}\n\nfunction malformedTask(list: string, id: string, field: string): MalformedTaskError {\n return new MalformedTaskError(`Malformed task \"${list}/${id}\": invalid \"${field}\".`);\n}\n\nfunction validateListName(name: string): string {\n if (\n name.length === 0 ||\n name.startsWith(\".\") ||\n name.includes(\"/\") ||\n name.includes(\"\\\\\") ||\n name.includes(\"..\")\n ) {\n throw new Error(`Invalid task list name \"${name}\".`);\n }\n\n return name;\n}\n\nfunction parseQualifiedId(qualifiedId: string): {\n id: string;\n list: string;\n} {\n const separatorIndex = qualifiedId.indexOf(\"/\");\n\n if (\n separatorIndex <= 0 ||\n separatorIndex !== qualifiedId.lastIndexOf(\"/\") ||\n separatorIndex === qualifiedId.length - 1\n ) {\n throw new Error(`Invalid qualified task id \"${qualifiedId}\".`);\n }\n\n return {\n list: validateListName(qualifiedId.slice(0, separatorIndex)),\n id: validateTaskId(qualifiedId.slice(separatorIndex + 1))\n };\n}\n\nfunction descriptionFromTaskRecord(taskRecord: TaskRecord): string {\n return typeof taskRecord.description === \"string\" ? taskRecord.description : \"\";\n}\n\nfunction metadataFromTaskRecord(taskRecord: TaskRecord): Record<string, unknown> {\n const metadata: Record<string, unknown> = {};\n\n for (const [key, value] of Object.entries(taskRecord)) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n metadata[key] = value;\n }\n }\n\n return metadata;\n}\n\nfunction createTask(list: string, id: string, taskRecord: TaskRecord, sourcePath?: string): Task {\n return {\n list,\n id,\n qualifiedId: `${list}/${id}`,\n name: taskRecord.name as string,\n state: taskRecord.state as string,\n description: descriptionFromTaskRecord(taskRecord),\n metadata: metadataFromTaskRecord(taskRecord),\n ...(sourcePath !== undefined && { sourcePath: path.resolve(sourcePath) })\n };\n}\n\nfunction matchesFilter(task: Task, filter?: ListFilter): boolean {\n if (!filter?.includeArchived && task.state === \"archived\") {\n return false;\n }\n\n if (filter?.state !== undefined && task.state !== filter.state) {\n return false;\n }\n\n return true;\n}\n\nfunction createTaskRecord(\n defaults: BackendDeps[\"defaults\"],\n input: TaskCreate,\n initialState: string\n): TaskRecord {\n const taskRecord: TaskRecord = {\n name: input.name,\n state: initialState,\n description: input.description ?? \"\"\n };\n\n for (const [key, value] of Object.entries(defaults.metadata)) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n taskRecord[key] = value;\n }\n }\n\n for (const [key, value] of Object.entries(input.metadata ?? {})) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n taskRecord[key] = value;\n }\n }\n\n taskRecord.created = new Date().toISOString();\n return taskRecord;\n}\n\nfunction assertCreateDoesNotSetState(input: TaskCreate): void {\n if (Object.prototype.hasOwnProperty.call(input, \"state\")) {\n throw new Error(\n 'Tasks.create() does not accept \"state\"; new tasks always start at stateMachine.initial.'\n );\n }\n}\n\nfunction assertCreateHasId(input: TaskCreate): asserts input is TaskCreate & { id: string } {\n if (input.id === undefined) {\n throw new Error(\"id is required for yaml-file backend\");\n }\n}\n\nfunction assertUpdateDoesNotSetState(patch: TaskUpdate): void {\n if (Object.prototype.hasOwnProperty.call(patch, \"state\")) {\n throw new Error('Tasks.update() does not accept \"state\"; use fire() to change task state.');\n }\n}\n\nfunction buildUpdatedTaskRecord(existing: TaskRecord, patch: TaskUpdate): TaskRecord {\n const nextTaskRecord: TaskRecord = {\n ...existing,\n name: patch.name ?? existing.name,\n state: existing.state,\n description: patch.description ?? descriptionFromTaskRecord(existing)\n };\n\n for (const [key, value] of Object.entries(patch.metadata ?? {})) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n nextTaskRecord[key] = value;\n }\n }\n\n return nextTaskRecord;\n}\n\nfunction buildTransitionedTaskRecord(existing: TaskRecord, to: string): TaskRecord {\n return {\n ...existing,\n state: to,\n description: descriptionFromTaskRecord(existing)\n };\n}\n\nfunction buildFiredTaskRecord(\n existing: TaskRecord,\n to: string,\n metadataPatch?: Record<string, unknown>\n): TaskRecord {\n const nextTaskRecord = buildTransitionedTaskRecord(existing, to);\n\n for (const [key, value] of Object.entries(metadataPatch ?? {})) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n nextTaskRecord[key] = value;\n }\n }\n\n return nextTaskRecord;\n}\n\nfunction parseStoreDocument(filePath: string, content: string) {\n let document;\n\n try {\n document = parseDocument(content, { keepSourceTokens: true, prettyErrors: false });\n } catch {\n throw malformedStore(filePath, \"yaml\");\n }\n\n if (document.errors.length > 0) {\n throw malformedStore(filePath, \"yaml\");\n }\n\n return document;\n}\n\nfunction assertValidStoreRecord(store: unknown, filePath: string): asserts store is StoreRecord {\n if (!isRecord(store)) {\n throw malformedStore(filePath, \"store\");\n }\n\n if (store.$schema !== STORE_SCHEMA_ID) {\n throw malformedStore(filePath, \"$schema\");\n }\n\n if (store.kind !== STORE_KIND) {\n throw malformedStore(filePath, \"kind\");\n }\n\n if (typeof store.version !== \"number\" || !Number.isInteger(store.version) || store.version !== STORE_VERSION) {\n throw malformedStore(filePath, \"version\");\n }\n\n if (!isRecord(store.lists)) {\n throw malformedStore(filePath, \"lists\");\n }\n}\n\nfunction assertValidTaskRecord(\n taskRecord: unknown,\n list: string,\n id: string,\n validStates: ReadonlySet<string>\n): asserts taskRecord is TaskRecord {\n if (!isRecord(taskRecord)) {\n throw malformedTask(list, id, \"task\");\n }\n\n if (\"$schema\" in taskRecord && taskRecord.$schema !== TASK_SCHEMA_ID) {\n throw malformedTask(list, id, \"$schema\");\n }\n\n if (\"kind\" in taskRecord && taskRecord.kind !== TASK_KIND) {\n throw malformedTask(list, id, \"kind\");\n }\n\n if (\"version\" in taskRecord) {\n if (\n typeof taskRecord.version !== \"number\" ||\n !Number.isInteger(taskRecord.version) ||\n taskRecord.version !== TASK_VERSION\n ) {\n throw malformedTask(list, id, \"version\");\n }\n }\n\n if (typeof taskRecord.name !== \"string\" || taskRecord.name.length === 0) {\n throw malformedTask(list, id, \"name\");\n }\n\n if (typeof taskRecord.state !== \"string\" || !validStates.has(taskRecord.state)) {\n throw malformedTask(list, id, \"state\");\n }\n\n if (\"description\" in taskRecord && typeof taskRecord.description !== \"string\") {\n throw malformedTask(list, id, \"description\");\n }\n}\n\nfunction validateStoreEntries(\n store: StoreRecord,\n filePath: string,\n validStates: ReadonlySet<string>\n): void {\n const lists = store.lists;\n\n if (!isRecord(lists)) {\n throw malformedStore(filePath, \"lists\");\n }\n\n for (const [list, listRecord] of Object.entries(lists)) {\n try {\n validateListName(list);\n } catch {\n throw malformedStore(filePath, `lists.${list}`);\n }\n\n if (!isRecord(listRecord)) {\n throw malformedStore(filePath, `lists.${list}`);\n }\n\n for (const [id, taskRecord] of Object.entries(listRecord)) {\n try {\n validateTaskId(id);\n } catch {\n throw malformedTask(list, id, \"id\");\n }\n\n assertValidTaskRecord(taskRecord, list, id, validStates);\n }\n }\n}\n\nfunction serializeDocument(document: { toString(): string }): string {\n const serialized = document.toString();\n return serialized.endsWith(\"\\n\") ? serialized : `${serialized}\\n`;\n}\n\nasync function readStore(\n fs: TaskListFs,\n filePath: string,\n validStates: ReadonlySet<string>\n): Promise<{\n document: ReturnType<typeof parseStoreDocument>;\n store: StoreRecord;\n}> {\n const content = await fs.readFile(filePath, \"utf8\");\n const document = parseStoreDocument(filePath, content);\n const store = document.toJS();\n\n assertValidStoreRecord(store, filePath);\n validateStoreEntries(store, filePath, validStates);\n\n return {\n document,\n store\n };\n}\n\nfunction getListsRecord(store: StoreRecord): Record<string, unknown> {\n return store.lists as Record<string, unknown>;\n}\n\nfunction getListRecord(store: StoreRecord, list: string): Record<string, unknown> | undefined {\n const listRecord = getListsRecord(store)[list];\n return isRecord(listRecord) ? listRecord : undefined;\n}\n\nfunction getTaskRecord(store: StoreRecord, list: string, id: string): TaskRecord | undefined {\n const listRecord = getListRecord(store, list);\n const taskRecord = listRecord?.[id];\n\n return isRecord(taskRecord) ? taskRecord : undefined;\n}\n\nfunction getTaskOrThrow(store: StoreRecord, list: string, id: string): TaskRecord {\n const taskRecord = getTaskRecord(store, list, id);\n\n if (!taskRecord) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n return taskRecord;\n}\n\nfunction getListNode(document: Document, list: string): YAMLMap | undefined {\n const lists = document.get(\"lists\");\n if (!isMap(lists)) {\n return undefined;\n }\n\n const listNode = lists.get(list);\n if (!isMap(listNode)) {\n return undefined;\n }\n\n return listNode;\n}\n\nfunction pairKey(pair: { key: unknown }): string | undefined {\n const key = pair.key;\n if (typeof key === \"string\") {\n return key;\n }\n if (key && typeof key === \"object\" && \"value\" in key && typeof (key as { value: unknown }).value === \"string\") {\n return (key as { value: string }).value;\n }\n return undefined;\n}\n\nfunction findItemIndex(listNode: YAMLMap, id: string): number {\n return listNode.items.findIndex((pair) => pairKey(pair) === id);\n}\n\nfunction activeItemIds(listNode: YAMLMap, validStates: ReadonlySet<string>): string[] {\n const ids: string[] = [];\n for (const pair of listNode.items) {\n const id = pairKey(pair);\n if (id === undefined) continue;\n\n const value = pair.value;\n let state: unknown;\n if (value && typeof value === \"object\" && \"get\" in value && typeof (value as { get: unknown }).get === \"function\") {\n state = (value as YAMLMap).get(\"state\");\n } else if (isRecord(value)) {\n state = value.state;\n }\n\n if (typeof state === \"string\" && validStates.has(state) && state !== \"archived\") {\n ids.push(id);\n }\n }\n return ids;\n}\n\n\nasync function ensureStorePath(deps: BackendDeps): Promise<void> {\n if (!deps.create) {\n await deps.fs.stat(deps.path);\n return;\n }\n\n const existing = await statIfExists(deps.fs, deps.path);\n if (existing !== undefined) {\n return;\n }\n\n await writeAtomically(\n deps.fs,\n deps.path,\n serializeDocument(\n parseDocument(\n [\n `$schema: ${STORE_SCHEMA_ID}`,\n `kind: ${STORE_KIND}`,\n `version: ${STORE_VERSION}`,\n \"lists: {}\",\n \"\"\n ].join(\"\\n\")\n )\n )\n );\n}\n\nasync function withStoreLock<T>(deps: BackendDeps, action: () => Promise<T>): Promise<T> {\n const release = await acquireFileLock(deps.path, {\n fs: deps.fs,\n staleMs: deps.lockStaleMs,\n retries: deps.lockRetries\n });\n\n try {\n return await action();\n } finally {\n await release();\n }\n}\n\nfunction createTasksView(deps: BackendDeps, list: string): Tasks {\n const stateMachine = resolveStateMachine(deps.stateMachine);\n const validStates = new Set(stateMachine.states);\n\n async function readTasks(filter?: ListFilter): Promise<Task[]> {\n const { store } = await readStore(deps.fs, deps.path, validStates);\n const listRecord = getListRecord(store, list);\n\n if (!listRecord) {\n return [];\n }\n\n const entries: OrderedEntry[] = Object.entries(listRecord)\n .map(([id, taskRecord]) => ({\n task: createTask(list, id, taskRecord as TaskRecord, deps.path),\n raw: taskRecord as TaskRecord\n }))\n .filter(({ task }) => matchesFilter(task, filter));\n\n return applyOrder(entries, filter?.order);\n }\n\n function assertFireableTaskEvent(task: Task, eventName: string) {\n const event = findEvent(stateMachine, task.state, eventName);\n\n if (event === undefined) {\n throw new InvalidTransitionError({\n task,\n event: eventName,\n to: stateMachine.events[eventName]?.to,\n reason: `Cannot fire event \"${eventName}\" from task state \"${task.state}\".`\n });\n }\n\n return event;\n }\n\n return {\n name: list,\n stateMachine,\n async all(filter?: ListFilter): Promise<Task[]> {\n return readTasks(filter);\n },\n async get(id: string): Promise<Task> {\n validateTaskId(id);\n const { store } = await readStore(deps.fs, deps.path, validStates);\n return createTask(list, id, getTaskOrThrow(store, list, id), deps.path);\n },\n async create(input: TaskCreate): Promise<Task> {\n assertCreateDoesNotSetState(input);\n assertCreateHasId(input);\n validateTaskId(input.id);\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n if (getTaskRecord(store, list, input.id)) {\n throw new TaskAlreadyExistsError(`Task \"${list}/${input.id}\" already exists.`);\n }\n\n const taskRecord = createTaskRecord(deps.defaults, input, stateMachine.initial);\n document.setIn([\"lists\", list, input.id], taskRecord);\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n return createTask(list, input.id, taskRecord, deps.path);\n });\n },\n async update(id: string, patch: TaskUpdate): Promise<Task> {\n assertUpdateDoesNotSetState(patch);\n validateTaskId(id);\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n const existing = getTaskOrThrow(store, list, id);\n const nextTaskRecord = buildUpdatedTaskRecord(existing, patch);\n\n if (patch.name !== undefined) {\n document.setIn([\"lists\", list, id, \"name\"], patch.name);\n }\n\n if (patch.description !== undefined) {\n document.setIn([\"lists\", list, id, \"description\"], patch.description);\n }\n\n for (const [key, value] of Object.entries(patch.metadata ?? {})) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n document.setIn([\"lists\", list, id, key], value);\n }\n }\n\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n return createTask(list, id, nextTaskRecord, deps.path);\n });\n },\n async fire(id: string, eventName: string, opts?: TaskFireOptions): Promise<Task> {\n validateTaskId(id);\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n const existing = getTaskOrThrow(store, list, id);\n const task = createTask(list, id, existing, deps.path);\n const event = assertFireableTaskEvent(task, eventName);\n const guardResult = event.guard?.(task) ?? true;\n\n if (guardResult !== true) {\n throw new InvalidTransitionError({\n task,\n event: eventName,\n to: event.to,\n reason: guardResult\n });\n }\n\n await event.onExit?.(task);\n\n const nextTaskRecord = buildFiredTaskRecord(existing, event.to, opts?.metadataPatch);\n document.setIn([\"lists\", list, id, \"state\"], event.to);\n\n for (const [key, value] of Object.entries(opts?.metadataPatch ?? {})) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n document.setIn([\"lists\", list, id, key], value);\n }\n }\n\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n const nextTask = createTask(list, id, nextTaskRecord, deps.path);\n await event.onEnter?.(nextTask);\n\n return nextTask;\n });\n },\n async canFire(id: string, eventName: string): Promise<boolean> {\n validateTaskId(id);\n const { store } = await readStore(deps.fs, deps.path, validStates);\n const task = createTask(list, id, getTaskOrThrow(store, list, id), deps.path);\n const event = findEvent(stateMachine, task.state, eventName);\n\n if (event === undefined) {\n return false;\n }\n\n return (event.guard?.(task) ?? true) === true;\n },\n async events(id: string): Promise<readonly string[]> {\n validateTaskId(id);\n const { store } = await readStore(deps.fs, deps.path, validStates);\n const task = createTask(list, id, getTaskOrThrow(store, list, id), deps.path);\n\n return eventsFromState(stateMachine, task.state);\n },\n async delete(id: string): Promise<void> {\n validateTaskId(id);\n\n await withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n getTaskOrThrow(store, list, id);\n document.deleteIn([\"lists\", list, id]);\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n });\n },\n async move(id: string, anchor: MoveAnchor): Promise<Task> {\n validateTaskId(id);\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n const taskRecord = getTaskOrThrow(store, list, id);\n const listNode = getListNode(document, list);\n if (!listNode) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n const fromIndex = findItemIndex(listNode, id);\n if (fromIndex < 0) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n const [movedPair] = listNode.items.splice(fromIndex, 1);\n\n let insertIndex: number;\n if (\"position\" in anchor) {\n insertIndex = anchor.position === \"top\" ? 0 : listNode.items.length;\n } else {\n const anchorId = \"before\" in anchor ? anchor.before : anchor.after;\n const anchorIndex = findItemIndex(listNode, anchorId);\n if (anchorIndex < 0) {\n listNode.items.splice(fromIndex, 0, movedPair);\n throw new AnchorNotFoundError(anchorId);\n }\n insertIndex = \"before\" in anchor ? anchorIndex : anchorIndex + 1;\n }\n\n listNode.items.splice(insertIndex, 0, movedPair);\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n return createTask(list, id, taskRecord, deps.path);\n });\n },\n async reorder(ids: readonly string[]): Promise<readonly Task[]> {\n for (const id of ids) {\n validateTaskId(id);\n }\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n const listNode = getListNode(document, list);\n if (!listNode) {\n throw new OrderMismatchError({ missing: [...ids], extra: [] });\n }\n\n const currentActive = activeItemIds(listNode, validStates);\n const currentSet = new Set(currentActive);\n const inputSet = new Set(ids);\n const missing = currentActive.filter((id) => !inputSet.has(id));\n const extra = ids.filter((id) => !currentSet.has(id));\n\n if (missing.length > 0 || extra.length > 0) {\n throw new OrderMismatchError({ missing, extra });\n }\n\n const archivedPairs = listNode.items.filter((pair) => {\n const id = pairKey(pair);\n return id !== undefined && !currentSet.has(id);\n });\n const orderedActive = ids.map((id) => {\n const pair = listNode.items.find((p) => pairKey(p) === id);\n if (!pair) {\n throw new OrderMismatchError({ missing: [id], extra: [] });\n }\n return pair;\n });\n\n listNode.items.splice(0, listNode.items.length, ...orderedActive, ...archivedPairs);\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n const tasks = ids.map((id) =>\n createTask(list, id, getTaskOrThrow(store, list, id), deps.path)\n );\n return tasks;\n });\n }\n };\n}\n\nexport async function yamlFileBackend(deps: BackendDeps): Promise<TaskList> {\n await ensureStorePath(deps);\n const stateMachine = resolveStateMachine(deps.stateMachine);\n const validStates = new Set(stateMachine.states);\n\n const list = (name: string): Tasks => {\n const listName = validateListName(name);\n return createTasksView({ ...deps, stateMachine }, listName);\n };\n\n const lists = async (): Promise<string[]> => {\n const { store } = await readStore(deps.fs, deps.path, validStates);\n return sortStrings(Object.keys(getListsRecord(store)));\n };\n\n const allTasks = async (filter?: ListFilter): Promise<Task[]> => {\n const { store } = await readStore(deps.fs, deps.path, validStates);\n const result: Task[] = [];\n\n const listNames = sortStrings(Object.keys(getListsRecord(store)));\n for (const listName of listNames) {\n const listRecord = getListsRecord(store)[listName];\n if (!isRecord(listRecord)) continue;\n\n const entries: OrderedEntry[] = Object.entries(listRecord)\n .map(([id, taskRecord]) => ({\n task: createTask(listName, id, taskRecord as TaskRecord, deps.path),\n raw: taskRecord as TaskRecord\n }))\n .filter(({ task }) => matchesFilter(task, filter));\n\n result.push(...applyOrder(entries, filter?.order));\n }\n\n return result;\n };\n\n const get = async (qualifiedId: string): Promise<Task> => {\n const { list: listName, id } = parseQualifiedId(qualifiedId);\n return list(listName).get(id);\n };\n\n const moveBetweenLists = async (qualifiedId: string, targetList: string): Promise<Task> => {\n const { list: sourceListName, id } = parseQualifiedId(qualifiedId);\n const targetListName = validateListName(targetList);\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n const taskRecord = getTaskOrThrow(store, sourceListName, id);\n\n if (sourceListName === targetListName) {\n return createTask(targetListName, id, taskRecord, deps.path);\n }\n\n if (getTaskRecord(store, targetListName, id)) {\n throw new TaskAlreadyExistsError(`Task \"${targetListName}/${id}\" already exists.`);\n }\n\n document.deleteIn([\"lists\", sourceListName, id]);\n document.setIn([\"lists\", targetListName, id], taskRecord);\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n return createTask(targetListName, id, taskRecord, deps.path);\n });\n };\n\n return {\n list,\n lists,\n allTasks,\n get,\n moveBetweenLists\n };\n}\n", "{\n \"$schema\": \"https://json-schema.org/draft/2020-12/schema\",\n \"$id\": \"https://poe-platform.github.io/poe-code/schemas/task-list/store.schema.json\",\n \"title\": \"Task Store\",\n \"description\": \"YAML multi-list task store.\",\n \"type\": \"object\",\n \"properties\": {\n \"$schema\": {\n \"type\": \"string\",\n \"const\": \"https://poe-platform.github.io/poe-code/schemas/task-list/store.schema.json\"\n },\n \"kind\": {\n \"type\": \"string\",\n \"const\": \"task-store\"\n },\n \"version\": {\n \"type\": \"integer\",\n \"const\": 1\n },\n \"lists\": {\n \"type\": \"object\",\n \"additionalProperties\": {\n \"type\": \"object\",\n \"additionalProperties\": {\n \"$ref\": \"./task.schema.json\"\n }\n }\n }\n },\n \"required\": [\"$schema\", \"kind\", \"version\", \"lists\"],\n \"additionalProperties\": false\n}\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const claudeCodeAgent: AgentDefinition = {\n id: \"claude-code\",\n name: \"claude-code\",\n label: \"Claude Code\",\n summary: \"Configure Claude Code to route through Poe.\",\n aliases: [\"claude\"],\n binaryName: \"claude\",\n apiShapes: [\"anthropic-messages\"],\n configPath: \"~/.claude/settings.json\",\n branding: {\n colors: {\n dark: \"#C15F3C\",\n light: \"#C15F3C\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const claudeDesktopAgent: AgentDefinition = {\n id: \"claude-desktop\",\n name: \"claude-desktop\",\n label: \"Claude Desktop\",\n summary: \"Anthropic's official desktop application for Claude\",\n configPath: \"~/.claude/settings.json\",\n branding: {\n colors: {\n dark: \"#D97757\",\n light: \"#D97757\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const codexAgent: AgentDefinition = {\n id: \"codex\",\n name: \"codex\",\n label: \"Codex\",\n summary: \"Configure Codex to use Poe as the model provider.\",\n binaryName: \"codex\",\n apiShapes: [\"openai-responses\"],\n configPath: \"~/.codex/config.toml\",\n branding: {\n colors: {\n dark: \"#D5D9DF\",\n light: \"#7A7F86\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const openCodeAgent: AgentDefinition = {\n id: \"opencode\",\n name: \"opencode\",\n label: \"OpenCode CLI\",\n summary: \"Configure OpenCode CLI to use the Poe API.\",\n binaryName: \"opencode\",\n apiShapes: [\"openai-chat-completions\"],\n configPath: \"~/.config/opencode/config.json\",\n branding: {\n colors: {\n dark: \"#4A4F55\",\n light: \"#2F3338\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const kimiAgent: AgentDefinition = {\n id: \"kimi\",\n name: \"kimi\",\n label: \"Kimi\",\n summary: \"Configure Kimi CLI to use Poe API\",\n aliases: [\"kimi-cli\"],\n binaryName: \"kimi\",\n apiShapes: [\"openai-chat-completions\"],\n configPath: \"~/.kimi/config.toml\",\n branding: {\n colors: {\n dark: \"#7B68EE\",\n light: \"#6A5ACD\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const gooseAgent: AgentDefinition = {\n id: \"goose\",\n name: \"goose\",\n label: \"Goose\",\n summary: \"Block's open-source AI agent with ACP support.\",\n binaryName: \"goose\",\n apiShapes: [\"openai-chat-completions\"],\n configPath: \"~/.config/goose/config.yaml\",\n branding: {\n colors: {\n dark: \"#FF6B35\",\n light: \"#E85D26\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const poeAgentAgent: AgentDefinition = {\n id: \"poe-agent\",\n name: \"poe-agent\",\n label: \"Poe Agent\",\n summary: \"Run one-shot prompts with the built-in Poe agent runtime.\",\n apiShapes: [\"openai-responses\", \"openai-chat-completions\"],\n configPath: \"~/.poe-code/config.json\",\n branding: {\n colors: {\n dark: \"#A465F7\",\n light: \"#7A3FD3\"\n }\n }\n};\n", "import type { AgentDefinition } from \"./types.js\";\nimport {\n claudeCodeAgent,\n claudeDesktopAgent,\n codexAgent,\n openCodeAgent,\n kimiAgent,\n gooseAgent,\n poeAgentAgent\n} from \"./agents/index.js\";\n\nexport const allAgents: AgentDefinition[] = [\n claudeCodeAgent,\n claudeDesktopAgent,\n codexAgent,\n openCodeAgent,\n kimiAgent,\n gooseAgent,\n poeAgentAgent\n];\n\nconst lookup = new Map<string, string>();\n\nfor (const agent of allAgents) {\n const values = [agent.id, agent.name, ...(agent.aliases ?? [])];\n for (const value of values) {\n const normalized = value.toLowerCase();\n if (!lookup.has(normalized)) {\n lookup.set(normalized, agent.id);\n }\n }\n}\n\nexport function resolveAgentId(input: string): string | undefined {\n if (!input) {\n return undefined;\n }\n return lookup.get(input.toLowerCase());\n}\n", "import { allAgents, parseAgentSpecifier, resolveAgentId } from \"@poe-code/agent-defs\";\n\ntype Select = typeof import(\"@poe-code/design-system\").select;\ntype IsCancel = typeof import(\"@poe-code/design-system\").isCancel;\n\nexport interface ResolveLoopAgentInput {\n providedAgent?: string;\n configuredDefaultAgent?: string | null;\n frontmatterAgent?: string | string[];\n assumeYes: boolean;\n fallbackAgent: string;\n message: string;\n select: Select;\n isCancel: IsCancel;\n}\n\nconst loopAgents = allAgents.filter(\n (agent) => agent.binaryName !== undefined || agent.id === \"poe-agent\"\n);\nconst supportedAgents = loopAgents.map((agent) => agent.id).join(\", \");\n\nfunction resolveSelectedAgent(agent: string): { agent: string } {\n const specifier = parseAgentSpecifier(agent);\n const resolvedAgentId = resolveAgentId(specifier.agent);\n\n if (!resolvedAgentId || !loopAgents.some((agent) => agent.id === resolvedAgentId)) {\n throw new Error(`Unsupported agent \"${agent}\". Supported agents: ${supportedAgents}`);\n }\n\n return {\n agent: specifier.model ? `${resolvedAgentId}:${specifier.model}` : resolvedAgentId\n };\n}\n\nexport async function resolveLoopAgent(\n input: ResolveLoopAgentInput\n): Promise<{ agent: string } | { cancelled: true }> {\n if (input.providedAgent !== undefined) {\n return resolveSelectedAgent(input.providedAgent);\n }\n\n if (Array.isArray(input.frontmatterAgent)) {\n throw new Error(\"array handled by caller\");\n }\n\n if (typeof input.frontmatterAgent === \"string\") {\n return resolveSelectedAgent(input.frontmatterAgent);\n }\n\n if (input.configuredDefaultAgent !== undefined && input.configuredDefaultAgent !== null) {\n return resolveSelectedAgent(input.configuredDefaultAgent);\n }\n\n if (input.assumeYes) {\n return resolveSelectedAgent(input.fallbackAgent);\n }\n\n const selectedAgent = await input.select({\n message: input.message,\n options: loopAgents.map((agent) => ({\n value: agent.id,\n label: agent.label,\n hint: agent.summary\n }))\n });\n\n if (input.isCancel(selectedAgent)) {\n return { cancelled: true };\n }\n\n return resolveSelectedAgent(selectedAgent);\n}\n", "import path from \"node:path\";\n\nexport interface ResolveRunLogDirOptions {\n planPath: string;\n runner: string;\n homeDir: string;\n}\n\nexport function resolveRunLogDir(options: ResolveRunLogDirOptions): string {\n const slug = slugifyPlanPath(options.planPath);\n return path.join(options.homeDir, \".poe-code\", \"logs\", options.runner, slug);\n}\n\nexport function slugifyPlanPath(planPath: string): string {\n const base = path.basename(planPath);\n const dot = base.lastIndexOf(\".\");\n const stem = dot > 0 ? base.slice(0, dot) : base;\n return slugifyLabel(stem);\n}\n\nexport function makeRunLogFileName(role: string, date: Date = new Date()): string {\n const day = `${date.getUTCFullYear()}${pad(date.getUTCMonth() + 1, 2)}${pad(date.getUTCDate(), 2)}`;\n const time = `${pad(date.getUTCHours(), 2)}${pad(date.getUTCMinutes(), 2)}${pad(date.getUTCSeconds(), 2)}`;\n const ms = pad(date.getUTCMilliseconds(), 3);\n const safeRole = slugifyLabel(role) || \"role\";\n return `${day}-${time}-${ms}-${safeRole}.jsonl`;\n}\n\nfunction slugifyLabel(value: string): string {\n let out = \"\";\n for (const char of value) {\n const code = char.charCodeAt(0);\n const lower = code >= 97 && code <= 122;\n const upper = code >= 65 && code <= 90;\n const digit = code >= 48 && code <= 57;\n\n if (lower || digit) {\n out += char;\n } else if (upper) {\n out += String.fromCharCode(code + 32);\n } else if (char === \"-\" || char === \"_\") {\n out += char;\n } else {\n out += \"-\";\n }\n }\n\n return collapseDashes(out).replace(/^-+|-+$/g, \"\");\n}\n\nfunction collapseDashes(value: string): string {\n let out = \"\";\n let prevDash = false;\n for (const char of value) {\n if (char === \"-\") {\n if (!prevDash) {\n out += \"-\";\n }\n prevDash = true;\n } else {\n out += char;\n prevDash = false;\n }\n }\n return out;\n}\n\nfunction pad(value: number, width: number): string {\n return String(value).padStart(width, \"0\");\n}\n", "import nodeFs from \"node:fs\";\nimport type { FSWatcher } from \"node:fs\";\nimport type { LogChunk } from \"./execution-env.js\";\n\nconst JOB_DIR = \"/tmp/poe-jobs\";\nconst POLL_INTERVAL_MS = 250;\n\nexport interface LogStreamEnv {\n fs?: LogStreamFs;\n}\n\nexport interface LogStreamFs {\n promises: {\n readFile(path: string): Promise<Buffer | string>;\n stat?(path: string): Promise<{ mtimeMs: number }>;\n };\n watch?: (path: string, listener: () => void) => FSWatcher;\n}\n\nexport function wrapForLogTee(argv: string[], jobId: string): string[] {\n if (argv.length === 0) {\n throw new Error(\"wrapForLogTee requires argv to contain at least one argument\");\n }\n\n const command = argv.map(shellQuote).join(\" \");\n const logFile = shellQuote(jobLogPath(jobId));\n const exitFile = shellQuote(jobExitPath(jobId));\n const exitTmpFile = shellQuote(`${jobExitPath(jobId)}.tmp`);\n const script = [\n `mkdir -p ${shellQuote(JOB_DIR)}`,\n `({ (${command}); echo $? > ${exitTmpFile}; } 2>&1 | tee ${logFile}; mv ${exitTmpFile} ${exitFile})`\n ].join(\" && \");\n\n return [\"sh\", \"-c\", script];\n}\n\nexport async function* streamLogFile(\n env: LogStreamEnv,\n jobId: string,\n opts: { sinceByte?: number; since?: Date }\n): AsyncIterable<LogChunk> {\n const fs = env.fs ?? nodeFs;\n const file = jobLogPath(jobId);\n let byteOffset = opts.sinceByte ?? 0;\n\n while (true) {\n if (opts.since !== undefined && !(await wasModifiedSince(fs, file, opts.since))) {\n await waitForLogChange(fs, file);\n continue;\n }\n\n const result = await readLogChunk(fs, file, byteOffset);\n if (result !== null) {\n byteOffset = result.nextByteOffset;\n yield result.chunk;\n continue;\n }\n\n await waitForLogChange(fs, file);\n }\n}\n\nasync function wasModifiedSince(fs: LogStreamFs, file: string, since: Date): Promise<boolean> {\n if (fs.promises.stat === undefined) {\n return true;\n }\n\n try {\n const stat = await fs.promises.stat(file);\n return stat.mtimeMs >= since.getTime();\n } catch (error) {\n if (isNodeError(error) && error.code === \"ENOENT\") {\n return false;\n }\n throw error;\n }\n}\n\nexport async function waitForExit(\n env: LogStreamEnv,\n jobId: string,\n opts: { signal?: AbortSignal } = {}\n): Promise<{ exitCode: number }> {\n const fs = env.fs ?? nodeFs;\n const file = jobExitPath(jobId);\n\n while (true) {\n throwIfAborted(opts.signal);\n const contents = await readTextFileIfExists(fs, file);\n if (contents !== null) {\n const text = contents.trim();\n const exitCode = Number(text);\n if (text.length === 0 || !Number.isInteger(exitCode)) {\n throw new Error(`Invalid exit code in ${file}: ${contents}`);\n }\n return { exitCode };\n }\n\n await sleep(POLL_INTERVAL_MS, opts.signal);\n }\n}\n\nfunction jobLogPath(jobId: string): string {\n return `${JOB_DIR}/${jobId}.log`;\n}\n\nfunction jobExitPath(jobId: string): string {\n return `${JOB_DIR}/${jobId}.exit`;\n}\n\nasync function readLogChunk(\n fs: LogStreamFs,\n file: string,\n byteOffset: number\n): Promise<{ chunk: LogChunk; nextByteOffset: number } | null> {\n const contents = await readFileIfExists(fs, file);\n if (contents === null || byteOffset >= contents.byteLength) {\n return null;\n }\n\n return {\n chunk: {\n byteOffset,\n data: contents.subarray(byteOffset).toString(\"utf8\")\n },\n nextByteOffset: contents.byteLength\n };\n}\n\nasync function readTextFileIfExists(fs: LogStreamFs, file: string): Promise<string | null> {\n const contents = await readFileIfExists(fs, file);\n return contents?.toString(\"utf8\") ?? null;\n}\n\nasync function readFileIfExists(fs: LogStreamFs, file: string): Promise<Buffer | null> {\n try {\n const contents = await fs.promises.readFile(file);\n return Buffer.isBuffer(contents) ? contents : Buffer.from(contents);\n } catch (error) {\n if (isNodeError(error) && error.code === \"ENOENT\") {\n return null;\n }\n throw error;\n }\n}\n\nasync function waitForLogChange(fs: LogStreamFs, file: string): Promise<void> {\n const watch = fs.watch;\n if (typeof watch !== \"function\") {\n await sleep(POLL_INTERVAL_MS);\n return;\n }\n\n await new Promise<void>((resolve) => {\n let watcher: FSWatcher | null = null;\n const timer = setTimeout(done, POLL_INTERVAL_MS);\n\n function done(): void {\n clearTimeout(timer);\n watcher?.close();\n resolve();\n }\n\n try {\n watcher = watch(file, done);\n } catch {\n done();\n }\n });\n}\n\nfunction sleep(ms: number, signal?: AbortSignal): Promise<void> {\n return new Promise((resolve, reject) => {\n let timer: NodeJS.Timeout | null = null;\n const abort = () => {\n if (timer !== null) {\n clearTimeout(timer);\n }\n reject(new Error(\"waitForExit aborted.\"));\n };\n\n if (signal?.aborted) {\n abort();\n return;\n }\n\n timer = setTimeout(() => {\n signal?.removeEventListener(\"abort\", abort);\n resolve();\n }, ms);\n signal?.addEventListener(\"abort\", abort, { once: true });\n });\n}\n\nfunction throwIfAborted(signal: AbortSignal | undefined): void {\n if (signal?.aborted) {\n throw new Error(\"waitForExit aborted.\");\n }\n}\n\nfunction shellQuote(value: string): string {\n return `'${value.replaceAll(\"'\", \"'\\\\''\")}'`;\n}\n\nfunction isNodeError(error: unknown): error is NodeJS.ErrnoException {\n return error instanceof Error && \"code\" in error;\n}\n", "import { randomBytes } from \"node:crypto\";\nimport { allAgents, resolveAgentId } from \"@poe-code/agent-defs\";\nimport type { StateManager } from \"@poe-code/poe-code-config\";\nimport type { RunHandle } from \"@poe-code/process-runner\";\nimport type { Readable } from \"node:stream\";\nimport { createBinaryExistsDetectors } from \"./binary-exists.js\";\nimport type { DownloadResult, ExecutionEnvFactory, OpenedEnv, OpenSpec } from \"./execution-env.js\";\nimport { waitForExit, wrapForLogTee, type LogStreamEnv } from \"./log-stream.js\";\n\nconst ULID_ALPHABET = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\";\n\nexport async function runPoeCommand(opts: {\n factory: ExecutionEnvFactory;\n openSpec: OpenSpec;\n detach: boolean;\n state: StateManager;\n signal?: AbortSignal;\n}): Promise<\n | {\n kind: \"sync\";\n exitCode: number;\n download: DownloadResult;\n stdout?: string;\n stderr?: string;\n }\n | { kind: \"detached\"; jobId: string; envId: string }\n> {\n const jobId = createUlid();\n const execution = opts.openSpec.execution;\n const wrapCommand = execution?.wrapForLogTee !== false;\n const pendingJob = opts.state.jobs.put({\n id: jobId,\n env_id: \"\",\n env_kind: opts.factory.type,\n tool: opts.openSpec.jobLabel.tool,\n argv: opts.openSpec.jobLabel.argv,\n cwd: opts.openSpec.cwd,\n started_at: \"\",\n status: \"pending\"\n });\n\n const opened = opts.factory.open(opts.openSpec);\n const env = isPromiseLike(opened) ? await opened : opened;\n let shouldClose = true;\n\n try {\n const upload = env.uploadWorkspace();\n await Promise.all([pendingJob, upload]);\n await configureE2bSpawnAgentIfAvailable({\n env,\n openSpec: opts.openSpec,\n factoryType: opts.factory.type\n });\n const argv = wrapCommand\n ? wrapForLogTee(opts.openSpec.jobLabel.argv, jobId)\n : opts.openSpec.jobLabel.argv;\n const handle = execution?.tty\n ? env.shell()\n : env.exec({\n command: argv[0],\n args: argv.slice(1),\n cwd: opts.openSpec.cwd,\n env: resolveExecutionEnv(opts.openSpec),\n stdin: execution?.stdin ?? \"inherit\",\n stdout: execution?.stdout ?? \"pipe\",\n stderr: execution?.stderr ?? \"pipe\",\n signal: opts.signal\n });\n\n if (execution?.input !== undefined) {\n writeExecutionInput(handle, execution.input);\n }\n\n const runningJob = opts.state.jobs.update(jobId, {\n status: \"running\",\n env_id: env.id,\n started_at: new Date().toISOString()\n });\n\n if (opts.detach) {\n await runningJob;\n setDetachedJobContext(env, {\n id: jobId,\n tool: opts.openSpec.jobLabel.tool,\n argv: opts.openSpec.jobLabel.argv\n });\n await env.detach();\n shouldClose = false;\n return { kind: \"detached\", jobId, envId: env.id };\n }\n\n const result = await runSync({\n env,\n handle,\n jobId,\n openSpec: opts.openSpec,\n signal: opts.signal,\n wrapCommand\n });\n await runningJob;\n shouldClose = false;\n\n await opts.state.jobs.update(jobId, {\n status: \"exited\",\n exit_code: result.exitCode,\n exited_at: new Date().toISOString()\n });\n\n return {\n kind: \"sync\",\n exitCode: result.exitCode,\n download: result.download,\n ...(result.stdout !== undefined ? { stdout: result.stdout } : {}),\n ...(result.stderr !== undefined ? { stderr: result.stderr } : {})\n };\n } finally {\n if (shouldClose) {\n await env.close();\n }\n }\n}\n\nexport interface PoeCommandSession {\n run(\n openSpec: OpenSpec,\n signal?: AbortSignal\n ): Promise<{\n kind: \"sync\";\n exitCode: number;\n download: DownloadResult;\n stdout?: string;\n stderr?: string;\n }>;\n close(): Promise<void>;\n}\n\nexport function createPoeCommandSession(opts: {\n factory: ExecutionEnvFactory;\n state: StateManager;\n}): PoeCommandSession {\n let env: OpenedEnv | null = null;\n let closed = false;\n\n async function getEnv(openSpec: OpenSpec): Promise<OpenedEnv> {\n if (closed) {\n throw new Error(\"Cannot run command after Poe command session is closed.\");\n }\n\n if (env !== null) {\n return env;\n }\n\n const opened = opts.factory.open(openSpec);\n env = isPromiseLike(opened) ? await opened : opened;\n await env.uploadWorkspace();\n return env;\n }\n\n return {\n async run(openSpec, signal) {\n const jobId = createUlid();\n const pendingJob = opts.state.jobs.put({\n id: jobId,\n env_id: \"\",\n env_kind: opts.factory.type,\n tool: openSpec.jobLabel.tool,\n argv: openSpec.jobLabel.argv,\n cwd: openSpec.cwd,\n started_at: \"\",\n status: \"pending\"\n });\n const currentEnv = await getEnv(openSpec);\n await pendingJob;\n await configureE2bSpawnAgentIfAvailable({\n env: currentEnv,\n openSpec,\n factoryType: opts.factory.type\n });\n const wrapCommand = openSpec.execution?.wrapForLogTee !== false;\n const argv = wrapCommand\n ? wrapForLogTee(openSpec.jobLabel.argv, jobId)\n : openSpec.jobLabel.argv;\n const handle = openSpec.execution?.tty\n ? currentEnv.shell()\n : currentEnv.exec({\n command: argv[0],\n args: argv.slice(1),\n cwd: openSpec.cwd,\n env: resolveExecutionEnv(openSpec),\n stdin: openSpec.execution?.stdin ?? \"inherit\",\n stdout: openSpec.execution?.stdout ?? \"pipe\",\n stderr: openSpec.execution?.stderr ?? \"pipe\",\n signal\n });\n\n if (openSpec.execution?.input !== undefined) {\n writeExecutionInput(handle, openSpec.execution.input);\n }\n\n await opts.state.jobs.update(jobId, {\n status: \"running\",\n env_id: currentEnv.id,\n started_at: new Date().toISOString()\n });\n\n const result = await runSync({\n env: currentEnv,\n handle,\n jobId,\n openSpec,\n signal,\n wrapCommand,\n closeAfterDownload: false\n });\n\n await opts.state.jobs.update(jobId, {\n status: \"exited\",\n exit_code: result.exitCode,\n exited_at: new Date().toISOString()\n });\n\n return {\n kind: \"sync\",\n exitCode: result.exitCode,\n download: result.download,\n ...(result.stdout !== undefined ? { stdout: result.stdout } : {}),\n ...(result.stderr !== undefined ? { stderr: result.stderr } : {})\n };\n },\n async close() {\n if (closed) {\n return;\n }\n closed = true;\n await env?.close();\n }\n };\n}\n\nasync function configureE2bSpawnAgentIfAvailable(opts: {\n env: OpenedEnv;\n openSpec: OpenSpec;\n factoryType: string;\n}): Promise<void> {\n if (opts.factoryType !== \"e2b\") {\n return;\n }\n\n const agentId = resolveAgentId(opts.openSpec.jobLabel.tool);\n const agent = allAgents.find((candidate) => candidate.id === agentId);\n const binaryName = agent?.binaryName;\n if (!agentId || !binaryName) {\n return;\n }\n\n const commandEnv = resolveExecutionEnv(opts.openSpec);\n const exists = await binaryExists(opts.env, {\n binaryName,\n cwd: opts.openSpec.cwd,\n env: commandEnv\n });\n if (!exists) {\n return;\n }\n\n const result = await runProbeCommand(opts.env, {\n command: \"poe-code\",\n args: [\"configure\", \"--yes\", \"--provider\", \"poe\", agentId],\n cwd: opts.openSpec.cwd,\n env: commandEnv\n });\n if (result.exitCode !== 0) {\n throw new Error(\n `Failed to configure ${agentId} for Poe inside E2B sandbox.\\n${formatProbeResult(result)}`\n );\n }\n}\n\nasync function binaryExists(\n env: OpenedEnv,\n opts: { binaryName: string; cwd: string; env: Record<string, string> | undefined }\n): Promise<boolean> {\n for (const detector of createBinaryExistsDetectors(opts.binaryName)) {\n const result = await runProbeCommand(env, {\n ...detector,\n cwd: opts.cwd,\n env: opts.env\n });\n if (detector.validate(result)) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction resolveExecutionEnv(openSpec: OpenSpec): Record<string, string> | undefined {\n const execution = openSpec.execution;\n return execution?.env ?? openSpec.env;\n}\n\nasync function runProbeCommand(\n env: OpenedEnv,\n spec: {\n command: string;\n args?: string[];\n cwd: string;\n env: Record<string, string> | undefined;\n }\n): Promise<{ exitCode: number; stdout: string; stderr: string }> {\n const handle = env.exec({\n command: spec.command,\n args: spec.args,\n cwd: spec.cwd,\n env: spec.env,\n stdin: \"ignore\",\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n const stdout = readStream(handle.stdout);\n const stderr = readStream(handle.stderr);\n const result = await handle.result;\n return {\n exitCode: result.exitCode,\n stdout: await stdout,\n stderr: await stderr\n };\n}\n\nfunction readStream(stream: Readable | null): Promise<string> {\n if (!stream) {\n return Promise.resolve(\"\");\n }\n return new Promise((resolve, reject) => {\n let output = \"\";\n stream.setEncoding(\"utf8\");\n stream.on(\"data\", (chunk) => {\n output += chunk.toString();\n });\n stream.on(\"error\", reject);\n stream.on(\"end\", () => resolve(output));\n });\n}\n\nfunction formatProbeResult(result: { exitCode: number; stdout: string; stderr: string }): string {\n return [\n `Exit code: ${result.exitCode}`,\n result.stdout.trim() ? `stdout:\\n${result.stdout.trim()}` : \"\",\n result.stderr.trim() ? `stderr:\\n${result.stderr.trim()}` : \"\"\n ]\n .filter(Boolean)\n .join(\"\\n\");\n}\n\nasync function runSync(opts: {\n env: OpenedEnv;\n handle: RunHandle;\n jobId: string;\n openSpec: OpenSpec;\n signal?: AbortSignal;\n wrapCommand: boolean;\n closeAfterDownload?: boolean;\n}): Promise<{ exitCode: number; download: DownloadResult; stdout?: string; stderr?: string }> {\n const execution = opts.openSpec.execution;\n const capture = execution?.captureOutput === true;\n const abort = createAbortSync(opts.signal, opts.handle, execution?.activityTimeoutMs);\n const streamState = capture\n ? captureRunStreams(opts.handle, execution, abort.resetActivityTimer)\n : pipeRunStreams(opts.handle);\n abort.resetActivityTimer();\n\n try {\n const { exitCode } = opts.wrapCommand\n ? await abort.waitForExit(opts.env, opts.jobId)\n : await abort.waitForHandle();\n const download = await opts.env.downloadWorkspace({\n conflictPolicy: opts.openSpec.runner?.download_conflict ?? \"refuse\"\n });\n if (opts.closeAfterDownload !== false) {\n await opts.env.close();\n }\n return {\n exitCode,\n download,\n ...(capture ? { stdout: streamState.stdout(), stderr: streamState.stderr() } : {})\n };\n } finally {\n abort.dispose();\n streamState.dispose();\n }\n}\n\nfunction pipeRunStreams(handle: RunHandle): {\n stdout(): string;\n stderr(): string;\n dispose(): void;\n} {\n handle.stdout?.pipe(process.stdout, { end: false });\n handle.stderr?.pipe(process.stderr, { end: false });\n return {\n stdout: () => \"\",\n stderr: () => \"\",\n dispose() {\n handle.stdout?.unpipe(process.stdout);\n handle.stderr?.unpipe(process.stderr);\n }\n };\n}\n\nfunction captureRunStreams(\n handle: RunHandle,\n execution: NonNullable<OpenSpec[\"execution\"]> | undefined,\n onActivity: () => void\n): {\n stdout(): string;\n stderr(): string;\n dispose(): void;\n} {\n let stdout = \"\";\n let stderr = \"\";\n const listeners: Array<() => void> = [];\n\n const bind = (stream: Readable | null, onChunk: (chunk: string) => void): void => {\n if (!stream) return;\n stream.setEncoding(\"utf8\");\n const listener = (chunk: string | Buffer) => {\n onActivity();\n onChunk(chunk.toString());\n };\n stream.on(\"data\", listener);\n listeners.push(() => {\n stream.off(\"data\", listener);\n });\n };\n\n bind(handle.stdout, (chunk) => {\n stdout += chunk;\n execution?.onStdout?.(chunk);\n });\n bind(handle.stderr, (chunk) => {\n stderr += chunk;\n execution?.onStderr?.(chunk);\n });\n\n return {\n stdout: () => stdout,\n stderr: () => stderr,\n dispose() {\n for (const remove of listeners) {\n remove();\n }\n }\n };\n}\n\nfunction createAbortSync(\n signal: AbortSignal | undefined,\n handle: RunHandle,\n activityTimeoutMs: number | undefined\n): {\n waitForExit(env: OpenedEnv, jobId: string): Promise<{ exitCode: number }>;\n waitForHandle(): Promise<{ exitCode: number }>;\n resetActivityTimer(): void;\n dispose(): void;\n} {\n let activityTimer: ReturnType<typeof setTimeout> | undefined;\n let timedOut = false;\n const resetActivityTimer = activityTimeoutMs\n ? () => {\n if (activityTimer) clearTimeout(activityTimer);\n activityTimer = setTimeout(() => {\n timedOut = true;\n handle.kill(\"SIGTERM\");\n notifyAbort?.();\n }, activityTimeoutMs);\n }\n : () => {};\n let notifyAbort: (() => void) | undefined;\n\n if (signal === undefined) {\n return {\n waitForExit: (env, jobId) => waitForExit(toLogStreamEnv(env), jobId),\n waitForHandle: async () => {\n const result = await handle.result;\n if (timedOut) {\n throw createActivityTimeoutError(activityTimeoutMs!);\n }\n return result;\n },\n resetActivityTimer,\n dispose() {\n if (activityTimer) clearTimeout(activityTimer);\n }\n };\n }\n\n const exitWaitController = new AbortController();\n let aborted = signal.aborted;\n const abortedPromise = new Promise<void>((resolve) => {\n notifyAbort = resolve;\n });\n const kill = () => {\n aborted = true;\n handle.kill(\"SIGTERM\");\n notifyAbort?.();\n };\n\n if (signal.aborted) {\n kill();\n } else {\n signal.addEventListener(\"abort\", kill, { once: true });\n }\n\n return {\n async waitForExit(env, jobId) {\n if (aborted) {\n return handle.result;\n }\n\n const exit = waitForExit(toLogStreamEnv(env), jobId, {\n signal: exitWaitController.signal\n }).then(\n (value) => ({ kind: \"exit\" as const, value }),\n (error: unknown) => ({ kind: \"error\" as const, error })\n );\n const result = await Promise.race([\n exit,\n abortedPromise.then(() => ({ kind: \"abort\" as const }))\n ]);\n\n if (result.kind === \"exit\") {\n return result.value;\n }\n\n if (result.kind === \"error\") {\n throw result.error;\n }\n\n exitWaitController.abort();\n return handle.result;\n },\n async waitForHandle() {\n const result = await Promise.race([\n handle.result.then((value) => ({ kind: \"exit\" as const, value })),\n abortedPromise.then(() => ({ kind: \"abort\" as const }))\n ]);\n\n if (result.kind === \"exit\") {\n if (aborted) {\n throw createAbortError();\n }\n if (timedOut) {\n throw createActivityTimeoutError(activityTimeoutMs!);\n }\n return result.value;\n }\n\n if (timedOut) {\n throw createActivityTimeoutError(activityTimeoutMs!);\n }\n throw createAbortError();\n },\n resetActivityTimer,\n dispose() {\n if (activityTimer) clearTimeout(activityTimer);\n exitWaitController.abort();\n signal.removeEventListener(\"abort\", kill);\n }\n };\n}\n\nfunction toLogStreamEnv(env: OpenedEnv): LogStreamEnv {\n const candidate = env as OpenedEnv & LogStreamEnv;\n return candidate.fs === undefined ? {} : { fs: candidate.fs };\n}\n\nfunction setDetachedJobContext(\n env: OpenedEnv,\n context: { id: string; tool: string; argv: string[] }\n): void {\n const candidate = env as OpenedEnv & {\n setDetachedJobContext?: (value: { id: string; tool: string; argv: string[] }) => void;\n };\n candidate.setDetachedJobContext?.(context);\n}\n\nfunction writeExecutionInput(handle: RunHandle, input: string | Buffer): void {\n const stdin = handle.stdin;\n if (stdin === null) {\n return;\n }\n\n stdin.on(\"error\", (error: NodeJS.ErrnoException) => {\n if (error.code !== \"EPIPE\") {\n throw error;\n }\n });\n stdin.setDefaultEncoding(\"utf8\");\n stdin.end(input);\n}\n\nfunction isPromiseLike<T>(value: T | Promise<T>): value is Promise<T> {\n return typeof (value as Promise<T>).then === \"function\";\n}\n\nfunction createAbortError(): Error {\n const error = new Error(\"Agent spawn aborted\");\n error.name = \"AbortError\";\n return error;\n}\n\nfunction createActivityTimeoutError(timeoutMs: number): Error {\n const error = new Error(`Agent spawn timed out after ${timeoutMs / 1000}s of inactivity`);\n error.name = \"ActivityTimeoutError\";\n return error;\n}\n\nfunction createUlid(): string {\n const time = BigInt(Date.now());\n const random = randomBytes(10);\n let randomValue = 0n;\n\n for (const byte of random) {\n randomValue = (randomValue << 8n) | BigInt(byte);\n }\n\n return encodeBase32(time, 10) + encodeBase32(randomValue, 16);\n}\n\nfunction encodeBase32(value: bigint, length: number): string {\n const chars = Array.from({ length }, () => \"0\");\n let remaining = value;\n\n for (let index = length - 1; index >= 0; index -= 1) {\n chars[index] = ULID_ALPHABET[Number(remaining & 31n)];\n remaining >>= 5n;\n }\n\n return chars.join(\"\");\n}\n", "export interface BinaryExistsDetectorResult {\n exitCode: number;\n stdout: string;\n}\n\nexport interface BinaryExistsDetector {\n command: string;\n args: string[];\n validate(result: BinaryExistsDetectorResult): boolean;\n}\n\nexport function createBinaryExistsDetectors(binaryName: string): BinaryExistsDetector[] {\n const commonPaths = [\n `/usr/local/bin/${binaryName}`,\n `/usr/bin/${binaryName}`,\n `$HOME/.local/bin/${binaryName}`,\n `$HOME/.claude/local/bin/${binaryName}`\n ];\n\n return [\n {\n command: \"which\",\n args: [binaryName],\n validate: (result) => result.exitCode === 0\n },\n {\n command: \"where\",\n args: [binaryName],\n validate: (result) => result.exitCode === 0 && result.stdout.trim().length > 0\n },\n {\n command: \"sh\",\n args: [\"-c\", commonPaths.map((p) => `test -f \"${p}\"`).join(\" || \")],\n validate: (result) => result.exitCode === 0\n }\n ];\n}\n", "import { existsSync, readFileSync } from \"node:fs\";\nimport os from \"node:os\";\nimport {\n createStateManager,\n deepMergeDocuments,\n parseRuntime,\n resolveConfigPath,\n resolveProjectConfigPath,\n resolveRuntime,\n resolveScope,\n runtimeConfigScope,\n type RunnerScope,\n type ConfigDocument,\n type JobEntry,\n type JobListFilter,\n type ResolvedConfig,\n type StateManager\n} from \"@poe-code/poe-code-config\";\nimport { selectExecutionEnv, type OpenSpec } from \"./execution-env.js\";\n\nexport type RuntimeOverrideOptions = {\n runtime?: \"host\" | \"docker\" | \"e2b\";\n runtimeImage?: string;\n runtimeTemplate?: string;\n detach?: boolean;\n mountPoeCode?: boolean;\n runnerSync?: RunnerScope[\"sync\"];\n};\n\nexport function resolvePoeCommandExecution(input: {\n cwd: string;\n runtimeConfigCwd?: string;\n env: Record<string, string>;\n argv: string[];\n tool: string;\n runtime?: RuntimeOverrideOptions;\n context?: {\n homeDir?: string;\n state?: StateManager;\n };\n openSpec?: Partial<Pick<OpenSpec, \"execution\" | \"shellSpec\">>;\n}): {\n factory: ReturnType<typeof selectExecutionEnv>;\n openSpec: OpenSpec;\n detach: boolean;\n state: StateManager;\n} {\n const homeDir = input.context?.homeDir ?? os.homedir();\n const runtimeConfigCwd = input.runtimeConfigCwd ?? input.cwd;\n const loaded = loadRuntimeConfig(runtimeConfigCwd, homeDir);\n const config = applyRuntimeOverrides(loaded, input.runtime, runtimeConfigCwd);\n const resolved = resolveRuntime({ cwd: runtimeConfigCwd, config });\n const factory = selectExecutionEnv(resolved.runtime);\n const state = input.context?.state ?? loadState(homeDir);\n\n return {\n factory,\n detach: factory.supportsDetach === true && config.runner.detach,\n state,\n openSpec: {\n cwd: input.cwd,\n runtimeCwd: runtimeConfigCwd,\n runtime: resolved.runtime,\n runner: config.runner,\n state,\n env: input.env,\n uploadIgnoreFiles: config.runner.workspace?.exclude ?? [],\n jobLabel: {\n tool: input.tool,\n argv: input.argv\n },\n ...input.openSpec\n }\n };\n}\n\nexport interface LoadedRuntimeConfig extends ResolvedConfig {\n /** Raw merged runtime scope preserved for re-parsing when overrides change the type. */\n rawScope: Record<string, unknown>;\n}\n\nexport function applyRuntimeOverrides(\n config: ResolvedConfig | LoadedRuntimeConfig,\n overrides: RuntimeOverrideOptions | undefined,\n cwd = process.cwd()\n): ResolvedConfig {\n if (!overrides) {\n return { runtime: config.runtime, runner: config.runner };\n }\n\n const base: Record<string, unknown> =\n \"rawScope\" in config && config.rawScope\n ? { ...config.rawScope }\n : { ...(config.runtime as unknown as Record<string, unknown>) };\n\n const runtime = parseRuntime({\n ...base,\n ...(overrides.runtime !== undefined ? { type: overrides.runtime } : {}),\n ...(overrides.runtimeImage !== undefined ? { image: overrides.runtimeImage } : {}),\n ...(overrides.runtimeTemplate !== undefined\n ? { template_id: overrides.runtimeTemplate }\n : {}),\n ...(overrides.mountPoeCode === true\n ? { mounts: [...config.runtime.mounts, createPoeCodeMount(cwd)] }\n : {})\n });\n\n return {\n runtime,\n runner: {\n ...config.runner,\n ...(overrides.detach === true ? { detach: true } : {}),\n ...(overrides.runnerSync !== undefined ? { sync: overrides.runnerSync } : {})\n }\n };\n}\n\nfunction createPoeCodeMount(cwd: string): { source: string; target: string; readonly: boolean } {\n return {\n source: cwd,\n target: \"/usr/local/lib/poe-code\",\n readonly: true\n };\n}\n\nfunction loadRuntimeConfig(cwd: string, homeDir: string): LoadedRuntimeConfig {\n const document = deepMergeDocuments(\n readConfigDocument(resolveConfigPath(homeDir)),\n readConfigDocument(resolveProjectConfigPath(cwd))\n );\n const runtimeScope = resolveScope(runtimeConfigScope.schema, document.runtime, process.env);\n\n return {\n rawScope: { ...(runtimeScope as unknown as Record<string, unknown>) },\n runtime: parseRuntime(runtimeScope),\n runner: runtimeScope.runner\n };\n}\n\nfunction readConfigDocument(filePath: string): ConfigDocument {\n if (!existsSync(filePath)) {\n return {};\n }\n return JSON.parse(readFileSync(filePath, \"utf8\")) as ConfigDocument;\n}\n\nfunction loadState(homeDir: string): StateManager {\n if (process.env.VITEST === \"true\") {\n return createMemoryStateManager();\n }\n return createStateManager(homeDir);\n}\n\nfunction createMemoryStateManager(): StateManager {\n const jobs = new Map<string, JobEntry>();\n return {\n templates: {\n async get() {\n return null;\n },\n async put() {},\n async remove() {},\n async list() {\n return [];\n }\n },\n jobs: {\n async get(id) {\n return jobs.get(id) ?? null;\n },\n async put(entry) {\n jobs.set(entry.id, entry);\n },\n async update(id, patch) {\n const current = jobs.get(id);\n if (!current) {\n return null;\n }\n const updated = { ...current, ...patch, id };\n jobs.set(id, updated);\n return updated;\n },\n async list(filter?: JobListFilter) {\n const entries = Array.from(jobs.values());\n if (!filter) {\n return entries;\n }\n return entries.filter((entry) =>\n Object.entries(filter).every(([key, value]) => entry[key as keyof JobEntry] === value)\n );\n },\n async remove(id) {\n jobs.delete(id);\n }\n }\n };\n}\n", "import { existsSync } from \"node:fs\";\nimport path from \"node:path\";\nimport type { ResolvedConfig, SchemaField, ScopeDefinition } from \"./types.js\";\n\nexport interface RuntimeMount {\n source: string;\n target: string;\n readonly?: boolean;\n}\n\nexport interface RunnerScope {\n detach: boolean;\n upload_max_file_mb: number;\n download_conflict: \"refuse\" | \"overwrite\";\n sync: \"both\" | \"upload\" | \"none\";\n workspace?: {\n exclude?: string[];\n };\n}\n\ninterface SharedRuntimeFields {\n build_args: Record<string, string>;\n mounts: RuntimeMount[];\n link?: string;\n}\n\nexport interface HostRuntime extends SharedRuntimeFields {\n type: \"host\";\n}\n\nexport interface DockerRuntime extends SharedRuntimeFields {\n type: \"docker\";\n image?: string;\n dockerfile?: string;\n build_context?: string;\n engine?: \"docker\" | \"podman\";\n network?: string;\n extra_args?: string[];\n}\n\nexport interface E2bRuntime extends SharedRuntimeFields {\n type: \"e2b\";\n template_id?: string;\n from_template?: string;\n dockerfile?: string;\n build_context?: string;\n workspace_dir?: string;\n cpu?: number;\n memory_mb?: number;\n timeout_minutes?: number;\n preserve_after_exit_hours?: number;\n}\n\nexport type RuntimeConfig = HostRuntime | DockerRuntime | E2bRuntime;\nexport type RuntimeRunner = RuntimeConfig[\"type\"];\n\nconst defaultWorkspaceExclude = [\n \".git\",\n \"node_modules\",\n \"dist\",\n \".turbo\",\n \".next\",\n \".poe-code/state.json\"\n];\n\nexport interface RuntimeResolveResult {\n runtime: RuntimeConfig;\n runner: RuntimeRunner;\n dockerfilePath: string | null;\n buildContext: string | null;\n}\n\ntype RuntimeResolver = (input: { cwd: string; runtime: RuntimeConfig }) => RuntimeResolveResult;\n\nexport const runtimeConfigScope = {\n scope: \"runtime\",\n schema: {\n type: {\n type: \"string\",\n default: \"host\",\n doc: \"Runtime backend: host, docker, or e2b\"\n },\n build_args: {\n type: \"json\",\n default: {} as Record<string, string>,\n parse: parseBuildArgs,\n doc: \"Build arguments passed to the runtime image build\"\n },\n mounts: {\n type: \"json\",\n default: [] as RuntimeMount[],\n parse: parseMounts,\n doc: \"Additional runtime mounts\"\n },\n runner: {\n type: \"json\",\n default: createDefaultRunnerScope(),\n parse: parseRunner,\n doc: \"Runner process and workspace transfer settings\"\n },\n link: {\n type: \"string\",\n default: \"\",\n doc: \"Informational link for the runtime definition\"\n },\n image: {\n type: \"string\",\n default: \"\",\n doc: \"Prebuilt Docker image\"\n },\n dockerfile: {\n type: \"string\",\n default: \"\",\n doc: \"Path to the Dockerfile used for docker or e2b builds\"\n },\n build_context: {\n type: \"string\",\n default: \"\",\n doc: \"Path to the Docker build context\"\n },\n workspace_dir: {\n type: \"string\",\n default: \"/workspace\",\n doc: \"Sandbox-local workspace directory for E2B runtime upload, execution, and download\"\n },\n engine: {\n type: \"string\",\n default: \"\",\n doc: \"Container engine for Docker runtime\"\n },\n network: {\n type: \"string\",\n default: \"\",\n doc: \"Docker network\"\n },\n extra_args: {\n type: \"json\",\n default: undefined as string[] | undefined,\n parse: parseOptionalStringArray,\n doc: \"Extra Docker runtime arguments\"\n },\n template_id: {\n type: \"string\",\n default: \"\",\n doc: \"Prebuilt E2B template id\"\n },\n from_template: {\n type: \"string\",\n default: \"\",\n doc: \"Existing E2B template alias to extend instead of using the Dockerfile FROM image\"\n },\n cpu: {\n type: \"json\",\n default: undefined as number | undefined,\n parse: parseOptionalNumber,\n doc: \"E2B CPU count\"\n },\n memory_mb: {\n type: \"json\",\n default: undefined as number | undefined,\n parse: parseOptionalNumber,\n doc: \"E2B memory in megabytes\"\n },\n timeout_minutes: {\n type: \"json\",\n default: undefined as number | undefined,\n parse: parseOptionalNumber,\n doc: \"E2B timeout in minutes\"\n },\n preserve_after_exit_hours: {\n type: \"json\",\n default: undefined as number | undefined,\n parse: parseOptionalNumber,\n doc: \"Hours to keep an E2B sandbox alive after job exit\"\n }\n }\n} satisfies ScopeDefinition<Record<string, SchemaField>>;\n\nexport function parseRunner(raw: unknown): RunnerScope {\n if (raw === undefined) {\n return createDefaultRunnerScope();\n }\n const record = asRecord(raw);\n if (record === undefined) {\n throw new Error(\"runner: expected an object.\");\n }\n\n const uploadMaxFileMb =\n parseOptionalNumber(record.upload_max_file_mb, \"runner.upload_max_file_mb\") ?? 100;\n if (uploadMaxFileMb <= 0) {\n throw new Error(\"runner.upload_max_file_mb: expected a positive finite number.\");\n }\n\n return omitUndefined({\n detach: parseOptionalBoolean(record.detach, \"runner.detach\") ?? false,\n upload_max_file_mb: uploadMaxFileMb,\n download_conflict: parseDownloadConflict(record.download_conflict),\n sync: parseRunnerSync(record.sync),\n workspace: parseRunnerWorkspace(record.workspace)\n });\n}\n\nexport function parseRuntime(raw: unknown): RuntimeConfig {\n if (raw === undefined) {\n return {\n type: \"host\",\n build_args: {},\n mounts: []\n };\n }\n const record = asRecord(raw);\n if (record === undefined) {\n throw new Error(\"runtime: expected an object.\");\n }\n const type = parseRuntimeType(record.type);\n const shared = parseSharedRuntimeFields(record);\n\n if (type === \"docker\") {\n return omitUndefined({\n ...shared,\n type,\n image: parseOptionalString(record.image),\n dockerfile: parseOptionalString(record.dockerfile),\n build_context: parseOptionalString(record.build_context),\n engine: parseEngine(record.engine),\n network: parseOptionalString(record.network),\n extra_args: parseOptionalStringArray(record.extra_args)\n });\n }\n\n if (type === \"e2b\") {\n const preserveAfterExitHours = parseOptionalNumber(record.preserve_after_exit_hours) ?? 24;\n if (preserveAfterExitHours < 0 || preserveAfterExitHours > 168) {\n throw new Error(\"preserve_after_exit_hours: expected a number from 0 to 168.\");\n }\n\n return omitUndefined({\n ...shared,\n type,\n template_id: parseOptionalString(record.template_id),\n from_template: parseOptionalString(record.from_template),\n dockerfile: parseOptionalString(record.dockerfile),\n build_context: parseOptionalString(record.build_context),\n workspace_dir: parseWorkspaceDir(record.workspace_dir),\n cpu: parseOptionalNumber(record.cpu),\n memory_mb: parseOptionalNumber(record.memory_mb),\n timeout_minutes: parseOptionalNumber(record.timeout_minutes),\n preserve_after_exit_hours: preserveAfterExitHours\n });\n }\n\n return {\n ...shared,\n type\n };\n}\n\nexport function resolveRuntime({\n cwd,\n config\n}: {\n cwd: string;\n config: Pick<ResolvedConfig, \"runtime\">;\n}): RuntimeResolveResult {\n const runtime = config.runtime;\n return runtimeResolvers[runtime.type]({ cwd, runtime });\n}\n\nconst runtimeResolvers: Record<RuntimeConfig[\"type\"], RuntimeResolver> = {\n host({ runtime }) {\n return {\n runtime,\n runner: \"host\",\n dockerfilePath: null,\n buildContext: null\n };\n },\n docker({ cwd, runtime }) {\n const dockerRuntime = runtime as DockerRuntime;\n const { dockerfilePath, buildContext } = resolveRuntimeBuildPaths(cwd, dockerRuntime);\n\n if (dockerRuntime.image !== undefined) {\n return {\n runtime: dockerRuntime,\n runner: \"docker\",\n dockerfilePath: null,\n buildContext: null\n };\n }\n if (!existsSync(dockerfilePath)) {\n throw new Error(`Docker runtime requires image or a Dockerfile at ${dockerfilePath}.`);\n }\n return {\n runtime: dockerRuntime,\n runner: \"docker\",\n dockerfilePath,\n buildContext\n };\n },\n e2b({ cwd, runtime }) {\n const e2bRuntime = runtime as E2bRuntime;\n const { dockerfilePath, buildContext } = resolveRuntimeBuildPaths(cwd, e2bRuntime);\n\n if (e2bRuntime.template_id !== undefined) {\n return {\n runtime: e2bRuntime,\n runner: \"e2b\",\n dockerfilePath: null,\n buildContext: null\n };\n }\n if (!existsSync(dockerfilePath)) {\n throw new Error(`E2B runtime requires template_id or a Dockerfile at ${dockerfilePath}.`);\n }\n return {\n runtime: e2bRuntime,\n runner: \"e2b\",\n dockerfilePath,\n buildContext\n };\n }\n};\n\nfunction resolveRuntimeBuildPaths(\n cwd: string,\n runtime: DockerRuntime | E2bRuntime\n): { dockerfilePath: string; buildContext: string } {\n return {\n dockerfilePath: path.resolve(cwd, runtime.dockerfile ?? path.join(\".poe-code\", \"Dockerfile\")),\n buildContext: path.resolve(cwd, runtime.build_context ?? \".\")\n };\n}\n\nfunction parseSharedRuntimeFields(record: Record<string, unknown>): SharedRuntimeFields {\n return omitUndefined({\n build_args: parseBuildArgs(record.build_args),\n mounts: parseMounts(record.mounts),\n link: parseOptionalString(record.link)\n });\n}\n\nfunction parseRuntimeType(value: unknown): RuntimeConfig[\"type\"] {\n if (value === undefined) {\n return \"host\";\n }\n if (value === \"host\" || value === \"docker\" || value === \"e2b\") {\n return value;\n }\n throw new Error('type: expected \"host\", \"docker\", or \"e2b\".');\n}\n\nfunction parseWorkspaceDir(value: unknown): string {\n const workspaceDir = parseOptionalString(value) ?? \"/workspace\";\n if (!path.posix.isAbsolute(workspaceDir)) {\n throw new Error(\"workspace_dir: expected an absolute sandbox path.\");\n }\n let normalized = path.posix.normalize(workspaceDir);\n while (normalized.length > 1 && normalized.endsWith(\"/\")) {\n normalized = normalized.slice(0, -1);\n }\n return normalized;\n}\n\nfunction createDefaultRunnerScope(): RunnerScope {\n return {\n detach: false,\n upload_max_file_mb: 100,\n download_conflict: \"refuse\",\n sync: \"both\",\n workspace: {\n exclude: [...defaultWorkspaceExclude]\n }\n };\n}\n\nfunction parseRunnerWorkspace(value: unknown): RunnerScope[\"workspace\"] {\n if (value === undefined) {\n return {\n exclude: [...defaultWorkspaceExclude]\n };\n }\n const record = asRecord(value);\n if (record === undefined) {\n throw new Error(\"runner.workspace: expected an object.\");\n }\n\n return {\n exclude: parseOptionalStringArray(record.exclude, \"runner.workspace.exclude\") ?? [\n ...defaultWorkspaceExclude\n ]\n };\n}\n\nfunction parseDownloadConflict(value: unknown): RunnerScope[\"download_conflict\"] {\n if (value === undefined) {\n return \"refuse\";\n }\n if (value === \"refuse\" || value === \"overwrite\") {\n return value;\n }\n throw new Error('runner.download_conflict: expected \"refuse\" or \"overwrite\".');\n}\n\nfunction parseRunnerSync(value: unknown): RunnerScope[\"sync\"] {\n if (value === undefined) {\n return \"both\";\n }\n if (value === \"both\" || value === \"upload\" || value === \"none\") {\n return value;\n }\n throw new Error('runner.sync: expected \"both\", \"upload\", or \"none\".');\n}\n\nfunction parseBuildArgs(value: unknown): Record<string, string> {\n if (value === undefined) {\n return {};\n }\n const record = asRecord(value);\n if (record === undefined) {\n throw new Error(\"build_args: expected an object.\");\n }\n\n const parsed: Record<string, string> = {};\n for (const [key, entry] of Object.entries(record)) {\n if (typeof entry !== \"string\") {\n throw new Error(`build_args.${key}: expected a string.`);\n }\n parsed[key] = entry;\n }\n return parsed;\n}\n\nfunction parseMounts(value: unknown): RuntimeMount[] {\n if (value === undefined) {\n return [];\n }\n if (!Array.isArray(value)) {\n throw new Error(\"mounts: expected an array.\");\n }\n\n return value.map((entry, index) => {\n const record = asRecord(entry);\n if (record === undefined) {\n throw new Error(`mounts[${index}]: expected an object.`);\n }\n const source = record.source;\n const target = record.target;\n if (typeof source !== \"string\") {\n throw new Error(`mounts[${index}].source: expected a string.`);\n }\n if (typeof target !== \"string\") {\n throw new Error(`mounts[${index}].target: expected a string.`);\n }\n\n return omitUndefined({\n source,\n target,\n readonly: parseOptionalBoolean(record.readonly, `mounts[${index}].readonly`)\n });\n });\n}\n\nfunction parseOptionalString(value: unknown): string | undefined {\n if (value === undefined) {\n return undefined;\n }\n if (typeof value !== \"string\") {\n throw new Error(\"expected a string.\");\n }\n if (value.length === 0) {\n return undefined;\n }\n return value;\n}\n\nfunction parseOptionalStringArray(value: unknown, key = \"\"): string[] | undefined {\n if (value === undefined) {\n return undefined;\n }\n if (!Array.isArray(value)) {\n throw new Error(`${key ? `${key}: ` : \"\"}expected an array.`);\n }\n return value.map((entry, index) => {\n if (typeof entry !== \"string\") {\n throw new Error(`${key}[${index}]: expected a string.`);\n }\n return entry;\n });\n}\n\nfunction parseEngine(value: unknown): \"docker\" | \"podman\" | undefined {\n const engine = parseOptionalString(value);\n if (engine === undefined || engine === \"docker\" || engine === \"podman\") {\n return engine;\n }\n throw new Error('engine: expected \"docker\" or \"podman\".');\n}\n\nfunction parseOptionalNumber(value: unknown, key = \"\"): number | undefined {\n if (value === undefined) {\n return undefined;\n }\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`${key ? `${key}: ` : \"\"}expected a finite number.`);\n }\n return value;\n}\n\nfunction parseOptionalBoolean(value: unknown, key: string): boolean | undefined {\n if (value === undefined) {\n return undefined;\n }\n if (typeof value !== \"boolean\") {\n throw new Error(`${key}: expected a boolean.`);\n }\n return value;\n}\n\nfunction asRecord(value: unknown): Record<string, unknown> | undefined {\n if (!value || typeof value !== \"object\" || Array.isArray(value)) {\n return undefined;\n }\n return value as Record<string, unknown>;\n}\n\nfunction omitUndefined<T extends Record<string, unknown>>(value: T): T {\n return Object.fromEntries(Object.entries(value).filter(([, entry]) => entry !== undefined)) as T;\n}\n", "import type {\n BraintrustIntegrationConfig,\n ScopeDefinition,\n ScopeSchema\n} from \"./types.js\";\n\nexport function defineScope<const S extends ScopeSchema>(\n scope: string,\n schema: S\n): ScopeDefinition<S> {\n return {\n scope,\n schema\n };\n}\n\nexport const integrationsConfigScope = defineScope(\"integrations\", {\n braintrust: {\n type: \"json\",\n default: {\n enabled: false\n } satisfies BraintrustIntegrationConfig,\n parse: parseBraintrustIntegrationConfig,\n doc: \"Braintrust integration configuration\"\n }\n});\n\nexport { runtimeConfigScope } from \"./runtime.js\";\n\nfunction parseBraintrustIntegrationConfig(value: unknown): BraintrustIntegrationConfig {\n if (!isRecord(value)) {\n throw new Error(\"expected an object\");\n }\n\n const enabled = value.enabled === undefined ? false : value.enabled;\n if (typeof enabled !== \"boolean\") {\n throw new Error(\"enabled must be a boolean\");\n }\n\n return {\n enabled,\n ...optionalStringEntry(\"apiKey\", value.apiKey),\n ...optionalStringEntry(\"apiUrl\", value.apiUrl),\n ...optionalStringEntry(\"project\", value.project)\n };\n}\n\nfunction optionalStringEntry(key: string, value: unknown): Record<string, string> {\n if (value === undefined) {\n return {};\n }\n\n if (typeof value !== \"string\") {\n throw new Error(`${key} must be a string`);\n }\n\n return { [key]: value };\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n", "import { defineScope } from \"./schema.js\";\n\nexport const planConfigScope = defineScope(\"plan\", {\n plan_directory: {\n type: \"string\",\n default: \"docs/plans\",\n env: \"POE_PLAN_DIRECTORY\",\n doc: \"Directory where planning documents are stored\"\n }\n});\n", "import path from \"node:path\";\nimport { resolve, type FileSystem as ResolveFileSystem } from \"@poe-code/config-extends\";\nimport { createTimestamp, isNotFound, type FileSystem } from \"@poe-code/config-mutations\";\nimport type { ConfigDocument } from \"./types.js\";\n\nexport async function readDocument(fs: FileSystem, filePath: string): Promise<ConfigDocument> {\n const document = await readStoredDocument(fs, filePath);\n return document.data;\n}\n\nexport async function writeScope(\n fs: FileSystem,\n filePath: string,\n scope: string,\n values: Record<string, unknown>\n): Promise<void> {\n const document = await readDocument(fs, filePath);\n const normalizedValues = normalizeScopeValues(values);\n\n if (Object.keys(normalizedValues).length === 0) {\n delete document[scope];\n } else {\n document[scope] = normalizedValues;\n }\n\n await writeDocument(fs, filePath, document);\n}\n\nexport async function readMergedDocument(\n fs: FileSystem,\n globalPath: string,\n projectPath?: string\n): Promise<ConfigDocument> {\n const globalDocument = await readStoredDocument(fs, globalPath);\n if (!projectPath || projectPath === globalPath) {\n return globalDocument.data;\n }\n\n const projectDocument = await readStoredDocument(fs, projectPath);\n const resolved = await resolve(\n [\n {\n source: \"project\",\n filePath: projectPath,\n content: projectDocument.content\n },\n {\n source: \"base\",\n path: path.dirname(globalPath)\n }\n ],\n {\n fs: createResolvedConfigFs(fs, globalPath, globalDocument.content),\n autoExtend: true\n }\n );\n\n return normalizeDocument(resolved.data);\n}\n\nasync function readStoredDocument(\n fs: FileSystem,\n filePath: string\n): Promise<{ content: string; data: ConfigDocument }> {\n try {\n const raw = await fs.readFile(filePath, \"utf8\");\n return await parseStoredDocument(fs, filePath, raw);\n } catch (error) {\n if (isNotFound(error)) {\n return {\n content: EMPTY_DOCUMENT,\n data: {}\n };\n }\n\n throw error;\n }\n}\n\nasync function parseStoredDocument(\n fs: FileSystem,\n filePath: string,\n raw: string\n): Promise<{ content: string; data: ConfigDocument }> {\n try {\n return {\n content: raw,\n data: normalizeDocument(JSON.parse(raw))\n };\n } catch (error) {\n if (error instanceof SyntaxError) {\n await recoverInvalidDocument(fs, filePath, raw);\n return {\n content: EMPTY_DOCUMENT,\n data: {}\n };\n }\n throw error;\n }\n}\n\nfunction normalizeDocument(value: unknown): ConfigDocument {\n if (!isRecord(value)) {\n return {};\n }\n\n const document: ConfigDocument = {};\n for (const [scope, scopeValues] of Object.entries(value)) {\n const normalizedValues = normalizeScopeValues(scopeValues);\n if (Object.keys(normalizedValues).length > 0) {\n document[scope] = normalizedValues;\n }\n }\n\n return document;\n}\n\nfunction normalizeScopeValues(value: unknown): Record<string, unknown> {\n if (!isRecord(value)) {\n return {};\n }\n\n const normalized: Record<string, unknown> = {};\n for (const [key, entry] of Object.entries(value)) {\n if (entry !== undefined) {\n normalized[key] = entry;\n }\n }\n\n return normalized;\n}\n\nfunction createResolvedConfigFs(\n fs: FileSystem,\n globalPath: string,\n globalContent: string\n): ResolveFileSystem {\n return {\n readFile(filePath: string, _encoding: BufferEncoding) {\n if (filePath === globalPath) {\n return Promise.resolve(globalContent);\n }\n\n return fs.readFile(filePath, \"utf8\");\n }\n };\n}\n\nasync function writeDocument(\n fs: FileSystem,\n filePath: string,\n document: ConfigDocument\n): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n await fs.writeFile(filePath, `${JSON.stringify(document, null, 2)}\\n`, {\n encoding: \"utf8\"\n });\n}\n\nasync function recoverInvalidDocument(\n fs: FileSystem,\n filePath: string,\n content: string\n): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n const backupPath = createInvalidBackupPath(filePath);\n await fs.writeFile(backupPath, content, { encoding: \"utf8\" });\n await fs.writeFile(filePath, EMPTY_DOCUMENT, { encoding: \"utf8\" });\n}\n\nfunction createInvalidBackupPath(filePath: string): string {\n const directory = path.dirname(filePath);\n const baseName = path.basename(filePath);\n return path.join(directory, `${baseName}.invalid-${createTimestamp()}.json`);\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value && typeof value === \"object\" && !Array.isArray(value));\n}\n\nexport function resolveConfigPath(homeDir: string): string {\n return path.join(homeDir, \".poe-code\", \"config.json\");\n}\n\nexport function resolveServicesConfigPath(homeDir: string): string {\n return path.join(homeDir, \".config\", \"poe-code\", \"services.json\");\n}\n\nexport function resolveProjectConfigPath(cwd: string): string {\n return path.join(cwd, \".poe-code\", \"config.json\");\n}\n\nconst EMPTY_DOCUMENT = `${JSON.stringify({}, null, 2)}\\n`;\n", "import path from \"node:path\";\nimport type { FileSystem } from \"./types.js\";\n\nexport interface DiscoveredBase {\n content: string;\n filePath: string;\n}\n\nexport async function findBase(\n name: string,\n bases: string[],\n fs: FileSystem\n): Promise<DiscoveredBase> {\n const checkedPaths: string[] = [];\n\n for (const basePath of bases) {\n for (const extension of [\".md\", \".yaml\", \".yml\", \".json\"]) {\n const filePath = path.join(basePath, `${name}${extension}`);\n checkedPaths.push(filePath);\n\n try {\n return {\n content: await fs.readFile(filePath, \"utf8\"),\n filePath\n };\n } catch (error) {\n if (hasCode(error, \"ENOENT\")) {\n continue;\n }\n\n throw error;\n }\n }\n }\n\n throw new Error(`Base \"${name}\" not found.\\nChecked paths:\\n- ${checkedPaths.join(\"\\n- \")}`);\n}\n\nfunction hasCode(error: unknown, code: string): error is NodeJS.ErrnoException {\n return (\n typeof error === \"object\" &&\n error !== null &&\n \"code\" in error &&\n error.code === code\n );\n}\n", "import path from \"node:path\";\nimport matter from \"gray-matter\";\nimport { parse as parseYaml } from \"yaml\";\nimport type { ParsedDocument } from \"./types.js\";\n\nexport function parseDocument(content: string, filePath: string): ParsedDocument {\n const normalizedContent = stripBom(content);\n const format = detectFormat(normalizedContent, filePath);\n const data =\n format === \"markdown\"\n ? parseMarkdown(normalizedContent)\n : toData(format === \"json\" ? JSON.parse(normalizedContent) : parseYaml(normalizedContent));\n const hasExtendsField = Object.hasOwn(data, \"extends\");\n const extendsValue = data.extends === true;\n\n delete data.extends;\n\n return {\n data,\n format,\n extends: extendsValue,\n hasExtendsField\n };\n}\n\nfunction detectFormat(\n content: string,\n filePath: string\n): ParsedDocument[\"format\"] {\n const extension = path.extname(filePath).toLowerCase();\n\n if (extension === \".md\") {\n return \"markdown\";\n }\n\n if (extension === \".yaml\" || extension === \".yml\") {\n return \"yaml\";\n }\n\n if (extension === \".json\") {\n return \"json\";\n }\n\n if (content.startsWith(\"{\")) {\n return \"json\";\n }\n\n if (content.startsWith(\"---\\n\") || content.startsWith(\"---\\r\\n\")) {\n return \"markdown\";\n }\n\n return \"yaml\";\n}\n\nfunction parseMarkdown(content: string): Record<string, unknown> {\n const document = matter(content);\n return {\n ...toData(document.data),\n prompt: document.content\n };\n}\n\nfunction toData(value: unknown): Record<string, unknown> {\n if (!value || typeof value !== \"object\" || Array.isArray(value)) {\n return {};\n }\n\n return { ...(value as Record<string, unknown>) };\n}\n\nfunction stripBom(content: string): string {\n if (!content.startsWith(\"\\uFEFF\")) {\n return content;\n }\n\n return content.slice(1);\n}\n", "import type { DataLayer } from \"./types.js\";\n\nexport interface MergeLayersResult {\n data: Record<string, unknown>;\n sources: Record<string, string>;\n}\n\nexport function mergeLayers(layers: DataLayer[]): MergeLayersResult {\n return mergeObjectLayers(layers, []);\n}\n\nfunction mergeObjectLayers(layers: DataLayer[], path: string[]): MergeLayersResult {\n const data: Record<string, unknown> = {};\n const sources: Record<string, string> = {};\n\n for (const key of collectKeys(layers)) {\n const resolved = resolveKey(layers, key, path);\n\n if (resolved === undefined) {\n continue;\n }\n\n data[key] = resolved.value;\n Object.assign(sources, resolved.sources);\n }\n\n return { data, sources };\n}\n\nfunction collectKeys(layers: DataLayer[]): string[] {\n const keys = new Set<string>();\n\n for (const layer of layers) {\n for (const key of Object.keys(layer.data)) {\n keys.add(key);\n }\n }\n\n return [...keys];\n}\n\nfunction resolveKey(\n layers: DataLayer[],\n key: string,\n path: string[]\n): { value: unknown; sources: Record<string, string> } | undefined {\n let winningSource: string | undefined;\n let winningValue: unknown;\n const objectLayers: DataLayer[] = [];\n\n for (const layer of layers) {\n const candidate = layer.data[key];\n\n if (!isWinningCandidate(key, candidate)) {\n continue;\n }\n\n if (winningSource === undefined) {\n winningSource = layer.source;\n winningValue = candidate;\n\n if (isPlainObject(candidate)) {\n objectLayers.push({\n source: layer.source,\n data: candidate\n });\n }\n\n continue;\n }\n\n if (isPlainObject(winningValue) && isPlainObject(candidate)) {\n objectLayers.push({\n source: layer.source,\n data: candidate\n });\n }\n }\n\n if (winningSource === undefined) {\n return undefined;\n }\n\n const fullPath = buildPath(path, key);\n\n if (isPlainObject(winningValue)) {\n const merged = mergeObjectLayers(objectLayers, [...path, key]);\n\n return {\n value: merged.data,\n sources: {\n [fullPath]: winningSource,\n ...merged.sources\n }\n };\n }\n\n return {\n value: cloneValue(winningValue),\n sources: {\n [fullPath]: winningSource\n }\n };\n}\n\nfunction isWinningCandidate(key: string, value: unknown): boolean {\n if (value === undefined) {\n return false;\n }\n\n if (key === \"prompt\" && value === \"\") {\n return false;\n }\n\n return true;\n}\n\nfunction buildPath(path: string[], key: string): string {\n return [...path, key].join(\".\");\n}\n\nfunction isPlainObject(value: unknown): value is Record<string, unknown> {\n if (value === null || Array.isArray(value) || typeof value !== \"object\") {\n return false;\n }\n\n const prototype = Object.getPrototypeOf(value);\n return prototype === Object.prototype || prototype === null;\n}\n\nfunction cloneValue(value: unknown): unknown {\n if (Array.isArray(value)) {\n return value.map((entry) => cloneValue(entry));\n }\n\n if (!isPlainObject(value)) {\n return value;\n }\n\n const clone = Object.create(Object.getPrototypeOf(value)) as Record<string, unknown>;\n\n for (const [key, entry] of Object.entries(value)) {\n clone[key] = cloneValue(entry);\n }\n\n return clone;\n}\n", "import path from \"node:path\";\nimport { renderTemplate } from \"@poe-code/design-system\";\nimport { findBase } from \"./discover.js\";\nimport { mergeLayers } from \"./merge.js\";\nimport { parseDocument } from \"./parse.js\";\nimport type {\n BaseLayer,\n ChainLayer,\n DataLayer,\n DocumentLayer,\n ResolveOptions,\n ResolvedDocument\n} from \"./types.js\";\n\nconst MAX_EXTENDS_DEPTH = 5;\nconst YIELD_TOKEN = \"{{yield}}\";\n\ninterface ClassifiedChain {\n baseLayers: BaseLayer[];\n documentIndex: number;\n documentLayer: DocumentLayer;\n}\n\ninterface ResolvedBaseChain {\n chain: string[];\n layers: DataLayer[];\n}\n\nexport async function resolve(\n chain: ChainLayer[],\n options: ResolveOptions\n): Promise<ResolvedDocument> {\n const { baseLayers, documentIndex, documentLayer } = classifyChain(chain);\n const parsedDocument = parseDocument(documentLayer.content, documentLayer.filePath);\n const resolvedBase = shouldResolveBase(parsedDocument, options.autoExtend)\n ? await resolveBaseChain({\n name: documentLayer.baseName ?? getBaseName(documentLayer.filePath),\n baseLayers,\n options,\n optional: !parsedDocument.extends,\n visited: new Set([documentLayer.filePath]),\n depth: 1\n })\n : undefined;\n const composedPrompt = composePromptChain(\n {\n source: documentLayer.source,\n data: parsedDocument.data\n },\n resolvedBase?.layers ?? []\n );\n const merged = mergeLayers([\n ...collectDataLayers(chain.slice(0, documentIndex)),\n {\n source: documentLayer.source,\n data: withResolvedPrompt(parsedDocument.data, composedPrompt?.prompt)\n },\n ...stripResolvedBasePrompts(resolvedBase?.layers ?? [], composedPrompt?.consumedBaseIndexes ?? new Set<number>()),\n ...collectDataLayers(chain.slice(documentIndex + 1))\n ]);\n\n if (composedPrompt !== undefined && merged.sources.prompt === documentLayer.source && composedPrompt.source !== undefined) {\n merged.sources.prompt = composedPrompt.source;\n }\n\n return {\n data: merged.data,\n sources: merged.sources,\n chain: [documentLayer.filePath, ...(resolvedBase?.chain ?? [])]\n };\n}\n\nfunction classifyChain(chain: ChainLayer[]): ClassifiedChain {\n const baseLayers: BaseLayer[] = [];\n const documentLayers: Array<{ index: number; layer: DocumentLayer }> = [];\n\n for (const [index, layer] of chain.entries()) {\n if (isDataLayer(layer)) {\n continue;\n }\n\n if (isDocumentLayer(layer)) {\n documentLayers.push({ index, layer });\n continue;\n }\n\n if (isBaseLayer(layer)) {\n baseLayers.push(layer);\n }\n }\n\n if (documentLayers.length !== 1) {\n throw new Error(`Exactly one document layer is required, received ${documentLayers.length}.`);\n }\n\n return {\n baseLayers,\n documentIndex: documentLayers[0].index,\n documentLayer: documentLayers[0].layer\n };\n}\n\nasync function resolveBaseChain({\n name,\n baseLayers,\n options,\n optional,\n visited,\n depth\n}: {\n name: string;\n baseLayers: BaseLayer[];\n options: ResolveOptions;\n optional: boolean;\n visited: Set<string>;\n depth: number;\n}): Promise<ResolvedBaseChain | undefined> {\n if (depth > MAX_EXTENDS_DEPTH) {\n throw new Error(`Maximum extends depth exceeded (${MAX_EXTENDS_DEPTH}).`);\n }\n\n let discoveredBase;\n\n try {\n discoveredBase = await findBase(\n name,\n baseLayers.map((layer) => layer.path),\n options.fs\n );\n } catch (error) {\n if (optional && isBaseNotFoundError(error)) {\n return undefined;\n }\n\n throw error;\n }\n\n if (visited.has(discoveredBase.filePath)) {\n if (optional) {\n return undefined;\n }\n\n throw new Error(\n `Circular extends detected.\\nVisited files:\\n- ${[...visited, discoveredBase.filePath].join(\"\\n- \")}`\n );\n }\n\n const matchedBaseIndex = baseLayers.findIndex(\n (layer) => layer.path === path.dirname(discoveredBase.filePath)\n );\n\n if (matchedBaseIndex === -1) {\n throw new Error(`Resolved base is outside configured base paths: ${discoveredBase.filePath}`);\n }\n\n const parsedBase = parseDocument(discoveredBase.content, discoveredBase.filePath);\n const nextVisited = new Set(visited);\n nextVisited.add(discoveredBase.filePath);\n const nestedBase = parsedBase.extends\n ? await resolveBaseChain({\n name: getBaseName(discoveredBase.filePath),\n baseLayers: baseLayers.slice(matchedBaseIndex + 1),\n options,\n optional: false,\n visited: nextVisited,\n depth: depth + 1\n })\n : undefined;\n\n return {\n layers: [\n {\n source: baseLayers[matchedBaseIndex].source,\n data: parsedBase.data\n },\n ...(nestedBase?.layers ?? [])\n ],\n chain: [discoveredBase.filePath, ...(nestedBase?.chain ?? [])]\n };\n}\n\nfunction collectDataLayers(chain: ChainLayer[]): DataLayer[] {\n return chain.filter(isDataLayer);\n}\n\ninterface ComposedPromptResult {\n consumedBaseIndexes: Set<number>;\n prompt: string;\n source?: string;\n}\n\nfunction composePromptChain(\n documentLayer: DataLayer,\n baseLayers: DataLayer[]\n): ComposedPromptResult | undefined {\n const documentPrompt = documentLayer.data.prompt;\n\n if (documentPrompt !== undefined && typeof documentPrompt !== \"string\") {\n return undefined;\n }\n\n if (documentPrompt !== undefined) {\n assertValidYieldCount(documentPrompt);\n }\n\n let prompt = documentPrompt;\n let source = prompt === undefined || prompt === \"\" ? undefined : documentLayer.source;\n const consumedBaseIndexes = new Set<number>();\n\n for (const [index, layer] of baseLayers.entries()) {\n const candidate = layer.data.prompt;\n\n if (candidate === undefined) {\n continue;\n }\n\n if (typeof candidate !== \"string\") {\n break;\n }\n\n assertValidYieldCount(candidate);\n consumedBaseIndexes.add(index);\n prompt = composeAdjacentPrompts(prompt, candidate);\n\n if (source === undefined && candidate !== \"\") {\n source = layer.source;\n }\n }\n\n if (prompt !== undefined && prompt.includes(YIELD_TOKEN)) {\n throw new Error('Final resolved prompt contains an unresolved \"{{yield}}\" token.');\n }\n\n if (prompt === undefined) {\n return undefined;\n }\n\n return {\n consumedBaseIndexes,\n prompt,\n source\n };\n}\n\nfunction composeAdjacentPrompts(\n high: string | undefined,\n low: string\n): string {\n if (high === undefined || high === \"\") {\n return low.includes(YIELD_TOKEN) ? replaceYield(low, \"\") : low;\n }\n\n if (high.includes(YIELD_TOKEN)) {\n return replaceYield(high, low);\n }\n\n if (low.includes(YIELD_TOKEN)) {\n return replaceYield(low, high);\n }\n\n return high;\n}\n\nfunction replaceYield(\n prompt: string,\n replacement: string\n): string {\n return renderTemplate(prompt, {}, { yield: replacement, escape: \"none\" });\n}\n\nfunction assertValidYieldCount(prompt: string): void {\n if (countYieldTokens(prompt) > 1) {\n throw new Error('Prompt composition supports exactly one \"{{yield}}\" token per prompt.');\n }\n}\n\nfunction countYieldTokens(prompt: string): number {\n return prompt.split(YIELD_TOKEN).length - 1;\n}\n\nfunction withResolvedPrompt(\n data: Record<string, unknown>,\n prompt: string | undefined\n): Record<string, unknown> {\n if (prompt === undefined) {\n return data;\n }\n\n return {\n ...data,\n prompt\n };\n}\n\nfunction stripResolvedBasePrompts(\n layers: DataLayer[],\n consumedBaseIndexes: Set<number>\n): DataLayer[] {\n return layers.map((layer, index) => {\n if (!consumedBaseIndexes.has(index) || typeof layer.data.prompt !== \"string\") {\n return layer;\n }\n\n const { prompt: ignoredPrompt, ...data } = layer.data;\n\n void ignoredPrompt;\n\n return {\n source: layer.source,\n data\n };\n });\n}\n\nfunction getBaseName(filePath: string): string {\n return path.basename(filePath, path.extname(filePath));\n}\n\nfunction shouldResolveBase(\n parsedDocument: ReturnType<typeof parseDocument>,\n autoExtend: boolean | undefined\n): boolean {\n return parsedDocument.extends || (autoExtend === true && !parsedDocument.hasExtendsField);\n}\n\nfunction isBaseNotFoundError(error: unknown): error is Error {\n return (\n error instanceof Error &&\n error.message.startsWith('Base \"') &&\n error.message.includes('\" not found.\\nChecked paths:')\n );\n}\n\nfunction isDataLayer(layer: ChainLayer): layer is DataLayer {\n return \"data\" in layer;\n}\n\nfunction isDocumentLayer(layer: ChainLayer): layer is DocumentLayer {\n return \"filePath\" in layer && \"content\" in layer;\n}\n\nfunction isBaseLayer(layer: ChainLayer): layer is BaseLayer {\n return \"path\" in layer;\n}\n", "export interface ColorSupportEnv {\n NO_COLOR?: string;\n FORCE_COLOR?: string;\n TERM?: string;\n}\n\nexport interface ColorSupportStream {\n isTTY?: boolean;\n}\n\nexport function supportsColor(\n env: ColorSupportEnv = process.env as ColorSupportEnv,\n stream: ColorSupportStream = process.stdout\n): boolean {\n if (env.FORCE_COLOR !== undefined && env.FORCE_COLOR !== \"0\") {\n return true;\n }\n\n if (env.NO_COLOR !== undefined) {\n return false;\n }\n\n if (stream.isTTY !== true) {\n return false;\n }\n\n return typeof env.TERM === \"string\" && env.TERM.length > 0 && env.TERM !== \"dumb\";\n}\n", "import { supportsColor } from \"../internal/color-support.js\";\n\ntype AnsiStyleName =\n | \"reset\"\n | \"bold\"\n | \"dim\"\n | \"italic\"\n | \"underline\"\n | \"inverse\"\n | \"strikethrough\"\n | \"black\"\n | \"red\"\n | \"green\"\n | \"yellow\"\n | \"blue\"\n | \"magenta\"\n | \"cyan\"\n | \"white\"\n | \"gray\"\n | \"magentaBright\"\n | \"cyanBright\"\n | \"bgRed\"\n | \"bgGreen\"\n | \"bgYellow\"\n | \"bgBlue\"\n | \"bgMagenta\";\n\ninterface AnsiPair {\n open: string;\n}\n\nexport interface Color {\n (text: string): string;\n reset: Color;\n bold: Color;\n dim: Color;\n italic: Color;\n underline: Color;\n inverse: Color;\n strikethrough: Color;\n black: Color;\n red: Color;\n green: Color;\n yellow: Color;\n blue: Color;\n magenta: Color;\n cyan: Color;\n white: Color;\n gray: Color;\n magentaBright: Color;\n cyanBright: Color;\n bgRed: Color;\n bgGreen: Color;\n bgYellow: Color;\n bgBlue: Color;\n bgMagenta: Color;\n hex: (value: string) => Color;\n rgb: (red: number, green: number, blue: number) => Color;\n bgHex: (value: string) => Color;\n bgRgb: (red: number, green: number, blue: number) => Color;\n}\n\nconst reset = \"\\x1b[0m\";\n\nconst ansiStyles: Record<AnsiStyleName, AnsiPair> = {\n reset: { open: reset },\n bold: { open: \"\\x1b[1m\" },\n dim: { open: \"\\x1b[2m\" },\n italic: { open: \"\\x1b[3m\" },\n underline: { open: \"\\x1b[4m\" },\n inverse: { open: \"\\x1b[7m\" },\n strikethrough: { open: \"\\x1b[9m\" },\n black: { open: \"\\x1b[30m\" },\n red: { open: \"\\x1b[31m\" },\n green: { open: \"\\x1b[32m\" },\n yellow: { open: \"\\x1b[33m\" },\n blue: { open: \"\\x1b[34m\" },\n magenta: { open: \"\\x1b[35m\" },\n cyan: { open: \"\\x1b[36m\" },\n white: { open: \"\\x1b[37m\" },\n gray: { open: \"\\x1b[90m\" },\n magentaBright: { open: \"\\x1b[95m\" },\n cyanBright: { open: \"\\x1b[96m\" },\n bgRed: { open: \"\\x1b[41m\" },\n bgGreen: { open: \"\\x1b[42m\" },\n bgYellow: { open: \"\\x1b[43m\" },\n bgBlue: { open: \"\\x1b[44m\" },\n bgMagenta: { open: \"\\x1b[45m\" }\n};\n\nconst styleNames = Object.keys(ansiStyles) as AnsiStyleName[];\n\nfunction replaceAll(value: string, search: string, replacement: string): string {\n return value.split(search).join(replacement);\n}\n\nfunction applyStyles(text: string, styles: AnsiPair[]): string {\n if (!supportsColor() || styles.length === 0) {\n return text;\n }\n\n const open = styles.map((style) => style.open).join(\"\");\n const output = text.includes(reset) ? replaceAll(text, reset, `${reset}${open}`) : text;\n\n return `${open}${output}${reset}`;\n}\n\nfunction clampRgb(value: number): number {\n if (Number.isNaN(value)) {\n return 0;\n }\n\n return Math.min(255, Math.max(0, Math.round(value)));\n}\n\nfunction hexChannel(value: string, offset: number): number {\n return Number.parseInt(value.slice(offset, offset + 2), 16);\n}\n\nfunction normalizeHex(value: string): [number, number, number] {\n const normalized = value.startsWith(\"#\") ? value.slice(1) : value;\n\n if (normalized.length === 3) {\n const red = normalized[0]!;\n const green = normalized[1]!;\n const blue = normalized[2]!;\n\n return [\n Number.parseInt(`${red}${red}`, 16),\n Number.parseInt(`${green}${green}`, 16),\n Number.parseInt(`${blue}${blue}`, 16)\n ];\n }\n\n if (normalized.length === 6) {\n return [\n hexChannel(normalized, 0),\n hexChannel(normalized, 2),\n hexChannel(normalized, 4)\n ];\n }\n\n return [0, 0, 0];\n}\n\nfunction rgbStyle(red: number, green: number, blue: number): AnsiPair {\n return {\n open: `\\x1b[38;2;${clampRgb(red)};${clampRgb(green)};${clampRgb(blue)}m`\n };\n}\n\nfunction bgRgbStyle(red: number, green: number, blue: number): AnsiPair {\n return {\n open: `\\x1b[48;2;${clampRgb(red)};${clampRgb(green)};${clampRgb(blue)}m`\n };\n}\n\nfunction createColor(styles: AnsiPair[] = []): Color {\n const builder = ((text: string) => applyStyles(String(text), styles)) as Color;\n\n for (const name of styleNames) {\n Object.defineProperty(builder, name, {\n configurable: true,\n enumerable: true,\n get: () => createColor([...styles, ansiStyles[name]])\n });\n }\n\n builder.hex = (value: string) => {\n const [red, green, blue] = normalizeHex(value);\n return createColor([...styles, rgbStyle(red, green, blue)]);\n };\n\n builder.rgb = (red: number, green: number, blue: number) =>\n createColor([...styles, rgbStyle(red, green, blue)]);\n\n builder.bgHex = (value: string) => {\n const [red, green, blue] = normalizeHex(value);\n return createColor([...styles, bgRgbStyle(red, green, blue)]);\n };\n\n builder.bgRgb = (red: number, green: number, blue: number) =>\n createColor([...styles, bgRgbStyle(red, green, blue)]);\n\n return builder;\n}\n\nexport const color = createColor();\n", "import { color } from \"../components/color.js\";\n\nexport const brand = \"#a200ff\";\n\nexport const dark = {\n header: (text: string) => color.magentaBright.bold(text),\n divider: (text: string) => color.dim(text),\n prompt: (text: string) => color.cyan(text),\n number: (text: string) => color.cyanBright(text),\n intro: (text: string) => color.bgMagenta.white(` Poe - ${text} `),\n resolvedSymbol: color.magenta(\"\u25C7\"),\n errorSymbol: color.red(\"\u25A0\"),\n accent: (text: string) => color.cyan(text),\n muted: (text: string) => color.dim(text),\n success: (text: string) => color.green(text),\n warning: (text: string) => color.yellow(text),\n error: (text: string) => color.red(text),\n info: (text: string) => color.magenta(text),\n badge: (text: string) => color.bgYellow.black(` ${text} `)\n};\n\nexport const light = {\n header: (text: string) => color.hex(\"#a200ff\").bold(text),\n divider: (text: string) => color.hex(\"#666666\")(text),\n prompt: (text: string) => color.hex(\"#006699\").bold(text),\n number: (text: string) => color.hex(\"#0077cc\").bold(text),\n intro: (text: string) => color.bgHex(\"#a200ff\").white(` Poe - ${text} `),\n resolvedSymbol: color.hex(\"#a200ff\")(\"\u25C7\"),\n errorSymbol: color.hex(\"#cc0000\")(\"\u25A0\"),\n accent: (text: string) => color.hex(\"#006699\").bold(text),\n muted: (text: string) => color.hex(\"#666666\")(text),\n success: (text: string) => color.hex(\"#008800\")(text),\n warning: (text: string) => color.hex(\"#cc6600\")(text),\n error: (text: string) => color.hex(\"#cc0000\")(text),\n info: (text: string) => color.hex(\"#a200ff\")(text),\n badge: (text: string) => color.bgHex(\"#cc6600\").white(` ${text} `)\n};\n\nexport type ThemeName = \"dark\" | \"light\";\nexport type ThemePalette = typeof dark;\n", "import { AsyncLocalStorage } from \"node:async_hooks\";\n\nexport type OutputFormat = \"terminal\" | \"markdown\" | \"json\";\n\nconst VALID_FORMATS = new Set<OutputFormat>([\"terminal\", \"markdown\", \"json\"]);\nconst formatStorage = new AsyncLocalStorage<OutputFormat>();\n\nlet cached: OutputFormat | undefined;\n\nexport function resolveOutputFormat(\n env: { OUTPUT_FORMAT?: string } = process.env as { OUTPUT_FORMAT?: string }\n): OutputFormat {\n const scoped = formatStorage.getStore();\n if (scoped) {\n return scoped;\n }\n if (cached) {\n return cached;\n }\n const raw = env.OUTPUT_FORMAT?.toLowerCase();\n cached = VALID_FORMATS.has(raw as OutputFormat) ? (raw as OutputFormat) : \"terminal\";\n return cached;\n}\n\nexport function withOutputFormat<T>(format: OutputFormat, fn: () => T): T {\n return formatStorage.run(format, fn);\n}\n\nexport function resetOutputFormatCache(): void {\n cached = undefined;\n}\n", "import { dark, light, type ThemeName, type ThemePalette } from \"../tokens/colors.js\";\n\nexport interface ThemeEnv {\n POE_CODE_THEME?: string;\n POE_THEME?: string;\n APPLE_INTERFACE_STYLE?: string;\n VSCODE_COLOR_THEME_KIND?: string;\n COLORFGBG?: string;\n}\n\nfunction detectThemeFromEnv(env: ThemeEnv): ThemeName | undefined {\n const apple = env.APPLE_INTERFACE_STYLE;\n if (typeof apple === \"string\") {\n return apple.toLowerCase() === \"dark\" ? \"dark\" : \"light\";\n }\n\n const vscodeKind = env.VSCODE_COLOR_THEME_KIND;\n if (typeof vscodeKind === \"string\") {\n const normalized = vscodeKind.toLowerCase();\n if (normalized.includes(\"light\")) {\n return \"light\";\n }\n if (normalized.includes(\"dark\")) {\n return \"dark\";\n }\n }\n\n const colorFGBG = env.COLORFGBG;\n if (typeof colorFGBG === \"string\") {\n const parts = colorFGBG.split(\";\").map((part) => Number.parseInt(part, 10));\n const background = parts.at(-1);\n if (Number.isFinite(background)) {\n return background! >= 8 ? \"light\" : \"dark\";\n }\n }\n\n return undefined;\n}\n\nexport function resolveThemeName(env: ThemeEnv = process.env as ThemeEnv): ThemeName {\n const raw = (env.POE_CODE_THEME ?? env.POE_THEME)?.toLowerCase();\n if (raw === \"light\" || raw === \"dark\") {\n return raw;\n }\n const detected = detectThemeFromEnv(env);\n if (detected) {\n return detected;\n }\n return \"dark\";\n}\n\nlet cachedTheme: ThemePalette | undefined;\n\nexport function getTheme(env?: ThemeEnv): ThemePalette {\n if (cachedTheme) {\n return cachedTheme;\n }\n const themeName = resolveThemeName(env);\n cachedTheme = themeName === \"light\" ? light : dark;\n return cachedTheme;\n}\n\nexport function resetThemeCache(): void {\n cachedTheme = undefined;\n}\n", "import { color } from \"./color.js\";\nimport { resolveOutputFormat } from \"../internal/output-format.js\";\nimport { getTheme } from \"../internal/theme-detect.js\";\n\nexport const symbols = {\n get info(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"info\";\n if (format === \"markdown\") return \"(i)\";\n return color.magenta(\"\u25CF\");\n },\n get success(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"success\";\n if (format === \"markdown\") return \"[ok]\";\n return color.magenta(\"\u25C6\");\n },\n get resolved(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"resolved\";\n if (format === \"markdown\") return \">\";\n return getTheme().resolvedSymbol;\n },\n get errorResolved(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"error\";\n if (format === \"markdown\") return \"[!]\";\n return getTheme().errorSymbol;\n },\n get bar(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"\";\n if (format === \"markdown\") return \"|\";\n return \"\u2502\";\n },\n cornerTopRight: \"\u256E\",\n cornerBottomRight: \"\u256F\",\n get warning(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"warning\";\n if (format === \"markdown\") return \"[!]\";\n return \"\u25B2\";\n },\n get active(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"active\";\n if (format === \"markdown\") return \"[x]\";\n return \"\u25C6\";\n },\n get inactive(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"inactive\";\n if (format === \"markdown\") return \"[ ]\";\n return \"\u25CB\";\n }\n} as const;\n", "export function stripAnsi(value: string): string {\n return value.replace(/\\u001b\\[[0-9;]*m/g, \"\");\n}\n", "import { color } from \"../../components/color.js\";\nimport { symbols } from \"../../components/symbols.js\";\nimport { resolveOutputFormat } from \"../../internal/output-format.js\";\nimport { stripAnsi } from \"../../internal/strip-ansi.js\";\n\nexport interface LogMessageOptions {\n symbol?: string;\n secondarySymbol?: string;\n spacing?: number;\n withGuide?: boolean;\n}\n\nfunction writeTerminalMessage(\n msg: string,\n {\n symbol = color.gray(\"\u2502\"),\n secondarySymbol = color.gray(\"\u2502\"),\n spacing = 1,\n withGuide = true\n }: LogMessageOptions = {}\n): void {\n const lines: string[] = [];\n const showGuide = withGuide !== false;\n const contentLines = msg.split(\"\\n\");\n const prefix = showGuide ? `${symbol} ` : \"\";\n const continuationPrefix = showGuide ? `${secondarySymbol} ` : \"\";\n const emptyGuide = showGuide ? secondarySymbol : \"\";\n\n for (let index = 0; index < spacing; index += 1) {\n lines.push(emptyGuide);\n }\n\n if (contentLines.length === 0) {\n process.stdout.write(\"\\n\");\n return;\n }\n\n const [firstLine = \"\", ...continuationLines] = contentLines;\n if (firstLine.length > 0) {\n lines.push(`${prefix}${firstLine}`);\n } else {\n lines.push(showGuide ? symbol : \"\");\n }\n\n for (const line of continuationLines) {\n if (line.length > 0) {\n lines.push(`${continuationPrefix}${line}`);\n continue;\n }\n lines.push(emptyGuide);\n }\n\n process.stdout.write(`${lines.join(\"\\n\")}\\n`);\n}\n\nexport function message(msg: string, options?: LogMessageOptions): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`- ${stripAnsi(msg)}\\n`);\n return;\n }\n if (format === \"json\") {\n process.stdout.write(\n `${JSON.stringify({ level: \"message\", message: stripAnsi(msg) })}\\n`\n );\n return;\n }\n\n writeTerminalMessage(msg, options);\n}\n\nexport function info(msg: string): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`- **info:** ${stripAnsi(msg)}\\n`);\n return;\n }\n if (format === \"json\") {\n process.stdout.write(\n `${JSON.stringify({ level: \"info\", message: stripAnsi(msg) })}\\n`\n );\n return;\n }\n\n message(msg, { symbol: symbols.info });\n}\n\nexport function success(msg: string): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`- **success:** ${stripAnsi(msg)}\\n`);\n return;\n }\n if (format === \"json\") {\n process.stdout.write(\n `${JSON.stringify({ level: \"success\", message: stripAnsi(msg) })}\\n`\n );\n return;\n }\n\n message(msg, { symbol: symbols.success });\n}\n\nexport function warn(msg: string): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`- **warning:** ${stripAnsi(msg)}\\n`);\n return;\n }\n if (format === \"json\") {\n process.stdout.write(\n `${JSON.stringify({ level: \"warn\", message: stripAnsi(msg) })}\\n`\n );\n return;\n }\n\n message(msg, { symbol: color.yellow(\"\u25B2\") });\n}\n\nexport function error(msg: string): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`- **error:** ${stripAnsi(msg)}\\n`);\n return;\n }\n if (format === \"json\") {\n process.stdout.write(\n `${JSON.stringify({ level: \"error\", message: stripAnsi(msg) })}\\n`\n );\n return;\n }\n\n message(msg, { symbol: color.red(\"\u25A0\") });\n}\n\nexport const log = {\n info,\n success,\n message,\n warn,\n error\n};\n", "import { color } from \"./color.js\";\nimport { log } from \"../prompts/primitives/log.js\";\nimport { symbols } from \"./symbols.js\";\n\nexport interface LoggerOutput {\n info(message: string): void;\n success(message: string): void;\n warn(message: string): void;\n error(message: string): void;\n resolved(label: string, value: string): void;\n errorResolved(label: string, value: string): void;\n message(message: string, symbol?: string): void;\n}\n\nexport function createLogger(emitter?: (message: string) => void): LoggerOutput {\n const emit = (\n level: \"info\" | \"success\" | \"warn\" | \"error\",\n message: string\n ): void => {\n if (emitter) {\n emitter(message);\n return;\n }\n if (level === \"success\") {\n log.success(message);\n return;\n }\n if (level === \"warn\") {\n log.warn(message);\n return;\n }\n if (level === \"error\") {\n log.error(message);\n return;\n }\n log.info(message);\n };\n\n return {\n info(message: string): void {\n emit(\"info\", message);\n },\n success(message: string): void {\n emit(\"success\", message);\n },\n warn(message: string): void {\n emit(\"warn\", message);\n },\n error(message: string): void {\n emit(\"error\", message);\n },\n resolved(label: string, value: string): void {\n if (emitter) {\n emitter(`${label}: ${value}`);\n return;\n }\n log.message(`${label}\\n ${value}`, { symbol: symbols.resolved });\n },\n errorResolved(label: string, value: string): void {\n if (emitter) {\n emitter(`${label}: ${value}`);\n return;\n }\n log.message(`${label}\\n ${value}`, { symbol: symbols.errorResolved });\n },\n message(message: string, symbol?: string): void {\n if (emitter) {\n emitter(message);\n return;\n }\n log.message(message, { symbol: symbol ?? color.gray(\"\u2502\") });\n }\n };\n}\n\nexport const logger = createLogger();\n", "import type { ThemePalette } from \"../tokens/colors.js\";\nimport { resolveOutputFormat } from \"../internal/output-format.js\";\nimport { stripAnsi } from \"../internal/strip-ansi.js\";\n\nexport interface TableColumn {\n name: string;\n title: string;\n alignment: \"left\" | \"right\";\n maxLen: number;\n}\n\nexport interface RenderTableOptions {\n theme: ThemePalette;\n columns: TableColumn[];\n rows: Record<string, string>[];\n}\n\ntype TableAlignment = TableColumn[\"alignment\"] | \"center\";\n\ninterface ComputedColumn {\n name: string;\n title: string;\n alignment: TableAlignment;\n width: number;\n}\n\nconst reset = \"\\x1b[0m\";\nconst ellipsis = \"\u2026\";\nconst graphemeSegmenter = new Intl.Segmenter(undefined, { granularity: \"grapheme\" });\n\nfunction isAnsiSequence(value: string, index: number): boolean {\n return value[index] === \"\\u001b\" && value[index + 1] === \"[\";\n}\n\nfunction readAnsiSequence(value: string, index: number): { sequence: string; nextIndex: number } {\n let nextIndex = index + 2;\n while (nextIndex < value.length && value[nextIndex] !== \"m\") {\n nextIndex += 1;\n }\n\n if (nextIndex < value.length) {\n nextIndex += 1;\n }\n\n return { sequence: value.slice(index, nextIndex), nextIndex };\n}\n\nfunction isCombiningCodePoint(codePoint: number): boolean {\n return (\n (codePoint >= 0x0300 && codePoint <= 0x036f) ||\n (codePoint >= 0x1ab0 && codePoint <= 0x1aff) ||\n (codePoint >= 0x1dc0 && codePoint <= 0x1dff) ||\n (codePoint >= 0x20d0 && codePoint <= 0x20ff) ||\n (codePoint >= 0xfe20 && codePoint <= 0xfe2f)\n );\n}\n\nfunction isWideCodePoint(codePoint: number): boolean {\n return (\n (codePoint >= 0x1100 && codePoint <= 0x115f) ||\n codePoint === 0x2329 ||\n codePoint === 0x232a ||\n (codePoint >= 0x2e80 && codePoint <= 0xa4cf && codePoint !== 0x303f) ||\n (codePoint >= 0xac00 && codePoint <= 0xd7a3) ||\n (codePoint >= 0xf900 && codePoint <= 0xfaff) ||\n (codePoint >= 0xfe10 && codePoint <= 0xfe19) ||\n (codePoint >= 0xfe30 && codePoint <= 0xfe6f) ||\n (codePoint >= 0xff00 && codePoint <= 0xff60) ||\n (codePoint >= 0xffe0 && codePoint <= 0xffe6) ||\n (codePoint >= 0x2600 && codePoint <= 0x27bf) ||\n (codePoint >= 0x1f300 && codePoint <= 0x1faff) ||\n (codePoint >= 0x20000 && codePoint <= 0x3fffd)\n );\n}\n\nfunction isEmojiClusterCodePoint(codePoint: number): boolean {\n return (\n (codePoint >= 0x1f1e6 && codePoint <= 0x1f1ff) ||\n (codePoint >= 0x1f300 && codePoint <= 0x1faff) ||\n (codePoint >= 0x2600 && codePoint <= 0x27bf)\n );\n}\n\nfunction codePointWidth(char: string): number {\n const codePoint = char.codePointAt(0) ?? 0;\n\n if (codePoint === 0 || codePoint < 0x20 || (codePoint >= 0x7f && codePoint < 0xa0)) {\n return 0;\n }\n\n if (\n codePoint === 0x200d ||\n (codePoint >= 0xfe00 && codePoint <= 0xfe0f) ||\n isCombiningCodePoint(codePoint)\n ) {\n return 0;\n }\n\n return isWideCodePoint(codePoint) ? 2 : 1;\n}\n\nfunction readPrintableCluster(value: string, index: number): string {\n const nextAnsiIndex = value.indexOf(\"\\u001b[\", index);\n const plainText = value.slice(index, nextAnsiIndex === -1 ? undefined : nextAnsiIndex);\n const firstSegment = graphemeSegmenter.segment(plainText)[Symbol.iterator]().next().value as\n | Intl.SegmentData\n | undefined;\n\n return firstSegment?.segment ?? Array.from(plainText)[0] ?? \"\";\n}\n\nfunction clusterWidth(cluster: string): number {\n const codePoints = Array.from(cluster).map((char) => char.codePointAt(0) ?? 0);\n const isEmojiCluster =\n codePoints.length > 1 &&\n codePoints.some(\n (codePoint) =>\n codePoint === 0x200d ||\n (codePoint >= 0xfe00 && codePoint <= 0xfe0f) ||\n isEmojiClusterCodePoint(codePoint)\n );\n\n if (isEmojiCluster) {\n return 2;\n }\n\n return codePoints.reduce((width, codePoint) => width + codePointWidth(String.fromCodePoint(codePoint)), 0);\n}\n\nfunction displayWidth(value: string): number {\n let width = 0;\n let index = 0;\n\n while (index < value.length) {\n if (isAnsiSequence(value, index)) {\n index = readAnsiSequence(value, index).nextIndex;\n continue;\n }\n\n const cluster = readPrintableCluster(value, index);\n width += clusterWidth(cluster);\n index += cluster.length;\n }\n\n return width;\n}\n\nfunction truncateToWidth(value: string, width: number): string {\n if (displayWidth(value) <= width) {\n return value;\n }\n\n if (width <= 0) {\n return \"\";\n }\n\n const targetWidth = width <= 1 ? 0 : width - displayWidth(ellipsis);\n let output = \"\";\n let currentWidth = 0;\n let index = 0;\n let sawAnsi = false;\n\n while (index < value.length) {\n if (isAnsiSequence(value, index)) {\n const ansi = readAnsiSequence(value, index);\n sawAnsi = true;\n output += ansi.sequence;\n index = ansi.nextIndex;\n continue;\n }\n\n const cluster = readPrintableCluster(value, index);\n const width = clusterWidth(cluster);\n if (currentWidth + width > targetWidth) {\n break;\n }\n\n output += cluster;\n currentWidth += width;\n index += cluster.length;\n }\n\n return `${output}${ellipsis}${sawAnsi ? reset : \"\"}`;\n}\n\nfunction padCell(value: string, width: number, alignment: TableAlignment): string {\n const visibleWidth = displayWidth(value);\n const padding = Math.max(0, width - visibleWidth);\n\n if (alignment === \"right\") {\n return `${\" \".repeat(padding)}${value}`;\n }\n\n if (alignment === \"center\") {\n const left = Math.floor(padding / 2);\n const right = padding - left;\n return `${\" \".repeat(left)}${value}${\" \".repeat(right)}`;\n }\n\n return `${value}${\" \".repeat(padding)}`;\n}\n\nfunction getAlignment(column: TableColumn): TableAlignment {\n const alignment = (column as { alignment: TableAlignment }).alignment;\n return alignment === \"right\" || alignment === \"center\" ? alignment : \"left\";\n}\n\nfunction getColumnWidth(column: TableColumn): number {\n const configuredMin = (column as { minLen?: number }).minLen;\n const minWidth = Math.max(1, configuredMin ?? 1);\n return Math.max(minWidth, column.maxLen);\n}\n\nfunction computeColumns(columns: TableColumn[]): ComputedColumn[] {\n return columns.map((column) => ({\n name: column.name,\n title: column.title,\n alignment: getAlignment(column),\n width: getColumnWidth(column)\n }));\n}\n\nfunction renderBorder(\n columns: ComputedColumn[],\n theme: ThemePalette,\n parts: { left: string; mid: string; right: string }\n): string {\n const horizontal = theme.muted(\"\u2500\");\n const segments = columns.map((column) => horizontal.repeat(column.width + 2));\n return [\n theme.muted(parts.left),\n segments.join(theme.muted(parts.mid)),\n theme.muted(parts.right)\n ].join(\"\");\n}\n\nfunction renderTerminalRow(values: string[], columns: ComputedColumn[], theme: ThemePalette): string {\n const vertical = theme.muted(\"\u2502\");\n const cells = values.map((value, index) => {\n const column = columns[index]!;\n const truncated = truncateToWidth(value, column.width);\n return ` ${padCell(truncated, column.width, column.alignment)} `;\n });\n\n return `${vertical}${cells.join(vertical)}${vertical}`;\n}\n\nfunction renderTableTerminal(options: RenderTableOptions): string {\n const { theme, columns, rows } = options;\n const computedColumns = computeColumns(columns);\n const separatorOptions = options as { rowSeparator?: boolean; rowSeparators?: boolean };\n const includeRowSeparators =\n separatorOptions.rowSeparator === true || separatorOptions.rowSeparators === true;\n\n const top = renderBorder(computedColumns, theme, { left: \"\u250C\", mid: \"\u252C\", right: \"\u2510\" });\n const header = renderTerminalRow(\n computedColumns.map((column) => theme.header(column.title)),\n computedColumns,\n theme\n );\n const headerBottom = renderBorder(computedColumns, theme, { left: \"\u251C\", mid: \"\u253C\", right: \"\u2524\" });\n const bottom = renderBorder(computedColumns, theme, { left: \"\u2514\", mid: \"\u2534\", right: \"\u2518\" });\n\n const renderedRows: string[] = [];\n for (const [index, row] of rows.entries()) {\n if (includeRowSeparators && index > 0) {\n renderedRows.push(headerBottom);\n }\n renderedRows.push(\n renderTerminalRow(\n computedColumns.map((column) => row[column.name] ?? \"\"),\n computedColumns,\n theme\n )\n );\n }\n\n return [top, header, headerBottom, ...renderedRows, bottom].join(\"\\n\");\n}\n\nfunction renderTableMarkdown(options: RenderTableOptions): string {\n const { columns, rows } = options;\n\n const header = `| ${columns.map((c) => c.title).join(\" | \")} |`;\n const separator = `| ${columns\n .map((c) => {\n const alignment = getAlignment(c);\n if (alignment === \"right\") {\n return \"---:\";\n }\n if (alignment === \"center\") {\n return \":---:\";\n }\n return \":---\";\n })\n .join(\" | \")} |`;\n\n const dataRows = rows.map(\n (row) =>\n `| ${columns.map((c) => stripAnsi(row[c.name] ?? \"\").replace(/\\|/g, \"\\\\|\")).join(\" | \")} |`\n );\n\n return [header, separator, ...dataRows].join(\"\\n\");\n}\n\nfunction renderTableJson(options: RenderTableOptions): string {\n const { columns, rows } = options;\n\n const cleaned = rows.map((row) => {\n const obj: Record<string, string> = {};\n for (const col of columns) {\n obj[col.name] = stripAnsi(row[col.name] ?? \"\");\n }\n return obj;\n });\n\n return JSON.stringify(cleaned, null, 2);\n}\n\nexport function renderTable(options: RenderTableOptions): string {\n const format = resolveOutputFormat();\n switch (format) {\n case \"markdown\":\n return renderTableMarkdown(options);\n case \"json\":\n return renderTableJson(options);\n default:\n return renderTableTerminal(options);\n }\n}\n", "export type TemplateEscape = \"html\" | \"none\";\n\nexport interface RenderTemplateOptions {\n escape?: TemplateEscape;\n yield?: string;\n}\n\ntype Token =\n | { type: \"text\"; value: string; start: number }\n | { type: \"name\" | \"unescaped\"; name: string; raw: string }\n | { type: \"section\" | \"inverted\"; name: string; children: Token[]; rawStart: number; rawEnd: number };\n\ninterface SectionFrame {\n token: Extract<Token, { type: \"section\" | \"inverted\" }>;\n parent: Token[];\n}\n\ninterface Context {\n view: unknown;\n parent?: Context;\n}\n\ntype Lambda = (...args: unknown[]) => unknown;\n\nconst HTML_ESCAPE: Record<string, string> = {\n \"&\": \"&amp;\",\n \"<\": \"&lt;\",\n \">\": \"&gt;\",\n '\"': \"&quot;\",\n \"'\": \"&#39;\",\n \"/\": \"&#x2F;\",\n \"`\": \"&#x60;\",\n \"=\": \"&#x3D;\"\n};\n\nexport function renderTemplate(\n template: string,\n view: Record<string, unknown>,\n options: RenderTemplateOptions = {}\n): string {\n const prepared = options.yield === undefined\n ? template\n : template.split(\"{{yield}}\").join(options.yield);\n const tokens = parseTemplate(prepared);\n const escape = options.escape === \"none\" ? String : escapeHtml;\n const preserveMissing = options.yield !== undefined && options.escape === \"none\";\n\n return renderTokens(tokens, { view }, prepared, escape, preserveMissing);\n}\n\nfunction renderTemplateInContext(\n template: string,\n context: Context,\n escape: (value: string) => string,\n preserveMissing: boolean\n): string {\n return renderTokens(parseTemplate(template), context, template, escape, preserveMissing);\n}\n\nfunction parseTemplate(template: string): Token[] {\n const root: Token[] = [];\n const stack: SectionFrame[] = [];\n let tokens = root;\n let index = 0;\n\n while (index < template.length) {\n const open = template.indexOf(\"{{\", index);\n if (open === -1) {\n appendText(tokens, template.slice(index), index);\n break;\n }\n\n appendText(tokens, template.slice(index, open), index);\n\n const parsed = parseTag(template, open);\n const standalone = getStandalone(template, open, parsed.end, parsed.kind);\n if (standalone !== undefined) {\n trimTextAfter(tokens, standalone.lineStart);\n }\n\n if (parsed.kind === \"comment\") {\n index = standalone?.nextIndex ?? parsed.end;\n continue;\n }\n\n if (parsed.kind === \"partial\") {\n throw new Error(`Partials are not supported: \"${parsed.name}\"`);\n }\n\n if (parsed.kind === \"delimiter\") {\n throw new Error(\"Custom delimiters are not supported\");\n }\n\n if (parsed.kind === \"section\" || parsed.kind === \"inverted\") {\n const token: Token = {\n type: parsed.kind,\n name: parsed.name,\n children: [],\n rawStart: parsed.end,\n rawEnd: standalone?.lineStart ?? open\n };\n tokens.push(token);\n stack.push({ token, parent: tokens });\n tokens = token.children;\n index = standalone?.nextIndex ?? parsed.end;\n continue;\n }\n\n if (parsed.kind === \"close\") {\n const frame = stack.pop();\n if (frame === undefined) {\n throw new Error(`Closing unopened section \"${parsed.name}\"`);\n }\n if (frame.token.name !== parsed.name) {\n throw new Error(`Unclosed section \"${frame.token.name}\" before closing \"${parsed.name}\"`);\n }\n frame.token.rawEnd = open;\n tokens = frame.parent;\n index = standalone?.nextIndex ?? parsed.end;\n continue;\n }\n\n tokens.push({ type: parsed.kind, name: parsed.name, raw: template.slice(open, parsed.end) });\n index = parsed.end;\n }\n\n const frame = stack.pop();\n if (frame !== undefined) {\n throw new Error(`Unclosed section \"${frame.token.name}\"`);\n }\n\n return root;\n}\n\nfunction parseTag(template: string, open: number): {\n kind: \"name\" | \"unescaped\" | \"section\" | \"inverted\" | \"close\" | \"comment\" | \"partial\" | \"delimiter\";\n name: string;\n end: number;\n} {\n if (template.startsWith(\"{{{\", open)) {\n const close = template.indexOf(\"}}}\", open + 3);\n if (close === -1) {\n throw new Error(\"Unclosed unescaped tag\");\n }\n return { kind: \"unescaped\", name: template.slice(open + 3, close).trim(), end: close + 3 };\n }\n\n const close = template.indexOf(\"}}\", open + 2);\n if (close === -1) {\n throw new Error(\"Unclosed tag\");\n }\n\n const raw = template.slice(open + 2, close).trim();\n const sigil = raw[0];\n const name = sigil === undefined ? \"\" : raw.slice(1).trim();\n const end = close + 2;\n\n if (sigil === \"#\") return { kind: \"section\", name, end };\n if (sigil === \"^\") return { kind: \"inverted\", name, end };\n if (sigil === \"/\") return { kind: \"close\", name, end };\n if (sigil === \"!\") return { kind: \"comment\", name, end };\n if (sigil === \"&\") return { kind: \"unescaped\", name, end };\n if (sigil === \">\") return { kind: \"partial\", name, end };\n if (sigil === \"=\" && raw.endsWith(\"=\")) return { kind: \"delimiter\", name, end };\n\n return { kind: \"name\", name: raw, end };\n}\n\nfunction getStandalone(\n template: string,\n tagStart: number,\n tagEnd: number,\n kind: ReturnType<typeof parseTag>[\"kind\"]\n): { lineStart: number; nextIndex: number } | undefined {\n if (![\"section\", \"inverted\", \"close\", \"comment\", \"partial\", \"delimiter\"].includes(kind)) {\n return undefined;\n }\n\n const lineStart = template.lastIndexOf(\"\\n\", tagStart - 1) + 1;\n if (!isWhitespace(template.slice(lineStart, tagStart))) {\n return undefined;\n }\n\n let cursor = tagEnd;\n while (cursor < template.length && (template[cursor] === \" \" || template[cursor] === \"\\t\")) {\n cursor += 1;\n }\n\n if (template.startsWith(\"\\r\\n\", cursor)) {\n return { lineStart, nextIndex: cursor + 2 };\n }\n\n if (template[cursor] === \"\\n\") {\n return { lineStart, nextIndex: cursor + 1 };\n }\n\n if (cursor === template.length) {\n return { lineStart, nextIndex: cursor };\n }\n\n return undefined;\n}\n\nfunction renderTokens(\n tokens: Token[],\n context: Context,\n template: string,\n escape: (value: string) => string,\n preserveMissing: boolean\n): string {\n let output = \"\";\n\n for (const token of tokens) {\n switch (token.type) {\n case \"text\":\n output += token.value;\n continue;\n\n case \"name\":\n case \"unescaped\": {\n const value = lookup(context, token.name);\n if (value == null) {\n if (preserveMissing) {\n output += token.raw;\n }\n continue;\n }\n const rendered = String(value);\n output += token.type === \"name\" ? escape(rendered) : rendered;\n continue;\n }\n\n case \"inverted\": {\n const value = lookup(context, token.name);\n if (!value || (Array.isArray(value) && value.length === 0)) {\n output += renderTokens(token.children, context, template, escape, preserveMissing);\n }\n continue;\n }\n\n case \"section\": {\n const value = lookup(context, token.name);\n if (!value) {\n continue;\n }\n\n if (Array.isArray(value)) {\n for (const item of value) {\n output += renderTokens(token.children, pushContext(context, item), template, escape, preserveMissing);\n }\n continue;\n }\n\n if (typeof value === \"function\") {\n const raw = template.slice(token.rawStart, token.rawEnd);\n const rendered = (value as Lambda).call(context.view, raw, (nextTemplate: string) =>\n renderTemplateInContext(nextTemplate, context, escape, preserveMissing)\n );\n if (rendered != null) {\n output += String(rendered);\n }\n continue;\n }\n\n if (typeof value === \"object\" || typeof value === \"string\" || typeof value === \"number\") {\n output += renderTokens(token.children, pushContext(context, value), template, escape, preserveMissing);\n continue;\n }\n\n output += renderTokens(token.children, context, template, escape, preserveMissing);\n }\n }\n }\n\n return output;\n}\n\nfunction lookup(context: Context, name: string): unknown {\n if (name === \".\") {\n return callLambda(context.view, context.view);\n }\n\n let cursor: Context | undefined = context;\n while (cursor !== undefined) {\n const result = name.includes(\".\")\n ? lookupDotted(cursor.view, name)\n : lookupName(cursor.view, name);\n\n if (result.hit) {\n return callLambda(result.value, cursor.view);\n }\n\n cursor = cursor.parent;\n }\n\n return undefined;\n}\n\nfunction lookupName(view: unknown, name: string): { hit: boolean; value: unknown } {\n if (!isPropertyContainer(view) || !hasProperty(view, name)) {\n return { hit: false, value: undefined };\n }\n\n return { hit: true, value: view[name] };\n}\n\nfunction lookupDotted(view: unknown, name: string): { hit: boolean; value: unknown } {\n const parts = name.split(\".\");\n let value = view;\n let hit = false;\n\n for (let index = 0; value != null && index < parts.length; index += 1) {\n const part = parts[index] ?? \"\";\n if (index === parts.length - 1) {\n hit = hasProperty(Object(value), part);\n }\n value = Object(value)[part as keyof typeof value];\n }\n\n return { hit, value };\n}\n\nfunction callLambda(value: unknown, view: unknown): unknown {\n return typeof value === \"function\" ? (value as Lambda).call(view) : value;\n}\n\nfunction pushContext(parent: Context, view: unknown): Context {\n return { view, parent };\n}\n\nfunction appendText(tokens: Token[], value: string, start: number): void {\n if (value === \"\") {\n return;\n }\n\n const previous = tokens[tokens.length - 1];\n if (previous?.type === \"text\") {\n previous.value += value;\n return;\n }\n\n tokens.push({ type: \"text\", value, start });\n}\n\nfunction trimTextAfter(tokens: Token[], lineStart: number): void {\n const previous = tokens[tokens.length - 1];\n if (previous?.type !== \"text\") {\n return;\n }\n\n const keep = Math.max(0, lineStart - previous.start);\n previous.value = previous.value.slice(0, keep);\n if (previous.value === \"\") {\n tokens.pop();\n }\n}\n\nfunction escapeHtml(value: string): string {\n return value.replace(/[&<>\"'`=/]/g, (char) => HTML_ESCAPE[char] ?? char);\n}\n\nfunction isWhitespace(value: string): boolean {\n return value.trim() === \"\";\n}\n\nfunction isPropertyContainer(value: unknown): value is Record<string, unknown> {\n return (typeof value === \"object\" && value !== null) || typeof value === \"function\";\n}\n\nfunction hasProperty(value: object, key: string): boolean {\n return key in value;\n}\n", "import { spawn } from \"node:child_process\";\nimport process from \"node:process\";\n\ninterface BrowserProcess {\n once(event: \"error\", listener: (error: Error) => void): this;\n once(event: \"spawn\", listener: () => void): this;\n unref(): void;\n}\n\ntype SpawnBrowserProcess = (\n command: string,\n args: string[],\n options: { detached: true; stdio: \"ignore\" }\n) => BrowserProcess;\n\nexport interface OpenExternalOptions {\n platform?: NodeJS.Platform;\n spawnProcess?: SpawnBrowserProcess;\n}\n\nexport async function openExternal(url: string, options: OpenExternalOptions = {}): Promise<void> {\n const parsed = new URL(url);\n const { command, args } = browserCommand(parsed.href, options.platform ?? process.platform);\n await launchBrowser(command, args, options.spawnProcess ?? spawn);\n}\n\nfunction browserCommand(url: string, platform: NodeJS.Platform): { command: string; args: string[] } {\n if (platform === \"darwin\") {\n return { command: \"open\", args: [url] };\n }\n\n if (platform === \"win32\") {\n return { command: \"cmd\", args: [\"/c\", \"start\", \"\", url] };\n }\n\n return { command: \"xdg-open\", args: [url] };\n}\n\nfunction launchBrowser(\n command: string,\n args: string[],\n spawnProcess: SpawnBrowserProcess\n): Promise<void> {\n return new Promise((resolve, reject) => {\n const child = spawnProcess(command, args, { detached: true, stdio: \"ignore\" });\n\n child.once(\"error\", reject);\n child.once(\"spawn\", () => {\n child.unref();\n resolve();\n });\n });\n}\n", "import { AsyncLocalStorage } from \"node:async_hooks\";\n\nexport type AcpLineWriter = (line: string) => void;\n\nconst storage = new AsyncLocalStorage<AcpLineWriter>();\n\nconst defaultWriter: AcpLineWriter = (line) => {\n process.stdout.write(`${line}\\n`);\n};\n\n/**\n * Return the writer active in the current async context, or the default\n * stdout writer if none is bound.\n */\nexport function getAcpWriter(): AcpLineWriter {\n return storage.getStore() ?? defaultWriter;\n}\n\n/**\n * Run `fn` with `writer` bound as the active ACP line writer. All calls to\n * `renderAgentMessage`, `renderToolStart`, `renderAcpEvent`, etc. made inside\n * `fn` (or async work awaited from `fn`) will go through `writer` instead of\n * writing to `process.stdout`.\n */\nexport function withAcpWriter<T>(writer: AcpLineWriter, fn: () => Promise<T>): Promise<T> {\n return storage.run(writer, fn);\n}\n", "import readline from \"node:readline\";\nimport { PassThrough } from \"node:stream\";\nimport { cellToAnsi } from \"./buffer.js\";\nimport type { Cell } from \"./types.js\";\n\nexport type KeypressEvent = {\n name?: string;\n ch?: string;\n ctrl: boolean;\n meta: boolean;\n shift: boolean;\n};\n\nexport type TerminalDriver = {\n enterRawMode(): void;\n exitRawMode(): void;\n enterAltScreen(): void;\n exitAltScreen(): void;\n disableLineWrap(): void;\n enableLineWrap(): void;\n hideCursor(): void;\n showCursor(): void;\n moveTo(x: number, y: number): void;\n write(text: string): void;\n flush(changes: Array<{ x: number; y: number; cell: Cell }>): void;\n getSize(): { cols: number; rows: number };\n onResize(handler: () => void): () => void;\n onKeypress(handler: (key: KeypressEvent) => void): () => void;\n destroy(): void;\n};\n\ntype ReadlineKey = {\n sequence?: string;\n name?: string;\n ctrl?: boolean;\n meta?: boolean;\n shift?: boolean;\n};\n\ntype KeypressInput = NodeJS.ReadableStream & {\n on(event: \"keypress\", listener: (str: string | undefined, key: ReadlineKey) => void): KeypressInput;\n off(event: \"keypress\", listener: (str: string | undefined, key: ReadlineKey) => void): KeypressInput;\n};\n\ntype TerminalInput = NodeJS.ReadStream & KeypressInput & {\n setRawMode?: (mode: boolean) => void;\n};\n\ntype TerminalOutput = NodeJS.WriteStream & {\n columns?: number;\n rows?: number;\n on(event: \"resize\", listener: () => void): TerminalOutput;\n off(event: \"resize\", listener: () => void): TerminalOutput;\n};\n\nexport function createTerminalDriver(opts?: {\n stdin?: NodeJS.ReadStream;\n stdout?: NodeJS.WriteStream;\n}): TerminalDriver {\n const stdin = (opts?.stdin ?? process.stdin) as TerminalInput;\n const stdout = (opts?.stdout ?? process.stdout) as TerminalOutput;\n const resizeListeners = new Set<() => void>();\n const keypressListeners = new Set<(str: string | undefined, key: ReadlineKey) => void>();\n let rawMode = false;\n let altScreen = false;\n let lineWrapEnabled = true;\n let cursorHidden = false;\n let destroyed = false;\n\n readline.emitKeypressEvents(stdin);\n\n function enterRawMode(): void {\n if (destroyed || rawMode) {\n return;\n }\n\n stdin.setRawMode?.(true);\n stdin.resume();\n rawMode = true;\n }\n\n function exitRawMode(): void {\n if (destroyed || !rawMode) {\n return;\n }\n\n stdin.setRawMode?.(false);\n stdin.pause();\n rawMode = false;\n }\n\n function enterAltScreen(): void {\n if (destroyed || altScreen) {\n return;\n }\n\n write(\"\\u001b[?1049h\");\n altScreen = true;\n }\n\n function exitAltScreen(): void {\n if (destroyed || !altScreen) {\n return;\n }\n\n write(\"\\u001b[?1049l\");\n altScreen = false;\n }\n\n function disableLineWrap(): void {\n if (destroyed || !lineWrapEnabled) {\n return;\n }\n\n write(\"\\u001b[?7l\");\n lineWrapEnabled = false;\n }\n\n function enableLineWrap(): void {\n if (destroyed || lineWrapEnabled) {\n return;\n }\n\n write(\"\\u001b[?7h\");\n lineWrapEnabled = true;\n }\n\n function hideCursor(): void {\n if (destroyed || cursorHidden) {\n return;\n }\n\n write(\"\\u001b[?25l\");\n cursorHidden = true;\n }\n\n function showCursor(): void {\n if (destroyed || !cursorHidden) {\n return;\n }\n\n write(\"\\u001b[?25h\");\n cursorHidden = false;\n }\n\n function moveTo(x: number, y: number): void {\n if (destroyed) {\n return;\n }\n\n write(cursorPositionAnsi(x, y));\n }\n\n function write(text: string): void {\n if (destroyed || text.length === 0) {\n return;\n }\n\n stdout.write(text);\n }\n\n function flush(changes: Array<{ x: number; y: number; cell: Cell }>): void {\n if (destroyed || changes.length === 0) {\n return;\n }\n\n let output = \"\";\n\n for (const change of changes) {\n output += `${cursorPositionAnsi(change.x, change.y)}${cellToAnsi(change.cell)}`;\n }\n\n write(output);\n }\n\n function getSize(): { cols: number; rows: number } {\n return {\n cols: normalizeSize(stdout.columns),\n rows: normalizeSize(stdout.rows)\n };\n }\n\n function onResize(handler: () => void): () => void {\n if (destroyed) {\n return () => {};\n }\n\n const listener = () => {\n handler();\n };\n\n resizeListeners.add(listener);\n stdout.on(\"resize\", listener);\n\n return () => {\n if (!resizeListeners.delete(listener)) {\n return;\n }\n\n stdout.off(\"resize\", listener);\n };\n }\n\n function onKeypress(handler: (key: KeypressEvent) => void): () => void {\n if (destroyed) {\n return () => {};\n }\n\n const listener = (str: string | undefined, key: ReadlineKey) => {\n const event = toKeypressEvent(str, key);\n if (event !== undefined) {\n handler(event);\n }\n };\n\n keypressListeners.add(listener);\n stdin.on(\"keypress\", listener);\n\n return () => {\n if (!keypressListeners.delete(listener)) {\n return;\n }\n\n stdin.off(\"keypress\", listener);\n };\n }\n\n function destroy(): void {\n if (destroyed) {\n return;\n }\n\n for (const listener of keypressListeners) {\n stdin.off(\"keypress\", listener);\n }\n keypressListeners.clear();\n\n for (const listener of resizeListeners) {\n stdout.off(\"resize\", listener);\n }\n resizeListeners.clear();\n\n exitRawMode();\n enableLineWrap();\n exitAltScreen();\n showCursor();\n destroyed = true;\n }\n\n return {\n enterRawMode,\n exitRawMode,\n enterAltScreen,\n exitAltScreen,\n disableLineWrap,\n enableLineWrap,\n hideCursor,\n showCursor,\n moveTo,\n write,\n flush,\n getSize,\n onResize,\n onKeypress,\n destroy\n };\n}\n\nexport function parseKeypress(data: Buffer): KeypressEvent | undefined {\n if (data.length === 0) {\n return undefined;\n }\n\n const stream = new PassThrough();\n const stdin = stream as unknown as KeypressInput;\n let event: KeypressEvent | undefined;\n\n readline.emitKeypressEvents(stdin);\n stdin.on(\"keypress\", (str, key) => {\n event = toKeypressEvent(str, key);\n });\n stream.emit(\"data\", data);\n stream.destroy();\n\n return event;\n}\n\nfunction toKeypressEvent(str: string | undefined, key: ReadlineKey | undefined): KeypressEvent | undefined {\n const controlCharacter = controlCharacterToKeypress(key?.sequence);\n if (controlCharacter !== undefined) {\n return controlCharacter;\n }\n\n const ctrl = key?.ctrl ?? false;\n const meta = key?.meta ?? false;\n const shift = key?.shift ?? false;\n const ch = extractPrintableCharacter(str, key?.sequence);\n\n if (ch !== undefined) {\n return { ch, ctrl, meta, shift };\n }\n\n if (key?.name === undefined) {\n return undefined;\n }\n\n return {\n name: key.name,\n ctrl,\n meta,\n shift\n };\n}\n\nfunction extractPrintableCharacter(str: string | undefined, sequence: string | undefined): string | undefined {\n if (isPrintableCharacter(str)) {\n return str;\n }\n\n if (isSinglePrintableSequence(sequence)) {\n return sequence;\n }\n\n if (sequence === undefined || sequence.length <= 1 || sequence[0] !== \"\\u001b\") {\n return undefined;\n }\n\n const candidate = sequence.slice(1);\n return isPrintableCharacter(candidate) ? candidate : undefined;\n}\n\nfunction isSinglePrintableSequence(value: string | undefined): boolean {\n if (value === undefined || Array.from(value).length !== 1) {\n return false;\n }\n\n const codePoint = value.codePointAt(0);\n return codePoint !== undefined && codePoint >= 0x20 && codePoint !== 0x7f;\n}\n\nfunction isPrintableCharacter(value: string | undefined): value is string {\n if (value === undefined || Array.from(value).length !== 1) {\n return false;\n }\n\n const codePoint = value.codePointAt(0);\n return codePoint !== undefined && codePoint >= 0x20 && codePoint !== 0x7f;\n}\n\nfunction controlCharacterToKeypress(sequence: string | undefined): KeypressEvent | undefined {\n if (sequence === \"\\u001f\") {\n return { ch: \"/\", ctrl: true, meta: false, shift: false };\n }\n\n if (sequence !== undefined && sequence.length === 1) {\n const code = sequence.charCodeAt(0);\n if (code >= 1 && code <= 26 && code !== 9 && code !== 10 && code !== 13) {\n return {\n name: String.fromCharCode(code + 96),\n ctrl: true,\n meta: false,\n shift: false\n };\n }\n }\n\n return undefined;\n}\n\nfunction cursorPositionAnsi(x: number, y: number): string {\n return `\\u001b[${normalizeCoordinate(y) + 1};${normalizeCoordinate(x) + 1}H`;\n}\n\nfunction normalizeCoordinate(value: number): number {\n return Math.max(0, Math.floor(value));\n}\n\nfunction normalizeSize(value: number | undefined): number {\n if (value === undefined || !Number.isFinite(value)) {\n return 0;\n }\n\n return Math.max(0, Math.floor(value));\n}\n", "import { resolveBindings, type ResolvedBindings } from \"./keymap.js\";\n\nexport type Tone = \"success\" | \"warning\" | \"error\" | \"info\" | \"muted\";\n\nexport interface Row {\n id: string;\n title: string;\n subtitle?: string;\n badge?: { text: string; tone?: Tone };\n group?: string; // grouped rendering; rows with same group cluster under a header\n}\n\nexport interface DetailItem {\n id: string;\n title?: string; // absent => item fills pane with no cursor / no selection chrome\n subtitle?: string;\n badge?: { text: string; tone?: Tone };\n render: (ctx: DetailCtx) => string | Promise<string>;\n}\n\nexport interface Detail<R> {\n items: (row: Row, ctx: DetailCtx) => Promise<DetailItem[]>;\n actions?: Action<R>[]; // run against the focused detail item\n}\n\nexport interface DetailCtx { width: number; height: number; signal: AbortSignal; row: Row }\n\nexport interface Action<R> {\n id: string;\n label: string | (() => string); // function form re-evaluated when state changes\n key?: string | string[];\n predicate?: (ctx: ActionContext<R>) => boolean;\n handler: (ctx: ActionContext<R>) => void | Promise<void>;\n destructive?: boolean;\n primary?: boolean; // bound to Enter\n showInFooter?: boolean; // default true\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport interface ActionContext<R> {\n row: Row; // currently highlighted left-pane row\n rows: Row[]; // multi-select; falls back to [row] if no selection\n item?: DetailItem; // populated for actions declared under detail.actions\n filter: string;\n refresh: () => Promise<void>;\n suspendAnd: <T>(fn: () => Promise<T>) => Promise<T>;\n toast: (msg: string, tone?: Tone) => void;\n confirm: (prompt: string) => Promise<boolean>;\n exit: (after?: () => void | Promise<void>) => void;\n}\n\nexport interface ReorderContext {\n refresh: () => Promise<void>;\n toast: (msg: string, tone?: Tone) => void;\n}\n\nexport interface ExplorerConfig<R> {\n title: string;\n rows: () => Promise<Row[]>;\n refresh?: () => Promise<void>;\n detail: Detail<R>;\n actions: Action<R>[];\n reorder?: { onReorder: (orderedIds: string[], ctx?: ReorderContext) => void | Promise<void> };\n multiSelect?: boolean;\n keybindOverrides?: Record<string, string | string[]>;\n emptyHint?: string;\n initialFilter?: string;\n}\n\nexport const REGION_HEADER = 1 << 0;\nexport const REGION_LIST = 1 << 1;\nexport const REGION_DETAIL = 1 << 2;\nexport const REGION_FOOTER = 1 << 3;\nexport const REGION_MODAL = 1 << 4;\nexport const REGION_TOAST = 1 << 5;\nexport const REGION_ALL =\n REGION_HEADER |\n REGION_LIST |\n REGION_DETAIL |\n REGION_FOOTER |\n REGION_MODAL |\n REGION_TOAST;\n\nexport type Dirty = number;\n\nexport type ExplorerLayoutMode =\n | \"wide\"\n | \"medium\"\n | \"narrow-vertical\"\n | \"narrow-list-only\"\n | \"too-narrow\";\n\nexport interface ExplorerSize {\n cols: number;\n rows: number;\n}\n\nexport interface ExplorerState {\n title: string;\n emptyHint: string;\n rows: Row[];\n filtered: number[];\n matchPositions: Map<number, number[]>;\n cursor: number;\n filter: string;\n filterFocused: boolean;\n focused: \"list\" | \"detail\";\n detail: {\n rowId: string | null;\n items: DetailItem[] | null;\n cursor: number;\n scroll: number;\n token: number;\n loading: boolean;\n };\n selected: Set<string>;\n modal:\n | null\n | { kind: \"help\" }\n | { kind: \"confirm\"; action: Action<unknown>; rows: Row[]; resolver: (ok: boolean) => void }\n | { kind: \"palette\"; query: string; cursor: number };\n toast: { message: string; tone: Tone; expiresAt: number } | null;\n dirty: Dirty;\n size: ExplorerSize;\n layout: ExplorerLayoutMode;\n bindings: ResolvedBindings;\n actionState: Map<string, ActionStateEntry>;\n}\n\nexport interface ActionStateEntry {\n available: boolean;\n label: string;\n running?: boolean;\n action?: Action<unknown>;\n source?: \"row\" | \"detail\";\n}\n\nexport function createInitialState<R>(\n config: ExplorerConfig<R>,\n size: ExplorerSize\n): ExplorerState {\n const normalizedSize = {\n cols: normalizeSize(size.cols),\n rows: normalizeSize(size.rows)\n };\n\n return {\n title: config.title,\n emptyHint: config.emptyHint ?? \"No detail\",\n rows: [],\n filtered: [],\n matchPositions: new Map(),\n cursor: 0,\n filter: config.initialFilter ?? \"\",\n filterFocused: false,\n focused: \"list\",\n detail: {\n rowId: null,\n items: null,\n cursor: 0,\n scroll: 0,\n token: 0,\n loading: false\n },\n selected: new Set(),\n modal: null,\n toast: null,\n dirty: REGION_ALL,\n size: normalizedSize,\n layout: resolveExplorerLayoutMode(normalizedSize.cols),\n bindings: resolveBindings(config),\n actionState: createInitialActionState(config)\n };\n}\n\nfunction createInitialActionState<R>(\n config: ExplorerConfig<R>\n): Map<string, ActionStateEntry> {\n const state = new Map<string, ActionStateEntry>();\n\n for (const action of config.actions) {\n state.set(action.id, {\n available: true,\n label: typeof action.label === \"function\" ? action.id : action.label,\n action: action as Action<unknown>,\n source: \"row\"\n });\n }\n\n for (const action of config.detail.actions ?? []) {\n state.set(action.id, {\n available: true,\n label: typeof action.label === \"function\" ? action.id : action.label,\n action: action as Action<unknown>,\n source: \"detail\"\n });\n }\n\n return state;\n}\n\nexport function resolveExplorerLayoutMode(cols: number): ExplorerLayoutMode {\n if (cols < 40) {\n return \"too-narrow\";\n }\n\n if (cols < 80) {\n return \"narrow-list-only\";\n }\n\n if (cols < 100) {\n return \"narrow-vertical\";\n }\n\n if (cols < 120) {\n return \"medium\";\n }\n\n return \"wide\";\n}\n\nfunction normalizeSize(value: number): number {\n if (!Number.isFinite(value)) {\n return 0;\n }\n\n return Math.max(0, Math.floor(value));\n}\n", "import { color } from \"../components/color.js\";\nimport * as clack from \"@clack/prompts\";\nimport { resolveOutputFormat } from \"../internal/output-format.js\";\nimport { stripAnsi } from \"../internal/strip-ansi.js\";\nimport { cancel, isCancel } from \"./primitives/cancel.js\";\nimport { intro } from \"./primitives/intro.js\";\nimport { log } from \"./primitives/log.js\";\nimport { note } from \"./primitives/note.js\";\nimport { outro } from \"./primitives/outro.js\";\nimport { spinner } from \"./primitives/spinner.js\";\n\nexport { isCancel, cancel, log };\nexport { intro, outro, note, spinner };\n\nexport function introPlain(title: string): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`# ${stripAnsi(title)}\\n\\n`);\n return;\n }\n if (format === \"json\") {\n return;\n }\n process.stdout.write(`${color.gray(\"\u250C\")} ${title}\\n`);\n}\n\nexport interface SelectOptions<Value> {\n message: string;\n options: Array<{ value: Value; label: string; hint?: string }>;\n initialValue?: Value;\n}\n\nexport async function select<Value>(opts: SelectOptions<Value>): Promise<Value | symbol> {\n return clack.select(opts as Parameters<typeof clack.select<Value>>[0]);\n}\n\nexport type MultiselectOptions<Value> = Parameters<typeof clack.multiselect<Value>>[0];\n\n/**\n * Prompts the user to select one or more values from a list.\n *\n * Returns the selected values as an array, or a cancellation symbol if the\n * user cancels. Use `isCancel` to check for cancellation.\n *\n * @example\n * const result = await multiselect({\n * message: \"Pick workflows to run\",\n * options: [{ label: \"Fix Vulnerabilities\", value: \"fix-vulnerabilities\" }],\n * required: true\n * });\n * if (!isCancel(result)) {\n * // result is Value[]\n * }\n */\nexport async function multiselect<Value>(\n opts: MultiselectOptions<Value>\n): Promise<Value[] | symbol> {\n return clack.multiselect(opts);\n}\n\nexport type TextOptions = Parameters<typeof clack.text>[0];\n\nexport async function text(opts: TextOptions): Promise<string | symbol> {\n return clack.text(opts as Parameters<typeof clack.text>[0]);\n}\n\nexport interface ConfirmOptions {\n message: string;\n initialValue?: boolean;\n}\n\nexport async function confirm(opts: ConfirmOptions): Promise<boolean | symbol> {\n return clack.confirm(opts as Parameters<typeof clack.confirm>[0]);\n}\n\nexport class PromptCancelledError extends Error {\n constructor(message = \"Operation cancelled.\") {\n super(message);\n this.name = \"PromptCancelledError\";\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, this.constructor);\n }\n }\n}\n\nexport async function confirmOrCancel(opts: ConfirmOptions): Promise<boolean> {\n const result = await confirm(opts);\n if (isCancel(result)) {\n cancel(\"Operation cancelled.\");\n throw new PromptCancelledError();\n }\n return result === true;\n}\n\nexport interface PasswordOptions {\n message: string;\n validate?: (value: string) => string | undefined;\n}\n\nexport async function password(opts: PasswordOptions): Promise<string | symbol> {\n return clack.password(opts as Parameters<typeof clack.password>[0]);\n}\n\nexport type SpinnerOptions = {\n start: (message?: string) => void;\n stop: (message?: string, code?: number) => void;\n message: (message?: string) => void;\n};\n\nexport interface WithSpinnerOptions<T> {\n message: string | (() => string);\n fn: () => Promise<T>;\n stopMessage?: (result: T) => string;\n subtext?: (result: T) => string | undefined;\n}\n\nfunction formatElapsed(ms: number): string {\n const totalSeconds = Math.floor(ms / 1000);\n if (totalSeconds < 60) {\n return `${totalSeconds}s`;\n }\n const minutes = Math.floor(totalSeconds / 60);\n const seconds = totalSeconds % 60;\n return `${minutes}m ${seconds}s`;\n}\n\nexport async function withSpinner<T>(options: WithSpinnerOptions<T>): Promise<T> {\n const { message, fn, stopMessage, subtext } = options;\n const readMessage = () => (typeof message === \"function\" ? message() : message);\n\n if (resolveOutputFormat() === \"json\") {\n const result = await fn();\n const sub = subtext ? subtext(result) : undefined;\n if (sub) {\n process.stdout.write(sub + \"\\n\");\n }\n return result;\n }\n\n const noSpinner = process.env.POE_NO_SPINNER === \"1\";\n const isTTY = process.stdout.isTTY;\n\n if (noSpinner || !isTTY) {\n const result = await fn();\n const msg = stopMessage ? stopMessage(result) : undefined;\n if (msg) {\n process.stdout.write(`\\x1b[32m\u25C6\\x1b[0m ${msg}\\n`);\n }\n const sub = subtext ? subtext(result) : undefined;\n if (sub) {\n for (const line of sub.split(\"\\n\")) {\n process.stdout.write(`\\x1b[90m\u2502\\x1b[0m ${line}\\n`);\n }\n }\n return result;\n }\n\n const s = spinner();\n const start = Date.now();\n s.start(readMessage());\n\n const timer = setInterval(() => {\n s.message(`${readMessage()} [${formatElapsed(Date.now() - start)}]`);\n }, 1000);\n\n try {\n const result = await fn();\n clearInterval(timer);\n const elapsed = formatElapsed(Date.now() - start);\n const msg = stopMessage ? stopMessage(result) : undefined;\n s.stop(msg ? `${msg} [${elapsed}]` : `Done [${elapsed}]`);\n\n const sub = subtext ? subtext(result) : undefined;\n if (sub) {\n for (const line of sub.split(\"\\n\")) {\n process.stdout.write(`\\x1b[90m\u2502\\x1b[0m ${line}\\n`);\n }\n }\n\n return result;\n } catch (error) {\n clearInterval(timer);\n s.stop(\"\", 1);\n throw error;\n }\n}\n", "import { color } from \"../../components/color.js\";\nexport { isCancel } from \"@clack/prompts\";\nimport { resolveOutputFormat } from \"../../internal/output-format.js\";\n\nexport function cancel(msg = \"\"): void {\n if (resolveOutputFormat() !== \"terminal\") {\n return;\n }\n\n process.stdout.write(`${color.gray(\"\u2514\")} ${color.red(msg)}\\n\\n`);\n}\n", "import type {\n ConfigMergeMutation,\n ConfigPruneMutation,\n ConfigTransformMutation,\n ConfigObject,\n ValueResolver,\n MutationOptions\n} from \"../types.js\";\n\nexport interface MergeOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** Value to merge into the config file */\n value: ValueResolver<ConfigObject>;\n /** Optional explicit format override */\n format?: \"json\" | \"toml\" | \"yaml\";\n /** Optional prune by prefix before merging (TOML) */\n pruneByPrefix?: Record<string, string>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface PruneOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** Shape to prune from the config file */\n shape: ValueResolver<ConfigObject>;\n /** Optional explicit format override */\n format?: \"json\" | \"toml\" | \"yaml\";\n /** Optional guard - only prune if predicate returns true */\n onlyIf?: (doc: ConfigObject, ctx: MutationOptions) => boolean;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface TransformOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** Optional explicit format override */\n format?: \"json\" | \"toml\" | \"yaml\";\n /** Transform function - receives parsed content, returns transformed content */\n transform: (\n content: ConfigObject,\n ctx: MutationOptions\n ) => { content: ConfigObject | null; changed: boolean };\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nfunction merge(options: MergeOptions): ConfigMergeMutation {\n return {\n kind: \"configMerge\",\n target: options.target,\n value: options.value,\n format: options.format,\n pruneByPrefix: options.pruneByPrefix,\n label: options.label\n };\n}\n\nfunction prune(options: PruneOptions): ConfigPruneMutation {\n return {\n kind: \"configPrune\",\n target: options.target,\n shape: options.shape,\n format: options.format,\n onlyIf: options.onlyIf,\n label: options.label\n };\n}\n\nfunction transform(options: TransformOptions): ConfigTransformMutation {\n return {\n kind: \"configTransform\",\n target: options.target,\n format: options.format,\n transform: options.transform,\n label: options.label\n };\n}\n\nexport const configMutation = {\n merge,\n prune,\n transform\n};\n", "import type {\n EnsureDirectoryMutation,\n RemoveDirectoryMutation,\n RemoveFileMutation,\n ChmodMutation,\n BackupMutation,\n ValueResolver\n} from \"../types.js\";\n\nexport interface EnsureDirectoryOptions {\n /** Directory path (must start with ~) */\n path: ValueResolver<string>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface RemoveOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** Only remove if file is empty/whitespace */\n whenEmpty?: boolean;\n /** Only remove if content matches regex */\n whenContentMatches?: RegExp;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface RemoveDirectoryOptions {\n /** Directory path (must start with ~) */\n path: ValueResolver<string>;\n /** Remove directory even when not empty */\n force?: boolean;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface ChmodOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** File permission mode (e.g., 0o755) */\n mode: number;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface BackupOptions {\n /** Target file path to backup (must start with ~) */\n target: ValueResolver<string>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nfunction ensureDirectory(options: EnsureDirectoryOptions): EnsureDirectoryMutation {\n return {\n kind: \"ensureDirectory\",\n path: options.path,\n label: options.label\n };\n}\n\nfunction remove(options: RemoveOptions): RemoveFileMutation {\n return {\n kind: \"removeFile\",\n target: options.target,\n whenEmpty: options.whenEmpty,\n whenContentMatches: options.whenContentMatches,\n label: options.label\n };\n}\n\nfunction removeDirectory(\n options: RemoveDirectoryOptions\n): RemoveDirectoryMutation {\n return {\n kind: \"removeDirectory\",\n path: options.path,\n force: options.force,\n label: options.label\n };\n}\n\nfunction chmod(options: ChmodOptions): ChmodMutation {\n return {\n kind: \"chmod\",\n target: options.target,\n mode: options.mode,\n label: options.label\n };\n}\n\nfunction backup(options: BackupOptions): BackupMutation {\n return {\n kind: \"backup\",\n target: options.target,\n label: options.label\n };\n}\n\nexport const fileMutation = {\n ensureDirectory,\n remove,\n removeDirectory,\n chmod,\n backup\n};\n", "import type {\n TemplateWriteMutation,\n TemplateMergeTomlMutation,\n TemplateMergeJsonMutation,\n ConfigObject,\n ValueResolver\n} from \"../types.js\";\n\nexport interface WriteOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** Template ID to load via template loader */\n templateId: string;\n /** Context to pass to renderTemplate() */\n context?: ValueResolver<ConfigObject>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface MergeTomlOptions {\n /** Target TOML file path (must start with ~) */\n target: ValueResolver<string>;\n /** Template ID to load via template loader */\n templateId: string;\n /** Context to pass to renderTemplate() */\n context?: ValueResolver<ConfigObject>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface MergeJsonOptions {\n /** Target JSON file path (must start with ~) */\n target: ValueResolver<string>;\n /** Template ID to load via template loader */\n templateId: string;\n /** Context to pass to renderTemplate() */\n context?: ValueResolver<ConfigObject>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nfunction write(options: WriteOptions): TemplateWriteMutation {\n return {\n kind: \"templateWrite\",\n target: options.target,\n templateId: options.templateId,\n context: options.context,\n label: options.label\n };\n}\n\nfunction mergeToml(options: MergeTomlOptions): TemplateMergeTomlMutation {\n return {\n kind: \"templateMergeToml\",\n target: options.target,\n templateId: options.templateId,\n context: options.context,\n label: options.label\n };\n}\n\nfunction mergeJson(options: MergeJsonOptions): TemplateMergeJsonMutation {\n return {\n kind: \"templateMergeJson\",\n target: options.target,\n templateId: options.templateId,\n context: options.context,\n label: options.label\n };\n}\n\nexport const templateMutation = {\n write,\n mergeToml,\n mergeJson\n};\n", "import * as jsonc from \"jsonc-parser\";\nimport type { ConfigFormat, ConfigObject, ConfigValue } from \"../types.js\";\n\nfunction isConfigObject(value: unknown): value is ConfigObject {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction detectIndent(content: string): string {\n const match = content.match(/^[\\t ]+/m);\n if (match) {\n return match[0];\n }\n return \" \";\n}\n\nfunction parse(content: string): ConfigObject {\n if (!content || content.trim() === \"\") {\n return {};\n }\n const errors: jsonc.ParseError[] = [];\n const parsed = jsonc.parse(content, errors, {\n allowTrailingComma: true,\n disallowComments: false\n });\n if (errors.length > 0) {\n throw new Error(`JSON parse error: ${jsonc.printParseErrorCode(errors[0].error)}`);\n }\n if (parsed === null || parsed === undefined) {\n return {};\n }\n if (!isConfigObject(parsed)) {\n throw new Error(\"Expected JSON object.\");\n }\n return parsed;\n}\n\nfunction serialize(obj: ConfigObject): string {\n return `${JSON.stringify(obj, null, 2)}\\n`;\n}\n\nfunction merge(base: ConfigObject, patch: ConfigObject): ConfigObject {\n const result: ConfigObject = { ...base };\n for (const [key, value] of Object.entries(patch)) {\n if (value === undefined) {\n continue;\n }\n const existing = result[key];\n if (isConfigObject(existing) && isConfigObject(value)) {\n result[key] = merge(existing, value);\n continue;\n }\n result[key] = value as ConfigValue;\n }\n return result;\n}\n\nfunction prune(\n obj: ConfigObject,\n shape: ConfigObject\n): { changed: boolean; result: ConfigObject } {\n let changed = false;\n const result: ConfigObject = { ...obj };\n\n for (const [key, pattern] of Object.entries(shape)) {\n if (!(key in result)) {\n continue;\n }\n\n const current = result[key];\n\n // Empty object pattern means \"delete this key entirely\"\n if (isConfigObject(pattern) && Object.keys(pattern).length === 0) {\n delete result[key];\n changed = true;\n continue;\n }\n\n // Non-empty object pattern with object current: recurse\n if (isConfigObject(pattern) && isConfigObject(current)) {\n const { changed: childChanged, result: childResult } = prune(\n current,\n pattern\n );\n if (childChanged) {\n changed = true;\n }\n if (Object.keys(childResult).length === 0) {\n delete result[key];\n } else {\n result[key] = childResult;\n }\n continue;\n }\n\n delete result[key];\n changed = true;\n }\n\n return { changed, result };\n}\n\n/**\n * Modify JSON content at a specific path while preserving comments and formatting.\n * Uses jsonc-parser's modify() for targeted updates.\n *\n * @param content - The original JSON content (may include comments)\n * @param path - JSON path array, e.g. [\"mcpServers\", \"my-server\"]\n * @param value - The value to set (or undefined to remove)\n * @returns The modified JSON content with comments preserved\n */\nfunction modifyAtPath(\n content: string,\n path: (string | number)[],\n value: ConfigValue | undefined\n): string {\n const indent = detectIndent(content);\n const formattingOptions: jsonc.FormattingOptions = {\n tabSize: indent === \"\\t\" ? 1 : indent.length,\n insertSpaces: indent !== \"\\t\",\n eol: \"\\n\"\n };\n\n const edits = jsonc.modify(content, path, value, { formattingOptions });\n let result = jsonc.applyEdits(content, edits);\n\n if (!result.endsWith(\"\\n\")) {\n result += \"\\n\";\n }\n\n return result;\n}\n\n/**\n * Merge a patch into JSON content while preserving comments and formatting.\n * Uses jsonc.modify() for each top-level key to preserve existing comments.\n *\n * @param content - The original JSON content (may include comments)\n * @param patch - Object with values to merge\n * @returns The modified JSON content with comments preserved\n */\nfunction mergePreservingComments(\n content: string,\n patch: ConfigObject\n): string {\n let result = content || \"{}\";\n\n for (const [key, value] of Object.entries(patch)) {\n if (value === undefined) {\n continue;\n }\n result = modifyAtPath(result, [key], value);\n }\n\n return result;\n}\n\n/**\n * Remove a key from JSON content while preserving comments and formatting.\n *\n * @param content - The original JSON content\n * @param path - JSON path array to the key to remove\n * @returns The modified JSON content with comments preserved\n */\nfunction removeAtPath(content: string, path: (string | number)[]): string {\n return modifyAtPath(content, path, undefined);\n}\n\nexport { detectIndent, modifyAtPath, mergePreservingComments, removeAtPath };\n\nexport const jsonFormat: ConfigFormat = {\n parse,\n serialize,\n merge,\n prune\n};\n", "import { parse as parseToml, stringify as stringifyToml } from \"smol-toml\";\nimport type { ConfigFormat, ConfigObject, ConfigValue } from \"../types.js\";\n\nfunction isConfigObject(value: unknown): value is ConfigObject {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction parse(content: string): ConfigObject {\n if (!content || content.trim() === \"\") {\n return {};\n }\n const parsed = parseToml(content);\n if (!isConfigObject(parsed)) {\n throw new Error(\"Expected TOML document to be a table.\");\n }\n return parsed as ConfigObject;\n}\n\nfunction serialize(obj: ConfigObject): string {\n const serialized = stringifyToml(obj);\n return serialized.endsWith(\"\\n\") ? serialized : `${serialized}\\n`;\n}\n\nfunction merge(base: ConfigObject, patch: ConfigObject): ConfigObject {\n const result: ConfigObject = { ...base };\n for (const [key, value] of Object.entries(patch)) {\n if (value === undefined) {\n continue;\n }\n const existing = result[key];\n if (isConfigObject(existing) && isConfigObject(value)) {\n result[key] = merge(existing, value);\n continue;\n }\n result[key] = value as ConfigValue;\n }\n return result;\n}\n\nfunction prune(\n obj: ConfigObject,\n shape: ConfigObject\n): { changed: boolean; result: ConfigObject } {\n let changed = false;\n const result: ConfigObject = { ...obj };\n\n for (const [key, pattern] of Object.entries(shape)) {\n if (!(key in result)) {\n continue;\n }\n\n const current = result[key];\n\n // Empty object pattern means \"delete this key entirely\"\n if (isConfigObject(pattern) && Object.keys(pattern).length === 0) {\n delete result[key];\n changed = true;\n continue;\n }\n\n // Non-empty object pattern with object current: recurse\n if (isConfigObject(pattern) && isConfigObject(current)) {\n const { changed: childChanged, result: childResult } = prune(\n current,\n pattern\n );\n if (childChanged) {\n changed = true;\n }\n if (Object.keys(childResult).length === 0) {\n delete result[key];\n } else {\n result[key] = childResult;\n }\n continue;\n }\n\n delete result[key];\n changed = true;\n }\n\n return { changed, result };\n}\n\nexport const tomlFormat: ConfigFormat = {\n parse,\n serialize,\n merge,\n prune\n};\n", "import { parse as parseYaml, stringify as stringifyYaml } from \"yaml\";\nimport type { ConfigFormat, ConfigObject, ConfigValue } from \"../types.js\";\n\nfunction isConfigObject(value: unknown): value is ConfigObject {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction parse(content: string): ConfigObject {\n if (!content || content.trim() === \"\") {\n return {};\n }\n const parsed = parseYaml(content);\n if (parsed === null || parsed === undefined) {\n return {};\n }\n if (!isConfigObject(parsed)) {\n throw new Error(\"Expected YAML object.\");\n }\n return parsed;\n}\n\nfunction serialize(obj: ConfigObject): string {\n const serialized = stringifyYaml(obj);\n return serialized.endsWith(\"\\n\") ? serialized : `${serialized}\\n`;\n}\n\nfunction merge(base: ConfigObject, patch: ConfigObject): ConfigObject {\n const result: ConfigObject = { ...base };\n for (const [key, value] of Object.entries(patch)) {\n if (value === undefined) {\n continue;\n }\n const existing = result[key];\n if (isConfigObject(existing) && isConfigObject(value)) {\n result[key] = merge(existing, value);\n continue;\n }\n result[key] = value as ConfigValue;\n }\n return result;\n}\n\nfunction prune(\n obj: ConfigObject,\n shape: ConfigObject\n): { changed: boolean; result: ConfigObject } {\n let changed = false;\n const result: ConfigObject = { ...obj };\n\n for (const [key, pattern] of Object.entries(shape)) {\n if (!(key in result)) {\n continue;\n }\n\n const current = result[key];\n\n if (isConfigObject(pattern) && Object.keys(pattern).length === 0) {\n delete result[key];\n changed = true;\n continue;\n }\n\n if (isConfigObject(pattern) && isConfigObject(current)) {\n const { changed: childChanged, result: childResult } = prune(current, pattern);\n if (childChanged) {\n changed = true;\n }\n if (Object.keys(childResult).length === 0) {\n delete result[key];\n } else {\n result[key] = childResult;\n }\n continue;\n }\n\n delete result[key];\n changed = true;\n }\n\n return { changed, result };\n}\n\nexport const yamlFormat: ConfigFormat = {\n parse,\n serialize,\n merge,\n prune\n};\n", "import type { ConfigFormat } from \"../types.js\";\nimport { jsonFormat } from \"./json.js\";\nimport { tomlFormat } from \"./toml.js\";\nimport { yamlFormat } from \"./yaml.js\";\n\nexport type FormatName = \"json\" | \"toml\" | \"yaml\";\n\nconst formatRegistry: Record<FormatName, ConfigFormat> = {\n json: jsonFormat,\n toml: tomlFormat,\n yaml: yamlFormat\n};\n\nconst extensionMap: Record<string, FormatName> = {\n \".json\": \"json\",\n \".toml\": \"toml\",\n \".yaml\": \"yaml\",\n \".yml\": \"yaml\"\n};\n\n/**\n * Get a format handler by path (auto-detect from extension) or explicit format name.\n */\nexport function getConfigFormat(pathOrFormat: string): ConfigFormat {\n // Check if it's an explicit format name\n if (pathOrFormat in formatRegistry) {\n return formatRegistry[pathOrFormat as FormatName];\n }\n\n // Try to detect from extension\n const ext = getExtension(pathOrFormat);\n const formatName = extensionMap[ext];\n\n if (!formatName) {\n throw new Error(\n `Unsupported config format. Cannot detect format from \"${pathOrFormat}\". ` +\n `Supported extensions: ${Object.keys(extensionMap).join(\", \")}. ` +\n `Supported format names: ${Object.keys(formatRegistry).join(\", \")}.`\n );\n }\n\n return formatRegistry[formatName];\n}\n\n/**\n * Detect format name from a file path.\n */\nexport function detectFormat(path: string): FormatName | undefined {\n const ext = getExtension(path);\n return extensionMap[ext];\n}\n\nfunction getExtension(path: string): string {\n const lastDot = path.lastIndexOf(\".\");\n if (lastDot === -1) {\n return \"\";\n }\n return path.slice(lastDot).toLowerCase();\n}\n\nexport { jsonFormat } from \"./json.js\";\nexport { tomlFormat } from \"./toml.js\";\nexport { yamlFormat } from \"./yaml.js\";\n", "import path from \"node:path\";\nimport type { PathMapper } from \"../types.js\";\n\n/**\n * Expand ~ shortcut to the provided home directory.\n */\nexport function expandHome(targetPath: string, homeDir: string): string {\n if (!targetPath?.startsWith(\"~\")) {\n return targetPath;\n }\n\n // Handle ~./ -> ~/.\n if (targetPath.startsWith(\"~./\")) {\n targetPath = `~/.${targetPath.slice(3)}`;\n }\n\n let remainder = targetPath.slice(1);\n\n // Remove leading slash or backslash\n if (remainder.startsWith(\"/\") || remainder.startsWith(\"\\\\\")) {\n remainder = remainder.slice(1);\n } else if (remainder.startsWith(\".\")) {\n // Handle ~/.\n remainder = remainder.slice(1);\n if (remainder.startsWith(\"/\") || remainder.startsWith(\"\\\\\")) {\n remainder = remainder.slice(1);\n }\n }\n\n return remainder.length === 0 ? homeDir : path.join(homeDir, remainder);\n}\n\n/**\n * Validate that a path is home-relative (starts with ~).\n * Throws if the path is not home-relative.\n */\nexport function validateHomePath(targetPath: string): void {\n if (typeof targetPath !== \"string\" || targetPath.length === 0) {\n throw new Error(\"Target path must be a non-empty string.\");\n }\n\n if (!targetPath.startsWith(\"~\")) {\n throw new Error(\n `All target paths must be home-relative (start with ~). Received: \"${targetPath}\"`\n );\n }\n}\n\n/**\n * Resolve a path with optional path mapping for isolated configurations.\n * 1. Validates the path starts with ~\n * 2. Expands ~ to home directory\n * 3. If pathMapper is provided, maps the directory portion and reconstructs the path\n */\nexport function resolvePath(\n rawPath: string,\n homeDir: string,\n pathMapper?: PathMapper\n): string {\n validateHomePath(rawPath);\n const expanded = expandHome(rawPath, homeDir);\n\n if (!pathMapper) {\n return expanded;\n }\n\n // Map the directory portion\n const rawDirectory = path.dirname(expanded);\n const mappedDirectory = pathMapper.mapTargetDirectory({\n targetDirectory: rawDirectory\n });\n const filename = path.basename(expanded);\n\n return filename.length === 0 ? mappedDirectory : path.join(mappedDirectory, filename);\n}\n", "import type { FileSystem } from \"./types.js\";\n\n/**\n * Check if an error is a \"file not found\" (ENOENT) error.\n */\nexport function isNotFound(error: unknown): boolean {\n return (\n typeof error === \"object\" &&\n error !== null &&\n \"code\" in error &&\n (error as { code?: string }).code === \"ENOENT\"\n );\n}\n\n/**\n * Read a file if it exists, returning null if not found.\n */\nexport async function readFileIfExists(\n fs: FileSystem,\n target: string\n): Promise<string | null> {\n try {\n return await fs.readFile(target, \"utf8\");\n } catch (error) {\n if (isNotFound(error)) {\n return null;\n }\n throw error;\n }\n}\n\n/**\n * Check if a path exists (file or directory).\n */\nexport async function pathExists(\n fs: FileSystem,\n target: string\n): Promise<boolean> {\n try {\n await fs.stat(target);\n return true;\n } catch (error) {\n if (isNotFound(error)) {\n return false;\n }\n throw error;\n }\n}\n\n/**\n * Create an ISO timestamp safe for use in filenames.\n * Replaces colons and dots with dashes.\n */\nexport function createTimestamp(): string {\n return new Date().toISOString().replaceAll(\":\", \"-\").replaceAll(\".\", \"-\");\n}\n", "import { renderTemplate } from \"@poe-code/design-system\";\nimport type {\n Mutation,\n MutationContext,\n MutationOutcome,\n MutationDetails,\n ConfigObject,\n MutationOptions,\n ValueResolver,\n FileSystem\n} from \"../types.js\";\nimport { getConfigFormat, detectFormat } from \"../formats/index.js\";\nimport { resolvePath } from \"./path-utils.js\";\nimport {\n isNotFound,\n readFileIfExists,\n pathExists,\n createTimestamp\n} from \"../fs-utils.js\";\n\n// ============================================================================\n// Helper Functions\n// ============================================================================\n\nfunction resolveValue<T>(\n resolver: ValueResolver<T>,\n options: MutationOptions\n): T {\n if (typeof resolver === \"function\") {\n return (resolver as (ctx: MutationOptions) => T)(options);\n }\n return resolver;\n}\n\nfunction createInvalidDocumentBackupPath(targetPath: string): string {\n const ext = targetPath.includes(\".\") ? targetPath.split(\".\").pop() : \"bak\";\n return `${targetPath}.invalid-${createTimestamp()}.${ext}`;\n}\n\nasync function backupInvalidDocument(\n fs: FileSystem,\n targetPath: string,\n content: string\n): Promise<void> {\n const backupPath = createInvalidDocumentBackupPath(targetPath);\n await fs.writeFile(backupPath, content, { encoding: \"utf8\" });\n}\n\nfunction describeMutation(kind: string, targetPath?: string): string {\n const displayPath = targetPath ?? \"target\";\n switch (kind) {\n case \"ensureDirectory\":\n return `Create ${displayPath}`;\n case \"removeDirectory\":\n return `Remove directory ${displayPath}`;\n case \"backup\":\n return `Backup ${displayPath}`;\n case \"templateWrite\":\n return `Write ${displayPath}`;\n case \"chmod\":\n return `Set permissions on ${displayPath}`;\n case \"removeFile\":\n return `Remove ${displayPath}`;\n case \"configMerge\":\n case \"configPrune\":\n case \"configTransform\":\n case \"templateMergeToml\":\n case \"templateMergeJson\":\n return `Update ${displayPath}`;\n default:\n return \"Operation\";\n }\n}\n\nfunction pruneKeysByPrefix(\n table: ConfigObject,\n prefix: string\n): ConfigObject {\n const result: ConfigObject = {};\n for (const [key, value] of Object.entries(table)) {\n if (!key.startsWith(prefix)) {\n result[key] = value;\n }\n }\n return result;\n}\n\nfunction isConfigObject(value: unknown): value is ConfigObject {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction mergeWithPruneByPrefix(\n base: ConfigObject,\n patch: ConfigObject,\n pruneByPrefix?: Record<string, string>\n): ConfigObject {\n const result: ConfigObject = { ...base };\n const prefixMap = pruneByPrefix ?? {};\n\n for (const [key, value] of Object.entries(patch)) {\n const current = result[key];\n const prefix = prefixMap[key];\n\n if (isConfigObject(current) && isConfigObject(value)) {\n if (prefix) {\n const pruned = pruneKeysByPrefix(current, prefix);\n result[key] = { ...pruned, ...value };\n } else {\n result[key] = mergeWithPruneByPrefix(\n current,\n value as ConfigObject,\n prefixMap\n );\n }\n continue;\n }\n result[key] = value;\n }\n return result;\n}\n\n// ============================================================================\n// Apply Mutation\n// ============================================================================\n\nexport async function applyMutation(\n mutation: Mutation,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n switch (mutation.kind) {\n case \"ensureDirectory\":\n return applyEnsureDirectory(mutation, context, options);\n case \"removeDirectory\":\n return applyRemoveDirectory(mutation, context, options);\n case \"removeFile\":\n return applyRemoveFile(mutation, context, options);\n case \"chmod\":\n return applyChmod(mutation, context, options);\n case \"backup\":\n return applyBackup(mutation, context, options);\n case \"configMerge\":\n return applyConfigMerge(mutation, context, options);\n case \"configPrune\":\n return applyConfigPrune(mutation, context, options);\n case \"configTransform\":\n return applyConfigTransform(mutation, context, options);\n case \"templateWrite\":\n return applyTemplateWrite(mutation, context, options);\n case \"templateMergeToml\":\n return applyTemplateMerge(mutation, context, options, \"toml\");\n case \"templateMergeJson\":\n return applyTemplateMerge(mutation, context, options, \"json\");\n default: {\n const never: never = mutation;\n throw new Error(`Unknown mutation kind: ${(never as Mutation).kind}`);\n }\n }\n}\n\n// ============================================================================\n// File Mutation Handlers\n// ============================================================================\n\nasync function applyEnsureDirectory(\n mutation: Extract<Mutation, { kind: \"ensureDirectory\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.path, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const existed = await pathExists(context.fs, targetPath);\n\n if (!context.dryRun) {\n await context.fs.mkdir(targetPath, { recursive: true });\n }\n\n return {\n outcome: {\n changed: !existed,\n effect: \"mkdir\",\n detail: existed ? \"noop\" : \"create\"\n },\n details\n };\n}\n\nasync function applyRemoveDirectory(\n mutation: Extract<Mutation, { kind: \"removeDirectory\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.path, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const existed = await pathExists(context.fs, targetPath);\n if (!existed) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (typeof context.fs.rm !== \"function\") {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (mutation.force) {\n if (!context.dryRun) {\n await context.fs.rm(targetPath, { recursive: true, force: true });\n }\n return {\n outcome: { changed: true, effect: \"delete\", detail: \"delete\" },\n details\n };\n }\n\n const entries = await context.fs.readdir(targetPath);\n if (entries.length > 0) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (!context.dryRun) {\n await context.fs.rm(targetPath, { recursive: true, force: true });\n }\n\n return {\n outcome: { changed: true, effect: \"delete\", detail: \"delete\" },\n details\n };\n}\n\nasync function applyRemoveFile(\n mutation: Extract<Mutation, { kind: \"removeFile\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n try {\n const content = await context.fs.readFile(targetPath, \"utf8\");\n const trimmed = content.trim();\n\n // Check whenContentMatches guard\n if (mutation.whenContentMatches && !mutation.whenContentMatches.test(trimmed)) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n // Check whenEmpty guard\n if (mutation.whenEmpty && trimmed.length > 0) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (!context.dryRun) {\n await context.fs.unlink(targetPath);\n }\n\n return {\n outcome: { changed: true, effect: \"delete\", detail: \"delete\" },\n details\n };\n } catch (error) {\n if (isNotFound(error)) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n throw error;\n }\n}\n\nasync function applyChmod(\n mutation: Extract<Mutation, { kind: \"chmod\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n if (typeof context.fs.chmod !== \"function\") {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n try {\n const stat = await context.fs.stat(targetPath);\n const currentMode = typeof stat.mode === \"number\" ? stat.mode & 0o777 : null;\n\n if (currentMode === mutation.mode) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (!context.dryRun) {\n await context.fs.chmod(targetPath, mutation.mode);\n }\n\n return {\n outcome: { changed: true, effect: \"chmod\", detail: \"update\" },\n details\n };\n } catch (error) {\n if (isNotFound(error)) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n throw error;\n }\n}\n\nasync function applyBackup(\n mutation: Extract<Mutation, { kind: \"backup\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const content = await readFileIfExists(context.fs, targetPath);\n if (content === null) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (!context.dryRun) {\n const backupPath = `${targetPath}.backup-${createTimestamp()}`;\n await context.fs.writeFile(backupPath, content, { encoding: \"utf8\" });\n }\n\n return {\n outcome: { changed: true, effect: \"copy\", detail: \"backup\" },\n details\n };\n}\n\n// ============================================================================\n// Config Mutation Handlers\n// ============================================================================\n\nasync function applyConfigMerge(\n mutation: Extract<Mutation, { kind: \"configMerge\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const formatName = mutation.format ?? detectFormat(rawPath);\n if (!formatName) {\n throw new Error(\n `Cannot detect config format for \"${rawPath}\". Provide explicit format option.`\n );\n }\n const format = getConfigFormat(formatName);\n\n const rawContent = await readFileIfExists(context.fs, targetPath);\n let current: ConfigObject;\n try {\n current = rawContent === null ? {} : format.parse(rawContent);\n } catch {\n // Invalid file - backup and start fresh\n if (rawContent !== null) {\n await backupInvalidDocument(context.fs, targetPath, rawContent);\n }\n current = {};\n }\n\n const value = resolveValue(mutation.value, options);\n\n // Use mergeWithPruneByPrefix for TOML files with pruneByPrefix option\n let merged: ConfigObject;\n if (mutation.pruneByPrefix) {\n merged = mergeWithPruneByPrefix(current, value, mutation.pruneByPrefix);\n } else {\n merged = format.merge(current, value);\n }\n\n const serialized = format.serialize(merged);\n const changed = serialized !== rawContent;\n\n if (changed && !context.dryRun) {\n await context.fs.writeFile(targetPath, serialized, { encoding: \"utf8\" });\n }\n\n return {\n outcome: {\n changed,\n effect: changed ? \"write\" : \"none\",\n detail: changed ? (rawContent === null ? \"create\" : \"update\") : \"noop\"\n },\n details\n };\n}\n\nasync function applyConfigPrune(\n mutation: Extract<Mutation, { kind: \"configPrune\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const rawContent = await readFileIfExists(context.fs, targetPath);\n if (rawContent === null) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n const formatName = mutation.format ?? detectFormat(rawPath);\n if (!formatName) {\n throw new Error(\n `Cannot detect config format for \"${rawPath}\". Provide explicit format option.`\n );\n }\n const format = getConfigFormat(formatName);\n\n let current: ConfigObject;\n try {\n current = format.parse(rawContent);\n } catch {\n // Invalid file - can't prune, leave as-is\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n // Check onlyIf guard\n if (mutation.onlyIf && !mutation.onlyIf(current, options)) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n const shape = resolveValue(mutation.shape, options);\n const { changed, result } = format.prune(current, shape);\n\n if (!changed) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n // Delete file if empty\n if (Object.keys(result).length === 0) {\n if (!context.dryRun) {\n await context.fs.unlink(targetPath);\n }\n return {\n outcome: { changed: true, effect: \"delete\", detail: \"delete\" },\n details\n };\n }\n\n const serialized = format.serialize(result);\n if (!context.dryRun) {\n await context.fs.writeFile(targetPath, serialized, { encoding: \"utf8\" });\n }\n\n return {\n outcome: { changed: true, effect: \"write\", detail: \"update\" },\n details\n };\n}\n\nasync function applyConfigTransform(\n mutation: Extract<Mutation, { kind: \"configTransform\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const formatName = mutation.format ?? detectFormat(rawPath);\n if (!formatName) {\n throw new Error(\n `Cannot detect config format for \"${rawPath}\". Provide explicit format option.`\n );\n }\n const format = getConfigFormat(formatName);\n\n const rawContent = await readFileIfExists(context.fs, targetPath);\n let current: ConfigObject;\n try {\n current = rawContent === null ? {} : format.parse(rawContent);\n } catch {\n if (rawContent !== null) {\n await backupInvalidDocument(context.fs, targetPath, rawContent);\n }\n current = {};\n }\n\n const { content: transformed, changed } = mutation.transform(current, options);\n\n if (!changed) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n // Delete file if null\n if (transformed === null) {\n if (rawContent === null) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n if (!context.dryRun) {\n await context.fs.unlink(targetPath);\n }\n return {\n outcome: { changed: true, effect: \"delete\", detail: \"delete\" },\n details\n };\n }\n\n const serialized = format.serialize(transformed);\n if (!context.dryRun) {\n await context.fs.writeFile(targetPath, serialized, { encoding: \"utf8\" });\n }\n\n return {\n outcome: {\n changed: true,\n effect: \"write\",\n detail: rawContent === null ? \"create\" : \"update\"\n },\n details\n };\n}\n\n// ============================================================================\n// Template Mutation Handlers\n// ============================================================================\n\nasync function applyTemplateWrite(\n mutation: Extract<Mutation, { kind: \"templateWrite\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n if (!context.templates) {\n throw new Error(\n \"Template mutations require a templates loader. \" +\n \"Provide templates function to runMutations context.\"\n );\n }\n\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const template = await context.templates(mutation.templateId);\n const templateContext = mutation.context\n ? resolveValue(mutation.context, options)\n : {};\n const rendered = renderTemplate(template, templateContext);\n\n const existed = await pathExists(context.fs, targetPath);\n\n if (!context.dryRun) {\n await context.fs.writeFile(targetPath, rendered, { encoding: \"utf8\" });\n }\n\n return {\n outcome: {\n changed: true,\n effect: \"write\",\n detail: existed ? \"update\" : \"create\"\n },\n details\n };\n}\n\nasync function applyTemplateMerge(\n mutation: Extract<Mutation, { kind: \"templateMergeToml\" | \"templateMergeJson\" }>,\n context: MutationContext,\n options: MutationOptions,\n formatName: \"toml\" | \"json\"\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n if (!context.templates) {\n throw new Error(\n \"Template mutations require a templates loader. \" +\n \"Provide templates function to runMutations context.\"\n );\n }\n\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const format = getConfigFormat(formatName);\n\n // Load and render template\n const template = await context.templates(mutation.templateId);\n const templateContext = mutation.context\n ? resolveValue(mutation.context, options)\n : {};\n const rendered = renderTemplate(template, templateContext);\n\n // Parse rendered template\n let templateDoc: ConfigObject;\n try {\n templateDoc = format.parse(rendered);\n } catch (error) {\n throw new Error(\n `Failed to parse rendered template \"${mutation.templateId}\" as ${formatName.toUpperCase()}: ${error}`,\n { cause: error }\n );\n }\n\n // Read and parse existing file\n const rawContent = await readFileIfExists(context.fs, targetPath);\n let current: ConfigObject;\n try {\n current = rawContent === null ? {} : format.parse(rawContent);\n } catch {\n if (rawContent !== null) {\n await backupInvalidDocument(context.fs, targetPath, rawContent);\n }\n current = {};\n }\n\n // Merge\n const merged = format.merge(current, templateDoc);\n const serialized = format.serialize(merged);\n const changed = serialized !== rawContent;\n\n if (changed && !context.dryRun) {\n await context.fs.writeFile(targetPath, serialized, { encoding: \"utf8\" });\n }\n\n return {\n outcome: {\n changed,\n effect: changed ? \"write\" : \"none\",\n detail: changed ? (rawContent === null ? \"create\" : \"update\") : \"noop\"\n },\n details\n };\n}\n", "import type {\n Mutation,\n MutationContext,\n MutationResult,\n MutationOptions\n} from \"../types.js\";\nimport { applyMutation } from \"./apply-mutation.js\";\n\n/**\n * Execute an array of mutations in order.\n *\n * All dependencies must be injected - no defaults, no globals.\n */\nexport async function runMutations(\n mutations: Mutation[],\n context: MutationContext,\n options?: MutationOptions\n): Promise<MutationResult> {\n const effects: MutationResult[\"effects\"] = [];\n let anyChanged = false;\n const resolverOptions = options ?? {};\n\n for (const mutation of mutations) {\n const { outcome } = await executeMutation(\n mutation,\n context,\n resolverOptions\n );\n effects.push(outcome);\n if (outcome.changed) {\n anyChanged = true;\n }\n }\n\n return {\n changed: anyChanged,\n effects\n };\n}\n\nasync function executeMutation(\n mutation: Mutation,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationResult[\"effects\"][number]; details: { kind: string; label: string; targetPath?: string } }> {\n // Call onStart observer\n context.observers?.onStart?.({\n kind: mutation.kind,\n label: mutation.label ?? mutation.kind,\n targetPath: undefined // Will be resolved during apply\n });\n\n try {\n const { outcome, details } = await applyMutation(mutation, context, options);\n\n // Call onComplete observer\n context.observers?.onComplete?.(details, outcome);\n\n return { outcome, details };\n } catch (error) {\n // Call onError observer\n context.observers?.onError?.(\n {\n kind: mutation.kind,\n label: mutation.label ?? mutation.kind,\n targetPath: undefined\n },\n error\n );\n\n // Re-throw the error\n throw error;\n }\n}\n", "// ============================================================================\n// Config Object Types\n// ============================================================================\n\nexport type ConfigPrimitive = string | number | boolean | null;\nexport type ConfigValue = ConfigPrimitive | ConfigObject | ConfigArray | Date;\nexport interface ConfigObject {\n [key: string]: ConfigValue;\n}\nexport type ConfigArray = ConfigValue[];\n\nexport function isConfigObject(value: unknown): value is ConfigObject {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\n// ============================================================================\n// FileSystem Interface\n// ============================================================================\n\nexport interface FileSystem {\n readFile(path: string, encoding: \"utf8\"): Promise<string>;\n writeFile(\n path: string,\n content: string,\n options?: { encoding: \"utf8\" }\n ): Promise<void>;\n mkdir(path: string, options?: { recursive: boolean }): Promise<void>;\n unlink(path: string): Promise<void>;\n rm?(\n path: string,\n options?: { recursive?: boolean; force?: boolean }\n ): Promise<void>;\n stat(path: string): Promise<{ mode?: number }>;\n readdir(path: string): Promise<string[]>;\n chmod?(path: string, mode: number): Promise<void>;\n}\n\n// ============================================================================\n// Template Loader\n// ============================================================================\n\nexport type TemplateLoader = (templateId: string) => Promise<string>;\n\n// ============================================================================\n// Config Format Interface\n// ============================================================================\n\nexport interface ConfigFormat {\n /** Parse string content into object */\n parse(content: string): ConfigObject;\n\n /** Serialize object to string (with consistent formatting) */\n serialize(obj: ConfigObject): string;\n\n /** Deep merge patch into base, returning new object */\n merge(base: ConfigObject, patch: ConfigObject): ConfigObject;\n\n /** Remove keys matching shape from object, returning new object */\n prune(\n obj: ConfigObject,\n shape: ConfigObject\n ): { changed: boolean; result: ConfigObject };\n}\n\n// ============================================================================\n// Path Mapper (for isolated configurations)\n// ============================================================================\n\nexport interface PathMapper {\n /** Map a target directory to a different location (e.g., for isolated configs) */\n mapTargetDirectory(input: { targetDirectory: string }): string;\n}\n\n// ============================================================================\n// Mutation Context (passed to runMutations)\n// ============================================================================\n\nexport interface MutationContext {\n /** Filesystem interface - required */\n fs: FileSystem;\n\n /** Home directory for ~ expansion - required */\n homeDir: string;\n\n /** Optional dry-run mode */\n dryRun?: boolean;\n\n /** Optional observers for logging */\n observers?: MutationObservers;\n\n /** Required for template mutations */\n templates?: TemplateLoader;\n\n /** Optional path mapper for redirecting paths (used for isolated configs) */\n pathMapper?: PathMapper;\n}\n\n// ============================================================================\n// Value Resolver (static value or context-aware function)\n// ============================================================================\n\nexport interface MutationOptions {\n [key: string]: unknown;\n}\n\nexport type ValueResolver<T> = T | ((ctx: MutationOptions) => T);\n\n// ============================================================================\n// Mutation Types\n// ============================================================================\n\ninterface BaseMutation {\n /** Human-readable label for logging */\n label?: string;\n}\n\n// Config mutations\nexport interface ConfigMergeMutation extends BaseMutation {\n kind: \"configMerge\";\n target: ValueResolver<string>;\n value: ValueResolver<ConfigObject>;\n format?: \"json\" | \"toml\" | \"yaml\";\n pruneByPrefix?: Record<string, string>;\n}\n\nexport interface ConfigPruneMutation extends BaseMutation {\n kind: \"configPrune\";\n target: ValueResolver<string>;\n shape: ValueResolver<ConfigObject>;\n format?: \"json\" | \"toml\" | \"yaml\";\n onlyIf?: (doc: ConfigObject, ctx: MutationOptions) => boolean;\n}\n\nexport interface ConfigTransformMutation extends BaseMutation {\n kind: \"configTransform\";\n target: ValueResolver<string>;\n format?: \"json\" | \"toml\" | \"yaml\";\n transform: (\n content: ConfigObject,\n ctx: MutationOptions\n ) => { content: ConfigObject | null; changed: boolean };\n}\n\n// File mutations\nexport interface EnsureDirectoryMutation extends BaseMutation {\n kind: \"ensureDirectory\";\n path: ValueResolver<string>;\n}\n\nexport interface RemoveDirectoryMutation extends BaseMutation {\n kind: \"removeDirectory\";\n path: ValueResolver<string>;\n force?: boolean;\n}\n\nexport interface RemoveFileMutation extends BaseMutation {\n kind: \"removeFile\";\n target: ValueResolver<string>;\n whenEmpty?: boolean;\n whenContentMatches?: RegExp;\n}\n\nexport interface ChmodMutation extends BaseMutation {\n kind: \"chmod\";\n target: ValueResolver<string>;\n mode: number;\n}\n\nexport interface BackupMutation extends BaseMutation {\n kind: \"backup\";\n target: ValueResolver<string>;\n}\n\n// Template mutations\nexport interface TemplateWriteMutation extends BaseMutation {\n kind: \"templateWrite\";\n target: ValueResolver<string>;\n templateId: string;\n context?: ValueResolver<ConfigObject>;\n}\n\nexport interface TemplateMergeTomlMutation extends BaseMutation {\n kind: \"templateMergeToml\";\n target: ValueResolver<string>;\n templateId: string;\n context?: ValueResolver<ConfigObject>;\n}\n\nexport interface TemplateMergeJsonMutation extends BaseMutation {\n kind: \"templateMergeJson\";\n target: ValueResolver<string>;\n templateId: string;\n context?: ValueResolver<ConfigObject>;\n}\n\nexport type Mutation =\n | ConfigMergeMutation\n | ConfigPruneMutation\n | ConfigTransformMutation\n | EnsureDirectoryMutation\n | RemoveDirectoryMutation\n | RemoveFileMutation\n | ChmodMutation\n | BackupMutation\n | TemplateWriteMutation\n | TemplateMergeTomlMutation\n | TemplateMergeJsonMutation;\n\n// ============================================================================\n// Mutation Result\n// ============================================================================\n\nexport type MutationEffect =\n | \"none\"\n | \"mkdir\"\n | \"write\"\n | \"delete\"\n | \"chmod\"\n | \"copy\";\n\nexport type MutationDetail =\n | \"create\"\n | \"update\"\n | \"delete\"\n | \"noop\"\n | \"backup\";\n\nexport interface MutationOutcome {\n changed: boolean;\n effect: MutationEffect;\n detail?: MutationDetail;\n}\n\nexport interface MutationDetails {\n kind: string;\n label: string;\n targetPath?: string;\n}\n\nexport interface MutationObservers {\n onStart?(details: MutationDetails): void;\n onComplete?(details: MutationDetails, outcome: MutationOutcome): void;\n onError?(details: MutationDetails, error: unknown): void;\n}\n\nexport interface MutationResult {\n changed: boolean;\n effects: MutationOutcome[];\n}\n", "import type {\n InferConfig,\n InferSchemaField,\n JsonSchemaField,\n SchemaField,\n ScopeSchema\n} from \"./types.js\";\n\nexport function resolveScope<S extends ScopeSchema>(\n schema: S,\n fileValues?: Record<string, unknown>,\n env: Record<string, string | undefined> = {}\n): InferConfig<S> {\n const resolved = {} as InferConfig<S>;\n\n for (const key of Object.keys(schema) as Array<keyof S & string>) {\n const field = schema[key];\n const envValue = resolveEnvValue(field, env, key);\n const fileValue = resolveFileValue(field, fileValues?.[key], key);\n resolved[key] = (envValue ?? fileValue ?? field.default) as InferConfig<S>[typeof key];\n }\n\n return resolved;\n}\n\nfunction resolveEnvValue<T extends SchemaField>(\n field: T,\n env: Record<string, string | undefined>,\n key: string\n): InferSchemaField<T> | undefined {\n if (!field.env) {\n return undefined;\n }\n\n const raw = env[field.env];\n if (raw === undefined) {\n return undefined;\n }\n\n return coerceValue(field, raw, key);\n}\n\nfunction resolveFileValue<T extends SchemaField>(\n field: T,\n value: unknown,\n key: string\n): InferSchemaField<T> | undefined {\n return coerceValue(field, value, key);\n}\n\nfunction coerceValue<T extends SchemaField>(\n field: T,\n value: unknown,\n key: string\n): InferSchemaField<T> | undefined {\n switch (field.type) {\n case \"string\":\n return typeof value === \"string\" ? value as InferSchemaField<T> : undefined;\n case \"number\":\n return coerceNumber(value) as InferSchemaField<T> | undefined;\n case \"boolean\":\n return coerceBoolean(value) as InferSchemaField<T> | undefined;\n case \"json\":\n return coerceJson(field, value, key) as InferSchemaField<T> | undefined;\n }\n}\n\nfunction coerceNumber(value: unknown): number | undefined {\n if (typeof value === \"number\" && Number.isFinite(value)) {\n return value;\n }\n\n if (typeof value !== \"string\" || value.length === 0) {\n return undefined;\n }\n\n const parsed = Number(value);\n return Number.isNaN(parsed) ? undefined : parsed;\n}\n\nfunction coerceBoolean(value: unknown): boolean | undefined {\n if (typeof value === \"boolean\") {\n return value;\n }\n\n if (value === \"true\" || value === \"1\") {\n return true;\n }\n\n if (value === \"false\" || value === \"0\") {\n return false;\n }\n\n return undefined;\n}\n\nfunction coerceJson<T>(\n field: JsonSchemaField<T>,\n value: unknown,\n key: string\n): T | undefined {\n if (value === undefined) {\n return undefined;\n }\n\n const parsedValue = parseJsonValue(value, key);\n try {\n return field.parse(parsedValue);\n } catch (error) {\n const message = error instanceof Error ? error.message : \"Invalid JSON value.\";\n throw new Error(`Invalid config value for \"${key}\": ${message}`);\n }\n}\n\nfunction parseJsonValue(value: unknown, key: string): unknown {\n if (typeof value !== \"string\") {\n return value;\n }\n\n try {\n return JSON.parse(value);\n } catch {\n throw new Error(`Invalid config value for \"${key}\": expected valid JSON.`);\n }\n}\n", "import type { ConfigDocument } from \"./types.js\";\n\nexport function deepMergeDocuments(base: ConfigDocument, override: ConfigDocument): ConfigDocument {\n const merged: ConfigDocument = {};\n const scopes = new Set([...Object.keys(base), ...Object.keys(override)]);\n\n for (const scope of scopes) {\n const baseScope = base[scope] ?? {};\n const overrideScope = override[scope] ?? {};\n const nextScope = mergeScope(scope, baseScope, overrideScope);\n\n if (Object.keys(nextScope).length > 0) {\n merged[scope] = nextScope;\n }\n }\n\n return merged;\n}\n\nfunction mergeScope(\n scope: string,\n baseScope: Record<string, unknown>,\n overrideScope: Record<string, unknown>\n): Record<string, unknown> {\n if (scope === \"runtime\") {\n return mergeRuntimeScope(baseScope, overrideScope);\n }\n\n const scopeEntries = Object.entries(overrideScope).filter(([, value]) => value !== undefined);\n return {\n ...baseScope,\n ...Object.fromEntries(scopeEntries)\n };\n}\n\nfunction mergeRuntimeScope(\n baseScope: Record<string, unknown>,\n overrideScope: Record<string, unknown>,\n path: string[] = []\n): Record<string, unknown> {\n const merged: Record<string, unknown> = {};\n const keys = new Set([...Object.keys(baseScope), ...Object.keys(overrideScope)]);\n\n for (const key of keys) {\n const baseValue = baseScope[key];\n const overrideValue = overrideScope[key];\n if (overrideValue === undefined) {\n if (baseValue !== undefined) {\n merged[key] = baseValue;\n }\n continue;\n }\n\n if (\n isRuntimeConcatenativeArray([...path, key]) &&\n Array.isArray(baseValue) &&\n Array.isArray(overrideValue)\n ) {\n merged[key] = [...baseValue, ...overrideValue];\n continue;\n }\n\n if (isRecord(baseValue) && isRecord(overrideValue)) {\n merged[key] = mergeRuntimeScope(baseValue, overrideValue, [...path, key]);\n continue;\n }\n\n merged[key] = overrideValue;\n }\n\n return merged;\n}\n\nfunction isRuntimeConcatenativeArray(path: string[]): boolean {\n return path.join(\".\") === \"mounts\" || path.join(\".\") === \"runner.workspace.exclude\";\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value && typeof value === \"object\" && !Array.isArray(value));\n}\n", "import path from \"node:path\";\nimport { pathExists, type FileSystem } from \"@poe-code/config-mutations\";\nimport type { ConfigDocument, ConfigFieldType, ScopeDefinition, ScopeSchema } from \"./types.js\";\n\nexport interface EnvOverrides {\n entries: string[];\n document: ConfigDocument;\n}\n\nexport interface EditTargetOptions {\n global?: boolean;\n project?: boolean;\n}\n\nexport function collectEnvOverrides(\n scopes: ReadonlyArray<ScopeDefinition<ScopeSchema>>,\n env: Record<string, string | undefined>\n): EnvOverrides {\n const document: ConfigDocument = {};\n const entries: string[] = [];\n\n for (const definition of scopes) {\n const scopeResult = collectScopeEnvOverrides(definition, env);\n if (Object.keys(scopeResult.values).length === 0) {\n continue;\n }\n\n document[definition.scope] = scopeResult.values;\n entries.push(...scopeResult.entries);\n }\n\n return { entries, document };\n}\n\nexport async function resolveEditTarget(\n fs: FileSystem,\n configPath: string,\n projectConfigPath: string,\n options: EditTargetOptions\n): Promise<string> {\n if (options.global && options.project) {\n throw new Error(\"Choose either --global or --project, not both.\");\n }\n\n if (options.global) {\n return configPath;\n }\n if (options.project) {\n return projectConfigPath;\n }\n if (await pathExists(fs, projectConfigPath)) {\n return projectConfigPath;\n }\n return configPath;\n}\n\nexport async function initProjectConfig(\n fs: FileSystem,\n targetPath: string\n): Promise<\"created\" | \"already-exists\"> {\n if (await pathExists(fs, targetPath)) {\n return \"already-exists\";\n }\n\n await fs.mkdir(path.dirname(targetPath), { recursive: true });\n await fs.writeFile(targetPath, EMPTY_DOCUMENT, { encoding: \"utf8\" });\n return \"created\";\n}\n\nfunction collectScopeEnvOverrides<S extends ScopeSchema>(\n definition: ScopeDefinition<S>,\n env: Record<string, string | undefined>\n): {\n entries: string[];\n values: Record<string, unknown>;\n} {\n const entries: string[] = [];\n const values: Record<string, unknown> = {};\n\n for (const [key, field] of Object.entries(definition.schema) as Array<\n [keyof S & string, S[keyof S & string]]\n >) {\n if (!field.env) {\n continue;\n }\n\n const value = coerceEnvValue(field.type, env[field.env]);\n if (value === undefined) {\n continue;\n }\n\n values[key] = value;\n entries.push(` ${field.env} = ${String(value)}`);\n }\n\n return { entries, values };\n}\n\nfunction coerceEnvValue(\n type: ConfigFieldType,\n raw: string | undefined\n): unknown {\n if (raw === undefined) {\n return undefined;\n }\n\n if (type === \"string\") {\n return raw;\n }\n if (type === \"number\") {\n if (raw.length === 0) {\n return undefined;\n }\n const parsed = Number(raw);\n return Number.isNaN(parsed) ? undefined : parsed;\n }\n if (type === \"json\") {\n try {\n return JSON.parse(raw);\n } catch {\n return undefined;\n }\n }\n if (raw === \"true\" || raw === \"1\") {\n return true;\n }\n if (raw === \"false\" || raw === \"0\") {\n return false;\n }\n return undefined;\n}\n\nconst EMPTY_DOCUMENT = `${JSON.stringify({}, null, 2)}\\n`;\n", "import path from \"node:path\";\nimport { allAgents, resolveAgentId, type AgentDefinition } from \"@poe-code/agent-defs\";\nimport { createTimestamp, readFileIfExists, type FileSystem } from \"@poe-code/config-mutations\";\nimport {\n anthropicProvider,\n cloudflareProvider,\n poeProvider,\n ProviderRegistry,\n resolveApiShape,\n type ApiShapeId\n} from \"@poe-code/providers\";\nimport { readDocument, readMergedDocument, writeScope } from \"./store.js\";\n\nexport interface ConfigStoreOptions {\n fs: FileSystem;\n filePath: string;\n projectFilePath?: string;\n providerRegistry?: Pick<ProviderRegistry, \"get\">;\n warn?: (message: string) => void;\n}\n\nexport interface ConfiguredServiceMetadata {\n provider: string;\n apiShape?: ApiShapeId;\n files: string[];\n}\n\ninterface LegacyConfigDocument {\n apiKey?: string;\n configured_services?: Record<string, ConfiguredServiceMetadata>;\n}\n\nexport interface SaveConfiguredServiceOptions extends ConfigStoreOptions {\n service: string;\n metadata: ConfiguredServiceMetadata;\n}\n\nexport interface UnconfigureServiceOptions extends ConfigStoreOptions {\n service: string;\n}\n\nexport async function loadConfiguredServices(\n options: ConfigStoreOptions\n): Promise<Record<string, ConfiguredServiceMetadata>> {\n const { fs, filePath, projectFilePath } = options;\n await migrateLegacyCredentialsIfNeeded(fs, filePath);\n await migrateConfiguredServicesIfNeeded(options, filePath);\n if (projectFilePath && projectFilePath !== filePath) {\n await migrateConfiguredServicesIfNeeded(options, projectFilePath);\n }\n\n const document = await readMergedDocument(fs, filePath, projectFilePath);\n return normalizeConfiguredServices(document[configuredServicesScope]);\n}\n\nexport async function saveConfiguredService(options: SaveConfiguredServiceOptions): Promise<void> {\n const { fs, filePath, service, metadata } = options;\n await migrateLegacyCredentialsIfNeeded(fs, filePath);\n await migrateConfiguredServicesIfNeeded(options, filePath);\n\n const document = await readDocument(fs, filePath);\n const services = normalizeConfiguredServices(document[configuredServicesScope]);\n const registry = options.providerRegistry ?? defaultProviderRegistry;\n services[service] = normalizeConfiguredServiceMetadata({\n ...metadata,\n apiShape:\n metadata.apiShape ??\n deriveApiShape({\n service,\n provider: metadata.provider,\n registry,\n warn: options.warn ?? console.warn\n })\n });\n\n await writeScope(fs, filePath, configuredServicesScope, services);\n}\n\nexport async function unconfigureService(options: UnconfigureServiceOptions): Promise<boolean> {\n const { fs, filePath, service } = options;\n await migrateLegacyCredentialsIfNeeded(fs, filePath);\n\n const document = await readDocument(fs, filePath);\n const services = normalizeConfiguredServices(document[configuredServicesScope]);\n\n if (!(service in services)) {\n return false;\n }\n\n delete services[service];\n await writeScope(fs, filePath, configuredServicesScope, services);\n return true;\n}\n\nasync function migrateConfiguredServicesIfNeeded(\n options: ConfigStoreOptions,\n filePath: string\n): Promise<void> {\n const document = await readDocument(options.fs, filePath);\n const rawServices = document[configuredServicesScope];\n if (!isRecord(rawServices)) {\n return;\n }\n\n let needsMigration = false;\n const migrated: Record<string, unknown> = {};\n const registry = options.providerRegistry ?? defaultProviderRegistry;\n\n for (const [service, entry] of Object.entries(rawServices)) {\n if (!isRecord(entry)) {\n continue;\n }\n\n const provider = typeof entry.provider === \"string\" ? entry.provider : \"poe\";\n const normalizedEntry: Record<string, unknown> = {\n ...entry,\n provider\n };\n\n if (typeof entry.provider !== \"string\") {\n needsMigration = true;\n }\n\n if (typeof entry.apiShape !== \"string\") {\n const apiShape = deriveApiShape({\n service,\n provider,\n registry,\n warn: options.warn ?? console.warn\n });\n if (apiShape) {\n normalizedEntry.apiShape = apiShape;\n needsMigration = true;\n }\n }\n\n migrated[service] = normalizedEntry;\n }\n\n if (needsMigration) {\n await writeScope(options.fs, filePath, configuredServicesScope, migrated);\n }\n}\n\nfunction deriveApiShape(input: {\n service: string;\n provider: string;\n registry: Pick<ProviderRegistry, \"get\">;\n warn: (message: string) => void;\n}): ApiShapeId | undefined {\n const provider = input.registry.get(input.provider);\n const agent = resolveConfiguredAgent(input.service);\n const apiShape = provider && agent ? resolveApiShape(provider, agent) : undefined;\n if (!apiShape) {\n input.warn(\n `Unable to derive apiShape for configured service \"${input.service}\" with provider \"${input.provider}\".`\n );\n }\n return apiShape;\n}\n\nfunction resolveConfiguredAgent(service: string): AgentDefinition | undefined {\n const agentId = resolveAgentId(service);\n return agentId ? agentsById.get(agentId) : undefined;\n}\n\nfunction normalizeConfiguredServices(value: unknown): Record<string, ConfiguredServiceMetadata> {\n if (!isRecord(value)) {\n return {};\n }\n\n const entries: Record<string, ConfiguredServiceMetadata> = {};\n for (const [key, entry] of Object.entries(value)) {\n if (!isRecord(entry)) {\n continue;\n }\n\n entries[key] = normalizeConfiguredServiceMetadata({\n provider: typeof entry.provider === \"string\" ? entry.provider : \"poe\",\n apiShape: typeof entry.apiShape === \"string\" ? (entry.apiShape as ApiShapeId) : undefined,\n files: Array.isArray(entry.files) ? entry.files : []\n });\n }\n\n return entries;\n}\n\nfunction normalizeConfiguredServiceMetadata(\n metadata: ConfiguredServiceMetadata\n): ConfiguredServiceMetadata {\n const seen = new Set<string>();\n const files: string[] = [];\n\n for (const entry of metadata.files ?? []) {\n if (typeof entry !== \"string\" || entry.length === 0) {\n continue;\n }\n if (!seen.has(entry)) {\n files.push(entry);\n seen.add(entry);\n }\n }\n\n return omitUndefined({\n provider: metadata.provider,\n apiShape: metadata.apiShape,\n files\n });\n}\n\nasync function migrateLegacyCredentialsIfNeeded(fs: FileSystem, filePath: string): Promise<void> {\n const currentRaw = await readFileIfExists(fs, filePath);\n if (currentRaw !== null) {\n return;\n }\n\n await migrateLegacyCredentialsFile(fs, filePath);\n}\n\nasync function migrateLegacyCredentialsFile(fs: FileSystem, configPath: string): Promise<void> {\n const legacyPath = path.join(path.dirname(configPath), \"credentials.json\");\n const raw = await readFileIfExists(fs, legacyPath);\n if (raw === null) {\n return;\n }\n\n let legacyDocument: LegacyConfigDocument;\n try {\n legacyDocument = normalizeLegacyConfigDocument(JSON.parse(raw));\n } catch (error) {\n if (error instanceof SyntaxError) {\n await recoverInvalidConfig(fs, legacyPath, raw);\n await fs.unlink(legacyPath);\n return;\n }\n throw error;\n }\n\n if (legacyDocument.configured_services) {\n await writeScope(fs, configPath, configuredServicesScope, legacyDocument.configured_services);\n }\n\n if (legacyDocument.apiKey) {\n await writeScope(fs, configPath, CORE_SCOPE, {\n apiKey: legacyDocument.apiKey\n });\n }\n\n await fs.unlink(legacyPath);\n}\n\nfunction normalizeLegacyConfigDocument(value: unknown): LegacyConfigDocument {\n if (!isRecord(value)) {\n return {};\n }\n\n const document: LegacyConfigDocument = {};\n if (typeof value.apiKey === \"string\" && value.apiKey.length > 0) {\n document.apiKey = value.apiKey;\n }\n\n const services = normalizeConfiguredServices(value.configured_services);\n if (Object.keys(services).length > 0) {\n document.configured_services = services;\n }\n\n return document;\n}\n\nasync function recoverInvalidConfig(\n fs: FileSystem,\n filePath: string,\n content: string\n): Promise<void> {\n const backupPath = createInvalidBackupPath(filePath);\n await fs.writeFile(backupPath, content, { encoding: \"utf8\" });\n await fs.writeFile(filePath, EMPTY_DOCUMENT, { encoding: \"utf8\" });\n}\n\nfunction createInvalidBackupPath(filePath: string): string {\n const directory = path.dirname(filePath);\n const baseName = path.basename(filePath);\n return path.join(directory, `${baseName}.invalid-${createTimestamp()}.json`);\n}\n\nfunction omitUndefined<T extends Record<string, unknown>>(value: T): T {\n return Object.fromEntries(Object.entries(value).filter(([, entry]) => entry !== undefined)) as T;\n}\n\nfunction isRecord(value: unknown): value is Record<string, any> {\n return Boolean(value && typeof value === \"object\" && !Array.isArray(value));\n}\n\nconst agentsById = new Map(allAgents.map((agent) => [agent.id, agent]));\nconst defaultProviderRegistry = new ProviderRegistry([\n poeProvider,\n anthropicProvider,\n cloudflareProvider\n]);\nconst CORE_SCOPE = \"core\";\nconst configuredServicesScope = \"configured_services\";\nconst EMPTY_DOCUMENT = `${JSON.stringify({}, null, 2)}\\n`;\n", "import type { ApiKeyAuth, AuthProvider } from \"../types.js\";\nimport type { AuthStrategy, AuthStrategyContext } from \"./types.js\";\n\nexport interface ApiKeyLoginOptions {\n apiKey?: string;\n}\n\nfunction requireApiKeyAuth(provider: AuthProvider): ApiKeyAuth {\n if (provider.auth.kind !== \"api-key\") {\n throw new Error(\n `Provider ${provider.id} does not use api-key auth (got ${provider.auth.kind}).`\n );\n }\n return provider.auth;\n}\n\nasync function acquireApiKey(\n provider: AuthProvider,\n options: ApiKeyLoginOptions,\n context: AuthStrategyContext\n): Promise<string> {\n const auth = requireApiKeyAuth(provider);\n const candidate =\n options.apiKey ?? (await context.promptForSecret?.(auth.prompt));\n const trimmed = candidate?.trim();\n if (!trimmed) {\n throw new Error(\n `No API key available for provider \"${provider.id}\". Pass --api-key or run interactively.`\n );\n }\n return trimmed;\n}\n\nexport const apiKeyAuthStrategy: AuthStrategy<ApiKeyLoginOptions> = {\n async login(provider, options, context) {\n const apiKey = await acquireApiKey(provider, options, context);\n await context.secretStore.set(apiKey);\n return apiKey;\n },\n\n async logout(_provider, context) {\n await context.secretStore.delete();\n },\n\n async isLoggedIn(_provider, context) {\n const value = await context.secretStore.get();\n return typeof value === \"string\" && value.trim().length > 0;\n },\n\n async resolveCredential(provider, context) {\n requireApiKeyAuth(provider);\n const value = await context.secretStore.get();\n if (!value || value.trim().length === 0) {\n throw new Error(\n `No stored credential for provider \"${provider.id}\". Run \\`poe-code provider login ${provider.id}\\`.`\n );\n }\n return value;\n }\n};\n", "import type { ApiShapeId, AuthProvider } from \"./types.js\";\n\nexport function resolveApiShape(\n provider: AuthProvider,\n agent: { apiShapes?: readonly ApiShapeId[] }\n): ApiShapeId | undefined {\n if (!provider.apiShapes || !agent.apiShapes) {\n return undefined;\n }\n for (const shapeId of agent.apiShapes) {\n if (provider.apiShapes.some((shape) => shape.id === shapeId)) {\n return shapeId;\n }\n }\n return undefined;\n}\n", "import type { ApiShapeId, AuthProvider } from \"./types.js\";\nimport type { SecretStore } from \"auth-store\";\nimport { apiKeyAuthStrategy } from \"./auth/api-key.js\";\nimport type { ApiKeyLoginOptions } from \"./auth/api-key.js\";\nimport type { PromptForSecret } from \"./auth/types.js\";\nimport { resolveApiShape } from \"./compatibility.js\";\n\nexport interface LoginContext {\n promptForSecret?: PromptForSecret;\n envVars?: Record<string, string | undefined>;\n resolvePreferredLogin?: (input: {\n provider: AuthProvider;\n apiKey?: string;\n envValue?: string;\n }) => Promise<string>;\n}\n\nexport type ProviderStoreFactory = (providerId: string) => SecretStore;\n\nexport interface ProviderRegistryOptions {\n envVars?: Record<string, string | undefined>;\n}\n\nexport interface ProviderAgent {\n id: string;\n apiShapes?: readonly ApiShapeId[];\n}\n\nexport class ProviderRegistry {\n private readonly providers: readonly AuthProvider[];\n private readonly byId: ReadonlyMap<string, AuthProvider>;\n private readonly storeFactory?: ProviderStoreFactory;\n private readonly envVars: Record<string, string | undefined>;\n\n constructor(\n providers: readonly AuthProvider[],\n storeFactory?: ProviderStoreFactory,\n options?: ProviderRegistryOptions\n ) {\n const byId = new Map<string, AuthProvider>();\n for (const provider of providers) {\n if (byId.has(provider.id)) {\n throw new Error(`Duplicate provider id: ${provider.id}`);\n }\n byId.set(provider.id, provider);\n }\n this.providers = providers;\n this.byId = byId;\n this.storeFactory = storeFactory;\n this.envVars = options?.envVars ?? {};\n }\n\n list(): readonly AuthProvider[] {\n return this.providers;\n }\n\n get(id: string): AuthProvider | undefined {\n return this.byId.get(id);\n }\n\n forAgent(agent: ProviderAgent): readonly AuthProvider[] {\n return this.providers.filter((provider) => {\n return resolveApiShape(provider, agent) !== undefined;\n });\n }\n\n async isLoggedIn(id: string): Promise<boolean> {\n const provider = this.requireProvider(id);\n if (provider.auth.kind === \"api-key\") {\n const envValue = this.envVars[provider.auth.envVar];\n if (typeof envValue === \"string\" && envValue.trim().length > 0) {\n return true;\n }\n }\n const store = this.requireStore(id);\n const credential = await store.get();\n return credential !== null;\n }\n\n async login(id: string, options: ApiKeyLoginOptions, context?: LoginContext): Promise<void> {\n const provider = this.requireProvider(id);\n const store = this.requireStore(id);\n if (provider.auth.kind !== \"api-key\") {\n throw new Error(`Provider \"${id}\" does not use api-key auth.`);\n }\n const auth = provider.auth;\n const envApiKey = context?.envVars?.[auth.envVar];\n const resolvedApiKey =\n options.apiKey ??\n (typeof envApiKey === \"string\" && envApiKey.trim() ? envApiKey : undefined);\n if (auth.preferredLogin && context?.resolvePreferredLogin) {\n const apiKey = await context.resolvePreferredLogin({\n provider,\n apiKey: options.apiKey,\n envValue: typeof envApiKey === \"string\" ? envApiKey : undefined\n });\n await store.set(apiKey);\n return;\n }\n await apiKeyAuthStrategy.login(\n provider,\n { apiKey: resolvedApiKey },\n { secretStore: store, promptForSecret: context?.promptForSecret }\n );\n }\n\n async resolveCredential(\n id: string,\n options: ApiKeyLoginOptions = {},\n context?: Pick<LoginContext, \"envVars\">\n ): Promise<string> {\n const provider = this.requireProvider(id);\n if (provider.auth.kind !== \"api-key\") {\n throw new Error(`Provider \"${id}\" does not use api-key auth.`);\n }\n\n if (options.apiKey !== undefined) {\n return normalizeRequiredCredential(provider.id, options.apiKey);\n }\n\n const envVars = context?.envVars ?? this.envVars;\n const envApiKey = envVars[provider.auth.envVar];\n if (typeof envApiKey === \"string\" && envApiKey.trim().length > 0) {\n return envApiKey.trim();\n }\n\n const store = this.requireStore(id);\n return apiKeyAuthStrategy.resolveCredential(provider, { secretStore: store });\n }\n\n async logout(id: string): Promise<void> {\n this.requireProvider(id);\n const store = this.requireStore(id);\n await store.delete();\n }\n\n private requireProvider(id: string): AuthProvider {\n const provider = this.byId.get(id);\n if (!provider) {\n throw new Error(`Unknown provider: \"${id}\".`);\n }\n return provider;\n }\n\n private requireStore(id: string): SecretStore {\n if (!this.storeFactory) {\n throw new Error(`No store factory configured for ProviderRegistry.`);\n }\n return this.storeFactory(id);\n }\n}\n\nfunction normalizeRequiredCredential(providerId: string, value: string): string {\n const trimmed = value.trim();\n if (trimmed.length === 0) {\n throw new Error(`No API key available for provider \"${providerId}\".`);\n }\n return trimmed;\n}\n", "import type { AuthProvider } from \"../types.js\";\n\nexport const POE_PROVIDER_ID = \"poe\" as const;\n\nexport const poeProvider: AuthProvider = {\n id: POE_PROVIDER_ID,\n label: \"Poe\",\n summary: \"Route AI coding agents through Poe's API.\",\n baseUrl: \"https://api.poe.com\",\n auth: {\n kind: \"api-key\",\n envVar: \"POE_API_KEY\",\n storageKey: \"provider:poe\",\n prompt: { title: \"Poe API key\" },\n preferredLogin: \"oauth\"\n },\n apiShapes: [\n {\n id: \"openai-chat-completions\",\n defaultBaseUrl: \"https://api.poe.com/v1\"\n },\n {\n id: \"openai-responses\",\n defaultBaseUrl: \"https://api.poe.com/v1\"\n },\n {\n id: \"anthropic-messages\",\n defaultBaseUrl: \"https://api.poe.com/anthropic\"\n }\n ]\n};\n", "import type { AuthProvider } from \"../types.js\";\n\nexport const anthropicProvider: AuthProvider = {\n id: \"anthropic\",\n label: \"Anthropic\",\n summary: \"Route AI coding agents through Anthropic's API.\",\n baseUrl: \"https://api.anthropic.com\",\n auth: {\n kind: \"api-key\",\n envVar: \"ANTHROPIC_API_KEY\",\n storageKey: \"provider:anthropic\",\n prompt: { title: \"Anthropic API key\" }\n },\n apiShapes: [\n {\n id: \"anthropic-messages\",\n defaultBaseUrl: \"https://api.anthropic.com\"\n }\n ]\n};\n", "import type { AuthProvider } from \"../types.js\";\n\nexport const cloudflareProvider: AuthProvider = {\n id: \"cloudflare\",\n label: \"Cloudflare AI Gateway\",\n summary: \"Route through the Poe Cloudflare gateway with BYOK keys.\",\n baseUrl: \"https://poe-ai-gateway.poe-dev.workers.dev\",\n auth: {\n kind: \"api-key\",\n envVar: \"CLOUDFLARE_API_KEY\",\n storageKey: \"provider:cloudflare\",\n prompt: { title: \"Cloudflare API key\" }\n },\n apiShapes: [\n {\n id: \"openai-chat-completions\",\n defaultBaseUrl: \"https://poe-ai-gateway.poe-dev.workers.dev/openai/v1\"\n },\n {\n id: \"openai-responses\",\n defaultBaseUrl: \"https://poe-ai-gateway.poe-dev.workers.dev/openai/v1\"\n },\n {\n id: \"anthropic-messages\",\n defaultBaseUrl: \"https://poe-ai-gateway.poe-dev.workers.dev/anthropic\"\n },\n {\n id: \"google-generations\",\n defaultBaseUrl: \"https://poe-ai-gateway.poe-dev.workers.dev/google-ai-studio\"\n }\n ]\n};\n", "import os from \"node:os\";\nimport { createJobRegistry, type JobRegistry } from \"./jobs.js\";\nimport { createTemplateRegistry, type TemplateRegistry } from \"./templates.js\";\nimport type { StateFileSystem } from \"./fs.js\";\n\nexport interface StateManager {\n templates: TemplateRegistry;\n jobs: JobRegistry;\n}\n\nexport async function loadStateManager(homeDir: string = os.homedir()): Promise<StateManager> {\n return {\n templates: createTemplateRegistry(homeDir),\n jobs: createJobRegistry(homeDir)\n };\n}\n\nexport function createStateManager(homeDir: string, fs?: StateFileSystem): StateManager {\n return {\n templates: createTemplateRegistry(homeDir, fs),\n jobs: createJobRegistry(homeDir, fs)\n };\n}\n\nexport {\n createJobRegistry,\n type JobEntry,\n type JobListFilter,\n type JobRegistry,\n type JobStatus\n} from \"./jobs.js\";\nexport {\n createTemplateRegistry,\n type TemplateBackend,\n type TemplateEntry,\n type TemplateRegistry\n} from \"./templates.js\";\nexport type { StateFileSystem } from \"./fs.js\";\n", "import path from \"node:path\";\nimport { acquireFileLock, type FileLockFs } from \"@poe-code/file-lock\";\nimport { defaultStateFs, isNotFoundError, type StateFileSystem } from \"./fs.js\";\n\nexport type JobStatus = \"pending\" | \"running\" | \"exited\" | \"killed\" | \"lost\";\n\nexport interface JobEntry {\n id: string;\n env_id: string;\n env_kind: string;\n tool: string;\n argv: string[];\n cwd: string;\n started_at: string;\n status: JobStatus;\n exit_code?: number;\n exited_at?: string;\n log_file?: string;\n}\n\nexport interface JobListFilter {\n env_id?: string;\n env_kind?: string;\n tool?: string;\n status?: JobStatus;\n}\n\nexport interface JobRegistry {\n get(id: string): Promise<JobEntry | null>;\n put(entry: JobEntry): Promise<void>;\n update(id: string, patch: Partial<JobEntry>): Promise<JobEntry | null>;\n list(filter?: JobListFilter): Promise<JobEntry[]>;\n remove(id: string): Promise<void>;\n}\n\nexport function createJobRegistry(\n homeDir: string,\n fs: StateFileSystem = defaultStateFs\n): JobRegistry {\n const jobsDir = path.join(homeDir, \".poe-code\", \"state\", \"jobs\");\n\n function jobPath(id: string): string {\n assertSafeJobId(id);\n return path.join(jobsDir, `${id}.json`);\n }\n\n async function get(id: string): Promise<JobEntry | null> {\n try {\n return parseJobEntry(await fs.readFile(jobPath(id), \"utf8\"));\n } catch (error) {\n if (isNotFoundError(error)) {\n return null;\n }\n\n throw error;\n }\n }\n\n async function put(entry: JobEntry): Promise<void> {\n assertJobEntry(entry);\n const filePath = jobPath(entry.id);\n await fs.mkdir(jobsDir, { recursive: true });\n const release = await acquireFileLock(filePath, { fs: fs as unknown as FileLockFs });\n try {\n await writeJobAtomically(filePath, entry);\n } finally {\n await release();\n }\n }\n\n async function update(id: string, patch: Partial<JobEntry>): Promise<JobEntry | null> {\n const filePath = jobPath(id);\n await fs.mkdir(jobsDir, { recursive: true });\n const release = await acquireFileLock(filePath, { fs: fs as unknown as FileLockFs });\n try {\n const current = await get(id);\n if (current === null) {\n return null;\n }\n\n const updated = {\n ...current,\n ...patch,\n id: current.id\n };\n assertJobEntry(updated);\n await writeJobAtomically(filePath, updated);\n return updated;\n } finally {\n await release();\n }\n }\n\n async function list(filter: JobListFilter = {}): Promise<JobEntry[]> {\n let entries: string[];\n\n try {\n entries = await fs.readdir(jobsDir);\n } catch (error) {\n if (isNotFoundError(error)) {\n return [];\n }\n\n throw error;\n }\n\n const jobs: JobEntry[] = [];\n for (const entry of entries.sort()) {\n if (!entry.endsWith(\".json\")) {\n continue;\n }\n\n const filePath = path.join(jobsDir, entry);\n const stat = await fs.stat(filePath);\n if (!stat.isFile()) {\n continue;\n }\n\n const job = parseJobEntry(await fs.readFile(filePath, \"utf8\"));\n if (matchesFilter(job, filter)) {\n jobs.push(job);\n }\n }\n return jobs;\n }\n\n async function remove(id: string): Promise<void> {\n const filePath = jobPath(id);\n try {\n await fs.stat(jobsDir);\n } catch (error) {\n if (isNotFoundError(error)) {\n return;\n }\n\n throw error;\n }\n\n const release = await acquireFileLock(filePath, { fs: fs as unknown as FileLockFs });\n try {\n await fs.unlink(filePath);\n } catch (error) {\n if (!isNotFoundError(error)) {\n throw error;\n }\n } finally {\n await release();\n }\n }\n\n async function writeJobAtomically(filePath: string, entry: JobEntry): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n const tempPath = `${filePath}.${process.pid}.${Date.now()}.${Math.random()\n .toString(36)\n .slice(2)}.tmp`;\n\n try {\n await fs.writeFile(tempPath, `${JSON.stringify(entry, null, 2)}\\n`, {\n encoding: \"utf8\"\n });\n await fs.rename(tempPath, filePath);\n } catch (error) {\n await removeTempFile(tempPath);\n throw error;\n }\n }\n\n async function removeTempFile(tempPath: string): Promise<void> {\n try {\n await fs.unlink(tempPath);\n } catch (error) {\n if (!isNotFoundError(error)) {\n throw error;\n }\n }\n }\n\n return {\n get,\n put,\n update,\n list,\n remove\n };\n}\n\nfunction assertSafeJobId(id: string): void {\n if (\n id.length === 0 ||\n id === \".\" ||\n id === \"..\" ||\n path.isAbsolute(id) ||\n id.includes(\"/\") ||\n id.includes(\"\\\\\") ||\n id.includes(\"\\0\")\n ) {\n throw new Error(\"Invalid job id.\");\n }\n}\n\nfunction assertJobEntry(entry: JobEntry): void {\n if (!isJobEntry(entry)) {\n throw new Error(\"Invalid job entry.\");\n }\n}\n\nfunction matchesFilter(job: JobEntry, filter: JobListFilter): boolean {\n return (\n (filter.env_id === undefined || job.env_id === filter.env_id) &&\n (filter.env_kind === undefined || job.env_kind === filter.env_kind) &&\n (filter.tool === undefined || job.tool === filter.tool) &&\n (filter.status === undefined || job.status === filter.status)\n );\n}\n\nfunction parseJobEntry(content: string): JobEntry {\n const parsed = JSON.parse(content) as unknown;\n if (!isJobEntry(parsed)) {\n throw new Error(\"Invalid job state file.\");\n }\n return parsed;\n}\n\nfunction isJobEntry(value: unknown): value is JobEntry {\n return (\n isRecord(value) &&\n typeof value.id === \"string\" &&\n typeof value.env_id === \"string\" &&\n typeof value.env_kind === \"string\" &&\n typeof value.tool === \"string\" &&\n Array.isArray(value.argv) &&\n value.argv.every((arg) => typeof arg === \"string\") &&\n typeof value.cwd === \"string\" &&\n typeof value.started_at === \"string\" &&\n isJobStatus(value.status) &&\n (value.exit_code === undefined || typeof value.exit_code === \"number\") &&\n (value.exited_at === undefined || typeof value.exited_at === \"string\") &&\n (value.log_file === undefined || typeof value.log_file === \"string\")\n );\n}\n\nfunction isJobStatus(value: unknown): value is JobStatus {\n return (\n value === \"pending\" ||\n value === \"running\" ||\n value === \"exited\" ||\n value === \"killed\" ||\n value === \"lost\"\n );\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value && typeof value === \"object\" && !Array.isArray(value));\n}\n\nexport type { StateFileSystem } from \"./fs.js\";\n", "import * as nodeFs from \"node:fs/promises\";\n\nexport interface StateFileSystem {\n mkdir(path: string, options: { recursive: true }): Promise<unknown>;\n readFile(path: string, encoding: BufferEncoding): Promise<string>;\n writeFile(\n path: string,\n data: string,\n options?: BufferEncoding | { encoding?: BufferEncoding }\n ): Promise<void>;\n rename(oldPath: string, newPath: string): Promise<void>;\n readdir(path: string): Promise<string[]>;\n stat(path: string): Promise<{\n isFile(): boolean;\n mtimeMs: number;\n }>;\n unlink(path: string): Promise<void>;\n open(path: string, flags: string): Promise<{\n close(): Promise<void>;\n writeFile(\n data: string,\n options?: BufferEncoding | { encoding?: BufferEncoding }\n ): Promise<void>;\n }>;\n}\n\nexport const defaultStateFs = nodeFs as unknown as StateFileSystem;\n\nexport function isNotFoundError(error: unknown): boolean {\n return error instanceof Error && \"code\" in error && error.code === \"ENOENT\";\n}\n", "import path from \"node:path\";\nimport { acquireFileLock, type FileLockFs } from \"@poe-code/file-lock\";\nimport { defaultStateFs, isNotFoundError, type StateFileSystem } from \"./fs.js\";\n\nexport type TemplateBackend = \"docker\" | \"e2b\";\n\nexport interface TemplateEntry {\n hash: string;\n template_id?: string;\n image?: string;\n runtime_type: string;\n dockerfile_path: string;\n built_at: string;\n}\n\ntype TemplateState = Record<TemplateBackend, Record<string, TemplateEntry>>;\n\nexport interface TemplateRegistry {\n get(backend: TemplateBackend, hash: string): Promise<TemplateEntry | null>;\n put(backend: TemplateBackend, entry: TemplateEntry): Promise<void>;\n remove(backend: TemplateBackend, hash: string): Promise<void>;\n list(backend?: TemplateBackend): Promise<TemplateEntry[]>;\n}\n\nexport function createTemplateRegistry(\n homeDir: string,\n fs: StateFileSystem = defaultStateFs\n): TemplateRegistry {\n const filePath = path.join(homeDir, \".poe-code\", \"state\", \"templates.json\");\n\n async function readState(): Promise<TemplateState> {\n try {\n const raw = await fs.readFile(filePath, \"utf8\");\n return normalizeTemplateState(JSON.parse(raw));\n } catch (error) {\n if (isNotFoundError(error)) {\n return createEmptyState();\n }\n\n throw error;\n }\n }\n\n async function writeState(state: TemplateState): Promise<void> {\n await fs.writeFile(filePath, `${JSON.stringify(state, null, 2)}\\n`, {\n encoding: \"utf8\"\n });\n }\n\n async function updateState(mutator: (state: TemplateState) => void): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n const release = await acquireFileLock(filePath, { fs: fs as unknown as FileLockFs });\n try {\n const state = await readState();\n mutator(state);\n await writeState(state);\n } finally {\n await release();\n }\n }\n\n async function get(backend: TemplateBackend, hash: string): Promise<TemplateEntry | null> {\n const state = await readState();\n return state[backend][hash] ?? null;\n }\n\n async function put(backend: TemplateBackend, entry: TemplateEntry): Promise<void> {\n await updateState((state) => {\n state[backend][entry.hash] = entry;\n });\n }\n\n async function remove(backend: TemplateBackend, hash: string): Promise<void> {\n await updateState((state) => {\n delete state[backend][hash];\n });\n }\n\n async function list(backend?: TemplateBackend): Promise<TemplateEntry[]> {\n const state = await readState();\n const entries =\n backend === undefined\n ? [...Object.values(state.docker), ...Object.values(state.e2b)]\n : Object.values(state[backend]);\n\n return entries.sort((left, right) => left.hash.localeCompare(right.hash));\n }\n\n return {\n get,\n put,\n remove,\n list\n };\n}\n\nfunction createEmptyState(): TemplateState {\n return {\n docker: {},\n e2b: {}\n };\n}\n\nfunction normalizeTemplateState(value: unknown): TemplateState {\n if (!isRecord(value)) {\n return createEmptyState();\n }\n\n return {\n docker: normalizeTemplateEntries(value.docker),\n e2b: normalizeTemplateEntries(value.e2b)\n };\n}\n\nfunction normalizeTemplateEntries(value: unknown): Record<string, TemplateEntry> {\n if (!isRecord(value)) {\n return {};\n }\n\n const entries: Record<string, TemplateEntry> = {};\n for (const [hash, entry] of Object.entries(value)) {\n if (isTemplateEntry(entry) && entry.hash === hash) {\n entries[hash] = entry;\n }\n }\n return entries;\n}\n\nfunction isTemplateEntry(value: unknown): value is TemplateEntry {\n return (\n isRecord(value) &&\n typeof value.hash === \"string\" &&\n typeof value.runtime_type === \"string\" &&\n typeof value.dockerfile_path === \"string\" &&\n typeof value.built_at === \"string\" &&\n (value.template_id === undefined || typeof value.template_id === \"string\") &&\n (value.image === undefined || typeof value.image === \"string\")\n );\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value && typeof value === \"object\" && !Array.isArray(value));\n}\n\nexport type { StateFileSystem } from \"./fs.js\";\n", "import type { RunnerScope, RuntimeConfig } from \"@poe-code/poe-code-config\";\nimport type { RunHandle, Runner, RunSpec } from \"@poe-code/process-runner\";\nimport type { StateManager } from \"@poe-code/poe-code-config\";\n\nexport type { RuntimeConfig } from \"@poe-code/poe-code-config\";\nexport type { RunHandle, RunSpec } from \"@poe-code/process-runner\";\n\nexport type ExecutionEnvType = \"host\" | \"docker\" | \"e2b\";\nexport type JobStatus = \"running\" | \"exited\" | \"killed\" | \"lost\";\n\nexport interface ExecutionEnvFactory {\n readonly type: ExecutionEnvType;\n readonly supportsDetach?: boolean;\n open(spec: OpenSpec): Promise<OpenedEnv>;\n attach(envId: string, context?: AttachedJobContext): Promise<OpenedEnv>;\n}\n\nexport interface OpenSpec {\n cwd: string;\n runtimeCwd?: string;\n runtime: RuntimeConfig;\n runner?: RunnerScope;\n state?: StateManager;\n hostRunner?: Runner;\n env: Record<string, string>;\n uploadIgnoreFiles: string[];\n jobLabel: { tool: string; argv: string[] };\n execution?: {\n wrapForLogTee?: boolean;\n stdin?: RunSpec[\"stdin\"];\n stdout?: RunSpec[\"stdout\"];\n stderr?: RunSpec[\"stderr\"];\n env?: RunSpec[\"env\"];\n tty?: boolean;\n input?: string | Buffer;\n captureOutput?: boolean;\n activityTimeoutMs?: number;\n onStdout?(chunk: string): void;\n onStderr?(chunk: string): void;\n };\n shellSpec?: RunSpec;\n}\n\nexport interface UploadResult {\n files: number;\n bytes: number;\n skipped: { path: string; bytes: number; reason: \"max_size\" }[];\n}\n\nexport interface DownloadResult {\n files: number;\n bytes: number;\n conflicts: { path: string; reason: \"local_modified\" }[];\n}\n\nexport interface LogChunk {\n byteOffset: number;\n data: string;\n}\n\nexport interface AttachedJobContext {\n jobId: string;\n tool: string;\n argv: string[];\n cwd: string;\n}\n\nexport interface OpenedEnv {\n readonly id: string;\n readonly job: JobHandle | null;\n uploadWorkspace(): Promise<UploadResult>;\n downloadWorkspace(opts: { conflictPolicy: \"refuse\" | \"overwrite\" }): Promise<DownloadResult>;\n exec(spec: RunSpec): RunHandle;\n detach(): Promise<JobHandle>;\n shell(): RunHandle;\n close(): Promise<void>;\n}\n\nexport interface JobHandle {\n readonly id: string;\n readonly envId: string;\n readonly tool: string;\n readonly argv: string[];\n status(): Promise<JobStatus>;\n stream(opts?: { sinceByte?: number; since?: Date }): AsyncIterable<LogChunk>;\n wait(): Promise<{ exitCode: number }>;\n kill(signal?: NodeJS.Signals): Promise<void>;\n}\n\nconst executionEnvFactories = new Map<ExecutionEnvType, ExecutionEnvFactory>();\n\nexport function registerExecutionEnvFactory(factory: ExecutionEnvFactory): void {\n executionEnvFactories.set(factory.type, factory);\n}\n\nexport function selectExecutionEnv(runtime: RuntimeConfig): ExecutionEnvFactory {\n return selectExecutionEnvFactory(runtime.type);\n}\n\nexport function selectExecutionEnvFactory(type: ExecutionEnvType): ExecutionEnvFactory {\n const factory = executionEnvFactories.get(type);\n if (factory === undefined) {\n throw new Error(\n `No execution environment factory registered for runtime type \"${type}\".`\n );\n }\n return factory;\n}\n", "import { createHash } from \"node:crypto\";\nimport { promises as nodeFs } from \"node:fs\";\nimport path from \"node:path\";\nimport type { RunnerScope } from \"@poe-code/poe-code-config\";\nimport type { DownloadResult, UploadResult } from \"./execution-env.js\";\n\nexport type { DownloadResult, UploadResult } from \"./execution-env.js\";\n\nexport interface WorkspaceTransferDirent {\n name: string;\n isFile(): boolean;\n isDirectory(): boolean;\n}\n\nexport interface WorkspaceTransferStats {\n isFile(): boolean;\n isDirectory(): boolean;\n size: number;\n}\n\nexport interface WorkspaceTransferFileSystem {\n mkdir(path: string, options?: { recursive?: boolean }): Promise<void>;\n readdir(path: string, options: { withFileTypes: true }): Promise<WorkspaceTransferDirent[]>;\n readFile(path: string): Promise<Buffer>;\n readFile(path: string, encoding: BufferEncoding): Promise<string>;\n writeFile(path: string, data: string | Buffer): Promise<void>;\n stat(path: string): Promise<WorkspaceTransferStats>;\n rm?(path: string, options?: { recursive?: boolean; force?: boolean }): Promise<void>;\n unlink?(path: string): Promise<void>;\n rmdir?(path: string): Promise<void>;\n}\n\nexport interface WorkspaceTransferEnv {\n cwd: string;\n uploadDir: string;\n workspaceDir?: string;\n fs?: WorkspaceTransferFileSystem;\n remoteFs?: WorkspaceTransferFileSystem;\n}\n\nexport interface WorkspaceTransferOptions {\n runner?: RunnerScope;\n uploadMaxFileMb?: number;\n workspaceExclude?: string[];\n warn?: (message: string) => void;\n}\n\nexport interface WorkspaceDownloadOptions {\n conflictPolicy: \"refuse\" | \"overwrite\";\n}\n\ninterface UploadedFileState {\n hash: string;\n uploaded: boolean;\n}\n\ninterface FileEntry {\n path: string;\n absolutePath: string;\n bytes: number;\n content: Buffer;\n}\n\ninterface IgnoreRule {\n pattern: string;\n negate: boolean;\n directoryOnly: boolean;\n anchored: boolean;\n}\n\nconst uploadState = new WeakMap<object, Map<string, UploadedFileState>>();\n\nexport async function uploadWorkspace(\n env: WorkspaceTransferEnv,\n opts: WorkspaceTransferOptions\n): Promise<UploadResult> {\n const localFs = env.fs ?? (nodeFs as unknown as WorkspaceTransferFileSystem);\n const remoteFs = env.remoteFs ?? localFs;\n const workspaceDir = env.workspaceDir ?? \"/workspace\";\n const maxBytes = (opts.uploadMaxFileMb ?? opts.runner?.upload_max_file_mb ?? 100) * 1024 * 1024;\n const warn = opts.warn ?? console.warn;\n const allFiles = await listFiles(localFs, env.cwd);\n const state = new Map<string, UploadedFileState>();\n const gitignore = await readIgnoreFile(localFs, env.cwd, \".gitignore\", true);\n const poeCodeIgnore = await readIgnoreFile(localFs, env.cwd, \".poe-code-ignore\", false);\n const workspaceExclude = parseIgnoreLines(\n [...(opts.runner?.workspace?.exclude ?? []), ...(opts.workspaceExclude ?? [])],\n false\n );\n const entries: FileEntry[] = [];\n const skipped: UploadResult[\"skipped\"] = [];\n\n for (const file of allFiles) {\n const content = await localFs.readFile(file.absolutePath);\n state.set(file.path, {\n hash: hashBuffer(content),\n uploaded: false\n });\n\n if (\n isIgnoredByGit(file.path, gitignore) ||\n isIgnoredAdditively(file.path, poeCodeIgnore) ||\n isIgnoredAdditively(file.path, workspaceExclude)\n ) {\n continue;\n }\n\n if (file.bytes > maxBytes) {\n skipped.push({ path: file.path, bytes: file.bytes, reason: \"max_size\" });\n warn(`Skipping ${file.path}: ${file.bytes} bytes exceeds upload_max_file_mb.`);\n continue;\n }\n\n entries.push({ ...file, content });\n state.set(file.path, {\n hash: hashBuffer(content),\n uploaded: true\n });\n }\n\n await removeTree(remoteFs, workspaceDir);\n await remoteFs.mkdir(workspaceDir, { recursive: true });\n await remoteFs.mkdir(env.uploadDir, { recursive: true });\n await remoteFs.writeFile(path.join(env.uploadDir, \"workspace.tar\"), createTar(entries));\n\n for (const entry of entries) {\n const remotePath = path.join(workspaceDir, entry.path);\n await remoteFs.mkdir(path.dirname(remotePath), { recursive: true });\n await remoteFs.writeFile(remotePath, entry.content);\n }\n\n uploadState.set(env, state);\n\n return {\n files: entries.length,\n bytes: entries.reduce((sum, entry) => sum + entry.bytes, 0),\n skipped\n };\n}\n\nexport async function downloadWorkspace(\n env: WorkspaceTransferEnv,\n opts: WorkspaceDownloadOptions\n): Promise<DownloadResult> {\n const localFs = env.fs ?? (nodeFs as unknown as WorkspaceTransferFileSystem);\n const remoteFs = env.remoteFs ?? localFs;\n const workspaceDir = env.workspaceDir ?? \"/workspace\";\n const state = uploadState.get(env) ?? new Map<string, UploadedFileState>();\n const remoteFiles = await listFilesIfExists(remoteFs, workspaceDir);\n const remotePaths = new Set(remoteFiles.map((file) => file.path));\n const conflicts: DownloadResult[\"conflicts\"] = [];\n let files = 0;\n let bytes = 0;\n\n for (const remoteFile of remoteFiles) {\n const remoteContent = await remoteFs.readFile(remoteFile.absolutePath);\n const localPath = path.join(env.cwd, remoteFile.path);\n const conflict = await isDownloadConflict(\n localFs,\n localPath,\n remoteFile.path,\n remoteContent,\n state\n );\n\n if (conflict && opts.conflictPolicy === \"refuse\") {\n conflicts.push({ path: remoteFile.path, reason: \"local_modified\" });\n continue;\n }\n\n await localFs.mkdir(path.dirname(localPath), { recursive: true });\n await localFs.writeFile(localPath, remoteContent);\n state.set(remoteFile.path, {\n hash: hashBuffer(remoteContent),\n uploaded: true\n });\n files += 1;\n bytes += remoteContent.length;\n }\n\n for (const [relativePath, fileState] of state) {\n if (!fileState.uploaded || remotePaths.has(relativePath)) {\n continue;\n }\n\n const localPath = path.join(env.cwd, relativePath);\n const localContent = await readFileIfExists(localFs, localPath);\n if (localContent === null) {\n continue;\n }\n\n if (opts.conflictPolicy === \"refuse\" && hashBuffer(localContent) !== fileState.hash) {\n conflicts.push({ path: relativePath, reason: \"local_modified\" });\n continue;\n }\n\n await removeFile(localFs, localPath);\n }\n\n return { files, bytes, conflicts };\n}\n\nasync function listFilesIfExists(\n fs: WorkspaceTransferFileSystem,\n root: string\n): Promise<Omit<FileEntry, \"content\">[]> {\n try {\n return await listFiles(fs, root);\n } catch (error) {\n if (isNotFoundError(error)) {\n return [];\n }\n throw error;\n }\n}\n\nasync function listFiles(\n fs: WorkspaceTransferFileSystem,\n root: string\n): Promise<Omit<FileEntry, \"content\">[]> {\n const result: Omit<FileEntry, \"content\">[] = [];\n\n async function visit(dir: string): Promise<void> {\n const dirents = await fs.readdir(dir, { withFileTypes: true });\n for (const dirent of dirents.sort((left, right) => left.name.localeCompare(right.name))) {\n const absolutePath = path.join(dir, dirent.name);\n if (dirent.isDirectory()) {\n await visit(absolutePath);\n continue;\n }\n if (!dirent.isFile()) {\n continue;\n }\n\n const stats = await fs.stat(absolutePath);\n result.push({\n path: toRelativePath(root, absolutePath),\n absolutePath,\n bytes: stats.size\n });\n }\n }\n\n await visit(root);\n return result;\n}\n\nasync function readIgnoreFile(\n fs: WorkspaceTransferFileSystem,\n cwd: string,\n fileName: string,\n allowNegation: boolean\n): Promise<IgnoreRule[]> {\n const content = await readFileIfExists(fs, path.join(cwd, fileName));\n if (content === null) {\n return [];\n }\n return parseIgnoreLines(content.toString(\"utf8\").split(\"\\n\"), allowNegation);\n}\n\nfunction parseIgnoreLines(lines: string[], allowNegation: boolean): IgnoreRule[] {\n const rules: IgnoreRule[] = [];\n for (const rawLine of lines) {\n const line = rawLine.trim();\n if (line.length === 0 || line.startsWith(\"#\")) {\n continue;\n }\n\n const negate = allowNegation && line.startsWith(\"!\");\n const patternWithMarker = negate ? line.slice(1) : line;\n if (patternWithMarker.length === 0) {\n continue;\n }\n\n const anchored = patternWithMarker.startsWith(\"/\");\n const directoryOnly = patternWithMarker.endsWith(\"/\");\n const pattern = stripSlashes(\n directoryOnly ? patternWithMarker.slice(0, -1) : patternWithMarker\n );\n if (pattern.length > 0) {\n rules.push({ pattern, negate, directoryOnly, anchored });\n }\n }\n return rules;\n}\n\nfunction isIgnoredByGit(relativePath: string, rules: IgnoreRule[]): boolean {\n let ignored = false;\n for (const rule of rules) {\n if (matchesRule(relativePath, rule)) {\n ignored = !rule.negate;\n }\n }\n return ignored;\n}\n\nfunction isIgnoredAdditively(relativePath: string, rules: IgnoreRule[]): boolean {\n return rules.some((rule) => matchesRule(relativePath, rule));\n}\n\nfunction matchesRule(relativePath: string, rule: IgnoreRule): boolean {\n const normalizedPath = normalizeRelativePath(relativePath);\n const normalizedPattern = normalizeRelativePath(rule.pattern);\n if (rule.directoryOnly) {\n return pathMatchesDirectory(normalizedPath, normalizedPattern, rule.anchored);\n }\n\n if (rule.anchored || normalizedPattern.includes(\"/\")) {\n return matchPathSegments(normalizedPath.split(\"/\"), normalizedPattern.split(\"/\"));\n }\n\n return normalizedPath.split(\"/\").some((segment) => matchSegment(segment, normalizedPattern));\n}\n\nfunction pathMatchesDirectory(relativePath: string, pattern: string, anchored: boolean): boolean {\n if (anchored || pattern.includes(\"/\")) {\n return relativePath === pattern || relativePath.startsWith(`${pattern}/`);\n }\n\n const segments = relativePath.split(\"/\");\n return segments.some((segment, index) => {\n return matchSegment(segment, pattern) && index < segments.length - 1;\n });\n}\n\nfunction matchPathSegments(pathSegments: string[], patternSegments: string[]): boolean {\n if (pathSegments.length !== patternSegments.length) {\n return false;\n }\n\n return patternSegments.every((patternSegment, index) =>\n matchSegment(pathSegments[index] ?? \"\", patternSegment)\n );\n}\n\nfunction matchSegment(value: string, pattern: string): boolean {\n const patternParts = pattern.split(\"*\");\n if (patternParts.length === 1) {\n return value === pattern;\n }\n\n let offset = 0;\n for (const [index, part] of patternParts.entries()) {\n if (part.length === 0) {\n continue;\n }\n\n const foundAt = value.indexOf(part, offset);\n if (foundAt === -1) {\n return false;\n }\n\n if (index === 0 && foundAt !== 0) {\n return false;\n }\n\n offset = foundAt + part.length;\n }\n\n const lastPart = patternParts.at(-1) ?? \"\";\n return lastPart.length === 0 || value.endsWith(lastPart);\n}\n\nasync function isDownloadConflict(\n fs: WorkspaceTransferFileSystem,\n localPath: string,\n relativePath: string,\n remoteContent: Buffer,\n state: Map<string, UploadedFileState>\n): Promise<boolean> {\n const localContent = await readFileIfExists(fs, localPath);\n if (localContent === null) {\n return false;\n }\n\n const localHash = hashBuffer(localContent);\n const remoteHash = hashBuffer(remoteContent);\n const uploadedHash = state.get(relativePath)?.hash;\n const localChanged = uploadedHash === undefined || localHash !== uploadedHash;\n return localChanged && localHash !== remoteHash;\n}\n\nasync function readFileIfExists(\n fs: WorkspaceTransferFileSystem,\n filePath: string\n): Promise<Buffer | null> {\n try {\n return await fs.readFile(filePath);\n } catch (error) {\n if (isNotFoundError(error)) {\n return null;\n }\n throw error;\n }\n}\n\nasync function removeTree(fs: WorkspaceTransferFileSystem, targetPath: string): Promise<void> {\n if (fs.rm) {\n await fs.rm(targetPath, { recursive: true, force: true });\n return;\n }\n\n const stats = await statIfExists(fs, targetPath);\n if (stats === null) {\n return;\n }\n if (stats.isFile()) {\n await removeFile(fs, targetPath);\n return;\n }\n\n const dirents = await fs.readdir(targetPath, { withFileTypes: true });\n for (const dirent of dirents) {\n await removeTree(fs, path.join(targetPath, dirent.name));\n }\n if (fs.rmdir) {\n await fs.rmdir(targetPath);\n }\n}\n\nasync function removeFile(fs: WorkspaceTransferFileSystem, filePath: string): Promise<void> {\n if (fs.rm) {\n await fs.rm(filePath, { force: true });\n return;\n }\n if (fs.unlink) {\n await fs.unlink(filePath);\n }\n}\n\nasync function statIfExists(\n fs: WorkspaceTransferFileSystem,\n targetPath: string\n): Promise<WorkspaceTransferStats | null> {\n try {\n return await fs.stat(targetPath);\n } catch (error) {\n if (isNotFoundError(error)) {\n return null;\n }\n throw error;\n }\n}\n\nfunction createTar(entries: FileEntry[]): Buffer {\n const chunks: Buffer[] = [];\n for (const entry of entries) {\n chunks.push(createTarHeader(entry.path, entry.bytes));\n chunks.push(entry.content);\n chunks.push(Buffer.alloc(paddingFor(entry.bytes)));\n }\n chunks.push(Buffer.alloc(1024));\n return Buffer.concat(chunks);\n}\n\nfunction createTarHeader(name: string, size: number): Buffer {\n const header = Buffer.alloc(512);\n writeString(header, name, 0, 100);\n writeOctal(header, 0o644, 100, 8);\n writeOctal(header, 0, 108, 8);\n writeOctal(header, 0, 116, 8);\n writeOctal(header, size, 124, 12);\n writeOctal(header, 0, 136, 12);\n header.fill(32, 148, 156);\n header.write(\"0\", 156, 1, \"ascii\");\n header.write(\"ustar\", 257, 5, \"ascii\");\n header.write(\"00\", 263, 2, \"ascii\");\n writeOctal(header, checksum(header), 148, 8);\n return header;\n}\n\nfunction writeString(buffer: Buffer, value: string, offset: number, length: number): void {\n const text = Buffer.from(value);\n text.copy(buffer, offset, 0, Math.min(text.length, length));\n}\n\nfunction writeOctal(buffer: Buffer, value: number, offset: number, length: number): void {\n const text = value.toString(8).padStart(length - 1, \"0\");\n buffer.write(text.slice(0, length - 1), offset, length - 1, \"ascii\");\n buffer[offset + length - 1] = 0;\n}\n\nfunction checksum(buffer: Buffer): number {\n return buffer.reduce((sum, value) => sum + value, 0);\n}\n\nfunction paddingFor(size: number): number {\n const remainder = size % 512;\n return remainder === 0 ? 0 : 512 - remainder;\n}\n\nfunction hashBuffer(buffer: Buffer): string {\n return createHash(\"sha256\").update(buffer).digest(\"hex\");\n}\n\nfunction toRelativePath(root: string, absolutePath: string): string {\n return normalizeRelativePath(path.relative(root, absolutePath));\n}\n\nfunction normalizeRelativePath(value: string): string {\n return stripSlashes(value.split(path.sep).join(\"/\"));\n}\n\nfunction stripSlashes(value: string): string {\n let start = 0;\n let end = value.length;\n while (value[start] === \"/\") {\n start += 1;\n }\n while (value[end - 1] === \"/\") {\n end -= 1;\n }\n return value.slice(start, end);\n}\n\nfunction isNotFoundError(error: unknown): boolean {\n return typeof error === \"object\" && error !== null && \"code\" in error && error.code === \"ENOENT\";\n}\n", "import path from \"node:path\";\nimport type { E2bRuntime } from \"@poe-code/poe-code-config\";\nimport type { ExecutionEnvFactory, OpenSpec, OpenedEnv } from \"@poe-code/agent-harness-tools\";\nimport { createSandbox, connectSandbox } from \"./sdk.js\";\nimport { buildE2bRuntimeTemplate } from \"./template-build.js\";\nimport { createOpenedE2bEnv } from \"./opened-env.js\";\nimport { resolveE2bApiKey } from \"./auth-scope.js\";\n\nexport const e2bExecutionEnvFactory: ExecutionEnvFactory = {\n type: \"e2b\",\n supportsDetach: true,\n async open(spec): Promise<OpenedEnv> {\n const runtime = parseE2bRuntime(spec.runtime);\n const runtimeCwd = spec.runtimeCwd ?? spec.cwd;\n const apiKey = await resolveE2bApiKey({ cwd: runtimeCwd });\n const templateId =\n runtime.template_id ??\n (\n await buildE2bRuntimeTemplate({\n runtime,\n dockerfilePath: path.resolve(\n runtimeCwd,\n runtime.dockerfile ?? path.join(\".poe-code\", \"Dockerfile\")\n ),\n buildContext: path.resolve(runtimeCwd, runtime.build_context ?? \".\"),\n state: spec.state,\n apiKey\n })\n ).templateId;\n const sandbox = await createSandbox({\n apiKey,\n templateId,\n env: spec.env,\n timeoutMinutes: runtime.timeout_minutes\n });\n\n return createOpenedE2bEnv({ sandbox, spec, runtime });\n },\n async attach(envId, context): Promise<OpenedEnv> {\n const cwd = context?.cwd ?? process.cwd();\n const apiKey = await resolveE2bApiKey({ cwd });\n const sandbox = await connectSandbox(envId, apiKey);\n return createOpenedE2bEnv({\n sandbox,\n spec: {\n cwd: context?.cwd ?? \"/workspace\",\n runtime: {\n type: \"e2b\",\n build_args: {},\n mounts: [],\n workspace_dir: \"/workspace\",\n preserve_after_exit_hours: 24\n },\n env: {},\n uploadIgnoreFiles: [],\n jobLabel: { tool: context?.tool ?? \"e2b\", argv: context?.argv ?? [] },\n ...(context?.jobId ? { detachedJobId: context.jobId } : {})\n } as OpenSpec & { detachedJobId?: string },\n runtime: {\n type: \"e2b\",\n build_args: {},\n mounts: [],\n workspace_dir: \"/workspace\",\n preserve_after_exit_hours: 24\n }\n });\n }\n};\n\nfunction parseE2bRuntime(runtime: unknown): E2bRuntime {\n if (!runtime || typeof runtime !== \"object\" || Array.isArray(runtime)) {\n throw new Error(\"e2b runtime must be an object\");\n }\n const record = runtime as Record<string, unknown>;\n if (record.type !== \"e2b\") {\n throw new Error('e2b runtime type must be \"e2b\"');\n }\n return record as unknown as E2bRuntime;\n}\n", "import { Template, Sandbox, TemplateBase } from \"e2b\";\nimport type { Readable } from \"node:stream\";\n\nexport interface E2bSandbox {\n readonly sandboxId: string;\n readonly commands: E2bCommands;\n readonly files: E2bFiles;\n readonly pty: E2bPty;\n setTimeout(timeoutMs: number): Promise<void>;\n kill(): Promise<void>;\n}\n\nexport interface E2bCommands {\n list(): Promise<E2bProcessInfo[]>;\n run(command: string, opts?: E2bCommandOptions): Promise<E2bCommandResult | E2bCommandHandle>;\n connect(pid: number, opts?: E2bCommandConnectOptions): Promise<E2bCommandHandle>;\n sendStdin(pid: number, data: string | Uint8Array): Promise<void>;\n closeStdin?(pid: number): Promise<void>;\n kill(pid: number): Promise<boolean>;\n}\n\nexport interface E2bPty {\n create(opts: E2bPtyOptions): Promise<E2bCommandHandle>;\n sendInput(pid: number, data: Uint8Array): Promise<void>;\n kill(pid: number): Promise<boolean>;\n}\n\nexport interface E2bFiles {\n read(path: string, opts: { format: \"bytes\" }): Promise<Uint8Array>;\n read(path: string): Promise<string>;\n write(path: string, data: string | ArrayBuffer | Blob | ReadableStream): Promise<unknown>;\n watchDir(\n path: string,\n onEvent: () => void | Promise<void>,\n opts?: { recursive?: boolean; onExit?: (error?: Error) => void | Promise<void> }\n ): Promise<{ stop(): Promise<void> }>;\n}\n\nexport interface E2bProcessInfo {\n pid: number;\n cmd: string;\n args: string[];\n}\n\nexport interface E2bCommandOptions {\n background?: boolean;\n cwd?: string;\n envs?: Record<string, string>;\n stdin?: boolean;\n timeoutMs?: number;\n onStdout?: (data: string) => void | Promise<void>;\n onStderr?: (data: string) => void | Promise<void>;\n}\n\nexport interface E2bPtyOptions {\n cols: number;\n rows: number;\n cwd?: string;\n envs?: Record<string, string>;\n timeoutMs?: number;\n onData: (data: Uint8Array) => void | Promise<void>;\n}\n\nexport interface E2bCommandConnectOptions {\n timeoutMs?: number;\n onStdout?: (data: string) => void | Promise<void>;\n onStderr?: (data: string) => void | Promise<void>;\n}\n\nexport interface E2bCommandResult {\n exitCode?: number;\n stdout?: string;\n stderr?: string;\n}\n\nexport interface E2bCommandHandle {\n readonly pid: number;\n wait(): Promise<E2bCommandResult>;\n kill(): Promise<boolean>;\n}\n\nexport interface CreateSandboxOptions {\n apiKey: string;\n templateId: string;\n env: Record<string, string>;\n timeoutMinutes?: number;\n}\n\nexport interface BuildTemplateOptions {\n apiKey: string;\n name: string;\n dockerfilePath: string;\n buildContext: string;\n cpu?: number;\n memoryMb?: number;\n fromTemplate?: string;\n onLog?: (entry: BuildLogEntry) => void;\n}\n\nexport interface BuildLogEntry {\n level: \"debug\" | \"info\" | \"warn\" | \"error\";\n message: string;\n timestamp: Date;\n}\n\nexport interface BuildTemplateResult {\n templateId: string;\n}\n\nexport interface SandboxInfo {\n sandboxId: string;\n}\n\nexport async function createSandbox(opts: CreateSandboxOptions): Promise<E2bSandbox> {\n return Sandbox.create(opts.templateId, {\n apiKey: opts.apiKey,\n envs: opts.env,\n ...(opts.timeoutMinutes === undefined ? {} : { timeoutMs: opts.timeoutMinutes * 60_000 })\n }) as Promise<E2bSandbox>;\n}\n\nexport async function connectSandbox(id: string, apiKey?: string): Promise<E2bSandbox> {\n return Sandbox.connect(id, apiKey === undefined ? undefined : { apiKey }) as Promise<E2bSandbox>;\n}\n\nexport async function buildTemplate(opts: BuildTemplateOptions): Promise<BuildTemplateResult> {\n const template = Template({ fileContextPath: opts.buildContext }).fromDockerfile(\n opts.dockerfilePath\n );\n if (opts.fromTemplate !== undefined && opts.fromTemplate.length > 0) {\n (template as TemplateBase).fromTemplate(opts.fromTemplate);\n }\n const result = await Template.build(template, opts.name, {\n apiKey: opts.apiKey,\n ...(opts.cpu === undefined ? {} : { cpuCount: opts.cpu }),\n ...(opts.memoryMb === undefined ? {} : { memoryMB: opts.memoryMb }),\n ...(opts.onLog ? { onBuildLogs: opts.onLog } : {})\n });\n return { templateId: result.templateId };\n}\n\nexport async function listSandboxes(apiKey?: string): Promise<SandboxInfo[]> {\n const paginator = Sandbox.list(apiKey === undefined ? undefined : { apiKey });\n const sandboxes: SandboxInfo[] = [];\n while (paginator.hasNext) {\n sandboxes.push(...((await paginator.nextItems()) as SandboxInfo[]));\n }\n return sandboxes;\n}\n\nexport function toArrayBuffer(buffer: Buffer): ArrayBuffer {\n const output = new ArrayBuffer(buffer.byteLength);\n new Uint8Array(output).set(buffer);\n return output;\n}\n\nexport async function readableToString(stream: Readable | null): Promise<string> {\n if (stream === null) {\n return \"\";\n }\n stream.setEncoding(\"utf8\");\n const chunks: string[] = [];\n for await (const chunk of stream) {\n chunks.push(String(chunk));\n }\n return chunks.join(\"\");\n}\n", "import { createHash } from \"node:crypto\";\nimport { readdir, readFile } from \"node:fs/promises\";\nimport path from \"node:path\";\nimport type { E2bRuntime, StateManager } from \"@poe-code/poe-code-config\";\nimport { buildTemplate, type BuildLogEntry } from \"./sdk.js\";\n\nexport interface BuildE2bRuntimeTemplateInput {\n runtime: E2bRuntime;\n dockerfilePath: string;\n buildContext: string;\n state?: Pick<StateManager, \"templates\">;\n apiKey: string;\n force?: boolean;\n onLog?: (entry: BuildLogEntry) => void;\n}\n\nexport interface BuildE2bRuntimeTemplateResult {\n backend: \"e2b\";\n hash: string;\n templateId: string;\n cached: boolean;\n}\n\nconst BUILD_LOG_TAIL_SIZE = 30;\n\nexport async function buildE2bRuntimeTemplate(\n input: BuildE2bRuntimeTemplateInput\n): Promise<BuildE2bRuntimeTemplateResult> {\n const dockerfileBytes = await readFile(input.dockerfilePath);\n const buildContextFiles = await readBuildContextFiles(input.buildContext);\n const hash = hashTemplate(dockerfileBytes, buildContextFiles, input.runtime.build_args);\n const cached = input.force === true ? null : await input.state?.templates.get(\"e2b\", hash);\n\n if (cached?.template_id !== undefined) {\n return { backend: \"e2b\", hash, templateId: cached.template_id, cached: true };\n }\n\n const tail: string[] = [];\n const onLog = (entry: BuildLogEntry): void => {\n tail.push(entry.message);\n if (tail.length > BUILD_LOG_TAIL_SIZE) {\n tail.shift();\n }\n input.onLog?.(entry);\n };\n\n let built;\n try {\n built = await buildTemplate({\n apiKey: input.apiKey,\n name: `poe-code-${hash.slice(0, 32)}`,\n dockerfilePath: input.dockerfilePath,\n buildContext: input.buildContext,\n cpu: input.runtime.cpu,\n memoryMb: input.runtime.memory_mb,\n fromTemplate: input.runtime.from_template,\n onLog\n });\n } catch (error) {\n throw decorateBuildError(error, tail);\n }\n\n await input.state?.templates.put(\"e2b\", {\n hash,\n template_id: built.templateId,\n runtime_type: \"e2b\",\n dockerfile_path: input.dockerfilePath,\n built_at: new Date().toISOString()\n });\n\n return { backend: \"e2b\", hash, templateId: built.templateId, cached: false };\n}\n\nfunction decorateBuildError(error: unknown, tail: string[]): Error {\n const original = error instanceof Error ? error : new Error(String(error));\n if (tail.length === 0) {\n return original;\n }\n const decorated = new Error(`${original.message}\\n\\nLast build output:\\n${tail.join(\"\\n\")}`);\n decorated.stack = original.stack;\n (decorated as Error & { cause?: unknown }).cause = original;\n return decorated;\n}\n\nfunction hashTemplate(\n dockerfileBytes: Buffer,\n buildContextFiles: BuildContextFile[],\n buildArgs: Record<string, string>\n): string {\n const hash = createHash(\"sha256\");\n hash.update(dockerfileBytes);\n hash.update(\"\\0\");\n for (const file of buildContextFiles) {\n hash.update(file.relativePath);\n hash.update(\"\\0\");\n hash.update(file.bytes);\n hash.update(\"\\0\");\n }\n for (const [key, value] of Object.entries(buildArgs).sort(([left], [right]) =>\n left.localeCompare(right)\n )) {\n hash.update(key);\n hash.update(\"=\");\n hash.update(value);\n hash.update(\"\\0\");\n }\n return hash.digest(\"hex\");\n}\n\ninterface BuildContextFile {\n relativePath: string;\n bytes: Buffer;\n}\n\nasync function readBuildContextFiles(buildContext: string): Promise<BuildContextFile[]> {\n const files: BuildContextFile[] = [];\n await collectBuildContextFiles(buildContext, \"\", files);\n return files.sort((left, right) => left.relativePath.localeCompare(right.relativePath));\n}\n\nasync function collectBuildContextFiles(\n buildContext: string,\n relativeDir: string,\n files: BuildContextFile[]\n): Promise<void> {\n const absoluteDir = path.join(buildContext, relativeDir);\n const entries = await readdir(absoluteDir, { withFileTypes: true });\n\n for (const entry of entries) {\n const relativePath = path.join(relativeDir, entry.name);\n if (entry.isDirectory()) {\n await collectBuildContextFiles(buildContext, relativePath, files);\n continue;\n }\n if (!entry.isFile()) {\n continue;\n }\n files.push({\n relativePath: relativePath.split(path.sep).join(\"/\"),\n bytes: await readFile(path.join(buildContext, relativePath))\n });\n }\n}\n", "import { mkdtempSync, rmSync } from \"node:fs\";\nimport { readFile, writeFile } from \"node:fs/promises\";\nimport { tmpdir } from \"node:os\";\nimport path from \"node:path\";\nimport { PassThrough, Writable } from \"node:stream\";\nimport type { E2bRuntime } from \"@poe-code/poe-code-config\";\nimport type {\n LogStreamFs,\n OpenSpec,\n OpenedEnv,\n RunHandle,\n RunSpec\n} from \"@poe-code/agent-harness-tools\";\nimport { createHostRunner, type Runner } from \"@poe-code/process-runner\";\nimport { createE2bJobHandle, createE2bLogStreamFs } from \"./job-handle.js\";\nimport {\n readableToString,\n toArrayBuffer,\n type E2bCommandHandle,\n type E2bCommandResult,\n type E2bSandbox\n} from \"./sdk.js\";\n\nconst REMOTE_COMMAND_STDERR_TAIL_SIZE = 30;\n\ninterface DetachedJobContext {\n id: string;\n tool: string;\n argv: string[];\n}\n\nexport interface E2bOpenedEnv extends OpenedEnv {\n fs: LogStreamFs;\n setDetachedJobContext(context: DetachedJobContext): void;\n}\n\nexport function createOpenedE2bEnv(input: {\n sandbox: E2bSandbox;\n spec: OpenSpec;\n runtime: E2bRuntime;\n}): E2bOpenedEnv {\n const hostRunner = input.spec.hostRunner ?? createHostRunner();\n const hostWorkspaceDir = path.resolve(input.spec.cwd);\n const sandboxWorkspaceDir = normalizeSandboxWorkspaceDir(input.runtime.workspace_dir);\n let lastProcess: { started: Promise<E2bCommandHandle> } | null = null;\n let detachedJobContext: DetachedJobContext | null = null;\n const mapWorkspaceCwd = (cwd: string | undefined): string | undefined => {\n if (cwd === undefined) {\n return undefined;\n }\n if (path.isAbsolute(cwd) && path.resolve(cwd) === hostWorkspaceDir) {\n return sandboxWorkspaceDir;\n }\n return cwd;\n };\n\n const attachedJobId = (input.spec as OpenSpec & { detachedJobId?: string }).detachedJobId;\n const env: E2bOpenedEnv = {\n id: input.sandbox.sandboxId,\n job: attachedJobId\n ? createE2bJobHandle({\n sandbox: input.sandbox,\n envId: input.sandbox.sandboxId,\n jobId: attachedJobId,\n tool: input.spec.jobLabel.tool,\n argv: input.spec.jobLabel.argv,\n preserveAfterExitHours: input.runtime.preserve_after_exit_hours ?? 24\n })\n : null,\n fs: createE2bLogStreamFs(input.sandbox),\n setDetachedJobContext(context) {\n detachedJobContext = context;\n },\n async uploadWorkspace() {\n if (input.spec.runner?.sync === \"none\") {\n return { files: 0, bytes: 0, skipped: [] };\n }\n const tempDir = mkdtempSync(path.join(tmpdir(), \"poe-e2b-upload-\"));\n const archivePath = path.join(tempDir, \"workspace.tar\");\n try {\n await runOrThrow(hostRunner, {\n command: \"tar\",\n args: [\n ...input.spec.uploadIgnoreFiles.flatMap((ignored) => [\"--exclude\", ignored]),\n \"-cf\",\n archivePath,\n \"-C\",\n input.spec.cwd,\n \".\"\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n await input.sandbox.files.write(\n \"/tmp/poe-workspace-upload.tar\",\n toArrayBuffer(await readFile(archivePath))\n );\n await runRemoteOrThrow(\n input.sandbox,\n createUploadWorkspaceCommand(sandboxWorkspaceDir)\n );\n return { files: 0, bytes: 0, skipped: [] };\n } finally {\n rmSync(tempDir, { recursive: true, force: true });\n }\n },\n async downloadWorkspace(opts) {\n if (input.spec.runner?.sync === \"upload\" || input.spec.runner?.sync === \"none\") {\n return { files: 0, bytes: 0, conflicts: [] };\n }\n const tempDir = mkdtempSync(path.join(tmpdir(), \"poe-e2b-download-\"));\n const archivePath = path.join(tempDir, \"workspace.tar\");\n try {\n await runRemoteOrThrow(\n input.sandbox,\n `tar -cf /tmp/poe-workspace-download.tar -C ${shellQuote(sandboxWorkspaceDir)} .`\n );\n const archive = await input.sandbox.files.read(\"/tmp/poe-workspace-download.tar\", {\n format: \"bytes\"\n });\n await writeFile(archivePath, Buffer.from(archive));\n await runOrThrow(hostRunner, {\n command: \"tar\",\n args: [\n opts.conflictPolicy === \"refuse\" ? \"-xkf\" : \"-xf\",\n archivePath,\n \"-C\",\n input.spec.cwd\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n return { files: 0, bytes: archive.byteLength, conflicts: [] };\n } finally {\n rmSync(tempDir, { recursive: true, force: true });\n }\n },\n exec(spec) {\n const handle = runE2bCommand(input.sandbox, {\n ...spec,\n cwd: mapWorkspaceCwd(spec.cwd),\n env: resolveSandboxCommandEnv(spec.env)\n });\n lastProcess = { started: handle.started };\n return handle;\n },\n async detach() {\n if (detachedJobContext === null) {\n throw new Error(\"Cannot detach E2B environment before a job context is registered.\");\n }\n if (lastProcess === null) {\n throw new Error(\"Cannot detach E2B environment before a command is running.\");\n }\n const command = await lastProcess.started;\n const preserveAfterExitHours = input.runtime.preserve_after_exit_hours ?? 24;\n const preserveMs = preserveAfterExitHours * 60 * 60 * 1000;\n if (preserveMs > 0) {\n await input.sandbox.setTimeout(preserveMs);\n }\n return createE2bJobHandle({\n sandbox: input.sandbox,\n envId: input.sandbox.sandboxId,\n jobId: detachedJobContext.id,\n tool: detachedJobContext.tool,\n argv: detachedJobContext.argv,\n pid: command.pid,\n preserveAfterExitHours\n });\n },\n shell() {\n const shellSpec = input.spec.shellSpec;\n const command = shellSpec?.command ?? input.spec.env.SHELL ?? \"sh\";\n return runE2bPty(input.sandbox, {\n command,\n ...(shellSpec?.args ? { args: shellSpec.args } : {}),\n cwd: mapWorkspaceCwd(shellSpec?.cwd ?? input.spec.cwd),\n env: resolveSandboxCommandEnv(\n shellSpec && \"env\" in shellSpec ? shellSpec.env : input.spec.env\n ),\n stdin: \"inherit\",\n stdout: \"inherit\",\n stderr: \"inherit\",\n tty: true\n });\n },\n async close() {\n await input.sandbox.kill();\n }\n };\n\n return env;\n}\n\nfunction runE2bCommand(\n sandbox: E2bSandbox,\n spec: RunSpec\n): RunHandle & { e2bHandle: E2bCommandHandle | null; started: Promise<E2bCommandHandle> } {\n const stdout = spec.stdout === \"inherit\" ? null : new PassThrough();\n const stderr = spec.stderr === \"inherit\" ? null : new PassThrough();\n let e2bHandle: E2bCommandHandle | null = null;\n const command = shellCommand([spec.command, ...(spec.args ?? [])]);\n const started = sandbox.commands.run(command, {\n background: true,\n cwd: spec.cwd,\n envs: spec.env,\n stdin: spec.stdin === \"pipe\",\n onStdout(data) {\n stdout?.write(data);\n if (spec.stdout === \"inherit\") {\n process.stdout.write(data);\n }\n },\n onStderr(data) {\n stderr?.write(data);\n if (spec.stderr === \"inherit\") {\n process.stderr.write(data);\n }\n }\n }) as Promise<E2bCommandHandle>;\n const stdin =\n spec.stdin === \"pipe\"\n ? new Writable({\n write(chunk, _encoding, callback) {\n started\n .then((handle) =>\n sandbox.commands.sendStdin(\n handle.pid,\n Buffer.isBuffer(chunk) ? chunk : Buffer.from(String(chunk))\n )\n )\n .then(() => callback(), callback);\n },\n final(callback) {\n if (sandbox.commands.closeStdin === undefined) {\n callback();\n return;\n }\n started\n .then((handle) => sandbox.commands.closeStdin!(handle.pid))\n .then(() => callback(), callback);\n }\n })\n : null;\n const result = started\n .then((handle) => {\n e2bHandle = handle;\n return handle.wait();\n })\n .then(\n (result) => {\n stdout?.end();\n stderr?.end();\n return { exitCode: result.exitCode ?? 0 };\n },\n (error: unknown) => {\n stdout?.end();\n stderr?.end();\n if (isExitError(error)) {\n return { exitCode: error.exitCode };\n }\n return { exitCode: 1 };\n }\n );\n\n return {\n get pid() {\n return e2bHandle?.pid ?? null;\n },\n stdin,\n stdout,\n stderr,\n result,\n kill() {\n void e2bHandle?.kill();\n },\n get e2bHandle() {\n return e2bHandle;\n },\n started\n };\n}\n\nfunction runE2bPty(sandbox: E2bSandbox, spec: RunSpec): RunHandle {\n const stdout = new PassThrough();\n let handleRef: E2bCommandHandle | null = null;\n const stdin = new Writable({\n write(chunk, _encoding, callback) {\n if (handleRef === null) {\n callback(new Error(\"E2B PTY stdin is not ready.\"));\n return;\n }\n sandbox.pty\n .sendInput(handleRef.pid, Buffer.isBuffer(chunk) ? chunk : Buffer.from(String(chunk)))\n .then(() => callback(), callback);\n }\n });\n const started = sandbox.pty.create({\n cols: process.stdout.columns || 80,\n rows: process.stdout.rows || 24,\n cwd: spec.cwd,\n envs: spec.env,\n onData(data) {\n stdout.write(Buffer.from(data));\n if (spec.stdout === \"inherit\") {\n process.stdout.write(Buffer.from(data));\n }\n }\n });\n const result = started\n .then((handle) => {\n handleRef = handle;\n return handle.wait();\n })\n .then(\n (result) => {\n stdout.end();\n return { exitCode: result.exitCode ?? 0 };\n },\n () => {\n stdout.end();\n return { exitCode: 1 };\n }\n );\n\n return {\n get pid() {\n return handleRef?.pid ?? null;\n },\n stdin: spec.stdin === \"inherit\" ? process.stdin : stdin,\n stdout: spec.stdout === \"inherit\" ? null : stdout,\n stderr: null,\n result,\n kill() {\n void (handleRef === null ? undefined : sandbox.pty.kill(handleRef.pid));\n }\n };\n}\n\nasync function runRemoteOrThrow(sandbox: E2bSandbox, command: string): Promise<void> {\n const stdoutTail = createLineTail(REMOTE_COMMAND_STDERR_TAIL_SIZE);\n const stderrTail = createLineTail(REMOTE_COMMAND_STDERR_TAIL_SIZE);\n let result: E2bCommandResult | E2bCommandHandle;\n try {\n result = await sandbox.commands.run(command, {\n onStdout(data) {\n stdoutTail.push(data);\n },\n onStderr(data) {\n stderrTail.push(data);\n }\n });\n } catch (error) {\n appendRemoteCommandOutput(error, stdoutTail, stderrTail);\n if (isCommandExitError(error)) {\n throw decorateRemoteCommandError(error, command, stderrTail.values());\n }\n throw error;\n }\n appendRemoteCommandOutput(result, stdoutTail, stderrTail);\n if (\"exitCode\" in result && result.exitCode !== 0) {\n throw decorateRemoteCommandError(\n new Error(`E2B command failed with exit code ${result.exitCode}`),\n command,\n stderrTail.values()\n );\n }\n}\n\nfunction appendRemoteCommandOutput(\n source: unknown,\n stdoutTail: { push(chunk: string): void },\n stderrTail: { push(chunk: string): void }\n): void {\n if (!source || typeof source !== \"object\") {\n return;\n }\n const output = source as { stdout?: unknown; stderr?: unknown };\n if (typeof output.stdout === \"string\") {\n stdoutTail.push(output.stdout);\n }\n if (typeof output.stderr === \"string\") {\n stderrTail.push(output.stderr);\n }\n}\n\nfunction decorateRemoteCommandError(error: unknown, command: string, stderrTail: string[]): Error {\n const original = error instanceof Error ? error : new Error(String(error));\n const tail = stderrTail.length === 0 ? \"\" : `\\n\\nLast stderr output:\\n${stderrTail.join(\"\\n\")}`;\n const decorated = new Error(`E2B command failed: ${command}\\n${original.message}${tail}`);\n decorated.stack = original.stack;\n (decorated as Error & { cause?: unknown }).cause = original;\n return decorated;\n}\n\nfunction createLineTail(maxLines: number): { push(chunk: string): void; values(): string[] } {\n const lines: string[] = [];\n let pending = \"\";\n const appendLine = (line: string): void => {\n lines.push(trimTrailingCarriageReturn(line));\n while (lines.length > maxLines) {\n lines.shift();\n }\n };\n\n return {\n push(chunk) {\n pending += chunk;\n const parts = pending.split(\"\\n\");\n pending = parts.pop() ?? \"\";\n for (const line of parts) {\n appendLine(line);\n }\n },\n values() {\n const output = [...lines];\n if (pending.length > 0) {\n output.push(trimTrailingCarriageReturn(pending));\n }\n return output.slice(-maxLines);\n }\n };\n}\n\nfunction trimTrailingCarriageReturn(value: string): string {\n return value.endsWith(\"\\r\") ? value.slice(0, -1) : value;\n}\n\nasync function runOrThrow(runner: Runner, spec: RunSpec): Promise<void> {\n const handle = runner.exec(spec);\n const stderr = readableToString(handle.stderr);\n const result = await handle.result;\n if (result.exitCode !== 0) {\n throw new Error(\n `Command failed with exit code ${result.exitCode}: ${spec.command} ${(spec.args ?? []).join(\" \")}\\n${await stderr}`\n );\n }\n}\n\nfunction shellCommand(argv: string[]): string {\n return argv.map(shellQuote).join(\" \");\n}\n\nfunction shellQuote(value: string): string {\n return `'${value.replaceAll(\"'\", \"'\\\\''\")}'`;\n}\n\nfunction createUploadWorkspaceCommand(sandboxWorkspaceDir: string): string {\n const quotedWorkspaceDir = shellQuote(sandboxWorkspaceDir);\n return [\n `mkdir -p ${quotedWorkspaceDir} || { command -v sudo >/dev/null 2>&1 && sudo mkdir -p ${quotedWorkspaceDir} && sudo chown \"$(id -u):$(id -g)\" ${quotedWorkspaceDir}; }`,\n `test -w ${quotedWorkspaceDir} && tar -xf /tmp/poe-workspace-upload.tar -C ${quotedWorkspaceDir}`\n ].join(\"\\n\");\n}\n\nfunction resolveSandboxCommandEnv(\n env: Record<string, string> | undefined\n): Record<string, string> | undefined {\n if (env === undefined) {\n return undefined;\n }\n return {\n ...env,\n HOME: \"/home/user\"\n };\n}\n\nfunction normalizeSandboxWorkspaceDir(workspaceDir: string | undefined): string {\n const resolvedWorkspaceDir = workspaceDir ?? \"/workspace\";\n if (!path.posix.isAbsolute(resolvedWorkspaceDir)) {\n throw new Error(\"E2B runtime workspace_dir must be an absolute sandbox path.\");\n }\n let normalized = path.posix.normalize(resolvedWorkspaceDir);\n while (normalized.length > 1 && normalized.endsWith(\"/\")) {\n normalized = normalized.slice(0, -1);\n }\n return normalized;\n}\n\nfunction isExitError(error: unknown): error is { exitCode: number } {\n return Boolean(\n error &&\n typeof error === \"object\" &&\n typeof (error as { exitCode?: unknown }).exitCode === \"number\"\n );\n}\n\nfunction isCommandExitError(error: unknown): boolean {\n return (\n isExitError(error) ||\n Boolean(\n error &&\n typeof error === \"object\" &&\n (error as { name?: unknown }).name === \"CommandExitError\"\n )\n );\n}\n", "import path from \"node:path\";\nimport type { JobHandle, JobStatus, LogChunk } from \"@poe-code/agent-harness-tools\";\nimport { streamLogFile, waitForExit, type LogStreamFs } from \"@poe-code/agent-harness-tools\";\nimport type { E2bSandbox } from \"./sdk.js\";\n\nconst JOB_DIR = \"/tmp/poe-jobs\";\n\nexport function createE2bJobHandle(input: {\n sandbox: E2bSandbox;\n envId: string;\n jobId: string;\n tool: string;\n argv: string[];\n pid?: number;\n preserveAfterExitHours: number;\n}): JobHandle {\n const fs = createE2bLogStreamFs(input.sandbox);\n\n return {\n id: input.jobId,\n envId: input.envId,\n tool: input.tool,\n argv: input.argv,\n async status(): Promise<JobStatus> {\n const exit = await readExitCode(input.sandbox, input.jobId);\n if (exit !== null) {\n return \"exited\";\n }\n\n const processes = await input.sandbox.commands.list();\n const isRunning =\n input.pid === undefined\n ? processes.some((process) => processMentionsJob(process, input.jobId))\n : processes.some((process) => process.pid === input.pid);\n return isRunning ? \"running\" : \"lost\";\n },\n stream(opts = {}): AsyncIterable<LogChunk> {\n return streamLogFile({ fs }, input.jobId, opts);\n },\n async wait(): Promise<{ exitCode: number }> {\n const result = await waitForExit({ fs }, input.jobId);\n const preserveMs = input.preserveAfterExitHours * 60 * 60 * 1000;\n if (preserveMs > 0) {\n await input.sandbox.setTimeout(preserveMs);\n }\n return result;\n },\n async kill(): Promise<void> {\n const pids =\n input.pid === undefined\n ? (await input.sandbox.commands.list())\n .filter((process) => processMentionsJob(process, input.jobId))\n .map((process) => process.pid)\n : [input.pid];\n await Promise.all(pids.map((pid) => input.sandbox.commands.kill(pid)));\n }\n };\n}\n\nexport function createE2bLogStreamFs(sandbox: E2bSandbox): LogStreamFs {\n return {\n promises: {\n async readFile(filePath) {\n return Buffer.from(await sandbox.files.read(filePath, { format: \"bytes\" }));\n },\n async stat(filePath) {\n const result = await sandbox.commands.run(\n `stat -c %Y ${shellQuote(filePath)} 2>/dev/null || stat -f %m ${shellQuote(filePath)}`\n );\n if (!(\"stdout\" in result)) {\n throw new Error(`Unable to stat ${filePath}`);\n }\n const seconds = Number(result.stdout?.trim());\n if (!Number.isFinite(seconds)) {\n throw new Error(`Unable to stat ${filePath}`);\n }\n return { mtimeMs: seconds * 1000 };\n }\n },\n watch(filePath, listener) {\n let closed = false;\n let stop: (() => void) | null = null;\n void sandbox.files\n .watchDir(path.dirname(filePath), listener, { recursive: false })\n .then((handle) => {\n if (closed) {\n void handle.stop();\n return;\n }\n stop = () => {\n void handle.stop();\n };\n });\n return {\n close() {\n closed = true;\n stop?.();\n }\n } as ReturnType<NonNullable<LogStreamFs[\"watch\"]>>;\n }\n };\n}\n\nfunction processMentionsJob(process: { cmd: string; args: string[] }, jobId: string): boolean {\n const needle = `/tmp/poe-jobs/${jobId}`;\n return process.cmd.includes(needle) || process.args.some((arg) => arg.includes(needle));\n}\n\nfunction shellQuote(value: string): string {\n return `'${value.replaceAll(\"'\", \"'\\\\''\")}'`;\n}\n\nasync function readExitCode(sandbox: E2bSandbox, jobId: string): Promise<number | null> {\n try {\n const contents = await sandbox.files.read(`${JOB_DIR}/${jobId}.exit`);\n const exitCode = Number(contents.trim());\n return Number.isInteger(exitCode) ? exitCode : null;\n } catch {\n return null;\n }\n}\n", "import os from \"node:os\";\nimport { promises as nodeFs } from \"node:fs\";\nimport {\n defineScope,\n readMergedDocument,\n resolveConfigPath,\n resolveProjectConfigPath,\n resolveScope\n} from \"@poe-code/poe-code-config\";\nimport type { FileSystem } from \"@poe-code/config-mutations\";\n\nexport const e2bAuthScope = defineScope(\"e2b\", {\n api_key: {\n type: \"string\",\n default: \"\",\n doc: \"E2B API key\",\n env: \"E2B_API_KEY\"\n }\n});\n\nexport interface ResolveE2bApiKeyInput {\n cwd: string;\n homeDir?: string;\n fs?: FileSystem;\n env?: Record<string, string | undefined>;\n}\n\nexport async function resolveE2bApiKey(input: ResolveE2bApiKeyInput): Promise<string> {\n const homeDir = input.homeDir ?? os.homedir();\n const fs = input.fs ?? (nodeFs as unknown as FileSystem);\n const env = input.env ?? process.env;\n const document = await readMergedDocument(\n fs,\n resolveConfigPath(homeDir),\n resolveProjectConfigPath(input.cwd)\n );\n const resolved = resolveScope(e2bAuthScope.schema, document.e2b, env);\n if (resolved.api_key.length === 0) {\n throw new Error(\n \"No E2B API key. Set E2B_API_KEY or e2b.api_key in ~/.poe-code/config.json.\"\n );\n }\n return resolved.api_key;\n}\n", "import type { ExecutionEnvFactory } from \"@poe-code/agent-harness-tools\";\nimport { e2bExecutionEnvFactory as factory } from \"./factory.js\";\n\nexport const e2bExecutionEnvFactory: ExecutionEnvFactory = factory;\nexport { e2bAuthScope, resolveE2bApiKey } from \"./auth-scope.js\";\nexport {\n buildE2bRuntimeTemplate,\n type BuildE2bRuntimeTemplateInput,\n type BuildE2bRuntimeTemplateResult\n} from \"./template-build.js\";\n", "import type { OtelSink, OtelSpan, SpawnMode, SpawnResult } from \"../types.js\";\n\nexport const noopOtelSink: OtelSink = {\n startSpan: () => noopOtelSpan,\n recordException: () => undefined\n};\n\nconst noopOtelSpan: OtelSpan = {\n setAttribute: () => undefined,\n addEvent: () => undefined,\n end: () => undefined\n};\n\nexport function observeAgentSpawn(\n input: {\n agent: string;\n cwd?: string;\n mode?: SpawnMode;\n otelSink?: OtelSink;\n prompt: string;\n },\n operation: () => Promise<SpawnResult>\n): Promise<SpawnResult> {\n const span = safeStartSpan(input.otelSink, \"agent.spawn\", {\n agent: input.agent,\n mode: input.mode ?? \"yolo\",\n cwd: input.cwd ?? process.cwd()\n });\n safeAddEvent(span, \"prompt\", { prompt: input.prompt });\n\n return (async () => {\n try {\n const result = await operation();\n safeAddEvent(span, \"summary\", { summary: readSummary(result) });\n safeAddEvent(span, \"exit\", { exitCode: result.exitCode });\n return result;\n } catch (error) {\n safeRecordException(input.otelSink, span, error);\n throw error;\n } finally {\n safeEndSpan(span);\n }\n })();\n}\n\nfunction safeStartSpan(\n sink: OtelSink | undefined,\n name: string,\n attrs: Record<string, unknown>\n): OtelSpan {\n if (sink === undefined) {\n return noopOtelSpan;\n }\n\n try {\n return sink.startSpan(name, attrs);\n } catch (error) {\n warnOtelSinkFailure(\"startSpan\", error);\n return noopOtelSpan;\n }\n}\n\nfunction safeAddEvent(\n span: OtelSpan | undefined,\n name: string,\n attrs: Record<string, unknown>\n): void {\n if (span === undefined) {\n return;\n }\n\n try {\n span.addEvent(name, attrs);\n } catch (error) {\n warnOtelSinkFailure(\"addEvent\", error);\n }\n}\n\nfunction safeRecordException(sink: OtelSink | undefined, span: OtelSpan, error: unknown): void {\n if (sink === undefined) {\n return;\n }\n\n try {\n sink.recordException(span, error);\n } catch (recordError) {\n warnOtelSinkFailure(\"recordException\", recordError);\n }\n}\n\nfunction safeEndSpan(span: OtelSpan): void {\n try {\n span.end();\n } catch (error) {\n warnOtelSinkFailure(\"end\", error);\n }\n}\n\nfunction readSummary(result: SpawnResult): string {\n return result.stdout.trim() || result.stderr.trim();\n}\n\nfunction warnOtelSinkFailure(method: string, error: unknown): void {\n console.warn(`OpenTelemetry sink ${method} failed: ${readErrorMessage(error)}`);\n}\n\nfunction readErrorMessage(error: unknown): string {\n return error instanceof Error ? error.message : String(error);\n}\n", "import { spawn } from \"node:child_process\";\n\nexport interface CommandRunnerResult {\n stdout: string;\n stderr: string;\n exitCode: number;\n}\n\nexport interface CommandRunnerOptions {\n cwd?: string;\n env?: Record<string, string | undefined>;\n stdin?: string | Buffer;\n}\n\nexport type CommandRunner = (\n command: string,\n args: string[],\n options?: CommandRunnerOptions\n) => Promise<CommandRunnerResult>;\n\nexport function runCommand(\n command: string,\n args: string[],\n options?: CommandRunnerOptions\n): Promise<CommandRunnerResult> {\n return new Promise((resolve) => {\n const hasStdin = options?.stdin != null;\n const child = spawn(command, args, {\n stdio: [hasStdin ? \"pipe\" : \"ignore\", \"pipe\", \"pipe\"],\n cwd: options?.cwd,\n env: options?.env\n ? {\n ...(process.env as Record<string, string | undefined>),\n ...options.env\n }\n : undefined\n });\n let stdout = \"\";\n let stderr = \"\";\n\n if (hasStdin && child.stdin) {\n child.stdin.on(\"error\", () => {});\n child.stdin.end(options!.stdin);\n }\n\n child.stdout?.setEncoding(\"utf8\");\n child.stdout?.on(\"data\", (chunk: string | Buffer) => {\n stdout += chunk.toString();\n });\n\n child.stderr?.setEncoding(\"utf8\");\n child.stderr?.on(\"data\", (chunk: string | Buffer) => {\n stderr += chunk.toString();\n });\n\n child.on(\"error\", (error: NodeJS.ErrnoException) => {\n const exitCode =\n typeof error.code === \"number\"\n ? error.code\n : typeof error.errno === \"number\"\n ? error.errno\n : 127;\n const message =\n error instanceof Error ? error.message : String(error ?? \"error\");\n resolve({\n stdout,\n stderr: stderr ? `${stderr}${message}` : message,\n exitCode\n });\n });\n\n child.on(\"close\", (code) => {\n resolve({\n stdout,\n stderr,\n exitCode: code ?? 0\n });\n });\n });\n}\n", "import type { AdapterType } from \"./adapters/index.js\";\nimport type { RuntimeOverrideOptions } from \"@poe-code/agent-harness-tools\";\nimport type { StateManager } from \"@poe-code/poe-code-config\";\nimport type { AcpMiddleware } from \"./acp/middleware.js\";\n\nexport type SpawnMode = \"yolo\" | \"edit\" | \"read\";\n\nexport type SpawnModeConfig = string[] | { args?: string[]; env?: Record<string, string> };\n\nexport function resolveModeConfig(modeConfig: SpawnModeConfig): {\n args: string[];\n env?: Record<string, string>;\n} {\n if (Array.isArray(modeConfig)) {\n return { args: modeConfig };\n }\n return {\n args: modeConfig.args ?? [],\n env: modeConfig.env && Object.keys(modeConfig.env).length > 0 ? modeConfig.env : undefined\n };\n}\n\nexport interface McpSpawnServer {\n command: string;\n args?: string[];\n env?: Record<string, string>;\n /**\n * Maximum time in seconds the agent should wait for a single tool call\n * to this MCP server before timing out. Omit to use the agent's default.\n */\n timeout?: number;\n}\n\nexport type McpSpawnConfig = Record<string, McpSpawnServer>;\n\nexport type OtelSpan = {\n setAttribute(key: string, value: unknown): void;\n addEvent(name: string, attrs: Record<string, unknown>): void;\n end(): void;\n};\n\nexport interface OtelSink {\n startSpan(name: string, attrs: Record<string, unknown>): OtelSpan;\n recordException(span: ReturnType<OtelSink[\"startSpan\"]>, error: unknown): void;\n}\n\nexport interface SpawnOptions {\n prompt: string;\n cwd?: string;\n model?: string;\n mode?: SpawnMode;\n args?: string[];\n mcpServers?: McpSpawnConfig;\n /** Skill references to bridge into the spawned agent for this run. */\n skills?: string[];\n /** Resume a prior provider thread/session before sending the prompt. */\n resumeThreadId?: string;\n useStdin?: boolean;\n interactive?: boolean;\n signal?: AbortSignal;\n otelSink?: OtelSink;\n middlewares?: AcpMiddleware[];\n tee?: {\n stdout?: { write(chunk: string): void };\n stderr?: { write(chunk: string): void };\n };\n /**\n * Kill the spawned process after this many milliseconds of inactivity (no stdout data).\n * Resets on every chunk of stdout/stderr received. Disabled when undefined.\n */\n activityTimeoutMs?: number;\n /**\n * Full path for the spawn log file. When set, stdout (and stderr for CLI spawns)\n * are appended to this file, and the absolute path is returned in `SpawnResult.logFile`.\n * Takes precedence over `logDir` + `logFileName`.\n */\n logPath?: string;\n /**\n * Directory for the spawn log file. When set together with `logFileName`, stdout\n * (and stderr for CLI spawns) are appended to `<logDir>/<logFileName>`, and the\n * absolute path is returned in `SpawnResult.logFile`.\n */\n logDir?: string;\n /** Overrides the auto-generated log filename. Must be used together with `logDir`. */\n logFileName?: string;\n /** Per-invocation runtime/runner config overrides. */\n runtime?: RuntimeOverrideOptions[\"runtime\"];\n /** Docker image override for docker runtime. */\n runtimeImage?: string;\n /** E2B template override for e2b runtime. */\n runtimeTemplate?: string;\n /** Directory used to load runtime config/templates when different from cwd. */\n runtimeConfigCwd?: string;\n /** Run through a detached runtime job when the backend supports it. */\n detach?: boolean;\n /** Mount the local poe-code checkout into the runtime for development. */\n mountPoeCode?: boolean;\n /** Override runner workspace sync behavior. */\n runnerSync?: RuntimeOverrideOptions[\"runnerSync\"];\n}\n\nexport interface SpawnUsage {\n inputTokens: number;\n outputTokens: number;\n cachedTokens?: number;\n costUsd?: number;\n}\n\nexport interface SpawnResult {\n stdout: string;\n stderr: string;\n exitCode: number;\n durationMs?: number;\n threadId?: string;\n usage?: SpawnUsage;\n logFile?: string;\n detached?: { jobId: string; envId: string };\n}\n\nexport interface AutonomousResult {\n summary?: string;\n log?: string;\n output?: string;\n stdout?: string;\n text?: string;\n logFile?: string;\n toolCalls?: unknown[];\n sessionResult?: {\n toolCalls?: unknown[];\n };\n}\n\nexport interface SpawnLogger {\n dryRun(message: string): void;\n}\n\nexport interface SpawnContext {\n dryRun?: boolean;\n logger?: SpawnLogger;\n homeDir?: string;\n state?: StateManager;\n}\n\nexport interface StdinMode {\n omitPrompt: boolean;\n extraArgs: string[];\n}\n\nexport interface InteractiveSpawnConfig {\n defaultArgs: string[];\n defaultArgsPosition?: \"beforePrompt\" | \"afterPrompt\";\n promptFlag?: string;\n}\n\nexport interface CliSpawnConfig {\n kind: \"cli\";\n agentId: string;\n adapter: AdapterType;\n promptFlag: string;\n defaultArgs: string[];\n defaultArgsPosition?: \"beforePrompt\" | \"afterPrompt\";\n modes: Record<SpawnMode, SpawnModeConfig>;\n stdinMode?: StdinMode;\n modelFlag?: string;\n /**\n * Controls whether the provider prefix is stripped from model IDs before passing to the CLI binary.\n *\n * When `true`: \"anthropic/claude-opus-4.6\" \u2192 \"claude-opus-4.6\", \"openai/gpt-5.2\" \u2192 \"gpt-5.2\"\n * When `false`: \"anthropic/claude-opus-4.6\" stays as-is, \"openai/gpt-5.2\" stays as-is\n *\n * Most CLI binaries only accept bare model IDs (e.g. `claude --model claude-opus-4.6`),\n * so they need `true`. OpenCode routes through poe and needs the full provider path, so it uses `false`.\n */\n modelStripProviderPrefix: boolean;\n /** Transform model ID before passing to CLI. Runs after provider prefix stripping (if enabled). */\n modelTransform?: (model: string) => string;\n /**\n * Transforms MCP server config into CLI args for this agent.\n * Presence of this function declares spawn-time MCP support.\n */\n mcpArgs?: (servers: McpSpawnConfig) => string[];\n /**\n * Transforms MCP server config into env vars for this agent.\n * Use instead of `mcpArgs` when the agent reads MCP config from the environment.\n */\n mcpEnv?: (servers: McpSpawnConfig) => Record<string, string>;\n /**\n * Controls where serialized MCP args are inserted relative to the command.\n *\n * - \"beforeCommand\": before the prompt/subcommand section (e.g. `codex -c ... exec \"prompt\"`)\n * - \"beforePrompt\": after `defaultArgs` but before the prompt/model section\n * - \"afterCommand\": after `defaultArgs` (default)\n */\n mcpArgsPosition?: \"beforeCommand\" | \"beforePrompt\" | \"afterCommand\";\n /**\n * @deprecated Prefer `mcpArgsPosition`.\n * When true, MCP args are placed before the subcommand (e.g. `codex -c ... exec \"prompt\"`).\n * When false/undefined, they are placed after defaultArgs (e.g. `claude -p \"prompt\" --mcp-servers ...`).\n */\n mcpArgsBeforeCommand?: boolean;\n interactive?: InteractiveSpawnConfig;\n resume?: ResumeSpec;\n}\n\nexport interface ResumeSpec {\n /** Args injected into the live spawn for non-interactive resume. */\n args: (threadId: string, cwd: string) => string[];\n /** Position of `args` relative to the prompt token. Default `afterPrompt`. */\n position?: \"beforePrompt\" | \"afterPrompt\";\n /**\n * Optional override for the printed copy-paste resume hint (e.g. an interactive\n * shell command). When omitted, the hint composes binaryName + `args`.\n */\n hintArgs?: (threadId: string, cwd: string) => string[];\n}\n\nexport interface FileSpawnConfig {\n kind: \"file\";\n agentId: string;\n launchCommand?: string;\n launchArgs?: string[];\n}\n\nexport interface AcpSpawnConfig {\n kind: \"acp\";\n agentId: string;\n /** Args passed to the agent binary to start its ACP server (e.g. [\"acp\"]). */\n acpArgs: string[];\n /** Environment variables required by the ACP server process. */\n env?: Record<string, string>;\n /** Whether to skip the ACP authenticate step (workaround for servers that advertise but don't implement auth). */\n skipAuth?: boolean;\n /** MCP server env serializer, same as CliSpawnConfig. */\n mcpEnv?: (servers: McpSpawnConfig) => Record<string, string>;\n}\n\nexport type SpawnConfig = CliSpawnConfig | FileSpawnConfig | AcpSpawnConfig;\n", "import type { McpSpawnConfig } from \"../types.js\";\n\ninterface JsonMcpServer {\n command: string;\n args?: string[];\n env?: Record<string, string>;\n timeout?: number;\n}\n\nfunction toJsonMcpServers(servers: McpSpawnConfig): Record<string, JsonMcpServer> {\n const out: Record<string, JsonMcpServer> = {};\n\n for (const [name, server] of Object.entries(servers)) {\n const mapped: JsonMcpServer = { command: server.command };\n if (server.args && server.args.length > 0) {\n mapped.args = server.args;\n }\n if (server.env && Object.keys(server.env).length > 0) {\n mapped.env = server.env;\n }\n if (server.timeout !== undefined) {\n mapped.timeout = server.timeout;\n }\n out[name] = mapped;\n }\n\n return out;\n}\n\nfunction toTomlString(value: string): string {\n return JSON.stringify(value);\n}\n\nfunction toTomlArray(values: string[]): string {\n const serialized = values.map((value) => toTomlString(value));\n return `[${serialized.join(\", \")}]`;\n}\n\nfunction toTomlInlineTable(values: Record<string, string>): string {\n const parts: string[] = [];\n for (const [key, value] of Object.entries(values)) {\n parts.push(`${JSON.stringify(key)}=${toTomlString(value)}`);\n }\n return `{${parts.join(\", \")}}`;\n}\n\nexport function serializeJsonMcpArgs(servers: McpSpawnConfig): string[] {\n return [\"--mcp-config\", JSON.stringify({ mcpServers: toJsonMcpServers(servers) })];\n}\n\nexport function serializeOpenCodeMcpEnv(servers: McpSpawnConfig): Record<string, string> {\n const mcp: Record<\n string,\n { type: \"local\"; command: string[]; environment?: Record<string, string> }\n > = {};\n for (const [name, server] of Object.entries(servers)) {\n const entry: {\n type: \"local\";\n command: string[];\n environment?: Record<string, string>;\n } = { type: \"local\", command: [server.command, ...(server.args ?? [])] };\n if (server.env && Object.keys(server.env).length > 0) {\n entry.environment = server.env;\n }\n mcp[name] = entry;\n }\n return { OPENCODE_CONFIG_CONTENT: JSON.stringify({ mcp }) };\n}\n\nexport function serializeCodexMcpArgs(servers: McpSpawnConfig): string[] {\n const args: string[] = [];\n\n for (const [name, server] of Object.entries(servers)) {\n const prefix = `mcp_servers.${name}`;\n args.push(\"-c\", `${prefix}.command=${toTomlString(server.command)}`);\n\n if (server.args && server.args.length > 0) {\n args.push(\"-c\", `${prefix}.args=${toTomlArray(server.args)}`);\n }\n\n if (server.env && Object.keys(server.env).length > 0) {\n args.push(\"-c\", `${prefix}.env=${toTomlInlineTable(server.env)}`);\n }\n\n if (server.timeout !== undefined) {\n args.push(\"-c\", `${prefix}.timeout=${server.timeout}`);\n }\n }\n\n return args;\n}\n\nexport function serializeGooseMcpArgs(servers: McpSpawnConfig): string[] {\n return Object.values(servers).flatMap((server) => [\n \"--with-extension\",\n [server.command, ...(server.args ?? [])].join(\" \")\n ]);\n}\n", "import type { CliSpawnConfig } from \"../types.js\";\nimport { serializeJsonMcpArgs } from \"./mcp.js\";\n\nexport const claudeCodeSpawnConfig: CliSpawnConfig = {\n kind: \"cli\",\n agentId: \"claude-code\",\n // ACP adapter support: yes (adapter: \"claude\")\n adapter: \"claude\",\n promptFlag: \"-p\",\n modelFlag: \"--model\",\n modelStripProviderPrefix: true,\n modelTransform: (model) => model.replaceAll(\".\", \"-\"),\n defaultArgs: [\n \"--output-format\",\n \"stream-json\",\n \"--verbose\"\n ],\n mcpArgs: serializeJsonMcpArgs,\n modes: {\n yolo: [\"--dangerously-skip-permissions\"],\n edit: [\"--permission-mode\", \"acceptEdits\", \"--allowedTools\", \"Bash,Read,Write,Edit,Glob,Grep,NotebookEdit\"],\n read: [\"--permission-mode\", \"plan\"]\n },\n stdinMode: {\n omitPrompt: true,\n extraArgs: [\"--input-format\", \"text\"]\n },\n interactive: {\n defaultArgs: []\n },\n resume: {\n args: (threadId) => [\"--resume\", threadId]\n }\n};\n", "import type { CliSpawnConfig } from \"../types.js\";\nimport { serializeCodexMcpArgs } from \"./mcp.js\";\n\nexport const codexSpawnConfig: CliSpawnConfig = {\n kind: \"cli\",\n agentId: \"codex\",\n // ACP adapter support: yes (adapter: \"codex\")\n adapter: \"codex\",\n promptFlag: \"exec\",\n modelFlag: \"--model\",\n modelStripProviderPrefix: true,\n defaultArgs: [\"--skip-git-repo-check\", \"--json\"],\n mcpArgs: serializeCodexMcpArgs,\n mcpArgsBeforeCommand: true,\n modes: {\n yolo: [\"-s\", \"danger-full-access\"],\n edit: [\"-s\", \"workspace-write\"],\n read: [\"-s\", \"read-only\"]\n },\n stdinMode: {\n omitPrompt: true,\n extraArgs: [\"-\"]\n },\n interactive: {\n defaultArgs: [\"-a\", \"never\"]\n },\n resume: {\n args: (threadId) => [\"resume\", threadId],\n position: \"beforePrompt\",\n hintArgs: (threadId, cwd) => [\"resume\", \"-C\", cwd, threadId]\n }\n};\n", "import type { AcpSpawnConfig, CliSpawnConfig } from \"../types.js\";\nimport { serializeOpenCodeMcpEnv } from \"./mcp.js\";\n\n/**\n * OpenCode JSON output format (empirically observed)\n *\n * OpenCode can emit \"raw JSON events\" when running a prompt via:\n * - `opencode run \"<prompt>\" --format json ...`\n *\n * Key observations (OpenCode CLI v1.1.47):\n * - Output is **NDJSON / line-delimited JSON**: one JSON object per stdout line.\n * - Each line is an event object with a top-level `type` string (NOT ACP's `{ event: ... }`).\n * - Common top-level fields:\n * - `type`: `\"step_start\" | \"text\" | \"tool_use\" | \"step_finish\" | ...`\n * - `timestamp`: number (ms since epoch)\n * - `sessionID`: string (e.g. `\"ses_...\"`)\n * - `part`: object with event-specific payload\n *\n * `text` events:\n * ```ts\n * {\n * type: \"text\",\n * sessionID: \"ses_...\",\n * part: {\n * type: \"text\",\n * messageID: \"msg_...\",\n * text: \"Hello ...\",\n * time: { start: 1770000000000, end: 1770000000000 }\n * }\n * }\n * ```\n *\n * Tool calls (`tool_use`):\n * - Represented as a single event with `part.type: \"tool\"` and `state.status`.\n * - `state.input` includes tool arguments; `state.output` is the tool result string.\n * ```ts\n * {\n * type: \"tool_use\",\n * sessionID: \"ses_...\",\n * part: {\n * type: \"tool\",\n * callID: \"call_...\",\n * tool: \"bash\",\n * state: {\n * status: \"completed\",\n * input: { command: \"echo hello\", description: \"...\" },\n * output: \"hello\\n\"\n * }\n * }\n * }\n * ```\n *\n * Step boundaries:\n * - `step_start` and `step_finish` wrap a single model/tool turn.\n * - `step_finish.part.tokens` contains token accounting:\n * `{ input, output, reasoning, cache: { read, write } }`\n *\n * Negative cases / gotchas:\n * - Some failures (e.g. invalid `--model` / unknown provider) can print a non-JSON stack trace\n * before any JSON events are emitted, even with `--format json`.\n * - If `--format json` is ever removed upstream, OpenCode will need a text-mode fallback\n * (no streaming event adapter).\n */\nexport const openCodeSpawnConfig: CliSpawnConfig = {\n kind: \"cli\",\n agentId: \"opencode\",\n // ACP adapter support: yes (adapter: \"opencode\").\n // OpenCode's `--format json` emits NDJSON events with `{ type, sessionID, part }`\n // (no `{ event, ... }` field), so it needs the OpenCode adapter (not \"native\").\n adapter: \"opencode\",\n promptFlag: \"run\",\n modelFlag: \"--model\",\n modelStripProviderPrefix: false,\n modelTransform: (model) => {\n return model.startsWith(\"poe/\") ? model : `poe/${model}`;\n },\n defaultArgs: [\"--format\", \"json\"],\n modes: {\n yolo: [],\n edit: [],\n read: [\"--agent\", \"plan\"]\n },\n interactive: {\n defaultArgs: [],\n promptFlag: \"--prompt\"\n },\n resume: {\n args: (threadId) => [\"--session\", threadId],\n hintArgs: (threadId, cwd) => [cwd, \"--session\", threadId]\n },\n mcpEnv: serializeOpenCodeMcpEnv\n};\n\nexport const openCodeAcpSpawnConfig: AcpSpawnConfig = {\n kind: \"acp\",\n agentId: \"opencode\",\n acpArgs: [\"acp\"],\n skipAuth: true,\n mcpEnv: serializeOpenCodeMcpEnv,\n};\n", "import type { AcpSpawnConfig, CliSpawnConfig } from \"../types.js\";\nimport { serializeJsonMcpArgs } from \"./mcp.js\";\n\nexport const kimiSpawnConfig: CliSpawnConfig = {\n kind: \"cli\",\n agentId: \"kimi\",\n // ACP adapter support: yes (adapter: \"kimi\").\n // Kimi's `--output-format stream-json` emits OpenAI-style `{ role, content }` JSON\n // (no `{ event, ... }` field), so it needs the Kimi adapter (not \"native\").\n adapter: \"kimi\",\n promptFlag: \"-p\",\n modelStripProviderPrefix: true,\n defaultArgs: [\"--print\", \"--output-format\", \"stream-json\"],\n mcpArgs: serializeJsonMcpArgs,\n modes: {\n yolo: [\"--yolo\"],\n edit: [],\n read: []\n },\n stdinMode: {\n omitPrompt: true,\n extraArgs: [\"--input-format\", \"stream-json\"]\n },\n interactive: {\n defaultArgs: [],\n promptFlag: \"-p\"\n },\n resume: {\n args: (threadId, cwd) => [\"--session\", threadId, \"--work-dir\", cwd]\n }\n};\n\nexport const kimiAcpSpawnConfig: AcpSpawnConfig = {\n kind: \"acp\",\n agentId: \"kimi\",\n acpArgs: [\"acp\"],\n};\n", "import type { AcpSpawnConfig, CliSpawnConfig } from \"../types.js\";\nimport { serializeGooseMcpArgs } from \"./mcp.js\";\n\nconst gooseFileSecretsEnv = { GOOSE_DISABLE_KEYRING: \"1\" };\n\nexport const gooseSpawnConfig: CliSpawnConfig = {\n kind: \"cli\",\n agentId: \"goose\",\n adapter: \"native\",\n promptFlag: \"--text\",\n modelFlag: \"--model\",\n modelStripProviderPrefix: false,\n defaultArgs: [\"run\", \"--output-format\", \"stream-json\"],\n defaultArgsPosition: \"beforePrompt\",\n mcpArgs: serializeGooseMcpArgs,\n mcpArgsPosition: \"beforePrompt\",\n modes: {\n yolo: { env: { ...gooseFileSecretsEnv, GOOSE_MODE: \"auto\" } },\n edit: { env: { ...gooseFileSecretsEnv, GOOSE_MODE: \"smart_approve\" } },\n read: { env: { ...gooseFileSecretsEnv, GOOSE_MODE: \"chat\" } }\n },\n stdinMode: {\n omitPrompt: true,\n extraArgs: [\"--instructions\", \"-\"]\n },\n interactive: {\n defaultArgs: [\"session\"],\n defaultArgsPosition: \"beforePrompt\"\n },\n resume: {\n args: (threadId) => [\"--resume\", \"--session-id\", threadId],\n hintArgs: (threadId) => [\"run\", \"--resume\", \"--session-id\", threadId, \"--text\", \"continue\"]\n }\n};\n\nexport const gooseAcpSpawnConfig: AcpSpawnConfig = {\n kind: \"acp\",\n agentId: \"goose\",\n acpArgs: [\"acp\"],\n env: gooseFileSecretsEnv,\n skipAuth: true\n};\n", "import { resolveAgentId } from \"@poe-code/agent-defs\";\nimport type { AcpSpawnConfig, SpawnConfig } from \"../types.js\";\nimport { claudeCodeSpawnConfig } from \"./claude-code.js\";\nimport { codexSpawnConfig } from \"./codex.js\";\nimport { openCodeSpawnConfig, openCodeAcpSpawnConfig } from \"./opencode.js\";\nimport { kimiSpawnConfig, kimiAcpSpawnConfig } from \"./kimi.js\";\nimport { gooseSpawnConfig, gooseAcpSpawnConfig } from \"./goose.js\";\n\n// ACP adapter support (spawn streaming):\n// - Supported (has `adapter`): claude-code, codex, opencode, kimi, goose\nexport const allSpawnConfigs: readonly SpawnConfig[] = [\n claudeCodeSpawnConfig,\n codexSpawnConfig,\n openCodeSpawnConfig,\n kimiSpawnConfig,\n gooseSpawnConfig\n];\n\nconst lookup = new Map<string, SpawnConfig>();\n\nfor (const config of allSpawnConfigs) {\n lookup.set(config.agentId, config);\n}\n\nconst acpLookup = new Map<string, AcpSpawnConfig>();\nacpLookup.set(openCodeAcpSpawnConfig.agentId, openCodeAcpSpawnConfig);\nacpLookup.set(kimiAcpSpawnConfig.agentId, kimiAcpSpawnConfig);\nacpLookup.set(gooseAcpSpawnConfig.agentId, gooseAcpSpawnConfig);\n\nexport function getSpawnConfig(input: string): SpawnConfig | undefined {\n const resolvedId = resolveAgentId(input);\n if (!resolvedId) {\n return undefined;\n }\n return lookup.get(resolvedId);\n}\n\nexport function getAcpSpawnConfig(input: string): AcpSpawnConfig | undefined {\n const resolvedId = resolveAgentId(input);\n if (!resolvedId) {\n return undefined;\n }\n return acpLookup.get(resolvedId);\n}\n\nexport function supportsMcpAtSpawn(input: string): boolean {\n const config = getSpawnConfig(input);\n return (\n !!config &&\n config.kind === \"cli\" &&\n (typeof config.mcpArgs === \"function\" || typeof config.mcpEnv === \"function\")\n );\n}\n\nexport function listMcpSupportedAgents(): string[] {\n const supported: string[] = [];\n\n for (const config of allSpawnConfigs) {\n if (\n config.kind !== \"cli\" ||\n (typeof config.mcpArgs !== \"function\" && typeof config.mcpEnv !== \"function\")\n ) {\n continue;\n }\n supported.push(config.agentId);\n }\n\n return supported;\n}\n", "import \"./register-factories.js\";\nimport { mkdirSync, openSync, writeSync, closeSync } from \"node:fs\";\nimport path from \"node:path\";\nimport { runPoeCommand } from \"@poe-code/agent-harness-tools\";\nimport { resolveConfig } from \"./configs/resolve-config.js\";\nimport { getMcpArgs } from \"./mcp-args.js\";\nimport { stripModelNamespace } from \"./model-utils.js\";\nimport { observeAgentSpawn } from \"./observability/otel.js\";\nimport { createSpawnParallel } from \"./parallel.js\";\nimport { shouldSendPromptViaStdin } from \"./prompt-transport.js\";\nimport { createSpawnRetry } from \"./retry.js\";\nimport { resolveSpawnExecution } from \"./runtime.js\";\nimport { bridgeSkillsForRun, cleanupSkillsForRun } from \"./skill-bridge.js\";\nimport { spawnStreaming } from \"./acp/spawn.js\";\nimport {\n resolveModeConfig,\n type CliSpawnConfig,\n type McpSpawnConfig,\n type SpawnContext,\n type SpawnMode,\n type SpawnOptions,\n type SpawnResult,\n type StdinMode\n} from \"./types.js\";\n\nfunction createAbortError(): Error {\n const error = new Error(\"Agent spawn aborted\");\n error.name = \"AbortError\";\n return error;\n}\n\nexport function isActivityTimeoutError(error: unknown): boolean {\n return error instanceof Error && error.name === \"ActivityTimeoutError\";\n}\n\nexport interface BuildSpawnArgsOptions {\n prompt: string;\n model?: string;\n mode?: SpawnMode;\n args?: string[];\n mcpServers?: McpSpawnConfig;\n resumeThreadId?: string;\n cwd?: string;\n useStdin?: boolean;\n}\n\nexport interface BuildSpawnArgsResult {\n binaryName: string;\n args: string[];\n env?: Record<string, string>;\n}\n\nfunction resolveCliConfig(agentId: string) {\n const resolved = resolveConfig(agentId);\n\n if (!resolved.spawnConfig) {\n throw new Error(`Agent \"${resolved.agentId}\" has no spawn config.`);\n }\n\n if (resolved.spawnConfig.kind !== \"cli\") {\n throw new Error(`Agent \"${resolved.agentId}\" does not support CLI spawn.`);\n }\n\n if (!resolved.binaryName) {\n throw new Error(`Agent \"${resolved.agentId}\" has no binaryName.`);\n }\n\n return {\n agentId: resolved.agentId,\n binaryName: resolved.binaryName,\n spawnConfig: resolved.spawnConfig\n };\n}\n\nfunction getDefaultArgsPosition(config: CliSpawnConfig): \"beforePrompt\" | \"afterPrompt\" {\n return config.defaultArgsPosition ?? \"afterPrompt\";\n}\n\nfunction getMcpArgsPosition(\n config: CliSpawnConfig\n): \"beforeCommand\" | \"beforePrompt\" | \"afterCommand\" {\n if (config.mcpArgsPosition) {\n return config.mcpArgsPosition;\n }\n return config.mcpArgsBeforeCommand ? \"beforeCommand\" : \"afterCommand\";\n}\n\nfunction buildCliArgs(\n config: CliSpawnConfig,\n options: BuildSpawnArgsOptions,\n stdinMode?: StdinMode\n): { args: string[]; env?: Record<string, string> } {\n const mcpArgs = getMcpArgs(config, options.mcpServers);\n const resumeArgs = getResumeArgs(config, options);\n const defaultArgsPosition = getDefaultArgsPosition(config);\n const mcpArgsPosition = getMcpArgsPosition(config);\n const resumeArgsPosition = config.resume?.position ?? \"afterPrompt\";\n\n const args: string[] = [];\n\n if (mcpArgsPosition === \"beforeCommand\") {\n args.push(...mcpArgs);\n }\n\n if (defaultArgsPosition === \"beforePrompt\") {\n args.push(...config.defaultArgs);\n }\n\n if (mcpArgsPosition === \"beforePrompt\") {\n args.push(...mcpArgs);\n }\n\n if (stdinMode) {\n args.push(config.promptFlag);\n if (resumeArgsPosition === \"beforePrompt\") {\n args.push(...resumeArgs);\n }\n args.push(...(stdinMode.omitPrompt ? [] : [options.prompt]), ...stdinMode.extraArgs);\n } else {\n args.push(config.promptFlag);\n if (resumeArgsPosition === \"beforePrompt\") {\n args.push(...resumeArgs);\n }\n args.push(options.prompt);\n }\n\n if (options.model && config.modelFlag) {\n let model = config.modelStripProviderPrefix\n ? stripModelNamespace(options.model)\n : options.model;\n if (config.modelTransform) model = config.modelTransform(model);\n args.push(config.modelFlag, model);\n }\n\n if (defaultArgsPosition === \"afterPrompt\") {\n args.push(...config.defaultArgs);\n }\n\n if (mcpArgsPosition === \"afterCommand\") {\n args.push(...mcpArgs);\n }\n\n const mode = resolveModeConfig(config.modes[options.mode ?? \"yolo\"]);\n args.push(...mode.args);\n\n if (options.args && options.args.length > 0) {\n if (resumeArgsPosition === \"afterPrompt\") {\n args.push(...resumeArgs);\n }\n args.push(...options.args);\n } else if (resumeArgsPosition === \"afterPrompt\") {\n args.push(...resumeArgs);\n }\n\n return { args, env: mode.env };\n}\n\nfunction getResumeArgs(\n config: CliSpawnConfig,\n options: Pick<BuildSpawnArgsOptions, \"resumeThreadId\" | \"cwd\">\n): string[] {\n if (!options.resumeThreadId) {\n return [];\n }\n\n if (!config.resume) {\n throw new Error(`Agent \"${config.agentId}\" does not support resumeThreadId.`);\n }\n\n return config.resume.args(options.resumeThreadId, options.cwd ?? process.cwd());\n}\n\nexport function buildSpawnArgs(\n agentId: string,\n options: BuildSpawnArgsOptions\n): BuildSpawnArgsResult {\n const { binaryName, spawnConfig } = resolveCliConfig(agentId);\n const stdinMode = shouldSendPromptViaStdin(spawnConfig, options)\n ? spawnConfig.stdinMode\n : undefined;\n const result = buildCliArgs(spawnConfig, options, stdinMode);\n return { binaryName, args: result.args, env: result.env };\n}\n\nexport async function spawn(\n agentId: string,\n options: SpawnOptions,\n context?: SpawnContext\n): Promise<SpawnResult> {\n return observeAgentSpawn(\n {\n agent: agentId,\n cwd: options.cwd,\n mode: options.mode,\n otelSink: options.otelSink,\n prompt: options.prompt\n },\n () => runSpawn(agentId, options, context)\n );\n}\n\nasync function runSpawn(\n agentId: string,\n options: SpawnOptions,\n context?: SpawnContext\n): Promise<SpawnResult> {\n if (options.signal?.aborted) {\n throw createAbortError();\n }\n\n const { agentId: resolvedId, binaryName, spawnConfig } = resolveCliConfig(agentId);\n\n const stdinMode = shouldSendPromptViaStdin(spawnConfig, options)\n ? spawnConfig.stdinMode\n : undefined;\n\n const { args: spawnArgs, env: modeEnv } = buildCliArgs(spawnConfig, options, stdinMode);\n\n if (context?.dryRun) {\n const rendered = [binaryName, ...spawnArgs].join(\" \");\n context.logger?.dryRun(rendered);\n return { stdout: \"\", stderr: \"\", exitCode: 0 };\n }\n\n const cwd = options.cwd ?? process.cwd();\n const manifest = bridgeSkillsForRun(agentId, cwd, options.skills);\n let logFd: number | undefined;\n\n try {\n const logFilePath = resolveSpawnLogPath(options);\n logFd = logFilePath ? openSpawnLog(logFilePath) : undefined;\n\n const processEnv = modeEnv ? { ...process.env, ...modeEnv } : undefined;\n const argv = [binaryName, ...spawnArgs];\n const execution = resolveSpawnExecution({\n cwd,\n runtimeConfigCwd: options.runtimeConfigCwd,\n env: (processEnv ?? process.env) as Record<string, string>,\n argv,\n tool: resolvedId,\n runtime: {\n runtime: options.runtime,\n runtimeImage: options.runtimeImage,\n runtimeTemplate: options.runtimeTemplate,\n detach: options.detach,\n mountPoeCode: options.mountPoeCode,\n runnerSync: options.runnerSync\n },\n context,\n openSpec: {\n execution: {\n wrapForLogTee: false,\n stdin: stdinMode ? \"pipe\" : \"inherit\",\n stdout: \"pipe\",\n stderr: \"pipe\",\n env: processEnv as Record<string, string> | undefined,\n input: stdinMode ? options.prompt : undefined,\n captureOutput: true,\n activityTimeoutMs: options.activityTimeoutMs,\n onStdout(chunk: string) {\n options.tee?.stdout?.write(chunk);\n appendSpawnLog(logFd, chunk);\n },\n onStderr(chunk: string) {\n options.tee?.stderr?.write(chunk);\n appendSpawnLog(logFd, chunk);\n }\n }\n }\n });\n\n const result = await runPoeCommand({\n factory: execution.factory,\n openSpec: execution.openSpec,\n detach: execution.detach,\n state: execution.state,\n signal: options.signal\n });\n\n if (result.kind === \"detached\") {\n return {\n stdout: \"\",\n stderr: \"\",\n exitCode: 0,\n detached: { jobId: result.jobId, envId: result.envId },\n ...(logFilePath ? { logFile: logFilePath } : {})\n };\n }\n\n const captured = result as typeof result & { stdout?: string; stderr?: string };\n return {\n stdout: captured.stdout ?? \"\",\n stderr: captured.stderr ?? \"\",\n exitCode: result.exitCode,\n ...(logFilePath ? { logFile: logFilePath } : {})\n };\n } finally {\n closeSpawnLog(logFd);\n cleanupSkillsForRun(manifest);\n }\n}\n\nspawn.retry = createSpawnRetry<SpawnOptions, SpawnResult>((service, options) => {\n const handle = spawnStreaming({ ...options, agentId: service });\n return {\n events: handle.events,\n result: handle.done\n };\n});\n\nspawn.parallel = createSpawnParallel<string, SpawnOptions, SpawnResult>((service, options) => ({\n events: (async function* () {})(),\n result: spawn(service, options)\n}));\n\nfunction resolveSpawnLogPath(options: SpawnOptions): string | undefined {\n if (options.logPath) {\n return options.logPath;\n }\n if (!options.logDir || !options.logFileName) {\n return undefined;\n }\n return path.join(options.logDir, options.logFileName);\n}\n\nfunction openSpawnLog(filePath: string): number | undefined {\n try {\n mkdirSync(path.dirname(filePath), { recursive: true });\n return openSync(filePath, \"a\");\n } catch {\n return undefined;\n }\n}\n\nfunction appendSpawnLog(fd: number | undefined, chunk: string): void {\n if (fd === undefined) return;\n try {\n writeSync(fd, chunk);\n } catch {\n // ignore \u2014 logging is best-effort\n }\n}\n\nfunction closeSpawnLog(fd: number | undefined): void {\n if (fd === undefined) return;\n try {\n closeSync(fd);\n } catch {\n // ignore\n }\n}\n", "import { allAgents, resolveAgentId } from \"@poe-code/agent-defs\";\nimport type { SpawnConfig } from \"../types.js\";\nimport { getSpawnConfig } from \"./index.js\";\n\nexport interface ResolvedSpawnConfig {\n agentId: string;\n binaryName?: string;\n spawnConfig?: SpawnConfig;\n}\n\nexport function resolveConfig(agentId: string): ResolvedSpawnConfig {\n const resolvedAgentId = resolveAgentId(agentId);\n if (!resolvedAgentId) {\n throw new Error(`Unknown agent \"${agentId}\".`);\n }\n\n const agentDefinition = allAgents.find((agent) => agent.id === resolvedAgentId);\n if (!agentDefinition) {\n throw new Error(`Unknown agent \"${agentId}\".`);\n }\n\n const spawnConfig = getSpawnConfig(resolvedAgentId);\n const binaryName = agentDefinition.binaryName;\n\n return { agentId: resolvedAgentId, binaryName, spawnConfig };\n}\n", "import { listMcpSupportedAgents } from \"./configs/index.js\";\nimport type { CliSpawnConfig, McpSpawnConfig } from \"./types.js\";\n\nexport function hasMcpServers(servers?: McpSpawnConfig): servers is McpSpawnConfig {\n if (!servers) {\n return false;\n }\n return Object.keys(servers).length > 0;\n}\n\nexport function getMcpArgs(\n config: CliSpawnConfig,\n servers?: McpSpawnConfig\n): string[] {\n if (!hasMcpServers(servers)) {\n return [];\n }\n if (!config.mcpArgs && !config.mcpEnv) {\n throw new Error(formatUnsupportedMcpSpawnMessage(config.agentId));\n }\n if (!config.mcpArgs) {\n return [];\n }\n return config.mcpArgs(servers);\n}\n\nexport function getMcpEnv(\n config: CliSpawnConfig,\n servers?: McpSpawnConfig\n): Record<string, string> {\n if (!hasMcpServers(servers) || !config.mcpEnv) {\n return {};\n }\n return config.mcpEnv(servers);\n}\n\nexport function formatUnsupportedMcpSpawnMessage(agentId: string): string {\n const supported = listMcpSupportedAgents();\n const supportedText = supported.length > 0 ? supported.join(\", \") : \"(none)\";\n return (\n `Agent \"${agentId}\" does not support MCP servers at spawn time.\\n` +\n `Agents with spawn-time MCP support: ${supportedText}`\n );\n}\n", "/**\n * Strips the provider namespace prefix from a model identifier.\n * e.g., \"anthropic/claude-opus-4.6\" \u2192 \"claude-opus-4.6\"\n *\n * CLI binaries (claude, codex, opencode, kimi) only accept bare model IDs.\n * Passing a namespaced model like \"anthropic/claude-opus-4.6\" causes the\n * binary to fail with \"model not found\". This function MUST be called\n * before passing any model to a CLI binary via spawn args.\n */\nexport function stripModelNamespace(model: string): string {\n const slashIndex = model.indexOf(\"/\");\n return slashIndex === -1 ? model : model.slice(slashIndex + 1);\n}\n", "import type { AcpEvent } from \"./acp/types.js\";\nimport type { SpawnHandle } from \"./retry.js\";\n\nexport type SpawnParallelTuple<TService, TOptions> = readonly [\n service: TService,\n options: TOptions\n];\n\nexport type SpawnParallelThunk<TResult extends { exitCode: number }> = (\n signal?: AbortSignal\n) => SpawnHandle<TResult>;\n\nexport type SpawnParallelCall<\n TService,\n TOptions,\n TResult extends { exitCode: number }\n> = SpawnParallelTuple<TService, TOptions> | SpawnParallelThunk<TResult>;\n\nexport type SpawnParallelOptions = {\n maxConcurrent?: number;\n failFast?: boolean;\n signal?: AbortSignal;\n};\n\nexport class SpawnParallelError<TResult extends { exitCode: number }> extends Error {\n readonly index: number;\n readonly result: TResult;\n readonly results: Array<TResult | undefined>;\n\n constructor(index: number, result: TResult, results: Array<TResult | undefined>) {\n super(`spawn.parallel call ${index} failed with exit code ${result.exitCode}.`);\n this.name = \"SpawnParallelError\";\n this.index = index;\n this.result = result;\n this.results = results;\n }\n}\n\nexport function createSpawnParallel<\n TService,\n TOptions extends { signal?: AbortSignal },\n TResult extends { exitCode: number }\n>(\n spawnOnce: (service: TService, options: TOptions) => SpawnHandle<TResult>\n): (\n calls: Array<SpawnParallelCall<TService, TOptions, TResult>>,\n options?: SpawnParallelOptions\n) => Promise<TResult[]> {\n return async function parallel(calls, options = {}) {\n if (calls.length === 0) {\n return [];\n }\n\n const maxConcurrent = normalizeMaxConcurrent(options.maxConcurrent);\n const failFast = options.failFast ?? true;\n const group = new AbortController();\n const results: Array<TResult | undefined> = new Array(calls.length);\n const errors: unknown[] = [];\n let nextIndex = 0;\n let primaryFailure: unknown;\n\n const removeParentAbort = linkParentAbort(options.signal, group, (error) => {\n primaryFailure ??= error;\n });\n\n const worker = async () => {\n while (!primaryFailure) {\n const index = nextIndex;\n nextIndex += 1;\n\n if (index >= calls.length) {\n return;\n }\n\n try {\n const result = await runParallelCall(calls[index], spawnOnce, group.signal);\n results[index] = result;\n\n if (failFast && result.exitCode !== 0) {\n const error = new SpawnParallelError(index, result, results);\n primaryFailure ??= error;\n group.abort(error);\n return;\n }\n } catch (error) {\n if (failFast || group.signal.aborted) {\n primaryFailure ??= error;\n group.abort(error);\n return;\n }\n\n errors.push(error);\n }\n }\n };\n\n try {\n await Promise.allSettled(\n Array.from({ length: Math.min(maxConcurrent, calls.length) }, () => worker())\n );\n } finally {\n removeParentAbort();\n }\n\n if (primaryFailure) {\n throw primaryFailure;\n }\n\n if (errors.length > 0) {\n throw new AggregateError(errors, \"spawn.parallel failed before every call returned a result.\");\n }\n\n return results as TResult[];\n };\n}\n\nasync function runParallelCall<\n TService,\n TOptions extends { signal?: AbortSignal },\n TResult extends { exitCode: number }\n>(\n call: SpawnParallelCall<TService, TOptions, TResult>,\n spawnOnce: (service: TService, options: TOptions) => SpawnHandle<TResult>,\n signal: AbortSignal\n): Promise<TResult> {\n throwIfAborted(signal);\n\n if (typeof call === \"function\") {\n const handle = call(signal);\n const [result] = await Promise.all([handle.result, drainEvents(handle.events)]);\n return result;\n }\n\n if (!isSpawnTuple(call)) {\n throw new Error(\"spawn.parallel calls must be [service, options] tuples or spawn thunks.\");\n }\n\n const { options, cleanup } = withAbortSignal(call[1], signal);\n try {\n const handle = spawnOnce(call[0], options);\n const [result] = await Promise.all([handle.result, drainEvents(handle.events)]);\n return result;\n } finally {\n cleanup();\n }\n}\n\nasync function drainEvents(events: AsyncIterable<AcpEvent>): Promise<void> {\n for await (const ignoredEvent of events) {\n void ignoredEvent;\n // Drain the stream so streaming providers can complete while parallel returns results only.\n }\n}\n\nfunction normalizeMaxConcurrent(maxConcurrent: number | undefined): number {\n const value = maxConcurrent ?? 4;\n if (!Number.isInteger(value) || value < 1) {\n throw new Error(\"spawn.parallel maxConcurrent must be an integer greater than or equal to 1.\");\n }\n return value;\n}\n\nfunction isSpawnTuple<TService, TOptions>(\n call: SpawnParallelCall<TService, TOptions, { exitCode: number }>\n): call is SpawnParallelTuple<TService, TOptions> {\n return Array.isArray(call) && call.length === 2;\n}\n\nfunction withAbortSignal<TOptions extends { signal?: AbortSignal }>(\n options: TOptions,\n signal: AbortSignal\n): { options: TOptions; cleanup(): void } {\n if (!options.signal) {\n return {\n options: { ...options, signal },\n cleanup() {}\n };\n }\n\n const controller = new AbortController();\n const abort = () => {\n controller.abort();\n };\n\n if (signal.aborted || options.signal.aborted) {\n controller.abort();\n } else {\n signal.addEventListener(\"abort\", abort, { once: true });\n options.signal.addEventListener(\"abort\", abort, { once: true });\n }\n\n return {\n options: { ...options, signal: controller.signal },\n cleanup() {\n signal.removeEventListener(\"abort\", abort);\n options.signal?.removeEventListener(\"abort\", abort);\n }\n };\n}\n\nfunction linkParentAbort(\n parentSignal: AbortSignal | undefined,\n group: AbortController,\n setFailure: (error: Error) => void\n): () => void {\n if (!parentSignal) {\n return () => {};\n }\n\n const abort = () => {\n const error = createAbortError();\n setFailure(error);\n group.abort(error);\n };\n\n if (parentSignal.aborted) {\n abort();\n return () => {};\n }\n\n parentSignal.addEventListener(\"abort\", abort, { once: true });\n return () => parentSignal.removeEventListener(\"abort\", abort);\n}\n\nfunction throwIfAborted(signal: AbortSignal): void {\n if (signal.aborted) {\n throw createAbortError();\n }\n}\n\nfunction createAbortError(): Error {\n const error = new Error(\"Agent spawn parallel aborted\");\n error.name = \"AbortError\";\n return error;\n}\n", "import type { CliSpawnConfig } from \"./types.js\";\n\nexport function shouldSendPromptViaStdin(\n config: CliSpawnConfig,\n options: { prompt: string; useStdin?: boolean }\n): boolean {\n return !!config.stdinMode && (options.useStdin === true || options.prompt.includes(\"\\0\"));\n}\n", "import type { AcpEvent } from \"./acp/types.js\";\n\nexport type SpawnRetryOptions<TResult extends { exitCode: number }> = {\n maxAttempts: number;\n backoffMs: number;\n isRetryable?: (result: TResult) => boolean;\n};\n\nexport type SpawnHandle<TResult> = {\n events: AsyncIterable<AcpEvent>;\n result: Promise<TResult>;\n};\n\nexport type SpawnRetryFunction<\n TOptions extends { signal?: AbortSignal },\n TResult extends { exitCode: number }\n> = (\n service: string,\n options: TOptions,\n retryOptions: SpawnRetryOptions<TResult>\n) => SpawnHandle<TResult>;\n\ntype EventQueue<T> = AsyncIterable<T> & {\n push(value: T): void;\n close(): void;\n fail(error: unknown): void;\n};\n\nconst retryableExitCodes = new Set([1, 124, 125, 137]);\nconst maxBackoffMs = 30_000;\n\nexport function createSpawnRetry<\n TOptions extends { signal?: AbortSignal },\n TResult extends { exitCode: number }\n>(\n spawnOnce: (service: string, options: TOptions) => SpawnHandle<TResult>\n): SpawnRetryFunction<TOptions, TResult> {\n return (service, options, retryOptions) => {\n const normalizedRetryOptions = normalizeRetryOptions(retryOptions);\n const queue = createEventQueue<AcpEvent>();\n const result = runRetryingSpawn({\n service,\n options,\n retryOptions: normalizedRetryOptions,\n spawnOnce,\n emit: queue.push\n })\n .then((value) => {\n queue.close();\n return value;\n })\n .catch((error: unknown) => {\n queue.fail(error);\n throw error;\n });\n\n return {\n events: queue,\n result\n };\n };\n}\n\nexport function defaultIsRetryable(result: { exitCode: number }): boolean {\n return retryableExitCodes.has(result.exitCode);\n}\n\nexport function calculateBackoffMs(baseBackoffMs: number, completedAttempt: number): number {\n return Math.min(baseBackoffMs * 2 ** (completedAttempt - 1), maxBackoffMs);\n}\n\nfunction normalizeRetryOptions<TResult extends { exitCode: number }>(\n retryOptions: SpawnRetryOptions<TResult>\n): Required<SpawnRetryOptions<TResult>> {\n if (!Number.isInteger(retryOptions.maxAttempts) || retryOptions.maxAttempts < 1) {\n throw new Error(\"spawn.retry maxAttempts must be an integer greater than or equal to 1.\");\n }\n\n if (!Number.isFinite(retryOptions.backoffMs) || retryOptions.backoffMs < 0) {\n throw new Error(\"spawn.retry backoffMs must be a non-negative finite number.\");\n }\n\n return {\n maxAttempts: retryOptions.maxAttempts,\n backoffMs: retryOptions.backoffMs,\n isRetryable: retryOptions.isRetryable ?? defaultIsRetryable\n };\n}\n\nasync function runRetryingSpawn<\n TOptions extends { signal?: AbortSignal },\n TResult extends { exitCode: number }\n>(input: {\n service: string;\n options: TOptions;\n retryOptions: Required<SpawnRetryOptions<TResult>>;\n spawnOnce: (service: string, options: TOptions) => SpawnHandle<TResult>;\n emit: (event: AcpEvent) => void;\n}): Promise<TResult> {\n for (let attempt = 1; attempt <= input.retryOptions.maxAttempts; attempt += 1) {\n throwIfAborted(input.options.signal);\n\n const handle = input.spawnOnce(input.service, input.options);\n const events = forwardAttemptEvents(handle.events, attempt, input.emit);\n const result = await handle.result;\n await events;\n\n const isLastAttempt = attempt >= input.retryOptions.maxAttempts;\n if (result.exitCode === 0 || isLastAttempt || !input.retryOptions.isRetryable(result)) {\n return result;\n }\n\n const delayMs = calculateBackoffMs(input.retryOptions.backoffMs, attempt);\n input.emit(createWaitEvent(attempt, delayMs));\n await sleep(delayMs, input.options.signal);\n }\n\n throw new Error(\"spawn.retry reached an unreachable retry state.\");\n}\n\nasync function forwardAttemptEvents(\n events: AsyncIterable<AcpEvent>,\n attempt: number,\n emit: (event: AcpEvent) => void\n): Promise<void> {\n for await (const event of events) {\n emit(prefixEvent(event, attempt));\n }\n}\n\nfunction prefixEvent(event: AcpEvent, attempt: number): AcpEvent {\n const prefix = `attempt: ${attempt}`;\n\n if (event.event === \"agent_message\" || event.event === \"reasoning\") {\n return { ...event, text: `${prefix} ${event.text}` };\n }\n\n if (event.event === \"error\") {\n return { ...event, message: `${prefix} ${event.message}` };\n }\n\n if (event.event === \"tool_start\") {\n return { ...event, title: `${prefix} ${event.title}` };\n }\n\n if (event.event === \"tool_complete\") {\n return { ...event, path: `${prefix} ${event.path}` };\n }\n\n return {\n ...event,\n _meta: {\n ...(typeof event._meta === \"object\" && event._meta !== null ? event._meta : {}),\n attempt\n }\n };\n}\n\nfunction createWaitEvent(attempt: number, delayMs: number): AcpEvent {\n return {\n event: \"agent_message\",\n text: `attempt: ${attempt} wait ${delayMs}ms before retry`\n };\n}\n\nfunction sleep(delayMs: number, signal: AbortSignal | undefined): Promise<void> {\n throwIfAborted(signal);\n\n return new Promise((resolve, reject) => {\n const timeout = setTimeout(() => {\n signal?.removeEventListener(\"abort\", onAbort);\n resolve();\n }, delayMs);\n\n const onAbort = () => {\n clearTimeout(timeout);\n reject(createAbortError());\n };\n\n signal?.addEventListener(\"abort\", onAbort, { once: true });\n });\n}\n\nfunction throwIfAborted(signal: AbortSignal | undefined): void {\n if (signal?.aborted) {\n throw createAbortError();\n }\n}\n\nfunction createAbortError(): Error {\n const error = new Error(\"Agent spawn retry aborted\");\n error.name = \"AbortError\";\n return error;\n}\n\nfunction createEventQueue<T>(): EventQueue<T> {\n const values: T[] = [];\n const waiters: Array<{\n resolve(value: IteratorResult<T>): void;\n reject(error: unknown): void;\n }> = [];\n let closed = false;\n let failure: unknown;\n\n const next = (): Promise<IteratorResult<T>> => {\n if (values.length > 0) {\n return Promise.resolve({ value: values.shift() as T, done: false });\n }\n\n if (failure !== undefined) {\n return Promise.reject(failure);\n }\n\n if (closed) {\n return Promise.resolve({ value: undefined, done: true });\n }\n\n return new Promise((resolve, reject) => {\n waiters.push({ resolve, reject });\n });\n };\n\n return {\n push(value) {\n if (closed || failure !== undefined) {\n return;\n }\n\n const waiter = waiters.shift();\n if (waiter) {\n waiter.resolve({ value, done: false });\n return;\n }\n\n values.push(value);\n },\n close() {\n if (closed || failure !== undefined) {\n return;\n }\n\n closed = true;\n for (const waiter of waiters.splice(0)) {\n waiter.resolve({ value: undefined, done: true });\n }\n },\n fail(error) {\n if (closed || failure !== undefined) {\n return;\n }\n\n failure = error;\n for (const waiter of waiters.splice(0)) {\n waiter.reject(error);\n }\n },\n async *[Symbol.asyncIterator]() {\n while (true) {\n const item = await next();\n if (item.done) {\n return;\n }\n yield item.value;\n }\n }\n };\n}\n", "import crypto from \"node:crypto\";\nimport os from \"node:os\";\nimport {\n bridgeActiveSkills,\n cleanupBridgedSkills,\n type BridgeManifest\n} from \"@poe-code/agent-skill-config\";\nimport { logger } from \"@poe-code/design-system\";\n\nexport function bridgeSkillsForRun(\n agentId: string,\n cwd: string,\n skills: string[] | undefined\n): BridgeManifest | undefined {\n if (!skills || skills.length === 0) {\n return undefined;\n }\n\n const manifest = bridgeActiveSkills(agentId, cwd, skills, os.homedir(), crypto.randomUUID());\n for (const warning of manifest.warnings) {\n logger.warn(warning.message);\n }\n return manifest;\n}\n\nexport function cleanupSkillsForRun(manifest: BridgeManifest | undefined): void {\n if (!manifest) {\n return;\n }\n cleanupBridgedSkills(manifest);\n}\n", "import os from \"node:os\";\nimport path from \"node:path\";\nimport { resolveAgentId } from \"@poe-code/agent-defs\";\n\nexport interface AgentSkillConfig {\n globalSkillDir: string;\n localSkillDir: string;\n}\n\nexport type SkillScope = \"global\" | \"local\";\n\nconst agentSkillConfigs: Record<string, AgentSkillConfig> = {\n \"claude-code\": {\n globalSkillDir: \"~/.claude/skills\",\n localSkillDir: \".claude/skills\"\n },\n codex: {\n globalSkillDir: \"~/.codex/skills\",\n localSkillDir: \".codex/skills\"\n },\n opencode: {\n globalSkillDir: \"~/.config/opencode/skills\",\n localSkillDir: \".opencode/skills\"\n },\n goose: {\n globalSkillDir: \"~/.agents/skills\",\n localSkillDir: \".agents/skills\"\n }\n};\n\nexport const supportedAgents = Object.keys(agentSkillConfigs) as readonly string[];\n\nexport type AgentSupportStatus = \"supported\" | \"unsupported\" | \"unknown\";\n\nexport interface AgentSupportResult {\n status: AgentSupportStatus;\n input: string;\n id?: string;\n config?: AgentSkillConfig;\n}\n\nexport function resolveAgentSupport(\n input: string,\n registry: Record<string, AgentSkillConfig> = agentSkillConfigs\n): AgentSupportResult {\n const resolvedId = resolveAgentId(input);\n if (!resolvedId) {\n return { status: \"unknown\", input };\n }\n\n const config = registry[resolvedId];\n if (!config) {\n return { status: \"unsupported\", input, id: resolvedId };\n }\n\n return { status: \"supported\", input, id: resolvedId, config };\n}\n\nexport function getAgentConfig(agentId: string): AgentSkillConfig | undefined {\n const support = resolveAgentSupport(agentId);\n return support.status === \"supported\" ? support.config : undefined;\n}\n\nfunction expandHome(targetPath: string, homeDir: string = os.homedir()): string {\n if (!targetPath?.startsWith(\"~\")) {\n return targetPath;\n }\n\n if (targetPath === \"~\") {\n return homeDir;\n }\n\n // Handle ~./ -> ~/.\n if (targetPath.startsWith(\"~./\")) {\n targetPath = `~/.${targetPath.slice(3)}`;\n }\n\n let remainder = targetPath.slice(1);\n if (remainder.startsWith(\"/\") || remainder.startsWith(\"\\\\\")) {\n remainder = remainder.slice(1);\n } else if (remainder.startsWith(\".\")) {\n remainder = remainder.slice(1);\n if (remainder.startsWith(\"/\") || remainder.startsWith(\"\\\\\")) {\n remainder = remainder.slice(1);\n }\n }\n\n return remainder.length === 0 ? homeDir : path.join(homeDir, remainder);\n}\n\nexport function resolveSkillDir(\n config: AgentSkillConfig,\n scope: SkillScope,\n cwd: string,\n homeDir?: string\n): string {\n if (scope === \"global\") {\n return path.resolve(expandHome(config.globalSkillDir, homeDir));\n }\n\n return path.resolve(cwd, config.localSkillDir);\n}\n", "import { readFile, stat } from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\nimport type { TemplateLoader } from \"@poe-code/config-mutations\";\n\nconst TEMPLATE_IDS = [\"poe-generate.md\", \"terminal-pilot.md\"] as const;\ntype TemplateId = (typeof TEMPLATE_IDS)[number];\n\nconst cache = new Map<TemplateId, string>();\n\nasync function pathExists(target: string): Promise<boolean> {\n try {\n await stat(target);\n return true;\n } catch (error) {\n if (error && typeof error === \"object\" && \"code\" in error && error.code === \"ENOENT\") {\n return false;\n }\n throw error;\n }\n}\n\nasync function findPackageRoot(entryFilePath: string): Promise<string> {\n let current = path.dirname(entryFilePath);\n while (true) {\n if (await pathExists(path.join(current, \"package.json\"))) {\n return current;\n }\n const parent = path.dirname(current);\n if (parent === current) {\n throw new Error(\"Unable to locate package root for agent-skill-config templates.\");\n }\n current = parent;\n }\n}\n\nasync function resolveTemplatePath(templateId: TemplateId): Promise<string> {\n const packageRoot = await findPackageRoot(fileURLToPath(import.meta.url));\n const candidates = [\n path.join(packageRoot, \"src\", \"templates\", templateId),\n path.join(packageRoot, \"dist\", \"templates\", templateId),\n path.join(packageRoot, \"dist\", \"templates\", \"skill\", templateId)\n ];\n\n for (const candidate of candidates) {\n if (await pathExists(candidate)) {\n return candidate;\n }\n }\n\n throw new Error(`Template not found: ${templateId}`);\n}\n\nfunction isKnownTemplate(templateId: string): templateId is TemplateId {\n return (TEMPLATE_IDS as readonly string[]).includes(templateId);\n}\n\nexport async function loadTemplate(templateId: string): Promise<string> {\n if (!isKnownTemplate(templateId)) {\n throw new Error(`Template not found: ${templateId}`);\n }\n\n const cached = cache.get(templateId);\n if (cached !== undefined) {\n return cached;\n }\n\n const resolved = await resolveTemplatePath(templateId);\n const content = await readFile(resolved, \"utf8\");\n cache.set(templateId, content);\n return content;\n}\n\nexport function createTemplateLoader(): TemplateLoader {\n return loadTemplate;\n}\n", "import { statSync } from \"node:fs\";\nimport path from \"node:path\";\nimport { getAgentConfig, resolveAgentSupport, resolveSkillDir } from \"./configs.js\";\n\nexport interface SkillSource {\n kind: \"resolved\";\n ref: string;\n name: string;\n sourceAgentId?: string;\n sourcePath: string;\n scope: \"project\" | \"user\";\n}\n\nexport type SkillResolutionFailure =\n | { kind: \"malformed\"; ref: string }\n | { kind: \"unknown-agent\"; ref: string; agentInput: string }\n | { kind: \"not-found\"; ref: string; searchedPaths: string[] };\n\nexport type SkillResolution = SkillSource | SkillResolutionFailure;\n\ninterface SearchTier {\n scope: \"project\" | \"user\";\n sourcePath: string;\n}\n\nfunction isMalformedSegment(segment: string): boolean {\n return segment.length === 0 || segment !== segment.trim();\n}\n\nfunction isDirectory(targetPath: string): boolean {\n try {\n return statSync(targetPath).isDirectory();\n } catch {\n return false;\n }\n}\n\nfunction findSkill(\n ref: string,\n name: string,\n tiers: SearchTier[],\n sourceAgentId?: string\n): SkillResolution {\n for (const tier of tiers) {\n if (isDirectory(tier.sourcePath)) {\n return {\n kind: \"resolved\",\n ref,\n name,\n ...(sourceAgentId ? { sourceAgentId } : {}),\n sourcePath: tier.sourcePath,\n scope: tier.scope\n };\n }\n }\n\n return {\n kind: \"not-found\",\n ref,\n searchedPaths: tiers.map((tier) => tier.sourcePath)\n };\n}\n\nexport function resolveSkillReference(ref: string, cwd: string, homeDir: string): SkillResolution {\n const slashIndex = ref.indexOf(\"/\");\n const hasPrefix = slashIndex !== -1;\n\n if (\n ref.length === 0 ||\n ref !== ref.trim() ||\n (hasPrefix && ref.indexOf(\"/\", slashIndex + 1) !== -1)\n ) {\n return { kind: \"malformed\", ref };\n }\n\n if (!hasPrefix) {\n if (isMalformedSegment(ref)) {\n return { kind: \"malformed\", ref };\n }\n\n const tiers: SearchTier[] = [\n {\n scope: \"project\",\n sourcePath: path.resolve(cwd, \".poe-code/skills\", ref)\n },\n {\n scope: \"user\",\n sourcePath: path.resolve(homeDir, \".poe-code/skills\", ref)\n }\n ];\n\n return findSkill(ref, ref, tiers);\n }\n\n const agentInput = ref.slice(0, slashIndex);\n const name = ref.slice(slashIndex + 1);\n if (isMalformedSegment(agentInput) || isMalformedSegment(name)) {\n return { kind: \"malformed\", ref };\n }\n\n const support = resolveAgentSupport(agentInput);\n if (support.status !== \"supported\" || !support.id) {\n return { kind: \"unknown-agent\", ref, agentInput };\n }\n\n const config = getAgentConfig(support.id);\n if (!config) {\n return { kind: \"unknown-agent\", ref, agentInput };\n }\n\n const tiers: SearchTier[] = [\n {\n scope: \"project\",\n sourcePath: path.resolve(resolveSkillDir(config, \"local\", cwd), name)\n },\n {\n scope: \"user\",\n sourcePath: path.resolve(resolveSkillDir(config, \"global\", cwd, homeDir), name)\n }\n ];\n\n return findSkill(ref, name, tiers, support.id);\n}\n", "import { execFileSync } from \"node:child_process\";\nimport * as fs from \"node:fs\";\nimport path from \"node:path\";\n\nexport type GitDirRunner = (cwd: string) => string | undefined;\n\nconst markerPrefix = \"# poe-code-spawn-skills:\";\n\nfunction defaultGitDirRunner(cwd: string): string | undefined {\n try {\n return execFileSync(\"git\", [\"rev-parse\", \"--git-dir\"], {\n cwd,\n encoding: \"utf8\",\n stdio: [\"ignore\", \"pipe\", \"ignore\"]\n }).trim();\n } catch {\n return undefined;\n }\n}\n\nlet gitDirRunner: GitDirRunner = defaultGitDirRunner;\n\nexport function setGitDirRunnerForTest(runner: GitDirRunner): () => void {\n const previous = gitDirRunner;\n gitDirRunner = runner;\n return () => {\n gitDirRunner = previous;\n };\n}\n\nfunction resolveExcludePath(cwd: string): string | undefined {\n const gitDir = gitDirRunner(cwd);\n if (gitDir === undefined || gitDir.length === 0) {\n return undefined;\n }\n\n return path.join(path.isAbsolute(gitDir) ? gitDir : path.resolve(cwd, gitDir), \"info/exclude\");\n}\n\nfunction markers(runId: string): { begin: string; end: string } {\n return {\n begin: `${markerPrefix}${runId} begin`,\n end: `${markerPrefix}${runId} end`\n };\n}\n\nfunction readExcludeFile(excludePath: string): string | undefined {\n try {\n return fs.readFileSync(excludePath, \"utf8\");\n } catch (error) {\n if (isNodeError(error) && error.code === \"ENOENT\") {\n return undefined;\n }\n throw error;\n }\n}\n\nfunction isNodeError(error: unknown): error is NodeJS.ErrnoException {\n return error instanceof Error && \"code\" in error;\n}\n\nfunction removeBlock(content: string, runId: string): string {\n const { begin, end } = markers(runId);\n const lines = content.split(\"\\n\");\n const result: string[] = [];\n\n for (let index = 0; index < lines.length; index += 1) {\n if (lines[index] === begin) {\n const endIndex = lines.indexOf(end, index + 1);\n if (endIndex !== -1) {\n index = endIndex;\n continue;\n }\n }\n\n result.push(lines[index]);\n }\n\n return result.join(\"\\n\");\n}\n\nfunction appendBlock(content: string | undefined, runId: string, entries: string[]): string {\n const { begin, end } = markers(runId);\n const existing = content ?? \"\";\n const prefix = existing.length === 0 || existing.endsWith(\"\\n\") ? existing : `${existing}\\n`;\n return `${prefix}${[begin, ...entries, end, \"\"].join(\"\\n\")}`;\n}\n\nexport function appendExcludeBlock(cwd: string, runId: string, entries: string[]): void {\n const excludePath = resolveExcludePath(cwd);\n if (excludePath === undefined) {\n return;\n }\n\n fs.mkdirSync(path.dirname(excludePath), { recursive: true });\n const content = readExcludeFile(excludePath);\n fs.writeFileSync(excludePath, appendBlock(content, runId, entries), \"utf8\");\n}\n\nexport function removeExcludeBlock(cwd: string, runId: string): void {\n const excludePath = resolveExcludePath(cwd);\n if (excludePath === undefined) {\n return;\n }\n\n const content = readExcludeFile(excludePath);\n if (content === undefined) {\n return;\n }\n\n fs.writeFileSync(excludePath, removeBlock(content, runId), \"utf8\");\n}\n", "import * as fs from \"node:fs\";\nimport path from \"node:path\";\nimport {\n getAgentConfig,\n resolveAgentSupport,\n resolveSkillDir,\n supportedAgents\n} from \"./configs.js\";\nimport { appendExcludeBlock, removeExcludeBlock } from \"./git-exclude.js\";\nimport { resolveSkillReference, type SkillResolutionFailure } from \"./resolve-skill-reference.js\";\n\nexport interface BridgeEntry {\n ref: string;\n sourcePath: string;\n targetPath: string;\n createdParents: string[];\n}\n\nexport type BridgeWarningKind =\n | \"local-collision\"\n | \"global-collision\"\n | \"self-reference\"\n | \"intra-batch-collision\";\n\nexport interface BridgeWarning {\n kind: BridgeWarningKind;\n ref: string;\n sourcePath: string;\n conflictingPath: string;\n message: string;\n}\n\nexport interface BridgeManifest {\n spawnAgentId: string;\n cwd: string;\n runId: string;\n entries: BridgeEntry[];\n warnings: BridgeWarning[];\n}\n\ntype ResolvedSkill = Extract<ReturnType<typeof resolveSkillReference>, { kind: \"resolved\" }>;\n\ninterface ResolvedBridgeSource {\n ref: string;\n source: ResolvedSkill;\n targetPath: string;\n globalTargetPath: string;\n}\n\nfunction isNodeError(error: unknown): error is NodeJS.ErrnoException {\n return error instanceof Error && \"code\" in error;\n}\n\nfunction pathExists(targetPath: string): boolean {\n try {\n fs.statSync(targetPath);\n return true;\n } catch (error) {\n if (isNodeError(error) && error.code === \"ENOENT\") {\n return false;\n }\n throw error;\n }\n}\n\nfunction isDirectory(targetPath: string): boolean {\n try {\n return fs.statSync(targetPath).isDirectory();\n } catch (error) {\n if (isNodeError(error) && error.code === \"ENOENT\") {\n return false;\n }\n throw error;\n }\n}\n\nfunction formatResolutionFailureError(failures: SkillResolutionFailure[]): Error {\n const malformed = failures.filter((failure) => failure.kind === \"malformed\");\n const unknownAgent = failures.filter((failure) => failure.kind === \"unknown-agent\");\n const notFound = failures.filter((failure) => failure.kind === \"not-found\");\n const lines = [\n `Failed to bridge active skills: ${failures.length} skill reference(s) could not be resolved.`\n ];\n\n if (malformed.length > 0) {\n lines.push(\"\", \"Malformed skill references:\");\n for (const failure of malformed) {\n lines.push(`- ${failure.ref}`);\n }\n lines.push('Expected syntax: \"<name>\" or \"<agentId>/<name>\".');\n }\n\n if (unknownAgent.length > 0) {\n lines.push(\"\", \"Unknown agent references:\");\n for (const failure of unknownAgent) {\n lines.push(`- ${failure.ref} (agent token: ${failure.agentInput})`);\n }\n lines.push(`Supported agents: ${supportedAgents.join(\", \")}.`);\n }\n\n if (notFound.length > 0) {\n lines.push(\"\", \"Not found skill references.\");\n for (const failure of notFound) {\n lines.push(`- ${failure.ref}`);\n lines.push(\" searched paths:\");\n for (const searchedPath of failure.searchedPaths) {\n lines.push(` - ${searchedPath}`);\n }\n }\n }\n\n return new Error(lines.join(\"\\n\"));\n}\n\nfunction copyDirectory(sourcePath: string, targetPath: string): void {\n fs.mkdirSync(targetPath, { recursive: true });\n for (const dirent of fs.readdirSync(sourcePath, { withFileTypes: true })) {\n const childSource = path.join(sourcePath, dirent.name);\n const childTarget = path.join(targetPath, dirent.name);\n\n if (dirent.isDirectory()) {\n copyDirectory(childSource, childTarget);\n continue;\n }\n\n if (dirent.isFile()) {\n fs.copyFileSync(childSource, childTarget);\n }\n }\n}\n\nfunction collectMissingParents(targetPath: string): string[] {\n const parents: string[] = [];\n let current = path.dirname(targetPath);\n\n while (!pathExists(current)) {\n parents.push(current);\n const parent = path.dirname(current);\n if (parent === current) {\n break;\n }\n current = parent;\n }\n\n return parents.reverse();\n}\n\nfunction removeDirectoryIfEmpty(targetPath: string): void {\n try {\n fs.rmdirSync(targetPath);\n } catch (error) {\n if (\n isNodeError(error) &&\n (error.code === \"ENOENT\" || error.code === \"ENOTEMPTY\" || error.code === \"EEXIST\")\n ) {\n return;\n }\n throw error;\n }\n}\n\nfunction removeTarget(targetPath: string): void {\n fs.rmSync(targetPath, { recursive: true, force: true });\n}\n\nfunction toCwdRelative(cwd: string, targetPath: string): string {\n return path.relative(cwd, targetPath);\n}\n\nfunction warning(\n kind: BridgeWarningKind,\n ref: string,\n sourcePath: string,\n conflictingPath: string\n): BridgeWarning {\n const messages: Record<BridgeWarningKind, string> = {\n \"intra-batch-collision\": `Skipping ${ref}: an earlier bridged skill already targets ${conflictingPath}.`,\n \"local-collision\": `Skipping ${ref}: local skill already exists at ${conflictingPath}.`,\n \"global-collision\": `Skipping ${ref}: global skill already exists at ${conflictingPath}.`,\n \"self-reference\": `Skipping ${ref}: spawning agent already sees this native skill at ${conflictingPath}.`\n };\n\n return {\n kind,\n ref,\n sourcePath,\n conflictingPath,\n message: messages[kind]\n };\n}\n\nexport function bridgeActiveSkills(\n spawnAgentId: string,\n cwd: string,\n refs: string[],\n homeDir: string,\n runId: string\n): BridgeManifest {\n const spawnConfig = getAgentConfig(spawnAgentId);\n const spawnSupport = resolveAgentSupport(spawnAgentId);\n if (!spawnConfig || spawnSupport.status !== \"supported\" || !spawnSupport.id) {\n throw new Error(\n `Unsupported spawn agent \"${spawnAgentId}\". Supported agents: ${supportedAgents.join(\", \")}.`\n );\n }\n\n const targetDir = resolveSkillDir(spawnConfig, \"local\", cwd);\n const globalTargetDir = resolveSkillDir(spawnConfig, \"global\", cwd, homeDir);\n const resolutions = refs.map((ref) => resolveSkillReference(ref, cwd, homeDir));\n const failures = resolutions.filter(\n (resolution): resolution is SkillResolutionFailure => resolution.kind !== \"resolved\"\n );\n if (failures.length > 0) {\n throw formatResolutionFailureError(failures);\n }\n\n const sources: ResolvedBridgeSource[] = resolutions.map((source, index) => ({\n ref: refs[index]!,\n source: source as ResolvedSkill,\n targetPath: path.resolve(targetDir, (source as ResolvedSkill).name),\n globalTargetPath: path.resolve(globalTargetDir, (source as ResolvedSkill).name)\n }));\n\n const entries: BridgeEntry[] = [];\n const warnings: BridgeWarning[] = [];\n const claimedTargets = new Set<string>();\n\n for (const item of sources) {\n if (claimedTargets.has(item.targetPath)) {\n warnings.push(\n warning(\"intra-batch-collision\", item.ref, item.source.sourcePath, item.targetPath)\n );\n continue;\n }\n\n if (item.source.sourceAgentId === spawnSupport.id) {\n warnings.push(\n warning(\"self-reference\", item.ref, item.source.sourcePath, item.source.sourcePath)\n );\n continue;\n }\n\n if (pathExists(item.targetPath)) {\n warnings.push(warning(\"local-collision\", item.ref, item.source.sourcePath, item.targetPath));\n continue;\n }\n\n if (isDirectory(item.globalTargetPath)) {\n warnings.push(\n warning(\"global-collision\", item.ref, item.source.sourcePath, item.globalTargetPath)\n );\n continue;\n }\n\n const createdParents = collectMissingParents(item.targetPath);\n fs.mkdirSync(path.dirname(item.targetPath), { recursive: true });\n copyDirectory(item.source.sourcePath, item.targetPath);\n claimedTargets.add(item.targetPath);\n entries.push({\n ref: item.ref,\n sourcePath: item.source.sourcePath,\n targetPath: item.targetPath,\n createdParents\n });\n }\n\n if (entries.length > 0) {\n appendExcludeBlock(\n cwd,\n runId,\n entries.map((entry) => toCwdRelative(cwd, entry.targetPath))\n );\n }\n\n return {\n spawnAgentId,\n cwd,\n runId,\n entries,\n warnings\n };\n}\n\nexport function cleanupBridgedSkills(manifest: BridgeManifest): void {\n for (const entry of manifest.entries) {\n removeTarget(entry.targetPath);\n for (const parent of [...entry.createdParents].reverse()) {\n removeDirectoryIfEmpty(parent);\n }\n }\n\n removeExcludeBlock(manifest.cwd, manifest.runId);\n}\n", "export function truncate(text: string, maxLength: number): string {\n if (text.length <= maxLength) return text;\n if (maxLength <= 3) return text.slice(0, maxLength);\n return `${text.slice(0, maxLength - 3)}...`;\n}\n\nexport function isNonEmptyString(value: unknown): value is string {\n return typeof value === \"string\" && value.length > 0;\n}\n\nexport function extractThreadId(value: unknown): string | undefined {\n if (!value || typeof value !== \"object\") return;\n\n const obj = value as Record<string, unknown>;\n const maybeThreadId =\n (isNonEmptyString(obj.thread_id) && obj.thread_id) ||\n (isNonEmptyString(obj.threadId) && obj.threadId) ||\n (isNonEmptyString(obj.threadID) && obj.threadID) ||\n (isNonEmptyString(obj.session_id) && obj.session_id) ||\n (isNonEmptyString(obj.sessionId) && obj.sessionId) ||\n (isNonEmptyString(obj.sessionID) && obj.sessionID);\n\n return maybeThreadId || undefined;\n}\n", "import type { AcpEvent } from \"../acp/types.js\";\nimport { truncate, isNonEmptyString, extractThreadId } from \"./utils.js\";\n\nexport const TOOL_KIND_MAP: Record<string, string> = {\n Read: \"read\",\n Write: \"edit\",\n Edit: \"edit\",\n NotebookEdit: \"edit\",\n Bash: \"exec\",\n Glob: \"search\",\n Grep: \"search\",\n Task: \"think\"\n};\n\ntype ClaudeEvent = {\n type?: unknown;\n message?: unknown;\n thread_id?: unknown;\n threadId?: unknown;\n threadID?: unknown;\n session_id?: unknown;\n sessionId?: unknown;\n sessionID?: unknown;\n input_tokens?: unknown;\n output_tokens?: unknown;\n num_input_tokens?: unknown;\n num_output_tokens?: unknown;\n cost_usd?: unknown;\n usage?: unknown;\n};\n\ntype ClaudeMessage = {\n content?: unknown;\n};\n\ntype ClaudeContentBlock = {\n type?: unknown;\n text?: unknown;\n id?: unknown;\n name?: unknown;\n input?: unknown;\n tool_use_id?: unknown;\n content?: unknown;\n};\n\nconst TITLE_KEYS: Record<string, string[]> = {\n Bash: [\"command\"],\n Read: [\"file_path\"],\n Write: [\"file_path\"],\n Edit: [\"file_path\"],\n NotebookEdit: [\"notebook_path\"],\n Glob: [\"pattern\"],\n Grep: [\"pattern\"],\n Task: [\"description\", \"prompt\"]\n};\n\nfunction extractTitle(name: string, input: unknown): string {\n const keys = TITLE_KEYS[name];\n if (keys && input && typeof input === \"object\") {\n const obj = input as Record<string, unknown>;\n for (const key of keys) {\n const value = obj[key];\n if (typeof value === \"string\" && value.length > 0) {\n return truncate(value, 80);\n }\n }\n }\n return name;\n}\n\nexport async function* adaptClaude(\n lines: AsyncIterable<string>\n): AsyncGenerator<AcpEvent> {\n const toolKindsById = new Map<string, string>();\n let emittedSessionStart = false;\n\n for await (const rawLine of lines) {\n const line = rawLine.trim();\n if (!line) continue;\n\n // Claude Code can emit non-JSON informational lines (especially in verbose mode).\n // Ignore lines that don't look like JSON to avoid polluting output with adapter errors.\n const firstChar = line[0];\n if (firstChar !== \"{\" && firstChar !== \"[\") {\n continue;\n }\n\n let event: ClaudeEvent;\n try {\n event = JSON.parse(line) as ClaudeEvent;\n } catch (error) {\n const stack = error instanceof Error ? error.stack : undefined;\n yield {\n event: \"error\",\n message: `[adaptClaude] Malformed JSON line: ${truncate(line, 200)}`,\n stack\n };\n continue;\n }\n\n const eventType = event.type;\n if (!isNonEmptyString(eventType)) continue;\n\n if (!emittedSessionStart) {\n const threadId = extractThreadId(event);\n emittedSessionStart = true;\n yield { event: \"session_start\", threadId };\n }\n\n if (eventType === \"result\") {\n const usage = (event.usage ?? {}) as {\n input_tokens?: unknown;\n output_tokens?: unknown;\n cost_usd?: unknown;\n };\n\n const inputTokens =\n typeof usage.input_tokens === \"number\"\n ? usage.input_tokens\n : typeof event.input_tokens === \"number\"\n ? event.input_tokens\n : typeof event.num_input_tokens === \"number\"\n ? event.num_input_tokens\n : 0;\n const outputTokens =\n typeof usage.output_tokens === \"number\"\n ? usage.output_tokens\n : typeof event.output_tokens === \"number\"\n ? event.output_tokens\n : typeof event.num_output_tokens === \"number\"\n ? event.num_output_tokens\n : 0;\n const costUsd =\n typeof usage.cost_usd === \"number\"\n ? usage.cost_usd\n : typeof event.cost_usd === \"number\"\n ? event.cost_usd\n : undefined;\n\n yield { event: \"usage\", inputTokens, outputTokens, costUsd };\n continue;\n }\n\n if (eventType !== \"assistant\" && eventType !== \"user\") continue;\n\n const message = (event.message ?? null) as ClaudeMessage | null;\n if (!message || typeof message !== \"object\") continue;\n\n const content = (message.content ?? null) as unknown;\n if (!Array.isArray(content)) continue;\n\n for (const block of content) {\n const item = block as ClaudeContentBlock;\n if (!item || typeof item !== \"object\") continue;\n\n const blockType = item.type;\n if (!isNonEmptyString(blockType)) continue;\n\n if (eventType === \"assistant\") {\n if (blockType === \"text\" && isNonEmptyString(item.text)) {\n yield {\n event: \"agent_message\",\n text: item.text\n };\n continue;\n }\n\n if (blockType === \"tool_use\" && isNonEmptyString(item.id) && isNonEmptyString(item.name)) {\n const kind = TOOL_KIND_MAP[item.name] ?? \"other\";\n toolKindsById.set(item.id, kind);\n\n yield {\n event: \"tool_start\",\n id: item.id,\n kind,\n title: extractTitle(item.name, item.input),\n input: item.input\n };\n }\n\n continue;\n }\n\n if (eventType === \"user\") {\n if (!isNonEmptyString(item.tool_use_id)) continue;\n if (blockType !== \"tool_result\") continue;\n\n const kind = toolKindsById.get(item.tool_use_id);\n toolKindsById.delete(item.tool_use_id);\n\n let path: string;\n if (typeof item.content === \"string\") {\n path = item.content;\n } else {\n try {\n path = JSON.stringify(item.content);\n } catch {\n path = String(item.content);\n }\n }\n\n yield {\n event: \"tool_complete\",\n id: item.tool_use_id,\n kind,\n path\n };\n }\n }\n }\n}\n", "import type { AcpEvent } from \"../acp/types.js\";\nimport { truncate, isNonEmptyString, extractThreadId } from \"./utils.js\";\n\ntype CodexEvent = {\n type?: unknown;\n thread_id?: unknown;\n threadId?: unknown;\n threadID?: unknown;\n session_id?: unknown;\n sessionId?: unknown;\n sessionID?: unknown;\n usage?: unknown;\n item?: unknown;\n error?: unknown;\n message?: unknown;\n reason?: unknown;\n};\n\ntype CodexItem = {\n id?: unknown;\n type?: unknown;\n command?: unknown;\n path?: unknown;\n text?: unknown;\n content?: unknown;\n summary?: unknown;\n server?: unknown;\n tool?: unknown;\n arguments?: unknown;\n result?: unknown;\n};\n\nexport async function* adaptCodex(\n lines: AsyncIterable<string>\n): AsyncGenerator<AcpEvent> {\n const toolTitleById = new Map<string, string>();\n const toolKindById = new Map<string, string>();\n\n for await (const rawLine of lines) {\n const line = rawLine.trim();\n if (!line) continue;\n\n let event: CodexEvent;\n try {\n event = JSON.parse(line) as CodexEvent;\n } catch (error) {\n const stack = error instanceof Error ? error.stack : undefined;\n yield {\n event: \"error\",\n message: `[adaptCodex] Malformed JSON line: ${truncate(line, 200)}`,\n stack\n };\n continue;\n }\n\n const eventType = event.type;\n if (!isNonEmptyString(eventType)) continue;\n\n if (eventType === \"thread.started\") {\n const maybeThreadId = extractThreadId(event);\n yield { event: \"session_start\", threadId: maybeThreadId };\n continue;\n }\n\n if (eventType === \"turn.started\") {\n continue;\n }\n\n if (eventType === \"turn.completed\") {\n const usage = (event.usage ?? {}) as {\n input_tokens?: unknown;\n output_tokens?: unknown;\n cached_input_tokens?: unknown;\n };\n\n const inputTokens = typeof usage.input_tokens === \"number\" ? usage.input_tokens : 0;\n const outputTokens = typeof usage.output_tokens === \"number\" ? usage.output_tokens : 0;\n const cachedTokens =\n typeof usage.cached_input_tokens === \"number\" ? usage.cached_input_tokens : 0;\n\n yield { event: \"usage\", inputTokens, outputTokens, cachedTokens };\n continue;\n }\n\n if (eventType === \"turn.failed\") {\n const message = extractErrorMessage(event) ?? \"Turn failed\";\n yield { event: \"error\", message };\n continue;\n }\n\n const item = (event.item ?? null) as CodexItem | null;\n if (!item || typeof item !== \"object\") continue;\n\n const itemType = item.type;\n if (!isNonEmptyString(itemType)) continue;\n\n if (eventType === \"item.started\") {\n if (!isNonEmptyString(item.id)) continue;\n\n let kind: string | undefined;\n let title: string | undefined;\n\n if (itemType === \"command_execution\") {\n kind = \"exec\";\n title = truncate(isNonEmptyString(item.command) ? item.command : \"\", 80);\n } else if (itemType === \"file_edit\") {\n kind = \"edit\";\n title = isNonEmptyString(item.path) ? item.path : \"\";\n } else if (itemType === \"thinking\") {\n kind = \"think\";\n title = \"thinking...\";\n } else if (itemType === \"mcp_tool_call\") {\n const server = isNonEmptyString(item.server) ? item.server : \"unknown\";\n const tool = isNonEmptyString(item.tool) ? item.tool : \"unknown\";\n kind = \"other\";\n title = `${server}.${tool}`;\n }\n\n if (kind && title !== undefined) {\n toolTitleById.set(item.id, title);\n toolKindById.set(item.id, kind);\n yield { event: \"tool_start\", id: item.id, kind, title };\n }\n continue;\n }\n\n if (eventType === \"item.completed\") {\n if (itemType === \"agent_message\") {\n if (!isNonEmptyString(item.text)) continue;\n yield { event: \"agent_message\", text: item.text };\n continue;\n }\n\n if (itemType === \"reasoning\") {\n const text = isNonEmptyString(item.text)\n ? item.text\n : isNonEmptyString(item.content)\n ? item.content\n : isNonEmptyString(item.summary)\n ? item.summary\n : undefined;\n if (!text) continue;\n yield { event: \"reasoning\", text };\n continue;\n }\n\n if (!isNonEmptyString(item.id)) continue;\n\n if (itemType === \"command_execution\" || itemType === \"file_edit\" || itemType === \"mcp_tool_call\") {\n const kindFromStart = toolKindById.get(item.id);\n const kind =\n kindFromStart ??\n (itemType === \"command_execution\"\n ? \"exec\"\n : itemType === \"file_edit\"\n ? \"edit\"\n : \"other\");\n\n const titleFromEvent = isNonEmptyString(item.path)\n ? item.path\n : itemType === \"mcp_tool_call\"\n ? `${isNonEmptyString(item.server) ? item.server : \"unknown\"}.${isNonEmptyString(item.tool) ? item.tool : \"unknown\"}`\n : undefined;\n const path = titleFromEvent ?? toolTitleById.get(item.id) ?? \"\";\n\n toolTitleById.delete(item.id);\n toolKindById.delete(item.id);\n\n yield { event: \"tool_complete\", id: item.id, kind, path };\n }\n }\n }\n}\n\nfunction extractErrorMessage(event: CodexEvent): string | undefined {\n if (isNonEmptyString(event.message)) return event.message;\n\n const error = event.error;\n if (isNonEmptyString(error)) return error;\n if (typeof error === \"object\" && error !== null) {\n const errorObj = error as { message?: unknown };\n if (isNonEmptyString(errorObj.message)) return errorObj.message;\n }\n\n if (isNonEmptyString(event.reason)) return event.reason;\n return undefined;\n}\n", "import type { AcpEvent } from \"../acp/types.js\";\nimport { truncate, isNonEmptyString, extractThreadId } from \"./utils.js\";\n\ntype KimiEvent = {\n role?: unknown;\n content?: unknown;\n thread_id?: unknown;\n threadId?: unknown;\n threadID?: unknown;\n session_id?: unknown;\n sessionId?: unknown;\n sessionID?: unknown;\n};\n\nexport async function* adaptKimi(\n lines: AsyncIterable<string>\n): AsyncGenerator<AcpEvent> {\n let emittedSessionStart = false;\n\n for await (const rawLine of lines) {\n const line = rawLine.trim();\n if (!line) continue;\n\n let event: KimiEvent;\n try {\n event = JSON.parse(line) as KimiEvent;\n } catch (error) {\n const stack = error instanceof Error ? error.stack : undefined;\n yield {\n event: \"error\",\n message: `[adaptKimi] Malformed JSON line: ${truncate(line, 200)}`,\n stack\n };\n continue;\n }\n\n if (!event || typeof event !== \"object\") continue;\n\n if (!emittedSessionStart) {\n const threadId = extractThreadId(event);\n if (threadId) {\n emittedSessionStart = true;\n yield { event: \"session_start\", threadId };\n }\n }\n\n const role = event.role;\n if (!isNonEmptyString(role) || role !== \"assistant\") continue;\n\n const content = event.content;\n if (!isNonEmptyString(content)) continue;\n\n yield { event: \"agent_message\", text: content };\n }\n}\n", "import { truncate, isNonEmptyString } from \"./utils.js\";\n\ntype AcpEvent = { event: string } & Record<string, unknown>;\n\nexport async function* adaptNative(\n lines: AsyncIterable<string>\n): AsyncGenerator<AcpEvent> {\n for await (const rawLine of lines) {\n const line = rawLine.trim();\n if (!line) continue;\n\n let event: unknown;\n try {\n event = JSON.parse(line) as unknown;\n } catch (error) {\n const stack = error instanceof Error ? error.stack : undefined;\n yield {\n event: \"error\",\n message: `[adaptNative] Malformed JSON line: ${truncate(line, 200)}`,\n stack\n };\n continue;\n }\n\n const maybeEventType = (event as { event?: unknown } | null)?.event;\n if (!isNonEmptyString(maybeEventType)) {\n yield {\n event: \"error\",\n message: `[adaptNative] Line missing string \"event\" field: ${truncate(line, 200)}`\n };\n continue;\n }\n\n yield event as AcpEvent;\n }\n}\n", "import type { AcpEvent } from \"../acp/types.js\";\nimport { truncate, isNonEmptyString, extractThreadId } from \"./utils.js\";\n\ntype OpenCodeEvent = {\n type?: unknown;\n sessionID?: unknown;\n sessionId?: unknown;\n session_id?: unknown;\n threadId?: unknown;\n thread_id?: unknown;\n threadID?: unknown;\n part?: unknown;\n};\n\ntype OpenCodeTextPart = {\n type?: unknown;\n text?: unknown;\n};\n\ntype OpenCodeToolState = {\n status?: unknown;\n input?: unknown;\n output?: unknown;\n};\n\ntype OpenCodeToolPart = {\n type?: unknown;\n callID?: unknown;\n tool?: unknown;\n state?: unknown;\n};\n\ntype OpenCodeStepFinishPart = {\n tokens?: unknown;\n};\n\ntype OpenCodeTokens = {\n input?: unknown;\n output?: unknown;\n cache?: unknown;\n};\n\ntype OpenCodeTokenCache = {\n read?: unknown;\n write?: unknown;\n};\n\nfunction guessToolKind(toolName: string): string {\n const normalized = toolName.toLowerCase();\n\n if (normalized === \"bash\" || normalized === \"shell\" || normalized === \"sh\") return \"exec\";\n if (normalized.includes(\"read\")) return \"read\";\n if (normalized.includes(\"write\") || normalized.includes(\"edit\") || normalized.includes(\"patch\")) {\n return \"edit\";\n }\n if (\n normalized.includes(\"search\") ||\n normalized.includes(\"grep\") ||\n normalized.includes(\"glob\") ||\n normalized.includes(\"find\")\n ) {\n return \"search\";\n }\n if (normalized.includes(\"think\") || normalized.includes(\"task\")) return \"think\";\n\n return \"other\";\n}\n\nfunction safeStringify(value: unknown): string {\n if (typeof value === \"string\") return value;\n try {\n return JSON.stringify(value);\n } catch {\n return String(value);\n }\n}\n\nexport async function* adaptOpenCode(\n lines: AsyncIterable<string>\n): AsyncGenerator<AcpEvent> {\n let emittedSessionStart = false;\n const toolKindById = new Map<string, string>();\n\n for await (const rawLine of lines) {\n const line = rawLine.trim();\n if (!line) continue;\n\n let event: OpenCodeEvent;\n try {\n event = JSON.parse(line) as OpenCodeEvent;\n } catch (error) {\n const stack = error instanceof Error ? error.stack : undefined;\n yield {\n event: \"error\",\n message: `[adaptOpenCode] Malformed JSON line: ${truncate(line, 200)}`,\n stack\n };\n continue;\n }\n\n if (!event || typeof event !== \"object\") continue;\n\n const sessionID = extractThreadId(event);\n if (!emittedSessionStart && isNonEmptyString(sessionID)) {\n emittedSessionStart = true;\n yield { event: \"session_start\", threadId: sessionID };\n }\n\n const eventType = event.type;\n if (!isNonEmptyString(eventType)) continue;\n\n if (eventType === \"text\") {\n const part = (event.part ?? null) as OpenCodeTextPart | null;\n if (!part || typeof part !== \"object\") continue;\n if (!isNonEmptyString(part.text)) continue;\n yield { event: \"agent_message\", text: part.text };\n continue;\n }\n\n if (eventType === \"tool_use\") {\n const part = (event.part ?? null) as OpenCodeToolPart | null;\n if (!part || typeof part !== \"object\") continue;\n if (!isNonEmptyString(part.callID) || !isNonEmptyString(part.tool)) continue;\n\n const state = (part.state ?? null) as OpenCodeToolState | null;\n if (!state || typeof state !== \"object\") continue;\n\n const kind = guessToolKind(part.tool);\n const status = state.status;\n const terminal = status === \"completed\" || status === \"failed\";\n\n if (!toolKindById.has(part.callID)) {\n toolKindById.set(part.callID, kind);\n\n let title = part.tool;\n const maybeInput = state.input;\n if (kind === \"exec\" && maybeInput && typeof maybeInput === \"object\") {\n const command = (maybeInput as { command?: unknown }).command;\n if (isNonEmptyString(command)) {\n title = truncate(command, 80);\n }\n }\n\n yield {\n event: \"tool_start\",\n id: part.callID,\n kind,\n title,\n input: state.input\n };\n }\n\n if (terminal) {\n const kindFromStart = toolKindById.get(part.callID) ?? kind;\n toolKindById.delete(part.callID);\n\n yield {\n event: \"tool_complete\",\n id: part.callID,\n kind: kindFromStart,\n path: safeStringify(state.output)\n };\n }\n\n continue;\n }\n\n if (eventType === \"step_finish\") {\n const part = (event.part ?? null) as OpenCodeStepFinishPart | null;\n if (!part || typeof part !== \"object\") continue;\n\n const tokens = (part.tokens ?? null) as OpenCodeTokens | null;\n if (!tokens || typeof tokens !== \"object\") continue;\n\n const inputTokens = typeof tokens.input === \"number\" ? tokens.input : 0;\n const outputTokens = typeof tokens.output === \"number\" ? tokens.output : 0;\n\n const cache = (tokens.cache ?? null) as OpenCodeTokenCache | null;\n const cachedTokens =\n cache && typeof cache === \"object\" && typeof cache.read === \"number\" ? cache.read : undefined;\n\n if (inputTokens === 0 && outputTokens === 0 && cachedTokens === undefined) continue;\n\n yield { event: \"usage\", inputTokens, outputTokens, cachedTokens };\n continue;\n }\n }\n}\n", "import { adaptClaude } from \"./claude.js\";\nimport { adaptCodex } from \"./codex.js\";\nimport { adaptKimi } from \"./kimi.js\";\nimport { adaptNative } from \"./native.js\";\nimport { adaptOpenCode } from \"./opencode.js\";\nimport type { AcpEvent, SessionUpdate } from \"../acp/types.js\";\n\nexport { adaptCodex } from \"./codex.js\";\nexport { adaptClaude } from \"./claude.js\";\nexport { adaptKimi } from \"./kimi.js\";\nexport { adaptNative } from \"./native.js\";\nexport { adaptOpenCode } from \"./opencode.js\";\n\nexport type AdapterType = \"codex\" | \"claude\" | \"kimi\" | \"native\" | \"opencode\";\n\nexport type AdapterOutput = AcpEvent | SessionUpdate;\nexport type Adapter = (lines: AsyncIterable<string>) => AsyncGenerator<AdapterOutput>;\n\nconst adapters = {\n codex: adaptCodex,\n claude: adaptClaude,\n kimi: adaptKimi,\n native: adaptNative,\n opencode: adaptOpenCode\n} satisfies Record<AdapterType, Adapter>;\n\nexport function getAdapter(type: AdapterType): Adapter {\n const adapter = (adapters as Record<string, Adapter | undefined>)[type];\n if (!adapter) {\n throw new Error(`Unknown adapter \"${String(type)}\".`);\n }\n return adapter;\n}\n", "export function stampReceiveTime<E>(event: E, ts: number): E {\n if (event === null || typeof event !== \"object\") {\n return event;\n }\n\n const target = event as { _meta?: Record<string, unknown> };\n const existing = target._meta;\n if (existing && typeof existing.ts === \"number\") {\n return event;\n }\n\n target._meta = existing ? { ...existing, ts } : { ts };\n return event;\n}\n", "import type { SpawnMode, SpawnUsage } from \"../types.js\";\nimport type { AcpEvent } from \"./types.js\";\n\nexport interface SessionToolCall {\n id?: string;\n kind?: string;\n title?: string;\n input?: unknown;\n path?: string;\n}\n\nexport interface SessionResult {\n output: string;\n messages: string[];\n toolCalls: SessionToolCall[];\n}\n\nexport interface SpawnContext {\n sessionId: string;\n agent: string;\n logPath?: string;\n logDir?: string;\n logFileName?: string;\n events: AcpEvent[];\n usage: SpawnUsage;\n eventStream?: AsyncIterable<AcpEvent>;\n sessionResult?: SessionResult;\n threadId?: string;\n prompt?: string;\n model?: string;\n mode?: SpawnMode;\n cwd?: string;\n startedAt?: Date;\n logFile?: string;\n}\n\nexport type AcpMiddleware = (ctx: SpawnContext, next: () => Promise<void>) => Promise<void>;\n\nexport async function applyMiddlewares(\n middlewares: AcpMiddleware[],\n ctx: SpawnContext\n): Promise<void> {\n let index = -1;\n\n async function dispatch(position: number): Promise<void> {\n if (position <= index) {\n throw new Error(\"next() called multiple times\");\n }\n\n index = position;\n if (position === middlewares.length) {\n return;\n }\n\n const middleware = middlewares[position];\n if (typeof middleware !== \"function\") {\n throw new Error(`Invalid ACP middleware at index ${position}`);\n }\n\n await middleware(ctx, () => dispatch(position + 1));\n }\n\n await dispatch(0);\n}\n", "import \"../register-factories.js\";\nimport { runPoeCommand } from \"@poe-code/agent-harness-tools\";\nimport { getAdapter } from \"../adapters/index.js\";\nimport { stampReceiveTime } from \"./meta.js\";\nimport type { AcpEvent } from \"./types.js\";\nimport { resolveConfig } from \"../configs/resolve-config.js\";\nimport { getMcpArgs, getMcpEnv } from \"../mcp-args.js\";\nimport { stripModelNamespace } from \"../model-utils.js\";\nimport { observeAgentSpawn } from \"../observability/otel.js\";\nimport { shouldSendPromptViaStdin } from \"../prompt-transport.js\";\nimport { resolveSpawnExecution } from \"../runtime.js\";\nimport { bridgeSkillsForRun, cleanupSkillsForRun } from \"../skill-bridge.js\";\nimport {\n resolveModeConfig,\n type CliSpawnConfig,\n type SpawnOptions,\n type SpawnResult\n} from \"../types.js\";\nimport { applyMiddlewares, type SpawnContext } from \"./middleware.js\";\n\nfunction createAbortError(): Error {\n const error = new Error(\"Agent spawn aborted\");\n error.name = \"AbortError\";\n return error;\n}\n\nexport interface SpawnStreamingOptions extends SpawnOptions {\n agentId: string;\n}\n\nexport interface SpawnStreamingResult {\n events: AsyncIterable<AcpEvent>;\n done: Promise<SpawnResult>;\n}\n\nfunction isAcpEvent(value: unknown): value is AcpEvent {\n return !!value && typeof value === \"object\" && \"event\" in value;\n}\n\nfunction accumulateUsage(ctx: SpawnContext, event: AcpEvent): void {\n if (event.event !== \"usage\") {\n return;\n }\n\n const usage = event as {\n inputTokens?: unknown;\n outputTokens?: unknown;\n cachedTokens?: unknown;\n costUsd?: unknown;\n };\n\n if (typeof usage.inputTokens === \"number\" && Number.isFinite(usage.inputTokens)) {\n ctx.usage.inputTokens += usage.inputTokens;\n }\n\n if (typeof usage.outputTokens === \"number\" && Number.isFinite(usage.outputTokens)) {\n ctx.usage.outputTokens += usage.outputTokens;\n }\n\n if (typeof usage.cachedTokens === \"number\" && Number.isFinite(usage.cachedTokens)) {\n ctx.usage.cachedTokens = (ctx.usage.cachedTokens ?? 0) + usage.cachedTokens;\n }\n\n if (typeof usage.costUsd === \"number\" && Number.isFinite(usage.costUsd)) {\n ctx.usage.costUsd = (ctx.usage.costUsd ?? 0) + usage.costUsd;\n }\n}\n\nfunction createLineQueue(): {\n push(chunk: string): void;\n close(): void;\n lines(): AsyncIterable<string>;\n} {\n const lines: string[] = [];\n const waiters: Array<{\n resolve(value: IteratorResult<string>): void;\n }> = [];\n let pending = \"\";\n let closed = false;\n\n const emit = (line: string): void => {\n const waiter = waiters.shift();\n if (waiter) {\n waiter.resolve({ done: false, value: line });\n return;\n }\n lines.push(line);\n };\n\n const finishWaiters = (): void => {\n while (waiters.length > 0) {\n const waiter = waiters.shift()!;\n waiter.resolve({ done: true, value: undefined });\n }\n };\n\n return {\n push(chunk: string): void {\n if (closed) return;\n pending += chunk;\n let newlineIndex = pending.indexOf(\"\\n\");\n while (newlineIndex !== -1) {\n const raw = pending.slice(0, newlineIndex);\n emit(raw.endsWith(\"\\r\") ? raw.slice(0, -1) : raw);\n pending = pending.slice(newlineIndex + 1);\n newlineIndex = pending.indexOf(\"\\n\");\n }\n },\n close(): void {\n if (closed) return;\n if (pending.length > 0) {\n emit(pending.endsWith(\"\\r\") ? pending.slice(0, -1) : pending);\n pending = \"\";\n }\n closed = true;\n finishWaiters();\n },\n lines(): AsyncIterable<string> {\n return {\n [Symbol.asyncIterator](): AsyncIterator<string> {\n return {\n next(): Promise<IteratorResult<string>> {\n if (lines.length > 0) {\n return Promise.resolve({ done: false, value: lines.shift()! });\n }\n if (closed) {\n return Promise.resolve({ done: true, value: undefined });\n }\n return new Promise((resolve) => {\n waiters.push({ resolve });\n });\n }\n };\n }\n };\n }\n };\n}\n\nfunction getDefaultArgsPosition(config: CliSpawnConfig): \"beforePrompt\" | \"afterPrompt\" {\n return config.defaultArgsPosition ?? \"afterPrompt\";\n}\n\nfunction getMcpArgsPosition(\n config: CliSpawnConfig\n): \"beforeCommand\" | \"beforePrompt\" | \"afterCommand\" {\n if (config.mcpArgsPosition) {\n return config.mcpArgsPosition;\n }\n return config.mcpArgsBeforeCommand ? \"beforeCommand\" : \"afterCommand\";\n}\n\nfunction getResumeArgs(\n config: CliSpawnConfig,\n options: Pick<SpawnStreamingOptions, \"resumeThreadId\" | \"cwd\">\n): string[] {\n if (!options.resumeThreadId) {\n return [];\n }\n\n if (!config.resume) {\n throw new Error(`Agent \"${config.agentId}\" does not support resumeThreadId.`);\n }\n\n return config.resume.args(options.resumeThreadId, options.cwd ?? process.cwd());\n}\n\nexport function spawnStreaming(options: SpawnStreamingOptions): SpawnStreamingResult {\n if (options.signal?.aborted) {\n throw createAbortError();\n }\n\n const { agentId, binaryName, spawnConfig } = resolveConfig(options.agentId);\n\n if (spawnConfig === undefined) {\n throw new Error(`Agent \"${agentId}\" has no spawn config.`);\n }\n\n if (spawnConfig.kind !== \"cli\") {\n throw new Error(`Agent \"${agentId}\" does not support CLI spawn.`);\n }\n\n if (!binaryName) {\n throw new Error(`Agent \"${agentId}\" has no binaryName.`);\n }\n\n const mcpArgs = getMcpArgs(spawnConfig, options.mcpServers);\n const mcpEnvVars = getMcpEnv(spawnConfig, options.mcpServers);\n const resumeArgs = getResumeArgs(spawnConfig, options);\n const defaultArgsPosition = getDefaultArgsPosition(spawnConfig);\n const mcpArgsPosition = getMcpArgsPosition(spawnConfig);\n const resumeArgsPosition = spawnConfig.resume?.position ?? \"afterPrompt\";\n const args: string[] = [];\n\n if (mcpArgsPosition === \"beforeCommand\") {\n args.push(...mcpArgs);\n }\n\n if (defaultArgsPosition === \"beforePrompt\") {\n args.push(...spawnConfig.defaultArgs);\n }\n\n if (mcpArgsPosition === \"beforePrompt\") {\n args.push(...mcpArgs);\n }\n\n args.push(spawnConfig.promptFlag);\n\n if (resumeArgsPosition === \"beforePrompt\") {\n args.push(...resumeArgs);\n }\n\n const useStdin = shouldSendPromptViaStdin(spawnConfig, options);\n if (!useStdin || !spawnConfig.stdinMode?.omitPrompt) {\n args.push(options.prompt);\n }\n\n if (options.model && spawnConfig.modelFlag) {\n let model = spawnConfig.modelStripProviderPrefix\n ? stripModelNamespace(options.model)\n : options.model;\n if (spawnConfig.modelTransform) model = spawnConfig.modelTransform(model);\n args.push(spawnConfig.modelFlag, model);\n }\n\n if (defaultArgsPosition === \"afterPrompt\") {\n args.push(...spawnConfig.defaultArgs);\n }\n\n if (mcpArgsPosition === \"afterCommand\") {\n args.push(...mcpArgs);\n }\n\n const modeResolved = resolveModeConfig(spawnConfig.modes[options.mode ?? \"yolo\"]);\n args.push(...modeResolved.args);\n\n if (useStdin) {\n args.push(...spawnConfig.stdinMode!.extraArgs);\n }\n\n if (options.args && options.args.length > 0) {\n if (resumeArgsPosition === \"afterPrompt\") {\n args.push(...resumeArgs);\n }\n args.push(...options.args);\n } else if (resumeArgsPosition === \"afterPrompt\") {\n args.push(...resumeArgs);\n }\n\n const envOverrides = { ...mcpEnvVars, ...modeResolved.env };\n const processEnv =\n Object.keys(envOverrides).length > 0 ? { ...process.env, ...envOverrides } : undefined;\n const cwd = options.cwd ?? process.cwd();\n const queue = createLineQueue();\n const argv = [binaryName, ...args];\n const execution = resolveSpawnExecution({\n cwd,\n runtimeConfigCwd: options.runtimeConfigCwd,\n env: (processEnv ?? process.env) as Record<string, string>,\n argv,\n tool: agentId,\n runtime: {\n runtime: options.runtime,\n runtimeImage: options.runtimeImage,\n runtimeTemplate: options.runtimeTemplate,\n detach: options.detach,\n mountPoeCode: options.mountPoeCode,\n runnerSync: options.runnerSync\n },\n openSpec: {\n execution: {\n wrapForLogTee: false,\n stdin: \"pipe\",\n stdout: \"pipe\",\n stderr: \"pipe\",\n env: processEnv as Record<string, string> | undefined,\n input: useStdin ? options.prompt : \"\",\n captureOutput: true,\n activityTimeoutMs: options.activityTimeoutMs,\n onStdout(chunk: string) {\n queue.push(chunk);\n },\n onStderr(chunk: string) {\n if (options.tee?.stderr) options.tee.stderr.write(chunk);\n }\n }\n }\n });\n\n const result: SpawnResult = { stdout: \"\", stderr: \"\", exitCode: 1 };\n const adapter = getAdapter(spawnConfig.adapter);\n let resolveEventStreamDone: (() => void) | undefined;\n let rejectEventStreamDone: ((error: unknown) => void) | undefined;\n const eventStreamDone = new Promise<void>((resolve, reject) => {\n resolveEventStreamDone = resolve;\n rejectEventStreamDone = reject;\n });\n const eventQueue: AcpEvent[] = [];\n const waiters: Array<{\n resolve(result: IteratorResult<AcpEvent>): void;\n reject(error: unknown): void;\n }> = [];\n let eventsDone = false;\n let eventStreamError: unknown;\n const ctx: SpawnContext = {\n sessionId: \"unknown\",\n agent: agentId,\n ...(options.logPath !== undefined ? { logPath: options.logPath } : {}),\n ...(options.logDir !== undefined ? { logDir: options.logDir } : {}),\n ...(options.logFileName !== undefined ? { logFileName: options.logFileName } : {}),\n events: [],\n usage: {\n inputTokens: 0,\n outputTokens: 0\n },\n prompt: options.prompt,\n model: options.model,\n mode: options.mode,\n cwd: options.cwd ?? process.cwd(),\n startedAt: new Date()\n };\n\n const pushEvent = (event: AcpEvent): void => {\n if (eventsDone) return;\n if (event.event === \"session_start\") {\n const threadId = (event as { threadId?: unknown }).threadId;\n if (typeof threadId === \"string\" && threadId.length > 0) {\n ctx.threadId = threadId;\n ctx.sessionId = threadId;\n }\n }\n ctx.events.push(event);\n accumulateUsage(ctx, event);\n const waiter = waiters.shift();\n if (waiter) {\n waiter.resolve({ done: false, value: event });\n return;\n }\n eventQueue.push(event);\n };\n\n const completeEventStream = (): void => {\n if (eventsDone) return;\n eventsDone = true;\n while (waiters.length > 0) {\n waiters.shift()?.resolve({ done: true, value: undefined });\n }\n };\n\n const failEventStream = (error: unknown): void => {\n if (eventsDone) return;\n eventStreamError = error;\n eventsDone = true;\n while (waiters.length > 0) {\n waiters.shift()?.reject(error);\n }\n };\n\n ctx.eventStream = {\n [Symbol.asyncIterator](): AsyncIterator<AcpEvent> {\n return {\n next(): Promise<IteratorResult<AcpEvent>> {\n if (eventQueue.length > 0) {\n return Promise.resolve({ done: false, value: eventQueue.shift()! });\n }\n if (eventStreamError) {\n return Promise.reject(eventStreamError);\n }\n if (eventsDone) {\n return Promise.resolve({ done: true, value: undefined });\n }\n return new Promise((resolve, reject) => {\n waiters.push({ resolve, reject });\n });\n }\n };\n }\n };\n\n const manifest = bridgeSkillsForRun(options.agentId, cwd, options.skills);\n\n void (async () => {\n try {\n for await (const output of adapter(queue.lines())) {\n if (!isAcpEvent(output)) continue;\n pushEvent(stampReceiveTime(output, Date.now()));\n }\n completeEventStream();\n resolveEventStreamDone?.();\n } catch (error) {\n failEventStream(error);\n rejectEventStreamDone?.(error);\n }\n })();\n\n const done = (async (): Promise<SpawnResult> => {\n try {\n await applyMiddlewares(\n [\n ...(options.middlewares ?? []),\n async (_ctx, next) => {\n try {\n const runResult = await runPoeCommand({\n factory: execution.factory,\n openSpec: execution.openSpec,\n detach: execution.detach,\n state: execution.state,\n signal: options.signal\n });\n\n if (runResult.kind === \"detached\") {\n result.stdout = \"\";\n result.stderr = \"\";\n result.exitCode = 0;\n result.detached = { jobId: runResult.jobId, envId: runResult.envId };\n } else {\n result.stderr = runResult.stderr ?? \"\";\n result.exitCode = runResult.exitCode;\n }\n } finally {\n queue.close();\n }\n await eventStreamDone;\n await next();\n }\n ],\n ctx\n );\n\n return {\n ...result,\n ...(ctx.logFile && !result.logFile ? { logFile: ctx.logFile } : {})\n };\n } finally {\n cleanupSkillsForRun(manifest);\n }\n })();\n\n return {\n events: ctx.eventStream,\n done: observeAgentSpawn(\n {\n agent: agentId,\n cwd: options.cwd,\n mode: options.mode,\n otelSink: options.otelSink,\n prompt: options.prompt\n },\n () => done\n )\n };\n}\n", "import { renderAcpStream } from \"./acp/renderer.js\";\nimport type { AcpEvent } from \"./acp/types.js\";\nimport { isActivityTimeoutError } from \"./spawn.js\";\n\nconst DEFAULT_ACTIVITY_TIMEOUT_MS = 10 * 60 * 1000;\nconst DEFAULT_MAX_TIMEOUT_RETRIES = 3;\n\nexport interface StreamingSpawnReturn<TResult> {\n events: AsyncIterable<AcpEvent>;\n result: Promise<TResult>;\n}\n\nexport type StreamingSpawnFn<TOptions, TResult> = (\n service: string,\n options: TOptions\n) => StreamingSpawnReturn<TResult>;\n\nexport type AutonomousOptions<TOptions> = TOptions & {\n service: string;\n maxTimeoutRetries?: number;\n activityTimeoutMs?: number;\n};\n\n/**\n * Drive a streaming spawn end-to-end: pipe ACP events through `renderAcpStream`\n * (which routes through `withAcpWriter` if bound) and return the final result.\n * Retries on activity timeout up to `maxTimeoutRetries` attempts.\n *\n * Both the SDK `spawn.autonomous` and the superintendent loop consume this \u2014\n * callers supply a streaming spawn function whose `result` promise resolves\n * to their own result shape.\n */\nexport async function spawnAutonomous<\n TOptions extends { activityTimeoutMs?: number },\n TResult\n>(\n streamSpawn: StreamingSpawnFn<TOptions, TResult>,\n options: AutonomousOptions<TOptions>\n): Promise<TResult> {\n const {\n service,\n maxTimeoutRetries = DEFAULT_MAX_TIMEOUT_RETRIES,\n activityTimeoutMs = DEFAULT_ACTIVITY_TIMEOUT_MS,\n ...rest\n } = options;\n\n const spawnOptions = { ...rest, activityTimeoutMs } as unknown as TOptions;\n\n for (let attempt = 1; attempt <= maxTimeoutRetries; attempt += 1) {\n let result: Promise<TResult> | undefined;\n try {\n const stream = streamSpawn(service, spawnOptions);\n result = stream.result;\n // Attach to the final result immediately so a failed attempt can retry\n // without hanging behind ACP rendering that is still flushing.\n const [spawnResult] = await Promise.all([\n result,\n renderAcpStream(stream.events)\n ]);\n return spawnResult;\n } catch (error) {\n result?.catch(() => {});\n if (!isActivityTimeoutError(error) || attempt === maxTimeoutRetries) {\n throw error;\n }\n }\n }\n\n throw new Error(\"Unreachable\");\n}\n", "import path from \"node:path\";\nimport { homedir } from \"node:os\";\nimport type { Dirent } from \"node:fs\";\nimport { open, readdir } from \"node:fs/promises\";\nimport { createInterface } from \"node:readline\";\nimport type { SessionUpdate } from \"@poe-code/poe-acp-client\";\nimport { mapLegacyEventToSessionUpdates } from \"@poe-code/poe-acp-client\";\nimport { renderSessionUpdateStream } from \"./renderer.js\";\nimport type { AcpEvent } from \"./types.js\";\n\nconst DEFAULT_LOG_LIMIT = 80;\nconst JSONL_EXTENSION = \".jsonl\";\n\nexport interface LogEntry {\n path: string;\n filename: string;\n agent?: string;\n timestamp?: Date;\n}\n\ninterface ListSpawnLogsOptions {\n agent?: string;\n limit?: number;\n}\n\nfunction isDigitString(value: string, length: number): boolean {\n if (value.length !== length) return false;\n for (const char of value) {\n if (char < \"0\" || char > \"9\") return false;\n }\n return true;\n}\n\nfunction parseTimestamp(day: string, time: string, milliseconds: string): Date | undefined {\n if (!isDigitString(day, 8) || !isDigitString(time, 6) || !isDigitString(milliseconds, 3)) {\n return undefined;\n }\n\n const year = Number(day.slice(0, 4));\n const month = Number(day.slice(4, 6));\n const date = Number(day.slice(6, 8));\n const hours = Number(time.slice(0, 2));\n const minutes = Number(time.slice(2, 4));\n const seconds = Number(time.slice(4, 6));\n const millis = Number(milliseconds);\n\n const timestamp = new Date(Date.UTC(year, month - 1, date, hours, minutes, seconds, millis));\n\n if (\n Number.isNaN(timestamp.getTime()) ||\n timestamp.getUTCFullYear() !== year ||\n timestamp.getUTCMonth() !== month - 1 ||\n timestamp.getUTCDate() !== date ||\n timestamp.getUTCHours() !== hours ||\n timestamp.getUTCMinutes() !== minutes ||\n timestamp.getUTCSeconds() !== seconds ||\n timestamp.getUTCMilliseconds() !== millis\n ) {\n return undefined;\n }\n\n return timestamp;\n}\n\nfunction parseLogFilename(filename: string): { agent?: string; timestamp?: Date } {\n if (!filename.endsWith(JSONL_EXTENSION)) return {};\n\n const baseName = filename.slice(0, -JSONL_EXTENSION.length);\n const parts = baseName.split(\"-\");\n\n if (parts.length < 4) return {};\n\n const timestamp = parseTimestamp(parts[0], parts[1], parts[2]);\n const agent = parts.slice(3).join(\"-\");\n\n return {\n agent: agent.length > 0 ? agent : undefined,\n timestamp\n };\n}\n\nfunction normalizeLimit(limit: number | undefined): number {\n if (typeof limit !== \"number\" || !Number.isFinite(limit) || limit < 0) {\n return DEFAULT_LOG_LIMIT;\n }\n return Math.floor(limit);\n}\n\nfunction isSessionUpdate(parsed: unknown): parsed is SessionUpdate {\n return (\n typeof parsed === \"object\" &&\n parsed !== null &&\n \"sessionUpdate\" in parsed &&\n typeof (parsed as Record<string, unknown>).sessionUpdate === \"string\"\n );\n}\n\nfunction isLegacyEvent(parsed: unknown): parsed is AcpEvent {\n return (\n typeof parsed === \"object\" &&\n parsed !== null &&\n \"event\" in parsed &&\n typeof (parsed as Record<string, unknown>).event === \"string\"\n );\n}\n\nexport async function* readSpawnLog(filePath: string): AsyncIterable<SessionUpdate> {\n const fileHandle = await open(filePath, \"r\");\n const stream = fileHandle.createReadStream({ encoding: \"utf8\" });\n const reader = createInterface({\n input: stream,\n crlfDelay: Infinity\n });\n\n try {\n for await (const line of reader) {\n const trimmed = line.trim();\n if (trimmed.length === 0) continue;\n\n const parsed: unknown = JSON.parse(trimmed);\n\n if (isSessionUpdate(parsed)) {\n yield parsed;\n continue;\n }\n\n if (isLegacyEvent(parsed)) {\n for (const update of mapLegacyEventToSessionUpdates(parsed as { event: string } & Record<string, unknown>)) {\n yield update;\n }\n }\n }\n } finally {\n reader.close();\n if (!stream.destroyed) {\n stream.destroy();\n }\n await fileHandle.close().catch(() => {});\n }\n}\n\nexport async function listSpawnLogs(options: ListSpawnLogsOptions = {}): Promise<LogEntry[]> {\n const logDir = path.join(homedir(), \".poe-code\", \"spawn-logs\");\n const limit = normalizeLimit(options.limit);\n\n let entries: Dirent[];\n try {\n entries = await readdir(logDir, { withFileTypes: true });\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code === \"ENOENT\") return [];\n throw error;\n }\n\n const logs: LogEntry[] = [];\n\n for (const entry of entries) {\n if (!entry.isFile() || !entry.name.endsWith(JSONL_EXTENSION)) continue;\n\n const logEntry: LogEntry = {\n path: path.join(logDir, entry.name),\n filename: entry.name,\n ...parseLogFilename(entry.name)\n };\n\n if (options.agent && logEntry.agent !== options.agent) continue;\n\n logs.push(logEntry);\n }\n\n logs.sort((a, b) => (a.filename < b.filename ? 1 : a.filename > b.filename ? -1 : 0));\n return logs.slice(0, limit);\n}\n\nexport async function findLatestLog(agent?: string): Promise<string | undefined> {\n const [entry] = await listSpawnLogs({ agent, limit: 1 });\n return entry?.path;\n}\n\nexport async function pickRandomLog(agent?: string): Promise<string | undefined> {\n const entries = await listSpawnLogs({ agent });\n if (entries.length === 0) return undefined;\n return entries[Math.floor(Math.random() * entries.length)]?.path;\n}\n\nexport async function replaySpawnLog(filePath: string): Promise<void> {\n await renderSessionUpdateStream(readSpawnLog(filePath));\n}\n", "import { isAbsolute } from \"node:path\";\nimport {\n AcpTransport,\n type AcpTransportClosedEvent,\n type AcpTransportOptions,\n} from \"./acp-transport.js\";\nimport type { JsonRpcRequestOptions } from \"./jsonrpc-message-layer.js\";\nimport {\n ACP_ERROR_CODE_INVALID_PARAMS,\n ACP_ERROR_CODE_RESOURCE_NOT_FOUND,\n AcpError,\n type AgentCapabilities,\n type AuthenticateResponse,\n type AuthMethod,\n type CancelNotification,\n type ClientCapabilities,\n type ContentBlock,\n type CreateTerminalRequest,\n type CreateTerminalResponse,\n type EnvVariable,\n type Implementation,\n type InitializeResponse,\n type KillTerminalCommandRequest,\n type KillTerminalCommandResponse,\n type LoadSessionResponse,\n type McpServer,\n type NewSessionResponse,\n type PermissionOption,\n type PromptResponse,\n type RequestId,\n type SessionConfigId,\n type SessionConfigOption,\n type SessionConfigValueId,\n type RequestPermissionOutcome,\n type RequestPermissionRequest,\n type RequestPermissionResponse,\n type ReadTextFileRequest,\n type ReadTextFileResponse,\n type ProtocolVersion,\n type SessionModeId,\n type SessionNotification,\n type SessionId,\n type SetSessionModeResponse,\n type SessionUpdateNotification,\n type ToolCallUpdate,\n type TerminalOutputRequest,\n type TerminalOutputResponse,\n type WaitForTerminalExitRequest,\n type WaitForTerminalExitResponse,\n type WriteTextFileRequest,\n type WriteTextFileResponse,\n type ReleaseTerminalRequest,\n type ReleaseTerminalResponse,\n} from \"./types.js\";\n\nexport type AcpClientState = \"uninitialized\" | \"initialized\" | \"ready\";\ntype ExtensionMethod = `_${string}`;\n\nexport interface PromptTurn extends AsyncIterable<SessionUpdateNotification> {\n response: Promise<PromptResponse>;\n}\n\ninterface AsyncQueue<T> extends AsyncIterable<T>, AsyncIterator<T> {\n push(value: T): void;\n complete(): void;\n fail(error: Error): void;\n}\n\nexport interface AcpClientFsHandler {\n readTextFile?: (args: {\n sessionId: SessionId;\n path: string;\n line?: number | null;\n limit?: number | null;\n }) => string | Promise<string>;\n writeTextFile?: (args: {\n sessionId: SessionId;\n path: string;\n content: string;\n }) => void | Promise<void>;\n}\n\nexport interface AcpClientTerminalHandler {\n create: (args: {\n sessionId: SessionId;\n command: string;\n args?: string[];\n cwd?: string | null;\n env?: EnvVariable[];\n outputByteLimit?: number | null;\n }) => string | Promise<string>;\n output: (args: {\n sessionId: SessionId;\n terminalId: string;\n }) => TerminalOutputResponse | Promise<TerminalOutputResponse>;\n waitForExit: (args: {\n sessionId: SessionId;\n terminalId: string;\n }) => WaitForTerminalExitResponse | Promise<WaitForTerminalExitResponse>;\n kill: (args: { sessionId: SessionId; terminalId: string }) => void | Promise<void>;\n release: (args: {\n sessionId: SessionId;\n terminalId: string;\n }) => void | Promise<void>;\n}\n\ntype AcpClientPermissionHandler = (args: {\n toolCall: ToolCallUpdate;\n options: PermissionOption[];\n}) => RequestPermissionOutcome | Promise<RequestPermissionOutcome>;\n\nexport interface AcpClientHandlers {\n permission?: AcpClientPermissionHandler;\n fs?: AcpClientFsHandler;\n terminal?: AcpClientTerminalHandler;\n}\n\ntype AcpClientTransport = Pick<\n AcpTransport,\n \"sendRequest\" | \"sendNotification\" | \"onRequest\" | \"onNotification\"\n> &\n Partial<Pick<AcpTransport, \"dispose\" | \"closed\">>;\n\ninterface AcpClientSharedOptions {\n protocolVersion?: ProtocolVersion;\n clientCapabilities?: ClientCapabilities;\n clientInfo?: Implementation | null;\n handlers?: AcpClientHandlers;\n permissionHandler?: AcpClientPermissionHandler;\n fsHandler?: AcpClientFsHandler;\n terminalHandler?: AcpClientTerminalHandler;\n skipAuth?: boolean;\n /**\n * Automatically approve all permission requests (selects the first\n * \"allow_always\" or \"allow_once\" option). Ignored when a custom\n * `permissionHandler` is provided.\n */\n autoApprove?: boolean;\n}\n\nexport interface AcpClientProcessOptions extends AcpClientSharedOptions {\n command: string;\n args?: readonly string[];\n cwd?: string;\n env?: NodeJS.ProcessEnv;\n firstRequestId?: number;\n spawn?: AcpTransportOptions[\"spawn\"];\n}\n\nexport interface AcpClientInjectedTransportOptions extends AcpClientSharedOptions {\n transport: AcpClientTransport;\n}\n\nexport type AcpClientOptions = AcpClientProcessOptions | AcpClientInjectedTransportOptions;\n\nfunction toError(reason: unknown): Error {\n return reason instanceof Error ? reason : new Error(String(reason));\n}\n\nfunction invalidParams(message: string): AcpError {\n return new AcpError(\n ACP_ERROR_CODE_INVALID_PARAMS,\n `Invalid params: ${message}`\n );\n}\n\nfunction resourceNotFound(resource: string): AcpError {\n return new AcpError(\n ACP_ERROR_CODE_RESOURCE_NOT_FOUND,\n `Resource not found: ${resource}`\n );\n}\n\nfunction assertAbsolutePath(path: string): void {\n if (!isAbsolute(path)) {\n throw invalidParams('\"path\" must be an absolute path');\n }\n}\n\nfunction assertOneBasedLineNumber(line: number | null | undefined): void {\n if (line === null || line === undefined) {\n return;\n }\n\n if (!Number.isInteger(line) || line < 1) {\n throw invalidParams('\"line\" must be a 1-based integer');\n }\n}\n\nfunction assertExtensionMethod(method: string): asserts method is ExtensionMethod {\n if (!method.startsWith(\"_\")) {\n throw new Error('Extension method must start with \"_\"');\n }\n}\n\nfunction isInjectedTransportOptions(\n options: AcpClientOptions\n): options is AcpClientInjectedTransportOptions {\n return \"transport\" in options;\n}\n\nfunction createAsyncQueue<T>(): AsyncQueue<T> {\n const values: T[] = [];\n const waiters: Array<{\n resolve: (result: IteratorResult<T>) => void;\n reject: (error: Error) => void;\n }> = [];\n let closed = false;\n let failure: Error | null = null;\n\n const resolveOne = (value: T): boolean => {\n const waiter = waiters.shift();\n if (!waiter) {\n return false;\n }\n\n waiter.resolve({ done: false, value });\n return true;\n };\n\n const iterator: AsyncQueue<T> = {\n push(value: T): void {\n if (closed || failure) {\n return;\n }\n\n if (!resolveOne(value)) {\n values.push(value);\n }\n },\n complete(): void {\n if (closed || failure) {\n return;\n }\n\n closed = true;\n while (waiters.length > 0) {\n waiters.shift()?.resolve({ done: true, value: undefined });\n }\n },\n fail(error: Error): void {\n if (closed || failure) {\n return;\n }\n\n failure = error;\n while (waiters.length > 0) {\n waiters.shift()?.reject(error);\n }\n },\n async next(): Promise<IteratorResult<T>> {\n if (values.length > 0) {\n const value = values.shift() as T;\n return { done: false, value };\n }\n\n if (failure) {\n throw failure;\n }\n\n if (closed) {\n return { done: true, value: undefined };\n }\n\n return new Promise<IteratorResult<T>>((resolve, reject) => {\n waiters.push({ resolve, reject });\n });\n },\n async return(): Promise<IteratorResult<T>> {\n iterator.complete();\n return { done: true, value: undefined };\n },\n async throw(error: unknown): Promise<IteratorResult<T>> {\n const normalizedError = toError(error);\n iterator.fail(normalizedError);\n throw normalizedError;\n },\n [Symbol.asyncIterator](): AsyncIterator<T> {\n return iterator;\n },\n };\n\n return iterator;\n}\n\nexport class AcpClient {\n private readonly transport: AcpClientTransport;\n private readonly clientProtocolVersion: ProtocolVersion;\n private clientCapabilities?: ClientCapabilities;\n private readonly clientInfo?: Implementation | null;\n private readonly skipAuth: boolean;\n private readonly permissionHandler?: AcpClientPermissionHandler;\n private readonly fsHandler?: AcpClientFsHandler;\n private readonly terminalHandler?: AcpClientTerminalHandler;\n private readonly activePromptUpdates = new Map<\n SessionId,\n AsyncQueue<SessionUpdateNotification>\n >();\n private readonly trackedTerminalIds = new Map<SessionId, Set<string>>();\n private hasRegisteredFsReadHandler = false;\n private hasRegisteredFsWriteHandler = false;\n private hasRegisteredTerminalHandlers = false;\n private disposed = false;\n\n private lifecycleState: AcpClientState = \"uninitialized\";\n private negotiatedVersion: ProtocolVersion | null = null;\n private availableAuthMethods: AuthMethod[] = [];\n private negotiatedAgentCapabilities: AgentCapabilities | undefined;\n private negotiatedAgentInfo: Implementation | null | undefined;\n\n constructor(options: AcpClientOptions) {\n this.transport = isInjectedTransportOptions(options)\n ? options.transport\n : new AcpTransport({\n command: options.command,\n args: options.args,\n cwd: options.cwd,\n env: options.env,\n firstRequestId: options.firstRequestId,\n spawn: options.spawn,\n });\n this.clientProtocolVersion = options.protocolVersion ?? 1;\n this.clientCapabilities = options.clientCapabilities;\n this.clientInfo = options.clientInfo;\n this.skipAuth = options.skipAuth ?? false;\n this.permissionHandler = options.handlers?.permission ?? options.permissionHandler;\n this.fsHandler = options.handlers?.fs ?? options.fsHandler;\n this.terminalHandler = options.handlers?.terminal ?? options.terminalHandler;\n\n const autoApprove = options.autoApprove === true && !this.permissionHandler;\n\n this.transport.onRequest(\n \"session/request_permission\",\n async (params: RequestPermissionRequest): Promise<RequestPermissionResponse> => {\n if (this.permissionHandler) {\n const outcome = await this.permissionHandler({\n toolCall: params.toolCall,\n options: params.options,\n });\n return { outcome };\n }\n\n if (autoApprove) {\n const allow =\n params.options.find((o: PermissionOption) => o.kind === \"allow_always\") ??\n params.options.find((o: PermissionOption) => o.kind === \"allow_once\");\n if (allow) {\n return { outcome: { outcome: \"selected\", optionId: allow.optionId } };\n }\n }\n\n return { outcome: { outcome: \"cancelled\" } };\n }\n );\n\n this.registerCapabilityHandlers(this.clientCapabilities);\n\n this.transport.onNotification(\"session/update\", (params: SessionNotification) => {\n this.handleSessionUpdateNotification(params);\n });\n }\n\n get state(): AcpClientState {\n return this.lifecycleState;\n }\n\n get negotiatedProtocolVersion(): ProtocolVersion | null {\n return this.negotiatedVersion;\n }\n\n get authMethods(): AuthMethod[] {\n return [...this.availableAuthMethods];\n }\n\n get agentCapabilities(): AgentCapabilities | undefined {\n return this.negotiatedAgentCapabilities;\n }\n\n get agentInfo(): Implementation | null | undefined {\n return this.negotiatedAgentInfo;\n }\n\n get closed(): Promise<AcpTransportClosedEvent> | undefined {\n return this.transport.closed;\n }\n\n async initialize(clientCapabilities?: ClientCapabilities): Promise<InitializeResponse> {\n if (this.lifecycleState !== \"uninitialized\") {\n throw new Error(\"initialize() can only be called once.\");\n }\n\n if (clientCapabilities !== undefined) {\n this.clientCapabilities = clientCapabilities;\n this.registerCapabilityHandlers(clientCapabilities);\n }\n\n const response = await this.transport.sendRequest(\"initialize\", {\n protocolVersion: this.clientProtocolVersion,\n clientInfo: this.clientInfo,\n clientCapabilities: this.clientCapabilities,\n });\n\n const negotiatedProtocolVersion = Math.min(\n this.clientProtocolVersion,\n response.protocolVersion\n );\n\n this.negotiatedVersion = negotiatedProtocolVersion;\n this.negotiatedAgentCapabilities = response.agentCapabilities;\n this.negotiatedAgentInfo = response.agentInfo;\n this.availableAuthMethods = response.authMethods ? [...response.authMethods] : [];\n\n const requiresAuth = this.availableAuthMethods.length > 0 && !this.skipAuth;\n this.lifecycleState = requiresAuth ? \"initialized\" : \"ready\";\n\n return {\n protocolVersion: negotiatedProtocolVersion,\n ...(this.negotiatedAgentCapabilities !== undefined\n ? { agentCapabilities: this.negotiatedAgentCapabilities }\n : {}),\n ...(this.negotiatedAgentInfo !== undefined ? { agentInfo: this.negotiatedAgentInfo } : {}),\n ...(this.availableAuthMethods.length > 0 ? { authMethods: this.authMethods } : {}),\n };\n }\n\n async authenticate(methodId: string): Promise<AuthenticateResponse> {\n if (this.lifecycleState === \"uninitialized\") {\n throw new Error(\"Cannot authenticate before initialize().\");\n }\n\n if (this.lifecycleState === \"ready\") {\n throw new Error(\"Authentication is not required for this agent.\");\n }\n\n if (!this.availableAuthMethods.some((authMethod) => authMethod.id === methodId)) {\n throw new Error(`Unknown auth method \"${methodId}\".`);\n }\n\n const response = await this.transport.sendRequest(\"authenticate\", {\n methodId,\n });\n\n this.lifecycleState = \"ready\";\n return response;\n }\n\n async newSession(cwd: string, mcpServers: McpServer[]): Promise<NewSessionResponse> {\n this.assertReady(\"session/new\");\n this.assertMcpServerCapabilitySupport(mcpServers);\n\n return this.transport.sendRequest(\"session/new\", {\n cwd,\n mcpServers,\n });\n }\n\n async loadSession(\n sessionId: SessionId,\n cwd: string,\n mcpServers: McpServer[]\n ): Promise<LoadSessionResponse> {\n this.assertReady(\"session/load\");\n if (this.negotiatedAgentCapabilities?.loadSession !== true) {\n throw new Error(\n 'Cannot call \"session/load\" because the agent does not support session loading.'\n );\n }\n this.assertMcpServerCapabilitySupport(mcpServers);\n\n return this.transport.sendRequest(\"session/load\", {\n sessionId,\n cwd,\n mcpServers,\n });\n }\n\n async cancelSession(sessionId: SessionId): Promise<void> {\n this.assertReady(\"session/cancel\");\n const payload: CancelNotification = { sessionId };\n this.transport.sendNotification(\"session/cancel\", payload);\n }\n\n async setMode(\n sessionId: SessionId,\n modeId: SessionModeId\n ): Promise<SetSessionModeResponse> {\n this.assertReady(\"session/set_mode\");\n return this.transport.sendRequest(\"session/set_mode\", {\n sessionId,\n modeId,\n });\n }\n\n async setConfigOption(\n sessionId: SessionId,\n configId: SessionConfigId,\n value: SessionConfigValueId\n ): Promise<SessionConfigOption[]> {\n this.assertReady(\"session/set_config_option\");\n const response = await this.transport.sendRequest(\"session/set_config_option\", {\n sessionId,\n configId,\n value,\n });\n\n return response.configOptions;\n }\n\n prompt(sessionId: SessionId, content: ContentBlock[]): PromptTurn {\n this.assertReady(\"session/prompt\");\n this.assertPromptContentCapabilitySupport(content);\n\n if (this.activePromptUpdates.has(sessionId)) {\n throw new Error(\n `Cannot call \"session/prompt\" while another prompt is in progress for session \"${sessionId}\".`\n );\n }\n\n const updates = createAsyncQueue<SessionUpdateNotification>();\n this.activePromptUpdates.set(sessionId, updates);\n\n let requestPromise: Promise<PromptResponse>;\n try {\n requestPromise = this.transport.sendRequest(\"session/prompt\", {\n sessionId,\n prompt: content,\n });\n } catch (error) {\n const normalizedError = toError(error);\n this.activePromptUpdates.delete(sessionId);\n updates.fail(normalizedError);\n throw normalizedError;\n }\n\n const response = requestPromise\n .then((promptResponse) => {\n this.activePromptUpdates.delete(sessionId);\n updates.complete();\n return promptResponse;\n })\n .catch((error) => {\n const normalizedError = toError(error);\n this.activePromptUpdates.delete(sessionId);\n updates.fail(normalizedError);\n throw normalizedError;\n });\n\n return {\n response,\n [Symbol.asyncIterator](): AsyncIterator<SessionUpdateNotification> {\n return updates;\n },\n };\n }\n\n async sendExtRequest<TResult = unknown>(\n method: ExtensionMethod,\n params?: unknown,\n options?: JsonRpcRequestOptions\n ): Promise<TResult>;\n async sendExtRequest<TResult = unknown>(\n method: string,\n params?: unknown,\n options: JsonRpcRequestOptions = {}\n ): Promise<TResult> {\n assertExtensionMethod(method);\n return this.transport.sendRequest(method, params, options) as Promise<TResult>;\n }\n\n async sendExtNotification(method: ExtensionMethod, params?: unknown): Promise<void>;\n async sendExtNotification(method: string, params?: unknown): Promise<void> {\n assertExtensionMethod(method);\n this.transport.sendNotification(method, params);\n }\n\n onExtRequest<TMethod extends ExtensionMethod>(\n method: TMethod,\n handler: (\n params: unknown,\n context: { id: RequestId; method: TMethod }\n ) => unknown | Promise<unknown>\n ): void;\n onExtRequest(\n method: string,\n handler: (params: unknown, context: { id: RequestId; method: string }) => unknown\n ): void {\n assertExtensionMethod(method);\n this.transport.onRequest(method, handler);\n }\n\n onExtNotification<TMethod extends ExtensionMethod>(\n method: TMethod,\n handler: (params: unknown, context: { method: TMethod }) => void | Promise<void>\n ): void;\n onExtNotification(\n method: string,\n handler: (params: unknown, context: { method: string }) => void | Promise<void>\n ): void {\n assertExtensionMethod(method);\n this.transport.onNotification(method, handler);\n }\n\n async dispose(): Promise<void> {\n if (this.disposed) {\n if (this.transport.closed) {\n await this.transport.closed;\n }\n return;\n }\n\n this.disposed = true;\n const disposeReason = new Error(\"ACP client disposed\");\n for (const updates of this.activePromptUpdates.values()) {\n updates.fail(disposeReason);\n }\n this.activePromptUpdates.clear();\n\n if (typeof this.transport.dispose === \"function\") {\n this.transport.dispose(disposeReason);\n }\n\n if (this.transport.closed) {\n await this.transport.closed;\n }\n }\n\n assertReady(operation: string): void {\n if (this.lifecycleState === \"ready\") {\n return;\n }\n\n if (this.lifecycleState === \"uninitialized\") {\n throw new Error(`Cannot call \"${operation}\" before initialize().`);\n }\n\n throw new Error(`Cannot call \"${operation}\" before authentication completes.`);\n }\n\n private registerCapabilityHandlers(capabilities: ClientCapabilities | undefined): void {\n if (\n !this.hasRegisteredFsReadHandler &&\n capabilities?.fs?.readTextFile === true &&\n this.fsHandler?.readTextFile\n ) {\n const readTextFile = this.fsHandler.readTextFile;\n this.transport.onRequest(\n \"fs/read_text_file\",\n async (params: ReadTextFileRequest): Promise<ReadTextFileResponse> => {\n assertAbsolutePath(params.path);\n assertOneBasedLineNumber(params.line);\n\n const content = await readTextFile({\n sessionId: params.sessionId,\n path: params.path,\n line: params.line,\n limit: params.limit,\n });\n return { content };\n }\n );\n this.hasRegisteredFsReadHandler = true;\n }\n\n if (\n !this.hasRegisteredFsWriteHandler &&\n capabilities?.fs?.writeTextFile === true &&\n this.fsHandler?.writeTextFile\n ) {\n const writeTextFile = this.fsHandler.writeTextFile;\n this.transport.onRequest(\n \"fs/write_text_file\",\n async (params: WriteTextFileRequest): Promise<WriteTextFileResponse> => {\n assertAbsolutePath(params.path);\n\n await writeTextFile({\n sessionId: params.sessionId,\n path: params.path,\n content: params.content,\n });\n\n return {};\n }\n );\n this.hasRegisteredFsWriteHandler = true;\n }\n\n if (\n !this.hasRegisteredTerminalHandlers &&\n capabilities?.terminal === true &&\n this.terminalHandler\n ) {\n const terminalHandler = this.terminalHandler;\n this.transport.onRequest(\n \"terminal/create\",\n async (params: CreateTerminalRequest): Promise<CreateTerminalResponse> => {\n const terminalId = await terminalHandler.create({\n sessionId: params.sessionId,\n command: params.command,\n args: params.args,\n cwd: params.cwd,\n env: params.env,\n outputByteLimit: params.outputByteLimit,\n });\n this.trackTerminal(params.sessionId, terminalId);\n\n return { terminalId };\n }\n );\n\n this.transport.onRequest(\n \"terminal/output\",\n async (params: TerminalOutputRequest): Promise<TerminalOutputResponse> => {\n this.assertKnownTerminal(params.sessionId, params.terminalId);\n\n return terminalHandler.output({\n sessionId: params.sessionId,\n terminalId: params.terminalId,\n });\n }\n );\n\n this.transport.onRequest(\n \"terminal/wait_for_exit\",\n async (params: WaitForTerminalExitRequest): Promise<WaitForTerminalExitResponse> => {\n this.assertKnownTerminal(params.sessionId, params.terminalId);\n\n return terminalHandler.waitForExit({\n sessionId: params.sessionId,\n terminalId: params.terminalId,\n });\n }\n );\n\n this.transport.onRequest(\n \"terminal/kill\",\n async (params: KillTerminalCommandRequest): Promise<KillTerminalCommandResponse> => {\n this.assertKnownTerminal(params.sessionId, params.terminalId);\n\n await terminalHandler.kill({\n sessionId: params.sessionId,\n terminalId: params.terminalId,\n });\n\n return {};\n }\n );\n\n this.transport.onRequest(\n \"terminal/release\",\n async (params: ReleaseTerminalRequest): Promise<ReleaseTerminalResponse> => {\n this.assertKnownTerminal(params.sessionId, params.terminalId);\n\n await terminalHandler.release({\n sessionId: params.sessionId,\n terminalId: params.terminalId,\n });\n this.untrackTerminal(params.sessionId, params.terminalId);\n\n return {};\n }\n );\n this.hasRegisteredTerminalHandlers = true;\n }\n }\n\n private assertMcpServerCapabilitySupport(mcpServers: McpServer[]): void {\n const mcpCapabilities = this.negotiatedAgentCapabilities?.mcpCapabilities;\n\n for (const mcpServer of mcpServers) {\n if (!(\"type\" in mcpServer)) {\n continue;\n }\n\n if (mcpServer.type === \"http\" && mcpCapabilities?.http !== true) {\n throw new Error('Agent does not support MCP server type \"http\".');\n }\n\n if (mcpServer.type === \"sse\" && mcpCapabilities?.sse !== true) {\n throw new Error('Agent does not support MCP server type \"sse\".');\n }\n }\n }\n\n private handleSessionUpdateNotification(notification: SessionNotification): void {\n const activePrompt = this.activePromptUpdates.get(notification.sessionId);\n if (!activePrompt) {\n return;\n }\n\n activePrompt.push({\n jsonrpc: \"2.0\",\n method: \"session/update\",\n params: notification,\n });\n }\n\n private trackTerminal(sessionId: SessionId, terminalId: string): void {\n const sessionTerminals = this.trackedTerminalIds.get(sessionId);\n if (sessionTerminals) {\n sessionTerminals.add(terminalId);\n return;\n }\n\n this.trackedTerminalIds.set(sessionId, new Set([terminalId]));\n }\n\n private assertKnownTerminal(sessionId: SessionId, terminalId: string): void {\n const sessionTerminals = this.trackedTerminalIds.get(sessionId);\n if (sessionTerminals?.has(terminalId) === true) {\n return;\n }\n\n throw resourceNotFound(`terminal \"${terminalId}\"`);\n }\n\n private untrackTerminal(sessionId: SessionId, terminalId: string): void {\n const sessionTerminals = this.trackedTerminalIds.get(sessionId);\n if (!sessionTerminals) {\n return;\n }\n\n sessionTerminals.delete(terminalId);\n if (sessionTerminals.size === 0) {\n this.trackedTerminalIds.delete(sessionId);\n }\n }\n\n private assertPromptContentCapabilitySupport(content: ContentBlock[]): void {\n const promptCapabilities = this.negotiatedAgentCapabilities?.promptCapabilities;\n\n for (const block of content) {\n if (block.type === \"image\" && promptCapabilities?.image !== true) {\n throw new Error('Agent does not support prompt content type \"image\".');\n }\n\n if (block.type === \"audio\" && promptCapabilities?.audio !== true) {\n throw new Error('Agent does not support prompt content type \"audio\".');\n }\n\n if (block.type === \"resource\" && promptCapabilities?.embeddedContext !== true) {\n throw new Error('Agent does not support prompt content type \"resource\".');\n }\n }\n }\n}\n", "import {\n spawn as spawnChildProcess,\n type ChildProcessWithoutNullStreams,\n type SpawnOptionsWithoutStdio,\n} from \"node:child_process\";\nimport {\n JsonRpcMessageLayer,\n type JsonRpcNotificationHandler,\n type JsonRpcRequestHandler,\n type JsonRpcRequestOptions,\n} from \"./jsonrpc-message-layer.js\";\nimport type {\n AuthenticateRequest,\n AuthenticateResponse,\n CancelNotification,\n CreateTerminalRequest,\n CreateTerminalResponse,\n InitializeRequest,\n InitializeResponse,\n KillTerminalCommandRequest,\n KillTerminalCommandResponse,\n LoadSessionRequest,\n LoadSessionResponse,\n NewSessionRequest,\n NewSessionResponse,\n PromptRequest,\n PromptResponse,\n ReadTextFileRequest,\n ReadTextFileResponse,\n ReleaseTerminalRequest,\n ReleaseTerminalResponse,\n RequestId,\n RequestPermissionRequest,\n RequestPermissionResponse,\n SessionNotification,\n SetSessionConfigOptionRequest,\n SetSessionConfigOptionResponse,\n SetSessionModeRequest,\n SetSessionModeResponse,\n TerminalOutputRequest,\n TerminalOutputResponse,\n WaitForTerminalExitRequest,\n WaitForTerminalExitResponse,\n WriteTextFileRequest,\n WriteTextFileResponse,\n} from \"./types.js\";\n\ninterface AcpRequestShape<TParams, TResult> {\n params: TParams;\n result: TResult;\n}\n\nexport interface AcpAgentRequestMap {\n initialize: AcpRequestShape<InitializeRequest, InitializeResponse>;\n authenticate: AcpRequestShape<AuthenticateRequest, AuthenticateResponse>;\n \"session/new\": AcpRequestShape<NewSessionRequest, NewSessionResponse>;\n \"session/load\": AcpRequestShape<LoadSessionRequest, LoadSessionResponse>;\n \"session/prompt\": AcpRequestShape<PromptRequest, PromptResponse>;\n \"session/set_mode\": AcpRequestShape<SetSessionModeRequest, SetSessionModeResponse>;\n \"session/set_config_option\": AcpRequestShape<\n SetSessionConfigOptionRequest,\n SetSessionConfigOptionResponse\n >;\n}\n\nexport interface AcpAgentNotificationMap {\n \"session/cancel\": CancelNotification;\n}\n\nexport interface AcpClientRequestMap {\n \"session/request_permission\": AcpRequestShape<\n RequestPermissionRequest,\n RequestPermissionResponse\n >;\n \"fs/read_text_file\": AcpRequestShape<ReadTextFileRequest, ReadTextFileResponse>;\n \"fs/write_text_file\": AcpRequestShape<WriteTextFileRequest, WriteTextFileResponse>;\n \"terminal/create\": AcpRequestShape<CreateTerminalRequest, CreateTerminalResponse>;\n \"terminal/output\": AcpRequestShape<TerminalOutputRequest, TerminalOutputResponse>;\n \"terminal/wait_for_exit\": AcpRequestShape<\n WaitForTerminalExitRequest,\n WaitForTerminalExitResponse\n >;\n \"terminal/kill\": AcpRequestShape<\n KillTerminalCommandRequest,\n KillTerminalCommandResponse\n >;\n \"terminal/release\": AcpRequestShape<ReleaseTerminalRequest, ReleaseTerminalResponse>;\n}\n\nexport interface AcpClientNotificationMap {\n \"session/update\": SessionNotification;\n}\n\ntype ExtensionMethod = `_${string}`;\n\nfunction assertExtensionMethod(method: string): asserts method is ExtensionMethod {\n if (!method.startsWith(\"_\")) {\n throw new Error('Extension method must start with \"_\"');\n }\n}\n\ntype SpawnFunction = (\n command: string,\n args?: ReadonlyArray<string>,\n options?: SpawnOptionsWithoutStdio\n) => ChildProcessWithoutNullStreams;\n\nexport interface AcpTransportOptions {\n command: string;\n args?: readonly string[];\n cwd?: string;\n env?: NodeJS.ProcessEnv;\n firstRequestId?: number;\n spawn?: SpawnFunction;\n}\n\nexport interface AcpTransportClosedEvent {\n code: number | null;\n signal: NodeJS.Signals | null;\n reason: Error;\n stderr: string;\n}\n\nexport class AcpTransport {\n readonly closed: Promise<AcpTransportClosedEvent>;\n\n private readonly command: string;\n private readonly child: ChildProcessWithoutNullStreams;\n private readonly layer: JsonRpcMessageLayer;\n private readonly stderrChunks: string[] = [];\n private resolveClosed: ((value: AcpTransportClosedEvent) => void) | null = null;\n private closeEvent: AcpTransportClosedEvent | null = null;\n private closeReason: Error | null = null;\n\n constructor(options: AcpTransportOptions) {\n const {\n command,\n args = [],\n cwd,\n env,\n firstRequestId,\n spawn = spawnChildProcess,\n } = options;\n\n this.command = command;\n this.closed = new Promise<AcpTransportClosedEvent>((resolve) => {\n this.resolveClosed = resolve;\n });\n\n this.child = spawn(command, [...args], {\n cwd,\n env,\n stdio: [\"pipe\", \"pipe\", \"pipe\"],\n });\n\n this.child.stderr.setEncoding(\"utf8\");\n this.child.stderr.on(\"data\", (chunk) => {\n this.stderrChunks.push(String(chunk));\n });\n\n this.child.stdin.on(\"error\", (error) => {\n const reason = error instanceof Error ? error : new Error(String(error));\n this.close(reason, this.child.exitCode ?? null, this.child.signalCode ?? null);\n });\n\n this.layer = new JsonRpcMessageLayer({\n input: this.child.stdout,\n output: this.child.stdin,\n firstRequestId,\n });\n\n this.child.once(\"error\", (error) => {\n const reason = error instanceof Error ? error : new Error(String(error));\n this.close(reason, this.child.exitCode ?? null, this.child.signalCode ?? null);\n });\n\n this.child.once(\"close\", (code, signal) => {\n const reason =\n this.closeReason ??\n new Error(\n `ACP transport closed (command \"${this.command}\", code: ${code ?? \"null\"}${\n signal ? `, signal: ${signal}` : \"\"\n })`\n );\n this.close(reason, code ?? null, signal ?? null);\n });\n }\n\n sendRequest<TMethod extends keyof AcpAgentRequestMap>(\n method: TMethod,\n params: AcpAgentRequestMap[TMethod][\"params\"],\n options?: JsonRpcRequestOptions\n ): Promise<AcpAgentRequestMap[TMethod][\"result\"]>;\n sendRequest<TResult = unknown>(\n method: string,\n params?: unknown,\n options?: JsonRpcRequestOptions\n ): Promise<TResult>;\n sendRequest(\n method: string,\n params?: unknown,\n options: JsonRpcRequestOptions = {}\n ): Promise<unknown> {\n return this.layer.sendRequest(method, params, options);\n }\n\n sendExtRequest<TResult = unknown>(\n method: ExtensionMethod,\n params?: unknown,\n options?: JsonRpcRequestOptions\n ): Promise<TResult>;\n sendExtRequest<TResult = unknown>(\n method: string,\n params?: unknown,\n options: JsonRpcRequestOptions = {}\n ): Promise<TResult> {\n assertExtensionMethod(method);\n return this.layer.sendRequest(method, params, options) as Promise<TResult>;\n }\n\n sendNotification<TMethod extends keyof AcpAgentNotificationMap>(\n method: TMethod,\n params: AcpAgentNotificationMap[TMethod]\n ): void;\n sendNotification(method: string, params?: unknown): void;\n sendNotification(method: string, params?: unknown): void {\n this.layer.sendNotification(method, params);\n }\n\n sendExtNotification(method: ExtensionMethod, params?: unknown): void;\n sendExtNotification(method: string, params?: unknown): void;\n sendExtNotification(method: string, params?: unknown): void {\n assertExtensionMethod(method);\n this.layer.sendNotification(method, params);\n }\n\n onRequest<TMethod extends keyof AcpClientRequestMap>(\n method: TMethod,\n handler: (\n params: AcpClientRequestMap[TMethod][\"params\"],\n context: { id: RequestId; method: TMethod }\n ) =>\n | AcpClientRequestMap[TMethod][\"result\"]\n | Promise<AcpClientRequestMap[TMethod][\"result\"]>\n ): void;\n onRequest(method: string, handler: JsonRpcRequestHandler): void;\n onRequest(method: string, handler: JsonRpcRequestHandler): void {\n this.layer.onRequest(method, handler);\n }\n\n onExtRequest<TMethod extends ExtensionMethod>(\n method: TMethod,\n handler: (\n params: unknown,\n context: { id: RequestId; method: TMethod }\n ) => unknown | Promise<unknown>\n ): void;\n onExtRequest(method: string, handler: JsonRpcRequestHandler): void;\n onExtRequest(method: string, handler: JsonRpcRequestHandler): void {\n assertExtensionMethod(method);\n this.layer.onRequest(method, handler);\n }\n\n onNotification<TMethod extends keyof AcpClientNotificationMap>(\n method: TMethod,\n handler: (\n params: AcpClientNotificationMap[TMethod],\n context: { method: TMethod }\n ) => void | Promise<void>\n ): void;\n onNotification(method: string, handler: JsonRpcNotificationHandler): void;\n onNotification(method: string, handler: JsonRpcNotificationHandler): void {\n this.layer.onNotification(method, handler);\n }\n\n onExtNotification<TMethod extends ExtensionMethod>(\n method: TMethod,\n handler: (params: unknown, context: { method: TMethod }) => void | Promise<void>\n ): void;\n onExtNotification(method: string, handler: JsonRpcNotificationHandler): void;\n onExtNotification(method: string, handler: JsonRpcNotificationHandler): void {\n assertExtensionMethod(method);\n this.layer.onNotification(method, handler);\n }\n\n getStderrOutput(): string {\n return this.stderrChunks.join(\"\");\n }\n\n pendingRequestCount(): number {\n return this.layer.pendingRequestCount();\n }\n\n dispose(reason: Error = new Error(\"ACP transport disposed\")): void {\n if (this.closeEvent !== null) {\n return;\n }\n\n this.closeReason = reason;\n this.layer.dispose(reason);\n\n if (!this.child.stdin.destroyed && !this.child.stdin.writableEnded) {\n this.child.stdin.end();\n }\n\n if (this.child.exitCode !== null || this.child.signalCode !== null) {\n this.close(reason, this.child.exitCode, this.child.signalCode);\n return;\n }\n\n const killed = this.child.kill();\n if (!killed) {\n this.close(reason, this.child.exitCode, this.child.signalCode);\n }\n }\n\n private close(reason: Error, code: number | null, signal: NodeJS.Signals | null): void {\n if (this.closeEvent !== null) {\n return;\n }\n\n this.layer.dispose(reason);\n this.closeEvent = {\n code,\n signal,\n reason,\n stderr: this.getStderrOutput(),\n };\n this.resolveClosed?.(this.closeEvent);\n this.resolveClosed = null;\n }\n}\n", "import * as fsPromises from \"node:fs/promises\";\nimport { homedir } from \"node:os\";\nimport { join } from \"node:path\";\nimport {\n extractToolCallSummariesFromSessionUpdateStream,\n extractUsageFromSessionUpdateStream,\n type ToolCallSummary,\n} from \"./stream-helpers.js\";\nimport type { Cost, SessionUpdate, SessionUpdateNotification, UsageUpdate } from \"./types.js\";\n\ntype SessionUpdateStreamItem = SessionUpdateNotification | SessionUpdate;\n\nexport type RunExitStatus = \"success\" | \"failed\";\n\nexport interface RunReportUsage {\n used: number;\n size: number;\n updates: number;\n cost?: Cost | null;\n}\n\nexport interface RunReportError {\n message: string;\n toolCallId?: string;\n}\n\nexport interface RunReport {\n runId: string;\n startTime: string;\n endTime: string;\n exitStatus: RunExitStatus;\n toolCalls: ToolCallSummary[];\n usage: RunReportUsage;\n errors: RunReportError[];\n}\n\nexport interface GenerateRunReportOptions {\n runId?: string;\n startTime?: string | Date;\n endTime?: string | Date;\n exitStatus?: RunExitStatus;\n errors?: string[];\n now?: () => Date;\n}\n\nexport type RunReportFileSystem = {\n mkdir(path: string, options?: { recursive?: boolean }): Promise<void>;\n writeFile(\n path: string,\n data: string,\n options?: { encoding?: BufferEncoding },\n ): Promise<void>;\n};\n\nexport interface SaveRunReportOptions {\n fs?: RunReportFileSystem;\n homeDir?: string;\n now?: () => Date;\n}\n\nexport interface SavedRunReportPaths {\n reportsDir: string;\n jsonPath: string;\n summaryPath: string;\n}\n\nexport async function generateRunReportFromSessionUpdateStream(\n stream: AsyncIterable<SessionUpdateStreamItem> | Iterable<SessionUpdateStreamItem>,\n options: GenerateRunReportOptions = {},\n): Promise<RunReport> {\n const now = options.now ?? (() => new Date());\n\n const bufferedEntries: SessionUpdateStreamItem[] = [];\n let runIdFromStream: string | undefined;\n\n for await (const entry of stream) {\n bufferedEntries.push(entry);\n if (runIdFromStream) {\n continue;\n }\n\n if (isSessionUpdateNotification(entry)) {\n const sessionId = toNonEmptyString(entry.params.sessionId);\n if (sessionId) {\n runIdFromStream = sessionId;\n }\n }\n }\n\n const runId = toNonEmptyString(options.runId) ?? runIdFromStream;\n if (!runId) {\n throw new Error(\"Run id is required via options.runId or session/update stream items\");\n }\n\n const startTime = normalizeTime(options.startTime, now);\n const endTime = normalizeTime(options.endTime, now);\n\n const toolCalls = await extractToolCallSummariesFromSessionUpdateStream(bufferedEntries);\n const usageUpdates = await extractUsageFromSessionUpdateStream(bufferedEntries);\n\n const usage = summarizeUsage(usageUpdates);\n const errors = collectErrors(toolCalls, options.errors);\n const exitStatus = options.exitStatus ?? (errors.length > 0 ? \"failed\" : \"success\");\n\n return {\n runId,\n startTime,\n endTime,\n exitStatus,\n toolCalls,\n usage,\n errors,\n };\n}\n\nexport function formatRunReportSummary(report: RunReport): string {\n const lines = [\n `Run ID: ${report.runId}`,\n `Start time: ${report.startTime}`,\n `End time: ${report.endTime}`,\n `Duration: ${toDuration(report.startTime, report.endTime)}`,\n `Exit status: ${report.exitStatus}`,\n `Tool count: ${report.toolCalls.length}`,\n `Token usage: ${report.usage.used}/${report.usage.size}`,\n `Error count: ${report.errors.length}`,\n ];\n\n if (report.usage.cost) {\n lines.push(`Cost: ${report.usage.cost.amount} ${report.usage.cost.currency}`);\n }\n\n return lines.join(\"\\n\");\n}\n\nexport async function saveRunReport(\n report: RunReport,\n options: SaveRunReportOptions = {},\n): Promise<SavedRunReportPaths> {\n const fs = options.fs ?? fsPromises;\n const now = options.now ?? (() => new Date());\n\n const reportsDir = join(options.homeDir ?? homedir(), \".poe-code\", \"reports\");\n await fs.mkdir(reportsDir, { recursive: true });\n\n const timestamp = toTimestampForFileName(now());\n const safeRunId = toSafeFileSegment(report.runId);\n const baseFileName = `${timestamp}-${safeRunId}`;\n\n const jsonPath = join(reportsDir, `${baseFileName}.json`);\n const summaryPath = join(reportsDir, `${baseFileName}.txt`);\n\n await fs.writeFile(jsonPath, JSON.stringify(report, null, 2), { encoding: \"utf8\" });\n await fs.writeFile(summaryPath, formatRunReportSummary(report), { encoding: \"utf8\" });\n\n return {\n reportsDir,\n jsonPath,\n summaryPath,\n };\n}\n\nfunction isSessionUpdateNotification(entry: SessionUpdateStreamItem): entry is SessionUpdateNotification {\n return (\n typeof (entry as SessionUpdateNotification).jsonrpc === \"string\" &&\n (entry as SessionUpdateNotification).method === \"session/update\"\n );\n}\n\nfunction normalizeTime(value: string | Date | undefined, now: () => Date): string {\n if (value instanceof Date) {\n return value.toISOString();\n }\n\n if (typeof value === \"string\" && value.length > 0) {\n const parsed = new Date(value);\n if (!Number.isNaN(parsed.getTime())) {\n return parsed.toISOString();\n }\n }\n\n return now().toISOString();\n}\n\nfunction summarizeUsage(updates: readonly UsageUpdate[]): RunReportUsage {\n let used = 0;\n let size = 0;\n let cost: Cost | null | undefined;\n\n for (const update of updates) {\n used += update.used;\n size += update.size;\n\n if (update.cost !== undefined) {\n cost = update.cost;\n }\n }\n\n const usage: RunReportUsage = {\n used,\n size,\n updates: updates.length,\n };\n\n if (cost !== undefined) {\n usage.cost = cost;\n }\n\n return usage;\n}\n\nfunction collectErrors(\n toolCalls: readonly ToolCallSummary[],\n additionalErrors: readonly string[] | undefined,\n): RunReportError[] {\n const errors: RunReportError[] = [];\n\n for (const toolCall of toolCalls) {\n if (toolCall.status !== \"failed\") {\n continue;\n }\n\n errors.push({\n toolCallId: toolCall.toolCallId,\n message: toErrorMessage(toolCall),\n });\n }\n\n if (additionalErrors) {\n for (const message of additionalErrors) {\n const text = toNonEmptyString(message);\n if (text) {\n errors.push({ message: text });\n }\n }\n }\n\n return errors;\n}\n\nfunction toErrorMessage(toolCall: ToolCallSummary): string {\n if (typeof toolCall.rawOutput === \"string\" && toolCall.rawOutput.length > 0) {\n return toolCall.rawOutput;\n }\n\n if (toolCall.rawOutput instanceof Error && toolCall.rawOutput.message.length > 0) {\n return toolCall.rawOutput.message;\n }\n\n if (toolCall.rawOutput !== undefined && toolCall.rawOutput !== null) {\n const encoded = trySerialize(toolCall.rawOutput);\n if (encoded) {\n return encoded;\n }\n }\n\n return `${toolCall.title} failed`;\n}\n\nfunction trySerialize(value: unknown): string | undefined {\n try {\n const serialized = JSON.stringify(value);\n if (typeof serialized === \"string\" && serialized.length > 0) {\n return serialized;\n }\n } catch {\n return undefined;\n }\n\n return undefined;\n}\n\nfunction toDuration(startTime: string, endTime: string): string {\n const startMs = Date.parse(startTime);\n const endMs = Date.parse(endTime);\n\n if (Number.isNaN(startMs) || Number.isNaN(endMs) || endMs < startMs) {\n return \"unknown\";\n }\n\n const seconds = (endMs - startMs) / 1000;\n return `${Number(seconds.toFixed(3))}s`;\n}\n\nfunction toSafeFileSegment(value: string): string {\n let output = \"\";\n\n for (const char of value) {\n if (isAsciiLetterOrDigit(char) || char === \"-\" || char === \"_\") {\n output += char;\n continue;\n }\n\n output += \"-\";\n }\n\n return output.length > 0 ? output : \"run\";\n}\n\nfunction isAsciiLetterOrDigit(value: string): boolean {\n const code = value.charCodeAt(0);\n return (\n (code >= 48 && code <= 57) ||\n (code >= 65 && code <= 90) ||\n (code >= 97 && code <= 122)\n );\n}\n\nfunction toTimestampForFileName(value: Date): string {\n return [\n String(value.getUTCFullYear()),\n pad(value.getUTCMonth() + 1, 2),\n pad(value.getUTCDate(), 2),\n ].join(\"\")\n + \"-\"\n + [\n pad(value.getUTCHours(), 2),\n pad(value.getUTCMinutes(), 2),\n pad(value.getUTCSeconds(), 2),\n ].join(\"\")\n + \"-\"\n + pad(value.getUTCMilliseconds(), 3);\n}\n\nfunction pad(value: number, size: number): string {\n const text = String(value);\n if (text.length >= size) {\n return text;\n }\n\n return `${\"0\".repeat(size - text.length)}${text}`;\n}\n\nfunction toNonEmptyString(value: unknown): string | undefined {\n if (typeof value !== \"string\" || value.length === 0) {\n return undefined;\n }\n\n return value;\n}\n", "import path from \"node:path\";\nimport { homedir } from \"node:os\";\nimport { mkdir, open, type FileHandle } from \"node:fs/promises\";\nimport type { AcpEvent } from \"../types.js\";\nimport type { AcpMiddleware, SpawnContext } from \"../middleware.js\";\n\nfunction pad(value: number, width: number): string {\n return String(value).padStart(width, \"0\");\n}\n\nfunction formatTimestamp(date: Date): { day: string; time: string; milliseconds: string } {\n const day = `${date.getUTCFullYear()}${pad(date.getUTCMonth() + 1, 2)}${pad(date.getUTCDate(), 2)}`;\n const time = `${pad(date.getUTCHours(), 2)}${pad(date.getUTCMinutes(), 2)}${pad(date.getUTCSeconds(), 2)}`;\n const milliseconds = pad(date.getUTCMilliseconds(), 3);\n return { day, time, milliseconds };\n}\n\nfunction normalizeAgent(agent: string): string {\n let normalized = \"\";\n for (const char of agent) {\n const code = char.charCodeAt(0);\n const isLower = code >= 97 && code <= 122;\n const isUpper = code >= 65 && code <= 90;\n const isDigit = code >= 48 && code <= 57;\n\n if (isLower || isUpper || isDigit || char === \"-\" || char === \"_\") {\n normalized += char;\n } else {\n normalized += \"-\";\n }\n }\n\n return normalized.length > 0 ? normalized : \"agent\";\n}\n\nfunction resolveStartedAt(value: Date | undefined): Date {\n if (!(value instanceof Date) || Number.isNaN(value.getTime())) {\n return new Date();\n }\n\n return value;\n}\n\nfunction resolveLogFilePath(ctx: SpawnContext): string {\n if (ctx.logPath) {\n return ctx.logPath;\n }\n const baseDir = ctx.logDir ?? path.join(homedir(), \".poe-code\", \"spawn-logs\");\n if (ctx.logFileName) {\n return path.join(baseDir, ctx.logFileName);\n }\n const startedAt = resolveStartedAt(ctx.startedAt);\n const { day, time, milliseconds } = formatTimestamp(startedAt);\n const fileName = `${day}-${time}-${milliseconds}-${normalizeAgent(ctx.agent)}.jsonl`;\n return path.join(baseDir, fileName);\n}\n\nclass SpawnLogWriter {\n private fileHandle: FileHandle | undefined;\n\n private isDisabled = false;\n\n readonly filePath: string;\n\n private readonly logDirPath: string;\n\n constructor(ctx: SpawnContext) {\n this.filePath = resolveLogFilePath(ctx);\n this.logDirPath = path.dirname(this.filePath);\n }\n\n async writeEvent(event: AcpEvent): Promise<void> {\n if (this.isDisabled) {\n return;\n }\n\n try {\n await this.ensureOpen();\n if (!this.fileHandle) {\n return;\n }\n\n const meta = (event as { _meta?: Record<string, unknown> })._meta;\n const toLog = meta?.raw ?? event;\n await this.fileHandle.appendFile(`${JSON.stringify(toLog)}\\n`, \"utf8\");\n } catch {\n this.isDisabled = true;\n await this.close();\n }\n }\n\n async close(): Promise<void> {\n if (!this.fileHandle) {\n return;\n }\n\n try {\n await this.fileHandle.close();\n } catch {\n // Ignore close errors to avoid disrupting event processing.\n } finally {\n this.fileHandle = undefined;\n }\n }\n\n private async ensureOpen(): Promise<void> {\n if (this.fileHandle || this.isDisabled) {\n return;\n }\n\n try {\n await mkdir(this.logDirPath, { recursive: true });\n this.fileHandle = await open(this.filePath, \"a\");\n } catch {\n this.isDisabled = true;\n }\n }\n}\n\nasync function writePreloadedEvents(writer: SpawnLogWriter, events: AcpEvent[]): Promise<void> {\n for (const event of events) {\n await writer.writeEvent(event);\n }\n}\n\nexport const spawnLog: AcpMiddleware = async (ctx, next) => {\n await next();\n\n const source = ctx.eventStream;\n const writer = new SpawnLogWriter(ctx);\n ctx.logFile = writer.filePath;\n\n await writePreloadedEvents(writer, ctx.events);\n\n if (!source) {\n await writer.close();\n return;\n }\n\n ctx.eventStream = (async function* () {\n try {\n for await (const event of source) {\n await writer.writeEvent(event);\n yield event;\n }\n } finally {\n await writer.close();\n }\n })();\n};\n", "import type {\n CommandRunner,\n CommandRunnerOptions,\n CommandRunnerResult\n} from \"@poe-code/agent-spawn\";\nimport { buildSpawnArgs } from \"@poe-code/agent-spawn\";\nimport { createBinaryExistsDetectors } from \"@poe-code/agent-harness-tools\";\n\nexport type {\n CommandRunner,\n CommandRunnerOptions,\n CommandRunnerResult\n} from \"@poe-code/agent-spawn\";\n\nexport function formatCommandRunnerResult(\n result: CommandRunnerResult\n): string {\n const stdout =\n result.stdout.length > 0 ? result.stdout : \"<empty>\";\n const stderr =\n result.stderr.length > 0 ? result.stderr : \"<empty>\";\n return `stdout:\\n${stdout}\\nstderr:\\n${stderr}`;\n}\n\nexport interface RunAndMatchOutputOptions {\n command: string;\n args: string[];\n expectedOutput: string;\n commandOptions?: CommandRunnerOptions;\n skipOnDryRun?: boolean;\n}\n\nexport function describeCommandExpectation(\n command: string,\n args: string[],\n expectedOutput: string\n): string {\n return `${renderCommandLine(command, args)} (expecting \"${expectedOutput}\")`;\n}\n\nexport interface CommandExpectationCheckOptions\n extends RunAndMatchOutputOptions {\n id: string;\n}\n\nexport function createCommandExpectationCheck(\n options: CommandExpectationCheckOptions\n): CommandCheck {\n return {\n id: options.id,\n description: describeCommandExpectation(\n options.command,\n options.args,\n options.expectedOutput\n ),\n async run(context) {\n await runAndMatchOutput(context, options);\n }\n };\n}\n\nexport async function runAndMatchOutput(\n context: CommandCheckContext,\n options: RunAndMatchOutputOptions\n): Promise<void> {\n const rendered = renderCommandLine(options.command, options.args);\n if (options.skipOnDryRun !== false && context.isDryRun) {\n if (context.logDryRun) {\n context.logDryRun(\n `Dry run: ${rendered} (expecting \"${options.expectedOutput}\")`\n );\n }\n return;\n }\n\n const result = options.commandOptions\n ? await context.runCommand(options.command, options.args, options.commandOptions)\n : await context.runCommand(options.command, options.args);\n if (result.exitCode !== 0) {\n const detail = formatCommandRunnerResult(result);\n throw new Error(\n [`Command ${rendered} failed with exit code ${result.exitCode}.`, detail].join(\"\\n\")\n );\n }\n\n if (!stdoutMatchesExpected(result.stdout, options.expectedOutput)) {\n const detail = formatCommandRunnerResult(result);\n const received = result.stdout.trim();\n throw new Error(\n [\n `Command ${rendered} failed: expected \"${options.expectedOutput}\" but received \"${received}\".`,\n detail\n ].join(\"\\n\")\n );\n }\n}\n\nexport function stdoutMatchesExpected(stdout: string, expected: string): boolean {\n const trimmed = stdout.trim();\n if (trimmed === expected) {\n return true;\n }\n\n const lines = stdout\n .split(/\\r?\\n/)\n .map((line) => line.trim())\n .filter((line) => line.length > 0);\n\n if (lines.some((line) => line === expected)) {\n return true;\n }\n\n for (const line of lines) {\n if (line[0] !== \"{\") continue;\n try {\n const parsed = JSON.parse(line) as { type?: string; result?: string };\n if (parsed.type === \"result\" && parsed.result === expected) {\n return true;\n }\n } catch {\n continue;\n }\n }\n\n return false;\n}\n\nfunction renderCommandLine(command: string, args: string[]): string {\n return [command, ...args].map(quoteIfNeeded).join(\" \").trim();\n}\n\nfunction quoteIfNeeded(value: string): string {\n if (value.length === 0) {\n return '\"\"';\n }\n if (needsQuoting(value)) {\n return `\"${value.replaceAll('\"', '\\\\\"')}\"`;\n }\n return value;\n}\n\nfunction needsQuoting(value: string): boolean {\n return (\n value.includes(\" \") ||\n value.includes(\"\\t\") ||\n value.includes(\"\\n\")\n );\n}\n\nexport interface CommandCheckContext {\n isDryRun: boolean;\n runCommand: CommandRunner;\n logDryRun?: (message: string) => void;\n}\n\nexport interface CommandCheck {\n id: string;\n description?: string;\n run(context: CommandCheckContext): Promise<void>;\n}\n\nexport function createSpawnHealthCheck(\n agentId: string,\n options: { model?: string; expectedOutput: string }\n): CommandCheck {\n const prompt = `Output exactly: ${options.expectedOutput}`;\n const { binaryName, args, env: modeEnv } = buildSpawnArgs(agentId, {\n prompt,\n model: options.model,\n mode: \"yolo\"\n });\n return {\n id: `${agentId}-cli-health`,\n description: `spawn ${agentId} (expecting \"${options.expectedOutput}\")`,\n async run(context) {\n if (context.isDryRun) {\n context.logDryRun?.(\n `Dry run: ${[binaryName, ...args].join(\" \")} (expecting \"${options.expectedOutput}\")`\n );\n return;\n }\n\n const result = modeEnv\n ? await context.runCommand(binaryName, args, { env: modeEnv })\n : await context.runCommand(binaryName, args);\n\n if (result.exitCode !== 0) {\n throw new Error(\n `spawn ${agentId} failed with exit code ${result.exitCode}.\\n${formatCommandRunnerResult(result)}`\n );\n }\n\n if (!result.stdout.includes(options.expectedOutput)) {\n throw new Error(\n `spawn ${agentId}: expected \"${options.expectedOutput}\" in stdout.\\n${formatCommandRunnerResult(result)}`\n );\n }\n }\n };\n}\n\n/**\n * Creates a check that detects if a binary exists using multiple fallback methods.\n * This is useful in Docker/containerized environments where PATH may not be updated after npm install.\n *\n * @param binaryName - The name of the binary to check for (e.g., \"claude\", \"codex\")\n * @param id - Unique identifier for the check\n * @param description - Human-readable description of what's being checked\n * @returns A CommandCheck that verifies the binary using multiple detection methods\n */\nexport function createBinaryExistsCheck(\n binaryName: string,\n id: string,\n description: string\n): CommandCheck {\n return {\n id,\n description,\n async run({ runCommand }) {\n for (const detector of createBinaryExistsDetectors(binaryName)) {\n const result = await runCommand(detector.command, detector.args);\n if (detector.validate(result)) {\n return;\n }\n }\n\n throw new Error(`${binaryName} CLI binary not found on PATH.`);\n }\n };\n}\n", "import type {\n CommandRunner,\n CommandCheckContext,\n CommandCheck\n} from \"../utils/command-checks.js\";\n\nexport interface InstallContext {\n isDryRun: boolean;\n runCommand: CommandRunner;\n logger: (message: string) => void;\n platform: NodeJS.Platform;\n}\n\nexport interface InstallCommand {\n id: string;\n command: string;\n args: string[];\n platforms?: NodeJS.Platform[];\n}\n\nexport interface ServiceInstallDefinition {\n id: string;\n summary: string;\n check: CommandCheck;\n steps: InstallCommand[];\n postChecks?: CommandCheck[];\n successMessage?: string;\n}\n\nexport async function runServiceInstall(\n definition: ServiceInstallDefinition,\n context: InstallContext\n): Promise<boolean> {\n const checkContext: CommandCheckContext = {\n isDryRun: context.isDryRun,\n runCommand: context.runCommand\n };\n\n let needsInstall = false;\n try {\n await definition.check.run(checkContext);\n context.logger(`${definition.summary} already installed.`);\n } catch (error) {\n const detail =\n error instanceof Error ? error.message : String(error);\n context.logger(`${definition.summary} not detected: ${detail}`);\n needsInstall = true;\n }\n\n if (!needsInstall) {\n return false;\n }\n\n if (context.isDryRun) {\n logInstallDryRun(definition, context);\n return true;\n }\n\n const platformSteps = filterStepsByPlatform(definition.steps, context.platform);\n for (const step of platformSteps) {\n await runInstallStep(step, context);\n }\n\n await definition.check.run(checkContext);\n\n if (definition.postChecks) {\n for (const postCheck of definition.postChecks) {\n await postCheck.run(checkContext);\n }\n }\n\n context.logger(\n definition.successMessage ?? `${definition.summary} installed.`\n );\n return true;\n}\n\nfunction describeInstallCommand(step: InstallCommand): string {\n return `[${step.id}] ${formatCommand(step.command, step.args)}`;\n}\n\nfunction formatCommand(command: string, args: string[]): string {\n return [command, ...args.map(quoteIfNeeded)].join(\" \");\n}\n\nfunction quoteIfNeeded(value: string): string {\n if (value.length === 0) {\n return '\"\"';\n }\n if (value.includes(\" \") || value.includes(\"\\t\") || value.includes(\"\\n\")) {\n return `\"${value.replaceAll('\"', '\\\\\"')}\"`;\n }\n return value;\n}\n\nfunction filterStepsByPlatform(\n steps: InstallCommand[],\n platform: NodeJS.Platform\n): InstallCommand[] {\n return steps.filter(\n (step) => !step.platforms || step.platforms.includes(platform)\n );\n}\n\nfunction logInstallDryRun(\n definition: ServiceInstallDefinition,\n context: InstallContext\n): void {\n context.logger(`Dry run: would install ${definition.summary}.`);\n const platformSteps = filterStepsByPlatform(definition.steps, context.platform);\n for (const step of platformSteps) {\n context.logger(`Dry run: ${describeInstallCommand(step)}`);\n }\n}\n\nasync function runInstallStep(\n step: InstallCommand,\n context: InstallContext\n): Promise<void> {\n context.logger(`Running ${describeInstallCommand(step)}`);\n const result = await context.runCommand(step.command, step.args);\n if (result.exitCode !== 0) {\n const stderr = result.stderr.trim();\n const suffix = stderr.length > 0 ? `: ${stderr}` : \"\";\n throw new Error(\n `${describeInstallCommand(step)} failed with exit code ${result.exitCode}${suffix}`\n );\n }\n}\n", "import type {\n ProviderService,\n ProviderContext,\n ProviderBranding,\n ProviderConfigurePrompts,\n ProviderIsolatedEnv\n} from \"../cli/service-registry.js\";\nimport {\n runMutations,\n type Mutation,\n type MutationObservers\n} from \"@poe-code/config-mutations\";\nimport {\n runServiceInstall,\n type ServiceInstallDefinition\n} from \"../services/service-install.js\";\n// Template imports are lazy to avoid breaking tsc output when imported\n// by generate-bin-wrappers.mjs (Node.js can't resolve .mustache as ESM modules)\nconst templateImports: Record<string, () => Promise<{ default: string }>> = {\n \"py-poe-spawn/env.mustache\": () => import(\"../templates/py-poe-spawn/env.mustache\"),\n \"py-poe-spawn/main.py.mustache\": () => import(\"../templates/py-poe-spawn/main.py.mustache\"),\n \"py-poe-spawn/requirements.txt.mustache\": () => import(\"../templates/py-poe-spawn/requirements.txt.mustache\"),\n \"codex/config.toml.mustache\": () => import(\"../templates/codex/config.toml.mustache\"),\n};\n\nasync function loadTemplate(templateId: string): Promise<string> {\n const loader = templateImports[templateId];\n if (!loader) {\n throw new Error(`Template not found: ${templateId}`);\n }\n const module = await loader();\n return module.default;\n}\n\ninterface ManifestVersionDefinition {\n configure: Mutation[];\n unconfigure?: Mutation[];\n}\n\nexport interface ServiceRunOptions {\n observers?: MutationObservers;\n}\n\ninterface CreateProviderOptions<\n ConfigureOptions,\n UnconfigureOptions,\n SpawnOptions\n> {\n name: string;\n aliases?: string[];\n label: string;\n id: string;\n summary: string;\n branding?: ProviderBranding;\n disabled?: boolean;\n supportsStdinPrompt?: boolean;\n supportsMcpSpawn?: boolean;\n requiresProvider?: boolean;\n configurePrompts?: ProviderConfigurePrompts;\n postConfigureMessages?: string[];\n extendConfigurePayload?: ProviderService<\n ConfigureOptions,\n UnconfigureOptions,\n SpawnOptions\n >[\"extendConfigurePayload\"];\n isolatedEnv?: ProviderIsolatedEnv;\n manifest: ManifestVersionDefinition;\n install?: ServiceInstallDefinition;\n test?: ProviderService<ConfigureOptions, UnconfigureOptions, SpawnOptions>[\"test\"];\n spawn?: ProviderService<\n ConfigureOptions,\n UnconfigureOptions,\n SpawnOptions\n >[\"spawn\"];\n}\n\nexport function createProvider<\n ConfigureOptions = any,\n UnconfigureOptions = ConfigureOptions,\n SpawnOptions = any\n>(\n opts: CreateProviderOptions<ConfigureOptions, UnconfigureOptions, SpawnOptions>\n): ProviderService<ConfigureOptions, UnconfigureOptions, SpawnOptions> {\n const provider: ProviderService<\n ConfigureOptions,\n UnconfigureOptions,\n SpawnOptions\n > = {\n id: opts.id,\n summary: opts.summary,\n name: opts.name,\n aliases: opts.aliases,\n label: opts.label,\n branding: opts.branding,\n disabled: opts.disabled,\n supportsStdinPrompt: opts.supportsStdinPrompt,\n supportsMcpSpawn: opts.supportsMcpSpawn,\n requiresProvider: opts.requiresProvider ?? true,\n configurePrompts: opts.configurePrompts,\n postConfigureMessages: opts.postConfigureMessages,\n extendConfigurePayload: opts.extendConfigurePayload,\n isolatedEnv: opts.isolatedEnv,\n async configure(context, runOptions) {\n await runMutations(opts.manifest.configure, {\n fs: context.fs,\n homeDir: context.env.homeDir,\n observers: runOptions?.observers,\n templates: loadTemplate,\n pathMapper: context.pathMapper\n }, context.options as Record<string, unknown>);\n context.command.flushDryRun({ emitIfEmpty: false });\n },\n async unconfigure(context, runOptions) {\n if (!opts.manifest.unconfigure) {\n return false;\n }\n const result = await runMutations(opts.manifest.unconfigure, {\n fs: context.fs,\n homeDir: context.env.homeDir,\n observers: runOptions?.observers,\n templates: loadTemplate,\n pathMapper: context.pathMapper\n }, context.options as Record<string, unknown>);\n context.command.flushDryRun({ emitIfEmpty: false });\n return result.changed;\n }\n };\n\n if (opts.install) {\n provider.install = createInstallRunner(opts.install);\n }\n\n if (opts.test) {\n provider.test = opts.test;\n }\n\n if (opts.spawn) {\n provider.spawn = opts.spawn;\n }\n\n return provider;\n}\n\nfunction createInstallRunner(definition: ServiceInstallDefinition) {\n return async (context: ProviderContext): Promise<void> => {\n await runServiceInstall(definition, {\n isDryRun: context.logger.context.dryRun,\n runCommand: context.command.runCommand,\n logger: (message) => context.logger.verbose(message),\n platform: context.env.platform\n });\n };\n}\n", "export const FRONTIER_MODELS = [\n \"anthropic/claude-opus-4.7\",\n \"anthropic/claude-sonnet-4.6\",\n \"openai/gpt-5.3-codex\",\n \"openai/gpt-5.5\",\n \"google/gemini-3.1-pro\"\n] as const;\n\nexport const DEFAULT_FRONTIER_MODEL = \"anthropic/claude-opus-4.7\";\n\nexport const DEFAULT_TEXT_MODEL = \"anthropic/claude-sonnet-4.6\";\nexport const DEFAULT_IMAGE_BOT = \"google/nano-banana-pro\";\nexport const DEFAULT_AUDIO_BOT = \"elevenlabs/elevenlabs-v3\";\nexport const DEFAULT_VIDEO_BOT = \"google/veo-3.1\";\n\nexport const CLAUDE_CODE_VARIANTS = {\n haiku: \"anthropic/claude-haiku-4.5\",\n sonnet: \"anthropic/claude-sonnet-4.6\",\n opus: \"anthropic/claude-opus-4.7\"\n} as const;\n\nexport const DEFAULT_CLAUDE_CODE_MODEL = CLAUDE_CODE_VARIANTS.sonnet;\n\n/**\n * Extracts the model ID from a namespaced model slug (lowercase).\n * e.g., \"anthropic/claude-sonnet-4.6\" -> \"claude-sonnet-4.6\"\n */\nexport function stripModelNamespace(model: string): string {\n const slashIndex = model.indexOf(\"/\");\n const id = slashIndex === -1 ? model : model.slice(slashIndex + 1);\n return id.toLowerCase();\n}\n\nexport const CODEX_MODELS = [\n \"openai/gpt-5.5\",\n \"openai/gpt-5.4\",\n \"openai/gpt-5.3-codex\",\n \"openai/gpt-5.2-codex\",\n \"openai/gpt-5.2\",\n \"openai/gpt-5.2-chat\",\n \"openai/gpt-5.2-pro\",\n \"openai/gpt-5.1\",\n \"openai/gpt-5.1-codex-mini\",\n \"anthropic/claude-opus-4.7\"\n] as const;\nexport const DEFAULT_CODEX_MODEL = CODEX_MODELS[0];\n\nexport const KIMI_MODELS = [\n \"novitaai/kimi-k2.5\",\n \"novitaai/kimi-k2-thinking\",\n \"novitaai/kimi-k2.5-fw\",\n] as const;\nexport const DEFAULT_KIMI_MODEL = KIMI_MODELS[0];\n\nexport const GOOSE_MODELS = FRONTIER_MODELS;\nexport const DEFAULT_GOOSE_MODEL = DEFAULT_FRONTIER_MODEL;\n\nexport const DEFAULT_REASONING = \"medium\";\nexport const PROVIDER_NAME = \"poe\";\nexport const FEEDBACK_URL = \"https://github.com/poe-platform/poe-code/issues\";\n", "import type { CliEnvironment } from \"../cli/environment.js\";\nimport {\n createBinaryExistsCheck,\n createSpawnHealthCheck\n} from \"../utils/command-checks.js\";\nimport { type ServiceInstallDefinition } from \"../services/service-install.js\";\nimport {\n configMutation,\n fileMutation,\n templateMutation,\n type ConfigObject,\n isConfigObject\n} from \"@poe-code/config-mutations\";\nimport { createProvider } from \"./create-provider.js\";\nimport {\n CODEX_MODELS,\n DEFAULT_CODEX_MODEL,\n DEFAULT_REASONING,\n PROVIDER_NAME,\n stripModelNamespace\n} from \"../cli/constants.js\";\nimport { codexAgent } from \"@poe-code/agent-defs\";\nimport type { ActiveProvider } from \"../cli/commands/shared.js\";\n\ntype CodexConfigureContext = {\n env: CliEnvironment;\n provider: ActiveProvider;\n model: string;\n reasoningEffort: string;\n timestamp?: () => string;\n};\n\ntype CodexUnconfigureContext = {\n env: CliEnvironment;\n provider?: { id: string };\n};\n\nconst PROFILE_KEYWORDS = [\"opus\", \"sonnet\", \"haiku\", \"codex\", \"pro\"] as const;\n\nexport function deriveCodexProfileName(model: string): string {\n const stripped = stripModelNamespace(model);\n const parts = stripped.split(/[-_.]/);\n for (const keyword of PROFILE_KEYWORDS) {\n if (parts.includes(keyword)) return keyword;\n }\n return stripped;\n}\n\nexport const CODEX_INSTALL_DEFINITION: ServiceInstallDefinition = {\n id: \"codex\",\n summary: \"Codex CLI\",\n check: createBinaryExistsCheck(\n \"codex\",\n \"codex-cli-binary\",\n \"Codex CLI binary must exist\"\n ),\n steps: [\n {\n id: \"install-codex-cli-npm\",\n command: \"npm\",\n args: [\"install\", \"-g\", \"@openai/codex\"]\n }\n ],\n successMessage: \"Installed Codex CLI via npm.\"\n};\n\nfunction deriveProviderIdFromDocument(document: ConfigObject): string | undefined {\n if (typeof document[\"model_provider\"] === \"string\") {\n return document[\"model_provider\"] as string;\n }\n const profiles = document[\"profiles\"];\n if (isConfigObject(profiles)) {\n for (const name of Object.keys(profiles)) {\n const profile = profiles[name];\n if (isConfigObject(profile) && typeof profile[\"model_provider\"] === \"string\") {\n return profile[\"model_provider\"] as string;\n }\n }\n }\n const providers = document[\"model_providers\"];\n if (isConfigObject(providers)) {\n const keys = Object.keys(providers);\n if (keys.length > 0) {\n return keys[0]!;\n }\n }\n return undefined;\n}\n\nfunction stripCodexConfiguration(\n document: ConfigObject,\n providerId?: string\n): { changed: boolean; empty: boolean } {\n if (!isConfigObject(document)) {\n return { changed: false, empty: false };\n }\n\n const id = providerId ?? deriveProviderIdFromDocument(document);\n if (!id) {\n return { changed: false, empty: false };\n }\n\n let changed = false;\n\n // Handle flat (legacy) config: top-level model_provider matches provider\n if (document[\"model_provider\"] === id) {\n delete document[\"model_provider\"];\n delete document[\"model\"];\n delete document[\"model_reasoning_effort\"];\n delete document[\"model_verbosity\"];\n changed = true;\n }\n\n // Handle profile-based config\n const profiles = document[\"profiles\"];\n if (isConfigObject(profiles)) {\n for (const name of Object.keys(profiles)) {\n const profile = profiles[name];\n if (isConfigObject(profile) && profile[\"model_provider\"] === id) {\n delete profiles[name];\n changed = true;\n }\n }\n if (isTableEmpty(profiles)) {\n delete document[\"profiles\"];\n }\n }\n\n // Clean up model_providers entry for this provider\n const providers = document[\"model_providers\"];\n if (isConfigObject(providers) && id in providers) {\n delete providers[id];\n if (isTableEmpty(providers)) {\n delete document[\"model_providers\"];\n }\n changed = true;\n }\n\n return {\n changed,\n empty: isTableEmpty(document)\n };\n}\n\nfunction isTableEmpty(value: unknown): value is ConfigObject {\n return isConfigObject(value) && Object.keys(value).length === 0;\n}\n\nexport const codexService = createProvider<\n CodexConfigureContext,\n CodexUnconfigureContext\n>({\n ...codexAgent,\n supportsStdinPrompt: true,\n configurePrompts: {\n model: {\n label: \"Codex model\",\n defaultValue: DEFAULT_CODEX_MODEL,\n choices: CODEX_MODELS.map((id) => ({\n title: id,\n value: id\n }))\n },\n reasoningEffort: {\n label: \"Codex reasoning effort\",\n defaultValue: DEFAULT_REASONING\n }\n },\n isolatedEnv: {\n agentBinary: codexAgent.binaryName!,\n configProbe: { kind: \"isolatedFile\", relativePath: \"config.toml\" },\n env: {\n CODEX_HOME: { kind: \"isolatedDir\" },\n XDG_CONFIG_HOME: { kind: \"isolatedDir\" }\n }\n },\n test(context) {\n return context.runCheck(\n createSpawnHealthCheck(\"codex\", {\n model: context.model ?? DEFAULT_CODEX_MODEL,\n expectedOutput: \"CODEX_OK\"\n })\n );\n },\n manifest: {\n configure: [\n fileMutation.ensureDirectory({ path: \"~/.codex\" }),\n fileMutation.backup({ target: \"~/.codex/config.toml\" }),\n configMutation.transform({\n target: \"~/.codex/config.toml\",\n transform: (document, ctx) => {\n const options = ctx as unknown as CodexConfigureContext;\n const result = stripCodexConfiguration(document as ConfigObject, options.provider?.id);\n return { changed: result.changed, content: result.empty ? null : document };\n }\n }),\n templateMutation.mergeToml({\n target: \"~/.codex/config.toml\",\n templateId: \"codex/config.toml.mustache\",\n context: (ctx) => {\n const options = ctx as unknown as CodexConfigureContext;\n const model = options.model ?? DEFAULT_CODEX_MODEL;\n return {\n apiKey: options.provider?.credential,\n baseUrl: options.provider?.baseUrl ?? \"\",\n model: stripModelNamespace(model),\n providerId: options.provider?.id ?? PROVIDER_NAME,\n reasoningEffort: options.reasoningEffort,\n profileName: deriveCodexProfileName(model)\n };\n }\n })\n ],\n unconfigure: [\n configMutation.transform({\n target: \"~/.codex/config.toml\",\n transform: (document, ctx) => {\n const options = ctx as unknown as CodexUnconfigureContext;\n const result = stripCodexConfiguration(document as ConfigObject, options.provider?.id);\n if (!result.changed) {\n return { changed: false, content: document };\n }\n return {\n changed: true,\n content: result.empty ? null : document\n };\n }\n })\n ]\n },\n install: CODEX_INSTALL_DEFINITION\n});\n\nexport const provider = codexService;\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["POE_API_KEY={{apiKey}}\nPOE_BASE_URL=https://api.poe.com/v1\nMODEL={{model}}\n", "import os\nfrom openai import OpenAI\nfrom dotenv import load_dotenv\n\nload_dotenv()\n\nclient = OpenAI(\n api_key=os.getenv(\"POE_API_KEY\"),\n base_url=os.getenv(\"POE_BASE_URL\")\n)\n\nresponse = client.chat.completions.create(\n model=os.getenv(\"MODEL\", \"{{model}}\"),\n messages=[{\"role\": \"user\", \"content\": \"Tell me a joke\"}]\n)\n\nprint(response.choices[0].message.content)\n", "openai>=1.0.0\npython-dotenv>=1.0.0\n", "model_provider = \"{{providerId}}\"\nmodel = \"{{{model}}}\"\nmodel_reasoning_effort = \"{{reasoningEffort}}\"\nmodel_verbosity = \"medium\"\n\n[profiles.\"{{{profileName}}}\"]\nmodel = \"{{{model}}}\"\nmodel_provider = \"{{providerId}}\"\nmodel_reasoning_effort = \"{{reasoningEffort}}\"\nmodel_verbosity = \"medium\"\n\n[model_providers.{{providerId}}]\nname = \"{{providerId}}\"\nbase_url = \"{{{baseUrl}}}\"\nwire_api = \"responses\"\nexperimental_bearer_token = \"{{apiKey}}\"\nrequires_openai_auth = false\nsupports_websockets = false\n", "import { spawn as spawnChildProcess } from \"node:child_process\";\nimport { registerExecutionEnvFactory } from \"@poe-code/agent-harness-tools\";\nimport type { ExecutionEnvFactory, OpenedEnv, RunSpec } from \"@poe-code/agent-harness-tools\";\nimport { dockerExecutionEnvFactory, hostExecutionEnvFactory } from \"@poe-code/process-runner\";\nimport { e2bExecutionEnvFactory } from \"@poe-code/runner-e2b\";\n\nregisterExecutionEnvFactory(hostExecutionEnvFactory);\nregisterExecutionEnvFactory(dockerExecutionEnvFactory);\nregisterExecutionEnvFactory(e2bExecutionEnvFactory);\n\nif (isVitest()) {\n registerExecutionEnvFactory(createTestHostExecutionEnvFactory());\n}\n\nfunction isVitest(): boolean {\n return process.env.VITEST !== undefined || process.env.VITEST_POOL_ID !== undefined;\n}\n\nfunction createTestHostExecutionEnvFactory(): ExecutionEnvFactory {\n return {\n type: \"host\",\n supportsDetach: false,\n open: ((openSpec: Parameters<ExecutionEnvFactory[\"open\"]>[0]) => {\n return {\n id: \"host\",\n job: null,\n async uploadWorkspace() {\n return { files: 0, bytes: 0, skipped: [] };\n },\n async downloadWorkspace() {\n return { files: 0, bytes: 0, conflicts: [] };\n },\n exec(spec) {\n return runHost(spawnChildProcess, spec);\n },\n async detach() {\n throw new Error(\n \"host runtime does not support detach because host has no addressable env\"\n );\n },\n shell() {\n return runHost(spawnChildProcess, {\n command: openSpec.shellSpec?.command ?? openSpec.env.SHELL ?? process.env.SHELL ?? \"sh\",\n args: openSpec.shellSpec?.args,\n cwd: openSpec.cwd,\n env:\n openSpec.shellSpec && \"env\" in openSpec.shellSpec\n ? openSpec.shellSpec.env\n : openSpec.env,\n stdin: \"inherit\",\n stdout: \"inherit\",\n stderr: \"inherit\",\n tty: true\n });\n },\n async close() {}\n } as OpenedEnv;\n }) as unknown as ExecutionEnvFactory[\"open\"],\n async attach() {\n throw new Error(\"host runtime does not support reattach\");\n }\n };\n}\n\nfunction runHost(spawnProcess: typeof import(\"node:child_process\").spawn, spec: RunSpec) {\n const stdin = spec.stdin ?? \"ignore\";\n const stdout = spec.stdout ?? \"pipe\";\n const stderr = spec.stderr ?? \"pipe\";\n const stdio =\n stdin === \"inherit\" && stdout === \"inherit\" && stderr === \"inherit\"\n ? \"inherit\"\n : ([stdin, stdout, stderr] as [\n \"pipe\" | \"inherit\" | \"ignore\",\n \"pipe\" | \"inherit\",\n \"pipe\" | \"inherit\"\n ]);\n const child = spawnProcess(spec.command, spec.args ?? [], {\n cwd: spec.cwd,\n env: spec.env,\n stdio\n });\n const result = new Promise<{ exitCode: number }>((resolve) => {\n child.once(\"close\", (code) => {\n resolve({ exitCode: code ?? 1 });\n });\n child.once(\"error\", () => {\n resolve({ exitCode: 1 });\n });\n });\n const kill = (signal?: NodeJS.Signals) => {\n child.kill(signal);\n };\n if (spec.signal?.aborted) {\n kill(\"SIGTERM\");\n } else {\n spec.signal?.addEventListener(\"abort\", () => kill(\"SIGTERM\"), { once: true });\n }\n return {\n pid: child.pid ?? null,\n stdin: child.stdin,\n stdout: child.stdout,\n stderr: child.stderr,\n result,\n kill\n };\n}\n", "import path from \"node:path\";\n\nexport function resolveWorkflowPath(inputPath: string, cwd: string, homeDir: string): string {\n if (inputPath.startsWith(\"~/\")) {\n return path.join(homeDir, inputPath.slice(2));\n }\n\n if (inputPath === \"~\") {\n return homeDir;\n }\n\n return path.isAbsolute(inputPath) ? inputPath : path.resolve(cwd, inputPath);\n}\n\nexport interface DiscoverDocsOptions {\n cwd: string;\n homeDir: string;\n subDirectory: string;\n glob?: string;\n fs: { readdir: (path: string) => Promise<string[]> };\n}\n\nfunction isMissingDirectory(error: unknown): boolean {\n return (\n !!error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n ((error as { code?: unknown }).code === \"ENOENT\" ||\n (error as { code?: unknown }).code === \"ENOTDIR\")\n );\n}\n\nfunction defaultGlobForSubDirectory(subDirectory: string): string {\n return subDirectory.startsWith(\"pipeline/\") ? \"*.yaml\" : \"*.md\";\n}\n\nfunction matchesGlob(fileName: string, glob: string): boolean {\n if (glob === \"*\") {\n return true;\n }\n\n if (glob.startsWith(\"*.\")) {\n const suffix = glob.slice(1).toLowerCase();\n return fileName.toLowerCase().endsWith(suffix);\n }\n\n return fileName === glob;\n}\n\nasync function readDirectory(\n fs: DiscoverDocsOptions[\"fs\"],\n directoryPath: string\n): Promise<string[]> {\n try {\n return await fs.readdir(directoryPath);\n } catch (error) {\n if (isMissingDirectory(error)) {\n return [];\n }\n\n throw error;\n }\n}\n\nasync function discoverFromDirectory(options: {\n fs: DiscoverDocsOptions[\"fs\"];\n directoryPath: string;\n glob: string;\n}): Promise<Array<{ fileName: string; absolutePath: string }>> {\n const entries = await readDirectory(options.fs, options.directoryPath);\n\n return entries\n .filter((entry) => matchesGlob(entry, options.glob))\n .map((entry) => ({\n fileName: entry,\n absolutePath: path.join(options.directoryPath, entry)\n }));\n}\n\nexport async function discoverWorkflowDocs(options: DiscoverDocsOptions): Promise<string[]> {\n const glob = options.glob ?? defaultGlobForSubDirectory(options.subDirectory);\n const projectDirectory = path.join(options.cwd, \".poe-code\", options.subDirectory);\n const globalDirectory = path.join(options.homeDir, \".poe-code\", options.subDirectory);\n\n const [projectDocs, globalDocs] = await Promise.all([\n discoverFromDirectory({\n fs: options.fs,\n directoryPath: projectDirectory,\n glob\n }),\n discoverFromDirectory({\n fs: options.fs,\n directoryPath: globalDirectory,\n glob\n })\n ]);\n\n const docsByFileName = new Map<string, string>();\n\n for (const doc of globalDocs) {\n docsByFileName.set(doc.fileName, doc.absolutePath);\n }\n\n for (const doc of projectDocs) {\n docsByFileName.set(doc.fileName, doc.absolutePath);\n }\n\n return [...docsByFileName.values()].sort((left, right) => left.localeCompare(right));\n}\n", "import * as fsPromises from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { openTaskList, type TaskList, type TaskListFs } from \"@poe-code/task-list\";\nimport { resolveWorkflowPath } from \"./paths.js\";\n\nconst PLAN_LIST_NAME = \"plans\";\nconst MARKDOWN_EXTENSION = \".md\";\n\nexport interface PlanRef {\n id: string;\n absolutePath: string;\n displayPath: string;\n kind: string;\n name: string;\n}\n\nexport interface DiscoverPlansOptions {\n cwd: string;\n homeDir: string;\n planDirectory: string;\n kinds?: readonly string[];\n fs?: TaskListFs;\n}\n\nexport interface ArchivePlanOptions {\n cwd: string;\n homeDir: string;\n planDirectory: string;\n id: string;\n fs?: TaskListFs;\n}\n\nexport interface OpenPlanListOptions {\n cwd: string;\n homeDir: string;\n planDirectory: string;\n fs?: TaskListFs;\n}\n\nfunction defaultFs(): TaskListFs {\n return fsPromises as unknown as TaskListFs;\n}\n\nfunction hasErrorCode(error: unknown, code: string): boolean {\n return (\n !!error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n (error as { code?: unknown }).code === code\n );\n}\n\nasync function directoryExists(fs: TaskListFs, directoryPath: string): Promise<boolean> {\n try {\n return (await fs.stat(directoryPath)).isDirectory();\n } catch (error) {\n if (hasErrorCode(error, \"ENOENT\") || hasErrorCode(error, \"ENOTDIR\")) {\n return false;\n }\n\n throw error;\n }\n}\n\nfunction stripMarkdownExtension(fileName: string): string | undefined {\n if (!fileName.endsWith(MARKDOWN_EXTENSION)) {\n return undefined;\n }\n\n return fileName.slice(0, -MARKDOWN_EXTENSION.length);\n}\n\nfunction idFromPlanFileName(fileName: string): string | undefined {\n const stem = stripMarkdownExtension(fileName);\n if (stem === undefined) {\n return undefined;\n }\n\n let index = 0;\n while (index < stem.length && stem.charCodeAt(index) >= 48 && stem.charCodeAt(index) <= 57) {\n index += 1;\n }\n\n if (index > 0 && stem[index] === \"-\" && index < stem.length - 1) {\n return stem.slice(index + 1);\n }\n\n return stem;\n}\n\nasync function readPlanPaths(fs: TaskListFs, directoryPath: string): Promise<Map<string, string>> {\n const fileNames = await fs.readdir(directoryPath);\n const pathsById = new Map<string, string>();\n\n for (const fileName of fileNames) {\n const id = idFromPlanFileName(fileName);\n if (id === undefined) {\n continue;\n }\n\n const absolutePath = path.join(directoryPath, fileName);\n const stat = await fs.stat(absolutePath);\n if (stat.isFile()) {\n pathsById.set(id, absolutePath);\n }\n }\n\n return pathsById;\n}\n\nfunction isPathWithin(basePath: string, targetPath: string): boolean {\n const relativePath = path.relative(basePath, targetPath);\n\n return relativePath === \"\" || (!relativePath.startsWith(\"..\") && !path.isAbsolute(relativePath));\n}\n\nfunction displayPlanPath(absolutePath: string, cwd: string, homeDir: string): string {\n if (isPathWithin(cwd, absolutePath)) {\n return path.relative(cwd, absolutePath);\n }\n\n if (isPathWithin(homeDir, absolutePath)) {\n const relativeToHome = path.relative(homeDir, absolutePath);\n return relativeToHome.length === 0 ? \"~\" : `~/${relativeToHome}`;\n }\n\n return absolutePath;\n}\n\nfunction resolvePlanDirectory(options: {\n cwd: string;\n homeDir: string;\n planDirectory: string;\n}): string {\n return resolveWorkflowPath(options.planDirectory, options.cwd, options.homeDir);\n}\n\nfunction planKind(metadata: Record<string, unknown>): string {\n return String(metadata.kind ?? \"plan\");\n}\n\nexport async function discoverPlans(options: DiscoverPlansOptions): Promise<PlanRef[]> {\n const resolvedDirectory = resolvePlanDirectory(options);\n const fs = options.fs ?? defaultFs();\n if (!(await directoryExists(fs, resolvedDirectory))) {\n return [];\n }\n\n const [taskList, pathsById] = await Promise.all([\n openPlanList(options),\n readPlanPaths(fs, resolvedDirectory)\n ]);\n const kindFilter = options.kinds === undefined ? undefined : new Set(options.kinds);\n const tasks = await taskList.list(PLAN_LIST_NAME).all();\n\n return tasks\n .map((task) => ({\n id: task.id,\n name: task.name,\n kind: planKind(task.metadata),\n absolutePath: pathsById.get(task.id) ?? path.join(resolvedDirectory, `${task.id}.md`)\n }))\n .filter((plan) => kindFilter === undefined || kindFilter.has(plan.kind))\n .map((plan) => ({\n ...plan,\n displayPath: displayPlanPath(plan.absolutePath, options.cwd, options.homeDir)\n }));\n}\n\nexport const archivePlan = async (options: ArchivePlanOptions): Promise<void> => {\n const taskList = await openPlanList(options);\n const plans = taskList.list(PLAN_LIST_NAME);\n\n await plans.fire(options.id, \"archive\");\n};\n\nexport function openPlanList(options: OpenPlanListOptions): Promise<TaskList> {\n return openTaskList({\n type: \"markdown-dir\",\n path: resolvePlanDirectory(options),\n singleList: PLAN_LIST_NAME,\n frontmatterMode: \"passthrough\",\n fs: options.fs\n });\n}\n", "import * as fsPromises from \"node:fs/promises\";\nimport { ghIssuesBackend } from \"./backends/gh-issues.js\";\nimport { resolveAuth, resolveEndpoint } from \"./backends/gh-issues-client.js\";\nimport { markdownDirBackend } from \"./backends/markdown-dir.js\";\nimport { yamlFileBackend } from \"./backends/yaml-file.js\";\nimport { validateMachine } from \"./state-machine.js\";\nimport { resolveStateMachine } from \"./state.js\";\nimport type {\n BackendFactory,\n BackendDeps,\n OpenGhIssuesOptions,\n OpenMarkdownDirOptions,\n OpenTaskListOptions,\n OpenYamlFileOptions,\n TaskList,\n TaskListFs\n} from \"./types.js\";\n\nconst DEFAULT_LOCK_STALE_MS = 30_000;\nconst DEFAULT_LOCK_RETRIES = 20;\n\ntype FileBackendOptions = OpenMarkdownDirOptions | OpenYamlFileOptions;\n\nexport const backendFactories: Record<FileBackendOptions[\"type\"], BackendFactory> = {\n \"markdown-dir\": markdownDirBackend,\n \"yaml-file\": yamlFileBackend\n};\n\nfunction createDefaultFs(): TaskListFs {\n return fsPromises as unknown as TaskListFs;\n}\n\nexport async function openTaskList(options: OpenTaskListOptions): Promise<TaskList> {\n switch (options.type) {\n case \"markdown-dir\":\n case \"yaml-file\":\n return openFileBackend(options);\n case \"gh-issues\":\n return openGhIssuesBackend(options);\n default:\n throw new Error(`Unknown task list backend type \"${(options as { type: string }).type}\".`);\n }\n}\n\nasync function openFileBackend(options: FileBackendOptions): Promise<TaskList> {\n const factory = backendFactories[options.type];\n const stateMachine = resolveStateMachine(options.stateMachine);\n validateMachine(stateMachine);\n const markdownOptions = options.type === \"markdown-dir\" ? options : undefined;\n\n const deps: BackendDeps = {\n path: options.path,\n defaults: {\n metadata: { ...(options.defaults?.metadata ?? {}) }\n },\n singleList: markdownOptions?.singleList,\n frontmatterMode: markdownOptions?.frontmatterMode ?? \"strict\",\n lockStaleMs: options.lockStaleMs ?? DEFAULT_LOCK_STALE_MS,\n lockRetries: options.lockRetries ?? DEFAULT_LOCK_RETRIES,\n create: options.create ?? false,\n fs: options.fs ?? createDefaultFs(),\n stateMachine\n };\n\n return factory(deps);\n}\n\nasync function openGhIssuesBackend(options: OpenGhIssuesOptions): Promise<TaskList> {\n const token = await resolveAuth({ explicitToken: options.auth?.token });\n const endpoint = resolveEndpoint();\n\n return ghIssuesBackend({\n repo: options.repo,\n project: options.project,\n defaults: {\n metadata: { ...(options.defaults?.metadata ?? {}) }\n },\n token,\n endpoint,\n fetch: options.fetch\n });\n}\n", "import type { Task } from \"./types.js\";\n\nexport interface StateMachineDef<TState extends string = string, TEvent extends string = string> {\n readonly initial: TState;\n readonly states: readonly TState[];\n readonly events: Readonly<Record<TEvent, EventDef<TState>>>;\n}\n\nexport interface EventDef<TState extends string = string> {\n readonly from: readonly TState[] | \"*\";\n readonly to: TState;\n readonly guard?: (task: Task) => true | string;\n readonly onEnter?: (task: Task) => void | Promise<void>;\n readonly onExit?: (task: Task) => void | Promise<void>;\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction isStateList(value: unknown): value is readonly string[] {\n return Array.isArray(value) && value.every((entry) => typeof entry === \"string\");\n}\n\nfunction canFireFromState<TState extends string>(event: EventDef<TState>, fromState: string): boolean {\n if (event.from === \"*\") {\n return event.to !== fromState;\n }\n\n return event.from.includes(fromState as TState);\n}\n\nexport function validateMachine(machine: StateMachineDef): void {\n if (!isRecord(machine)) {\n throw new TypeError(\"State machine must be an object.\");\n }\n\n if (!isStateList(machine.states)) {\n throw new TypeError(\"State machine states must be a string array.\");\n }\n\n const states = new Set(machine.states);\n\n if (typeof machine.initial !== \"string\") {\n throw new TypeError(\"State machine initial must be a string.\");\n }\n\n if (!states.has(machine.initial)) {\n throw new Error(`Initial state \"${machine.initial}\" is not declared.`);\n }\n\n if (!isRecord(machine.events)) {\n throw new TypeError(\"State machine events must be an object.\");\n }\n\n for (const [eventName, event] of Object.entries(machine.events)) {\n if (!isRecord(event)) {\n throw new TypeError(`Event \"${eventName}\" must be an object.`);\n }\n\n if (event.from !== \"*\" && !isStateList(event.from)) {\n throw new TypeError(`Event \"${eventName}\" has an invalid \"from\" definition.`);\n }\n\n if (typeof event.to !== \"string\") {\n throw new TypeError(`Event \"${eventName}\" target state must be a string.`);\n }\n\n if (!states.has(event.to)) {\n throw new Error(`Event \"${eventName}\" references unknown target state \"${event.to}\".`);\n }\n\n if (event.from !== \"*\") {\n for (const fromState of event.from) {\n if (!states.has(fromState)) {\n throw new Error(`Event \"${eventName}\" references unknown source state \"${fromState}\".`);\n }\n }\n }\n }\n}\n\nexport function eventsFromState<TState extends string, TEvent extends string>(\n machine: StateMachineDef<TState, TEvent>,\n fromState: TState\n): readonly TEvent[] {\n const events: TEvent[] = [];\n\n for (const [eventName, event] of Object.entries(machine.events) as Array<[TEvent, EventDef<TState>]>) {\n if (canFireFromState(event, fromState)) {\n events.push(eventName);\n }\n }\n\n return events;\n}\n\nexport function findEvent<TState extends string, TEvent extends string>(\n machine: StateMachineDef<TState, TEvent>,\n fromState: TState,\n eventName: TEvent\n): EventDef<TState> | undefined {\n const event = machine.events[eventName];\n\n if (event === undefined) {\n return undefined;\n }\n\n return canFireFromState(event, fromState) ? event : undefined;\n}\n", "import { text } from \"node:stream/consumers\";\nimport { createHostRunner, type Runner } from \"@poe-code/process-runner\";\n\nconst DEFAULT_ENDPOINT = \"https://api.github.com/graphql\";\nconst USER_AGENT = \"poe-code-task-list/0.0.1\";\nconst AUTH_ERROR = \"gh auth token failed; install gh, run 'gh auth login', or pass auth: { token }\";\n\nexport interface GhClientOptions {\n token: string;\n endpoint?: string;\n fetch?: typeof fetch;\n}\n\nexport interface GhClient {\n graphql<T>(query: string, variables: Record<string, unknown>): Promise<T>;\n}\n\nexport function createGhClient(options: GhClientOptions): GhClient {\n const fetchImpl = options.fetch ?? fetch;\n const endpoint = options.endpoint || DEFAULT_ENDPOINT;\n\n return {\n async graphql<T>(query: string, variables: Record<string, unknown>) {\n const response = await fetchImpl(endpoint, {\n method: \"POST\",\n headers: {\n Authorization: `Bearer ${options.token}`,\n \"Content-Type\": \"application/json\",\n \"User-Agent\": USER_AGENT\n },\n body: JSON.stringify({ query, variables })\n });\n\n const body = await response.text();\n if (response.status !== 200) {\n throw new Error(`GitHub GraphQL request failed with status ${response.status}: ${body}`);\n }\n\n const parsed = JSON.parse(body) as {\n data?: T;\n errors?: { message?: string }[];\n };\n const firstError = parsed.errors?.[0];\n if (firstError !== undefined) {\n throw new Error(firstError.message ?? \"GitHub GraphQL request failed\");\n }\n\n return parsed.data as T;\n }\n };\n}\n\nexport interface ResolveAuthOptions {\n explicitToken?: string;\n runner?: Runner;\n}\n\nexport async function resolveAuth(options: ResolveAuthOptions): Promise<string> {\n if (options.explicitToken !== undefined) {\n return options.explicitToken;\n }\n\n const runner = options.runner ?? createHostRunner();\n const handle = runner.exec({\n command: \"gh\",\n args: [\"auth\", \"token\"],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n\n const [stdout, , result] = await Promise.all([\n handle.stdout === null ? Promise.resolve(\"\") : text(handle.stdout),\n handle.stderr === null ? Promise.resolve(\"\") : text(handle.stderr),\n handle.result\n ]);\n const token = stdout.trim();\n\n if (result.exitCode !== 0 || token.length === 0) {\n throw new Error(AUTH_ERROR);\n }\n\n return token;\n}\n\nexport interface ResolveEndpointOptions {\n env?: Record<string, string | undefined>;\n}\n\nexport function resolveEndpoint(options: ResolveEndpointOptions = {}): string {\n const env = options.env ?? process.env;\n const host = env.GH_HOST;\n\n if (host !== undefined && host !== \"\" && host !== \"github.com\") {\n return `https://${host}/api/graphql`;\n }\n\n return DEFAULT_ENDPOINT;\n}\n", "import { execSync } from \"node:child_process\";\nimport type { Engine } from \"../types.js\";\n\ninterface ColimaProfile {\n name?: string;\n profile?: string;\n status?: string;\n runtime?: string;\n}\n\nexport function detectContext(): string | null {\n try {\n const output = execSync(\"colima list --json\", {\n encoding: \"utf-8\",\n stdio: [\"pipe\", \"pipe\", \"ignore\"]\n });\n const lines = output.trim().split(\"\\n\").filter(Boolean);\n\n for (const line of lines) {\n const profile = JSON.parse(line) as ColimaProfile;\n\n if (profile.status === \"Running\" && profile.runtime === \"docker\") {\n const name = profile.name ?? profile.profile;\n\n if (!name) {\n continue;\n }\n\n return name === \"default\" ? \"colima\" : `colima-${name}`;\n }\n }\n } catch {\n return null;\n }\n\n return null;\n}\n\nexport function buildContextArgs(engine: Engine, context: string | null): string[] {\n if (engine === \"docker\" && context) {\n return [\"--context\", context];\n }\n\n return [];\n}\n", "import { execSync } from \"node:child_process\";\nimport type { Engine } from \"../types.js\";\n\nexport function detectEngine(): Engine {\n if (isEngineAvailable(\"docker\")) {\n return \"docker\";\n }\n\n if (isEngineAvailable(\"podman\")) {\n return \"podman\";\n }\n\n throw new Error(\n \"No container engine found. Please install Docker or Podman:\\n\" +\n \" - Docker Desktop: https://www.docker.com/products/docker-desktop\\n\" +\n \" - Colima (macOS): brew install colima && colima start\\n\" +\n \" - Podman: https://podman.io/docs/installation\"\n );\n}\n\nexport function isEngineAvailable(engine: Engine): boolean {\n try {\n execSync(`${engine} --version`, {\n stdio: \"ignore\"\n });\n return true;\n } catch {\n return false;\n }\n}\n", "import * as childProcess from \"node:child_process\";\nimport { randomBytes } from \"node:crypto\";\nimport { buildDockerRunArgs } from \"./args.js\";\nimport { buildContextArgs, detectContext } from \"./context.js\";\nimport { detectEngine } from \"./engine.js\";\nimport type { DockerRunnerOptions, RunHandle, Runner, RunResult, RunSpec } from \"../types.js\";\n\nexport function createDockerRunner(options: DockerRunnerOptions): Runner {\n const engine = options.engine ?? detectEngine();\n const context = options.context ?? detectContext();\n\n return {\n name: \"docker\",\n exec(spec: RunSpec): RunHandle {\n const stdinMode = spec.stdin ?? \"ignore\";\n const stdoutMode = spec.stdout ?? \"pipe\";\n const stderrMode = spec.stderr ?? \"pipe\";\n const interactiveMode =\n stdinMode === \"inherit\" &&\n stdoutMode === \"inherit\" &&\n stderrMode === \"inherit\" &&\n spec.tty === true;\n const containerName = buildContainerName(options.containerName ?? spec.command);\n const runArgs = buildDockerRunArgs({\n engine,\n context,\n image: options.image,\n command: spec.command,\n args: spec.args ?? [],\n cwd: spec.cwd,\n env: spec.env,\n mounts: options.mounts ?? [],\n ports: options.ports ?? [],\n network: options.network,\n containerName,\n detached: false,\n interactive: stdinMode === \"pipe\" || stdinMode === \"inherit\",\n tty: spec.tty ?? false,\n rm: true,\n extraArgs: options.extraArgs ?? []\n });\n const [command, ...args] = runArgs;\n const child = childProcess.spawn(command, args, {\n stdio: interactiveMode ? \"inherit\" : [stdinMode, stdoutMode, stderrMode]\n });\n let isResultSettled = false;\n let resolveResult: ((value: RunResult) => void) | null = null;\n const result = new Promise<RunResult>((resolve) => {\n resolveResult = resolve;\n });\n const cleanupAbort = bindAbortSignal(spec.signal, () => {\n spawnControlCommand(engine, context, [\"stop\", containerName]);\n });\n const settleResult = (exitCode: number) => {\n if (isResultSettled) {\n return;\n }\n\n isResultSettled = true;\n cleanupAbort();\n resolveResult?.({ exitCode });\n };\n\n child.once(\"error\", () => {\n settleResult(1);\n });\n\n child.once(\"close\", (code) => {\n settleResult(code ?? 1);\n });\n\n return {\n pid: null,\n stdin: interactiveMode ? null : child.stdin,\n stdout: interactiveMode ? null : child.stdout,\n stderr: interactiveMode ? null : child.stderr,\n result,\n kill(signal?: NodeJS.Signals) {\n if (signal === \"SIGKILL\") {\n spawnControlCommand(engine, context, [\"kill\", containerName]);\n return;\n }\n\n if (signal === undefined || signal === \"SIGTERM\") {\n spawnControlCommand(engine, context, [\"stop\", containerName]);\n return;\n }\n\n spawnControlCommand(engine, context, [\"kill\", `--signal=${signal}`, containerName]);\n }\n };\n }\n };\n}\n\nfunction buildContainerName(name: string): string {\n const suffix = randomBytes(3).toString(\"hex\").slice(0, 6);\n const sanitizedName = sanitizeContainerName(name);\n\n return `poe-run-${sanitizedName}-${suffix}`;\n}\n\nfunction sanitizeContainerName(name: string): string {\n let sanitized = \"\";\n\n for (const char of name) {\n if (isContainerNameCharacter(char)) {\n sanitized += char;\n continue;\n }\n\n sanitized += \"-\";\n }\n\n return sanitized.length > 0 ? sanitized : \"command\";\n}\n\nfunction isContainerNameCharacter(char: string): boolean {\n const code = char.charCodeAt(0);\n\n if (code >= 48 && code <= 57) {\n return true;\n }\n\n if (code >= 65 && code <= 90) {\n return true;\n }\n\n if (code >= 97 && code <= 122) {\n return true;\n }\n\n return char === \".\" || char === \"_\" || char === \"-\";\n}\n\nfunction spawnControlCommand(\n engine: DockerRunnerOptions[\"engine\"] extends infer T ? Exclude<T, undefined> : never,\n context: string | null,\n args: string[]\n): void {\n childProcess.spawn(engine, [...buildContextArgs(engine, context), ...args], {\n stdio: \"ignore\"\n });\n}\n\nfunction bindAbortSignal(signal: AbortSignal | undefined, onAbort: () => void): () => void {\n if (signal === undefined) {\n return () => {};\n }\n\n if (signal.aborted) {\n onAbort();\n return () => {};\n }\n\n signal.addEventListener(\"abort\", onAbort, { once: true });\n\n return () => {\n signal.removeEventListener(\"abort\", onAbort);\n };\n}\n", "import path from \"node:path\";\nimport type { DockerRunArgs } from \"../types.js\";\n\nexport function buildDockerRunArgs(input: DockerRunArgs): string[] {\n const args: string[] = [input.engine];\n\n if (input.engine === \"docker\" && input.context) {\n args.push(\"--context\", input.context);\n }\n\n args.push(\"run\");\n\n if (input.rm) {\n args.push(\"--rm\");\n }\n\n if (input.detached) {\n args.push(\"-d\");\n }\n\n if (input.interactive) {\n args.push(\"-i\");\n }\n\n if (input.tty) {\n args.push(\"-t\");\n }\n\n args.push(\"--name\", input.containerName);\n\n if (input.cwd !== undefined) {\n args.push(\"-w\", input.cwd);\n }\n\n for (const [key, value] of Object.entries(input.env ?? {})) {\n args.push(\"-e\", `${key}=${value}`);\n }\n\n for (const mount of input.mounts) {\n const volume = `${path.resolve(mount.source)}:${mount.target}${mount.readonly ? \":ro\" : \"\"}`;\n args.push(\"-v\", volume);\n }\n\n for (const port of input.ports) {\n const mapping = `${port.host}:${port.container}${port.protocol === undefined || port.protocol === \"tcp\" ? \"\" : `/${port.protocol}`}`;\n args.push(\"-p\", mapping);\n }\n\n if (input.network !== undefined) {\n args.push(\"--network\", input.network);\n }\n\n args.push(...input.extraArgs, input.image, input.command, ...input.args);\n\n return args;\n}\n", "import { createHash, randomBytes } from \"node:crypto\";\nimport { mkdtempSync, rmSync } from \"node:fs\";\nimport { readFile } from \"node:fs/promises\";\nimport { tmpdir } from \"node:os\";\nimport path from \"node:path\";\nimport { buildDockerRunArgs } from \"./args.js\";\nimport { buildContextArgs, detectContext } from \"./context.js\";\nimport { detectEngine } from \"./engine.js\";\nimport { createHostRunner } from \"../host/host-runner.js\";\nimport type {\n DockerMount,\n Engine,\n ExecutionState,\n ExecutionEnvFactory,\n OpenSpec,\n OpenedEnv,\n Runner,\n RunSpec\n} from \"../types.js\";\n\ninterface DockerRuntime {\n type: \"docker\";\n image?: string;\n dockerfile?: string;\n build_context?: string;\n build_args?: Record<string, string>;\n mounts?: DockerMount[];\n engine?: Engine;\n network?: string;\n extra_args?: string[];\n}\n\nexport interface BuildDockerRuntimeTemplateInput {\n cwd: string;\n runtime: DockerRuntime;\n state?: ExecutionState;\n runner?: Runner;\n force?: boolean;\n}\n\nexport interface BuildDockerRuntimeTemplateResult {\n backend: \"docker\";\n hash: string;\n image: string;\n cached: boolean;\n}\n\nconst containerCommand = [\"sh\", \"-c\", \"while :; do sleep 3600; done\"] as const;\n\nexport const dockerExecutionEnvFactory: ExecutionEnvFactory = {\n type: \"docker\",\n supportsDetach: true,\n async open(spec): Promise<OpenedEnv> {\n const runtime = parseDockerRuntime(spec.runtime);\n const runner = spec.hostRunner ?? createHostRunner();\n const engine = runtime.engine ?? detectEngine();\n const context = detectContext();\n const image = await resolveImage({\n spec,\n runtime,\n runner,\n engine,\n context\n });\n const containerName = createContainerName();\n const runArgs = buildDockerRunArgs({\n engine,\n context,\n image,\n command: containerCommand[0],\n args: containerCommand.slice(1),\n cwd: undefined,\n env: undefined,\n mounts: runtime.mounts ?? [],\n ports: [],\n network: runtime.network,\n containerName,\n detached: true,\n interactive: true,\n tty: false,\n rm: false,\n extraArgs: runtime.extra_args ?? []\n });\n const [command, ...args] = runArgs;\n const id = (await runAndRead(runner, { command, args, stdout: \"pipe\", stderr: \"pipe\" })).trim();\n\n return createDockerEnv({\n id,\n spec,\n runner,\n engine,\n context\n });\n },\n async attach(envId, context): Promise<OpenedEnv> {\n const engine = detectEngine();\n return createDockerEnv({\n id: envId,\n spec: createAttachedSpec(context?.cwd),\n runner: createHostRunner(),\n engine,\n context: detectContext(),\n attachedJobId: context?.jobId\n });\n }\n};\n\nfunction createDockerEnv(input: {\n id: string;\n spec: OpenSpec;\n runner: Runner;\n engine: Engine;\n context: string | null;\n attachedJobId?: string;\n}): OpenedEnv {\n const containerRef = input.id;\n\n return {\n id: containerRef,\n job:\n input.attachedJobId === undefined\n ? null\n : createContainerJob(containerRef, input.runner, input.engine, input.context, input.attachedJobId),\n async uploadWorkspace() {\n const tempDir = mkdtempSync(path.join(tmpdir(), \"poe-docker-upload-\"));\n const archivePath = path.join(tempDir, \"workspace.tar\");\n try {\n const excludeArgs = input.spec.uploadIgnoreFiles.flatMap((ignored) => [\n \"--exclude\",\n ignored\n ]);\n const tarArgs = [...excludeArgs, \"-cf\", archivePath, \"-C\", input.spec.cwd, \".\"];\n await runOrThrow(input.runner, {\n command: \"tar\",\n args: tarArgs,\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"cp\",\n archivePath,\n `${containerRef}:/tmp/poe-workspace-upload.tar`\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"exec\",\n containerRef,\n \"sh\",\n \"-c\",\n `mkdir -p ${shellQuote(input.spec.cwd)} && tar -xf /tmp/poe-workspace-upload.tar -C ${shellQuote(input.spec.cwd)}`\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n\n return { files: 0, bytes: 0, skipped: [] };\n } finally {\n rmSync(tempDir, { recursive: true, force: true });\n }\n },\n async downloadWorkspace(opts) {\n const tempDir = mkdtempSync(path.join(tmpdir(), \"poe-docker-download-\"));\n const archivePath = path.join(tempDir, \"workspace.tar\");\n try {\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"exec\",\n containerRef,\n \"sh\",\n \"-c\",\n `tar -cf /tmp/poe-workspace-download.tar -C ${shellQuote(input.spec.cwd)} .`\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"cp\",\n `${containerRef}:/tmp/poe-workspace-download.tar`,\n archivePath\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n const extractMode = opts.conflictPolicy === \"refuse\" ? \"-xkf\" : \"-xf\";\n await runOrThrow(input.runner, {\n command: \"tar\",\n args: [extractMode, archivePath, \"-C\", input.spec.cwd],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n\n return { files: 0, bytes: 0, conflicts: [] };\n } finally {\n rmSync(tempDir, { recursive: true, force: true });\n }\n },\n exec(spec) {\n return input.runner.exec({\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"exec\",\n ...(spec.stdin === \"pipe\" || spec.stdin === \"inherit\" ? [\"-i\"] : []),\n ...(spec.tty === true ? [\"-t\"] : []),\n ...(spec.cwd !== undefined ? [\"-w\", spec.cwd] : []),\n ...buildEnvArgs(spec.env),\n containerRef,\n spec.command,\n ...(spec.args ?? [])\n ],\n stdin: spec.stdin,\n stdout: spec.stdout,\n stderr: spec.stderr,\n tty: spec.tty\n });\n },\n async detach() {\n return createContainerJob(containerRef, input.runner, input.engine, input.context);\n },\n shell() {\n const shellSpec = input.spec.shellSpec;\n return this.exec({\n command: shellSpec?.command ?? input.spec.env.SHELL ?? \"sh\",\n ...(shellSpec?.args ? { args: shellSpec.args } : {}),\n cwd: input.spec.cwd,\n env: shellSpec && \"env\" in shellSpec ? shellSpec.env : input.spec.env,\n stdin: \"inherit\",\n stdout: \"inherit\",\n stderr: \"inherit\",\n tty: true\n });\n },\n async close() {\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [...buildContextArgs(input.engine, input.context), \"rm\", \"-f\", containerRef],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n }\n };\n}\n\nasync function resolveImage(input: {\n spec: OpenSpec;\n runtime: DockerRuntime;\n runner: Runner;\n engine: Engine;\n context: string | null;\n}): Promise<string> {\n if (input.runtime.image !== undefined) {\n return input.runtime.image;\n }\n\n const result = await buildDockerRuntimeTemplate({\n cwd: input.spec.cwd,\n runtime: input.runtime,\n state: input.spec.state,\n runner: input.runner\n });\n return result.image;\n}\n\nexport async function buildDockerRuntimeTemplate(\n input: BuildDockerRuntimeTemplateInput\n): Promise<BuildDockerRuntimeTemplateResult> {\n const runner = input.runner ?? createHostRunner();\n const engine = input.runtime.engine ?? detectEngine();\n const context = detectContext();\n const dockerfilePath = path.resolve(\n input.cwd,\n input.runtime.dockerfile ?? path.join(\".poe-code\", \"Dockerfile\")\n );\n const buildContext = path.resolve(input.cwd, input.runtime.build_context ?? \".\");\n const dockerfileBytes = await readFile(dockerfilePath);\n const hash = hashDockerTemplate(dockerfileBytes, input.runtime.build_args ?? {});\n const cached = input.force ? null : await input.state?.templates.get(\"docker\", hash);\n\n if (cached?.image !== undefined) {\n return {\n backend: \"docker\",\n hash,\n image: cached.image,\n cached: true\n };\n }\n\n const image = `poe-code/local:${hash}`;\n await buildImage({\n runner,\n engine,\n context,\n image,\n dockerfilePath,\n buildContext,\n buildArgs: input.runtime.build_args ?? {}\n });\n await input.state?.templates.put(\"docker\", {\n hash,\n image,\n runtime_type: \"docker\",\n dockerfile_path: dockerfilePath,\n built_at: new Date().toISOString()\n });\n\n return {\n backend: \"docker\",\n hash,\n image,\n cached: false\n };\n}\n\nfunction hashDockerTemplate(dockerfileBytes: Buffer, buildArgs: Record<string, string>): string {\n const hash = createHash(\"sha256\");\n hash.update(dockerfileBytes);\n hash.update(\"\\0\");\n for (const [key, value] of sortedBuildArgs(buildArgs)) {\n hash.update(key);\n hash.update(\"=\");\n hash.update(value);\n hash.update(\"\\0\");\n }\n return hash.digest(\"hex\");\n}\n\nasync function buildImage(input: {\n runner: Runner;\n engine: Engine;\n context: string | null;\n image: string;\n dockerfilePath: string;\n buildContext: string;\n buildArgs: Record<string, string>;\n}): Promise<void> {\n await runOrThrow(input.runner, {\n command: input.engine,\n args: [\n ...buildContextArgs(input.engine, input.context),\n \"build\",\n \"--tag\",\n input.image,\n \"-f\",\n input.dockerfilePath,\n ...sortedBuildArgs(input.buildArgs).flatMap(([key, value]) => [\n \"--build-arg\",\n `${key}=${value}`\n ]),\n input.buildContext\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n}\n\nfunction parseDockerRuntime(runtime: unknown): DockerRuntime {\n if (!runtime || typeof runtime !== \"object\" || Array.isArray(runtime)) {\n throw new Error(\"docker runtime must be an object\");\n }\n const record = runtime as Record<string, unknown>;\n if (record.type !== \"docker\") {\n throw new Error('docker runtime type must be \"docker\"');\n }\n return record as unknown as DockerRuntime;\n}\n\nasync function runAndRead(runner: Runner, spec: RunSpec): Promise<string> {\n const handle = runner.exec(spec);\n const stdout = readStream(handle.stdout);\n const stderr = readStream(handle.stderr);\n const result = await handle.result;\n const output = await stdout;\n if (result.exitCode !== 0) {\n const errorOutput = await stderr;\n throw new Error(\n `Command failed with exit code ${result.exitCode}: ${spec.command} ${(spec.args ?? []).join(\" \")}${errorOutput ? `\\n${errorOutput}` : \"\"}`\n );\n }\n return output;\n}\n\nasync function runOrThrow(runner: Runner, spec: RunSpec): Promise<void> {\n await runAndRead(runner, spec);\n}\n\nasync function readStream(stream: NodeJS.ReadableStream | null): Promise<string> {\n if (stream === null) {\n return \"\";\n }\n\n stream.setEncoding(\"utf8\");\n const chunks: string[] = [];\n for await (const chunk of stream) {\n chunks.push(String(chunk));\n }\n return chunks.join(\"\");\n}\n\nfunction sortedBuildArgs(buildArgs: Record<string, string>): Array<[string, string]> {\n return Object.entries(buildArgs).sort(([left], [right]) => left.localeCompare(right));\n}\n\nfunction buildEnvArgs(env: RunSpec[\"env\"]): string[] {\n if (env === undefined) {\n return [];\n }\n\n return Object.entries(env).flatMap(([key, value]) => [\"-e\", `${key}=${value}`]);\n}\n\nfunction createContainerName(): string {\n return `poe-env-${randomBytes(6).toString(\"hex\")}`;\n}\n\nfunction createContainerJob(\n containerId: string,\n runner: Runner,\n engine: Engine,\n context: string | null,\n jobId = containerId\n) {\n return {\n id: jobId,\n envId: containerId,\n tool: \"docker\",\n argv: [\"attach\", containerId],\n async status() {\n const handle = runner.exec({\n command: engine,\n args: [\n ...buildContextArgs(engine, context),\n \"inspect\",\n \"-f\",\n \"{{.State.Status}}\",\n containerId\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n const stdout = await readStream(handle.stdout);\n const result = await handle.result;\n if (result.exitCode !== 0) {\n return \"lost\" as const;\n }\n return stdout.trim() === \"running\" ? (\"running\" as const) : (\"exited\" as const);\n },\n async *stream(opts?: { sinceByte?: number }) {\n const handle = runner.exec({\n command: engine,\n args: [\n ...buildContextArgs(engine, context),\n \"exec\",\n containerId,\n \"sh\",\n \"-c\",\n `test -f ${shellQuote(`/tmp/poe-jobs/${jobId}.log`)} && tail -c +${(opts?.sinceByte ?? 0) + 1} ${shellQuote(`/tmp/poe-jobs/${jobId}.log`)} || true`\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n const stdout = await readStream(handle.stdout);\n await handle.result;\n if (stdout.length > 0) {\n yield { byteOffset: opts?.sinceByte ?? 0, data: stdout };\n }\n },\n async wait() {\n const handle = runner.exec({\n command: engine,\n args: [...buildContextArgs(engine, context), \"wait\", containerId],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n const stdout = await readStream(handle.stdout);\n const result = await handle.result;\n return { exitCode: Number.parseInt(stdout.trim(), 10) || result.exitCode };\n },\n async kill(signal?: NodeJS.Signals) {\n const args =\n signal === undefined || signal === \"SIGTERM\"\n ? [\"stop\", containerId]\n : [\"kill\", ...(signal === \"SIGKILL\" ? [] : [`--signal=${signal}`]), containerId];\n await runOrThrow(runner, {\n command: engine,\n args: [...buildContextArgs(engine, context), ...args],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n }\n };\n}\n\nfunction createAttachedSpec(cwd = \"/workspace\"): OpenSpec {\n return {\n cwd,\n runtime: {\n type: \"docker\",\n image: \"attached\",\n build_args: {},\n mounts: []\n },\n env: {},\n uploadIgnoreFiles: [],\n jobLabel: {\n tool: \"docker\",\n argv: []\n }\n };\n}\n\nfunction shellQuote(value: string): string {\n return `'${value.replaceAll(\"'\", \"'\\\\''\")}'`;\n}\n", "import { spawn as spawnChildProcess } from \"node:child_process\";\nimport type { Runner, RunSpec } from \"../types.js\";\nimport type { HostRunnerOptions, RunHandle, RunResult } from \"../types.js\";\n\nexport function createHostRunner(options: HostRunnerOptions = {}): Runner {\n const detached = options.detached === true;\n\n return {\n name: \"host\",\n exec(spec: RunSpec): RunHandle {\n const stdinMode = spec.stdin ?? \"ignore\";\n const stdoutMode = spec.stdout ?? \"pipe\";\n const stderrMode = spec.stderr ?? \"pipe\";\n const stdio =\n stdinMode === \"inherit\" && stdoutMode === \"inherit\" && stderrMode === \"inherit\"\n ? \"inherit\"\n : [stdinMode, stdoutMode, stderrMode];\n const child = spawnChildProcess(spec.command, spec.args ?? [], {\n cwd: spec.cwd,\n env: spec.env,\n stdio,\n ...(detached ? { detached: true } : {})\n });\n\n if (detached) {\n child.unref();\n }\n\n const kill = (signal?: NodeJS.Signals) => {\n if (detached && process.platform !== \"win32\" && child.pid !== undefined) {\n process.kill(-child.pid, signal);\n return;\n }\n\n child.kill(signal);\n };\n\n let settled = false;\n let resolveResult: ((value: RunResult) => void) | null = null;\n const result = new Promise<RunResult>((resolve) => {\n resolveResult = resolve;\n });\n\n const cleanupAbort = bindAbortSignal(spec.signal, () => {\n kill(\"SIGTERM\");\n });\n\n child.once(\"close\", (code) => {\n if (settled) return;\n settled = true;\n cleanupAbort();\n resolveResult?.({ exitCode: code ?? 1 });\n });\n child.once(\"error\", () => {\n if (settled) return;\n settled = true;\n cleanupAbort();\n resolveResult?.({ exitCode: 1 });\n });\n\n return {\n pid: child.pid ?? null,\n stdin: child.stdin,\n stdout: child.stdout,\n stderr: child.stderr,\n result,\n kill\n };\n }\n };\n}\n\nfunction bindAbortSignal(signal: AbortSignal | undefined, onAbort: () => void): () => void {\n if (signal === undefined) {\n return () => {};\n }\n\n if (signal.aborted) {\n onAbort();\n return () => {};\n }\n\n signal.addEventListener(\"abort\", onAbort, { once: true });\n\n return () => {\n signal.removeEventListener(\"abort\", onAbort);\n };\n}\n", "import { createHostRunner } from \"./host-runner.js\";\nimport type { ExecutionEnvFactory, OpenedEnv, RunSpec } from \"../types.js\";\n\nexport const hostExecutionEnvFactory: ExecutionEnvFactory = {\n type: \"host\",\n supportsDetach: false,\n async open(openSpec): Promise<OpenedEnv> {\n return {\n id: \"host\",\n job: null,\n async uploadWorkspace() {\n return {\n files: 0,\n bytes: 0,\n skipped: []\n };\n },\n async downloadWorkspace() {\n return {\n files: 0,\n bytes: 0,\n conflicts: []\n };\n },\n exec(spec: RunSpec) {\n return createHostRunner().exec(spec);\n },\n async detach() {\n throw new Error(\"host runtime does not support detach because host has no addressable env\");\n },\n shell() {\n const shellSpec = openSpec.shellSpec;\n return createHostRunner().exec({\n command: shellSpec?.command ?? openSpec.env.SHELL ?? process.env.SHELL ?? \"sh\",\n ...(shellSpec?.args ? { args: shellSpec.args } : {}),\n cwd: openSpec.cwd,\n env: shellSpec && \"env\" in shellSpec ? shellSpec.env : openSpec.env,\n stdin: \"inherit\",\n stdout: \"inherit\",\n stderr: \"inherit\",\n tty: true\n });\n },\n async close() {}\n };\n },\n async attach() {\n throw new Error(\"host runtime does not support reattach\");\n }\n};\n", "import { Readable, Writable } from \"node:stream\";\nimport type { MockRunBehavior, RunHandle, Runner, RunSpec } from \"../types.js\";\n\nexport function createMockRunner(behaviors: MockRunBehavior[]): Runner {\n const remaining = [...behaviors];\n\n return {\n name: \"mock\",\n exec(spec) {\n const behavior = remaining.shift();\n if (behavior === undefined) {\n throw new Error(\"No mock run behaviors left\");\n }\n\n return createRunHandle(spec, behavior);\n }\n };\n}\n\nexport function createMockRunnerByCommand(\n behaviorsByCommand: Record<string, MockRunBehavior>\n): Runner {\n return {\n name: \"mock\",\n exec(spec) {\n const behavior = behaviorsByCommand[spec.command];\n if (behavior === undefined) {\n throw new Error(\n `No mock run behavior found for command \"${spec.command}\"`\n );\n }\n\n return createRunHandle(spec, behavior);\n }\n };\n}\n\nfunction createRunHandle(spec: RunSpec, behavior: MockRunBehavior): RunHandle {\n const stdoutMode = spec.stdout ?? \"pipe\";\n const stderrMode = spec.stderr ?? \"pipe\";\n const stdinMode = spec.stdin ?? \"ignore\";\n const interval = behavior.stdoutInterval ?? 10;\n\n const stdoutController =\n stdoutMode === \"pipe\" && behavior.stdout !== undefined\n ? createReadableStream(behavior.stdout, interval)\n : null;\n const stderrController =\n stderrMode === \"pipe\" && behavior.stderr !== undefined\n ? createReadableStream(behavior.stderr, interval)\n : null;\n\n let resolveResult: ((value: { exitCode: number }) => void) | null = null;\n const result = new Promise<{ exitCode: number }>((resolve) => {\n resolveResult = resolve;\n });\n\n let finished = false;\n const complete = () => {\n if (finished || resolveResult === null) {\n return;\n }\n\n finished = true;\n resolveResult({ exitCode: behavior.exitCode });\n };\n\n const stopStreams = () => {\n stdoutController?.stop();\n stderrController?.stop();\n };\n\n const exitAfterMs = behavior.exitAfterMs ?? 0;\n const exitTimer =\n exitAfterMs > 0\n ? setTimeout(complete, exitAfterMs)\n : queueMicrotask(complete);\n\n return {\n pid: behavior.pid ?? null,\n stdout: stdoutController?.stream ?? null,\n stderr: stderrController?.stream ?? null,\n stdin: stdinMode === \"pipe\" ? createWritableStream() : null,\n result,\n kill() {\n if (typeof exitTimer === \"object\" && exitTimer !== null && \"hasRef\" in exitTimer) {\n clearTimeout(exitTimer);\n }\n stopStreams();\n complete();\n }\n };\n}\n\nfunction createReadableStream(lines: string[], interval: number) {\n const stream = new Readable({\n read() {}\n });\n\n const timers = new Set<NodeJS.Timeout>();\n let stopped = false;\n\n const stop = () => {\n if (stopped) {\n return;\n }\n\n stopped = true;\n for (const timer of timers) {\n clearTimeout(timer);\n }\n timers.clear();\n stream.push(null);\n };\n\n if (lines.length === 0) {\n queueMicrotask(stop);\n return { stream, stop };\n }\n\n for (const [index, line] of lines.entries()) {\n const timer = setTimeout(() => {\n timers.delete(timer);\n if (stopped) {\n return;\n }\n\n stream.push(line);\n if (index === lines.length - 1) {\n stop();\n }\n }, interval * (index + 1));\n\n timers.add(timer);\n }\n\n return { stream, stop };\n}\n\nfunction createWritableStream(): Writable {\n return new Writable({\n write(_chunk, _encoding, callback) {\n callback();\n }\n });\n}\n", "import path from \"node:path\";\nimport type { ListFilter, Task, TaskListFs } from \"../types.js\";\n\nexport interface OrderedEntry {\n task: Task;\n raw: Record<string, unknown>;\n}\n\nexport function compareCreated(left: OrderedEntry, right: OrderedEntry): number {\n const leftCreated = typeof left.raw.created === \"string\" ? left.raw.created : \"\";\n const rightCreated = typeof right.raw.created === \"string\" ? right.raw.created : \"\";\n\n if (leftCreated === \"\" && rightCreated === \"\") {\n return left.task.qualifiedId.localeCompare(right.task.qualifiedId);\n }\n if (leftCreated === \"\") return 1;\n if (rightCreated === \"\") return -1;\n return leftCreated.localeCompare(rightCreated);\n}\n\nexport function applyOrder(entries: OrderedEntry[], order: ListFilter[\"order\"]): Task[] {\n if (order === \"alphabetical\") {\n return sortTasks(entries.map((entry) => entry.task));\n }\n if (order === \"created\") {\n return [...entries].sort(compareCreated).map((entry) => entry.task);\n }\n return entries.map((entry) => entry.task);\n}\n\nlet tmpFileCounter = 0;\n\nexport function hasErrorCode(error: unknown, code: string): boolean {\n return (\n !!error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n (error as { code?: unknown }).code === code\n );\n}\n\nexport function isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nexport function sortStrings(values: string[]): string[] {\n return [...values].sort((left, right) => left.localeCompare(right));\n}\n\nexport function sortTasks(tasks: Task[]): Task[] {\n return [...tasks].sort((left, right) => left.qualifiedId.localeCompare(right.qualifiedId));\n}\n\nexport function validateTaskId(id: string): string {\n if (\n id.length === 0 ||\n id.startsWith(\".\") ||\n id.includes(\"/\") ||\n id.includes(\"\\\\\") ||\n id.includes(\"..\")\n ) {\n throw new Error(`Invalid task id \"${id}\".`);\n }\n\n return id;\n}\n\nexport async function statIfExists(\n fs: TaskListFs,\n filePath: string\n): Promise<Awaited<ReturnType<TaskListFs[\"stat\"]>> | undefined> {\n try {\n return await fs.stat(filePath);\n } catch (error) {\n if (hasErrorCode(error, \"ENOENT\")) {\n return undefined;\n }\n\n throw error;\n }\n}\n\nexport async function writeAtomically(fs: TaskListFs, filePath: string, content: string): Promise<void> {\n const tempPath = `${filePath}.tmp-${process.pid}-${tmpFileCounter}`;\n tmpFileCounter += 1;\n\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n\n try {\n await fs.writeFile(tempPath, content, { encoding: \"utf8\", flag: \"wx\" });\n await fs.rename(tempPath, filePath);\n } catch (error) {\n try {\n await fs.unlink(tempPath);\n } catch (unlinkError) {\n if (!hasErrorCode(unlinkError, \"ENOENT\")) {\n throw unlinkError;\n }\n }\n\n throw error;\n }\n}\n", "import path from \"node:path\";\nimport { acquireFileLock } from \"@poe-code/file-lock\";\nimport { parseDocument, stringify } from \"yaml\";\nimport taskSchema from \"../schema/task.schema.json\" with { type: \"json\" };\nimport { eventsFromState, findEvent } from \"../state-machine.js\";\nimport { resolveStateMachine } from \"../state.js\";\nimport {\n AnchorNotFoundError,\n InvalidTransitionError,\n MalformedTaskError,\n OrderMismatchError,\n TaskAlreadyExistsError,\n TaskNotFoundError,\n type BackendDeps,\n type ListFilter,\n type MoveAnchor,\n type Task,\n type TaskCreate,\n type TaskFireOptions,\n type TaskList,\n type TaskListFs,\n type Tasks,\n type TaskUpdate\n} from \"../types.js\";\nimport {\n applyOrder,\n hasErrorCode,\n isRecord,\n sortStrings,\n statIfExists,\n validateTaskId,\n writeAtomically,\n type OrderedEntry\n} from \"./utils.js\";\n\nconst ARCHIVE_DIRECTORY_NAME = \"archive\";\nconst MARKDOWN_EXTENSION = \".md\";\nconst TASK_KIND = \"task\";\nconst TASK_VERSION = 1;\nconst TASK_SCHEMA_ID = taskSchema.$id;\nconst ORDER_LOCK_FILENAME = \".order.lock\";\nconst MIN_PREFIX_WIDTH = 2;\nconst RESERVED_FRONTMATTER_KEYS = new Set([\n \"$schema\",\n \"created\",\n \"description\",\n \"kind\",\n \"name\",\n \"state\",\n \"version\"\n]);\nconst PASSTHROUGH_RESERVED_FRONTMATTER_KEYS = new Set([\"description\", \"name\", \"state\"]);\n\ntype TaskRecord = Record<string, unknown>;\n\ntype TaskFile = {\n task: Task;\n frontmatter: TaskRecord;\n path: string;\n};\n\ntype TaskLocation = {\n archived: boolean;\n path: string;\n};\n\ntype ListLayout = { kind: \"multi\" } | { kind: \"single\"; name: string };\n\nfunction resolveListLayout(deps: BackendDeps): ListLayout {\n return deps.singleList ? { kind: \"single\", name: deps.singleList } : { kind: \"multi\" };\n}\n\nfunction validateListName(name: string): string {\n if (\n name.length === 0 ||\n name === ARCHIVE_DIRECTORY_NAME ||\n name.startsWith(\".\") ||\n name.includes(\"/\") ||\n name.includes(\"\\\\\") ||\n name.includes(\"..\")\n ) {\n throw new Error(`Invalid task list name \"${name}\".`);\n }\n\n return name;\n}\n\nfunction parseQualifiedId(qualifiedId: string): {\n id: string;\n list: string;\n} {\n const separatorIndex = qualifiedId.indexOf(\"/\");\n\n if (\n separatorIndex <= 0 ||\n separatorIndex !== qualifiedId.lastIndexOf(\"/\") ||\n separatorIndex === qualifiedId.length - 1\n ) {\n throw new Error(`Invalid qualified task id \"${qualifiedId}\".`);\n }\n\n return {\n list: validateListName(qualifiedId.slice(0, separatorIndex)),\n id: validateTaskId(qualifiedId.slice(separatorIndex + 1))\n };\n}\n\nfunction listPath(rootPath: string, layout: ListLayout, list: string): string {\n return layout.kind === \"single\" ? rootPath : path.join(rootPath, list);\n}\n\nfunction archiveDirectoryPath(rootPath: string, layout: ListLayout, list: string): string {\n return layout.kind === \"single\"\n ? path.join(rootPath, ARCHIVE_DIRECTORY_NAME)\n : path.join(rootPath, list, ARCHIVE_DIRECTORY_NAME);\n}\n\nfunction activeTaskFilename(id: string, order: number, width: number): string {\n return `${String(order).padStart(width, \"0\")}-${id}${MARKDOWN_EXTENSION}`;\n}\n\nfunction archivedTaskPath(rootPath: string, layout: ListLayout, list: string, id: string): string {\n return path.join(archiveDirectoryPath(rootPath, layout, list), `${id}${MARKDOWN_EXTENSION}`);\n}\n\nfunction isMarkdownFile(entryName: string): boolean {\n return entryName.endsWith(MARKDOWN_EXTENSION);\n}\n\nfunction isHiddenEntry(entryName: string): boolean {\n return entryName.startsWith(\".\");\n}\n\nfunction isLockFile(entryName: string): boolean {\n return entryName.endsWith(\".lock\");\n}\n\nfunction isValidTaskIdShape(id: string): boolean {\n return (\n id.length > 0 &&\n !id.startsWith(\".\") &&\n !id.includes(\"/\") &&\n !id.includes(\"\\\\\") &&\n !id.includes(\"..\")\n );\n}\n\nfunction parseActiveFilename(entryName: string): { id: string; order: number | null } | undefined {\n if (!isMarkdownFile(entryName)) return undefined;\n const stem = entryName.slice(0, -MARKDOWN_EXTENSION.length);\n\n const match = /^(\\d+)-(.+)$/.exec(stem);\n if (match) {\n const id = match[2];\n if (isValidTaskIdShape(id)) {\n return { id, order: Number.parseInt(match[1], 10) };\n }\n }\n\n if (isValidTaskIdShape(stem)) {\n return { id: stem, order: null };\n }\n\n return undefined;\n}\n\nfunction padWidthForCount(count: number): number {\n return Math.max(MIN_PREFIX_WIDTH, String(Math.max(count, 1)).length);\n}\n\nfunction malformedTask(filePath: string, field: string): MalformedTaskError {\n return new MalformedTaskError(`Malformed task \"${filePath}\": invalid \"${field}\".`);\n}\n\nfunction stripTrailingCarriageReturn(line: string): string {\n return line.endsWith(\"\\r\") ? line.slice(0, -1) : line;\n}\n\nfunction splitTaskDocument(\n content: string,\n filePath: string,\n mode: BackendDeps[\"frontmatterMode\"]\n): {\n body: string;\n frontmatter: string;\n} {\n const lines = content.split(\"\\n\");\n const hasFrontmatterBlock =\n lines.length > 0 && stripTrailingCarriageReturn(lines[0]) === \"---\";\n\n if (!hasFrontmatterBlock) {\n if (mode === \"passthrough\") {\n return { frontmatter: \"\", body: content };\n }\n throw malformedTask(filePath, \"frontmatter\");\n }\n\n let closingIndex = -1;\n for (let index = 1; index < lines.length; index += 1) {\n if (stripTrailingCarriageReturn(lines[index]) === \"---\") {\n closingIndex = index;\n break;\n }\n }\n\n if (closingIndex === -1) {\n throw malformedTask(filePath, \"frontmatter\");\n }\n\n const bodyLines = lines.slice(closingIndex + 1);\n if (bodyLines.length > 0 && stripTrailingCarriageReturn(bodyLines[0]) === \"\") {\n bodyLines.shift();\n }\n\n return {\n frontmatter: lines.slice(1, closingIndex).join(\"\\n\"),\n body: bodyLines.join(\"\\n\")\n };\n}\n\nfunction readFrontmatter(frontmatterContent: string, filePath: string): TaskRecord {\n const document = parseDocument(frontmatterContent);\n\n if (document.errors.length > 0) {\n throw malformedTask(filePath, \"frontmatter\");\n }\n\n const parsed = document.toJS();\n if (!isRecord(parsed)) {\n throw malformedTask(filePath, \"frontmatter\");\n }\n\n return parsed;\n}\n\nfunction assertValidTaskRecord(\n frontmatter: TaskRecord,\n filePath: string,\n validStates: ReadonlySet<string>\n): void {\n if (\"$schema\" in frontmatter && frontmatter.$schema !== TASK_SCHEMA_ID) {\n throw malformedTask(filePath, \"$schema\");\n }\n\n if (\"kind\" in frontmatter && frontmatter.kind !== TASK_KIND) {\n throw malformedTask(filePath, \"kind\");\n }\n\n if (\"version\" in frontmatter) {\n if (\n typeof frontmatter.version !== \"number\" ||\n !Number.isInteger(frontmatter.version) ||\n frontmatter.version !== TASK_VERSION\n ) {\n throw malformedTask(filePath, \"version\");\n }\n }\n\n if (typeof frontmatter.name !== \"string\" || frontmatter.name.length === 0) {\n throw malformedTask(filePath, \"name\");\n }\n\n if (typeof frontmatter.state !== \"string\" || !validStates.has(frontmatter.state)) {\n throw malformedTask(filePath, \"state\");\n }\n\n if (\"description\" in frontmatter && typeof frontmatter.description !== \"string\") {\n throw malformedTask(filePath, \"description\");\n }\n}\n\nfunction reservedFrontmatterKeys(mode: BackendDeps[\"frontmatterMode\"]): ReadonlySet<string> {\n return mode === \"passthrough\" ? PASSTHROUGH_RESERVED_FRONTMATTER_KEYS : RESERVED_FRONTMATTER_KEYS;\n}\n\nfunction metadataFromFrontmatter(\n frontmatter: TaskRecord,\n mode: BackendDeps[\"frontmatterMode\"]\n): Record<string, unknown> {\n const metadata: Record<string, unknown> = {};\n const reservedKeys = reservedFrontmatterKeys(mode);\n\n for (const [key, value] of Object.entries(frontmatter)) {\n if (!reservedKeys.has(key)) {\n metadata[key] = value;\n }\n }\n\n return metadata;\n}\n\nfunction createTask(\n list: string,\n id: string,\n frontmatter: TaskRecord,\n body: string,\n mode: BackendDeps[\"frontmatterMode\"],\n sourcePath?: string\n): Task {\n return {\n list,\n id,\n qualifiedId: `${list}/${id}`,\n name: frontmatter.name as string,\n state: frontmatter.state as string,\n description: body,\n metadata: metadataFromFrontmatter(frontmatter, mode),\n ...(sourcePath !== undefined && { sourcePath: path.resolve(sourcePath) })\n };\n}\n\nfunction serializeTaskDocument(frontmatter: TaskRecord, description: string): string {\n return `---\\n${stringify(frontmatter)}---\\n\\n${description}`;\n}\n\nasync function readDirectoryNames(fs: TaskListFs, directoryPath: string): Promise<string[]> {\n try {\n return sortStrings(await fs.readdir(directoryPath));\n } catch (error) {\n if (hasErrorCode(error, \"ENOENT\")) {\n return [];\n }\n\n throw error;\n }\n}\n\nasync function ensureRootPath(deps: BackendDeps): Promise<void> {\n if (deps.create) {\n await deps.fs.mkdir(deps.path, { recursive: true });\n return;\n }\n\n await deps.fs.stat(deps.path);\n}\n\nasync function readTaskFile(\n fs: TaskListFs,\n list: string,\n id: string,\n filePath: string,\n validStates: ReadonlySet<string>,\n initialState: string,\n mode: BackendDeps[\"frontmatterMode\"]\n): Promise<TaskFile> {\n const content = await fs.readFile(filePath, \"utf8\");\n const document = splitTaskDocument(content, filePath, mode);\n const frontmatter =\n mode === \"passthrough\" && document.frontmatter.trim().length === 0\n ? {}\n : readFrontmatter(document.frontmatter, filePath);\n\n if (mode !== \"passthrough\") {\n assertValidTaskRecord(frontmatter, filePath, validStates);\n return {\n path: filePath,\n frontmatter,\n task: createTask(list, id, frontmatter, document.body, mode, filePath)\n };\n }\n\n const parsedFilename = parseActiveFilename(path.basename(filePath));\n const defaultName = parsedFilename?.id ?? id;\n const effectiveFrontmatter: TaskRecord = {\n ...frontmatter,\n name: typeof frontmatter.name === \"string\" ? frontmatter.name : defaultName,\n state:\n typeof frontmatter.state === \"string\" && validStates.has(frontmatter.state)\n ? frontmatter.state\n : initialState\n };\n\n return {\n path: filePath,\n frontmatter,\n task: createTask(list, id, effectiveFrontmatter, document.body, mode, filePath)\n };\n}\n\nasync function findActiveTaskFilename(\n fs: TaskListFs,\n listDirectoryPath: string,\n id: string\n): Promise<string | undefined> {\n const entries = await readDirectoryNames(fs, listDirectoryPath);\n for (const entryName of entries) {\n if (isHiddenEntry(entryName) || isLockFile(entryName)) continue;\n const parsed = parseActiveFilename(entryName);\n if (parsed?.id === id) {\n return entryName;\n }\n }\n return undefined;\n}\n\nasync function findTaskLocation(\n fs: TaskListFs,\n rootPath: string,\n layout: ListLayout,\n list: string,\n id: string\n): Promise<TaskLocation | undefined> {\n const listDirectoryPath = listPath(rootPath, layout, list);\n const activeName = await findActiveTaskFilename(fs, listDirectoryPath, id);\n if (activeName) {\n const activePath = path.join(listDirectoryPath, activeName);\n const activeStat = await statIfExists(fs, activePath);\n if (activeStat?.isFile()) {\n return { archived: false, path: activePath };\n }\n }\n\n const archivedPath = archivedTaskPath(rootPath, layout, list, id);\n const archivedStat = await statIfExists(fs, archivedPath);\n if (archivedStat?.isFile()) {\n return { archived: true, path: archivedPath };\n }\n\n return undefined;\n}\n\nasync function readTaskAtLocation(\n fs: TaskListFs,\n rootPath: string,\n layout: ListLayout,\n list: string,\n id: string,\n validStates: ReadonlySet<string>,\n initialState: string,\n mode: BackendDeps[\"frontmatterMode\"]\n): Promise<TaskFile> {\n const location = await findTaskLocation(fs, rootPath, layout, list, id);\n\n if (!location) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n return readTaskFile(fs, list, id, location.path, validStates, initialState, mode);\n}\n\nfunction createdFrontmatter(\n defaults: BackendDeps[\"defaults\"],\n input: TaskCreate,\n initialState: string,\n mode: BackendDeps[\"frontmatterMode\"]\n): TaskRecord {\n const frontmatter: TaskRecord =\n mode !== \"passthrough\"\n ? {\n $schema: TASK_SCHEMA_ID,\n kind: TASK_KIND,\n version: TASK_VERSION,\n name: input.name,\n state: initialState\n }\n : {\n name: input.name,\n state: initialState\n };\n const reservedKeys = reservedFrontmatterKeys(mode);\n\n for (const [key, value] of Object.entries(defaults.metadata)) {\n if (!reservedKeys.has(key)) {\n frontmatter[key] = value;\n }\n }\n\n for (const [key, value] of Object.entries(input.metadata ?? {})) {\n if (!reservedKeys.has(key)) {\n frontmatter[key] = value;\n }\n }\n\n frontmatter.created = new Date().toISOString();\n return frontmatter;\n}\n\nfunction updatedFrontmatter(\n existingFrontmatter: TaskRecord,\n task: Task,\n patch: TaskUpdate,\n mode: BackendDeps[\"frontmatterMode\"]\n): TaskRecord {\n const nextFrontmatter: TaskRecord =\n mode !== \"passthrough\"\n ? {\n ...existingFrontmatter,\n $schema: existingFrontmatter.$schema ?? TASK_SCHEMA_ID,\n kind: existingFrontmatter.kind ?? TASK_KIND,\n version: existingFrontmatter.version ?? TASK_VERSION,\n name: patch.name ?? task.name,\n state: task.state\n }\n : {\n ...existingFrontmatter,\n name: patch.name ?? task.name,\n state: task.state\n };\n const reservedKeys = reservedFrontmatterKeys(mode);\n\n for (const [key, value] of Object.entries(patch.metadata ?? {})) {\n if (!reservedKeys.has(key)) {\n nextFrontmatter[key] = value;\n }\n }\n\n return nextFrontmatter;\n}\n\nfunction transitionedFrontmatter(\n existingFrontmatter: TaskRecord,\n task: Task,\n to: string,\n mode: BackendDeps[\"frontmatterMode\"]\n): TaskRecord {\n return mode !== \"passthrough\"\n ? {\n ...existingFrontmatter,\n $schema: existingFrontmatter.$schema ?? TASK_SCHEMA_ID,\n kind: existingFrontmatter.kind ?? TASK_KIND,\n version: existingFrontmatter.version ?? TASK_VERSION,\n name: task.name,\n state: to\n }\n : {\n ...existingFrontmatter,\n name: task.name,\n state: to\n };\n}\n\nfunction firedFrontmatter(\n existingFrontmatter: TaskRecord,\n task: Task,\n to: string,\n mode: BackendDeps[\"frontmatterMode\"],\n metadataPatch?: Record<string, unknown>\n): TaskRecord {\n const nextFrontmatter = transitionedFrontmatter(existingFrontmatter, task, to, mode);\n const reservedKeys = reservedFrontmatterKeys(mode);\n\n for (const [key, value] of Object.entries(metadataPatch ?? {})) {\n if (!reservedKeys.has(key)) {\n nextFrontmatter[key] = value;\n }\n }\n\n return nextFrontmatter;\n}\n\nfunction assertCreateDoesNotSetState(input: TaskCreate): void {\n if (Object.prototype.hasOwnProperty.call(input, \"state\")) {\n throw new Error(\n 'Tasks.create() does not accept \"state\"; new tasks always start at stateMachine.initial.'\n );\n }\n}\n\nfunction assertCreateHasId(input: TaskCreate): asserts input is TaskCreate & { id: string } {\n if (input.id === undefined) {\n throw new Error(\"id is required for markdown-dir backend\");\n }\n}\n\nfunction assertUpdateDoesNotSetState(patch: TaskUpdate): void {\n if (Object.prototype.hasOwnProperty.call(patch, \"state\")) {\n throw new Error('Tasks.update() does not accept \"state\"; use fire() to change task state.');\n }\n}\n\ninterface ActiveEntry {\n id: string;\n order: number | null;\n filename: string;\n}\n\nfunction createTasksView(deps: BackendDeps, layout: ListLayout, list: string): Tasks {\n const listDirectoryPath = listPath(deps.path, layout, list);\n const stateMachine = resolveStateMachine(deps.stateMachine);\n const validStates = new Set(stateMachine.states);\n\n async function readActiveEntries(): Promise<ActiveEntry[]> {\n const entries = await readDirectoryNames(deps.fs, listDirectoryPath);\n const result: ActiveEntry[] = [];\n\n for (const entryName of entries) {\n if (isHiddenEntry(entryName) || isLockFile(entryName)) continue;\n const parsed = parseActiveFilename(entryName);\n if (!parsed) continue;\n\n const entryPath = path.join(listDirectoryPath, entryName);\n const entryStat = await statIfExists(deps.fs, entryPath);\n if (!entryStat?.isFile()) continue;\n\n result.push({ id: parsed.id, order: parsed.order, filename: entryName });\n }\n\n result.sort((left, right) => {\n const leftOrder = left.order ?? Number.POSITIVE_INFINITY;\n const rightOrder = right.order ?? Number.POSITIVE_INFINITY;\n if (leftOrder !== rightOrder) return leftOrder - rightOrder;\n return left.filename.localeCompare(right.filename);\n });\n\n return result;\n }\n\n async function readActiveTasks(): Promise<{\n entries: ActiveEntry[];\n tasks: Map<string, { task: Task; raw: TaskRecord }>;\n }> {\n const entries = await readActiveEntries();\n const tasks = new Map<string, { task: Task; raw: TaskRecord }>();\n\n for (const entry of entries) {\n const filePath = path.join(listDirectoryPath, entry.filename);\n const file = await readTaskFile(\n deps.fs,\n list,\n entry.id,\n filePath,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n tasks.set(entry.id, { task: file.task, raw: file.frontmatter });\n }\n\n return { entries, tasks };\n }\n\n async function readArchivedTasks(): Promise<{ task: Task; raw: TaskRecord }[]> {\n const archivePath = archiveDirectoryPath(deps.path, layout, list);\n const entries = await readDirectoryNames(deps.fs, archivePath);\n const result: { task: Task; raw: TaskRecord }[] = [];\n\n for (const entryName of entries) {\n if (isHiddenEntry(entryName) || isLockFile(entryName) || !isMarkdownFile(entryName)) continue;\n\n const entryPath = path.join(archivePath, entryName);\n const entryStat = await statIfExists(deps.fs, entryPath);\n if (!entryStat?.isFile()) continue;\n\n const id = entryName.slice(0, -MARKDOWN_EXTENSION.length);\n const file = await readTaskFile(\n deps.fs,\n list,\n id,\n entryPath,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n result.push({ task: file.task, raw: file.frontmatter });\n }\n\n return result.sort((left, right) =>\n left.task.qualifiedId.localeCompare(right.task.qualifiedId)\n );\n }\n\n async function renameActiveEntries(\n entries: ActiveEntry[],\n desiredOrdersById: ReadonlyMap<string, number>\n ): Promise<void> {\n const staged: { from: string; to: string }[] = [];\n const maxOrder = Math.max(...desiredOrdersById.values(), entries.length);\n const width = padWidthForCount(maxOrder);\n\n for (let index = 0; index < entries.length; index += 1) {\n const entry = entries[index];\n const desiredOrder = desiredOrdersById.get(entry.id);\n if (desiredOrder === undefined) continue;\n\n const desiredFilename = activeTaskFilename(entry.id, desiredOrder, width);\n if (entry.filename !== desiredFilename) {\n const fromPath = path.join(listDirectoryPath, entry.filename);\n const stagingPath = path.join(\n listDirectoryPath,\n `${desiredFilename}.staging-${process.pid}-${index}`\n );\n const targetPath = path.join(listDirectoryPath, desiredFilename);\n await deps.fs.rename(fromPath, stagingPath);\n staged.push({ from: stagingPath, to: targetPath });\n }\n }\n\n for (const entry of staged) {\n await deps.fs.rename(entry.from, entry.to);\n }\n }\n\n async function rewriteListPrefixes(orderedIds: readonly string[]): Promise<void> {\n const entries = await readActiveEntries();\n const byId = new Map(entries.map((entry) => [entry.id, entry]));\n const desiredOrdersById = new Map<string, number>();\n\n for (let index = 0; index < orderedIds.length; index += 1) {\n const id = orderedIds[index];\n const entry = byId.get(id);\n if (!entry) continue;\n\n desiredOrdersById.set(id, index + 1);\n }\n\n await renameActiveEntries(entries, desiredOrdersById);\n }\n\n function entryOrder(entry: ActiveEntry, index: number): number {\n return entry.order ?? index + 1;\n }\n\n async function rewriteMovedPrefix(movedId: string, orderedIds: readonly string[]): Promise<void> {\n const entries = await readActiveEntries();\n const byId = new Map(entries.map((entry, index) => [entry.id, { entry, index }]));\n const movedIndex = orderedIds.indexOf(movedId);\n const moved = byId.get(movedId);\n if (movedIndex < 0 || moved === undefined) return;\n\n const desiredOrdersById = new Map<string, number>();\n const previousId = movedIndex > 0 ? orderedIds[movedIndex - 1] : undefined;\n const nextId = movedIndex < orderedIds.length - 1 ? orderedIds[movedIndex + 1] : undefined;\n const previous = previousId === undefined ? undefined : byId.get(previousId);\n const next = nextId === undefined ? undefined : byId.get(nextId);\n\n if (previous !== undefined && next === undefined) {\n desiredOrdersById.set(movedId, entryOrder(previous.entry, previous.index) + 1);\n await renameActiveEntries(entries, desiredOrdersById);\n return;\n }\n\n if (previous === undefined && next !== undefined) {\n const nextOrder = entryOrder(next.entry, next.index);\n if (nextOrder > 1) {\n desiredOrdersById.set(movedId, nextOrder - 1);\n await renameActiveEntries(entries, desiredOrdersById);\n return;\n }\n\n desiredOrdersById.set(movedId, 1);\n let lastOrder = 1;\n for (let index = movedIndex + 1; index < orderedIds.length; index += 1) {\n const candidate = byId.get(orderedIds[index]);\n if (candidate === undefined) continue;\n\n const currentOrder = entryOrder(candidate.entry, candidate.index);\n if (currentOrder > lastOrder) break;\n\n lastOrder += 1;\n desiredOrdersById.set(candidate.entry.id, lastOrder);\n }\n\n await renameActiveEntries(entries, desiredOrdersById);\n return;\n }\n\n if (previous !== undefined && next !== undefined) {\n const previousOrder = entryOrder(previous.entry, previous.index);\n const nextOrder = entryOrder(next.entry, next.index);\n\n if (nextOrder - previousOrder > 1) {\n desiredOrdersById.set(movedId, previousOrder + 1);\n await renameActiveEntries(entries, desiredOrdersById);\n return;\n }\n\n let lastOrder = previousOrder + 1;\n desiredOrdersById.set(movedId, lastOrder);\n for (let index = movedIndex + 1; index < orderedIds.length; index += 1) {\n const candidate = byId.get(orderedIds[index]);\n if (candidate === undefined) continue;\n\n const currentOrder = entryOrder(candidate.entry, candidate.index);\n if (currentOrder > lastOrder) break;\n\n lastOrder += 1;\n desiredOrdersById.set(candidate.entry.id, lastOrder);\n }\n\n await renameActiveEntries(entries, desiredOrdersById);\n }\n }\n\n async function withListLock<T>(action: () => Promise<T>): Promise<T> {\n await deps.fs.mkdir(listDirectoryPath, { recursive: true });\n const release = await acquireFileLock(path.join(listDirectoryPath, ORDER_LOCK_FILENAME), {\n fs: deps.fs,\n staleMs: deps.lockStaleMs,\n retries: deps.lockRetries\n });\n\n try {\n return await action();\n } finally {\n await release();\n }\n }\n\n async function withTaskLock<T>(id: string, action: () => Promise<T>): Promise<T> {\n validateTaskId(id);\n return withListLock(action);\n }\n\n async function withLocatedTaskLock<T>(location: TaskLocation, action: () => Promise<T>) {\n const release = await acquireFileLock(location.path, {\n fs: deps.fs,\n staleMs: deps.lockStaleMs,\n retries: deps.lockRetries\n });\n\n try {\n return await action();\n } finally {\n await release();\n }\n }\n\n async function getTaskFile(id: string): Promise<TaskFile> {\n validateTaskId(id);\n return readTaskAtLocation(\n deps.fs,\n deps.path,\n layout,\n list,\n id,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n }\n\n function assertFireableTaskEvent(task: Task, eventName: string) {\n const event = findEvent(stateMachine, task.state, eventName);\n\n if (event === undefined) {\n throw new InvalidTransitionError({\n task,\n event: eventName,\n to: stateMachine.events[eventName]?.to,\n reason: `Cannot fire event \"${eventName}\" from task state \"${task.state}\".`\n });\n }\n\n return event;\n }\n\n return {\n name: list,\n stateMachine,\n async all(filter?: ListFilter): Promise<Task[]> {\n const { entries: activeEntries, tasks: activeTasks } = await readActiveTasks();\n const archivedEntries = filter?.includeArchived ? await readArchivedTasks() : [];\n\n const orderedActive: OrderedEntry[] = activeEntries\n .map((entry) => activeTasks.get(entry.id)!)\n .filter((entry) => {\n if (filter?.state && entry.task.state !== filter.state) return false;\n return true;\n });\n\n const filteredArchived = archivedEntries.filter((entry) => {\n if (filter?.state && entry.task.state !== filter.state) return false;\n return true;\n });\n\n const orderedActiveTasks = applyOrder(orderedActive, filter?.order);\n return [...orderedActiveTasks, ...filteredArchived.map((entry) => entry.task)];\n },\n async get(id: string): Promise<Task> {\n return (await getTaskFile(id)).task;\n },\n async create(input: TaskCreate): Promise<Task> {\n assertCreateDoesNotSetState(input);\n assertCreateHasId(input);\n validateTaskId(input.id);\n await deps.fs.mkdir(listDirectoryPath, { recursive: true });\n\n return withListLock(async () => {\n const existing = await findTaskLocation(deps.fs, deps.path, layout, list, input.id);\n if (existing) {\n throw new TaskAlreadyExistsError(`Task \"${list}/${input.id}\" already exists.`);\n }\n\n const activeEntries = await readActiveEntries();\n const maxOrder = activeEntries.reduce(\n (max, entry) => (entry.order !== null && entry.order > max ? entry.order : max),\n 0\n );\n const nextOrder = maxOrder + 1;\n const width = padWidthForCount(activeEntries.length + 1);\n const filename = activeTaskFilename(input.id, nextOrder, width);\n const targetPath = path.join(listDirectoryPath, filename);\n\n const frontmatter = createdFrontmatter(\n deps.defaults,\n input,\n stateMachine.initial,\n deps.frontmatterMode\n );\n const description = input.description ?? \"\";\n\n await writeAtomically(deps.fs, targetPath, serializeTaskDocument(frontmatter, description));\n\n return createTask(\n list,\n input.id,\n frontmatter,\n description,\n deps.frontmatterMode,\n targetPath\n );\n });\n },\n async update(id: string, patch: TaskUpdate): Promise<Task> {\n assertUpdateDoesNotSetState(patch);\n\n return withTaskLock(id, async () => {\n const existing = await getTaskFile(id);\n const nextFrontmatter = updatedFrontmatter(\n existing.frontmatter,\n existing.task,\n patch,\n deps.frontmatterMode\n );\n const description = patch.description ?? existing.task.description;\n\n await writeAtomically(\n deps.fs,\n existing.path,\n serializeTaskDocument(nextFrontmatter, description)\n );\n\n return createTask(\n list,\n id,\n nextFrontmatter,\n description,\n deps.frontmatterMode,\n existing.path\n );\n });\n },\n async fire(id: string, eventName: string, opts?: TaskFireOptions): Promise<Task> {\n const fireTask = async (): Promise<Task> => {\n const existing = await getTaskFile(id);\n const event = assertFireableTaskEvent(existing.task, eventName);\n const guardResult = event.guard?.(existing.task) ?? true;\n\n if (guardResult !== true) {\n throw new InvalidTransitionError({\n task: existing.task,\n event: eventName,\n to: event.to,\n reason: guardResult\n });\n }\n\n await event.onExit?.(existing.task);\n\n const nextFrontmatter = firedFrontmatter(\n existing.frontmatter,\n existing.task,\n event.to,\n deps.frontmatterMode,\n opts?.metadataPatch\n );\n const serializedTask = serializeTaskDocument(nextFrontmatter, existing.task.description);\n\n if (event.to === \"archived\") {\n const targetPath = archivedTaskPath(deps.path, layout, list, id);\n const archivedTargetExists = await statIfExists(deps.fs, targetPath);\n if (archivedTargetExists?.isFile()) {\n throw new TaskAlreadyExistsError(`Task \"${list}/${id}\" already exists in archive.`);\n }\n\n await writeAtomically(deps.fs, existing.path, serializedTask);\n await deps.fs.mkdir(archiveDirectoryPath(deps.path, layout, list), { recursive: true });\n await deps.fs.rename(existing.path, targetPath);\n const nextTask = createTask(\n list,\n id,\n nextFrontmatter,\n existing.task.description,\n deps.frontmatterMode,\n targetPath\n );\n await event.onEnter?.(nextTask);\n\n return nextTask;\n }\n\n await writeAtomically(deps.fs, existing.path, serializedTask);\n const nextTask = createTask(\n list,\n id,\n nextFrontmatter,\n existing.task.description,\n deps.frontmatterMode,\n existing.path\n );\n await event.onEnter?.(nextTask);\n\n return nextTask;\n };\n\n if (stateMachine.events[eventName]?.to === \"archived\") {\n validateTaskId(id);\n\n return withListLock(async () => {\n const location = await findTaskLocation(deps.fs, deps.path, layout, list, id);\n if (!location) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n return withLocatedTaskLock(location, fireTask);\n });\n }\n\n return withTaskLock(id, fireTask);\n },\n async canFire(id: string, eventName: string): Promise<boolean> {\n const task = (await getTaskFile(id)).task;\n const event = findEvent(stateMachine, task.state, eventName);\n\n if (event === undefined) {\n return false;\n }\n\n return (event.guard?.(task) ?? true) === true;\n },\n async events(id: string): Promise<readonly string[]> {\n const task = (await getTaskFile(id)).task;\n return eventsFromState(stateMachine, task.state);\n },\n async delete(id: string): Promise<void> {\n await withTaskLock(id, async () => {\n const location = await findTaskLocation(deps.fs, deps.path, layout, list, id);\n if (!location) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n await deps.fs.unlink(location.path);\n });\n },\n async move(id: string, anchor: MoveAnchor): Promise<Task> {\n validateTaskId(id);\n\n return withListLock(async () => {\n const { entries } = await readActiveTasks();\n const fromIndex = entries.findIndex((entry) => entry.id === id);\n if (fromIndex < 0) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n const ordered = entries.map((entry) => entry.id);\n ordered.splice(fromIndex, 1);\n\n let insertIndex: number;\n if (\"position\" in anchor) {\n insertIndex = anchor.position === \"top\" ? 0 : ordered.length;\n } else {\n const anchorId = \"before\" in anchor ? anchor.before : anchor.after;\n const anchorIndex = ordered.indexOf(anchorId);\n if (anchorIndex < 0) {\n throw new AnchorNotFoundError(anchorId);\n }\n insertIndex = \"before\" in anchor ? anchorIndex : anchorIndex + 1;\n }\n\n ordered.splice(insertIndex, 0, id);\n await rewriteMovedPrefix(id, ordered);\n\n return (await getTaskFile(id)).task;\n });\n },\n async reorder(ids: readonly string[]): Promise<readonly Task[]> {\n for (const id of ids) {\n validateTaskId(id);\n }\n\n return withListLock(async () => {\n const { entries } = await readActiveTasks();\n const currentIds = entries.map((entry) => entry.id);\n const currentSet = new Set(currentIds);\n const inputSet = new Set(ids);\n const missing = currentIds.filter((id) => !inputSet.has(id));\n const extra = ids.filter((id) => !currentSet.has(id));\n\n if (missing.length > 0 || extra.length > 0) {\n throw new OrderMismatchError({ missing, extra });\n }\n\n await rewriteListPrefixes(ids);\n\n return Promise.all(ids.map(async (id) => (await getTaskFile(id)).task));\n });\n }\n };\n}\n\nexport async function markdownDirBackend(deps: BackendDeps): Promise<TaskList> {\n await ensureRootPath(deps);\n const layout = resolveListLayout(deps);\n const stateMachine = resolveStateMachine(deps.stateMachine);\n const validStates = new Set(stateMachine.states);\n\n const list = (name: string): Tasks => {\n if (layout.kind === \"single\") {\n if (name !== layout.name) {\n throw new Error(`Task list \"${name}\" not found.`);\n }\n\n return createTasksView(deps, layout, name);\n }\n\n const listName = validateListName(name);\n return createTasksView(deps, layout, listName);\n };\n\n const lists = async (): Promise<string[]> => {\n if (layout.kind === \"single\") {\n return [layout.name];\n }\n\n const entries = await readDirectoryNames(deps.fs, deps.path);\n const result: string[] = [];\n\n for (const entryName of entries) {\n if (\n entryName === ARCHIVE_DIRECTORY_NAME ||\n isHiddenEntry(entryName) ||\n isLockFile(entryName)\n ) {\n continue;\n }\n\n const entryPath = path.join(deps.path, entryName);\n const entryStat = await statIfExists(deps.fs, entryPath);\n if (entryStat?.isDirectory()) {\n result.push(entryName);\n }\n }\n\n return sortStrings(result);\n };\n\n const allTasks = async (filter?: ListFilter): Promise<Task[]> => {\n const allLists = await lists();\n const tasks: Task[] = [];\n\n for (const taskListName of allLists) {\n tasks.push(...(await list(taskListName).all(filter)));\n }\n\n return tasks;\n };\n\n const get = async (qualifiedId: string): Promise<Task> => {\n const { list: listName, id } = parseQualifiedId(qualifiedId);\n return list(listName).get(id);\n };\n\n const moveBetweenLists = async (qualifiedId: string, targetList: string): Promise<Task> => {\n if (layout.kind === \"single\") {\n throw new Error(\"moveBetweenLists is unsupported in single-list mode.\");\n }\n\n const { list: sourceListName, id } = parseQualifiedId(qualifiedId);\n const targetListName = validateListName(targetList);\n\n if (sourceListName === targetListName) {\n const file = await readTaskAtLocation(\n deps.fs,\n deps.path,\n layout,\n sourceListName,\n id,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n return file.task;\n }\n\n const targetExisting = await findTaskLocation(deps.fs, deps.path, layout, targetListName, id);\n if (targetExisting) {\n throw new TaskAlreadyExistsError(`Task \"${targetListName}/${id}\" already exists.`);\n }\n\n const sourceLocation = await findTaskLocation(deps.fs, deps.path, layout, sourceListName, id);\n if (!sourceLocation) {\n throw new TaskNotFoundError(`Task \"${sourceListName}/${id}\" not found.`);\n }\n\n const targetListDir = listPath(deps.path, layout, targetListName);\n await deps.fs.mkdir(targetListDir, { recursive: true });\n\n const targetEntries = await (async () => {\n const out: ActiveEntry[] = [];\n const names = await readDirectoryNames(deps.fs, targetListDir);\n for (const entryName of names) {\n if (isHiddenEntry(entryName) || isLockFile(entryName)) continue;\n const parsed = parseActiveFilename(entryName);\n if (!parsed) continue;\n out.push({ id: parsed.id, order: parsed.order, filename: entryName });\n }\n return out;\n })();\n\n if (sourceLocation.archived) {\n const archivedTargetDir = archiveDirectoryPath(deps.path, layout, targetListName);\n await deps.fs.mkdir(archivedTargetDir, { recursive: true });\n const archivedTargetPath = archivedTaskPath(deps.path, layout, targetListName, id);\n await deps.fs.rename(sourceLocation.path, archivedTargetPath);\n const file = await readTaskFile(\n deps.fs,\n targetListName,\n id,\n archivedTargetPath,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n return file.task;\n }\n\n const maxOrder = targetEntries.reduce(\n (max, entry) => (entry.order !== null && entry.order > max ? entry.order : max),\n 0\n );\n const width = padWidthForCount(targetEntries.length + 1);\n const targetFilename = activeTaskFilename(id, maxOrder + 1, width);\n const targetPath = path.join(targetListDir, targetFilename);\n\n await deps.fs.rename(sourceLocation.path, targetPath);\n const file = await readTaskFile(\n deps.fs,\n targetListName,\n id,\n targetPath,\n validStates,\n stateMachine.initial,\n deps.frontmatterMode\n );\n return file.task;\n };\n\n return {\n list,\n lists,\n allTasks,\n get,\n moveBetweenLists\n };\n}\n", "import * as fsPromises from \"node:fs/promises\";\nimport * as os from \"node:os\";\n\nexport interface FileLockFs {\n open(path: string, flags: string): Promise<{\n close(): Promise<void>;\n writeFile(\n data: string,\n options?: BufferEncoding | { encoding?: BufferEncoding }\n ): Promise<void>;\n }>;\n stat(path: string): Promise<{\n mtimeMs: number;\n }>;\n readFile?(path: string, encoding: BufferEncoding): Promise<string>;\n unlink(path: string): Promise<void>;\n}\n\nexport interface FileLockOptions {\n staleMs?: number;\n retries?: number;\n minTimeout?: number;\n maxTimeout?: number;\n fs?: FileLockFs;\n isPidRunning?: (pid: number) => boolean;\n signal?: AbortSignal;\n}\n\nexport type ReleaseLock = () => Promise<void>;\n\nexport class LockTimeoutError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"LockTimeoutError\";\n }\n}\n\nfunction createAbortError(): Error {\n const error = new Error(\"The operation was aborted.\");\n error.name = \"AbortError\";\n return error;\n}\n\nfunction throwIfAborted(signal?: AbortSignal): void {\n if (signal?.aborted) {\n throw createAbortError();\n }\n}\n\nfunction sleep(ms: number, signal?: AbortSignal): Promise<void> {\n if (!signal) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n\n if (signal.aborted) {\n return Promise.reject(createAbortError());\n }\n\n return new Promise((resolve, reject) => {\n const timeoutId = setTimeout(() => {\n signal.removeEventListener(\"abort\", onAbort);\n resolve();\n }, ms);\n\n const onAbort = () => {\n clearTimeout(timeoutId);\n signal.removeEventListener(\"abort\", onAbort);\n reject(createAbortError());\n };\n\n signal.addEventListener(\"abort\", onAbort, { once: true });\n });\n}\n\nfunction backoff(attempt: number, minTimeout: number, maxTimeout: number): number {\n const delay = Math.min(maxTimeout, minTimeout * 2 ** attempt);\n return delay + Math.random() * delay * 0.1;\n}\n\nfunction hasErrorCode(error: unknown, code: string): boolean {\n return (\n !!error &&\n typeof error === \"object\" &&\n \"code\" in error &&\n (error as { code?: unknown }).code === code\n );\n}\n\nfunction hasAnyErrorCode(error: unknown, codes: readonly string[]): boolean {\n return codes.some((code) => hasErrorCode(error, code));\n}\n\nfunction isPidRunning(pid: number): boolean {\n try {\n process.kill(pid, 0);\n return true;\n } catch (error) {\n return !hasErrorCode(error, \"ESRCH\");\n }\n}\n\nfunction createDefaultFs(): FileLockFs {\n return {\n open: (path, flags) => fsPromises.open(path, flags),\n readFile: (path, encoding) => fsPromises.readFile(path, encoding),\n stat: fsPromises.stat,\n unlink: fsPromises.unlink\n };\n}\n\nasync function removeLockFile(\n fs: FileLockFs,\n lockPath: string,\n signal?: AbortSignal\n): Promise<void> {\n for (let attempt = 0; attempt <= 4; attempt += 1) {\n throwIfAborted(signal);\n\n try {\n await fs.unlink(lockPath);\n return;\n } catch (error) {\n if (hasErrorCode(error, \"ENOENT\")) {\n return;\n }\n\n if (!hasAnyErrorCode(error, [\"EPERM\", \"EBUSY\"]) || attempt === 4) {\n throw error;\n }\n }\n\n await sleep(25 * 2 ** attempt, signal);\n }\n}\n\ntype LockMetadata = {\n host: string;\n pid: number;\n};\n\nfunction parseLockMetadata(content: string): LockMetadata | undefined {\n try {\n const parsed = JSON.parse(content) as unknown;\n if (!parsed || typeof parsed !== \"object\" || !(\"host\" in parsed) || !(\"pid\" in parsed)) {\n return undefined;\n }\n\n const { host, pid } = parsed;\n if (typeof host === \"string\" && typeof pid === \"number\" && Number.isSafeInteger(pid) && pid > 0) {\n return {\n host,\n pid\n };\n }\n } catch (ignoredError) {\n void ignoredError;\n }\n\n return undefined;\n}\n\nasync function readLockMetadata(\n fs: FileLockFs,\n lockPath: string\n): Promise<LockMetadata | undefined | null> {\n if (!fs.readFile) {\n return undefined;\n }\n\n try {\n return parseLockMetadata(await fs.readFile(lockPath, \"utf8\"));\n } catch (error) {\n if (hasErrorCode(error, \"ENOENT\")) {\n return null;\n }\n\n return undefined;\n }\n}\n\nasync function shouldReclaimLock(options: {\n fs: FileLockFs;\n isPidRunning: (pid: number) => boolean;\n lockPath: string;\n staleMs: number;\n stat: Awaited<ReturnType<FileLockFs[\"stat\"]>>;\n}): Promise<boolean | \"missing\"> {\n const metadata = await readLockMetadata(options.fs, options.lockPath);\n if (metadata === null) {\n return \"missing\";\n }\n\n if (metadata?.host === os.hostname()) {\n return !options.isPidRunning(metadata.pid);\n }\n\n return Date.now() - options.stat.mtimeMs > options.staleMs;\n}\n\nasync function writeLockMetadata(handle: Awaited<ReturnType<FileLockFs[\"open\"]>>): Promise<void> {\n try {\n await handle.writeFile(\n JSON.stringify({ pid: process.pid, host: os.hostname(), acquiredAt: new Date().toISOString() }),\n { encoding: \"utf8\" }\n );\n } catch (ignoredError) {\n void ignoredError;\n }\n try {\n await handle.close();\n } catch (ignoredError) {\n void ignoredError;\n }\n}\n\nexport async function acquireFileLock(\n filePath: string,\n options: FileLockOptions = {}\n): Promise<ReleaseLock> {\n const fs = options.fs ?? createDefaultFs();\n const retries = options.retries ?? 20;\n const minTimeout = options.minTimeout ?? 25;\n const maxTimeout = options.maxTimeout ?? 250;\n const staleMs = options.staleMs ?? 1_000;\n const pidIsRunning = options.isPidRunning ?? isPidRunning;\n const lockPath = `${filePath}.lock`;\n\n let attempt = 0;\n\n while (attempt <= retries) {\n throwIfAborted(options.signal);\n\n try {\n const handle = await fs.open(lockPath, \"wx\");\n await writeLockMetadata(handle);\n let released = false;\n\n return async () => {\n if (released) {\n return;\n }\n\n released = true;\n await removeLockFile(fs, lockPath, options.signal);\n };\n } catch (error) {\n if (!hasErrorCode(error, \"EEXIST\")) {\n throw error;\n }\n }\n\n let stat: Awaited<ReturnType<FileLockFs[\"stat\"]>>;\n try {\n stat = await fs.stat(lockPath);\n } catch (statError) {\n if (hasErrorCode(statError, \"ENOENT\")) {\n continue;\n }\n\n throw statError;\n }\n\n const reclaimLock = await shouldReclaimLock({\n fs,\n isPidRunning: pidIsRunning,\n lockPath,\n staleMs,\n stat\n });\n if (reclaimLock === \"missing\") {\n continue;\n }\n\n if (reclaimLock) {\n await removeLockFile(fs, lockPath, options.signal);\n continue;\n }\n\n if (attempt >= retries) {\n break;\n }\n\n await sleep(backoff(attempt, minTimeout, maxTimeout), options.signal);\n attempt += 1;\n }\n\n throw new LockTimeoutError(`Failed to acquire lock on \"${filePath}\".`);\n}\n", "{\n \"$schema\": \"https://json-schema.org/draft/2020-12/schema\",\n \"$id\": \"https://poe-platform.github.io/poe-code/schemas/task-list/task.schema.json\",\n \"title\": \"Task\",\n \"description\": \"Persisted task payload used by task-list backends.\",\n \"type\": \"object\",\n \"properties\": {\n \"$schema\": {\n \"type\": \"string\",\n \"const\": \"https://poe-platform.github.io/poe-code/schemas/task-list/task.schema.json\"\n },\n \"kind\": {\n \"type\": \"string\",\n \"const\": \"task\"\n },\n \"version\": {\n \"type\": \"integer\",\n \"const\": 1\n },\n \"name\": {\n \"type\": \"string\",\n \"minLength\": 1\n },\n \"state\": {\n \"type\": \"string\"\n },\n \"description\": {\n \"type\": \"string\"\n }\n },\n \"required\": [\"name\", \"state\"],\n \"additionalProperties\": true\n}\n", "import {\n findEvent,\n type EventDef,\n type StateMachineDef\n} from \"./state-machine.js\";\nimport { InvalidTransitionError, type TaskState } from \"./types.js\";\n\nexport type TaskEvent = \"plan\" | \"start\" | \"complete\" | \"archive\";\n\nexport const defaultStateMachine = {\n initial: \"draft\",\n states: [\"draft\", \"planned\", \"in-progress\", \"done\", \"archived\"],\n events: {\n plan: { from: [\"draft\"], to: \"planned\" },\n start: { from: [\"planned\"], to: \"in-progress\" },\n complete: { from: [\"in-progress\"], to: \"done\" },\n archive: { from: \"*\", to: \"archived\" }\n }\n} as const satisfies StateMachineDef<TaskState, TaskEvent>;\n\nfunction deriveLegacyTransitions(\n machine: typeof defaultStateMachine\n): Readonly<Record<TaskState, ReadonlySet<TaskState>>> {\n const transitions = Object.fromEntries(\n machine.states.map((state) => [state, new Set<TaskState>()])\n ) as Record<TaskState, Set<TaskState>>;\n\n for (const fromState of machine.states) {\n for (const eventName of Object.keys(machine.events) as TaskEvent[]) {\n const event = findEvent(machine, fromState, eventName);\n\n if (event !== undefined) {\n transitions[fromState].add(event.to);\n }\n }\n }\n\n const terminalState = machine.events.archive.to;\n const activeStates = machine.states.filter((state) => state !== terminalState);\n\n for (let index = 1; index < activeStates.length; index += 1) {\n transitions[activeStates[index]].add(activeStates[index - 1]);\n }\n\n return transitions;\n}\n\nconst defaultTransitions = deriveLegacyTransitions(defaultStateMachine);\n\nexport function resolveStateMachine(\n stateMachine?: StateMachineDef\n): StateMachineDef {\n return stateMachine ?? defaultStateMachine;\n}\n\nexport function assertEvent<TState extends string, TEvent extends string>(\n machine: StateMachineDef<TState, TEvent>,\n fromState: TState,\n eventName: TEvent\n): EventDef<TState> {\n const event = findEvent(machine, fromState, eventName);\n\n if (event === undefined) {\n throw new InvalidTransitionError(\n `Cannot fire event \"${eventName}\" from task state \"${fromState}\".`\n );\n }\n\n return event;\n}\n\nfunction canTransition(\n machine: StateMachineDef,\n fromState: string,\n toState: string\n): boolean {\n if (Object.is(machine, defaultStateMachine)) {\n return defaultTransitions[fromState as TaskState]?.has(toState as TaskState) ?? false;\n }\n\n for (const eventName of Object.keys(machine.events)) {\n if (findEvent(machine, fromState, eventName)?.to === toState) {\n return true;\n }\n }\n\n return false;\n}\n\nexport function assertTransition(from: TaskState, to: TaskState): void;\nexport function assertTransition<TState extends string, TEvent extends string>(\n machine: StateMachineDef<TState, TEvent>,\n from: TState,\n to: TState\n): void;\nexport function assertTransition<TState extends string, TEvent extends string>(\n machineOrFrom: StateMachineDef<TState, TEvent> | TaskState,\n fromOrTo: TState | TaskState,\n maybeTo?: TState\n): void {\n const machine =\n maybeTo === undefined\n ? defaultStateMachine\n : (machineOrFrom as StateMachineDef<TState, TEvent>);\n const fromState = maybeTo === undefined ? (machineOrFrom as TaskState) : (fromOrTo as TState);\n const toState = maybeTo === undefined ? (fromOrTo as TaskState) : maybeTo;\n\n if (!canTransition(machine, fromState, toState)) {\n throw new InvalidTransitionError(\n `Cannot transition task from \"${fromState}\" to \"${toState}\".`\n );\n }\n}\n", "import path from \"node:path\";\nimport { acquireFileLock } from \"@poe-code/file-lock\";\nimport { isMap, parseDocument, type Document, type YAMLMap } from \"yaml\";\nimport storeSchema from \"../schema/store.schema.json\" with { type: \"json\" };\nimport taskSchema from \"../schema/task.schema.json\" with { type: \"json\" };\nimport { eventsFromState, findEvent } from \"../state-machine.js\";\nimport { resolveStateMachine } from \"../state.js\";\nimport {\n AnchorNotFoundError,\n InvalidTransitionError,\n MalformedTaskError,\n OrderMismatchError,\n TaskAlreadyExistsError,\n TaskNotFoundError,\n type BackendDeps,\n type ListFilter,\n type MoveAnchor,\n type Task,\n type TaskCreate,\n type TaskFireOptions,\n type TaskList,\n type TaskListFs,\n type Tasks,\n type TaskUpdate\n} from \"../types.js\";\nimport {\n applyOrder,\n isRecord,\n sortStrings,\n statIfExists,\n validateTaskId,\n writeAtomically,\n type OrderedEntry\n} from \"./utils.js\";\n\nconst STORE_KIND = \"task-store\";\nconst STORE_SCHEMA_ID = storeSchema.$id;\nconst STORE_VERSION = 1;\nconst TASK_KIND = \"task\";\nconst TASK_SCHEMA_ID = taskSchema.$id;\nconst TASK_VERSION = 1;\nconst RESERVED_TASK_KEYS = new Set([\n \"$schema\",\n \"created\",\n \"description\",\n \"kind\",\n \"name\",\n \"state\",\n \"version\"\n]);\n\ntype StoreRecord = Record<string, unknown>;\ntype TaskRecord = Record<string, unknown>;\n\nfunction malformedStore(filePath: string, field: string): MalformedTaskError {\n return new MalformedTaskError(`Malformed task store \"${filePath}\": invalid \"${field}\".`);\n}\n\nfunction malformedTask(list: string, id: string, field: string): MalformedTaskError {\n return new MalformedTaskError(`Malformed task \"${list}/${id}\": invalid \"${field}\".`);\n}\n\nfunction validateListName(name: string): string {\n if (\n name.length === 0 ||\n name.startsWith(\".\") ||\n name.includes(\"/\") ||\n name.includes(\"\\\\\") ||\n name.includes(\"..\")\n ) {\n throw new Error(`Invalid task list name \"${name}\".`);\n }\n\n return name;\n}\n\nfunction parseQualifiedId(qualifiedId: string): {\n id: string;\n list: string;\n} {\n const separatorIndex = qualifiedId.indexOf(\"/\");\n\n if (\n separatorIndex <= 0 ||\n separatorIndex !== qualifiedId.lastIndexOf(\"/\") ||\n separatorIndex === qualifiedId.length - 1\n ) {\n throw new Error(`Invalid qualified task id \"${qualifiedId}\".`);\n }\n\n return {\n list: validateListName(qualifiedId.slice(0, separatorIndex)),\n id: validateTaskId(qualifiedId.slice(separatorIndex + 1))\n };\n}\n\nfunction descriptionFromTaskRecord(taskRecord: TaskRecord): string {\n return typeof taskRecord.description === \"string\" ? taskRecord.description : \"\";\n}\n\nfunction metadataFromTaskRecord(taskRecord: TaskRecord): Record<string, unknown> {\n const metadata: Record<string, unknown> = {};\n\n for (const [key, value] of Object.entries(taskRecord)) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n metadata[key] = value;\n }\n }\n\n return metadata;\n}\n\nfunction createTask(list: string, id: string, taskRecord: TaskRecord, sourcePath?: string): Task {\n return {\n list,\n id,\n qualifiedId: `${list}/${id}`,\n name: taskRecord.name as string,\n state: taskRecord.state as string,\n description: descriptionFromTaskRecord(taskRecord),\n metadata: metadataFromTaskRecord(taskRecord),\n ...(sourcePath !== undefined && { sourcePath: path.resolve(sourcePath) })\n };\n}\n\nfunction matchesFilter(task: Task, filter?: ListFilter): boolean {\n if (!filter?.includeArchived && task.state === \"archived\") {\n return false;\n }\n\n if (filter?.state !== undefined && task.state !== filter.state) {\n return false;\n }\n\n return true;\n}\n\nfunction createTaskRecord(\n defaults: BackendDeps[\"defaults\"],\n input: TaskCreate,\n initialState: string\n): TaskRecord {\n const taskRecord: TaskRecord = {\n name: input.name,\n state: initialState,\n description: input.description ?? \"\"\n };\n\n for (const [key, value] of Object.entries(defaults.metadata)) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n taskRecord[key] = value;\n }\n }\n\n for (const [key, value] of Object.entries(input.metadata ?? {})) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n taskRecord[key] = value;\n }\n }\n\n taskRecord.created = new Date().toISOString();\n return taskRecord;\n}\n\nfunction assertCreateDoesNotSetState(input: TaskCreate): void {\n if (Object.prototype.hasOwnProperty.call(input, \"state\")) {\n throw new Error(\n 'Tasks.create() does not accept \"state\"; new tasks always start at stateMachine.initial.'\n );\n }\n}\n\nfunction assertCreateHasId(input: TaskCreate): asserts input is TaskCreate & { id: string } {\n if (input.id === undefined) {\n throw new Error(\"id is required for yaml-file backend\");\n }\n}\n\nfunction assertUpdateDoesNotSetState(patch: TaskUpdate): void {\n if (Object.prototype.hasOwnProperty.call(patch, \"state\")) {\n throw new Error('Tasks.update() does not accept \"state\"; use fire() to change task state.');\n }\n}\n\nfunction buildUpdatedTaskRecord(existing: TaskRecord, patch: TaskUpdate): TaskRecord {\n const nextTaskRecord: TaskRecord = {\n ...existing,\n name: patch.name ?? existing.name,\n state: existing.state,\n description: patch.description ?? descriptionFromTaskRecord(existing)\n };\n\n for (const [key, value] of Object.entries(patch.metadata ?? {})) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n nextTaskRecord[key] = value;\n }\n }\n\n return nextTaskRecord;\n}\n\nfunction buildTransitionedTaskRecord(existing: TaskRecord, to: string): TaskRecord {\n return {\n ...existing,\n state: to,\n description: descriptionFromTaskRecord(existing)\n };\n}\n\nfunction buildFiredTaskRecord(\n existing: TaskRecord,\n to: string,\n metadataPatch?: Record<string, unknown>\n): TaskRecord {\n const nextTaskRecord = buildTransitionedTaskRecord(existing, to);\n\n for (const [key, value] of Object.entries(metadataPatch ?? {})) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n nextTaskRecord[key] = value;\n }\n }\n\n return nextTaskRecord;\n}\n\nfunction parseStoreDocument(filePath: string, content: string) {\n let document;\n\n try {\n document = parseDocument(content, { keepSourceTokens: true, prettyErrors: false });\n } catch {\n throw malformedStore(filePath, \"yaml\");\n }\n\n if (document.errors.length > 0) {\n throw malformedStore(filePath, \"yaml\");\n }\n\n return document;\n}\n\nfunction assertValidStoreRecord(store: unknown, filePath: string): asserts store is StoreRecord {\n if (!isRecord(store)) {\n throw malformedStore(filePath, \"store\");\n }\n\n if (store.$schema !== STORE_SCHEMA_ID) {\n throw malformedStore(filePath, \"$schema\");\n }\n\n if (store.kind !== STORE_KIND) {\n throw malformedStore(filePath, \"kind\");\n }\n\n if (typeof store.version !== \"number\" || !Number.isInteger(store.version) || store.version !== STORE_VERSION) {\n throw malformedStore(filePath, \"version\");\n }\n\n if (!isRecord(store.lists)) {\n throw malformedStore(filePath, \"lists\");\n }\n}\n\nfunction assertValidTaskRecord(\n taskRecord: unknown,\n list: string,\n id: string,\n validStates: ReadonlySet<string>\n): asserts taskRecord is TaskRecord {\n if (!isRecord(taskRecord)) {\n throw malformedTask(list, id, \"task\");\n }\n\n if (\"$schema\" in taskRecord && taskRecord.$schema !== TASK_SCHEMA_ID) {\n throw malformedTask(list, id, \"$schema\");\n }\n\n if (\"kind\" in taskRecord && taskRecord.kind !== TASK_KIND) {\n throw malformedTask(list, id, \"kind\");\n }\n\n if (\"version\" in taskRecord) {\n if (\n typeof taskRecord.version !== \"number\" ||\n !Number.isInteger(taskRecord.version) ||\n taskRecord.version !== TASK_VERSION\n ) {\n throw malformedTask(list, id, \"version\");\n }\n }\n\n if (typeof taskRecord.name !== \"string\" || taskRecord.name.length === 0) {\n throw malformedTask(list, id, \"name\");\n }\n\n if (typeof taskRecord.state !== \"string\" || !validStates.has(taskRecord.state)) {\n throw malformedTask(list, id, \"state\");\n }\n\n if (\"description\" in taskRecord && typeof taskRecord.description !== \"string\") {\n throw malformedTask(list, id, \"description\");\n }\n}\n\nfunction validateStoreEntries(\n store: StoreRecord,\n filePath: string,\n validStates: ReadonlySet<string>\n): void {\n const lists = store.lists;\n\n if (!isRecord(lists)) {\n throw malformedStore(filePath, \"lists\");\n }\n\n for (const [list, listRecord] of Object.entries(lists)) {\n try {\n validateListName(list);\n } catch {\n throw malformedStore(filePath, `lists.${list}`);\n }\n\n if (!isRecord(listRecord)) {\n throw malformedStore(filePath, `lists.${list}`);\n }\n\n for (const [id, taskRecord] of Object.entries(listRecord)) {\n try {\n validateTaskId(id);\n } catch {\n throw malformedTask(list, id, \"id\");\n }\n\n assertValidTaskRecord(taskRecord, list, id, validStates);\n }\n }\n}\n\nfunction serializeDocument(document: { toString(): string }): string {\n const serialized = document.toString();\n return serialized.endsWith(\"\\n\") ? serialized : `${serialized}\\n`;\n}\n\nasync function readStore(\n fs: TaskListFs,\n filePath: string,\n validStates: ReadonlySet<string>\n): Promise<{\n document: ReturnType<typeof parseStoreDocument>;\n store: StoreRecord;\n}> {\n const content = await fs.readFile(filePath, \"utf8\");\n const document = parseStoreDocument(filePath, content);\n const store = document.toJS();\n\n assertValidStoreRecord(store, filePath);\n validateStoreEntries(store, filePath, validStates);\n\n return {\n document,\n store\n };\n}\n\nfunction getListsRecord(store: StoreRecord): Record<string, unknown> {\n return store.lists as Record<string, unknown>;\n}\n\nfunction getListRecord(store: StoreRecord, list: string): Record<string, unknown> | undefined {\n const listRecord = getListsRecord(store)[list];\n return isRecord(listRecord) ? listRecord : undefined;\n}\n\nfunction getTaskRecord(store: StoreRecord, list: string, id: string): TaskRecord | undefined {\n const listRecord = getListRecord(store, list);\n const taskRecord = listRecord?.[id];\n\n return isRecord(taskRecord) ? taskRecord : undefined;\n}\n\nfunction getTaskOrThrow(store: StoreRecord, list: string, id: string): TaskRecord {\n const taskRecord = getTaskRecord(store, list, id);\n\n if (!taskRecord) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n return taskRecord;\n}\n\nfunction getListNode(document: Document, list: string): YAMLMap | undefined {\n const lists = document.get(\"lists\");\n if (!isMap(lists)) {\n return undefined;\n }\n\n const listNode = lists.get(list);\n if (!isMap(listNode)) {\n return undefined;\n }\n\n return listNode;\n}\n\nfunction pairKey(pair: { key: unknown }): string | undefined {\n const key = pair.key;\n if (typeof key === \"string\") {\n return key;\n }\n if (key && typeof key === \"object\" && \"value\" in key && typeof (key as { value: unknown }).value === \"string\") {\n return (key as { value: string }).value;\n }\n return undefined;\n}\n\nfunction findItemIndex(listNode: YAMLMap, id: string): number {\n return listNode.items.findIndex((pair) => pairKey(pair) === id);\n}\n\nfunction activeItemIds(listNode: YAMLMap, validStates: ReadonlySet<string>): string[] {\n const ids: string[] = [];\n for (const pair of listNode.items) {\n const id = pairKey(pair);\n if (id === undefined) continue;\n\n const value = pair.value;\n let state: unknown;\n if (value && typeof value === \"object\" && \"get\" in value && typeof (value as { get: unknown }).get === \"function\") {\n state = (value as YAMLMap).get(\"state\");\n } else if (isRecord(value)) {\n state = value.state;\n }\n\n if (typeof state === \"string\" && validStates.has(state) && state !== \"archived\") {\n ids.push(id);\n }\n }\n return ids;\n}\n\n\nasync function ensureStorePath(deps: BackendDeps): Promise<void> {\n if (!deps.create) {\n await deps.fs.stat(deps.path);\n return;\n }\n\n const existing = await statIfExists(deps.fs, deps.path);\n if (existing !== undefined) {\n return;\n }\n\n await writeAtomically(\n deps.fs,\n deps.path,\n serializeDocument(\n parseDocument(\n [\n `$schema: ${STORE_SCHEMA_ID}`,\n `kind: ${STORE_KIND}`,\n `version: ${STORE_VERSION}`,\n \"lists: {}\",\n \"\"\n ].join(\"\\n\")\n )\n )\n );\n}\n\nasync function withStoreLock<T>(deps: BackendDeps, action: () => Promise<T>): Promise<T> {\n const release = await acquireFileLock(deps.path, {\n fs: deps.fs,\n staleMs: deps.lockStaleMs,\n retries: deps.lockRetries\n });\n\n try {\n return await action();\n } finally {\n await release();\n }\n}\n\nfunction createTasksView(deps: BackendDeps, list: string): Tasks {\n const stateMachine = resolveStateMachine(deps.stateMachine);\n const validStates = new Set(stateMachine.states);\n\n async function readTasks(filter?: ListFilter): Promise<Task[]> {\n const { store } = await readStore(deps.fs, deps.path, validStates);\n const listRecord = getListRecord(store, list);\n\n if (!listRecord) {\n return [];\n }\n\n const entries: OrderedEntry[] = Object.entries(listRecord)\n .map(([id, taskRecord]) => ({\n task: createTask(list, id, taskRecord as TaskRecord, deps.path),\n raw: taskRecord as TaskRecord\n }))\n .filter(({ task }) => matchesFilter(task, filter));\n\n return applyOrder(entries, filter?.order);\n }\n\n function assertFireableTaskEvent(task: Task, eventName: string) {\n const event = findEvent(stateMachine, task.state, eventName);\n\n if (event === undefined) {\n throw new InvalidTransitionError({\n task,\n event: eventName,\n to: stateMachine.events[eventName]?.to,\n reason: `Cannot fire event \"${eventName}\" from task state \"${task.state}\".`\n });\n }\n\n return event;\n }\n\n return {\n name: list,\n stateMachine,\n async all(filter?: ListFilter): Promise<Task[]> {\n return readTasks(filter);\n },\n async get(id: string): Promise<Task> {\n validateTaskId(id);\n const { store } = await readStore(deps.fs, deps.path, validStates);\n return createTask(list, id, getTaskOrThrow(store, list, id), deps.path);\n },\n async create(input: TaskCreate): Promise<Task> {\n assertCreateDoesNotSetState(input);\n assertCreateHasId(input);\n validateTaskId(input.id);\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n if (getTaskRecord(store, list, input.id)) {\n throw new TaskAlreadyExistsError(`Task \"${list}/${input.id}\" already exists.`);\n }\n\n const taskRecord = createTaskRecord(deps.defaults, input, stateMachine.initial);\n document.setIn([\"lists\", list, input.id], taskRecord);\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n return createTask(list, input.id, taskRecord, deps.path);\n });\n },\n async update(id: string, patch: TaskUpdate): Promise<Task> {\n assertUpdateDoesNotSetState(patch);\n validateTaskId(id);\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n const existing = getTaskOrThrow(store, list, id);\n const nextTaskRecord = buildUpdatedTaskRecord(existing, patch);\n\n if (patch.name !== undefined) {\n document.setIn([\"lists\", list, id, \"name\"], patch.name);\n }\n\n if (patch.description !== undefined) {\n document.setIn([\"lists\", list, id, \"description\"], patch.description);\n }\n\n for (const [key, value] of Object.entries(patch.metadata ?? {})) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n document.setIn([\"lists\", list, id, key], value);\n }\n }\n\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n return createTask(list, id, nextTaskRecord, deps.path);\n });\n },\n async fire(id: string, eventName: string, opts?: TaskFireOptions): Promise<Task> {\n validateTaskId(id);\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n const existing = getTaskOrThrow(store, list, id);\n const task = createTask(list, id, existing, deps.path);\n const event = assertFireableTaskEvent(task, eventName);\n const guardResult = event.guard?.(task) ?? true;\n\n if (guardResult !== true) {\n throw new InvalidTransitionError({\n task,\n event: eventName,\n to: event.to,\n reason: guardResult\n });\n }\n\n await event.onExit?.(task);\n\n const nextTaskRecord = buildFiredTaskRecord(existing, event.to, opts?.metadataPatch);\n document.setIn([\"lists\", list, id, \"state\"], event.to);\n\n for (const [key, value] of Object.entries(opts?.metadataPatch ?? {})) {\n if (!RESERVED_TASK_KEYS.has(key)) {\n document.setIn([\"lists\", list, id, key], value);\n }\n }\n\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n const nextTask = createTask(list, id, nextTaskRecord, deps.path);\n await event.onEnter?.(nextTask);\n\n return nextTask;\n });\n },\n async canFire(id: string, eventName: string): Promise<boolean> {\n validateTaskId(id);\n const { store } = await readStore(deps.fs, deps.path, validStates);\n const task = createTask(list, id, getTaskOrThrow(store, list, id), deps.path);\n const event = findEvent(stateMachine, task.state, eventName);\n\n if (event === undefined) {\n return false;\n }\n\n return (event.guard?.(task) ?? true) === true;\n },\n async events(id: string): Promise<readonly string[]> {\n validateTaskId(id);\n const { store } = await readStore(deps.fs, deps.path, validStates);\n const task = createTask(list, id, getTaskOrThrow(store, list, id), deps.path);\n\n return eventsFromState(stateMachine, task.state);\n },\n async delete(id: string): Promise<void> {\n validateTaskId(id);\n\n await withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n getTaskOrThrow(store, list, id);\n document.deleteIn([\"lists\", list, id]);\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n });\n },\n async move(id: string, anchor: MoveAnchor): Promise<Task> {\n validateTaskId(id);\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n const taskRecord = getTaskOrThrow(store, list, id);\n const listNode = getListNode(document, list);\n if (!listNode) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n const fromIndex = findItemIndex(listNode, id);\n if (fromIndex < 0) {\n throw new TaskNotFoundError(`Task \"${list}/${id}\" not found.`);\n }\n\n const [movedPair] = listNode.items.splice(fromIndex, 1);\n\n let insertIndex: number;\n if (\"position\" in anchor) {\n insertIndex = anchor.position === \"top\" ? 0 : listNode.items.length;\n } else {\n const anchorId = \"before\" in anchor ? anchor.before : anchor.after;\n const anchorIndex = findItemIndex(listNode, anchorId);\n if (anchorIndex < 0) {\n listNode.items.splice(fromIndex, 0, movedPair);\n throw new AnchorNotFoundError(anchorId);\n }\n insertIndex = \"before\" in anchor ? anchorIndex : anchorIndex + 1;\n }\n\n listNode.items.splice(insertIndex, 0, movedPair);\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n return createTask(list, id, taskRecord, deps.path);\n });\n },\n async reorder(ids: readonly string[]): Promise<readonly Task[]> {\n for (const id of ids) {\n validateTaskId(id);\n }\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n const listNode = getListNode(document, list);\n if (!listNode) {\n throw new OrderMismatchError({ missing: [...ids], extra: [] });\n }\n\n const currentActive = activeItemIds(listNode, validStates);\n const currentSet = new Set(currentActive);\n const inputSet = new Set(ids);\n const missing = currentActive.filter((id) => !inputSet.has(id));\n const extra = ids.filter((id) => !currentSet.has(id));\n\n if (missing.length > 0 || extra.length > 0) {\n throw new OrderMismatchError({ missing, extra });\n }\n\n const archivedPairs = listNode.items.filter((pair) => {\n const id = pairKey(pair);\n return id !== undefined && !currentSet.has(id);\n });\n const orderedActive = ids.map((id) => {\n const pair = listNode.items.find((p) => pairKey(p) === id);\n if (!pair) {\n throw new OrderMismatchError({ missing: [id], extra: [] });\n }\n return pair;\n });\n\n listNode.items.splice(0, listNode.items.length, ...orderedActive, ...archivedPairs);\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n const tasks = ids.map((id) =>\n createTask(list, id, getTaskOrThrow(store, list, id), deps.path)\n );\n return tasks;\n });\n }\n };\n}\n\nexport async function yamlFileBackend(deps: BackendDeps): Promise<TaskList> {\n await ensureStorePath(deps);\n const stateMachine = resolveStateMachine(deps.stateMachine);\n const validStates = new Set(stateMachine.states);\n\n const list = (name: string): Tasks => {\n const listName = validateListName(name);\n return createTasksView({ ...deps, stateMachine }, listName);\n };\n\n const lists = async (): Promise<string[]> => {\n const { store } = await readStore(deps.fs, deps.path, validStates);\n return sortStrings(Object.keys(getListsRecord(store)));\n };\n\n const allTasks = async (filter?: ListFilter): Promise<Task[]> => {\n const { store } = await readStore(deps.fs, deps.path, validStates);\n const result: Task[] = [];\n\n const listNames = sortStrings(Object.keys(getListsRecord(store)));\n for (const listName of listNames) {\n const listRecord = getListsRecord(store)[listName];\n if (!isRecord(listRecord)) continue;\n\n const entries: OrderedEntry[] = Object.entries(listRecord)\n .map(([id, taskRecord]) => ({\n task: createTask(listName, id, taskRecord as TaskRecord, deps.path),\n raw: taskRecord as TaskRecord\n }))\n .filter(({ task }) => matchesFilter(task, filter));\n\n result.push(...applyOrder(entries, filter?.order));\n }\n\n return result;\n };\n\n const get = async (qualifiedId: string): Promise<Task> => {\n const { list: listName, id } = parseQualifiedId(qualifiedId);\n return list(listName).get(id);\n };\n\n const moveBetweenLists = async (qualifiedId: string, targetList: string): Promise<Task> => {\n const { list: sourceListName, id } = parseQualifiedId(qualifiedId);\n const targetListName = validateListName(targetList);\n\n return withStoreLock(deps, async () => {\n const { document, store } = await readStore(deps.fs, deps.path, validStates);\n const taskRecord = getTaskOrThrow(store, sourceListName, id);\n\n if (sourceListName === targetListName) {\n return createTask(targetListName, id, taskRecord, deps.path);\n }\n\n if (getTaskRecord(store, targetListName, id)) {\n throw new TaskAlreadyExistsError(`Task \"${targetListName}/${id}\" already exists.`);\n }\n\n document.deleteIn([\"lists\", sourceListName, id]);\n document.setIn([\"lists\", targetListName, id], taskRecord);\n await writeAtomically(deps.fs, deps.path, serializeDocument(document));\n\n return createTask(targetListName, id, taskRecord, deps.path);\n });\n };\n\n return {\n list,\n lists,\n allTasks,\n get,\n moveBetweenLists\n };\n}\n", "{\n \"$schema\": \"https://json-schema.org/draft/2020-12/schema\",\n \"$id\": \"https://poe-platform.github.io/poe-code/schemas/task-list/store.schema.json\",\n \"title\": \"Task Store\",\n \"description\": \"YAML multi-list task store.\",\n \"type\": \"object\",\n \"properties\": {\n \"$schema\": {\n \"type\": \"string\",\n \"const\": \"https://poe-platform.github.io/poe-code/schemas/task-list/store.schema.json\"\n },\n \"kind\": {\n \"type\": \"string\",\n \"const\": \"task-store\"\n },\n \"version\": {\n \"type\": \"integer\",\n \"const\": 1\n },\n \"lists\": {\n \"type\": \"object\",\n \"additionalProperties\": {\n \"type\": \"object\",\n \"additionalProperties\": {\n \"$ref\": \"./task.schema.json\"\n }\n }\n }\n },\n \"required\": [\"$schema\", \"kind\", \"version\", \"lists\"],\n \"additionalProperties\": false\n}\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const claudeCodeAgent: AgentDefinition = {\n id: \"claude-code\",\n name: \"claude-code\",\n label: \"Claude Code\",\n summary: \"Configure Claude Code to route through Poe.\",\n aliases: [\"claude\"],\n binaryName: \"claude\",\n apiShapes: [\"anthropic-messages\"],\n configPath: \"~/.claude/settings.json\",\n branding: {\n colors: {\n dark: \"#C15F3C\",\n light: \"#C15F3C\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const claudeDesktopAgent: AgentDefinition = {\n id: \"claude-desktop\",\n name: \"claude-desktop\",\n label: \"Claude Desktop\",\n summary: \"Anthropic's official desktop application for Claude\",\n configPath: \"~/.claude/settings.json\",\n branding: {\n colors: {\n dark: \"#D97757\",\n light: \"#D97757\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const codexAgent: AgentDefinition = {\n id: \"codex\",\n name: \"codex\",\n label: \"Codex\",\n summary: \"Configure Codex to use Poe as the model provider.\",\n binaryName: \"codex\",\n apiShapes: [\"openai-responses\"],\n configPath: \"~/.codex/config.toml\",\n branding: {\n colors: {\n dark: \"#D5D9DF\",\n light: \"#7A7F86\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const openCodeAgent: AgentDefinition = {\n id: \"opencode\",\n name: \"opencode\",\n label: \"OpenCode CLI\",\n summary: \"Configure OpenCode CLI to use the Poe API.\",\n binaryName: \"opencode\",\n apiShapes: [\"openai-chat-completions\"],\n configPath: \"~/.config/opencode/config.json\",\n branding: {\n colors: {\n dark: \"#4A4F55\",\n light: \"#2F3338\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const kimiAgent: AgentDefinition = {\n id: \"kimi\",\n name: \"kimi\",\n label: \"Kimi\",\n summary: \"Configure Kimi CLI to use Poe API\",\n aliases: [\"kimi-cli\"],\n binaryName: \"kimi\",\n apiShapes: [\"openai-chat-completions\"],\n configPath: \"~/.kimi/config.toml\",\n branding: {\n colors: {\n dark: \"#7B68EE\",\n light: \"#6A5ACD\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const gooseAgent: AgentDefinition = {\n id: \"goose\",\n name: \"goose\",\n label: \"Goose\",\n summary: \"Block's open-source AI agent with ACP support.\",\n binaryName: \"goose\",\n apiShapes: [\"openai-chat-completions\"],\n configPath: \"~/.config/goose/config.yaml\",\n branding: {\n colors: {\n dark: \"#FF6B35\",\n light: \"#E85D26\"\n }\n }\n};\n", "import type { AgentDefinition } from \"../types.js\";\n\nexport const poeAgentAgent: AgentDefinition = {\n id: \"poe-agent\",\n name: \"poe-agent\",\n label: \"Poe Agent\",\n summary: \"Run one-shot prompts with the built-in Poe agent runtime.\",\n apiShapes: [\"openai-responses\", \"openai-chat-completions\"],\n configPath: \"~/.poe-code/config.json\",\n branding: {\n colors: {\n dark: \"#A465F7\",\n light: \"#7A3FD3\"\n }\n }\n};\n", "import type { AgentDefinition } from \"./types.js\";\nimport {\n claudeCodeAgent,\n claudeDesktopAgent,\n codexAgent,\n openCodeAgent,\n kimiAgent,\n gooseAgent,\n poeAgentAgent\n} from \"./agents/index.js\";\n\nexport const allAgents: AgentDefinition[] = [\n claudeCodeAgent,\n claudeDesktopAgent,\n codexAgent,\n openCodeAgent,\n kimiAgent,\n gooseAgent,\n poeAgentAgent\n];\n\nconst lookup = new Map<string, string>();\n\nfor (const agent of allAgents) {\n const values = [agent.id, agent.name, ...(agent.aliases ?? [])];\n for (const value of values) {\n const normalized = value.toLowerCase();\n if (!lookup.has(normalized)) {\n lookup.set(normalized, agent.id);\n }\n }\n}\n\nexport function resolveAgentId(input: string): string | undefined {\n if (!input) {\n return undefined;\n }\n return lookup.get(input.toLowerCase());\n}\n", "import { allAgents, parseAgentSpecifier, resolveAgentId } from \"@poe-code/agent-defs\";\n\ntype Select = typeof import(\"@poe-code/design-system\").select;\ntype IsCancel = typeof import(\"@poe-code/design-system\").isCancel;\n\nexport interface ResolveLoopAgentInput {\n providedAgent?: string;\n configuredDefaultAgent?: string | null;\n frontmatterAgent?: string | string[];\n assumeYes: boolean;\n fallbackAgent: string;\n message: string;\n select: Select;\n isCancel: IsCancel;\n}\n\nconst loopAgents = allAgents.filter(\n (agent) => agent.binaryName !== undefined || agent.id === \"poe-agent\"\n);\nconst supportedAgents = loopAgents.map((agent) => agent.id).join(\", \");\n\nfunction resolveSelectedAgent(agent: string): { agent: string } {\n const specifier = parseAgentSpecifier(agent);\n const resolvedAgentId = resolveAgentId(specifier.agent);\n\n if (!resolvedAgentId || !loopAgents.some((agent) => agent.id === resolvedAgentId)) {\n throw new Error(`Unsupported agent \"${agent}\". Supported agents: ${supportedAgents}`);\n }\n\n return {\n agent: specifier.model ? `${resolvedAgentId}:${specifier.model}` : resolvedAgentId\n };\n}\n\nexport async function resolveLoopAgent(\n input: ResolveLoopAgentInput\n): Promise<{ agent: string } | { cancelled: true }> {\n if (input.providedAgent !== undefined) {\n return resolveSelectedAgent(input.providedAgent);\n }\n\n if (Array.isArray(input.frontmatterAgent)) {\n throw new Error(\"array handled by caller\");\n }\n\n if (typeof input.frontmatterAgent === \"string\") {\n return resolveSelectedAgent(input.frontmatterAgent);\n }\n\n if (input.configuredDefaultAgent !== undefined && input.configuredDefaultAgent !== null) {\n return resolveSelectedAgent(input.configuredDefaultAgent);\n }\n\n if (input.assumeYes) {\n return resolveSelectedAgent(input.fallbackAgent);\n }\n\n const selectedAgent = await input.select({\n message: input.message,\n options: loopAgents.map((agent) => ({\n value: agent.id,\n label: agent.label,\n hint: agent.summary\n }))\n });\n\n if (input.isCancel(selectedAgent)) {\n return { cancelled: true };\n }\n\n return resolveSelectedAgent(selectedAgent);\n}\n", "import path from \"node:path\";\n\nexport interface ResolveRunLogDirOptions {\n planPath: string;\n runner: string;\n homeDir: string;\n}\n\nexport function resolveRunLogDir(options: ResolveRunLogDirOptions): string {\n const slug = slugifyPlanPath(options.planPath);\n return path.join(options.homeDir, \".poe-code\", \"logs\", options.runner, slug);\n}\n\nexport function slugifyPlanPath(planPath: string): string {\n const base = path.basename(planPath);\n const dot = base.lastIndexOf(\".\");\n const stem = dot > 0 ? base.slice(0, dot) : base;\n return slugifyLabel(stem);\n}\n\nexport function makeRunLogFileName(role: string, date: Date = new Date()): string {\n const day = `${date.getUTCFullYear()}${pad(date.getUTCMonth() + 1, 2)}${pad(date.getUTCDate(), 2)}`;\n const time = `${pad(date.getUTCHours(), 2)}${pad(date.getUTCMinutes(), 2)}${pad(date.getUTCSeconds(), 2)}`;\n const ms = pad(date.getUTCMilliseconds(), 3);\n const safeRole = slugifyLabel(role) || \"role\";\n return `${day}-${time}-${ms}-${safeRole}.jsonl`;\n}\n\nfunction slugifyLabel(value: string): string {\n let out = \"\";\n for (const char of value) {\n const code = char.charCodeAt(0);\n const lower = code >= 97 && code <= 122;\n const upper = code >= 65 && code <= 90;\n const digit = code >= 48 && code <= 57;\n\n if (lower || digit) {\n out += char;\n } else if (upper) {\n out += String.fromCharCode(code + 32);\n } else if (char === \"-\" || char === \"_\") {\n out += char;\n } else {\n out += \"-\";\n }\n }\n\n return collapseDashes(out).replace(/^-+|-+$/g, \"\");\n}\n\nfunction collapseDashes(value: string): string {\n let out = \"\";\n let prevDash = false;\n for (const char of value) {\n if (char === \"-\") {\n if (!prevDash) {\n out += \"-\";\n }\n prevDash = true;\n } else {\n out += char;\n prevDash = false;\n }\n }\n return out;\n}\n\nfunction pad(value: number, width: number): string {\n return String(value).padStart(width, \"0\");\n}\n", "import nodeFs from \"node:fs\";\nimport type { FSWatcher } from \"node:fs\";\nimport type { LogChunk } from \"./execution-env.js\";\n\nconst JOB_DIR = \"/tmp/poe-jobs\";\nconst POLL_INTERVAL_MS = 250;\n\nexport interface LogStreamEnv {\n fs?: LogStreamFs;\n}\n\nexport interface LogStreamFs {\n promises: {\n readFile(path: string): Promise<Buffer | string>;\n stat?(path: string): Promise<{ mtimeMs: number }>;\n };\n watch?: (path: string, listener: () => void) => FSWatcher;\n}\n\nexport function wrapForLogTee(argv: string[], jobId: string): string[] {\n if (argv.length === 0) {\n throw new Error(\"wrapForLogTee requires argv to contain at least one argument\");\n }\n\n const command = argv.map(shellQuote).join(\" \");\n const logFile = shellQuote(jobLogPath(jobId));\n const exitFile = shellQuote(jobExitPath(jobId));\n const exitTmpFile = shellQuote(`${jobExitPath(jobId)}.tmp`);\n const script = [\n `mkdir -p ${shellQuote(JOB_DIR)}`,\n `({ (${command}); echo $? > ${exitTmpFile}; } 2>&1 | tee ${logFile}; mv ${exitTmpFile} ${exitFile})`\n ].join(\" && \");\n\n return [\"sh\", \"-c\", script];\n}\n\nexport async function* streamLogFile(\n env: LogStreamEnv,\n jobId: string,\n opts: { sinceByte?: number; since?: Date }\n): AsyncIterable<LogChunk> {\n const fs = env.fs ?? nodeFs;\n const file = jobLogPath(jobId);\n let byteOffset = opts.sinceByte ?? 0;\n\n while (true) {\n if (opts.since !== undefined && !(await wasModifiedSince(fs, file, opts.since))) {\n await waitForLogChange(fs, file);\n continue;\n }\n\n const result = await readLogChunk(fs, file, byteOffset);\n if (result !== null) {\n byteOffset = result.nextByteOffset;\n yield result.chunk;\n continue;\n }\n\n await waitForLogChange(fs, file);\n }\n}\n\nasync function wasModifiedSince(fs: LogStreamFs, file: string, since: Date): Promise<boolean> {\n if (fs.promises.stat === undefined) {\n return true;\n }\n\n try {\n const stat = await fs.promises.stat(file);\n return stat.mtimeMs >= since.getTime();\n } catch (error) {\n if (isNodeError(error) && error.code === \"ENOENT\") {\n return false;\n }\n throw error;\n }\n}\n\nexport async function waitForExit(\n env: LogStreamEnv,\n jobId: string,\n opts: { signal?: AbortSignal } = {}\n): Promise<{ exitCode: number }> {\n const fs = env.fs ?? nodeFs;\n const file = jobExitPath(jobId);\n\n while (true) {\n throwIfAborted(opts.signal);\n const contents = await readTextFileIfExists(fs, file);\n if (contents !== null) {\n const text = contents.trim();\n const exitCode = Number(text);\n if (text.length === 0 || !Number.isInteger(exitCode)) {\n throw new Error(`Invalid exit code in ${file}: ${contents}`);\n }\n return { exitCode };\n }\n\n await sleep(POLL_INTERVAL_MS, opts.signal);\n }\n}\n\nfunction jobLogPath(jobId: string): string {\n return `${JOB_DIR}/${jobId}.log`;\n}\n\nfunction jobExitPath(jobId: string): string {\n return `${JOB_DIR}/${jobId}.exit`;\n}\n\nasync function readLogChunk(\n fs: LogStreamFs,\n file: string,\n byteOffset: number\n): Promise<{ chunk: LogChunk; nextByteOffset: number } | null> {\n const contents = await readFileIfExists(fs, file);\n if (contents === null || byteOffset >= contents.byteLength) {\n return null;\n }\n\n return {\n chunk: {\n byteOffset,\n data: contents.subarray(byteOffset).toString(\"utf8\")\n },\n nextByteOffset: contents.byteLength\n };\n}\n\nasync function readTextFileIfExists(fs: LogStreamFs, file: string): Promise<string | null> {\n const contents = await readFileIfExists(fs, file);\n return contents?.toString(\"utf8\") ?? null;\n}\n\nasync function readFileIfExists(fs: LogStreamFs, file: string): Promise<Buffer | null> {\n try {\n const contents = await fs.promises.readFile(file);\n return Buffer.isBuffer(contents) ? contents : Buffer.from(contents);\n } catch (error) {\n if (isNodeError(error) && error.code === \"ENOENT\") {\n return null;\n }\n throw error;\n }\n}\n\nasync function waitForLogChange(fs: LogStreamFs, file: string): Promise<void> {\n const watch = fs.watch;\n if (typeof watch !== \"function\") {\n await sleep(POLL_INTERVAL_MS);\n return;\n }\n\n await new Promise<void>((resolve) => {\n let watcher: FSWatcher | null = null;\n const timer = setTimeout(done, POLL_INTERVAL_MS);\n\n function done(): void {\n clearTimeout(timer);\n watcher?.close();\n resolve();\n }\n\n try {\n watcher = watch(file, done);\n } catch {\n done();\n }\n });\n}\n\nfunction sleep(ms: number, signal?: AbortSignal): Promise<void> {\n return new Promise((resolve, reject) => {\n let timer: NodeJS.Timeout | null = null;\n const abort = () => {\n if (timer !== null) {\n clearTimeout(timer);\n }\n reject(new Error(\"waitForExit aborted.\"));\n };\n\n if (signal?.aborted) {\n abort();\n return;\n }\n\n timer = setTimeout(() => {\n signal?.removeEventListener(\"abort\", abort);\n resolve();\n }, ms);\n signal?.addEventListener(\"abort\", abort, { once: true });\n });\n}\n\nfunction throwIfAborted(signal: AbortSignal | undefined): void {\n if (signal?.aborted) {\n throw new Error(\"waitForExit aborted.\");\n }\n}\n\nfunction shellQuote(value: string): string {\n return `'${value.replaceAll(\"'\", \"'\\\\''\")}'`;\n}\n\nfunction isNodeError(error: unknown): error is NodeJS.ErrnoException {\n return error instanceof Error && \"code\" in error;\n}\n", "import { randomBytes } from \"node:crypto\";\nimport { allAgents, resolveAgentId } from \"@poe-code/agent-defs\";\nimport type { StateManager } from \"@poe-code/poe-code-config\";\nimport type { RunHandle } from \"@poe-code/process-runner\";\nimport type { Readable } from \"node:stream\";\nimport { createBinaryExistsDetectors } from \"./binary-exists.js\";\nimport type { DownloadResult, ExecutionEnvFactory, OpenedEnv, OpenSpec } from \"./execution-env.js\";\nimport { waitForExit, wrapForLogTee, type LogStreamEnv } from \"./log-stream.js\";\n\nconst ULID_ALPHABET = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\";\n\nexport async function runPoeCommand(opts: {\n factory: ExecutionEnvFactory;\n openSpec: OpenSpec;\n detach: boolean;\n state: StateManager;\n signal?: AbortSignal;\n}): Promise<\n | {\n kind: \"sync\";\n exitCode: number;\n download: DownloadResult;\n stdout?: string;\n stderr?: string;\n }\n | { kind: \"detached\"; jobId: string; envId: string }\n> {\n const jobId = createUlid();\n const execution = opts.openSpec.execution;\n const wrapCommand = execution?.wrapForLogTee !== false;\n const pendingJob = opts.state.jobs.put({\n id: jobId,\n env_id: \"\",\n env_kind: opts.factory.type,\n tool: opts.openSpec.jobLabel.tool,\n argv: opts.openSpec.jobLabel.argv,\n cwd: opts.openSpec.cwd,\n started_at: \"\",\n status: \"pending\"\n });\n\n const opened = opts.factory.open(opts.openSpec);\n const env = isPromiseLike(opened) ? await opened : opened;\n let shouldClose = true;\n\n try {\n const upload = env.uploadWorkspace();\n await Promise.all([pendingJob, upload]);\n await configureE2bSpawnAgentIfAvailable({\n env,\n openSpec: opts.openSpec,\n factoryType: opts.factory.type\n });\n const argv = wrapCommand\n ? wrapForLogTee(opts.openSpec.jobLabel.argv, jobId)\n : opts.openSpec.jobLabel.argv;\n const handle = execution?.tty\n ? env.shell()\n : env.exec({\n command: argv[0],\n args: argv.slice(1),\n cwd: opts.openSpec.cwd,\n env: resolveExecutionEnv(opts.openSpec),\n stdin: execution?.stdin ?? \"inherit\",\n stdout: execution?.stdout ?? \"pipe\",\n stderr: execution?.stderr ?? \"pipe\",\n signal: opts.signal\n });\n\n if (execution?.input !== undefined) {\n writeExecutionInput(handle, execution.input);\n }\n\n const runningJob = opts.state.jobs.update(jobId, {\n status: \"running\",\n env_id: env.id,\n started_at: new Date().toISOString()\n });\n\n if (opts.detach) {\n await runningJob;\n setDetachedJobContext(env, {\n id: jobId,\n tool: opts.openSpec.jobLabel.tool,\n argv: opts.openSpec.jobLabel.argv\n });\n await env.detach();\n shouldClose = false;\n return { kind: \"detached\", jobId, envId: env.id };\n }\n\n const result = await runSync({\n env,\n handle,\n jobId,\n openSpec: opts.openSpec,\n signal: opts.signal,\n wrapCommand\n });\n await runningJob;\n shouldClose = false;\n\n await opts.state.jobs.update(jobId, {\n status: \"exited\",\n exit_code: result.exitCode,\n exited_at: new Date().toISOString()\n });\n\n return {\n kind: \"sync\",\n exitCode: result.exitCode,\n download: result.download,\n ...(result.stdout !== undefined ? { stdout: result.stdout } : {}),\n ...(result.stderr !== undefined ? { stderr: result.stderr } : {})\n };\n } finally {\n if (shouldClose) {\n await env.close();\n }\n }\n}\n\nexport interface PoeCommandSession {\n run(\n openSpec: OpenSpec,\n signal?: AbortSignal\n ): Promise<{\n kind: \"sync\";\n exitCode: number;\n download: DownloadResult;\n stdout?: string;\n stderr?: string;\n }>;\n close(): Promise<void>;\n}\n\nexport function createPoeCommandSession(opts: {\n factory: ExecutionEnvFactory;\n state: StateManager;\n}): PoeCommandSession {\n let env: OpenedEnv | null = null;\n let closed = false;\n\n async function getEnv(openSpec: OpenSpec): Promise<OpenedEnv> {\n if (closed) {\n throw new Error(\"Cannot run command after Poe command session is closed.\");\n }\n\n if (env !== null) {\n return env;\n }\n\n const opened = opts.factory.open(openSpec);\n env = isPromiseLike(opened) ? await opened : opened;\n await env.uploadWorkspace();\n return env;\n }\n\n return {\n async run(openSpec, signal) {\n const jobId = createUlid();\n const pendingJob = opts.state.jobs.put({\n id: jobId,\n env_id: \"\",\n env_kind: opts.factory.type,\n tool: openSpec.jobLabel.tool,\n argv: openSpec.jobLabel.argv,\n cwd: openSpec.cwd,\n started_at: \"\",\n status: \"pending\"\n });\n const currentEnv = await getEnv(openSpec);\n await pendingJob;\n await configureE2bSpawnAgentIfAvailable({\n env: currentEnv,\n openSpec,\n factoryType: opts.factory.type\n });\n const wrapCommand = openSpec.execution?.wrapForLogTee !== false;\n const argv = wrapCommand\n ? wrapForLogTee(openSpec.jobLabel.argv, jobId)\n : openSpec.jobLabel.argv;\n const handle = openSpec.execution?.tty\n ? currentEnv.shell()\n : currentEnv.exec({\n command: argv[0],\n args: argv.slice(1),\n cwd: openSpec.cwd,\n env: resolveExecutionEnv(openSpec),\n stdin: openSpec.execution?.stdin ?? \"inherit\",\n stdout: openSpec.execution?.stdout ?? \"pipe\",\n stderr: openSpec.execution?.stderr ?? \"pipe\",\n signal\n });\n\n if (openSpec.execution?.input !== undefined) {\n writeExecutionInput(handle, openSpec.execution.input);\n }\n\n await opts.state.jobs.update(jobId, {\n status: \"running\",\n env_id: currentEnv.id,\n started_at: new Date().toISOString()\n });\n\n const result = await runSync({\n env: currentEnv,\n handle,\n jobId,\n openSpec,\n signal,\n wrapCommand,\n closeAfterDownload: false\n });\n\n await opts.state.jobs.update(jobId, {\n status: \"exited\",\n exit_code: result.exitCode,\n exited_at: new Date().toISOString()\n });\n\n return {\n kind: \"sync\",\n exitCode: result.exitCode,\n download: result.download,\n ...(result.stdout !== undefined ? { stdout: result.stdout } : {}),\n ...(result.stderr !== undefined ? { stderr: result.stderr } : {})\n };\n },\n async close() {\n if (closed) {\n return;\n }\n closed = true;\n await env?.close();\n }\n };\n}\n\nasync function configureE2bSpawnAgentIfAvailable(opts: {\n env: OpenedEnv;\n openSpec: OpenSpec;\n factoryType: string;\n}): Promise<void> {\n if (opts.factoryType !== \"e2b\") {\n return;\n }\n\n const agentId = resolveAgentId(opts.openSpec.jobLabel.tool);\n const agent = allAgents.find((candidate) => candidate.id === agentId);\n const binaryName = agent?.binaryName;\n if (!agentId || !binaryName) {\n return;\n }\n\n const commandEnv = resolveExecutionEnv(opts.openSpec);\n const exists = await binaryExists(opts.env, {\n binaryName,\n cwd: opts.openSpec.cwd,\n env: commandEnv\n });\n if (!exists) {\n return;\n }\n\n const result = await runProbeCommand(opts.env, {\n command: \"poe-code\",\n args: [\"configure\", \"--yes\", \"--provider\", \"poe\", agentId],\n cwd: opts.openSpec.cwd,\n env: commandEnv\n });\n if (result.exitCode !== 0) {\n throw new Error(\n `Failed to configure ${agentId} for Poe inside E2B sandbox.\\n${formatProbeResult(result)}`\n );\n }\n}\n\nasync function binaryExists(\n env: OpenedEnv,\n opts: { binaryName: string; cwd: string; env: Record<string, string> | undefined }\n): Promise<boolean> {\n for (const detector of createBinaryExistsDetectors(opts.binaryName)) {\n const result = await runProbeCommand(env, {\n ...detector,\n cwd: opts.cwd,\n env: opts.env\n });\n if (detector.validate(result)) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction resolveExecutionEnv(openSpec: OpenSpec): Record<string, string> | undefined {\n const execution = openSpec.execution;\n return execution?.env ?? openSpec.env;\n}\n\nasync function runProbeCommand(\n env: OpenedEnv,\n spec: {\n command: string;\n args?: string[];\n cwd: string;\n env: Record<string, string> | undefined;\n }\n): Promise<{ exitCode: number; stdout: string; stderr: string }> {\n const handle = env.exec({\n command: spec.command,\n args: spec.args,\n cwd: spec.cwd,\n env: spec.env,\n stdin: \"ignore\",\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n const stdout = readStream(handle.stdout);\n const stderr = readStream(handle.stderr);\n const result = await handle.result;\n return {\n exitCode: result.exitCode,\n stdout: await stdout,\n stderr: await stderr\n };\n}\n\nfunction readStream(stream: Readable | null): Promise<string> {\n if (!stream) {\n return Promise.resolve(\"\");\n }\n return new Promise((resolve, reject) => {\n let output = \"\";\n stream.setEncoding(\"utf8\");\n stream.on(\"data\", (chunk) => {\n output += chunk.toString();\n });\n stream.on(\"error\", reject);\n stream.on(\"end\", () => resolve(output));\n });\n}\n\nfunction formatProbeResult(result: { exitCode: number; stdout: string; stderr: string }): string {\n return [\n `Exit code: ${result.exitCode}`,\n result.stdout.trim() ? `stdout:\\n${result.stdout.trim()}` : \"\",\n result.stderr.trim() ? `stderr:\\n${result.stderr.trim()}` : \"\"\n ]\n .filter(Boolean)\n .join(\"\\n\");\n}\n\nasync function runSync(opts: {\n env: OpenedEnv;\n handle: RunHandle;\n jobId: string;\n openSpec: OpenSpec;\n signal?: AbortSignal;\n wrapCommand: boolean;\n closeAfterDownload?: boolean;\n}): Promise<{ exitCode: number; download: DownloadResult; stdout?: string; stderr?: string }> {\n const execution = opts.openSpec.execution;\n const capture = execution?.captureOutput === true;\n const abort = createAbortSync(opts.signal, opts.handle, execution?.activityTimeoutMs);\n const streamState = capture\n ? captureRunStreams(opts.handle, execution, abort.resetActivityTimer)\n : pipeRunStreams(opts.handle);\n abort.resetActivityTimer();\n\n try {\n const { exitCode } = opts.wrapCommand\n ? await abort.waitForExit(opts.env, opts.jobId)\n : await abort.waitForHandle();\n const download = await opts.env.downloadWorkspace({\n conflictPolicy: opts.openSpec.runner?.download_conflict ?? \"refuse\"\n });\n if (opts.closeAfterDownload !== false) {\n await opts.env.close();\n }\n return {\n exitCode,\n download,\n ...(capture ? { stdout: streamState.stdout(), stderr: streamState.stderr() } : {})\n };\n } finally {\n abort.dispose();\n streamState.dispose();\n }\n}\n\nfunction pipeRunStreams(handle: RunHandle): {\n stdout(): string;\n stderr(): string;\n dispose(): void;\n} {\n handle.stdout?.pipe(process.stdout, { end: false });\n handle.stderr?.pipe(process.stderr, { end: false });\n return {\n stdout: () => \"\",\n stderr: () => \"\",\n dispose() {\n handle.stdout?.unpipe(process.stdout);\n handle.stderr?.unpipe(process.stderr);\n }\n };\n}\n\nfunction captureRunStreams(\n handle: RunHandle,\n execution: NonNullable<OpenSpec[\"execution\"]> | undefined,\n onActivity: () => void\n): {\n stdout(): string;\n stderr(): string;\n dispose(): void;\n} {\n let stdout = \"\";\n let stderr = \"\";\n const listeners: Array<() => void> = [];\n\n const bind = (stream: Readable | null, onChunk: (chunk: string) => void): void => {\n if (!stream) return;\n stream.setEncoding(\"utf8\");\n const listener = (chunk: string | Buffer) => {\n onActivity();\n onChunk(chunk.toString());\n };\n stream.on(\"data\", listener);\n listeners.push(() => {\n stream.off(\"data\", listener);\n });\n };\n\n bind(handle.stdout, (chunk) => {\n stdout += chunk;\n execution?.onStdout?.(chunk);\n });\n bind(handle.stderr, (chunk) => {\n stderr += chunk;\n execution?.onStderr?.(chunk);\n });\n\n return {\n stdout: () => stdout,\n stderr: () => stderr,\n dispose() {\n for (const remove of listeners) {\n remove();\n }\n }\n };\n}\n\nfunction createAbortSync(\n signal: AbortSignal | undefined,\n handle: RunHandle,\n activityTimeoutMs: number | undefined\n): {\n waitForExit(env: OpenedEnv, jobId: string): Promise<{ exitCode: number }>;\n waitForHandle(): Promise<{ exitCode: number }>;\n resetActivityTimer(): void;\n dispose(): void;\n} {\n let activityTimer: ReturnType<typeof setTimeout> | undefined;\n let timedOut = false;\n const resetActivityTimer = activityTimeoutMs\n ? () => {\n if (activityTimer) clearTimeout(activityTimer);\n activityTimer = setTimeout(() => {\n timedOut = true;\n handle.kill(\"SIGTERM\");\n notifyAbort?.();\n }, activityTimeoutMs);\n }\n : () => {};\n let notifyAbort: (() => void) | undefined;\n\n if (signal === undefined) {\n return {\n waitForExit: (env, jobId) => waitForExit(toLogStreamEnv(env), jobId),\n waitForHandle: async () => {\n const result = await handle.result;\n if (timedOut) {\n throw createActivityTimeoutError(activityTimeoutMs!);\n }\n return result;\n },\n resetActivityTimer,\n dispose() {\n if (activityTimer) clearTimeout(activityTimer);\n }\n };\n }\n\n const exitWaitController = new AbortController();\n let aborted = signal.aborted;\n const abortedPromise = new Promise<void>((resolve) => {\n notifyAbort = resolve;\n });\n const kill = () => {\n aborted = true;\n handle.kill(\"SIGTERM\");\n notifyAbort?.();\n };\n\n if (signal.aborted) {\n kill();\n } else {\n signal.addEventListener(\"abort\", kill, { once: true });\n }\n\n return {\n async waitForExit(env, jobId) {\n if (aborted) {\n return handle.result;\n }\n\n const exit = waitForExit(toLogStreamEnv(env), jobId, {\n signal: exitWaitController.signal\n }).then(\n (value) => ({ kind: \"exit\" as const, value }),\n (error: unknown) => ({ kind: \"error\" as const, error })\n );\n const result = await Promise.race([\n exit,\n abortedPromise.then(() => ({ kind: \"abort\" as const }))\n ]);\n\n if (result.kind === \"exit\") {\n return result.value;\n }\n\n if (result.kind === \"error\") {\n throw result.error;\n }\n\n exitWaitController.abort();\n return handle.result;\n },\n async waitForHandle() {\n const result = await Promise.race([\n handle.result.then((value) => ({ kind: \"exit\" as const, value })),\n abortedPromise.then(() => ({ kind: \"abort\" as const }))\n ]);\n\n if (result.kind === \"exit\") {\n if (aborted) {\n throw createAbortError();\n }\n if (timedOut) {\n throw createActivityTimeoutError(activityTimeoutMs!);\n }\n return result.value;\n }\n\n if (timedOut) {\n throw createActivityTimeoutError(activityTimeoutMs!);\n }\n throw createAbortError();\n },\n resetActivityTimer,\n dispose() {\n if (activityTimer) clearTimeout(activityTimer);\n exitWaitController.abort();\n signal.removeEventListener(\"abort\", kill);\n }\n };\n}\n\nfunction toLogStreamEnv(env: OpenedEnv): LogStreamEnv {\n const candidate = env as OpenedEnv & LogStreamEnv;\n return candidate.fs === undefined ? {} : { fs: candidate.fs };\n}\n\nfunction setDetachedJobContext(\n env: OpenedEnv,\n context: { id: string; tool: string; argv: string[] }\n): void {\n const candidate = env as OpenedEnv & {\n setDetachedJobContext?: (value: { id: string; tool: string; argv: string[] }) => void;\n };\n candidate.setDetachedJobContext?.(context);\n}\n\nfunction writeExecutionInput(handle: RunHandle, input: string | Buffer): void {\n const stdin = handle.stdin;\n if (stdin === null) {\n return;\n }\n\n stdin.on(\"error\", (error: NodeJS.ErrnoException) => {\n if (error.code !== \"EPIPE\") {\n throw error;\n }\n });\n stdin.setDefaultEncoding(\"utf8\");\n stdin.end(input);\n}\n\nfunction isPromiseLike<T>(value: T | Promise<T>): value is Promise<T> {\n return typeof (value as Promise<T>).then === \"function\";\n}\n\nfunction createAbortError(): Error {\n const error = new Error(\"Agent spawn aborted\");\n error.name = \"AbortError\";\n return error;\n}\n\nfunction createActivityTimeoutError(timeoutMs: number): Error {\n const error = new Error(`Agent spawn timed out after ${timeoutMs / 1000}s of inactivity`);\n error.name = \"ActivityTimeoutError\";\n return error;\n}\n\nfunction createUlid(): string {\n const time = BigInt(Date.now());\n const random = randomBytes(10);\n let randomValue = 0n;\n\n for (const byte of random) {\n randomValue = (randomValue << 8n) | BigInt(byte);\n }\n\n return encodeBase32(time, 10) + encodeBase32(randomValue, 16);\n}\n\nfunction encodeBase32(value: bigint, length: number): string {\n const chars = Array.from({ length }, () => \"0\");\n let remaining = value;\n\n for (let index = length - 1; index >= 0; index -= 1) {\n chars[index] = ULID_ALPHABET[Number(remaining & 31n)];\n remaining >>= 5n;\n }\n\n return chars.join(\"\");\n}\n", "export interface BinaryExistsDetectorResult {\n exitCode: number;\n stdout: string;\n}\n\nexport interface BinaryExistsDetector {\n command: string;\n args: string[];\n validate(result: BinaryExistsDetectorResult): boolean;\n}\n\nexport function createBinaryExistsDetectors(binaryName: string): BinaryExistsDetector[] {\n const commonPaths = [\n `/usr/local/bin/${binaryName}`,\n `/usr/bin/${binaryName}`,\n `$HOME/.local/bin/${binaryName}`,\n `$HOME/.claude/local/bin/${binaryName}`\n ];\n\n return [\n {\n command: \"which\",\n args: [binaryName],\n validate: (result) => result.exitCode === 0\n },\n {\n command: \"where\",\n args: [binaryName],\n validate: (result) => result.exitCode === 0 && result.stdout.trim().length > 0\n },\n {\n command: \"sh\",\n args: [\"-c\", commonPaths.map((p) => `test -f \"${p}\"`).join(\" || \")],\n validate: (result) => result.exitCode === 0\n }\n ];\n}\n", "import { existsSync, readFileSync } from \"node:fs\";\nimport os from \"node:os\";\nimport {\n createStateManager,\n deepMergeDocuments,\n parseRuntime,\n resolveConfigPath,\n resolveProjectConfigPath,\n resolveRuntime,\n resolveScope,\n runtimeConfigScope,\n type RunnerScope,\n type ConfigDocument,\n type JobEntry,\n type JobListFilter,\n type ResolvedConfig,\n type StateManager\n} from \"@poe-code/poe-code-config\";\nimport { selectExecutionEnv, type OpenSpec } from \"./execution-env.js\";\n\nexport type RuntimeOverrideOptions = {\n runtime?: \"host\" | \"docker\" | \"e2b\";\n runtimeImage?: string;\n runtimeTemplate?: string;\n detach?: boolean;\n mountPoeCode?: boolean;\n runnerSync?: RunnerScope[\"sync\"];\n};\n\nexport function resolvePoeCommandExecution(input: {\n cwd: string;\n runtimeConfigCwd?: string;\n env: Record<string, string>;\n argv: string[];\n tool: string;\n runtime?: RuntimeOverrideOptions;\n context?: {\n homeDir?: string;\n state?: StateManager;\n };\n openSpec?: Partial<Pick<OpenSpec, \"execution\" | \"shellSpec\">>;\n}): {\n factory: ReturnType<typeof selectExecutionEnv>;\n openSpec: OpenSpec;\n detach: boolean;\n state: StateManager;\n} {\n const homeDir = input.context?.homeDir ?? os.homedir();\n const runtimeConfigCwd = input.runtimeConfigCwd ?? input.cwd;\n const loaded = loadRuntimeConfig(runtimeConfigCwd, homeDir);\n const config = applyRuntimeOverrides(loaded, input.runtime, runtimeConfigCwd);\n const resolved = resolveRuntime({ cwd: runtimeConfigCwd, config });\n const factory = selectExecutionEnv(resolved.runtime);\n const state = input.context?.state ?? loadState(homeDir);\n\n return {\n factory,\n detach: factory.supportsDetach === true && config.runner.detach,\n state,\n openSpec: {\n cwd: input.cwd,\n runtimeCwd: runtimeConfigCwd,\n runtime: resolved.runtime,\n runner: config.runner,\n state,\n env: input.env,\n uploadIgnoreFiles: config.runner.workspace?.exclude ?? [],\n jobLabel: {\n tool: input.tool,\n argv: input.argv\n },\n ...input.openSpec\n }\n };\n}\n\nexport interface LoadedRuntimeConfig extends ResolvedConfig {\n /** Raw merged runtime scope preserved for re-parsing when overrides change the type. */\n rawScope: Record<string, unknown>;\n}\n\nexport function applyRuntimeOverrides(\n config: ResolvedConfig | LoadedRuntimeConfig,\n overrides: RuntimeOverrideOptions | undefined,\n cwd = process.cwd()\n): ResolvedConfig {\n if (!overrides) {\n return { runtime: config.runtime, runner: config.runner };\n }\n\n const base: Record<string, unknown> =\n \"rawScope\" in config && config.rawScope\n ? { ...config.rawScope }\n : { ...(config.runtime as unknown as Record<string, unknown>) };\n\n const runtime = parseRuntime({\n ...base,\n ...(overrides.runtime !== undefined ? { type: overrides.runtime } : {}),\n ...(overrides.runtimeImage !== undefined ? { image: overrides.runtimeImage } : {}),\n ...(overrides.runtimeTemplate !== undefined\n ? { template_id: overrides.runtimeTemplate }\n : {}),\n ...(overrides.mountPoeCode === true\n ? { mounts: [...config.runtime.mounts, createPoeCodeMount(cwd)] }\n : {})\n });\n\n return {\n runtime,\n runner: {\n ...config.runner,\n ...(overrides.detach === true ? { detach: true } : {}),\n ...(overrides.runnerSync !== undefined ? { sync: overrides.runnerSync } : {})\n }\n };\n}\n\nfunction createPoeCodeMount(cwd: string): { source: string; target: string; readonly: boolean } {\n return {\n source: cwd,\n target: \"/usr/local/lib/poe-code\",\n readonly: true\n };\n}\n\nfunction loadRuntimeConfig(cwd: string, homeDir: string): LoadedRuntimeConfig {\n const document = deepMergeDocuments(\n readConfigDocument(resolveConfigPath(homeDir)),\n readConfigDocument(resolveProjectConfigPath(cwd))\n );\n const runtimeScope = resolveScope(runtimeConfigScope.schema, document.runtime, process.env);\n\n return {\n rawScope: { ...(runtimeScope as unknown as Record<string, unknown>) },\n runtime: parseRuntime(runtimeScope),\n runner: runtimeScope.runner\n };\n}\n\nfunction readConfigDocument(filePath: string): ConfigDocument {\n if (!existsSync(filePath)) {\n return {};\n }\n return JSON.parse(readFileSync(filePath, \"utf8\")) as ConfigDocument;\n}\n\nfunction loadState(homeDir: string): StateManager {\n if (process.env.VITEST === \"true\") {\n return createMemoryStateManager();\n }\n return createStateManager(homeDir);\n}\n\nfunction createMemoryStateManager(): StateManager {\n const jobs = new Map<string, JobEntry>();\n return {\n templates: {\n async get() {\n return null;\n },\n async put() {},\n async remove() {},\n async list() {\n return [];\n }\n },\n jobs: {\n async get(id) {\n return jobs.get(id) ?? null;\n },\n async put(entry) {\n jobs.set(entry.id, entry);\n },\n async update(id, patch) {\n const current = jobs.get(id);\n if (!current) {\n return null;\n }\n const updated = { ...current, ...patch, id };\n jobs.set(id, updated);\n return updated;\n },\n async list(filter?: JobListFilter) {\n const entries = Array.from(jobs.values());\n if (!filter) {\n return entries;\n }\n return entries.filter((entry) =>\n Object.entries(filter).every(([key, value]) => entry[key as keyof JobEntry] === value)\n );\n },\n async remove(id) {\n jobs.delete(id);\n }\n }\n };\n}\n", "import { existsSync } from \"node:fs\";\nimport path from \"node:path\";\nimport type { ResolvedConfig, SchemaField, ScopeDefinition } from \"./types.js\";\n\nexport interface RuntimeMount {\n source: string;\n target: string;\n readonly?: boolean;\n}\n\nexport interface RunnerScope {\n detach: boolean;\n upload_max_file_mb: number;\n download_conflict: \"refuse\" | \"overwrite\";\n sync: \"both\" | \"upload\" | \"none\";\n workspace?: {\n exclude?: string[];\n };\n}\n\ninterface SharedRuntimeFields {\n build_args: Record<string, string>;\n mounts: RuntimeMount[];\n link?: string;\n}\n\nexport interface HostRuntime extends SharedRuntimeFields {\n type: \"host\";\n}\n\nexport interface DockerRuntime extends SharedRuntimeFields {\n type: \"docker\";\n image?: string;\n dockerfile?: string;\n build_context?: string;\n engine?: \"docker\" | \"podman\";\n network?: string;\n extra_args?: string[];\n}\n\nexport interface E2bRuntime extends SharedRuntimeFields {\n type: \"e2b\";\n template_id?: string;\n from_template?: string;\n dockerfile?: string;\n build_context?: string;\n workspace_dir?: string;\n cpu?: number;\n memory_mb?: number;\n timeout_minutes?: number;\n preserve_after_exit_hours?: number;\n}\n\nexport type RuntimeConfig = HostRuntime | DockerRuntime | E2bRuntime;\nexport type RuntimeRunner = RuntimeConfig[\"type\"];\n\nconst defaultWorkspaceExclude = [\n \".git\",\n \"node_modules\",\n \"dist\",\n \".turbo\",\n \".next\",\n \".poe-code/state.json\"\n];\n\nexport interface RuntimeResolveResult {\n runtime: RuntimeConfig;\n runner: RuntimeRunner;\n dockerfilePath: string | null;\n buildContext: string | null;\n}\n\ntype RuntimeResolver = (input: { cwd: string; runtime: RuntimeConfig }) => RuntimeResolveResult;\n\nexport const runtimeConfigScope = {\n scope: \"runtime\",\n schema: {\n type: {\n type: \"string\",\n default: \"host\",\n doc: \"Runtime backend: host, docker, or e2b\"\n },\n build_args: {\n type: \"json\",\n default: {} as Record<string, string>,\n parse: parseBuildArgs,\n doc: \"Build arguments passed to the runtime image build\"\n },\n mounts: {\n type: \"json\",\n default: [] as RuntimeMount[],\n parse: parseMounts,\n doc: \"Additional runtime mounts\"\n },\n runner: {\n type: \"json\",\n default: createDefaultRunnerScope(),\n parse: parseRunner,\n doc: \"Runner process and workspace transfer settings\"\n },\n link: {\n type: \"string\",\n default: \"\",\n doc: \"Informational link for the runtime definition\"\n },\n image: {\n type: \"string\",\n default: \"\",\n doc: \"Prebuilt Docker image\"\n },\n dockerfile: {\n type: \"string\",\n default: \"\",\n doc: \"Path to the Dockerfile used for docker or e2b builds\"\n },\n build_context: {\n type: \"string\",\n default: \"\",\n doc: \"Path to the Docker build context\"\n },\n workspace_dir: {\n type: \"string\",\n default: \"/workspace\",\n doc: \"Sandbox-local workspace directory for E2B runtime upload, execution, and download\"\n },\n engine: {\n type: \"string\",\n default: \"\",\n doc: \"Container engine for Docker runtime\"\n },\n network: {\n type: \"string\",\n default: \"\",\n doc: \"Docker network\"\n },\n extra_args: {\n type: \"json\",\n default: undefined as string[] | undefined,\n parse: parseOptionalStringArray,\n doc: \"Extra Docker runtime arguments\"\n },\n template_id: {\n type: \"string\",\n default: \"\",\n doc: \"Prebuilt E2B template id\"\n },\n from_template: {\n type: \"string\",\n default: \"\",\n doc: \"Existing E2B template alias to extend instead of using the Dockerfile FROM image\"\n },\n cpu: {\n type: \"json\",\n default: undefined as number | undefined,\n parse: parseOptionalNumber,\n doc: \"E2B CPU count\"\n },\n memory_mb: {\n type: \"json\",\n default: undefined as number | undefined,\n parse: parseOptionalNumber,\n doc: \"E2B memory in megabytes\"\n },\n timeout_minutes: {\n type: \"json\",\n default: undefined as number | undefined,\n parse: parseOptionalNumber,\n doc: \"E2B timeout in minutes\"\n },\n preserve_after_exit_hours: {\n type: \"json\",\n default: undefined as number | undefined,\n parse: parseOptionalNumber,\n doc: \"Hours to keep an E2B sandbox alive after job exit\"\n }\n }\n} satisfies ScopeDefinition<Record<string, SchemaField>>;\n\nexport function parseRunner(raw: unknown): RunnerScope {\n if (raw === undefined) {\n return createDefaultRunnerScope();\n }\n const record = asRecord(raw);\n if (record === undefined) {\n throw new Error(\"runner: expected an object.\");\n }\n\n const uploadMaxFileMb =\n parseOptionalNumber(record.upload_max_file_mb, \"runner.upload_max_file_mb\") ?? 100;\n if (uploadMaxFileMb <= 0) {\n throw new Error(\"runner.upload_max_file_mb: expected a positive finite number.\");\n }\n\n return omitUndefined({\n detach: parseOptionalBoolean(record.detach, \"runner.detach\") ?? false,\n upload_max_file_mb: uploadMaxFileMb,\n download_conflict: parseDownloadConflict(record.download_conflict),\n sync: parseRunnerSync(record.sync),\n workspace: parseRunnerWorkspace(record.workspace)\n });\n}\n\nexport function parseRuntime(raw: unknown): RuntimeConfig {\n if (raw === undefined) {\n return {\n type: \"host\",\n build_args: {},\n mounts: []\n };\n }\n const record = asRecord(raw);\n if (record === undefined) {\n throw new Error(\"runtime: expected an object.\");\n }\n const type = parseRuntimeType(record.type);\n const shared = parseSharedRuntimeFields(record);\n\n if (type === \"docker\") {\n return omitUndefined({\n ...shared,\n type,\n image: parseOptionalString(record.image),\n dockerfile: parseOptionalString(record.dockerfile),\n build_context: parseOptionalString(record.build_context),\n engine: parseEngine(record.engine),\n network: parseOptionalString(record.network),\n extra_args: parseOptionalStringArray(record.extra_args)\n });\n }\n\n if (type === \"e2b\") {\n const preserveAfterExitHours = parseOptionalNumber(record.preserve_after_exit_hours) ?? 24;\n if (preserveAfterExitHours < 0 || preserveAfterExitHours > 168) {\n throw new Error(\"preserve_after_exit_hours: expected a number from 0 to 168.\");\n }\n\n return omitUndefined({\n ...shared,\n type,\n template_id: parseOptionalString(record.template_id),\n from_template: parseOptionalString(record.from_template),\n dockerfile: parseOptionalString(record.dockerfile),\n build_context: parseOptionalString(record.build_context),\n workspace_dir: parseWorkspaceDir(record.workspace_dir),\n cpu: parseOptionalNumber(record.cpu),\n memory_mb: parseOptionalNumber(record.memory_mb),\n timeout_minutes: parseOptionalNumber(record.timeout_minutes),\n preserve_after_exit_hours: preserveAfterExitHours\n });\n }\n\n return {\n ...shared,\n type\n };\n}\n\nexport function resolveRuntime({\n cwd,\n config\n}: {\n cwd: string;\n config: Pick<ResolvedConfig, \"runtime\">;\n}): RuntimeResolveResult {\n const runtime = config.runtime;\n return runtimeResolvers[runtime.type]({ cwd, runtime });\n}\n\nconst runtimeResolvers: Record<RuntimeConfig[\"type\"], RuntimeResolver> = {\n host({ runtime }) {\n return {\n runtime,\n runner: \"host\",\n dockerfilePath: null,\n buildContext: null\n };\n },\n docker({ cwd, runtime }) {\n const dockerRuntime = runtime as DockerRuntime;\n const { dockerfilePath, buildContext } = resolveRuntimeBuildPaths(cwd, dockerRuntime);\n\n if (dockerRuntime.image !== undefined) {\n return {\n runtime: dockerRuntime,\n runner: \"docker\",\n dockerfilePath: null,\n buildContext: null\n };\n }\n if (!existsSync(dockerfilePath)) {\n throw new Error(`Docker runtime requires image or a Dockerfile at ${dockerfilePath}.`);\n }\n return {\n runtime: dockerRuntime,\n runner: \"docker\",\n dockerfilePath,\n buildContext\n };\n },\n e2b({ cwd, runtime }) {\n const e2bRuntime = runtime as E2bRuntime;\n const { dockerfilePath, buildContext } = resolveRuntimeBuildPaths(cwd, e2bRuntime);\n\n if (e2bRuntime.template_id !== undefined) {\n return {\n runtime: e2bRuntime,\n runner: \"e2b\",\n dockerfilePath: null,\n buildContext: null\n };\n }\n if (!existsSync(dockerfilePath)) {\n throw new Error(`E2B runtime requires template_id or a Dockerfile at ${dockerfilePath}.`);\n }\n return {\n runtime: e2bRuntime,\n runner: \"e2b\",\n dockerfilePath,\n buildContext\n };\n }\n};\n\nfunction resolveRuntimeBuildPaths(\n cwd: string,\n runtime: DockerRuntime | E2bRuntime\n): { dockerfilePath: string; buildContext: string } {\n return {\n dockerfilePath: path.resolve(cwd, runtime.dockerfile ?? path.join(\".poe-code\", \"Dockerfile\")),\n buildContext: path.resolve(cwd, runtime.build_context ?? \".\")\n };\n}\n\nfunction parseSharedRuntimeFields(record: Record<string, unknown>): SharedRuntimeFields {\n return omitUndefined({\n build_args: parseBuildArgs(record.build_args),\n mounts: parseMounts(record.mounts),\n link: parseOptionalString(record.link)\n });\n}\n\nfunction parseRuntimeType(value: unknown): RuntimeConfig[\"type\"] {\n if (value === undefined) {\n return \"host\";\n }\n if (value === \"host\" || value === \"docker\" || value === \"e2b\") {\n return value;\n }\n throw new Error('type: expected \"host\", \"docker\", or \"e2b\".');\n}\n\nfunction parseWorkspaceDir(value: unknown): string {\n const workspaceDir = parseOptionalString(value) ?? \"/workspace\";\n if (!path.posix.isAbsolute(workspaceDir)) {\n throw new Error(\"workspace_dir: expected an absolute sandbox path.\");\n }\n let normalized = path.posix.normalize(workspaceDir);\n while (normalized.length > 1 && normalized.endsWith(\"/\")) {\n normalized = normalized.slice(0, -1);\n }\n return normalized;\n}\n\nfunction createDefaultRunnerScope(): RunnerScope {\n return {\n detach: false,\n upload_max_file_mb: 100,\n download_conflict: \"refuse\",\n sync: \"both\",\n workspace: {\n exclude: [...defaultWorkspaceExclude]\n }\n };\n}\n\nfunction parseRunnerWorkspace(value: unknown): RunnerScope[\"workspace\"] {\n if (value === undefined) {\n return {\n exclude: [...defaultWorkspaceExclude]\n };\n }\n const record = asRecord(value);\n if (record === undefined) {\n throw new Error(\"runner.workspace: expected an object.\");\n }\n\n return {\n exclude: parseOptionalStringArray(record.exclude, \"runner.workspace.exclude\") ?? [\n ...defaultWorkspaceExclude\n ]\n };\n}\n\nfunction parseDownloadConflict(value: unknown): RunnerScope[\"download_conflict\"] {\n if (value === undefined) {\n return \"refuse\";\n }\n if (value === \"refuse\" || value === \"overwrite\") {\n return value;\n }\n throw new Error('runner.download_conflict: expected \"refuse\" or \"overwrite\".');\n}\n\nfunction parseRunnerSync(value: unknown): RunnerScope[\"sync\"] {\n if (value === undefined) {\n return \"both\";\n }\n if (value === \"both\" || value === \"upload\" || value === \"none\") {\n return value;\n }\n throw new Error('runner.sync: expected \"both\", \"upload\", or \"none\".');\n}\n\nfunction parseBuildArgs(value: unknown): Record<string, string> {\n if (value === undefined) {\n return {};\n }\n const record = asRecord(value);\n if (record === undefined) {\n throw new Error(\"build_args: expected an object.\");\n }\n\n const parsed: Record<string, string> = {};\n for (const [key, entry] of Object.entries(record)) {\n if (typeof entry !== \"string\") {\n throw new Error(`build_args.${key}: expected a string.`);\n }\n parsed[key] = entry;\n }\n return parsed;\n}\n\nfunction parseMounts(value: unknown): RuntimeMount[] {\n if (value === undefined) {\n return [];\n }\n if (!Array.isArray(value)) {\n throw new Error(\"mounts: expected an array.\");\n }\n\n return value.map((entry, index) => {\n const record = asRecord(entry);\n if (record === undefined) {\n throw new Error(`mounts[${index}]: expected an object.`);\n }\n const source = record.source;\n const target = record.target;\n if (typeof source !== \"string\") {\n throw new Error(`mounts[${index}].source: expected a string.`);\n }\n if (typeof target !== \"string\") {\n throw new Error(`mounts[${index}].target: expected a string.`);\n }\n\n return omitUndefined({\n source,\n target,\n readonly: parseOptionalBoolean(record.readonly, `mounts[${index}].readonly`)\n });\n });\n}\n\nfunction parseOptionalString(value: unknown): string | undefined {\n if (value === undefined) {\n return undefined;\n }\n if (typeof value !== \"string\") {\n throw new Error(\"expected a string.\");\n }\n if (value.length === 0) {\n return undefined;\n }\n return value;\n}\n\nfunction parseOptionalStringArray(value: unknown, key = \"\"): string[] | undefined {\n if (value === undefined) {\n return undefined;\n }\n if (!Array.isArray(value)) {\n throw new Error(`${key ? `${key}: ` : \"\"}expected an array.`);\n }\n return value.map((entry, index) => {\n if (typeof entry !== \"string\") {\n throw new Error(`${key}[${index}]: expected a string.`);\n }\n return entry;\n });\n}\n\nfunction parseEngine(value: unknown): \"docker\" | \"podman\" | undefined {\n const engine = parseOptionalString(value);\n if (engine === undefined || engine === \"docker\" || engine === \"podman\") {\n return engine;\n }\n throw new Error('engine: expected \"docker\" or \"podman\".');\n}\n\nfunction parseOptionalNumber(value: unknown, key = \"\"): number | undefined {\n if (value === undefined) {\n return undefined;\n }\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`${key ? `${key}: ` : \"\"}expected a finite number.`);\n }\n return value;\n}\n\nfunction parseOptionalBoolean(value: unknown, key: string): boolean | undefined {\n if (value === undefined) {\n return undefined;\n }\n if (typeof value !== \"boolean\") {\n throw new Error(`${key}: expected a boolean.`);\n }\n return value;\n}\n\nfunction asRecord(value: unknown): Record<string, unknown> | undefined {\n if (!value || typeof value !== \"object\" || Array.isArray(value)) {\n return undefined;\n }\n return value as Record<string, unknown>;\n}\n\nfunction omitUndefined<T extends Record<string, unknown>>(value: T): T {\n return Object.fromEntries(Object.entries(value).filter(([, entry]) => entry !== undefined)) as T;\n}\n", "import type {\n BraintrustIntegrationConfig,\n ScopeDefinition,\n ScopeSchema\n} from \"./types.js\";\n\nexport function defineScope<const S extends ScopeSchema>(\n scope: string,\n schema: S\n): ScopeDefinition<S> {\n return {\n scope,\n schema\n };\n}\n\nexport const integrationsConfigScope = defineScope(\"integrations\", {\n braintrust: {\n type: \"json\",\n default: {\n enabled: false\n } satisfies BraintrustIntegrationConfig,\n parse: parseBraintrustIntegrationConfig,\n doc: \"Braintrust integration configuration\"\n }\n});\n\nexport { runtimeConfigScope } from \"./runtime.js\";\n\nfunction parseBraintrustIntegrationConfig(value: unknown): BraintrustIntegrationConfig {\n if (!isRecord(value)) {\n throw new Error(\"expected an object\");\n }\n\n const enabled = value.enabled === undefined ? false : value.enabled;\n if (typeof enabled !== \"boolean\") {\n throw new Error(\"enabled must be a boolean\");\n }\n\n return {\n enabled,\n ...optionalStringEntry(\"apiKey\", value.apiKey),\n ...optionalStringEntry(\"apiUrl\", value.apiUrl),\n ...optionalStringEntry(\"project\", value.project)\n };\n}\n\nfunction optionalStringEntry(key: string, value: unknown): Record<string, string> {\n if (value === undefined) {\n return {};\n }\n\n if (typeof value !== \"string\") {\n throw new Error(`${key} must be a string`);\n }\n\n return { [key]: value };\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n", "import { defineScope } from \"./schema.js\";\n\nexport const planConfigScope = defineScope(\"plan\", {\n plan_directory: {\n type: \"string\",\n default: \"docs/plans\",\n env: \"POE_PLAN_DIRECTORY\",\n doc: \"Directory where planning documents are stored\"\n }\n});\n", "import path from \"node:path\";\nimport { resolve, type FileSystem as ResolveFileSystem } from \"@poe-code/config-extends\";\nimport { createTimestamp, isNotFound, type FileSystem } from \"@poe-code/config-mutations\";\nimport type { ConfigDocument } from \"./types.js\";\n\nexport async function readDocument(fs: FileSystem, filePath: string): Promise<ConfigDocument> {\n const document = await readStoredDocument(fs, filePath);\n return document.data;\n}\n\nexport async function writeScope(\n fs: FileSystem,\n filePath: string,\n scope: string,\n values: Record<string, unknown>\n): Promise<void> {\n const document = await readDocument(fs, filePath);\n const normalizedValues = normalizeScopeValues(values);\n\n if (Object.keys(normalizedValues).length === 0) {\n delete document[scope];\n } else {\n document[scope] = normalizedValues;\n }\n\n await writeDocument(fs, filePath, document);\n}\n\nexport async function readMergedDocument(\n fs: FileSystem,\n globalPath: string,\n projectPath?: string\n): Promise<ConfigDocument> {\n const globalDocument = await readStoredDocument(fs, globalPath);\n if (!projectPath || projectPath === globalPath) {\n return globalDocument.data;\n }\n\n const projectDocument = await readStoredDocument(fs, projectPath);\n const resolved = await resolve(\n [\n {\n source: \"project\",\n filePath: projectPath,\n content: projectDocument.content\n },\n {\n source: \"base\",\n path: path.dirname(globalPath)\n }\n ],\n {\n fs: createResolvedConfigFs(fs, globalPath, globalDocument.content),\n autoExtend: true\n }\n );\n\n return normalizeDocument(resolved.data);\n}\n\nasync function readStoredDocument(\n fs: FileSystem,\n filePath: string\n): Promise<{ content: string; data: ConfigDocument }> {\n try {\n const raw = await fs.readFile(filePath, \"utf8\");\n return await parseStoredDocument(fs, filePath, raw);\n } catch (error) {\n if (isNotFound(error)) {\n return {\n content: EMPTY_DOCUMENT,\n data: {}\n };\n }\n\n throw error;\n }\n}\n\nasync function parseStoredDocument(\n fs: FileSystem,\n filePath: string,\n raw: string\n): Promise<{ content: string; data: ConfigDocument }> {\n try {\n return {\n content: raw,\n data: normalizeDocument(JSON.parse(raw))\n };\n } catch (error) {\n if (error instanceof SyntaxError) {\n await recoverInvalidDocument(fs, filePath, raw);\n return {\n content: EMPTY_DOCUMENT,\n data: {}\n };\n }\n throw error;\n }\n}\n\nfunction normalizeDocument(value: unknown): ConfigDocument {\n if (!isRecord(value)) {\n return {};\n }\n\n const document: ConfigDocument = {};\n for (const [scope, scopeValues] of Object.entries(value)) {\n const normalizedValues = normalizeScopeValues(scopeValues);\n if (Object.keys(normalizedValues).length > 0) {\n document[scope] = normalizedValues;\n }\n }\n\n return document;\n}\n\nfunction normalizeScopeValues(value: unknown): Record<string, unknown> {\n if (!isRecord(value)) {\n return {};\n }\n\n const normalized: Record<string, unknown> = {};\n for (const [key, entry] of Object.entries(value)) {\n if (entry !== undefined) {\n normalized[key] = entry;\n }\n }\n\n return normalized;\n}\n\nfunction createResolvedConfigFs(\n fs: FileSystem,\n globalPath: string,\n globalContent: string\n): ResolveFileSystem {\n return {\n readFile(filePath: string, _encoding: BufferEncoding) {\n if (filePath === globalPath) {\n return Promise.resolve(globalContent);\n }\n\n return fs.readFile(filePath, \"utf8\");\n }\n };\n}\n\nasync function writeDocument(\n fs: FileSystem,\n filePath: string,\n document: ConfigDocument\n): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n await fs.writeFile(filePath, `${JSON.stringify(document, null, 2)}\\n`, {\n encoding: \"utf8\"\n });\n}\n\nasync function recoverInvalidDocument(\n fs: FileSystem,\n filePath: string,\n content: string\n): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n const backupPath = createInvalidBackupPath(filePath);\n await fs.writeFile(backupPath, content, { encoding: \"utf8\" });\n await fs.writeFile(filePath, EMPTY_DOCUMENT, { encoding: \"utf8\" });\n}\n\nfunction createInvalidBackupPath(filePath: string): string {\n const directory = path.dirname(filePath);\n const baseName = path.basename(filePath);\n return path.join(directory, `${baseName}.invalid-${createTimestamp()}.json`);\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value && typeof value === \"object\" && !Array.isArray(value));\n}\n\nexport function resolveConfigPath(homeDir: string): string {\n return path.join(homeDir, \".poe-code\", \"config.json\");\n}\n\nexport function resolveServicesConfigPath(homeDir: string): string {\n return path.join(homeDir, \".config\", \"poe-code\", \"services.json\");\n}\n\nexport function resolveProjectConfigPath(cwd: string): string {\n return path.join(cwd, \".poe-code\", \"config.json\");\n}\n\nconst EMPTY_DOCUMENT = `${JSON.stringify({}, null, 2)}\\n`;\n", "import path from \"node:path\";\nimport type { FileSystem } from \"./types.js\";\n\nexport interface DiscoveredBase {\n content: string;\n filePath: string;\n}\n\nexport async function findBase(\n name: string,\n bases: string[],\n fs: FileSystem\n): Promise<DiscoveredBase> {\n const checkedPaths: string[] = [];\n\n for (const basePath of bases) {\n for (const extension of [\".md\", \".yaml\", \".yml\", \".json\"]) {\n const filePath = path.join(basePath, `${name}${extension}`);\n checkedPaths.push(filePath);\n\n try {\n return {\n content: await fs.readFile(filePath, \"utf8\"),\n filePath\n };\n } catch (error) {\n if (hasCode(error, \"ENOENT\")) {\n continue;\n }\n\n throw error;\n }\n }\n }\n\n throw new Error(`Base \"${name}\" not found.\\nChecked paths:\\n- ${checkedPaths.join(\"\\n- \")}`);\n}\n\nfunction hasCode(error: unknown, code: string): error is NodeJS.ErrnoException {\n return (\n typeof error === \"object\" &&\n error !== null &&\n \"code\" in error &&\n error.code === code\n );\n}\n", "import path from \"node:path\";\nimport matter from \"gray-matter\";\nimport { parse as parseYaml } from \"yaml\";\nimport type { ParsedDocument } from \"./types.js\";\n\nexport function parseDocument(content: string, filePath: string): ParsedDocument {\n const normalizedContent = stripBom(content);\n const format = detectFormat(normalizedContent, filePath);\n const data =\n format === \"markdown\"\n ? parseMarkdown(normalizedContent)\n : toData(format === \"json\" ? JSON.parse(normalizedContent) : parseYaml(normalizedContent));\n const hasExtendsField = Object.hasOwn(data, \"extends\");\n const extendsValue = data.extends === true;\n\n delete data.extends;\n\n return {\n data,\n format,\n extends: extendsValue,\n hasExtendsField\n };\n}\n\nfunction detectFormat(\n content: string,\n filePath: string\n): ParsedDocument[\"format\"] {\n const extension = path.extname(filePath).toLowerCase();\n\n if (extension === \".md\") {\n return \"markdown\";\n }\n\n if (extension === \".yaml\" || extension === \".yml\") {\n return \"yaml\";\n }\n\n if (extension === \".json\") {\n return \"json\";\n }\n\n if (content.startsWith(\"{\")) {\n return \"json\";\n }\n\n if (content.startsWith(\"---\\n\") || content.startsWith(\"---\\r\\n\")) {\n return \"markdown\";\n }\n\n return \"yaml\";\n}\n\nfunction parseMarkdown(content: string): Record<string, unknown> {\n const document = matter(content);\n return {\n ...toData(document.data),\n prompt: document.content\n };\n}\n\nfunction toData(value: unknown): Record<string, unknown> {\n if (!value || typeof value !== \"object\" || Array.isArray(value)) {\n return {};\n }\n\n return { ...(value as Record<string, unknown>) };\n}\n\nfunction stripBom(content: string): string {\n if (!content.startsWith(\"\\uFEFF\")) {\n return content;\n }\n\n return content.slice(1);\n}\n", "import type { DataLayer } from \"./types.js\";\n\nexport interface MergeLayersResult {\n data: Record<string, unknown>;\n sources: Record<string, string>;\n}\n\nexport function mergeLayers(layers: DataLayer[]): MergeLayersResult {\n return mergeObjectLayers(layers, []);\n}\n\nfunction mergeObjectLayers(layers: DataLayer[], path: string[]): MergeLayersResult {\n const data: Record<string, unknown> = {};\n const sources: Record<string, string> = {};\n\n for (const key of collectKeys(layers)) {\n const resolved = resolveKey(layers, key, path);\n\n if (resolved === undefined) {\n continue;\n }\n\n data[key] = resolved.value;\n Object.assign(sources, resolved.sources);\n }\n\n return { data, sources };\n}\n\nfunction collectKeys(layers: DataLayer[]): string[] {\n const keys = new Set<string>();\n\n for (const layer of layers) {\n for (const key of Object.keys(layer.data)) {\n keys.add(key);\n }\n }\n\n return [...keys];\n}\n\nfunction resolveKey(\n layers: DataLayer[],\n key: string,\n path: string[]\n): { value: unknown; sources: Record<string, string> } | undefined {\n let winningSource: string | undefined;\n let winningValue: unknown;\n const objectLayers: DataLayer[] = [];\n\n for (const layer of layers) {\n const candidate = layer.data[key];\n\n if (!isWinningCandidate(key, candidate)) {\n continue;\n }\n\n if (winningSource === undefined) {\n winningSource = layer.source;\n winningValue = candidate;\n\n if (isPlainObject(candidate)) {\n objectLayers.push({\n source: layer.source,\n data: candidate\n });\n }\n\n continue;\n }\n\n if (isPlainObject(winningValue) && isPlainObject(candidate)) {\n objectLayers.push({\n source: layer.source,\n data: candidate\n });\n }\n }\n\n if (winningSource === undefined) {\n return undefined;\n }\n\n const fullPath = buildPath(path, key);\n\n if (isPlainObject(winningValue)) {\n const merged = mergeObjectLayers(objectLayers, [...path, key]);\n\n return {\n value: merged.data,\n sources: {\n [fullPath]: winningSource,\n ...merged.sources\n }\n };\n }\n\n return {\n value: cloneValue(winningValue),\n sources: {\n [fullPath]: winningSource\n }\n };\n}\n\nfunction isWinningCandidate(key: string, value: unknown): boolean {\n if (value === undefined) {\n return false;\n }\n\n if (key === \"prompt\" && value === \"\") {\n return false;\n }\n\n return true;\n}\n\nfunction buildPath(path: string[], key: string): string {\n return [...path, key].join(\".\");\n}\n\nfunction isPlainObject(value: unknown): value is Record<string, unknown> {\n if (value === null || Array.isArray(value) || typeof value !== \"object\") {\n return false;\n }\n\n const prototype = Object.getPrototypeOf(value);\n return prototype === Object.prototype || prototype === null;\n}\n\nfunction cloneValue(value: unknown): unknown {\n if (Array.isArray(value)) {\n return value.map((entry) => cloneValue(entry));\n }\n\n if (!isPlainObject(value)) {\n return value;\n }\n\n const clone = Object.create(Object.getPrototypeOf(value)) as Record<string, unknown>;\n\n for (const [key, entry] of Object.entries(value)) {\n clone[key] = cloneValue(entry);\n }\n\n return clone;\n}\n", "import path from \"node:path\";\nimport { renderTemplate } from \"@poe-code/design-system\";\nimport { findBase } from \"./discover.js\";\nimport { mergeLayers } from \"./merge.js\";\nimport { parseDocument } from \"./parse.js\";\nimport type {\n BaseLayer,\n ChainLayer,\n DataLayer,\n DocumentLayer,\n ResolveOptions,\n ResolvedDocument\n} from \"./types.js\";\n\nconst MAX_EXTENDS_DEPTH = 5;\nconst YIELD_TOKEN = \"{{yield}}\";\n\ninterface ClassifiedChain {\n baseLayers: BaseLayer[];\n documentIndex: number;\n documentLayer: DocumentLayer;\n}\n\ninterface ResolvedBaseChain {\n chain: string[];\n layers: DataLayer[];\n}\n\nexport async function resolve(\n chain: ChainLayer[],\n options: ResolveOptions\n): Promise<ResolvedDocument> {\n const { baseLayers, documentIndex, documentLayer } = classifyChain(chain);\n const parsedDocument = parseDocument(documentLayer.content, documentLayer.filePath);\n const resolvedBase = shouldResolveBase(parsedDocument, options.autoExtend)\n ? await resolveBaseChain({\n name: documentLayer.baseName ?? getBaseName(documentLayer.filePath),\n baseLayers,\n options,\n optional: !parsedDocument.extends,\n visited: new Set([documentLayer.filePath]),\n depth: 1\n })\n : undefined;\n const composedPrompt = composePromptChain(\n {\n source: documentLayer.source,\n data: parsedDocument.data\n },\n resolvedBase?.layers ?? []\n );\n const merged = mergeLayers([\n ...collectDataLayers(chain.slice(0, documentIndex)),\n {\n source: documentLayer.source,\n data: withResolvedPrompt(parsedDocument.data, composedPrompt?.prompt)\n },\n ...stripResolvedBasePrompts(resolvedBase?.layers ?? [], composedPrompt?.consumedBaseIndexes ?? new Set<number>()),\n ...collectDataLayers(chain.slice(documentIndex + 1))\n ]);\n\n if (composedPrompt !== undefined && merged.sources.prompt === documentLayer.source && composedPrompt.source !== undefined) {\n merged.sources.prompt = composedPrompt.source;\n }\n\n return {\n data: merged.data,\n sources: merged.sources,\n chain: [documentLayer.filePath, ...(resolvedBase?.chain ?? [])]\n };\n}\n\nfunction classifyChain(chain: ChainLayer[]): ClassifiedChain {\n const baseLayers: BaseLayer[] = [];\n const documentLayers: Array<{ index: number; layer: DocumentLayer }> = [];\n\n for (const [index, layer] of chain.entries()) {\n if (isDataLayer(layer)) {\n continue;\n }\n\n if (isDocumentLayer(layer)) {\n documentLayers.push({ index, layer });\n continue;\n }\n\n if (isBaseLayer(layer)) {\n baseLayers.push(layer);\n }\n }\n\n if (documentLayers.length !== 1) {\n throw new Error(`Exactly one document layer is required, received ${documentLayers.length}.`);\n }\n\n return {\n baseLayers,\n documentIndex: documentLayers[0].index,\n documentLayer: documentLayers[0].layer\n };\n}\n\nasync function resolveBaseChain({\n name,\n baseLayers,\n options,\n optional,\n visited,\n depth\n}: {\n name: string;\n baseLayers: BaseLayer[];\n options: ResolveOptions;\n optional: boolean;\n visited: Set<string>;\n depth: number;\n}): Promise<ResolvedBaseChain | undefined> {\n if (depth > MAX_EXTENDS_DEPTH) {\n throw new Error(`Maximum extends depth exceeded (${MAX_EXTENDS_DEPTH}).`);\n }\n\n let discoveredBase;\n\n try {\n discoveredBase = await findBase(\n name,\n baseLayers.map((layer) => layer.path),\n options.fs\n );\n } catch (error) {\n if (optional && isBaseNotFoundError(error)) {\n return undefined;\n }\n\n throw error;\n }\n\n if (visited.has(discoveredBase.filePath)) {\n if (optional) {\n return undefined;\n }\n\n throw new Error(\n `Circular extends detected.\\nVisited files:\\n- ${[...visited, discoveredBase.filePath].join(\"\\n- \")}`\n );\n }\n\n const matchedBaseIndex = baseLayers.findIndex(\n (layer) => layer.path === path.dirname(discoveredBase.filePath)\n );\n\n if (matchedBaseIndex === -1) {\n throw new Error(`Resolved base is outside configured base paths: ${discoveredBase.filePath}`);\n }\n\n const parsedBase = parseDocument(discoveredBase.content, discoveredBase.filePath);\n const nextVisited = new Set(visited);\n nextVisited.add(discoveredBase.filePath);\n const nestedBase = parsedBase.extends\n ? await resolveBaseChain({\n name: getBaseName(discoveredBase.filePath),\n baseLayers: baseLayers.slice(matchedBaseIndex + 1),\n options,\n optional: false,\n visited: nextVisited,\n depth: depth + 1\n })\n : undefined;\n\n return {\n layers: [\n {\n source: baseLayers[matchedBaseIndex].source,\n data: parsedBase.data\n },\n ...(nestedBase?.layers ?? [])\n ],\n chain: [discoveredBase.filePath, ...(nestedBase?.chain ?? [])]\n };\n}\n\nfunction collectDataLayers(chain: ChainLayer[]): DataLayer[] {\n return chain.filter(isDataLayer);\n}\n\ninterface ComposedPromptResult {\n consumedBaseIndexes: Set<number>;\n prompt: string;\n source?: string;\n}\n\nfunction composePromptChain(\n documentLayer: DataLayer,\n baseLayers: DataLayer[]\n): ComposedPromptResult | undefined {\n const documentPrompt = documentLayer.data.prompt;\n\n if (documentPrompt !== undefined && typeof documentPrompt !== \"string\") {\n return undefined;\n }\n\n if (documentPrompt !== undefined) {\n assertValidYieldCount(documentPrompt);\n }\n\n let prompt = documentPrompt;\n let source = prompt === undefined || prompt === \"\" ? undefined : documentLayer.source;\n const consumedBaseIndexes = new Set<number>();\n\n for (const [index, layer] of baseLayers.entries()) {\n const candidate = layer.data.prompt;\n\n if (candidate === undefined) {\n continue;\n }\n\n if (typeof candidate !== \"string\") {\n break;\n }\n\n assertValidYieldCount(candidate);\n consumedBaseIndexes.add(index);\n prompt = composeAdjacentPrompts(prompt, candidate);\n\n if (source === undefined && candidate !== \"\") {\n source = layer.source;\n }\n }\n\n if (prompt !== undefined && prompt.includes(YIELD_TOKEN)) {\n throw new Error('Final resolved prompt contains an unresolved \"{{yield}}\" token.');\n }\n\n if (prompt === undefined) {\n return undefined;\n }\n\n return {\n consumedBaseIndexes,\n prompt,\n source\n };\n}\n\nfunction composeAdjacentPrompts(\n high: string | undefined,\n low: string\n): string {\n if (high === undefined || high === \"\") {\n return low.includes(YIELD_TOKEN) ? replaceYield(low, \"\") : low;\n }\n\n if (high.includes(YIELD_TOKEN)) {\n return replaceYield(high, low);\n }\n\n if (low.includes(YIELD_TOKEN)) {\n return replaceYield(low, high);\n }\n\n return high;\n}\n\nfunction replaceYield(\n prompt: string,\n replacement: string\n): string {\n return renderTemplate(prompt, {}, { yield: replacement, escape: \"none\" });\n}\n\nfunction assertValidYieldCount(prompt: string): void {\n if (countYieldTokens(prompt) > 1) {\n throw new Error('Prompt composition supports exactly one \"{{yield}}\" token per prompt.');\n }\n}\n\nfunction countYieldTokens(prompt: string): number {\n return prompt.split(YIELD_TOKEN).length - 1;\n}\n\nfunction withResolvedPrompt(\n data: Record<string, unknown>,\n prompt: string | undefined\n): Record<string, unknown> {\n if (prompt === undefined) {\n return data;\n }\n\n return {\n ...data,\n prompt\n };\n}\n\nfunction stripResolvedBasePrompts(\n layers: DataLayer[],\n consumedBaseIndexes: Set<number>\n): DataLayer[] {\n return layers.map((layer, index) => {\n if (!consumedBaseIndexes.has(index) || typeof layer.data.prompt !== \"string\") {\n return layer;\n }\n\n const { prompt: ignoredPrompt, ...data } = layer.data;\n\n void ignoredPrompt;\n\n return {\n source: layer.source,\n data\n };\n });\n}\n\nfunction getBaseName(filePath: string): string {\n return path.basename(filePath, path.extname(filePath));\n}\n\nfunction shouldResolveBase(\n parsedDocument: ReturnType<typeof parseDocument>,\n autoExtend: boolean | undefined\n): boolean {\n return parsedDocument.extends || (autoExtend === true && !parsedDocument.hasExtendsField);\n}\n\nfunction isBaseNotFoundError(error: unknown): error is Error {\n return (\n error instanceof Error &&\n error.message.startsWith('Base \"') &&\n error.message.includes('\" not found.\\nChecked paths:')\n );\n}\n\nfunction isDataLayer(layer: ChainLayer): layer is DataLayer {\n return \"data\" in layer;\n}\n\nfunction isDocumentLayer(layer: ChainLayer): layer is DocumentLayer {\n return \"filePath\" in layer && \"content\" in layer;\n}\n\nfunction isBaseLayer(layer: ChainLayer): layer is BaseLayer {\n return \"path\" in layer;\n}\n", "export interface ColorSupportEnv {\n NO_COLOR?: string;\n FORCE_COLOR?: string;\n TERM?: string;\n}\n\nexport interface ColorSupportStream {\n isTTY?: boolean;\n}\n\nexport function supportsColor(\n env: ColorSupportEnv = process.env as ColorSupportEnv,\n stream: ColorSupportStream = process.stdout\n): boolean {\n if (env.FORCE_COLOR !== undefined && env.FORCE_COLOR !== \"0\") {\n return true;\n }\n\n if (env.NO_COLOR !== undefined) {\n return false;\n }\n\n if (stream.isTTY !== true) {\n return false;\n }\n\n return typeof env.TERM === \"string\" && env.TERM.length > 0 && env.TERM !== \"dumb\";\n}\n", "import { supportsColor } from \"../internal/color-support.js\";\n\ntype AnsiStyleName =\n | \"reset\"\n | \"bold\"\n | \"dim\"\n | \"italic\"\n | \"underline\"\n | \"inverse\"\n | \"strikethrough\"\n | \"black\"\n | \"red\"\n | \"green\"\n | \"yellow\"\n | \"blue\"\n | \"magenta\"\n | \"cyan\"\n | \"white\"\n | \"gray\"\n | \"magentaBright\"\n | \"cyanBright\"\n | \"bgRed\"\n | \"bgGreen\"\n | \"bgYellow\"\n | \"bgBlue\"\n | \"bgMagenta\";\n\ninterface AnsiPair {\n open: string;\n}\n\nexport interface Color {\n (text: string): string;\n reset: Color;\n bold: Color;\n dim: Color;\n italic: Color;\n underline: Color;\n inverse: Color;\n strikethrough: Color;\n black: Color;\n red: Color;\n green: Color;\n yellow: Color;\n blue: Color;\n magenta: Color;\n cyan: Color;\n white: Color;\n gray: Color;\n magentaBright: Color;\n cyanBright: Color;\n bgRed: Color;\n bgGreen: Color;\n bgYellow: Color;\n bgBlue: Color;\n bgMagenta: Color;\n hex: (value: string) => Color;\n rgb: (red: number, green: number, blue: number) => Color;\n bgHex: (value: string) => Color;\n bgRgb: (red: number, green: number, blue: number) => Color;\n}\n\nconst reset = \"\\x1b[0m\";\n\nconst ansiStyles: Record<AnsiStyleName, AnsiPair> = {\n reset: { open: reset },\n bold: { open: \"\\x1b[1m\" },\n dim: { open: \"\\x1b[2m\" },\n italic: { open: \"\\x1b[3m\" },\n underline: { open: \"\\x1b[4m\" },\n inverse: { open: \"\\x1b[7m\" },\n strikethrough: { open: \"\\x1b[9m\" },\n black: { open: \"\\x1b[30m\" },\n red: { open: \"\\x1b[31m\" },\n green: { open: \"\\x1b[32m\" },\n yellow: { open: \"\\x1b[33m\" },\n blue: { open: \"\\x1b[34m\" },\n magenta: { open: \"\\x1b[35m\" },\n cyan: { open: \"\\x1b[36m\" },\n white: { open: \"\\x1b[37m\" },\n gray: { open: \"\\x1b[90m\" },\n magentaBright: { open: \"\\x1b[95m\" },\n cyanBright: { open: \"\\x1b[96m\" },\n bgRed: { open: \"\\x1b[41m\" },\n bgGreen: { open: \"\\x1b[42m\" },\n bgYellow: { open: \"\\x1b[43m\" },\n bgBlue: { open: \"\\x1b[44m\" },\n bgMagenta: { open: \"\\x1b[45m\" }\n};\n\nconst styleNames = Object.keys(ansiStyles) as AnsiStyleName[];\n\nfunction replaceAll(value: string, search: string, replacement: string): string {\n return value.split(search).join(replacement);\n}\n\nfunction applyStyles(text: string, styles: AnsiPair[]): string {\n if (!supportsColor() || styles.length === 0) {\n return text;\n }\n\n const open = styles.map((style) => style.open).join(\"\");\n const output = text.includes(reset) ? replaceAll(text, reset, `${reset}${open}`) : text;\n\n return `${open}${output}${reset}`;\n}\n\nfunction clampRgb(value: number): number {\n if (Number.isNaN(value)) {\n return 0;\n }\n\n return Math.min(255, Math.max(0, Math.round(value)));\n}\n\nfunction hexChannel(value: string, offset: number): number {\n return Number.parseInt(value.slice(offset, offset + 2), 16);\n}\n\nfunction normalizeHex(value: string): [number, number, number] {\n const normalized = value.startsWith(\"#\") ? value.slice(1) : value;\n\n if (normalized.length === 3) {\n const red = normalized[0]!;\n const green = normalized[1]!;\n const blue = normalized[2]!;\n\n return [\n Number.parseInt(`${red}${red}`, 16),\n Number.parseInt(`${green}${green}`, 16),\n Number.parseInt(`${blue}${blue}`, 16)\n ];\n }\n\n if (normalized.length === 6) {\n return [\n hexChannel(normalized, 0),\n hexChannel(normalized, 2),\n hexChannel(normalized, 4)\n ];\n }\n\n return [0, 0, 0];\n}\n\nfunction rgbStyle(red: number, green: number, blue: number): AnsiPair {\n return {\n open: `\\x1b[38;2;${clampRgb(red)};${clampRgb(green)};${clampRgb(blue)}m`\n };\n}\n\nfunction bgRgbStyle(red: number, green: number, blue: number): AnsiPair {\n return {\n open: `\\x1b[48;2;${clampRgb(red)};${clampRgb(green)};${clampRgb(blue)}m`\n };\n}\n\nfunction createColor(styles: AnsiPair[] = []): Color {\n const builder = ((text: string) => applyStyles(String(text), styles)) as Color;\n\n for (const name of styleNames) {\n Object.defineProperty(builder, name, {\n configurable: true,\n enumerable: true,\n get: () => createColor([...styles, ansiStyles[name]])\n });\n }\n\n builder.hex = (value: string) => {\n const [red, green, blue] = normalizeHex(value);\n return createColor([...styles, rgbStyle(red, green, blue)]);\n };\n\n builder.rgb = (red: number, green: number, blue: number) =>\n createColor([...styles, rgbStyle(red, green, blue)]);\n\n builder.bgHex = (value: string) => {\n const [red, green, blue] = normalizeHex(value);\n return createColor([...styles, bgRgbStyle(red, green, blue)]);\n };\n\n builder.bgRgb = (red: number, green: number, blue: number) =>\n createColor([...styles, bgRgbStyle(red, green, blue)]);\n\n return builder;\n}\n\nexport const color = createColor();\n", "import { color } from \"../components/color.js\";\n\nexport const brand = \"#a200ff\";\n\nexport const dark = {\n header: (text: string) => color.magentaBright.bold(text),\n divider: (text: string) => color.dim(text),\n prompt: (text: string) => color.cyan(text),\n number: (text: string) => color.cyanBright(text),\n intro: (text: string) => color.bgMagenta.white(` Poe - ${text} `),\n resolvedSymbol: color.magenta(\"\u25C7\"),\n errorSymbol: color.red(\"\u25A0\"),\n accent: (text: string) => color.cyan(text),\n muted: (text: string) => color.dim(text),\n success: (text: string) => color.green(text),\n warning: (text: string) => color.yellow(text),\n error: (text: string) => color.red(text),\n info: (text: string) => color.magenta(text),\n badge: (text: string) => color.bgYellow.black(` ${text} `)\n};\n\nexport const light = {\n header: (text: string) => color.hex(\"#a200ff\").bold(text),\n divider: (text: string) => color.hex(\"#666666\")(text),\n prompt: (text: string) => color.hex(\"#006699\").bold(text),\n number: (text: string) => color.hex(\"#0077cc\").bold(text),\n intro: (text: string) => color.bgHex(\"#a200ff\").white(` Poe - ${text} `),\n resolvedSymbol: color.hex(\"#a200ff\")(\"\u25C7\"),\n errorSymbol: color.hex(\"#cc0000\")(\"\u25A0\"),\n accent: (text: string) => color.hex(\"#006699\").bold(text),\n muted: (text: string) => color.hex(\"#666666\")(text),\n success: (text: string) => color.hex(\"#008800\")(text),\n warning: (text: string) => color.hex(\"#cc6600\")(text),\n error: (text: string) => color.hex(\"#cc0000\")(text),\n info: (text: string) => color.hex(\"#a200ff\")(text),\n badge: (text: string) => color.bgHex(\"#cc6600\").white(` ${text} `)\n};\n\nexport type ThemeName = \"dark\" | \"light\";\nexport type ThemePalette = typeof dark;\n", "import { AsyncLocalStorage } from \"node:async_hooks\";\n\nexport type OutputFormat = \"terminal\" | \"markdown\" | \"json\";\n\nconst VALID_FORMATS = new Set<OutputFormat>([\"terminal\", \"markdown\", \"json\"]);\nconst formatStorage = new AsyncLocalStorage<OutputFormat>();\n\nlet cached: OutputFormat | undefined;\n\nexport function resolveOutputFormat(\n env: { OUTPUT_FORMAT?: string } = process.env as { OUTPUT_FORMAT?: string }\n): OutputFormat {\n const scoped = formatStorage.getStore();\n if (scoped) {\n return scoped;\n }\n if (cached) {\n return cached;\n }\n const raw = env.OUTPUT_FORMAT?.toLowerCase();\n cached = VALID_FORMATS.has(raw as OutputFormat) ? (raw as OutputFormat) : \"terminal\";\n return cached;\n}\n\nexport function withOutputFormat<T>(format: OutputFormat, fn: () => T): T {\n return formatStorage.run(format, fn);\n}\n\nexport function resetOutputFormatCache(): void {\n cached = undefined;\n}\n", "import { dark, light, type ThemeName, type ThemePalette } from \"../tokens/colors.js\";\n\nexport interface ThemeEnv {\n POE_CODE_THEME?: string;\n POE_THEME?: string;\n APPLE_INTERFACE_STYLE?: string;\n VSCODE_COLOR_THEME_KIND?: string;\n COLORFGBG?: string;\n}\n\nfunction detectThemeFromEnv(env: ThemeEnv): ThemeName | undefined {\n const apple = env.APPLE_INTERFACE_STYLE;\n if (typeof apple === \"string\") {\n return apple.toLowerCase() === \"dark\" ? \"dark\" : \"light\";\n }\n\n const vscodeKind = env.VSCODE_COLOR_THEME_KIND;\n if (typeof vscodeKind === \"string\") {\n const normalized = vscodeKind.toLowerCase();\n if (normalized.includes(\"light\")) {\n return \"light\";\n }\n if (normalized.includes(\"dark\")) {\n return \"dark\";\n }\n }\n\n const colorFGBG = env.COLORFGBG;\n if (typeof colorFGBG === \"string\") {\n const parts = colorFGBG.split(\";\").map((part) => Number.parseInt(part, 10));\n const background = parts.at(-1);\n if (Number.isFinite(background)) {\n return background! >= 8 ? \"light\" : \"dark\";\n }\n }\n\n return undefined;\n}\n\nexport function resolveThemeName(env: ThemeEnv = process.env as ThemeEnv): ThemeName {\n const raw = (env.POE_CODE_THEME ?? env.POE_THEME)?.toLowerCase();\n if (raw === \"light\" || raw === \"dark\") {\n return raw;\n }\n const detected = detectThemeFromEnv(env);\n if (detected) {\n return detected;\n }\n return \"dark\";\n}\n\nlet cachedTheme: ThemePalette | undefined;\n\nexport function getTheme(env?: ThemeEnv): ThemePalette {\n if (cachedTheme) {\n return cachedTheme;\n }\n const themeName = resolveThemeName(env);\n cachedTheme = themeName === \"light\" ? light : dark;\n return cachedTheme;\n}\n\nexport function resetThemeCache(): void {\n cachedTheme = undefined;\n}\n", "import { color } from \"./color.js\";\nimport { resolveOutputFormat } from \"../internal/output-format.js\";\nimport { getTheme } from \"../internal/theme-detect.js\";\n\nexport const symbols = {\n get info(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"info\";\n if (format === \"markdown\") return \"(i)\";\n return color.magenta(\"\u25CF\");\n },\n get success(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"success\";\n if (format === \"markdown\") return \"[ok]\";\n return color.magenta(\"\u25C6\");\n },\n get resolved(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"resolved\";\n if (format === \"markdown\") return \">\";\n return getTheme().resolvedSymbol;\n },\n get errorResolved(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"error\";\n if (format === \"markdown\") return \"[!]\";\n return getTheme().errorSymbol;\n },\n get bar(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"\";\n if (format === \"markdown\") return \"|\";\n return \"\u2502\";\n },\n cornerTopRight: \"\u256E\",\n cornerBottomRight: \"\u256F\",\n get warning(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"warning\";\n if (format === \"markdown\") return \"[!]\";\n return \"\u25B2\";\n },\n get active(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"active\";\n if (format === \"markdown\") return \"[x]\";\n return \"\u25C6\";\n },\n get inactive(): string {\n const format = resolveOutputFormat();\n if (format === \"json\") return \"inactive\";\n if (format === \"markdown\") return \"[ ]\";\n return \"\u25CB\";\n }\n} as const;\n", "export function stripAnsi(value: string): string {\n return value.replace(/\\u001b\\[[0-9;]*m/g, \"\");\n}\n", "import { color } from \"../../components/color.js\";\nimport { symbols } from \"../../components/symbols.js\";\nimport { resolveOutputFormat } from \"../../internal/output-format.js\";\nimport { stripAnsi } from \"../../internal/strip-ansi.js\";\n\nexport interface LogMessageOptions {\n symbol?: string;\n secondarySymbol?: string;\n spacing?: number;\n withGuide?: boolean;\n}\n\nfunction writeTerminalMessage(\n msg: string,\n {\n symbol = color.gray(\"\u2502\"),\n secondarySymbol = color.gray(\"\u2502\"),\n spacing = 1,\n withGuide = true\n }: LogMessageOptions = {}\n): void {\n const lines: string[] = [];\n const showGuide = withGuide !== false;\n const contentLines = msg.split(\"\\n\");\n const prefix = showGuide ? `${symbol} ` : \"\";\n const continuationPrefix = showGuide ? `${secondarySymbol} ` : \"\";\n const emptyGuide = showGuide ? secondarySymbol : \"\";\n\n for (let index = 0; index < spacing; index += 1) {\n lines.push(emptyGuide);\n }\n\n if (contentLines.length === 0) {\n process.stdout.write(\"\\n\");\n return;\n }\n\n const [firstLine = \"\", ...continuationLines] = contentLines;\n if (firstLine.length > 0) {\n lines.push(`${prefix}${firstLine}`);\n } else {\n lines.push(showGuide ? symbol : \"\");\n }\n\n for (const line of continuationLines) {\n if (line.length > 0) {\n lines.push(`${continuationPrefix}${line}`);\n continue;\n }\n lines.push(emptyGuide);\n }\n\n process.stdout.write(`${lines.join(\"\\n\")}\\n`);\n}\n\nexport function message(msg: string, options?: LogMessageOptions): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`- ${stripAnsi(msg)}\\n`);\n return;\n }\n if (format === \"json\") {\n process.stdout.write(\n `${JSON.stringify({ level: \"message\", message: stripAnsi(msg) })}\\n`\n );\n return;\n }\n\n writeTerminalMessage(msg, options);\n}\n\nexport function info(msg: string): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`- **info:** ${stripAnsi(msg)}\\n`);\n return;\n }\n if (format === \"json\") {\n process.stdout.write(\n `${JSON.stringify({ level: \"info\", message: stripAnsi(msg) })}\\n`\n );\n return;\n }\n\n message(msg, { symbol: symbols.info });\n}\n\nexport function success(msg: string): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`- **success:** ${stripAnsi(msg)}\\n`);\n return;\n }\n if (format === \"json\") {\n process.stdout.write(\n `${JSON.stringify({ level: \"success\", message: stripAnsi(msg) })}\\n`\n );\n return;\n }\n\n message(msg, { symbol: symbols.success });\n}\n\nexport function warn(msg: string): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`- **warning:** ${stripAnsi(msg)}\\n`);\n return;\n }\n if (format === \"json\") {\n process.stdout.write(\n `${JSON.stringify({ level: \"warn\", message: stripAnsi(msg) })}\\n`\n );\n return;\n }\n\n message(msg, { symbol: color.yellow(\"\u25B2\") });\n}\n\nexport function error(msg: string): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`- **error:** ${stripAnsi(msg)}\\n`);\n return;\n }\n if (format === \"json\") {\n process.stdout.write(\n `${JSON.stringify({ level: \"error\", message: stripAnsi(msg) })}\\n`\n );\n return;\n }\n\n message(msg, { symbol: color.red(\"\u25A0\") });\n}\n\nexport const log = {\n info,\n success,\n message,\n warn,\n error\n};\n", "import { color } from \"./color.js\";\nimport { log } from \"../prompts/primitives/log.js\";\nimport { symbols } from \"./symbols.js\";\n\nexport interface LoggerOutput {\n info(message: string): void;\n success(message: string): void;\n warn(message: string): void;\n error(message: string): void;\n resolved(label: string, value: string): void;\n errorResolved(label: string, value: string): void;\n message(message: string, symbol?: string): void;\n}\n\nexport function createLogger(emitter?: (message: string) => void): LoggerOutput {\n const emit = (\n level: \"info\" | \"success\" | \"warn\" | \"error\",\n message: string\n ): void => {\n if (emitter) {\n emitter(message);\n return;\n }\n if (level === \"success\") {\n log.success(message);\n return;\n }\n if (level === \"warn\") {\n log.warn(message);\n return;\n }\n if (level === \"error\") {\n log.error(message);\n return;\n }\n log.info(message);\n };\n\n return {\n info(message: string): void {\n emit(\"info\", message);\n },\n success(message: string): void {\n emit(\"success\", message);\n },\n warn(message: string): void {\n emit(\"warn\", message);\n },\n error(message: string): void {\n emit(\"error\", message);\n },\n resolved(label: string, value: string): void {\n if (emitter) {\n emitter(`${label}: ${value}`);\n return;\n }\n log.message(`${label}\\n ${value}`, { symbol: symbols.resolved });\n },\n errorResolved(label: string, value: string): void {\n if (emitter) {\n emitter(`${label}: ${value}`);\n return;\n }\n log.message(`${label}\\n ${value}`, { symbol: symbols.errorResolved });\n },\n message(message: string, symbol?: string): void {\n if (emitter) {\n emitter(message);\n return;\n }\n log.message(message, { symbol: symbol ?? color.gray(\"\u2502\") });\n }\n };\n}\n\nexport const logger = createLogger();\n", "import type { ThemePalette } from \"../tokens/colors.js\";\nimport { resolveOutputFormat } from \"../internal/output-format.js\";\nimport { stripAnsi } from \"../internal/strip-ansi.js\";\n\nexport interface TableColumn {\n name: string;\n title: string;\n alignment: \"left\" | \"right\";\n maxLen: number;\n}\n\nexport interface RenderTableOptions {\n theme: ThemePalette;\n columns: TableColumn[];\n rows: Record<string, string>[];\n}\n\ntype TableAlignment = TableColumn[\"alignment\"] | \"center\";\n\ninterface ComputedColumn {\n name: string;\n title: string;\n alignment: TableAlignment;\n width: number;\n}\n\nconst reset = \"\\x1b[0m\";\nconst ellipsis = \"\u2026\";\nconst graphemeSegmenter = new Intl.Segmenter(undefined, { granularity: \"grapheme\" });\n\nfunction isAnsiSequence(value: string, index: number): boolean {\n return value[index] === \"\\u001b\" && value[index + 1] === \"[\";\n}\n\nfunction readAnsiSequence(value: string, index: number): { sequence: string; nextIndex: number } {\n let nextIndex = index + 2;\n while (nextIndex < value.length && value[nextIndex] !== \"m\") {\n nextIndex += 1;\n }\n\n if (nextIndex < value.length) {\n nextIndex += 1;\n }\n\n return { sequence: value.slice(index, nextIndex), nextIndex };\n}\n\nfunction isCombiningCodePoint(codePoint: number): boolean {\n return (\n (codePoint >= 0x0300 && codePoint <= 0x036f) ||\n (codePoint >= 0x1ab0 && codePoint <= 0x1aff) ||\n (codePoint >= 0x1dc0 && codePoint <= 0x1dff) ||\n (codePoint >= 0x20d0 && codePoint <= 0x20ff) ||\n (codePoint >= 0xfe20 && codePoint <= 0xfe2f)\n );\n}\n\nfunction isWideCodePoint(codePoint: number): boolean {\n return (\n (codePoint >= 0x1100 && codePoint <= 0x115f) ||\n codePoint === 0x2329 ||\n codePoint === 0x232a ||\n (codePoint >= 0x2e80 && codePoint <= 0xa4cf && codePoint !== 0x303f) ||\n (codePoint >= 0xac00 && codePoint <= 0xd7a3) ||\n (codePoint >= 0xf900 && codePoint <= 0xfaff) ||\n (codePoint >= 0xfe10 && codePoint <= 0xfe19) ||\n (codePoint >= 0xfe30 && codePoint <= 0xfe6f) ||\n (codePoint >= 0xff00 && codePoint <= 0xff60) ||\n (codePoint >= 0xffe0 && codePoint <= 0xffe6) ||\n (codePoint >= 0x2600 && codePoint <= 0x27bf) ||\n (codePoint >= 0x1f300 && codePoint <= 0x1faff) ||\n (codePoint >= 0x20000 && codePoint <= 0x3fffd)\n );\n}\n\nfunction isEmojiClusterCodePoint(codePoint: number): boolean {\n return (\n (codePoint >= 0x1f1e6 && codePoint <= 0x1f1ff) ||\n (codePoint >= 0x1f300 && codePoint <= 0x1faff) ||\n (codePoint >= 0x2600 && codePoint <= 0x27bf)\n );\n}\n\nfunction codePointWidth(char: string): number {\n const codePoint = char.codePointAt(0) ?? 0;\n\n if (codePoint === 0 || codePoint < 0x20 || (codePoint >= 0x7f && codePoint < 0xa0)) {\n return 0;\n }\n\n if (\n codePoint === 0x200d ||\n (codePoint >= 0xfe00 && codePoint <= 0xfe0f) ||\n isCombiningCodePoint(codePoint)\n ) {\n return 0;\n }\n\n return isWideCodePoint(codePoint) ? 2 : 1;\n}\n\nfunction readPrintableCluster(value: string, index: number): string {\n const nextAnsiIndex = value.indexOf(\"\\u001b[\", index);\n const plainText = value.slice(index, nextAnsiIndex === -1 ? undefined : nextAnsiIndex);\n const firstSegment = graphemeSegmenter.segment(plainText)[Symbol.iterator]().next().value as\n | Intl.SegmentData\n | undefined;\n\n return firstSegment?.segment ?? Array.from(plainText)[0] ?? \"\";\n}\n\nfunction clusterWidth(cluster: string): number {\n const codePoints = Array.from(cluster).map((char) => char.codePointAt(0) ?? 0);\n const isEmojiCluster =\n codePoints.length > 1 &&\n codePoints.some(\n (codePoint) =>\n codePoint === 0x200d ||\n (codePoint >= 0xfe00 && codePoint <= 0xfe0f) ||\n isEmojiClusterCodePoint(codePoint)\n );\n\n if (isEmojiCluster) {\n return 2;\n }\n\n return codePoints.reduce((width, codePoint) => width + codePointWidth(String.fromCodePoint(codePoint)), 0);\n}\n\nfunction displayWidth(value: string): number {\n let width = 0;\n let index = 0;\n\n while (index < value.length) {\n if (isAnsiSequence(value, index)) {\n index = readAnsiSequence(value, index).nextIndex;\n continue;\n }\n\n const cluster = readPrintableCluster(value, index);\n width += clusterWidth(cluster);\n index += cluster.length;\n }\n\n return width;\n}\n\nfunction truncateToWidth(value: string, width: number): string {\n if (displayWidth(value) <= width) {\n return value;\n }\n\n if (width <= 0) {\n return \"\";\n }\n\n const targetWidth = width <= 1 ? 0 : width - displayWidth(ellipsis);\n let output = \"\";\n let currentWidth = 0;\n let index = 0;\n let sawAnsi = false;\n\n while (index < value.length) {\n if (isAnsiSequence(value, index)) {\n const ansi = readAnsiSequence(value, index);\n sawAnsi = true;\n output += ansi.sequence;\n index = ansi.nextIndex;\n continue;\n }\n\n const cluster = readPrintableCluster(value, index);\n const width = clusterWidth(cluster);\n if (currentWidth + width > targetWidth) {\n break;\n }\n\n output += cluster;\n currentWidth += width;\n index += cluster.length;\n }\n\n return `${output}${ellipsis}${sawAnsi ? reset : \"\"}`;\n}\n\nfunction padCell(value: string, width: number, alignment: TableAlignment): string {\n const visibleWidth = displayWidth(value);\n const padding = Math.max(0, width - visibleWidth);\n\n if (alignment === \"right\") {\n return `${\" \".repeat(padding)}${value}`;\n }\n\n if (alignment === \"center\") {\n const left = Math.floor(padding / 2);\n const right = padding - left;\n return `${\" \".repeat(left)}${value}${\" \".repeat(right)}`;\n }\n\n return `${value}${\" \".repeat(padding)}`;\n}\n\nfunction getAlignment(column: TableColumn): TableAlignment {\n const alignment = (column as { alignment: TableAlignment }).alignment;\n return alignment === \"right\" || alignment === \"center\" ? alignment : \"left\";\n}\n\nfunction getColumnWidth(column: TableColumn): number {\n const configuredMin = (column as { minLen?: number }).minLen;\n const minWidth = Math.max(1, configuredMin ?? 1);\n return Math.max(minWidth, column.maxLen);\n}\n\nfunction computeColumns(columns: TableColumn[]): ComputedColumn[] {\n return columns.map((column) => ({\n name: column.name,\n title: column.title,\n alignment: getAlignment(column),\n width: getColumnWidth(column)\n }));\n}\n\nfunction renderBorder(\n columns: ComputedColumn[],\n theme: ThemePalette,\n parts: { left: string; mid: string; right: string }\n): string {\n const horizontal = theme.muted(\"\u2500\");\n const segments = columns.map((column) => horizontal.repeat(column.width + 2));\n return [\n theme.muted(parts.left),\n segments.join(theme.muted(parts.mid)),\n theme.muted(parts.right)\n ].join(\"\");\n}\n\nfunction renderTerminalRow(values: string[], columns: ComputedColumn[], theme: ThemePalette): string {\n const vertical = theme.muted(\"\u2502\");\n const cells = values.map((value, index) => {\n const column = columns[index]!;\n const truncated = truncateToWidth(value, column.width);\n return ` ${padCell(truncated, column.width, column.alignment)} `;\n });\n\n return `${vertical}${cells.join(vertical)}${vertical}`;\n}\n\nfunction renderTableTerminal(options: RenderTableOptions): string {\n const { theme, columns, rows } = options;\n const computedColumns = computeColumns(columns);\n const separatorOptions = options as { rowSeparator?: boolean; rowSeparators?: boolean };\n const includeRowSeparators =\n separatorOptions.rowSeparator === true || separatorOptions.rowSeparators === true;\n\n const top = renderBorder(computedColumns, theme, { left: \"\u250C\", mid: \"\u252C\", right: \"\u2510\" });\n const header = renderTerminalRow(\n computedColumns.map((column) => theme.header(column.title)),\n computedColumns,\n theme\n );\n const headerBottom = renderBorder(computedColumns, theme, { left: \"\u251C\", mid: \"\u253C\", right: \"\u2524\" });\n const bottom = renderBorder(computedColumns, theme, { left: \"\u2514\", mid: \"\u2534\", right: \"\u2518\" });\n\n const renderedRows: string[] = [];\n for (const [index, row] of rows.entries()) {\n if (includeRowSeparators && index > 0) {\n renderedRows.push(headerBottom);\n }\n renderedRows.push(\n renderTerminalRow(\n computedColumns.map((column) => row[column.name] ?? \"\"),\n computedColumns,\n theme\n )\n );\n }\n\n return [top, header, headerBottom, ...renderedRows, bottom].join(\"\\n\");\n}\n\nfunction renderTableMarkdown(options: RenderTableOptions): string {\n const { columns, rows } = options;\n\n const header = `| ${columns.map((c) => c.title).join(\" | \")} |`;\n const separator = `| ${columns\n .map((c) => {\n const alignment = getAlignment(c);\n if (alignment === \"right\") {\n return \"---:\";\n }\n if (alignment === \"center\") {\n return \":---:\";\n }\n return \":---\";\n })\n .join(\" | \")} |`;\n\n const dataRows = rows.map(\n (row) =>\n `| ${columns.map((c) => stripAnsi(row[c.name] ?? \"\").replace(/\\|/g, \"\\\\|\")).join(\" | \")} |`\n );\n\n return [header, separator, ...dataRows].join(\"\\n\");\n}\n\nfunction renderTableJson(options: RenderTableOptions): string {\n const { columns, rows } = options;\n\n const cleaned = rows.map((row) => {\n const obj: Record<string, string> = {};\n for (const col of columns) {\n obj[col.name] = stripAnsi(row[col.name] ?? \"\");\n }\n return obj;\n });\n\n return JSON.stringify(cleaned, null, 2);\n}\n\nexport function renderTable(options: RenderTableOptions): string {\n const format = resolveOutputFormat();\n switch (format) {\n case \"markdown\":\n return renderTableMarkdown(options);\n case \"json\":\n return renderTableJson(options);\n default:\n return renderTableTerminal(options);\n }\n}\n", "export type TemplateEscape = \"html\" | \"none\";\n\nexport interface RenderTemplateOptions {\n escape?: TemplateEscape;\n yield?: string;\n}\n\ntype Token =\n | { type: \"text\"; value: string; start: number }\n | { type: \"name\" | \"unescaped\"; name: string; raw: string }\n | { type: \"section\" | \"inverted\"; name: string; children: Token[]; rawStart: number; rawEnd: number };\n\ninterface SectionFrame {\n token: Extract<Token, { type: \"section\" | \"inverted\" }>;\n parent: Token[];\n}\n\ninterface Context {\n view: unknown;\n parent?: Context;\n}\n\ntype Lambda = (...args: unknown[]) => unknown;\n\nconst HTML_ESCAPE: Record<string, string> = {\n \"&\": \"&amp;\",\n \"<\": \"&lt;\",\n \">\": \"&gt;\",\n '\"': \"&quot;\",\n \"'\": \"&#39;\",\n \"/\": \"&#x2F;\",\n \"`\": \"&#x60;\",\n \"=\": \"&#x3D;\"\n};\n\nexport function renderTemplate(\n template: string,\n view: Record<string, unknown>,\n options: RenderTemplateOptions = {}\n): string {\n const prepared = options.yield === undefined\n ? template\n : template.split(\"{{yield}}\").join(options.yield);\n const tokens = parseTemplate(prepared);\n const escape = options.escape === \"none\" ? String : escapeHtml;\n const preserveMissing = options.yield !== undefined && options.escape === \"none\";\n\n return renderTokens(tokens, { view }, prepared, escape, preserveMissing);\n}\n\nfunction renderTemplateInContext(\n template: string,\n context: Context,\n escape: (value: string) => string,\n preserveMissing: boolean\n): string {\n return renderTokens(parseTemplate(template), context, template, escape, preserveMissing);\n}\n\nfunction parseTemplate(template: string): Token[] {\n const root: Token[] = [];\n const stack: SectionFrame[] = [];\n let tokens = root;\n let index = 0;\n\n while (index < template.length) {\n const open = template.indexOf(\"{{\", index);\n if (open === -1) {\n appendText(tokens, template.slice(index), index);\n break;\n }\n\n appendText(tokens, template.slice(index, open), index);\n\n const parsed = parseTag(template, open);\n const standalone = getStandalone(template, open, parsed.end, parsed.kind);\n if (standalone !== undefined) {\n trimTextAfter(tokens, standalone.lineStart);\n }\n\n if (parsed.kind === \"comment\") {\n index = standalone?.nextIndex ?? parsed.end;\n continue;\n }\n\n if (parsed.kind === \"partial\") {\n throw new Error(`Partials are not supported: \"${parsed.name}\"`);\n }\n\n if (parsed.kind === \"delimiter\") {\n throw new Error(\"Custom delimiters are not supported\");\n }\n\n if (parsed.kind === \"section\" || parsed.kind === \"inverted\") {\n const token: Token = {\n type: parsed.kind,\n name: parsed.name,\n children: [],\n rawStart: parsed.end,\n rawEnd: standalone?.lineStart ?? open\n };\n tokens.push(token);\n stack.push({ token, parent: tokens });\n tokens = token.children;\n index = standalone?.nextIndex ?? parsed.end;\n continue;\n }\n\n if (parsed.kind === \"close\") {\n const frame = stack.pop();\n if (frame === undefined) {\n throw new Error(`Closing unopened section \"${parsed.name}\"`);\n }\n if (frame.token.name !== parsed.name) {\n throw new Error(`Unclosed section \"${frame.token.name}\" before closing \"${parsed.name}\"`);\n }\n frame.token.rawEnd = open;\n tokens = frame.parent;\n index = standalone?.nextIndex ?? parsed.end;\n continue;\n }\n\n tokens.push({ type: parsed.kind, name: parsed.name, raw: template.slice(open, parsed.end) });\n index = parsed.end;\n }\n\n const frame = stack.pop();\n if (frame !== undefined) {\n throw new Error(`Unclosed section \"${frame.token.name}\"`);\n }\n\n return root;\n}\n\nfunction parseTag(template: string, open: number): {\n kind: \"name\" | \"unescaped\" | \"section\" | \"inverted\" | \"close\" | \"comment\" | \"partial\" | \"delimiter\";\n name: string;\n end: number;\n} {\n if (template.startsWith(\"{{{\", open)) {\n const close = template.indexOf(\"}}}\", open + 3);\n if (close === -1) {\n throw new Error(\"Unclosed unescaped tag\");\n }\n return { kind: \"unescaped\", name: template.slice(open + 3, close).trim(), end: close + 3 };\n }\n\n const close = template.indexOf(\"}}\", open + 2);\n if (close === -1) {\n throw new Error(\"Unclosed tag\");\n }\n\n const raw = template.slice(open + 2, close).trim();\n const sigil = raw[0];\n const name = sigil === undefined ? \"\" : raw.slice(1).trim();\n const end = close + 2;\n\n if (sigil === \"#\") return { kind: \"section\", name, end };\n if (sigil === \"^\") return { kind: \"inverted\", name, end };\n if (sigil === \"/\") return { kind: \"close\", name, end };\n if (sigil === \"!\") return { kind: \"comment\", name, end };\n if (sigil === \"&\") return { kind: \"unescaped\", name, end };\n if (sigil === \">\") return { kind: \"partial\", name, end };\n if (sigil === \"=\" && raw.endsWith(\"=\")) return { kind: \"delimiter\", name, end };\n\n return { kind: \"name\", name: raw, end };\n}\n\nfunction getStandalone(\n template: string,\n tagStart: number,\n tagEnd: number,\n kind: ReturnType<typeof parseTag>[\"kind\"]\n): { lineStart: number; nextIndex: number } | undefined {\n if (![\"section\", \"inverted\", \"close\", \"comment\", \"partial\", \"delimiter\"].includes(kind)) {\n return undefined;\n }\n\n const lineStart = template.lastIndexOf(\"\\n\", tagStart - 1) + 1;\n if (!isWhitespace(template.slice(lineStart, tagStart))) {\n return undefined;\n }\n\n let cursor = tagEnd;\n while (cursor < template.length && (template[cursor] === \" \" || template[cursor] === \"\\t\")) {\n cursor += 1;\n }\n\n if (template.startsWith(\"\\r\\n\", cursor)) {\n return { lineStart, nextIndex: cursor + 2 };\n }\n\n if (template[cursor] === \"\\n\") {\n return { lineStart, nextIndex: cursor + 1 };\n }\n\n if (cursor === template.length) {\n return { lineStart, nextIndex: cursor };\n }\n\n return undefined;\n}\n\nfunction renderTokens(\n tokens: Token[],\n context: Context,\n template: string,\n escape: (value: string) => string,\n preserveMissing: boolean\n): string {\n let output = \"\";\n\n for (const token of tokens) {\n switch (token.type) {\n case \"text\":\n output += token.value;\n continue;\n\n case \"name\":\n case \"unescaped\": {\n const value = lookup(context, token.name);\n if (value == null) {\n if (preserveMissing) {\n output += token.raw;\n }\n continue;\n }\n const rendered = String(value);\n output += token.type === \"name\" ? escape(rendered) : rendered;\n continue;\n }\n\n case \"inverted\": {\n const value = lookup(context, token.name);\n if (!value || (Array.isArray(value) && value.length === 0)) {\n output += renderTokens(token.children, context, template, escape, preserveMissing);\n }\n continue;\n }\n\n case \"section\": {\n const value = lookup(context, token.name);\n if (!value) {\n continue;\n }\n\n if (Array.isArray(value)) {\n for (const item of value) {\n output += renderTokens(token.children, pushContext(context, item), template, escape, preserveMissing);\n }\n continue;\n }\n\n if (typeof value === \"function\") {\n const raw = template.slice(token.rawStart, token.rawEnd);\n const rendered = (value as Lambda).call(context.view, raw, (nextTemplate: string) =>\n renderTemplateInContext(nextTemplate, context, escape, preserveMissing)\n );\n if (rendered != null) {\n output += String(rendered);\n }\n continue;\n }\n\n if (typeof value === \"object\" || typeof value === \"string\" || typeof value === \"number\") {\n output += renderTokens(token.children, pushContext(context, value), template, escape, preserveMissing);\n continue;\n }\n\n output += renderTokens(token.children, context, template, escape, preserveMissing);\n }\n }\n }\n\n return output;\n}\n\nfunction lookup(context: Context, name: string): unknown {\n if (name === \".\") {\n return callLambda(context.view, context.view);\n }\n\n let cursor: Context | undefined = context;\n while (cursor !== undefined) {\n const result = name.includes(\".\")\n ? lookupDotted(cursor.view, name)\n : lookupName(cursor.view, name);\n\n if (result.hit) {\n return callLambda(result.value, cursor.view);\n }\n\n cursor = cursor.parent;\n }\n\n return undefined;\n}\n\nfunction lookupName(view: unknown, name: string): { hit: boolean; value: unknown } {\n if (!isPropertyContainer(view) || !hasProperty(view, name)) {\n return { hit: false, value: undefined };\n }\n\n return { hit: true, value: view[name] };\n}\n\nfunction lookupDotted(view: unknown, name: string): { hit: boolean; value: unknown } {\n const parts = name.split(\".\");\n let value = view;\n let hit = false;\n\n for (let index = 0; value != null && index < parts.length; index += 1) {\n const part = parts[index] ?? \"\";\n if (index === parts.length - 1) {\n hit = hasProperty(Object(value), part);\n }\n value = Object(value)[part as keyof typeof value];\n }\n\n return { hit, value };\n}\n\nfunction callLambda(value: unknown, view: unknown): unknown {\n return typeof value === \"function\" ? (value as Lambda).call(view) : value;\n}\n\nfunction pushContext(parent: Context, view: unknown): Context {\n return { view, parent };\n}\n\nfunction appendText(tokens: Token[], value: string, start: number): void {\n if (value === \"\") {\n return;\n }\n\n const previous = tokens[tokens.length - 1];\n if (previous?.type === \"text\") {\n previous.value += value;\n return;\n }\n\n tokens.push({ type: \"text\", value, start });\n}\n\nfunction trimTextAfter(tokens: Token[], lineStart: number): void {\n const previous = tokens[tokens.length - 1];\n if (previous?.type !== \"text\") {\n return;\n }\n\n const keep = Math.max(0, lineStart - previous.start);\n previous.value = previous.value.slice(0, keep);\n if (previous.value === \"\") {\n tokens.pop();\n }\n}\n\nfunction escapeHtml(value: string): string {\n return value.replace(/[&<>\"'`=/]/g, (char) => HTML_ESCAPE[char] ?? char);\n}\n\nfunction isWhitespace(value: string): boolean {\n return value.trim() === \"\";\n}\n\nfunction isPropertyContainer(value: unknown): value is Record<string, unknown> {\n return (typeof value === \"object\" && value !== null) || typeof value === \"function\";\n}\n\nfunction hasProperty(value: object, key: string): boolean {\n return key in value;\n}\n", "import { spawn } from \"node:child_process\";\nimport process from \"node:process\";\n\ninterface BrowserProcess {\n once(event: \"error\", listener: (error: Error) => void): this;\n once(event: \"spawn\", listener: () => void): this;\n unref(): void;\n}\n\ntype SpawnBrowserProcess = (\n command: string,\n args: string[],\n options: { detached: true; stdio: \"ignore\" }\n) => BrowserProcess;\n\nexport interface OpenExternalOptions {\n platform?: NodeJS.Platform;\n spawnProcess?: SpawnBrowserProcess;\n}\n\nexport async function openExternal(url: string, options: OpenExternalOptions = {}): Promise<void> {\n const parsed = new URL(url);\n const { command, args } = browserCommand(parsed.href, options.platform ?? process.platform);\n await launchBrowser(command, args, options.spawnProcess ?? spawn);\n}\n\nfunction browserCommand(url: string, platform: NodeJS.Platform): { command: string; args: string[] } {\n if (platform === \"darwin\") {\n return { command: \"open\", args: [url] };\n }\n\n if (platform === \"win32\") {\n return { command: \"cmd\", args: [\"/c\", \"start\", \"\", url] };\n }\n\n return { command: \"xdg-open\", args: [url] };\n}\n\nfunction launchBrowser(\n command: string,\n args: string[],\n spawnProcess: SpawnBrowserProcess\n): Promise<void> {\n return new Promise((resolve, reject) => {\n const child = spawnProcess(command, args, { detached: true, stdio: \"ignore\" });\n\n child.once(\"error\", reject);\n child.once(\"spawn\", () => {\n child.unref();\n resolve();\n });\n });\n}\n", "import { AsyncLocalStorage } from \"node:async_hooks\";\n\nexport type AcpLineWriter = (line: string) => void;\n\nconst storage = new AsyncLocalStorage<AcpLineWriter>();\n\nconst defaultWriter: AcpLineWriter = (line) => {\n process.stdout.write(`${line}\\n`);\n};\n\n/**\n * Return the writer active in the current async context, or the default\n * stdout writer if none is bound.\n */\nexport function getAcpWriter(): AcpLineWriter {\n return storage.getStore() ?? defaultWriter;\n}\n\n/**\n * Run `fn` with `writer` bound as the active ACP line writer. All calls to\n * `renderAgentMessage`, `renderToolStart`, `renderAcpEvent`, etc. made inside\n * `fn` (or async work awaited from `fn`) will go through `writer` instead of\n * writing to `process.stdout`.\n */\nexport function withAcpWriter<T>(writer: AcpLineWriter, fn: () => Promise<T>): Promise<T> {\n return storage.run(writer, fn);\n}\n", "import readline from \"node:readline\";\nimport { PassThrough } from \"node:stream\";\nimport { cellToAnsi } from \"./buffer.js\";\nimport type { Cell } from \"./types.js\";\n\nexport type KeypressEvent = {\n name?: string;\n ch?: string;\n ctrl: boolean;\n meta: boolean;\n shift: boolean;\n};\n\nexport type TerminalDriver = {\n enterRawMode(): void;\n exitRawMode(): void;\n enterAltScreen(): void;\n exitAltScreen(): void;\n disableLineWrap(): void;\n enableLineWrap(): void;\n hideCursor(): void;\n showCursor(): void;\n moveTo(x: number, y: number): void;\n write(text: string): void;\n flush(changes: Array<{ x: number; y: number; cell: Cell }>): void;\n getSize(): { cols: number; rows: number };\n onResize(handler: () => void): () => void;\n onKeypress(handler: (key: KeypressEvent) => void): () => void;\n destroy(): void;\n};\n\ntype ReadlineKey = {\n sequence?: string;\n name?: string;\n ctrl?: boolean;\n meta?: boolean;\n shift?: boolean;\n};\n\ntype KeypressInput = NodeJS.ReadableStream & {\n on(event: \"keypress\", listener: (str: string | undefined, key: ReadlineKey) => void): KeypressInput;\n off(event: \"keypress\", listener: (str: string | undefined, key: ReadlineKey) => void): KeypressInput;\n};\n\ntype TerminalInput = NodeJS.ReadStream & KeypressInput & {\n setRawMode?: (mode: boolean) => void;\n};\n\ntype TerminalOutput = NodeJS.WriteStream & {\n columns?: number;\n rows?: number;\n on(event: \"resize\", listener: () => void): TerminalOutput;\n off(event: \"resize\", listener: () => void): TerminalOutput;\n};\n\nexport function createTerminalDriver(opts?: {\n stdin?: NodeJS.ReadStream;\n stdout?: NodeJS.WriteStream;\n}): TerminalDriver {\n const stdin = (opts?.stdin ?? process.stdin) as TerminalInput;\n const stdout = (opts?.stdout ?? process.stdout) as TerminalOutput;\n const resizeListeners = new Set<() => void>();\n const keypressListeners = new Set<(str: string | undefined, key: ReadlineKey) => void>();\n let rawMode = false;\n let altScreen = false;\n let lineWrapEnabled = true;\n let cursorHidden = false;\n let destroyed = false;\n\n readline.emitKeypressEvents(stdin);\n\n function enterRawMode(): void {\n if (destroyed || rawMode) {\n return;\n }\n\n stdin.setRawMode?.(true);\n stdin.resume();\n rawMode = true;\n }\n\n function exitRawMode(): void {\n if (destroyed || !rawMode) {\n return;\n }\n\n stdin.setRawMode?.(false);\n stdin.pause();\n rawMode = false;\n }\n\n function enterAltScreen(): void {\n if (destroyed || altScreen) {\n return;\n }\n\n write(\"\\u001b[?1049h\");\n altScreen = true;\n }\n\n function exitAltScreen(): void {\n if (destroyed || !altScreen) {\n return;\n }\n\n write(\"\\u001b[?1049l\");\n altScreen = false;\n }\n\n function disableLineWrap(): void {\n if (destroyed || !lineWrapEnabled) {\n return;\n }\n\n write(\"\\u001b[?7l\");\n lineWrapEnabled = false;\n }\n\n function enableLineWrap(): void {\n if (destroyed || lineWrapEnabled) {\n return;\n }\n\n write(\"\\u001b[?7h\");\n lineWrapEnabled = true;\n }\n\n function hideCursor(): void {\n if (destroyed || cursorHidden) {\n return;\n }\n\n write(\"\\u001b[?25l\");\n cursorHidden = true;\n }\n\n function showCursor(): void {\n if (destroyed || !cursorHidden) {\n return;\n }\n\n write(\"\\u001b[?25h\");\n cursorHidden = false;\n }\n\n function moveTo(x: number, y: number): void {\n if (destroyed) {\n return;\n }\n\n write(cursorPositionAnsi(x, y));\n }\n\n function write(text: string): void {\n if (destroyed || text.length === 0) {\n return;\n }\n\n stdout.write(text);\n }\n\n function flush(changes: Array<{ x: number; y: number; cell: Cell }>): void {\n if (destroyed || changes.length === 0) {\n return;\n }\n\n let output = \"\";\n\n for (const change of changes) {\n output += `${cursorPositionAnsi(change.x, change.y)}${cellToAnsi(change.cell)}`;\n }\n\n write(output);\n }\n\n function getSize(): { cols: number; rows: number } {\n return {\n cols: normalizeSize(stdout.columns),\n rows: normalizeSize(stdout.rows)\n };\n }\n\n function onResize(handler: () => void): () => void {\n if (destroyed) {\n return () => {};\n }\n\n const listener = () => {\n handler();\n };\n\n resizeListeners.add(listener);\n stdout.on(\"resize\", listener);\n\n return () => {\n if (!resizeListeners.delete(listener)) {\n return;\n }\n\n stdout.off(\"resize\", listener);\n };\n }\n\n function onKeypress(handler: (key: KeypressEvent) => void): () => void {\n if (destroyed) {\n return () => {};\n }\n\n const listener = (str: string | undefined, key: ReadlineKey) => {\n const event = toKeypressEvent(str, key);\n if (event !== undefined) {\n handler(event);\n }\n };\n\n keypressListeners.add(listener);\n stdin.on(\"keypress\", listener);\n\n return () => {\n if (!keypressListeners.delete(listener)) {\n return;\n }\n\n stdin.off(\"keypress\", listener);\n };\n }\n\n function destroy(): void {\n if (destroyed) {\n return;\n }\n\n for (const listener of keypressListeners) {\n stdin.off(\"keypress\", listener);\n }\n keypressListeners.clear();\n\n for (const listener of resizeListeners) {\n stdout.off(\"resize\", listener);\n }\n resizeListeners.clear();\n\n exitRawMode();\n enableLineWrap();\n exitAltScreen();\n showCursor();\n destroyed = true;\n }\n\n return {\n enterRawMode,\n exitRawMode,\n enterAltScreen,\n exitAltScreen,\n disableLineWrap,\n enableLineWrap,\n hideCursor,\n showCursor,\n moveTo,\n write,\n flush,\n getSize,\n onResize,\n onKeypress,\n destroy\n };\n}\n\nexport function parseKeypress(data: Buffer): KeypressEvent | undefined {\n if (data.length === 0) {\n return undefined;\n }\n\n const stream = new PassThrough();\n const stdin = stream as unknown as KeypressInput;\n let event: KeypressEvent | undefined;\n\n readline.emitKeypressEvents(stdin);\n stdin.on(\"keypress\", (str, key) => {\n event = toKeypressEvent(str, key);\n });\n stream.emit(\"data\", data);\n stream.destroy();\n\n return event;\n}\n\nfunction toKeypressEvent(str: string | undefined, key: ReadlineKey | undefined): KeypressEvent | undefined {\n const controlCharacter = controlCharacterToKeypress(key?.sequence);\n if (controlCharacter !== undefined) {\n return controlCharacter;\n }\n\n const ctrl = key?.ctrl ?? false;\n const meta = key?.meta ?? false;\n const shift = key?.shift ?? false;\n const ch = extractPrintableCharacter(str, key?.sequence);\n\n if (ch !== undefined) {\n return { ch, ctrl, meta, shift };\n }\n\n if (key?.name === undefined) {\n return undefined;\n }\n\n return {\n name: key.name,\n ctrl,\n meta,\n shift\n };\n}\n\nfunction extractPrintableCharacter(str: string | undefined, sequence: string | undefined): string | undefined {\n if (isPrintableCharacter(str)) {\n return str;\n }\n\n if (isSinglePrintableSequence(sequence)) {\n return sequence;\n }\n\n if (sequence === undefined || sequence.length <= 1 || sequence[0] !== \"\\u001b\") {\n return undefined;\n }\n\n const candidate = sequence.slice(1);\n return isPrintableCharacter(candidate) ? candidate : undefined;\n}\n\nfunction isSinglePrintableSequence(value: string | undefined): boolean {\n if (value === undefined || Array.from(value).length !== 1) {\n return false;\n }\n\n const codePoint = value.codePointAt(0);\n return codePoint !== undefined && codePoint >= 0x20 && codePoint !== 0x7f;\n}\n\nfunction isPrintableCharacter(value: string | undefined): value is string {\n if (value === undefined || Array.from(value).length !== 1) {\n return false;\n }\n\n const codePoint = value.codePointAt(0);\n return codePoint !== undefined && codePoint >= 0x20 && codePoint !== 0x7f;\n}\n\nfunction controlCharacterToKeypress(sequence: string | undefined): KeypressEvent | undefined {\n if (sequence === \"\\u001f\") {\n return { ch: \"/\", ctrl: true, meta: false, shift: false };\n }\n\n if (sequence !== undefined && sequence.length === 1) {\n const code = sequence.charCodeAt(0);\n if (code >= 1 && code <= 26 && code !== 9 && code !== 10 && code !== 13) {\n return {\n name: String.fromCharCode(code + 96),\n ctrl: true,\n meta: false,\n shift: false\n };\n }\n }\n\n return undefined;\n}\n\nfunction cursorPositionAnsi(x: number, y: number): string {\n return `\\u001b[${normalizeCoordinate(y) + 1};${normalizeCoordinate(x) + 1}H`;\n}\n\nfunction normalizeCoordinate(value: number): number {\n return Math.max(0, Math.floor(value));\n}\n\nfunction normalizeSize(value: number | undefined): number {\n if (value === undefined || !Number.isFinite(value)) {\n return 0;\n }\n\n return Math.max(0, Math.floor(value));\n}\n", "import { resolveBindings, type ResolvedBindings } from \"./keymap.js\";\n\nexport type Tone = \"success\" | \"warning\" | \"error\" | \"info\" | \"muted\";\n\nexport interface Row {\n id: string;\n title: string;\n subtitle?: string;\n badge?: { text: string; tone?: Tone };\n group?: string; // grouped rendering; rows with same group cluster under a header\n}\n\nexport interface DetailItem {\n id: string;\n title?: string; // absent => item fills pane with no cursor / no selection chrome\n subtitle?: string;\n badge?: { text: string; tone?: Tone };\n render: (ctx: DetailCtx) => string | Promise<string>;\n}\n\nexport interface Detail<R> {\n items: (row: Row, ctx: DetailCtx) => Promise<DetailItem[]>;\n actions?: Action<R>[]; // run against the focused detail item\n}\n\nexport interface DetailCtx { width: number; height: number; signal: AbortSignal; row: Row }\n\nexport interface Action<R> {\n id: string;\n label: string | (() => string); // function form re-evaluated when state changes\n key?: string | string[];\n predicate?: (ctx: ActionContext<R>) => boolean;\n handler: (ctx: ActionContext<R>) => void | Promise<void>;\n destructive?: boolean;\n primary?: boolean; // bound to Enter\n showInFooter?: boolean; // default true\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport interface ActionContext<R> {\n row: Row; // currently highlighted left-pane row\n rows: Row[]; // multi-select; falls back to [row] if no selection\n item?: DetailItem; // populated for actions declared under detail.actions\n filter: string;\n refresh: () => Promise<void>;\n suspendAnd: <T>(fn: () => Promise<T>) => Promise<T>;\n toast: (msg: string, tone?: Tone) => void;\n confirm: (prompt: string) => Promise<boolean>;\n exit: (after?: () => void | Promise<void>) => void;\n}\n\nexport interface ReorderContext {\n refresh: () => Promise<void>;\n toast: (msg: string, tone?: Tone) => void;\n}\n\nexport interface ExplorerConfig<R> {\n title: string;\n rows: () => Promise<Row[]>;\n refresh?: () => Promise<void>;\n detail: Detail<R>;\n actions: Action<R>[];\n reorder?: { onReorder: (orderedIds: string[], ctx?: ReorderContext) => void | Promise<void> };\n multiSelect?: boolean;\n keybindOverrides?: Record<string, string | string[]>;\n emptyHint?: string;\n initialFilter?: string;\n}\n\nexport const REGION_HEADER = 1 << 0;\nexport const REGION_LIST = 1 << 1;\nexport const REGION_DETAIL = 1 << 2;\nexport const REGION_FOOTER = 1 << 3;\nexport const REGION_MODAL = 1 << 4;\nexport const REGION_TOAST = 1 << 5;\nexport const REGION_ALL =\n REGION_HEADER |\n REGION_LIST |\n REGION_DETAIL |\n REGION_FOOTER |\n REGION_MODAL |\n REGION_TOAST;\n\nexport type Dirty = number;\n\nexport type ExplorerLayoutMode =\n | \"wide\"\n | \"medium\"\n | \"narrow-vertical\"\n | \"narrow-list-only\"\n | \"too-narrow\";\n\nexport interface ExplorerSize {\n cols: number;\n rows: number;\n}\n\nexport interface ExplorerState {\n title: string;\n emptyHint: string;\n rows: Row[];\n filtered: number[];\n matchPositions: Map<number, number[]>;\n cursor: number;\n filter: string;\n filterFocused: boolean;\n focused: \"list\" | \"detail\";\n detail: {\n rowId: string | null;\n items: DetailItem[] | null;\n cursor: number;\n scroll: number;\n token: number;\n loading: boolean;\n };\n selected: Set<string>;\n modal:\n | null\n | { kind: \"help\" }\n | { kind: \"confirm\"; action: Action<unknown>; rows: Row[]; resolver: (ok: boolean) => void }\n | { kind: \"palette\"; query: string; cursor: number };\n toast: { message: string; tone: Tone; expiresAt: number } | null;\n dirty: Dirty;\n size: ExplorerSize;\n layout: ExplorerLayoutMode;\n bindings: ResolvedBindings;\n actionState: Map<string, ActionStateEntry>;\n}\n\nexport interface ActionStateEntry {\n available: boolean;\n label: string;\n running?: boolean;\n action?: Action<unknown>;\n source?: \"row\" | \"detail\";\n}\n\nexport function createInitialState<R>(\n config: ExplorerConfig<R>,\n size: ExplorerSize\n): ExplorerState {\n const normalizedSize = {\n cols: normalizeSize(size.cols),\n rows: normalizeSize(size.rows)\n };\n\n return {\n title: config.title,\n emptyHint: config.emptyHint ?? \"No detail\",\n rows: [],\n filtered: [],\n matchPositions: new Map(),\n cursor: 0,\n filter: config.initialFilter ?? \"\",\n filterFocused: false,\n focused: \"list\",\n detail: {\n rowId: null,\n items: null,\n cursor: 0,\n scroll: 0,\n token: 0,\n loading: false\n },\n selected: new Set(),\n modal: null,\n toast: null,\n dirty: REGION_ALL,\n size: normalizedSize,\n layout: resolveExplorerLayoutMode(normalizedSize.cols),\n bindings: resolveBindings(config),\n actionState: createInitialActionState(config)\n };\n}\n\nfunction createInitialActionState<R>(\n config: ExplorerConfig<R>\n): Map<string, ActionStateEntry> {\n const state = new Map<string, ActionStateEntry>();\n\n for (const action of config.actions) {\n state.set(action.id, {\n available: true,\n label: typeof action.label === \"function\" ? action.id : action.label,\n action: action as Action<unknown>,\n source: \"row\"\n });\n }\n\n for (const action of config.detail.actions ?? []) {\n state.set(action.id, {\n available: true,\n label: typeof action.label === \"function\" ? action.id : action.label,\n action: action as Action<unknown>,\n source: \"detail\"\n });\n }\n\n return state;\n}\n\nexport function resolveExplorerLayoutMode(cols: number): ExplorerLayoutMode {\n if (cols < 40) {\n return \"too-narrow\";\n }\n\n if (cols < 80) {\n return \"narrow-list-only\";\n }\n\n if (cols < 100) {\n return \"narrow-vertical\";\n }\n\n if (cols < 120) {\n return \"medium\";\n }\n\n return \"wide\";\n}\n\nfunction normalizeSize(value: number): number {\n if (!Number.isFinite(value)) {\n return 0;\n }\n\n return Math.max(0, Math.floor(value));\n}\n", "import { color } from \"../components/color.js\";\nimport * as clack from \"@clack/prompts\";\nimport { resolveOutputFormat } from \"../internal/output-format.js\";\nimport { stripAnsi } from \"../internal/strip-ansi.js\";\nimport { cancel, isCancel } from \"./primitives/cancel.js\";\nimport { intro } from \"./primitives/intro.js\";\nimport { log } from \"./primitives/log.js\";\nimport { note } from \"./primitives/note.js\";\nimport { outro } from \"./primitives/outro.js\";\nimport { spinner } from \"./primitives/spinner.js\";\n\nexport { isCancel, cancel, log };\nexport { intro, outro, note, spinner };\n\nexport function introPlain(title: string): void {\n const format = resolveOutputFormat();\n if (format === \"markdown\") {\n process.stdout.write(`# ${stripAnsi(title)}\\n\\n`);\n return;\n }\n if (format === \"json\") {\n return;\n }\n process.stdout.write(`${color.gray(\"\u250C\")} ${title}\\n`);\n}\n\nexport interface SelectOptions<Value> {\n message: string;\n options: Array<{ value: Value; label: string; hint?: string }>;\n initialValue?: Value;\n}\n\nexport async function select<Value>(opts: SelectOptions<Value>): Promise<Value | symbol> {\n return clack.select(opts as Parameters<typeof clack.select<Value>>[0]);\n}\n\nexport type MultiselectOptions<Value> = Parameters<typeof clack.multiselect<Value>>[0];\n\n/**\n * Prompts the user to select one or more values from a list.\n *\n * Returns the selected values as an array, or a cancellation symbol if the\n * user cancels. Use `isCancel` to check for cancellation.\n *\n * @example\n * const result = await multiselect({\n * message: \"Pick workflows to run\",\n * options: [{ label: \"Fix Vulnerabilities\", value: \"fix-vulnerabilities\" }],\n * required: true\n * });\n * if (!isCancel(result)) {\n * // result is Value[]\n * }\n */\nexport async function multiselect<Value>(\n opts: MultiselectOptions<Value>\n): Promise<Value[] | symbol> {\n return clack.multiselect(opts);\n}\n\nexport type TextOptions = Parameters<typeof clack.text>[0];\n\nexport async function text(opts: TextOptions): Promise<string | symbol> {\n return clack.text(opts as Parameters<typeof clack.text>[0]);\n}\n\nexport interface ConfirmOptions {\n message: string;\n initialValue?: boolean;\n}\n\nexport async function confirm(opts: ConfirmOptions): Promise<boolean | symbol> {\n return clack.confirm(opts as Parameters<typeof clack.confirm>[0]);\n}\n\nexport class PromptCancelledError extends Error {\n constructor(message = \"Operation cancelled.\") {\n super(message);\n this.name = \"PromptCancelledError\";\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, this.constructor);\n }\n }\n}\n\nexport async function confirmOrCancel(opts: ConfirmOptions): Promise<boolean> {\n const result = await confirm(opts);\n if (isCancel(result)) {\n cancel(\"Operation cancelled.\");\n throw new PromptCancelledError();\n }\n return result === true;\n}\n\nexport interface PasswordOptions {\n message: string;\n validate?: (value: string) => string | undefined;\n}\n\nexport async function password(opts: PasswordOptions): Promise<string | symbol> {\n return clack.password(opts as Parameters<typeof clack.password>[0]);\n}\n\nexport type SpinnerOptions = {\n start: (message?: string) => void;\n stop: (message?: string, code?: number) => void;\n message: (message?: string) => void;\n};\n\nexport interface WithSpinnerOptions<T> {\n message: string | (() => string);\n fn: () => Promise<T>;\n stopMessage?: (result: T) => string;\n subtext?: (result: T) => string | undefined;\n}\n\nfunction formatElapsed(ms: number): string {\n const totalSeconds = Math.floor(ms / 1000);\n if (totalSeconds < 60) {\n return `${totalSeconds}s`;\n }\n const minutes = Math.floor(totalSeconds / 60);\n const seconds = totalSeconds % 60;\n return `${minutes}m ${seconds}s`;\n}\n\nexport async function withSpinner<T>(options: WithSpinnerOptions<T>): Promise<T> {\n const { message, fn, stopMessage, subtext } = options;\n const readMessage = () => (typeof message === \"function\" ? message() : message);\n\n if (resolveOutputFormat() === \"json\") {\n const result = await fn();\n const sub = subtext ? subtext(result) : undefined;\n if (sub) {\n process.stdout.write(sub + \"\\n\");\n }\n return result;\n }\n\n const noSpinner = process.env.POE_NO_SPINNER === \"1\";\n const isTTY = process.stdout.isTTY;\n\n if (noSpinner || !isTTY) {\n const result = await fn();\n const msg = stopMessage ? stopMessage(result) : undefined;\n if (msg) {\n process.stdout.write(`\\x1b[32m\u25C6\\x1b[0m ${msg}\\n`);\n }\n const sub = subtext ? subtext(result) : undefined;\n if (sub) {\n for (const line of sub.split(\"\\n\")) {\n process.stdout.write(`\\x1b[90m\u2502\\x1b[0m ${line}\\n`);\n }\n }\n return result;\n }\n\n const s = spinner();\n const start = Date.now();\n s.start(readMessage());\n\n const timer = setInterval(() => {\n s.message(`${readMessage()} [${formatElapsed(Date.now() - start)}]`);\n }, 1000);\n\n try {\n const result = await fn();\n clearInterval(timer);\n const elapsed = formatElapsed(Date.now() - start);\n const msg = stopMessage ? stopMessage(result) : undefined;\n s.stop(msg ? `${msg} [${elapsed}]` : `Done [${elapsed}]`);\n\n const sub = subtext ? subtext(result) : undefined;\n if (sub) {\n for (const line of sub.split(\"\\n\")) {\n process.stdout.write(`\\x1b[90m\u2502\\x1b[0m ${line}\\n`);\n }\n }\n\n return result;\n } catch (error) {\n clearInterval(timer);\n s.stop(\"\", 1);\n throw error;\n }\n}\n", "import { color } from \"../../components/color.js\";\nexport { isCancel } from \"@clack/prompts\";\nimport { resolveOutputFormat } from \"../../internal/output-format.js\";\n\nexport function cancel(msg = \"\"): void {\n if (resolveOutputFormat() !== \"terminal\") {\n return;\n }\n\n process.stdout.write(`${color.gray(\"\u2514\")} ${color.red(msg)}\\n\\n`);\n}\n", "import type {\n ConfigMergeMutation,\n ConfigPruneMutation,\n ConfigTransformMutation,\n ConfigObject,\n ValueResolver,\n MutationOptions\n} from \"../types.js\";\n\nexport interface MergeOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** Value to merge into the config file */\n value: ValueResolver<ConfigObject>;\n /** Optional explicit format override */\n format?: \"json\" | \"toml\" | \"yaml\";\n /** Optional prune by prefix before merging (TOML) */\n pruneByPrefix?: Record<string, string>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface PruneOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** Shape to prune from the config file */\n shape: ValueResolver<ConfigObject>;\n /** Optional explicit format override */\n format?: \"json\" | \"toml\" | \"yaml\";\n /** Optional guard - only prune if predicate returns true */\n onlyIf?: (doc: ConfigObject, ctx: MutationOptions) => boolean;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface TransformOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** Optional explicit format override */\n format?: \"json\" | \"toml\" | \"yaml\";\n /** Transform function - receives parsed content, returns transformed content */\n transform: (\n content: ConfigObject,\n ctx: MutationOptions\n ) => { content: ConfigObject | null; changed: boolean };\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nfunction merge(options: MergeOptions): ConfigMergeMutation {\n return {\n kind: \"configMerge\",\n target: options.target,\n value: options.value,\n format: options.format,\n pruneByPrefix: options.pruneByPrefix,\n label: options.label\n };\n}\n\nfunction prune(options: PruneOptions): ConfigPruneMutation {\n return {\n kind: \"configPrune\",\n target: options.target,\n shape: options.shape,\n format: options.format,\n onlyIf: options.onlyIf,\n label: options.label\n };\n}\n\nfunction transform(options: TransformOptions): ConfigTransformMutation {\n return {\n kind: \"configTransform\",\n target: options.target,\n format: options.format,\n transform: options.transform,\n label: options.label\n };\n}\n\nexport const configMutation = {\n merge,\n prune,\n transform\n};\n", "import type {\n EnsureDirectoryMutation,\n RemoveDirectoryMutation,\n RemoveFileMutation,\n ChmodMutation,\n BackupMutation,\n ValueResolver\n} from \"../types.js\";\n\nexport interface EnsureDirectoryOptions {\n /** Directory path (must start with ~) */\n path: ValueResolver<string>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface RemoveOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** Only remove if file is empty/whitespace */\n whenEmpty?: boolean;\n /** Only remove if content matches regex */\n whenContentMatches?: RegExp;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface RemoveDirectoryOptions {\n /** Directory path (must start with ~) */\n path: ValueResolver<string>;\n /** Remove directory even when not empty */\n force?: boolean;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface ChmodOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** File permission mode (e.g., 0o755) */\n mode: number;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface BackupOptions {\n /** Target file path to backup (must start with ~) */\n target: ValueResolver<string>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nfunction ensureDirectory(options: EnsureDirectoryOptions): EnsureDirectoryMutation {\n return {\n kind: \"ensureDirectory\",\n path: options.path,\n label: options.label\n };\n}\n\nfunction remove(options: RemoveOptions): RemoveFileMutation {\n return {\n kind: \"removeFile\",\n target: options.target,\n whenEmpty: options.whenEmpty,\n whenContentMatches: options.whenContentMatches,\n label: options.label\n };\n}\n\nfunction removeDirectory(\n options: RemoveDirectoryOptions\n): RemoveDirectoryMutation {\n return {\n kind: \"removeDirectory\",\n path: options.path,\n force: options.force,\n label: options.label\n };\n}\n\nfunction chmod(options: ChmodOptions): ChmodMutation {\n return {\n kind: \"chmod\",\n target: options.target,\n mode: options.mode,\n label: options.label\n };\n}\n\nfunction backup(options: BackupOptions): BackupMutation {\n return {\n kind: \"backup\",\n target: options.target,\n label: options.label\n };\n}\n\nexport const fileMutation = {\n ensureDirectory,\n remove,\n removeDirectory,\n chmod,\n backup\n};\n", "import type {\n TemplateWriteMutation,\n TemplateMergeTomlMutation,\n TemplateMergeJsonMutation,\n ConfigObject,\n ValueResolver\n} from \"../types.js\";\n\nexport interface WriteOptions {\n /** Target file path (must start with ~) */\n target: ValueResolver<string>;\n /** Template ID to load via template loader */\n templateId: string;\n /** Context to pass to renderTemplate() */\n context?: ValueResolver<ConfigObject>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface MergeTomlOptions {\n /** Target TOML file path (must start with ~) */\n target: ValueResolver<string>;\n /** Template ID to load via template loader */\n templateId: string;\n /** Context to pass to renderTemplate() */\n context?: ValueResolver<ConfigObject>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nexport interface MergeJsonOptions {\n /** Target JSON file path (must start with ~) */\n target: ValueResolver<string>;\n /** Template ID to load via template loader */\n templateId: string;\n /** Context to pass to renderTemplate() */\n context?: ValueResolver<ConfigObject>;\n /** Optional human-readable label for logging */\n label?: string;\n}\n\nfunction write(options: WriteOptions): TemplateWriteMutation {\n return {\n kind: \"templateWrite\",\n target: options.target,\n templateId: options.templateId,\n context: options.context,\n label: options.label\n };\n}\n\nfunction mergeToml(options: MergeTomlOptions): TemplateMergeTomlMutation {\n return {\n kind: \"templateMergeToml\",\n target: options.target,\n templateId: options.templateId,\n context: options.context,\n label: options.label\n };\n}\n\nfunction mergeJson(options: MergeJsonOptions): TemplateMergeJsonMutation {\n return {\n kind: \"templateMergeJson\",\n target: options.target,\n templateId: options.templateId,\n context: options.context,\n label: options.label\n };\n}\n\nexport const templateMutation = {\n write,\n mergeToml,\n mergeJson\n};\n", "import * as jsonc from \"jsonc-parser\";\nimport type { ConfigFormat, ConfigObject, ConfigValue } from \"../types.js\";\n\nfunction isConfigObject(value: unknown): value is ConfigObject {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction detectIndent(content: string): string {\n const match = content.match(/^[\\t ]+/m);\n if (match) {\n return match[0];\n }\n return \" \";\n}\n\nfunction parse(content: string): ConfigObject {\n if (!content || content.trim() === \"\") {\n return {};\n }\n const errors: jsonc.ParseError[] = [];\n const parsed = jsonc.parse(content, errors, {\n allowTrailingComma: true,\n disallowComments: false\n });\n if (errors.length > 0) {\n throw new Error(`JSON parse error: ${jsonc.printParseErrorCode(errors[0].error)}`);\n }\n if (parsed === null || parsed === undefined) {\n return {};\n }\n if (!isConfigObject(parsed)) {\n throw new Error(\"Expected JSON object.\");\n }\n return parsed;\n}\n\nfunction serialize(obj: ConfigObject): string {\n return `${JSON.stringify(obj, null, 2)}\\n`;\n}\n\nfunction merge(base: ConfigObject, patch: ConfigObject): ConfigObject {\n const result: ConfigObject = { ...base };\n for (const [key, value] of Object.entries(patch)) {\n if (value === undefined) {\n continue;\n }\n const existing = result[key];\n if (isConfigObject(existing) && isConfigObject(value)) {\n result[key] = merge(existing, value);\n continue;\n }\n result[key] = value as ConfigValue;\n }\n return result;\n}\n\nfunction prune(\n obj: ConfigObject,\n shape: ConfigObject\n): { changed: boolean; result: ConfigObject } {\n let changed = false;\n const result: ConfigObject = { ...obj };\n\n for (const [key, pattern] of Object.entries(shape)) {\n if (!(key in result)) {\n continue;\n }\n\n const current = result[key];\n\n // Empty object pattern means \"delete this key entirely\"\n if (isConfigObject(pattern) && Object.keys(pattern).length === 0) {\n delete result[key];\n changed = true;\n continue;\n }\n\n // Non-empty object pattern with object current: recurse\n if (isConfigObject(pattern) && isConfigObject(current)) {\n const { changed: childChanged, result: childResult } = prune(\n current,\n pattern\n );\n if (childChanged) {\n changed = true;\n }\n if (Object.keys(childResult).length === 0) {\n delete result[key];\n } else {\n result[key] = childResult;\n }\n continue;\n }\n\n delete result[key];\n changed = true;\n }\n\n return { changed, result };\n}\n\n/**\n * Modify JSON content at a specific path while preserving comments and formatting.\n * Uses jsonc-parser's modify() for targeted updates.\n *\n * @param content - The original JSON content (may include comments)\n * @param path - JSON path array, e.g. [\"mcpServers\", \"my-server\"]\n * @param value - The value to set (or undefined to remove)\n * @returns The modified JSON content with comments preserved\n */\nfunction modifyAtPath(\n content: string,\n path: (string | number)[],\n value: ConfigValue | undefined\n): string {\n const indent = detectIndent(content);\n const formattingOptions: jsonc.FormattingOptions = {\n tabSize: indent === \"\\t\" ? 1 : indent.length,\n insertSpaces: indent !== \"\\t\",\n eol: \"\\n\"\n };\n\n const edits = jsonc.modify(content, path, value, { formattingOptions });\n let result = jsonc.applyEdits(content, edits);\n\n if (!result.endsWith(\"\\n\")) {\n result += \"\\n\";\n }\n\n return result;\n}\n\n/**\n * Merge a patch into JSON content while preserving comments and formatting.\n * Uses jsonc.modify() for each top-level key to preserve existing comments.\n *\n * @param content - The original JSON content (may include comments)\n * @param patch - Object with values to merge\n * @returns The modified JSON content with comments preserved\n */\nfunction mergePreservingComments(\n content: string,\n patch: ConfigObject\n): string {\n let result = content || \"{}\";\n\n for (const [key, value] of Object.entries(patch)) {\n if (value === undefined) {\n continue;\n }\n result = modifyAtPath(result, [key], value);\n }\n\n return result;\n}\n\n/**\n * Remove a key from JSON content while preserving comments and formatting.\n *\n * @param content - The original JSON content\n * @param path - JSON path array to the key to remove\n * @returns The modified JSON content with comments preserved\n */\nfunction removeAtPath(content: string, path: (string | number)[]): string {\n return modifyAtPath(content, path, undefined);\n}\n\nexport { detectIndent, modifyAtPath, mergePreservingComments, removeAtPath };\n\nexport const jsonFormat: ConfigFormat = {\n parse,\n serialize,\n merge,\n prune\n};\n", "import { parse as parseToml, stringify as stringifyToml } from \"smol-toml\";\nimport type { ConfigFormat, ConfigObject, ConfigValue } from \"../types.js\";\n\nfunction isConfigObject(value: unknown): value is ConfigObject {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction parse(content: string): ConfigObject {\n if (!content || content.trim() === \"\") {\n return {};\n }\n const parsed = parseToml(content);\n if (!isConfigObject(parsed)) {\n throw new Error(\"Expected TOML document to be a table.\");\n }\n return parsed as ConfigObject;\n}\n\nfunction serialize(obj: ConfigObject): string {\n const serialized = stringifyToml(obj);\n return serialized.endsWith(\"\\n\") ? serialized : `${serialized}\\n`;\n}\n\nfunction merge(base: ConfigObject, patch: ConfigObject): ConfigObject {\n const result: ConfigObject = { ...base };\n for (const [key, value] of Object.entries(patch)) {\n if (value === undefined) {\n continue;\n }\n const existing = result[key];\n if (isConfigObject(existing) && isConfigObject(value)) {\n result[key] = merge(existing, value);\n continue;\n }\n result[key] = value as ConfigValue;\n }\n return result;\n}\n\nfunction prune(\n obj: ConfigObject,\n shape: ConfigObject\n): { changed: boolean; result: ConfigObject } {\n let changed = false;\n const result: ConfigObject = { ...obj };\n\n for (const [key, pattern] of Object.entries(shape)) {\n if (!(key in result)) {\n continue;\n }\n\n const current = result[key];\n\n // Empty object pattern means \"delete this key entirely\"\n if (isConfigObject(pattern) && Object.keys(pattern).length === 0) {\n delete result[key];\n changed = true;\n continue;\n }\n\n // Non-empty object pattern with object current: recurse\n if (isConfigObject(pattern) && isConfigObject(current)) {\n const { changed: childChanged, result: childResult } = prune(\n current,\n pattern\n );\n if (childChanged) {\n changed = true;\n }\n if (Object.keys(childResult).length === 0) {\n delete result[key];\n } else {\n result[key] = childResult;\n }\n continue;\n }\n\n delete result[key];\n changed = true;\n }\n\n return { changed, result };\n}\n\nexport const tomlFormat: ConfigFormat = {\n parse,\n serialize,\n merge,\n prune\n};\n", "import { parse as parseYaml, stringify as stringifyYaml } from \"yaml\";\nimport type { ConfigFormat, ConfigObject, ConfigValue } from \"../types.js\";\n\nfunction isConfigObject(value: unknown): value is ConfigObject {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction parse(content: string): ConfigObject {\n if (!content || content.trim() === \"\") {\n return {};\n }\n const parsed = parseYaml(content);\n if (parsed === null || parsed === undefined) {\n return {};\n }\n if (!isConfigObject(parsed)) {\n throw new Error(\"Expected YAML object.\");\n }\n return parsed;\n}\n\nfunction serialize(obj: ConfigObject): string {\n const serialized = stringifyYaml(obj);\n return serialized.endsWith(\"\\n\") ? serialized : `${serialized}\\n`;\n}\n\nfunction merge(base: ConfigObject, patch: ConfigObject): ConfigObject {\n const result: ConfigObject = { ...base };\n for (const [key, value] of Object.entries(patch)) {\n if (value === undefined) {\n continue;\n }\n const existing = result[key];\n if (isConfigObject(existing) && isConfigObject(value)) {\n result[key] = merge(existing, value);\n continue;\n }\n result[key] = value as ConfigValue;\n }\n return result;\n}\n\nfunction prune(\n obj: ConfigObject,\n shape: ConfigObject\n): { changed: boolean; result: ConfigObject } {\n let changed = false;\n const result: ConfigObject = { ...obj };\n\n for (const [key, pattern] of Object.entries(shape)) {\n if (!(key in result)) {\n continue;\n }\n\n const current = result[key];\n\n if (isConfigObject(pattern) && Object.keys(pattern).length === 0) {\n delete result[key];\n changed = true;\n continue;\n }\n\n if (isConfigObject(pattern) && isConfigObject(current)) {\n const { changed: childChanged, result: childResult } = prune(current, pattern);\n if (childChanged) {\n changed = true;\n }\n if (Object.keys(childResult).length === 0) {\n delete result[key];\n } else {\n result[key] = childResult;\n }\n continue;\n }\n\n delete result[key];\n changed = true;\n }\n\n return { changed, result };\n}\n\nexport const yamlFormat: ConfigFormat = {\n parse,\n serialize,\n merge,\n prune\n};\n", "import type { ConfigFormat } from \"../types.js\";\nimport { jsonFormat } from \"./json.js\";\nimport { tomlFormat } from \"./toml.js\";\nimport { yamlFormat } from \"./yaml.js\";\n\nexport type FormatName = \"json\" | \"toml\" | \"yaml\";\n\nconst formatRegistry: Record<FormatName, ConfigFormat> = {\n json: jsonFormat,\n toml: tomlFormat,\n yaml: yamlFormat\n};\n\nconst extensionMap: Record<string, FormatName> = {\n \".json\": \"json\",\n \".toml\": \"toml\",\n \".yaml\": \"yaml\",\n \".yml\": \"yaml\"\n};\n\n/**\n * Get a format handler by path (auto-detect from extension) or explicit format name.\n */\nexport function getConfigFormat(pathOrFormat: string): ConfigFormat {\n // Check if it's an explicit format name\n if (pathOrFormat in formatRegistry) {\n return formatRegistry[pathOrFormat as FormatName];\n }\n\n // Try to detect from extension\n const ext = getExtension(pathOrFormat);\n const formatName = extensionMap[ext];\n\n if (!formatName) {\n throw new Error(\n `Unsupported config format. Cannot detect format from \"${pathOrFormat}\". ` +\n `Supported extensions: ${Object.keys(extensionMap).join(\", \")}. ` +\n `Supported format names: ${Object.keys(formatRegistry).join(\", \")}.`\n );\n }\n\n return formatRegistry[formatName];\n}\n\n/**\n * Detect format name from a file path.\n */\nexport function detectFormat(path: string): FormatName | undefined {\n const ext = getExtension(path);\n return extensionMap[ext];\n}\n\nfunction getExtension(path: string): string {\n const lastDot = path.lastIndexOf(\".\");\n if (lastDot === -1) {\n return \"\";\n }\n return path.slice(lastDot).toLowerCase();\n}\n\nexport { jsonFormat } from \"./json.js\";\nexport { tomlFormat } from \"./toml.js\";\nexport { yamlFormat } from \"./yaml.js\";\n", "import path from \"node:path\";\nimport type { PathMapper } from \"../types.js\";\n\n/**\n * Expand ~ shortcut to the provided home directory.\n */\nexport function expandHome(targetPath: string, homeDir: string): string {\n if (!targetPath?.startsWith(\"~\")) {\n return targetPath;\n }\n\n // Handle ~./ -> ~/.\n if (targetPath.startsWith(\"~./\")) {\n targetPath = `~/.${targetPath.slice(3)}`;\n }\n\n let remainder = targetPath.slice(1);\n\n // Remove leading slash or backslash\n if (remainder.startsWith(\"/\") || remainder.startsWith(\"\\\\\")) {\n remainder = remainder.slice(1);\n } else if (remainder.startsWith(\".\")) {\n // Handle ~/.\n remainder = remainder.slice(1);\n if (remainder.startsWith(\"/\") || remainder.startsWith(\"\\\\\")) {\n remainder = remainder.slice(1);\n }\n }\n\n return remainder.length === 0 ? homeDir : path.join(homeDir, remainder);\n}\n\n/**\n * Validate that a path is home-relative (starts with ~).\n * Throws if the path is not home-relative.\n */\nexport function validateHomePath(targetPath: string): void {\n if (typeof targetPath !== \"string\" || targetPath.length === 0) {\n throw new Error(\"Target path must be a non-empty string.\");\n }\n\n if (!targetPath.startsWith(\"~\")) {\n throw new Error(\n `All target paths must be home-relative (start with ~). Received: \"${targetPath}\"`\n );\n }\n}\n\n/**\n * Resolve a path with optional path mapping for isolated configurations.\n * 1. Validates the path starts with ~\n * 2. Expands ~ to home directory\n * 3. If pathMapper is provided, maps the directory portion and reconstructs the path\n */\nexport function resolvePath(\n rawPath: string,\n homeDir: string,\n pathMapper?: PathMapper\n): string {\n validateHomePath(rawPath);\n const expanded = expandHome(rawPath, homeDir);\n\n if (!pathMapper) {\n return expanded;\n }\n\n // Map the directory portion\n const rawDirectory = path.dirname(expanded);\n const mappedDirectory = pathMapper.mapTargetDirectory({\n targetDirectory: rawDirectory\n });\n const filename = path.basename(expanded);\n\n return filename.length === 0 ? mappedDirectory : path.join(mappedDirectory, filename);\n}\n", "import type { FileSystem } from \"./types.js\";\n\n/**\n * Check if an error is a \"file not found\" (ENOENT) error.\n */\nexport function isNotFound(error: unknown): boolean {\n return (\n typeof error === \"object\" &&\n error !== null &&\n \"code\" in error &&\n (error as { code?: string }).code === \"ENOENT\"\n );\n}\n\n/**\n * Read a file if it exists, returning null if not found.\n */\nexport async function readFileIfExists(\n fs: FileSystem,\n target: string\n): Promise<string | null> {\n try {\n return await fs.readFile(target, \"utf8\");\n } catch (error) {\n if (isNotFound(error)) {\n return null;\n }\n throw error;\n }\n}\n\n/**\n * Check if a path exists (file or directory).\n */\nexport async function pathExists(\n fs: FileSystem,\n target: string\n): Promise<boolean> {\n try {\n await fs.stat(target);\n return true;\n } catch (error) {\n if (isNotFound(error)) {\n return false;\n }\n throw error;\n }\n}\n\n/**\n * Create an ISO timestamp safe for use in filenames.\n * Replaces colons and dots with dashes.\n */\nexport function createTimestamp(): string {\n return new Date().toISOString().replaceAll(\":\", \"-\").replaceAll(\".\", \"-\");\n}\n", "import { renderTemplate } from \"@poe-code/design-system\";\nimport type {\n Mutation,\n MutationContext,\n MutationOutcome,\n MutationDetails,\n ConfigObject,\n MutationOptions,\n ValueResolver,\n FileSystem\n} from \"../types.js\";\nimport { getConfigFormat, detectFormat } from \"../formats/index.js\";\nimport { resolvePath } from \"./path-utils.js\";\nimport {\n isNotFound,\n readFileIfExists,\n pathExists,\n createTimestamp\n} from \"../fs-utils.js\";\n\n// ============================================================================\n// Helper Functions\n// ============================================================================\n\nfunction resolveValue<T>(\n resolver: ValueResolver<T>,\n options: MutationOptions\n): T {\n if (typeof resolver === \"function\") {\n return (resolver as (ctx: MutationOptions) => T)(options);\n }\n return resolver;\n}\n\nfunction createInvalidDocumentBackupPath(targetPath: string): string {\n const ext = targetPath.includes(\".\") ? targetPath.split(\".\").pop() : \"bak\";\n return `${targetPath}.invalid-${createTimestamp()}.${ext}`;\n}\n\nasync function backupInvalidDocument(\n fs: FileSystem,\n targetPath: string,\n content: string\n): Promise<void> {\n const backupPath = createInvalidDocumentBackupPath(targetPath);\n await fs.writeFile(backupPath, content, { encoding: \"utf8\" });\n}\n\nfunction describeMutation(kind: string, targetPath?: string): string {\n const displayPath = targetPath ?? \"target\";\n switch (kind) {\n case \"ensureDirectory\":\n return `Create ${displayPath}`;\n case \"removeDirectory\":\n return `Remove directory ${displayPath}`;\n case \"backup\":\n return `Backup ${displayPath}`;\n case \"templateWrite\":\n return `Write ${displayPath}`;\n case \"chmod\":\n return `Set permissions on ${displayPath}`;\n case \"removeFile\":\n return `Remove ${displayPath}`;\n case \"configMerge\":\n case \"configPrune\":\n case \"configTransform\":\n case \"templateMergeToml\":\n case \"templateMergeJson\":\n return `Update ${displayPath}`;\n default:\n return \"Operation\";\n }\n}\n\nfunction pruneKeysByPrefix(\n table: ConfigObject,\n prefix: string\n): ConfigObject {\n const result: ConfigObject = {};\n for (const [key, value] of Object.entries(table)) {\n if (!key.startsWith(prefix)) {\n result[key] = value;\n }\n }\n return result;\n}\n\nfunction isConfigObject(value: unknown): value is ConfigObject {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction mergeWithPruneByPrefix(\n base: ConfigObject,\n patch: ConfigObject,\n pruneByPrefix?: Record<string, string>\n): ConfigObject {\n const result: ConfigObject = { ...base };\n const prefixMap = pruneByPrefix ?? {};\n\n for (const [key, value] of Object.entries(patch)) {\n const current = result[key];\n const prefix = prefixMap[key];\n\n if (isConfigObject(current) && isConfigObject(value)) {\n if (prefix) {\n const pruned = pruneKeysByPrefix(current, prefix);\n result[key] = { ...pruned, ...value };\n } else {\n result[key] = mergeWithPruneByPrefix(\n current,\n value as ConfigObject,\n prefixMap\n );\n }\n continue;\n }\n result[key] = value;\n }\n return result;\n}\n\n// ============================================================================\n// Apply Mutation\n// ============================================================================\n\nexport async function applyMutation(\n mutation: Mutation,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n switch (mutation.kind) {\n case \"ensureDirectory\":\n return applyEnsureDirectory(mutation, context, options);\n case \"removeDirectory\":\n return applyRemoveDirectory(mutation, context, options);\n case \"removeFile\":\n return applyRemoveFile(mutation, context, options);\n case \"chmod\":\n return applyChmod(mutation, context, options);\n case \"backup\":\n return applyBackup(mutation, context, options);\n case \"configMerge\":\n return applyConfigMerge(mutation, context, options);\n case \"configPrune\":\n return applyConfigPrune(mutation, context, options);\n case \"configTransform\":\n return applyConfigTransform(mutation, context, options);\n case \"templateWrite\":\n return applyTemplateWrite(mutation, context, options);\n case \"templateMergeToml\":\n return applyTemplateMerge(mutation, context, options, \"toml\");\n case \"templateMergeJson\":\n return applyTemplateMerge(mutation, context, options, \"json\");\n default: {\n const never: never = mutation;\n throw new Error(`Unknown mutation kind: ${(never as Mutation).kind}`);\n }\n }\n}\n\n// ============================================================================\n// File Mutation Handlers\n// ============================================================================\n\nasync function applyEnsureDirectory(\n mutation: Extract<Mutation, { kind: \"ensureDirectory\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.path, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const existed = await pathExists(context.fs, targetPath);\n\n if (!context.dryRun) {\n await context.fs.mkdir(targetPath, { recursive: true });\n }\n\n return {\n outcome: {\n changed: !existed,\n effect: \"mkdir\",\n detail: existed ? \"noop\" : \"create\"\n },\n details\n };\n}\n\nasync function applyRemoveDirectory(\n mutation: Extract<Mutation, { kind: \"removeDirectory\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.path, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const existed = await pathExists(context.fs, targetPath);\n if (!existed) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (typeof context.fs.rm !== \"function\") {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (mutation.force) {\n if (!context.dryRun) {\n await context.fs.rm(targetPath, { recursive: true, force: true });\n }\n return {\n outcome: { changed: true, effect: \"delete\", detail: \"delete\" },\n details\n };\n }\n\n const entries = await context.fs.readdir(targetPath);\n if (entries.length > 0) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (!context.dryRun) {\n await context.fs.rm(targetPath, { recursive: true, force: true });\n }\n\n return {\n outcome: { changed: true, effect: \"delete\", detail: \"delete\" },\n details\n };\n}\n\nasync function applyRemoveFile(\n mutation: Extract<Mutation, { kind: \"removeFile\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n try {\n const content = await context.fs.readFile(targetPath, \"utf8\");\n const trimmed = content.trim();\n\n // Check whenContentMatches guard\n if (mutation.whenContentMatches && !mutation.whenContentMatches.test(trimmed)) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n // Check whenEmpty guard\n if (mutation.whenEmpty && trimmed.length > 0) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (!context.dryRun) {\n await context.fs.unlink(targetPath);\n }\n\n return {\n outcome: { changed: true, effect: \"delete\", detail: \"delete\" },\n details\n };\n } catch (error) {\n if (isNotFound(error)) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n throw error;\n }\n}\n\nasync function applyChmod(\n mutation: Extract<Mutation, { kind: \"chmod\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n if (typeof context.fs.chmod !== \"function\") {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n try {\n const stat = await context.fs.stat(targetPath);\n const currentMode = typeof stat.mode === \"number\" ? stat.mode & 0o777 : null;\n\n if (currentMode === mutation.mode) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (!context.dryRun) {\n await context.fs.chmod(targetPath, mutation.mode);\n }\n\n return {\n outcome: { changed: true, effect: \"chmod\", detail: \"update\" },\n details\n };\n } catch (error) {\n if (isNotFound(error)) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n throw error;\n }\n}\n\nasync function applyBackup(\n mutation: Extract<Mutation, { kind: \"backup\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const content = await readFileIfExists(context.fs, targetPath);\n if (content === null) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n if (!context.dryRun) {\n const backupPath = `${targetPath}.backup-${createTimestamp()}`;\n await context.fs.writeFile(backupPath, content, { encoding: \"utf8\" });\n }\n\n return {\n outcome: { changed: true, effect: \"copy\", detail: \"backup\" },\n details\n };\n}\n\n// ============================================================================\n// Config Mutation Handlers\n// ============================================================================\n\nasync function applyConfigMerge(\n mutation: Extract<Mutation, { kind: \"configMerge\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const formatName = mutation.format ?? detectFormat(rawPath);\n if (!formatName) {\n throw new Error(\n `Cannot detect config format for \"${rawPath}\". Provide explicit format option.`\n );\n }\n const format = getConfigFormat(formatName);\n\n const rawContent = await readFileIfExists(context.fs, targetPath);\n let current: ConfigObject;\n try {\n current = rawContent === null ? {} : format.parse(rawContent);\n } catch {\n // Invalid file - backup and start fresh\n if (rawContent !== null) {\n await backupInvalidDocument(context.fs, targetPath, rawContent);\n }\n current = {};\n }\n\n const value = resolveValue(mutation.value, options);\n\n // Use mergeWithPruneByPrefix for TOML files with pruneByPrefix option\n let merged: ConfigObject;\n if (mutation.pruneByPrefix) {\n merged = mergeWithPruneByPrefix(current, value, mutation.pruneByPrefix);\n } else {\n merged = format.merge(current, value);\n }\n\n const serialized = format.serialize(merged);\n const changed = serialized !== rawContent;\n\n if (changed && !context.dryRun) {\n await context.fs.writeFile(targetPath, serialized, { encoding: \"utf8\" });\n }\n\n return {\n outcome: {\n changed,\n effect: changed ? \"write\" : \"none\",\n detail: changed ? (rawContent === null ? \"create\" : \"update\") : \"noop\"\n },\n details\n };\n}\n\nasync function applyConfigPrune(\n mutation: Extract<Mutation, { kind: \"configPrune\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const rawContent = await readFileIfExists(context.fs, targetPath);\n if (rawContent === null) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n const formatName = mutation.format ?? detectFormat(rawPath);\n if (!formatName) {\n throw new Error(\n `Cannot detect config format for \"${rawPath}\". Provide explicit format option.`\n );\n }\n const format = getConfigFormat(formatName);\n\n let current: ConfigObject;\n try {\n current = format.parse(rawContent);\n } catch {\n // Invalid file - can't prune, leave as-is\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n // Check onlyIf guard\n if (mutation.onlyIf && !mutation.onlyIf(current, options)) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n const shape = resolveValue(mutation.shape, options);\n const { changed, result } = format.prune(current, shape);\n\n if (!changed) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n // Delete file if empty\n if (Object.keys(result).length === 0) {\n if (!context.dryRun) {\n await context.fs.unlink(targetPath);\n }\n return {\n outcome: { changed: true, effect: \"delete\", detail: \"delete\" },\n details\n };\n }\n\n const serialized = format.serialize(result);\n if (!context.dryRun) {\n await context.fs.writeFile(targetPath, serialized, { encoding: \"utf8\" });\n }\n\n return {\n outcome: { changed: true, effect: \"write\", detail: \"update\" },\n details\n };\n}\n\nasync function applyConfigTransform(\n mutation: Extract<Mutation, { kind: \"configTransform\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const formatName = mutation.format ?? detectFormat(rawPath);\n if (!formatName) {\n throw new Error(\n `Cannot detect config format for \"${rawPath}\". Provide explicit format option.`\n );\n }\n const format = getConfigFormat(formatName);\n\n const rawContent = await readFileIfExists(context.fs, targetPath);\n let current: ConfigObject;\n try {\n current = rawContent === null ? {} : format.parse(rawContent);\n } catch {\n if (rawContent !== null) {\n await backupInvalidDocument(context.fs, targetPath, rawContent);\n }\n current = {};\n }\n\n const { content: transformed, changed } = mutation.transform(current, options);\n\n if (!changed) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n\n // Delete file if null\n if (transformed === null) {\n if (rawContent === null) {\n return {\n outcome: { changed: false, effect: \"none\", detail: \"noop\" },\n details\n };\n }\n if (!context.dryRun) {\n await context.fs.unlink(targetPath);\n }\n return {\n outcome: { changed: true, effect: \"delete\", detail: \"delete\" },\n details\n };\n }\n\n const serialized = format.serialize(transformed);\n if (!context.dryRun) {\n await context.fs.writeFile(targetPath, serialized, { encoding: \"utf8\" });\n }\n\n return {\n outcome: {\n changed: true,\n effect: \"write\",\n detail: rawContent === null ? \"create\" : \"update\"\n },\n details\n };\n}\n\n// ============================================================================\n// Template Mutation Handlers\n// ============================================================================\n\nasync function applyTemplateWrite(\n mutation: Extract<Mutation, { kind: \"templateWrite\" }>,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n if (!context.templates) {\n throw new Error(\n \"Template mutations require a templates loader. \" +\n \"Provide templates function to runMutations context.\"\n );\n }\n\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const template = await context.templates(mutation.templateId);\n const templateContext = mutation.context\n ? resolveValue(mutation.context, options)\n : {};\n const rendered = renderTemplate(template, templateContext);\n\n const existed = await pathExists(context.fs, targetPath);\n\n if (!context.dryRun) {\n await context.fs.writeFile(targetPath, rendered, { encoding: \"utf8\" });\n }\n\n return {\n outcome: {\n changed: true,\n effect: \"write\",\n detail: existed ? \"update\" : \"create\"\n },\n details\n };\n}\n\nasync function applyTemplateMerge(\n mutation: Extract<Mutation, { kind: \"templateMergeToml\" | \"templateMergeJson\" }>,\n context: MutationContext,\n options: MutationOptions,\n formatName: \"toml\" | \"json\"\n): Promise<{ outcome: MutationOutcome; details: MutationDetails }> {\n if (!context.templates) {\n throw new Error(\n \"Template mutations require a templates loader. \" +\n \"Provide templates function to runMutations context.\"\n );\n }\n\n const rawPath = resolveValue(mutation.target, options);\n const targetPath = resolvePath(rawPath, context.homeDir, context.pathMapper);\n\n const details: MutationDetails = {\n kind: mutation.kind,\n label: mutation.label ?? describeMutation(mutation.kind, targetPath),\n targetPath\n };\n\n const format = getConfigFormat(formatName);\n\n // Load and render template\n const template = await context.templates(mutation.templateId);\n const templateContext = mutation.context\n ? resolveValue(mutation.context, options)\n : {};\n const rendered = renderTemplate(template, templateContext);\n\n // Parse rendered template\n let templateDoc: ConfigObject;\n try {\n templateDoc = format.parse(rendered);\n } catch (error) {\n throw new Error(\n `Failed to parse rendered template \"${mutation.templateId}\" as ${formatName.toUpperCase()}: ${error}`,\n { cause: error }\n );\n }\n\n // Read and parse existing file\n const rawContent = await readFileIfExists(context.fs, targetPath);\n let current: ConfigObject;\n try {\n current = rawContent === null ? {} : format.parse(rawContent);\n } catch {\n if (rawContent !== null) {\n await backupInvalidDocument(context.fs, targetPath, rawContent);\n }\n current = {};\n }\n\n // Merge\n const merged = format.merge(current, templateDoc);\n const serialized = format.serialize(merged);\n const changed = serialized !== rawContent;\n\n if (changed && !context.dryRun) {\n await context.fs.writeFile(targetPath, serialized, { encoding: \"utf8\" });\n }\n\n return {\n outcome: {\n changed,\n effect: changed ? \"write\" : \"none\",\n detail: changed ? (rawContent === null ? \"create\" : \"update\") : \"noop\"\n },\n details\n };\n}\n", "import type {\n Mutation,\n MutationContext,\n MutationResult,\n MutationOptions\n} from \"../types.js\";\nimport { applyMutation } from \"./apply-mutation.js\";\n\n/**\n * Execute an array of mutations in order.\n *\n * All dependencies must be injected - no defaults, no globals.\n */\nexport async function runMutations(\n mutations: Mutation[],\n context: MutationContext,\n options?: MutationOptions\n): Promise<MutationResult> {\n const effects: MutationResult[\"effects\"] = [];\n let anyChanged = false;\n const resolverOptions = options ?? {};\n\n for (const mutation of mutations) {\n const { outcome } = await executeMutation(\n mutation,\n context,\n resolverOptions\n );\n effects.push(outcome);\n if (outcome.changed) {\n anyChanged = true;\n }\n }\n\n return {\n changed: anyChanged,\n effects\n };\n}\n\nasync function executeMutation(\n mutation: Mutation,\n context: MutationContext,\n options: MutationOptions\n): Promise<{ outcome: MutationResult[\"effects\"][number]; details: { kind: string; label: string; targetPath?: string } }> {\n // Call onStart observer\n context.observers?.onStart?.({\n kind: mutation.kind,\n label: mutation.label ?? mutation.kind,\n targetPath: undefined // Will be resolved during apply\n });\n\n try {\n const { outcome, details } = await applyMutation(mutation, context, options);\n\n // Call onComplete observer\n context.observers?.onComplete?.(details, outcome);\n\n return { outcome, details };\n } catch (error) {\n // Call onError observer\n context.observers?.onError?.(\n {\n kind: mutation.kind,\n label: mutation.label ?? mutation.kind,\n targetPath: undefined\n },\n error\n );\n\n // Re-throw the error\n throw error;\n }\n}\n", "// ============================================================================\n// Config Object Types\n// ============================================================================\n\nexport type ConfigPrimitive = string | number | boolean | null;\nexport type ConfigValue = ConfigPrimitive | ConfigObject | ConfigArray | Date;\nexport interface ConfigObject {\n [key: string]: ConfigValue;\n}\nexport type ConfigArray = ConfigValue[];\n\nexport function isConfigObject(value: unknown): value is ConfigObject {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\n// ============================================================================\n// FileSystem Interface\n// ============================================================================\n\nexport interface FileSystem {\n readFile(path: string, encoding: \"utf8\"): Promise<string>;\n writeFile(\n path: string,\n content: string,\n options?: { encoding: \"utf8\" }\n ): Promise<void>;\n mkdir(path: string, options?: { recursive: boolean }): Promise<void>;\n unlink(path: string): Promise<void>;\n rm?(\n path: string,\n options?: { recursive?: boolean; force?: boolean }\n ): Promise<void>;\n stat(path: string): Promise<{ mode?: number }>;\n readdir(path: string): Promise<string[]>;\n chmod?(path: string, mode: number): Promise<void>;\n}\n\n// ============================================================================\n// Template Loader\n// ============================================================================\n\nexport type TemplateLoader = (templateId: string) => Promise<string>;\n\n// ============================================================================\n// Config Format Interface\n// ============================================================================\n\nexport interface ConfigFormat {\n /** Parse string content into object */\n parse(content: string): ConfigObject;\n\n /** Serialize object to string (with consistent formatting) */\n serialize(obj: ConfigObject): string;\n\n /** Deep merge patch into base, returning new object */\n merge(base: ConfigObject, patch: ConfigObject): ConfigObject;\n\n /** Remove keys matching shape from object, returning new object */\n prune(\n obj: ConfigObject,\n shape: ConfigObject\n ): { changed: boolean; result: ConfigObject };\n}\n\n// ============================================================================\n// Path Mapper (for isolated configurations)\n// ============================================================================\n\nexport interface PathMapper {\n /** Map a target directory to a different location (e.g., for isolated configs) */\n mapTargetDirectory(input: { targetDirectory: string }): string;\n}\n\n// ============================================================================\n// Mutation Context (passed to runMutations)\n// ============================================================================\n\nexport interface MutationContext {\n /** Filesystem interface - required */\n fs: FileSystem;\n\n /** Home directory for ~ expansion - required */\n homeDir: string;\n\n /** Optional dry-run mode */\n dryRun?: boolean;\n\n /** Optional observers for logging */\n observers?: MutationObservers;\n\n /** Required for template mutations */\n templates?: TemplateLoader;\n\n /** Optional path mapper for redirecting paths (used for isolated configs) */\n pathMapper?: PathMapper;\n}\n\n// ============================================================================\n// Value Resolver (static value or context-aware function)\n// ============================================================================\n\nexport interface MutationOptions {\n [key: string]: unknown;\n}\n\nexport type ValueResolver<T> = T | ((ctx: MutationOptions) => T);\n\n// ============================================================================\n// Mutation Types\n// ============================================================================\n\ninterface BaseMutation {\n /** Human-readable label for logging */\n label?: string;\n}\n\n// Config mutations\nexport interface ConfigMergeMutation extends BaseMutation {\n kind: \"configMerge\";\n target: ValueResolver<string>;\n value: ValueResolver<ConfigObject>;\n format?: \"json\" | \"toml\" | \"yaml\";\n pruneByPrefix?: Record<string, string>;\n}\n\nexport interface ConfigPruneMutation extends BaseMutation {\n kind: \"configPrune\";\n target: ValueResolver<string>;\n shape: ValueResolver<ConfigObject>;\n format?: \"json\" | \"toml\" | \"yaml\";\n onlyIf?: (doc: ConfigObject, ctx: MutationOptions) => boolean;\n}\n\nexport interface ConfigTransformMutation extends BaseMutation {\n kind: \"configTransform\";\n target: ValueResolver<string>;\n format?: \"json\" | \"toml\" | \"yaml\";\n transform: (\n content: ConfigObject,\n ctx: MutationOptions\n ) => { content: ConfigObject | null; changed: boolean };\n}\n\n// File mutations\nexport interface EnsureDirectoryMutation extends BaseMutation {\n kind: \"ensureDirectory\";\n path: ValueResolver<string>;\n}\n\nexport interface RemoveDirectoryMutation extends BaseMutation {\n kind: \"removeDirectory\";\n path: ValueResolver<string>;\n force?: boolean;\n}\n\nexport interface RemoveFileMutation extends BaseMutation {\n kind: \"removeFile\";\n target: ValueResolver<string>;\n whenEmpty?: boolean;\n whenContentMatches?: RegExp;\n}\n\nexport interface ChmodMutation extends BaseMutation {\n kind: \"chmod\";\n target: ValueResolver<string>;\n mode: number;\n}\n\nexport interface BackupMutation extends BaseMutation {\n kind: \"backup\";\n target: ValueResolver<string>;\n}\n\n// Template mutations\nexport interface TemplateWriteMutation extends BaseMutation {\n kind: \"templateWrite\";\n target: ValueResolver<string>;\n templateId: string;\n context?: ValueResolver<ConfigObject>;\n}\n\nexport interface TemplateMergeTomlMutation extends BaseMutation {\n kind: \"templateMergeToml\";\n target: ValueResolver<string>;\n templateId: string;\n context?: ValueResolver<ConfigObject>;\n}\n\nexport interface TemplateMergeJsonMutation extends BaseMutation {\n kind: \"templateMergeJson\";\n target: ValueResolver<string>;\n templateId: string;\n context?: ValueResolver<ConfigObject>;\n}\n\nexport type Mutation =\n | ConfigMergeMutation\n | ConfigPruneMutation\n | ConfigTransformMutation\n | EnsureDirectoryMutation\n | RemoveDirectoryMutation\n | RemoveFileMutation\n | ChmodMutation\n | BackupMutation\n | TemplateWriteMutation\n | TemplateMergeTomlMutation\n | TemplateMergeJsonMutation;\n\n// ============================================================================\n// Mutation Result\n// ============================================================================\n\nexport type MutationEffect =\n | \"none\"\n | \"mkdir\"\n | \"write\"\n | \"delete\"\n | \"chmod\"\n | \"copy\";\n\nexport type MutationDetail =\n | \"create\"\n | \"update\"\n | \"delete\"\n | \"noop\"\n | \"backup\";\n\nexport interface MutationOutcome {\n changed: boolean;\n effect: MutationEffect;\n detail?: MutationDetail;\n}\n\nexport interface MutationDetails {\n kind: string;\n label: string;\n targetPath?: string;\n}\n\nexport interface MutationObservers {\n onStart?(details: MutationDetails): void;\n onComplete?(details: MutationDetails, outcome: MutationOutcome): void;\n onError?(details: MutationDetails, error: unknown): void;\n}\n\nexport interface MutationResult {\n changed: boolean;\n effects: MutationOutcome[];\n}\n", "import type {\n InferConfig,\n InferSchemaField,\n JsonSchemaField,\n SchemaField,\n ScopeSchema\n} from \"./types.js\";\n\nexport function resolveScope<S extends ScopeSchema>(\n schema: S,\n fileValues?: Record<string, unknown>,\n env: Record<string, string | undefined> = {}\n): InferConfig<S> {\n const resolved = {} as InferConfig<S>;\n\n for (const key of Object.keys(schema) as Array<keyof S & string>) {\n const field = schema[key];\n const envValue = resolveEnvValue(field, env, key);\n const fileValue = resolveFileValue(field, fileValues?.[key], key);\n resolved[key] = (envValue ?? fileValue ?? field.default) as InferConfig<S>[typeof key];\n }\n\n return resolved;\n}\n\nfunction resolveEnvValue<T extends SchemaField>(\n field: T,\n env: Record<string, string | undefined>,\n key: string\n): InferSchemaField<T> | undefined {\n if (!field.env) {\n return undefined;\n }\n\n const raw = env[field.env];\n if (raw === undefined) {\n return undefined;\n }\n\n return coerceValue(field, raw, key);\n}\n\nfunction resolveFileValue<T extends SchemaField>(\n field: T,\n value: unknown,\n key: string\n): InferSchemaField<T> | undefined {\n return coerceValue(field, value, key);\n}\n\nfunction coerceValue<T extends SchemaField>(\n field: T,\n value: unknown,\n key: string\n): InferSchemaField<T> | undefined {\n switch (field.type) {\n case \"string\":\n return typeof value === \"string\" ? value as InferSchemaField<T> : undefined;\n case \"number\":\n return coerceNumber(value) as InferSchemaField<T> | undefined;\n case \"boolean\":\n return coerceBoolean(value) as InferSchemaField<T> | undefined;\n case \"json\":\n return coerceJson(field, value, key) as InferSchemaField<T> | undefined;\n }\n}\n\nfunction coerceNumber(value: unknown): number | undefined {\n if (typeof value === \"number\" && Number.isFinite(value)) {\n return value;\n }\n\n if (typeof value !== \"string\" || value.length === 0) {\n return undefined;\n }\n\n const parsed = Number(value);\n return Number.isNaN(parsed) ? undefined : parsed;\n}\n\nfunction coerceBoolean(value: unknown): boolean | undefined {\n if (typeof value === \"boolean\") {\n return value;\n }\n\n if (value === \"true\" || value === \"1\") {\n return true;\n }\n\n if (value === \"false\" || value === \"0\") {\n return false;\n }\n\n return undefined;\n}\n\nfunction coerceJson<T>(\n field: JsonSchemaField<T>,\n value: unknown,\n key: string\n): T | undefined {\n if (value === undefined) {\n return undefined;\n }\n\n const parsedValue = parseJsonValue(value, key);\n try {\n return field.parse(parsedValue);\n } catch (error) {\n const message = error instanceof Error ? error.message : \"Invalid JSON value.\";\n throw new Error(`Invalid config value for \"${key}\": ${message}`);\n }\n}\n\nfunction parseJsonValue(value: unknown, key: string): unknown {\n if (typeof value !== \"string\") {\n return value;\n }\n\n try {\n return JSON.parse(value);\n } catch {\n throw new Error(`Invalid config value for \"${key}\": expected valid JSON.`);\n }\n}\n", "import type { ConfigDocument } from \"./types.js\";\n\nexport function deepMergeDocuments(base: ConfigDocument, override: ConfigDocument): ConfigDocument {\n const merged: ConfigDocument = {};\n const scopes = new Set([...Object.keys(base), ...Object.keys(override)]);\n\n for (const scope of scopes) {\n const baseScope = base[scope] ?? {};\n const overrideScope = override[scope] ?? {};\n const nextScope = mergeScope(scope, baseScope, overrideScope);\n\n if (Object.keys(nextScope).length > 0) {\n merged[scope] = nextScope;\n }\n }\n\n return merged;\n}\n\nfunction mergeScope(\n scope: string,\n baseScope: Record<string, unknown>,\n overrideScope: Record<string, unknown>\n): Record<string, unknown> {\n if (scope === \"runtime\") {\n return mergeRuntimeScope(baseScope, overrideScope);\n }\n\n const scopeEntries = Object.entries(overrideScope).filter(([, value]) => value !== undefined);\n return {\n ...baseScope,\n ...Object.fromEntries(scopeEntries)\n };\n}\n\nfunction mergeRuntimeScope(\n baseScope: Record<string, unknown>,\n overrideScope: Record<string, unknown>,\n path: string[] = []\n): Record<string, unknown> {\n const merged: Record<string, unknown> = {};\n const keys = new Set([...Object.keys(baseScope), ...Object.keys(overrideScope)]);\n\n for (const key of keys) {\n const baseValue = baseScope[key];\n const overrideValue = overrideScope[key];\n if (overrideValue === undefined) {\n if (baseValue !== undefined) {\n merged[key] = baseValue;\n }\n continue;\n }\n\n if (\n isRuntimeConcatenativeArray([...path, key]) &&\n Array.isArray(baseValue) &&\n Array.isArray(overrideValue)\n ) {\n merged[key] = [...baseValue, ...overrideValue];\n continue;\n }\n\n if (isRecord(baseValue) && isRecord(overrideValue)) {\n merged[key] = mergeRuntimeScope(baseValue, overrideValue, [...path, key]);\n continue;\n }\n\n merged[key] = overrideValue;\n }\n\n return merged;\n}\n\nfunction isRuntimeConcatenativeArray(path: string[]): boolean {\n return path.join(\".\") === \"mounts\" || path.join(\".\") === \"runner.workspace.exclude\";\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value && typeof value === \"object\" && !Array.isArray(value));\n}\n", "import path from \"node:path\";\nimport { pathExists, type FileSystem } from \"@poe-code/config-mutations\";\nimport type { ConfigDocument, ConfigFieldType, ScopeDefinition, ScopeSchema } from \"./types.js\";\n\nexport interface EnvOverrides {\n entries: string[];\n document: ConfigDocument;\n}\n\nexport interface EditTargetOptions {\n global?: boolean;\n project?: boolean;\n}\n\nexport function collectEnvOverrides(\n scopes: ReadonlyArray<ScopeDefinition<ScopeSchema>>,\n env: Record<string, string | undefined>\n): EnvOverrides {\n const document: ConfigDocument = {};\n const entries: string[] = [];\n\n for (const definition of scopes) {\n const scopeResult = collectScopeEnvOverrides(definition, env);\n if (Object.keys(scopeResult.values).length === 0) {\n continue;\n }\n\n document[definition.scope] = scopeResult.values;\n entries.push(...scopeResult.entries);\n }\n\n return { entries, document };\n}\n\nexport async function resolveEditTarget(\n fs: FileSystem,\n configPath: string,\n projectConfigPath: string,\n options: EditTargetOptions\n): Promise<string> {\n if (options.global && options.project) {\n throw new Error(\"Choose either --global or --project, not both.\");\n }\n\n if (options.global) {\n return configPath;\n }\n if (options.project) {\n return projectConfigPath;\n }\n if (await pathExists(fs, projectConfigPath)) {\n return projectConfigPath;\n }\n return configPath;\n}\n\nexport async function initProjectConfig(\n fs: FileSystem,\n targetPath: string\n): Promise<\"created\" | \"already-exists\"> {\n if (await pathExists(fs, targetPath)) {\n return \"already-exists\";\n }\n\n await fs.mkdir(path.dirname(targetPath), { recursive: true });\n await fs.writeFile(targetPath, EMPTY_DOCUMENT, { encoding: \"utf8\" });\n return \"created\";\n}\n\nfunction collectScopeEnvOverrides<S extends ScopeSchema>(\n definition: ScopeDefinition<S>,\n env: Record<string, string | undefined>\n): {\n entries: string[];\n values: Record<string, unknown>;\n} {\n const entries: string[] = [];\n const values: Record<string, unknown> = {};\n\n for (const [key, field] of Object.entries(definition.schema) as Array<\n [keyof S & string, S[keyof S & string]]\n >) {\n if (!field.env) {\n continue;\n }\n\n const value = coerceEnvValue(field.type, env[field.env]);\n if (value === undefined) {\n continue;\n }\n\n values[key] = value;\n entries.push(` ${field.env} = ${String(value)}`);\n }\n\n return { entries, values };\n}\n\nfunction coerceEnvValue(\n type: ConfigFieldType,\n raw: string | undefined\n): unknown {\n if (raw === undefined) {\n return undefined;\n }\n\n if (type === \"string\") {\n return raw;\n }\n if (type === \"number\") {\n if (raw.length === 0) {\n return undefined;\n }\n const parsed = Number(raw);\n return Number.isNaN(parsed) ? undefined : parsed;\n }\n if (type === \"json\") {\n try {\n return JSON.parse(raw);\n } catch {\n return undefined;\n }\n }\n if (raw === \"true\" || raw === \"1\") {\n return true;\n }\n if (raw === \"false\" || raw === \"0\") {\n return false;\n }\n return undefined;\n}\n\nconst EMPTY_DOCUMENT = `${JSON.stringify({}, null, 2)}\\n`;\n", "import path from \"node:path\";\nimport { allAgents, resolveAgentId, type AgentDefinition } from \"@poe-code/agent-defs\";\nimport { createTimestamp, readFileIfExists, type FileSystem } from \"@poe-code/config-mutations\";\nimport {\n anthropicProvider,\n cloudflareProvider,\n poeProvider,\n ProviderRegistry,\n resolveApiShape,\n type ApiShapeId\n} from \"@poe-code/providers\";\nimport { readDocument, readMergedDocument, writeScope } from \"./store.js\";\n\nexport interface ConfigStoreOptions {\n fs: FileSystem;\n filePath: string;\n projectFilePath?: string;\n providerRegistry?: Pick<ProviderRegistry, \"get\">;\n warn?: (message: string) => void;\n}\n\nexport interface ConfiguredServiceMetadata {\n provider: string;\n apiShape?: ApiShapeId;\n files: string[];\n}\n\ninterface LegacyConfigDocument {\n apiKey?: string;\n configured_services?: Record<string, ConfiguredServiceMetadata>;\n}\n\nexport interface SaveConfiguredServiceOptions extends ConfigStoreOptions {\n service: string;\n metadata: ConfiguredServiceMetadata;\n}\n\nexport interface UnconfigureServiceOptions extends ConfigStoreOptions {\n service: string;\n}\n\nexport async function loadConfiguredServices(\n options: ConfigStoreOptions\n): Promise<Record<string, ConfiguredServiceMetadata>> {\n const { fs, filePath, projectFilePath } = options;\n await migrateLegacyCredentialsIfNeeded(fs, filePath);\n await migrateConfiguredServicesIfNeeded(options, filePath);\n if (projectFilePath && projectFilePath !== filePath) {\n await migrateConfiguredServicesIfNeeded(options, projectFilePath);\n }\n\n const document = await readMergedDocument(fs, filePath, projectFilePath);\n return normalizeConfiguredServices(document[configuredServicesScope]);\n}\n\nexport async function saveConfiguredService(options: SaveConfiguredServiceOptions): Promise<void> {\n const { fs, filePath, service, metadata } = options;\n await migrateLegacyCredentialsIfNeeded(fs, filePath);\n await migrateConfiguredServicesIfNeeded(options, filePath);\n\n const document = await readDocument(fs, filePath);\n const services = normalizeConfiguredServices(document[configuredServicesScope]);\n const registry = options.providerRegistry ?? defaultProviderRegistry;\n services[service] = normalizeConfiguredServiceMetadata({\n ...metadata,\n apiShape:\n metadata.apiShape ??\n deriveApiShape({\n service,\n provider: metadata.provider,\n registry,\n warn: options.warn ?? console.warn\n })\n });\n\n await writeScope(fs, filePath, configuredServicesScope, services);\n}\n\nexport async function unconfigureService(options: UnconfigureServiceOptions): Promise<boolean> {\n const { fs, filePath, service } = options;\n await migrateLegacyCredentialsIfNeeded(fs, filePath);\n\n const document = await readDocument(fs, filePath);\n const services = normalizeConfiguredServices(document[configuredServicesScope]);\n\n if (!(service in services)) {\n return false;\n }\n\n delete services[service];\n await writeScope(fs, filePath, configuredServicesScope, services);\n return true;\n}\n\nasync function migrateConfiguredServicesIfNeeded(\n options: ConfigStoreOptions,\n filePath: string\n): Promise<void> {\n const document = await readDocument(options.fs, filePath);\n const rawServices = document[configuredServicesScope];\n if (!isRecord(rawServices)) {\n return;\n }\n\n let needsMigration = false;\n const migrated: Record<string, unknown> = {};\n const registry = options.providerRegistry ?? defaultProviderRegistry;\n\n for (const [service, entry] of Object.entries(rawServices)) {\n if (!isRecord(entry)) {\n continue;\n }\n\n const provider = typeof entry.provider === \"string\" ? entry.provider : \"poe\";\n const normalizedEntry: Record<string, unknown> = {\n ...entry,\n provider\n };\n\n if (typeof entry.provider !== \"string\") {\n needsMigration = true;\n }\n\n if (typeof entry.apiShape !== \"string\") {\n const apiShape = deriveApiShape({\n service,\n provider,\n registry,\n warn: options.warn ?? console.warn\n });\n if (apiShape) {\n normalizedEntry.apiShape = apiShape;\n needsMigration = true;\n }\n }\n\n migrated[service] = normalizedEntry;\n }\n\n if (needsMigration) {\n await writeScope(options.fs, filePath, configuredServicesScope, migrated);\n }\n}\n\nfunction deriveApiShape(input: {\n service: string;\n provider: string;\n registry: Pick<ProviderRegistry, \"get\">;\n warn: (message: string) => void;\n}): ApiShapeId | undefined {\n const provider = input.registry.get(input.provider);\n const agent = resolveConfiguredAgent(input.service);\n const apiShape = provider && agent ? resolveApiShape(provider, agent) : undefined;\n if (!apiShape) {\n input.warn(\n `Unable to derive apiShape for configured service \"${input.service}\" with provider \"${input.provider}\".`\n );\n }\n return apiShape;\n}\n\nfunction resolveConfiguredAgent(service: string): AgentDefinition | undefined {\n const agentId = resolveAgentId(service);\n return agentId ? agentsById.get(agentId) : undefined;\n}\n\nfunction normalizeConfiguredServices(value: unknown): Record<string, ConfiguredServiceMetadata> {\n if (!isRecord(value)) {\n return {};\n }\n\n const entries: Record<string, ConfiguredServiceMetadata> = {};\n for (const [key, entry] of Object.entries(value)) {\n if (!isRecord(entry)) {\n continue;\n }\n\n entries[key] = normalizeConfiguredServiceMetadata({\n provider: typeof entry.provider === \"string\" ? entry.provider : \"poe\",\n apiShape: typeof entry.apiShape === \"string\" ? (entry.apiShape as ApiShapeId) : undefined,\n files: Array.isArray(entry.files) ? entry.files : []\n });\n }\n\n return entries;\n}\n\nfunction normalizeConfiguredServiceMetadata(\n metadata: ConfiguredServiceMetadata\n): ConfiguredServiceMetadata {\n const seen = new Set<string>();\n const files: string[] = [];\n\n for (const entry of metadata.files ?? []) {\n if (typeof entry !== \"string\" || entry.length === 0) {\n continue;\n }\n if (!seen.has(entry)) {\n files.push(entry);\n seen.add(entry);\n }\n }\n\n return omitUndefined({\n provider: metadata.provider,\n apiShape: metadata.apiShape,\n files\n });\n}\n\nasync function migrateLegacyCredentialsIfNeeded(fs: FileSystem, filePath: string): Promise<void> {\n const currentRaw = await readFileIfExists(fs, filePath);\n if (currentRaw !== null) {\n return;\n }\n\n await migrateLegacyCredentialsFile(fs, filePath);\n}\n\nasync function migrateLegacyCredentialsFile(fs: FileSystem, configPath: string): Promise<void> {\n const legacyPath = path.join(path.dirname(configPath), \"credentials.json\");\n const raw = await readFileIfExists(fs, legacyPath);\n if (raw === null) {\n return;\n }\n\n let legacyDocument: LegacyConfigDocument;\n try {\n legacyDocument = normalizeLegacyConfigDocument(JSON.parse(raw));\n } catch (error) {\n if (error instanceof SyntaxError) {\n await recoverInvalidConfig(fs, legacyPath, raw);\n await fs.unlink(legacyPath);\n return;\n }\n throw error;\n }\n\n if (legacyDocument.configured_services) {\n await writeScope(fs, configPath, configuredServicesScope, legacyDocument.configured_services);\n }\n\n if (legacyDocument.apiKey) {\n await writeScope(fs, configPath, CORE_SCOPE, {\n apiKey: legacyDocument.apiKey\n });\n }\n\n await fs.unlink(legacyPath);\n}\n\nfunction normalizeLegacyConfigDocument(value: unknown): LegacyConfigDocument {\n if (!isRecord(value)) {\n return {};\n }\n\n const document: LegacyConfigDocument = {};\n if (typeof value.apiKey === \"string\" && value.apiKey.length > 0) {\n document.apiKey = value.apiKey;\n }\n\n const services = normalizeConfiguredServices(value.configured_services);\n if (Object.keys(services).length > 0) {\n document.configured_services = services;\n }\n\n return document;\n}\n\nasync function recoverInvalidConfig(\n fs: FileSystem,\n filePath: string,\n content: string\n): Promise<void> {\n const backupPath = createInvalidBackupPath(filePath);\n await fs.writeFile(backupPath, content, { encoding: \"utf8\" });\n await fs.writeFile(filePath, EMPTY_DOCUMENT, { encoding: \"utf8\" });\n}\n\nfunction createInvalidBackupPath(filePath: string): string {\n const directory = path.dirname(filePath);\n const baseName = path.basename(filePath);\n return path.join(directory, `${baseName}.invalid-${createTimestamp()}.json`);\n}\n\nfunction omitUndefined<T extends Record<string, unknown>>(value: T): T {\n return Object.fromEntries(Object.entries(value).filter(([, entry]) => entry !== undefined)) as T;\n}\n\nfunction isRecord(value: unknown): value is Record<string, any> {\n return Boolean(value && typeof value === \"object\" && !Array.isArray(value));\n}\n\nconst agentsById = new Map(allAgents.map((agent) => [agent.id, agent]));\nconst defaultProviderRegistry = new ProviderRegistry([\n poeProvider,\n anthropicProvider,\n cloudflareProvider\n]);\nconst CORE_SCOPE = \"core\";\nconst configuredServicesScope = \"configured_services\";\nconst EMPTY_DOCUMENT = `${JSON.stringify({}, null, 2)}\\n`;\n", "import type { ApiKeyAuth, AuthProvider } from \"../types.js\";\nimport type { AuthStrategy, AuthStrategyContext } from \"./types.js\";\n\nexport interface ApiKeyLoginOptions {\n apiKey?: string;\n}\n\nfunction requireApiKeyAuth(provider: AuthProvider): ApiKeyAuth {\n if (provider.auth.kind !== \"api-key\") {\n throw new Error(\n `Provider ${provider.id} does not use api-key auth (got ${provider.auth.kind}).`\n );\n }\n return provider.auth;\n}\n\nasync function acquireApiKey(\n provider: AuthProvider,\n options: ApiKeyLoginOptions,\n context: AuthStrategyContext\n): Promise<string> {\n const auth = requireApiKeyAuth(provider);\n const candidate =\n options.apiKey ?? (await context.promptForSecret?.(auth.prompt));\n const trimmed = candidate?.trim();\n if (!trimmed) {\n throw new Error(\n `No API key available for provider \"${provider.id}\". Pass --api-key or run interactively.`\n );\n }\n return trimmed;\n}\n\nexport const apiKeyAuthStrategy: AuthStrategy<ApiKeyLoginOptions> = {\n async login(provider, options, context) {\n const apiKey = await acquireApiKey(provider, options, context);\n await context.secretStore.set(apiKey);\n return apiKey;\n },\n\n async logout(_provider, context) {\n await context.secretStore.delete();\n },\n\n async isLoggedIn(_provider, context) {\n const value = await context.secretStore.get();\n return typeof value === \"string\" && value.trim().length > 0;\n },\n\n async resolveCredential(provider, context) {\n requireApiKeyAuth(provider);\n const value = await context.secretStore.get();\n if (!value || value.trim().length === 0) {\n throw new Error(\n `No stored credential for provider \"${provider.id}\". Run \\`poe-code provider login ${provider.id}\\`.`\n );\n }\n return value;\n }\n};\n", "import type { ApiShapeId, AuthProvider } from \"./types.js\";\n\nexport function resolveApiShape(\n provider: AuthProvider,\n agent: { apiShapes?: readonly ApiShapeId[] }\n): ApiShapeId | undefined {\n if (!provider.apiShapes || !agent.apiShapes) {\n return undefined;\n }\n for (const shapeId of agent.apiShapes) {\n if (provider.apiShapes.some((shape) => shape.id === shapeId)) {\n return shapeId;\n }\n }\n return undefined;\n}\n", "import type { ApiShapeId, AuthProvider } from \"./types.js\";\nimport type { SecretStore } from \"auth-store\";\nimport { apiKeyAuthStrategy } from \"./auth/api-key.js\";\nimport type { ApiKeyLoginOptions } from \"./auth/api-key.js\";\nimport type { PromptForSecret } from \"./auth/types.js\";\nimport { resolveApiShape } from \"./compatibility.js\";\n\nexport interface LoginContext {\n promptForSecret?: PromptForSecret;\n envVars?: Record<string, string | undefined>;\n resolvePreferredLogin?: (input: {\n provider: AuthProvider;\n apiKey?: string;\n envValue?: string;\n }) => Promise<string>;\n}\n\nexport type ProviderStoreFactory = (providerId: string) => SecretStore;\n\nexport interface ProviderRegistryOptions {\n envVars?: Record<string, string | undefined>;\n}\n\nexport interface ProviderAgent {\n id: string;\n apiShapes?: readonly ApiShapeId[];\n}\n\nexport class ProviderRegistry {\n private readonly providers: readonly AuthProvider[];\n private readonly byId: ReadonlyMap<string, AuthProvider>;\n private readonly storeFactory?: ProviderStoreFactory;\n private readonly envVars: Record<string, string | undefined>;\n\n constructor(\n providers: readonly AuthProvider[],\n storeFactory?: ProviderStoreFactory,\n options?: ProviderRegistryOptions\n ) {\n const byId = new Map<string, AuthProvider>();\n for (const provider of providers) {\n if (byId.has(provider.id)) {\n throw new Error(`Duplicate provider id: ${provider.id}`);\n }\n byId.set(provider.id, provider);\n }\n this.providers = providers;\n this.byId = byId;\n this.storeFactory = storeFactory;\n this.envVars = options?.envVars ?? {};\n }\n\n list(): readonly AuthProvider[] {\n return this.providers;\n }\n\n get(id: string): AuthProvider | undefined {\n return this.byId.get(id);\n }\n\n forAgent(agent: ProviderAgent): readonly AuthProvider[] {\n return this.providers.filter((provider) => {\n return resolveApiShape(provider, agent) !== undefined;\n });\n }\n\n async isLoggedIn(id: string): Promise<boolean> {\n const provider = this.requireProvider(id);\n if (provider.auth.kind === \"api-key\") {\n const envValue = this.envVars[provider.auth.envVar];\n if (typeof envValue === \"string\" && envValue.trim().length > 0) {\n return true;\n }\n }\n const store = this.requireStore(id);\n const credential = await store.get();\n return credential !== null;\n }\n\n async login(id: string, options: ApiKeyLoginOptions, context?: LoginContext): Promise<void> {\n const provider = this.requireProvider(id);\n const store = this.requireStore(id);\n if (provider.auth.kind !== \"api-key\") {\n throw new Error(`Provider \"${id}\" does not use api-key auth.`);\n }\n const auth = provider.auth;\n const envApiKey = context?.envVars?.[auth.envVar];\n const resolvedApiKey =\n options.apiKey ??\n (typeof envApiKey === \"string\" && envApiKey.trim() ? envApiKey : undefined);\n if (auth.preferredLogin && context?.resolvePreferredLogin) {\n const apiKey = await context.resolvePreferredLogin({\n provider,\n apiKey: options.apiKey,\n envValue: typeof envApiKey === \"string\" ? envApiKey : undefined\n });\n await store.set(apiKey);\n return;\n }\n await apiKeyAuthStrategy.login(\n provider,\n { apiKey: resolvedApiKey },\n { secretStore: store, promptForSecret: context?.promptForSecret }\n );\n }\n\n async resolveCredential(\n id: string,\n options: ApiKeyLoginOptions = {},\n context?: Pick<LoginContext, \"envVars\">\n ): Promise<string> {\n const provider = this.requireProvider(id);\n if (provider.auth.kind !== \"api-key\") {\n throw new Error(`Provider \"${id}\" does not use api-key auth.`);\n }\n\n if (options.apiKey !== undefined) {\n return normalizeRequiredCredential(provider.id, options.apiKey);\n }\n\n const envVars = context?.envVars ?? this.envVars;\n const envApiKey = envVars[provider.auth.envVar];\n if (typeof envApiKey === \"string\" && envApiKey.trim().length > 0) {\n return envApiKey.trim();\n }\n\n const store = this.requireStore(id);\n return apiKeyAuthStrategy.resolveCredential(provider, { secretStore: store });\n }\n\n async logout(id: string): Promise<void> {\n this.requireProvider(id);\n const store = this.requireStore(id);\n await store.delete();\n }\n\n private requireProvider(id: string): AuthProvider {\n const provider = this.byId.get(id);\n if (!provider) {\n throw new Error(`Unknown provider: \"${id}\".`);\n }\n return provider;\n }\n\n private requireStore(id: string): SecretStore {\n if (!this.storeFactory) {\n throw new Error(`No store factory configured for ProviderRegistry.`);\n }\n return this.storeFactory(id);\n }\n}\n\nfunction normalizeRequiredCredential(providerId: string, value: string): string {\n const trimmed = value.trim();\n if (trimmed.length === 0) {\n throw new Error(`No API key available for provider \"${providerId}\".`);\n }\n return trimmed;\n}\n", "import type { AuthProvider } from \"../types.js\";\n\nexport const POE_PROVIDER_ID = \"poe\" as const;\n\nexport const poeProvider: AuthProvider = {\n id: POE_PROVIDER_ID,\n label: \"Poe\",\n summary: \"Route AI coding agents through Poe's API.\",\n baseUrl: \"https://api.poe.com\",\n auth: {\n kind: \"api-key\",\n envVar: \"POE_API_KEY\",\n storageKey: \"provider:poe\",\n prompt: { title: \"Poe API key\" },\n preferredLogin: \"oauth\"\n },\n apiShapes: [\n {\n id: \"openai-chat-completions\",\n defaultBaseUrl: \"https://api.poe.com/v1\"\n },\n {\n id: \"openai-responses\",\n defaultBaseUrl: \"https://api.poe.com/v1\"\n },\n {\n id: \"anthropic-messages\",\n defaultBaseUrl: \"https://api.poe.com/anthropic\"\n }\n ]\n};\n", "import type { AuthProvider } from \"../types.js\";\n\nexport const anthropicProvider: AuthProvider = {\n id: \"anthropic\",\n label: \"Anthropic\",\n summary: \"Route AI coding agents through Anthropic's API.\",\n baseUrl: \"https://api.anthropic.com\",\n auth: {\n kind: \"api-key\",\n envVar: \"ANTHROPIC_API_KEY\",\n storageKey: \"provider:anthropic\",\n prompt: { title: \"Anthropic API key\" }\n },\n apiShapes: [\n {\n id: \"anthropic-messages\",\n defaultBaseUrl: \"https://api.anthropic.com\"\n }\n ]\n};\n", "import type { AuthProvider } from \"../types.js\";\n\nexport const cloudflareProvider: AuthProvider = {\n id: \"cloudflare\",\n label: \"Cloudflare AI Gateway\",\n summary: \"Route coding agents through Cloudflare AI Gateway.\",\n baseUrlEnvVar: \"CF_AIG_BASE_URL\",\n requiresBaseUrl: true,\n modelInput: { kind: \"freeform\" },\n auth: {\n kind: \"api-key\",\n envVar: \"CF_AIG_TOKEN\",\n storageKey: \"provider:cloudflare\",\n prompt: { title: \"Cloudflare AI Gateway token\" }\n },\n apiShapes: [\n {\n id: \"openai-chat-completions\",\n baseUrlPath: \"compat\"\n },\n {\n id: \"openai-responses\",\n baseUrlPath: \"openai\"\n },\n {\n id: \"anthropic-messages\",\n baseUrlPath: \"anthropic\"\n },\n {\n id: \"google-generations\",\n baseUrlPath: \"google-ai-studio\"\n }\n ]\n};\n", "import os from \"node:os\";\nimport { createJobRegistry, type JobRegistry } from \"./jobs.js\";\nimport { createTemplateRegistry, type TemplateRegistry } from \"./templates.js\";\nimport type { StateFileSystem } from \"./fs.js\";\n\nexport interface StateManager {\n templates: TemplateRegistry;\n jobs: JobRegistry;\n}\n\nexport async function loadStateManager(homeDir: string = os.homedir()): Promise<StateManager> {\n return {\n templates: createTemplateRegistry(homeDir),\n jobs: createJobRegistry(homeDir)\n };\n}\n\nexport function createStateManager(homeDir: string, fs?: StateFileSystem): StateManager {\n return {\n templates: createTemplateRegistry(homeDir, fs),\n jobs: createJobRegistry(homeDir, fs)\n };\n}\n\nexport {\n createJobRegistry,\n type JobEntry,\n type JobListFilter,\n type JobRegistry,\n type JobStatus\n} from \"./jobs.js\";\nexport {\n createTemplateRegistry,\n type TemplateBackend,\n type TemplateEntry,\n type TemplateRegistry\n} from \"./templates.js\";\nexport type { StateFileSystem } from \"./fs.js\";\n", "import path from \"node:path\";\nimport { acquireFileLock, type FileLockFs } from \"@poe-code/file-lock\";\nimport { defaultStateFs, isNotFoundError, type StateFileSystem } from \"./fs.js\";\n\nexport type JobStatus = \"pending\" | \"running\" | \"exited\" | \"killed\" | \"lost\";\n\nexport interface JobEntry {\n id: string;\n env_id: string;\n env_kind: string;\n tool: string;\n argv: string[];\n cwd: string;\n started_at: string;\n status: JobStatus;\n exit_code?: number;\n exited_at?: string;\n log_file?: string;\n}\n\nexport interface JobListFilter {\n env_id?: string;\n env_kind?: string;\n tool?: string;\n status?: JobStatus;\n}\n\nexport interface JobRegistry {\n get(id: string): Promise<JobEntry | null>;\n put(entry: JobEntry): Promise<void>;\n update(id: string, patch: Partial<JobEntry>): Promise<JobEntry | null>;\n list(filter?: JobListFilter): Promise<JobEntry[]>;\n remove(id: string): Promise<void>;\n}\n\nexport function createJobRegistry(\n homeDir: string,\n fs: StateFileSystem = defaultStateFs\n): JobRegistry {\n const jobsDir = path.join(homeDir, \".poe-code\", \"state\", \"jobs\");\n\n function jobPath(id: string): string {\n assertSafeJobId(id);\n return path.join(jobsDir, `${id}.json`);\n }\n\n async function get(id: string): Promise<JobEntry | null> {\n try {\n return parseJobEntry(await fs.readFile(jobPath(id), \"utf8\"));\n } catch (error) {\n if (isNotFoundError(error)) {\n return null;\n }\n\n throw error;\n }\n }\n\n async function put(entry: JobEntry): Promise<void> {\n assertJobEntry(entry);\n const filePath = jobPath(entry.id);\n await fs.mkdir(jobsDir, { recursive: true });\n const release = await acquireFileLock(filePath, { fs: fs as unknown as FileLockFs });\n try {\n await writeJobAtomically(filePath, entry);\n } finally {\n await release();\n }\n }\n\n async function update(id: string, patch: Partial<JobEntry>): Promise<JobEntry | null> {\n const filePath = jobPath(id);\n await fs.mkdir(jobsDir, { recursive: true });\n const release = await acquireFileLock(filePath, { fs: fs as unknown as FileLockFs });\n try {\n const current = await get(id);\n if (current === null) {\n return null;\n }\n\n const updated = {\n ...current,\n ...patch,\n id: current.id\n };\n assertJobEntry(updated);\n await writeJobAtomically(filePath, updated);\n return updated;\n } finally {\n await release();\n }\n }\n\n async function list(filter: JobListFilter = {}): Promise<JobEntry[]> {\n let entries: string[];\n\n try {\n entries = await fs.readdir(jobsDir);\n } catch (error) {\n if (isNotFoundError(error)) {\n return [];\n }\n\n throw error;\n }\n\n const jobs: JobEntry[] = [];\n for (const entry of entries.sort()) {\n if (!entry.endsWith(\".json\")) {\n continue;\n }\n\n const filePath = path.join(jobsDir, entry);\n const stat = await fs.stat(filePath);\n if (!stat.isFile()) {\n continue;\n }\n\n const job = parseJobEntry(await fs.readFile(filePath, \"utf8\"));\n if (matchesFilter(job, filter)) {\n jobs.push(job);\n }\n }\n return jobs;\n }\n\n async function remove(id: string): Promise<void> {\n const filePath = jobPath(id);\n try {\n await fs.stat(jobsDir);\n } catch (error) {\n if (isNotFoundError(error)) {\n return;\n }\n\n throw error;\n }\n\n const release = await acquireFileLock(filePath, { fs: fs as unknown as FileLockFs });\n try {\n await fs.unlink(filePath);\n } catch (error) {\n if (!isNotFoundError(error)) {\n throw error;\n }\n } finally {\n await release();\n }\n }\n\n async function writeJobAtomically(filePath: string, entry: JobEntry): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n const tempPath = `${filePath}.${process.pid}.${Date.now()}.${Math.random()\n .toString(36)\n .slice(2)}.tmp`;\n\n try {\n await fs.writeFile(tempPath, `${JSON.stringify(entry, null, 2)}\\n`, {\n encoding: \"utf8\"\n });\n await fs.rename(tempPath, filePath);\n } catch (error) {\n await removeTempFile(tempPath);\n throw error;\n }\n }\n\n async function removeTempFile(tempPath: string): Promise<void> {\n try {\n await fs.unlink(tempPath);\n } catch (error) {\n if (!isNotFoundError(error)) {\n throw error;\n }\n }\n }\n\n return {\n get,\n put,\n update,\n list,\n remove\n };\n}\n\nfunction assertSafeJobId(id: string): void {\n if (\n id.length === 0 ||\n id === \".\" ||\n id === \"..\" ||\n path.isAbsolute(id) ||\n id.includes(\"/\") ||\n id.includes(\"\\\\\") ||\n id.includes(\"\\0\")\n ) {\n throw new Error(\"Invalid job id.\");\n }\n}\n\nfunction assertJobEntry(entry: JobEntry): void {\n if (!isJobEntry(entry)) {\n throw new Error(\"Invalid job entry.\");\n }\n}\n\nfunction matchesFilter(job: JobEntry, filter: JobListFilter): boolean {\n return (\n (filter.env_id === undefined || job.env_id === filter.env_id) &&\n (filter.env_kind === undefined || job.env_kind === filter.env_kind) &&\n (filter.tool === undefined || job.tool === filter.tool) &&\n (filter.status === undefined || job.status === filter.status)\n );\n}\n\nfunction parseJobEntry(content: string): JobEntry {\n const parsed = JSON.parse(content) as unknown;\n if (!isJobEntry(parsed)) {\n throw new Error(\"Invalid job state file.\");\n }\n return parsed;\n}\n\nfunction isJobEntry(value: unknown): value is JobEntry {\n return (\n isRecord(value) &&\n typeof value.id === \"string\" &&\n typeof value.env_id === \"string\" &&\n typeof value.env_kind === \"string\" &&\n typeof value.tool === \"string\" &&\n Array.isArray(value.argv) &&\n value.argv.every((arg) => typeof arg === \"string\") &&\n typeof value.cwd === \"string\" &&\n typeof value.started_at === \"string\" &&\n isJobStatus(value.status) &&\n (value.exit_code === undefined || typeof value.exit_code === \"number\") &&\n (value.exited_at === undefined || typeof value.exited_at === \"string\") &&\n (value.log_file === undefined || typeof value.log_file === \"string\")\n );\n}\n\nfunction isJobStatus(value: unknown): value is JobStatus {\n return (\n value === \"pending\" ||\n value === \"running\" ||\n value === \"exited\" ||\n value === \"killed\" ||\n value === \"lost\"\n );\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value && typeof value === \"object\" && !Array.isArray(value));\n}\n\nexport type { StateFileSystem } from \"./fs.js\";\n", "import * as nodeFs from \"node:fs/promises\";\n\nexport interface StateFileSystem {\n mkdir(path: string, options: { recursive: true }): Promise<unknown>;\n readFile(path: string, encoding: BufferEncoding): Promise<string>;\n writeFile(\n path: string,\n data: string,\n options?: BufferEncoding | { encoding?: BufferEncoding }\n ): Promise<void>;\n rename(oldPath: string, newPath: string): Promise<void>;\n readdir(path: string): Promise<string[]>;\n stat(path: string): Promise<{\n isFile(): boolean;\n mtimeMs: number;\n }>;\n unlink(path: string): Promise<void>;\n open(path: string, flags: string): Promise<{\n close(): Promise<void>;\n writeFile(\n data: string,\n options?: BufferEncoding | { encoding?: BufferEncoding }\n ): Promise<void>;\n }>;\n}\n\nexport const defaultStateFs = nodeFs as unknown as StateFileSystem;\n\nexport function isNotFoundError(error: unknown): boolean {\n return error instanceof Error && \"code\" in error && error.code === \"ENOENT\";\n}\n", "import path from \"node:path\";\nimport { acquireFileLock, type FileLockFs } from \"@poe-code/file-lock\";\nimport { defaultStateFs, isNotFoundError, type StateFileSystem } from \"./fs.js\";\n\nexport type TemplateBackend = \"docker\" | \"e2b\";\n\nexport interface TemplateEntry {\n hash: string;\n template_id?: string;\n image?: string;\n runtime_type: string;\n dockerfile_path: string;\n built_at: string;\n}\n\ntype TemplateState = Record<TemplateBackend, Record<string, TemplateEntry>>;\n\nexport interface TemplateRegistry {\n get(backend: TemplateBackend, hash: string): Promise<TemplateEntry | null>;\n put(backend: TemplateBackend, entry: TemplateEntry): Promise<void>;\n remove(backend: TemplateBackend, hash: string): Promise<void>;\n list(backend?: TemplateBackend): Promise<TemplateEntry[]>;\n}\n\nexport function createTemplateRegistry(\n homeDir: string,\n fs: StateFileSystem = defaultStateFs\n): TemplateRegistry {\n const filePath = path.join(homeDir, \".poe-code\", \"state\", \"templates.json\");\n\n async function readState(): Promise<TemplateState> {\n try {\n const raw = await fs.readFile(filePath, \"utf8\");\n return normalizeTemplateState(JSON.parse(raw));\n } catch (error) {\n if (isNotFoundError(error)) {\n return createEmptyState();\n }\n\n throw error;\n }\n }\n\n async function writeState(state: TemplateState): Promise<void> {\n await fs.writeFile(filePath, `${JSON.stringify(state, null, 2)}\\n`, {\n encoding: \"utf8\"\n });\n }\n\n async function updateState(mutator: (state: TemplateState) => void): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n const release = await acquireFileLock(filePath, { fs: fs as unknown as FileLockFs });\n try {\n const state = await readState();\n mutator(state);\n await writeState(state);\n } finally {\n await release();\n }\n }\n\n async function get(backend: TemplateBackend, hash: string): Promise<TemplateEntry | null> {\n const state = await readState();\n return state[backend][hash] ?? null;\n }\n\n async function put(backend: TemplateBackend, entry: TemplateEntry): Promise<void> {\n await updateState((state) => {\n state[backend][entry.hash] = entry;\n });\n }\n\n async function remove(backend: TemplateBackend, hash: string): Promise<void> {\n await updateState((state) => {\n delete state[backend][hash];\n });\n }\n\n async function list(backend?: TemplateBackend): Promise<TemplateEntry[]> {\n const state = await readState();\n const entries =\n backend === undefined\n ? [...Object.values(state.docker), ...Object.values(state.e2b)]\n : Object.values(state[backend]);\n\n return entries.sort((left, right) => left.hash.localeCompare(right.hash));\n }\n\n return {\n get,\n put,\n remove,\n list\n };\n}\n\nfunction createEmptyState(): TemplateState {\n return {\n docker: {},\n e2b: {}\n };\n}\n\nfunction normalizeTemplateState(value: unknown): TemplateState {\n if (!isRecord(value)) {\n return createEmptyState();\n }\n\n return {\n docker: normalizeTemplateEntries(value.docker),\n e2b: normalizeTemplateEntries(value.e2b)\n };\n}\n\nfunction normalizeTemplateEntries(value: unknown): Record<string, TemplateEntry> {\n if (!isRecord(value)) {\n return {};\n }\n\n const entries: Record<string, TemplateEntry> = {};\n for (const [hash, entry] of Object.entries(value)) {\n if (isTemplateEntry(entry) && entry.hash === hash) {\n entries[hash] = entry;\n }\n }\n return entries;\n}\n\nfunction isTemplateEntry(value: unknown): value is TemplateEntry {\n return (\n isRecord(value) &&\n typeof value.hash === \"string\" &&\n typeof value.runtime_type === \"string\" &&\n typeof value.dockerfile_path === \"string\" &&\n typeof value.built_at === \"string\" &&\n (value.template_id === undefined || typeof value.template_id === \"string\") &&\n (value.image === undefined || typeof value.image === \"string\")\n );\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value && typeof value === \"object\" && !Array.isArray(value));\n}\n\nexport type { StateFileSystem } from \"./fs.js\";\n", "import type { RunnerScope, RuntimeConfig } from \"@poe-code/poe-code-config\";\nimport type { RunHandle, Runner, RunSpec } from \"@poe-code/process-runner\";\nimport type { StateManager } from \"@poe-code/poe-code-config\";\n\nexport type { RuntimeConfig } from \"@poe-code/poe-code-config\";\nexport type { RunHandle, RunSpec } from \"@poe-code/process-runner\";\n\nexport type ExecutionEnvType = \"host\" | \"docker\" | \"e2b\";\nexport type JobStatus = \"running\" | \"exited\" | \"killed\" | \"lost\";\n\nexport interface ExecutionEnvFactory {\n readonly type: ExecutionEnvType;\n readonly supportsDetach?: boolean;\n open(spec: OpenSpec): Promise<OpenedEnv>;\n attach(envId: string, context?: AttachedJobContext): Promise<OpenedEnv>;\n}\n\nexport interface OpenSpec {\n cwd: string;\n runtimeCwd?: string;\n runtime: RuntimeConfig;\n runner?: RunnerScope;\n state?: StateManager;\n hostRunner?: Runner;\n env: Record<string, string>;\n uploadIgnoreFiles: string[];\n jobLabel: { tool: string; argv: string[] };\n execution?: {\n wrapForLogTee?: boolean;\n stdin?: RunSpec[\"stdin\"];\n stdout?: RunSpec[\"stdout\"];\n stderr?: RunSpec[\"stderr\"];\n env?: RunSpec[\"env\"];\n tty?: boolean;\n input?: string | Buffer;\n captureOutput?: boolean;\n activityTimeoutMs?: number;\n onStdout?(chunk: string): void;\n onStderr?(chunk: string): void;\n };\n shellSpec?: RunSpec;\n}\n\nexport interface UploadResult {\n files: number;\n bytes: number;\n skipped: { path: string; bytes: number; reason: \"max_size\" }[];\n}\n\nexport interface DownloadResult {\n files: number;\n bytes: number;\n conflicts: { path: string; reason: \"local_modified\" }[];\n}\n\nexport interface LogChunk {\n byteOffset: number;\n data: string;\n}\n\nexport interface AttachedJobContext {\n jobId: string;\n tool: string;\n argv: string[];\n cwd: string;\n}\n\nexport interface OpenedEnv {\n readonly id: string;\n readonly job: JobHandle | null;\n uploadWorkspace(): Promise<UploadResult>;\n downloadWorkspace(opts: { conflictPolicy: \"refuse\" | \"overwrite\" }): Promise<DownloadResult>;\n exec(spec: RunSpec): RunHandle;\n detach(): Promise<JobHandle>;\n shell(): RunHandle;\n close(): Promise<void>;\n}\n\nexport interface JobHandle {\n readonly id: string;\n readonly envId: string;\n readonly tool: string;\n readonly argv: string[];\n status(): Promise<JobStatus>;\n stream(opts?: { sinceByte?: number; since?: Date }): AsyncIterable<LogChunk>;\n wait(): Promise<{ exitCode: number }>;\n kill(signal?: NodeJS.Signals): Promise<void>;\n}\n\nconst executionEnvFactories = new Map<ExecutionEnvType, ExecutionEnvFactory>();\n\nexport function registerExecutionEnvFactory(factory: ExecutionEnvFactory): void {\n executionEnvFactories.set(factory.type, factory);\n}\n\nexport function selectExecutionEnv(runtime: RuntimeConfig): ExecutionEnvFactory {\n return selectExecutionEnvFactory(runtime.type);\n}\n\nexport function selectExecutionEnvFactory(type: ExecutionEnvType): ExecutionEnvFactory {\n const factory = executionEnvFactories.get(type);\n if (factory === undefined) {\n throw new Error(\n `No execution environment factory registered for runtime type \"${type}\".`\n );\n }\n return factory;\n}\n", "import { createHash } from \"node:crypto\";\nimport { promises as nodeFs } from \"node:fs\";\nimport path from \"node:path\";\nimport type { RunnerScope } from \"@poe-code/poe-code-config\";\nimport type { DownloadResult, UploadResult } from \"./execution-env.js\";\n\nexport type { DownloadResult, UploadResult } from \"./execution-env.js\";\n\nexport interface WorkspaceTransferDirent {\n name: string;\n isFile(): boolean;\n isDirectory(): boolean;\n}\n\nexport interface WorkspaceTransferStats {\n isFile(): boolean;\n isDirectory(): boolean;\n size: number;\n}\n\nexport interface WorkspaceTransferFileSystem {\n mkdir(path: string, options?: { recursive?: boolean }): Promise<void>;\n readdir(path: string, options: { withFileTypes: true }): Promise<WorkspaceTransferDirent[]>;\n readFile(path: string): Promise<Buffer>;\n readFile(path: string, encoding: BufferEncoding): Promise<string>;\n writeFile(path: string, data: string | Buffer): Promise<void>;\n stat(path: string): Promise<WorkspaceTransferStats>;\n rm?(path: string, options?: { recursive?: boolean; force?: boolean }): Promise<void>;\n unlink?(path: string): Promise<void>;\n rmdir?(path: string): Promise<void>;\n}\n\nexport interface WorkspaceTransferEnv {\n cwd: string;\n uploadDir: string;\n workspaceDir?: string;\n fs?: WorkspaceTransferFileSystem;\n remoteFs?: WorkspaceTransferFileSystem;\n}\n\nexport interface WorkspaceTransferOptions {\n runner?: RunnerScope;\n uploadMaxFileMb?: number;\n workspaceExclude?: string[];\n warn?: (message: string) => void;\n}\n\nexport interface WorkspaceDownloadOptions {\n conflictPolicy: \"refuse\" | \"overwrite\";\n}\n\ninterface UploadedFileState {\n hash: string;\n uploaded: boolean;\n}\n\ninterface FileEntry {\n path: string;\n absolutePath: string;\n bytes: number;\n content: Buffer;\n}\n\ninterface IgnoreRule {\n pattern: string;\n negate: boolean;\n directoryOnly: boolean;\n anchored: boolean;\n}\n\nconst uploadState = new WeakMap<object, Map<string, UploadedFileState>>();\n\nexport async function uploadWorkspace(\n env: WorkspaceTransferEnv,\n opts: WorkspaceTransferOptions\n): Promise<UploadResult> {\n const localFs = env.fs ?? (nodeFs as unknown as WorkspaceTransferFileSystem);\n const remoteFs = env.remoteFs ?? localFs;\n const workspaceDir = env.workspaceDir ?? \"/workspace\";\n const maxBytes = (opts.uploadMaxFileMb ?? opts.runner?.upload_max_file_mb ?? 100) * 1024 * 1024;\n const warn = opts.warn ?? console.warn;\n const allFiles = await listFiles(localFs, env.cwd);\n const state = new Map<string, UploadedFileState>();\n const gitignore = await readIgnoreFile(localFs, env.cwd, \".gitignore\", true);\n const poeCodeIgnore = await readIgnoreFile(localFs, env.cwd, \".poe-code-ignore\", false);\n const workspaceExclude = parseIgnoreLines(\n [...(opts.runner?.workspace?.exclude ?? []), ...(opts.workspaceExclude ?? [])],\n false\n );\n const entries: FileEntry[] = [];\n const skipped: UploadResult[\"skipped\"] = [];\n\n for (const file of allFiles) {\n const content = await localFs.readFile(file.absolutePath);\n state.set(file.path, {\n hash: hashBuffer(content),\n uploaded: false\n });\n\n if (\n isIgnoredByGit(file.path, gitignore) ||\n isIgnoredAdditively(file.path, poeCodeIgnore) ||\n isIgnoredAdditively(file.path, workspaceExclude)\n ) {\n continue;\n }\n\n if (file.bytes > maxBytes) {\n skipped.push({ path: file.path, bytes: file.bytes, reason: \"max_size\" });\n warn(`Skipping ${file.path}: ${file.bytes} bytes exceeds upload_max_file_mb.`);\n continue;\n }\n\n entries.push({ ...file, content });\n state.set(file.path, {\n hash: hashBuffer(content),\n uploaded: true\n });\n }\n\n await removeTree(remoteFs, workspaceDir);\n await remoteFs.mkdir(workspaceDir, { recursive: true });\n await remoteFs.mkdir(env.uploadDir, { recursive: true });\n await remoteFs.writeFile(path.join(env.uploadDir, \"workspace.tar\"), createTar(entries));\n\n for (const entry of entries) {\n const remotePath = path.join(workspaceDir, entry.path);\n await remoteFs.mkdir(path.dirname(remotePath), { recursive: true });\n await remoteFs.writeFile(remotePath, entry.content);\n }\n\n uploadState.set(env, state);\n\n return {\n files: entries.length,\n bytes: entries.reduce((sum, entry) => sum + entry.bytes, 0),\n skipped\n };\n}\n\nexport async function downloadWorkspace(\n env: WorkspaceTransferEnv,\n opts: WorkspaceDownloadOptions\n): Promise<DownloadResult> {\n const localFs = env.fs ?? (nodeFs as unknown as WorkspaceTransferFileSystem);\n const remoteFs = env.remoteFs ?? localFs;\n const workspaceDir = env.workspaceDir ?? \"/workspace\";\n const state = uploadState.get(env) ?? new Map<string, UploadedFileState>();\n const remoteFiles = await listFilesIfExists(remoteFs, workspaceDir);\n const remotePaths = new Set(remoteFiles.map((file) => file.path));\n const conflicts: DownloadResult[\"conflicts\"] = [];\n let files = 0;\n let bytes = 0;\n\n for (const remoteFile of remoteFiles) {\n const remoteContent = await remoteFs.readFile(remoteFile.absolutePath);\n const localPath = path.join(env.cwd, remoteFile.path);\n const conflict = await isDownloadConflict(\n localFs,\n localPath,\n remoteFile.path,\n remoteContent,\n state\n );\n\n if (conflict && opts.conflictPolicy === \"refuse\") {\n conflicts.push({ path: remoteFile.path, reason: \"local_modified\" });\n continue;\n }\n\n await localFs.mkdir(path.dirname(localPath), { recursive: true });\n await localFs.writeFile(localPath, remoteContent);\n state.set(remoteFile.path, {\n hash: hashBuffer(remoteContent),\n uploaded: true\n });\n files += 1;\n bytes += remoteContent.length;\n }\n\n for (const [relativePath, fileState] of state) {\n if (!fileState.uploaded || remotePaths.has(relativePath)) {\n continue;\n }\n\n const localPath = path.join(env.cwd, relativePath);\n const localContent = await readFileIfExists(localFs, localPath);\n if (localContent === null) {\n continue;\n }\n\n if (opts.conflictPolicy === \"refuse\" && hashBuffer(localContent) !== fileState.hash) {\n conflicts.push({ path: relativePath, reason: \"local_modified\" });\n continue;\n }\n\n await removeFile(localFs, localPath);\n }\n\n return { files, bytes, conflicts };\n}\n\nasync function listFilesIfExists(\n fs: WorkspaceTransferFileSystem,\n root: string\n): Promise<Omit<FileEntry, \"content\">[]> {\n try {\n return await listFiles(fs, root);\n } catch (error) {\n if (isNotFoundError(error)) {\n return [];\n }\n throw error;\n }\n}\n\nasync function listFiles(\n fs: WorkspaceTransferFileSystem,\n root: string\n): Promise<Omit<FileEntry, \"content\">[]> {\n const result: Omit<FileEntry, \"content\">[] = [];\n\n async function visit(dir: string): Promise<void> {\n const dirents = await fs.readdir(dir, { withFileTypes: true });\n for (const dirent of dirents.sort((left, right) => left.name.localeCompare(right.name))) {\n const absolutePath = path.join(dir, dirent.name);\n if (dirent.isDirectory()) {\n await visit(absolutePath);\n continue;\n }\n if (!dirent.isFile()) {\n continue;\n }\n\n const stats = await fs.stat(absolutePath);\n result.push({\n path: toRelativePath(root, absolutePath),\n absolutePath,\n bytes: stats.size\n });\n }\n }\n\n await visit(root);\n return result;\n}\n\nasync function readIgnoreFile(\n fs: WorkspaceTransferFileSystem,\n cwd: string,\n fileName: string,\n allowNegation: boolean\n): Promise<IgnoreRule[]> {\n const content = await readFileIfExists(fs, path.join(cwd, fileName));\n if (content === null) {\n return [];\n }\n return parseIgnoreLines(content.toString(\"utf8\").split(\"\\n\"), allowNegation);\n}\n\nfunction parseIgnoreLines(lines: string[], allowNegation: boolean): IgnoreRule[] {\n const rules: IgnoreRule[] = [];\n for (const rawLine of lines) {\n const line = rawLine.trim();\n if (line.length === 0 || line.startsWith(\"#\")) {\n continue;\n }\n\n const negate = allowNegation && line.startsWith(\"!\");\n const patternWithMarker = negate ? line.slice(1) : line;\n if (patternWithMarker.length === 0) {\n continue;\n }\n\n const anchored = patternWithMarker.startsWith(\"/\");\n const directoryOnly = patternWithMarker.endsWith(\"/\");\n const pattern = stripSlashes(\n directoryOnly ? patternWithMarker.slice(0, -1) : patternWithMarker\n );\n if (pattern.length > 0) {\n rules.push({ pattern, negate, directoryOnly, anchored });\n }\n }\n return rules;\n}\n\nfunction isIgnoredByGit(relativePath: string, rules: IgnoreRule[]): boolean {\n let ignored = false;\n for (const rule of rules) {\n if (matchesRule(relativePath, rule)) {\n ignored = !rule.negate;\n }\n }\n return ignored;\n}\n\nfunction isIgnoredAdditively(relativePath: string, rules: IgnoreRule[]): boolean {\n return rules.some((rule) => matchesRule(relativePath, rule));\n}\n\nfunction matchesRule(relativePath: string, rule: IgnoreRule): boolean {\n const normalizedPath = normalizeRelativePath(relativePath);\n const normalizedPattern = normalizeRelativePath(rule.pattern);\n if (rule.directoryOnly) {\n return pathMatchesDirectory(normalizedPath, normalizedPattern, rule.anchored);\n }\n\n if (rule.anchored || normalizedPattern.includes(\"/\")) {\n return matchPathSegments(normalizedPath.split(\"/\"), normalizedPattern.split(\"/\"));\n }\n\n return normalizedPath.split(\"/\").some((segment) => matchSegment(segment, normalizedPattern));\n}\n\nfunction pathMatchesDirectory(relativePath: string, pattern: string, anchored: boolean): boolean {\n if (anchored || pattern.includes(\"/\")) {\n return relativePath === pattern || relativePath.startsWith(`${pattern}/`);\n }\n\n const segments = relativePath.split(\"/\");\n return segments.some((segment, index) => {\n return matchSegment(segment, pattern) && index < segments.length - 1;\n });\n}\n\nfunction matchPathSegments(pathSegments: string[], patternSegments: string[]): boolean {\n if (pathSegments.length !== patternSegments.length) {\n return false;\n }\n\n return patternSegments.every((patternSegment, index) =>\n matchSegment(pathSegments[index] ?? \"\", patternSegment)\n );\n}\n\nfunction matchSegment(value: string, pattern: string): boolean {\n const patternParts = pattern.split(\"*\");\n if (patternParts.length === 1) {\n return value === pattern;\n }\n\n let offset = 0;\n for (const [index, part] of patternParts.entries()) {\n if (part.length === 0) {\n continue;\n }\n\n const foundAt = value.indexOf(part, offset);\n if (foundAt === -1) {\n return false;\n }\n\n if (index === 0 && foundAt !== 0) {\n return false;\n }\n\n offset = foundAt + part.length;\n }\n\n const lastPart = patternParts.at(-1) ?? \"\";\n return lastPart.length === 0 || value.endsWith(lastPart);\n}\n\nasync function isDownloadConflict(\n fs: WorkspaceTransferFileSystem,\n localPath: string,\n relativePath: string,\n remoteContent: Buffer,\n state: Map<string, UploadedFileState>\n): Promise<boolean> {\n const localContent = await readFileIfExists(fs, localPath);\n if (localContent === null) {\n return false;\n }\n\n const localHash = hashBuffer(localContent);\n const remoteHash = hashBuffer(remoteContent);\n const uploadedHash = state.get(relativePath)?.hash;\n const localChanged = uploadedHash === undefined || localHash !== uploadedHash;\n return localChanged && localHash !== remoteHash;\n}\n\nasync function readFileIfExists(\n fs: WorkspaceTransferFileSystem,\n filePath: string\n): Promise<Buffer | null> {\n try {\n return await fs.readFile(filePath);\n } catch (error) {\n if (isNotFoundError(error)) {\n return null;\n }\n throw error;\n }\n}\n\nasync function removeTree(fs: WorkspaceTransferFileSystem, targetPath: string): Promise<void> {\n if (fs.rm) {\n await fs.rm(targetPath, { recursive: true, force: true });\n return;\n }\n\n const stats = await statIfExists(fs, targetPath);\n if (stats === null) {\n return;\n }\n if (stats.isFile()) {\n await removeFile(fs, targetPath);\n return;\n }\n\n const dirents = await fs.readdir(targetPath, { withFileTypes: true });\n for (const dirent of dirents) {\n await removeTree(fs, path.join(targetPath, dirent.name));\n }\n if (fs.rmdir) {\n await fs.rmdir(targetPath);\n }\n}\n\nasync function removeFile(fs: WorkspaceTransferFileSystem, filePath: string): Promise<void> {\n if (fs.rm) {\n await fs.rm(filePath, { force: true });\n return;\n }\n if (fs.unlink) {\n await fs.unlink(filePath);\n }\n}\n\nasync function statIfExists(\n fs: WorkspaceTransferFileSystem,\n targetPath: string\n): Promise<WorkspaceTransferStats | null> {\n try {\n return await fs.stat(targetPath);\n } catch (error) {\n if (isNotFoundError(error)) {\n return null;\n }\n throw error;\n }\n}\n\nfunction createTar(entries: FileEntry[]): Buffer {\n const chunks: Buffer[] = [];\n for (const entry of entries) {\n chunks.push(createTarHeader(entry.path, entry.bytes));\n chunks.push(entry.content);\n chunks.push(Buffer.alloc(paddingFor(entry.bytes)));\n }\n chunks.push(Buffer.alloc(1024));\n return Buffer.concat(chunks);\n}\n\nfunction createTarHeader(name: string, size: number): Buffer {\n const header = Buffer.alloc(512);\n writeString(header, name, 0, 100);\n writeOctal(header, 0o644, 100, 8);\n writeOctal(header, 0, 108, 8);\n writeOctal(header, 0, 116, 8);\n writeOctal(header, size, 124, 12);\n writeOctal(header, 0, 136, 12);\n header.fill(32, 148, 156);\n header.write(\"0\", 156, 1, \"ascii\");\n header.write(\"ustar\", 257, 5, \"ascii\");\n header.write(\"00\", 263, 2, \"ascii\");\n writeOctal(header, checksum(header), 148, 8);\n return header;\n}\n\nfunction writeString(buffer: Buffer, value: string, offset: number, length: number): void {\n const text = Buffer.from(value);\n text.copy(buffer, offset, 0, Math.min(text.length, length));\n}\n\nfunction writeOctal(buffer: Buffer, value: number, offset: number, length: number): void {\n const text = value.toString(8).padStart(length - 1, \"0\");\n buffer.write(text.slice(0, length - 1), offset, length - 1, \"ascii\");\n buffer[offset + length - 1] = 0;\n}\n\nfunction checksum(buffer: Buffer): number {\n return buffer.reduce((sum, value) => sum + value, 0);\n}\n\nfunction paddingFor(size: number): number {\n const remainder = size % 512;\n return remainder === 0 ? 0 : 512 - remainder;\n}\n\nfunction hashBuffer(buffer: Buffer): string {\n return createHash(\"sha256\").update(buffer).digest(\"hex\");\n}\n\nfunction toRelativePath(root: string, absolutePath: string): string {\n return normalizeRelativePath(path.relative(root, absolutePath));\n}\n\nfunction normalizeRelativePath(value: string): string {\n return stripSlashes(value.split(path.sep).join(\"/\"));\n}\n\nfunction stripSlashes(value: string): string {\n let start = 0;\n let end = value.length;\n while (value[start] === \"/\") {\n start += 1;\n }\n while (value[end - 1] === \"/\") {\n end -= 1;\n }\n return value.slice(start, end);\n}\n\nfunction isNotFoundError(error: unknown): boolean {\n return typeof error === \"object\" && error !== null && \"code\" in error && error.code === \"ENOENT\";\n}\n", "import path from \"node:path\";\nimport type { E2bRuntime } from \"@poe-code/poe-code-config\";\nimport type { ExecutionEnvFactory, OpenSpec, OpenedEnv } from \"@poe-code/agent-harness-tools\";\nimport { createSandbox, connectSandbox } from \"./sdk.js\";\nimport { buildE2bRuntimeTemplate } from \"./template-build.js\";\nimport { createOpenedE2bEnv } from \"./opened-env.js\";\nimport { resolveE2bApiKey } from \"./auth-scope.js\";\n\nexport const e2bExecutionEnvFactory: ExecutionEnvFactory = {\n type: \"e2b\",\n supportsDetach: true,\n async open(spec): Promise<OpenedEnv> {\n const runtime = parseE2bRuntime(spec.runtime);\n const runtimeCwd = spec.runtimeCwd ?? spec.cwd;\n const apiKey = await resolveE2bApiKey({ cwd: runtimeCwd });\n const templateId =\n runtime.template_id ??\n (\n await buildE2bRuntimeTemplate({\n runtime,\n dockerfilePath: path.resolve(\n runtimeCwd,\n runtime.dockerfile ?? path.join(\".poe-code\", \"Dockerfile\")\n ),\n buildContext: path.resolve(runtimeCwd, runtime.build_context ?? \".\"),\n state: spec.state,\n apiKey\n })\n ).templateId;\n const sandbox = await createSandbox({\n apiKey,\n templateId,\n env: spec.env,\n timeoutMinutes: runtime.timeout_minutes\n });\n\n return createOpenedE2bEnv({ sandbox, spec, runtime });\n },\n async attach(envId, context): Promise<OpenedEnv> {\n const cwd = context?.cwd ?? process.cwd();\n const apiKey = await resolveE2bApiKey({ cwd });\n const sandbox = await connectSandbox(envId, apiKey);\n return createOpenedE2bEnv({\n sandbox,\n spec: {\n cwd: context?.cwd ?? \"/workspace\",\n runtime: {\n type: \"e2b\",\n build_args: {},\n mounts: [],\n workspace_dir: \"/workspace\",\n preserve_after_exit_hours: 24\n },\n env: {},\n uploadIgnoreFiles: [],\n jobLabel: { tool: context?.tool ?? \"e2b\", argv: context?.argv ?? [] },\n ...(context?.jobId ? { detachedJobId: context.jobId } : {})\n } as OpenSpec & { detachedJobId?: string },\n runtime: {\n type: \"e2b\",\n build_args: {},\n mounts: [],\n workspace_dir: \"/workspace\",\n preserve_after_exit_hours: 24\n }\n });\n }\n};\n\nfunction parseE2bRuntime(runtime: unknown): E2bRuntime {\n if (!runtime || typeof runtime !== \"object\" || Array.isArray(runtime)) {\n throw new Error(\"e2b runtime must be an object\");\n }\n const record = runtime as Record<string, unknown>;\n if (record.type !== \"e2b\") {\n throw new Error('e2b runtime type must be \"e2b\"');\n }\n return record as unknown as E2bRuntime;\n}\n", "import { Template, Sandbox, TemplateBase } from \"e2b\";\nimport type { Readable } from \"node:stream\";\n\nexport interface E2bSandbox {\n readonly sandboxId: string;\n readonly commands: E2bCommands;\n readonly files: E2bFiles;\n readonly pty: E2bPty;\n setTimeout(timeoutMs: number): Promise<void>;\n kill(): Promise<void>;\n}\n\nexport interface E2bCommands {\n list(): Promise<E2bProcessInfo[]>;\n run(command: string, opts?: E2bCommandOptions): Promise<E2bCommandResult | E2bCommandHandle>;\n connect(pid: number, opts?: E2bCommandConnectOptions): Promise<E2bCommandHandle>;\n sendStdin(pid: number, data: string | Uint8Array): Promise<void>;\n closeStdin?(pid: number): Promise<void>;\n kill(pid: number): Promise<boolean>;\n}\n\nexport interface E2bPty {\n create(opts: E2bPtyOptions): Promise<E2bCommandHandle>;\n sendInput(pid: number, data: Uint8Array): Promise<void>;\n kill(pid: number): Promise<boolean>;\n}\n\nexport interface E2bFiles {\n read(path: string, opts: { format: \"bytes\" }): Promise<Uint8Array>;\n read(path: string): Promise<string>;\n write(path: string, data: string | ArrayBuffer | Blob | ReadableStream): Promise<unknown>;\n watchDir(\n path: string,\n onEvent: () => void | Promise<void>,\n opts?: { recursive?: boolean; onExit?: (error?: Error) => void | Promise<void> }\n ): Promise<{ stop(): Promise<void> }>;\n}\n\nexport interface E2bProcessInfo {\n pid: number;\n cmd: string;\n args: string[];\n}\n\nexport interface E2bCommandOptions {\n background?: boolean;\n cwd?: string;\n envs?: Record<string, string>;\n stdin?: boolean;\n timeoutMs?: number;\n onStdout?: (data: string) => void | Promise<void>;\n onStderr?: (data: string) => void | Promise<void>;\n}\n\nexport interface E2bPtyOptions {\n cols: number;\n rows: number;\n cwd?: string;\n envs?: Record<string, string>;\n timeoutMs?: number;\n onData: (data: Uint8Array) => void | Promise<void>;\n}\n\nexport interface E2bCommandConnectOptions {\n timeoutMs?: number;\n onStdout?: (data: string) => void | Promise<void>;\n onStderr?: (data: string) => void | Promise<void>;\n}\n\nexport interface E2bCommandResult {\n exitCode?: number;\n stdout?: string;\n stderr?: string;\n}\n\nexport interface E2bCommandHandle {\n readonly pid: number;\n wait(): Promise<E2bCommandResult>;\n kill(): Promise<boolean>;\n}\n\nexport interface CreateSandboxOptions {\n apiKey: string;\n templateId: string;\n env: Record<string, string>;\n timeoutMinutes?: number;\n}\n\nexport interface BuildTemplateOptions {\n apiKey: string;\n name: string;\n dockerfilePath: string;\n buildContext: string;\n cpu?: number;\n memoryMb?: number;\n fromTemplate?: string;\n onLog?: (entry: BuildLogEntry) => void;\n}\n\nexport interface BuildLogEntry {\n level: \"debug\" | \"info\" | \"warn\" | \"error\";\n message: string;\n timestamp: Date;\n}\n\nexport interface BuildTemplateResult {\n templateId: string;\n}\n\nexport interface SandboxInfo {\n sandboxId: string;\n}\n\nexport async function createSandbox(opts: CreateSandboxOptions): Promise<E2bSandbox> {\n return Sandbox.create(opts.templateId, {\n apiKey: opts.apiKey,\n envs: opts.env,\n ...(opts.timeoutMinutes === undefined ? {} : { timeoutMs: opts.timeoutMinutes * 60_000 })\n }) as Promise<E2bSandbox>;\n}\n\nexport async function connectSandbox(id: string, apiKey?: string): Promise<E2bSandbox> {\n return Sandbox.connect(id, apiKey === undefined ? undefined : { apiKey }) as Promise<E2bSandbox>;\n}\n\nexport async function buildTemplate(opts: BuildTemplateOptions): Promise<BuildTemplateResult> {\n const template = Template({ fileContextPath: opts.buildContext }).fromDockerfile(\n opts.dockerfilePath\n );\n if (opts.fromTemplate !== undefined && opts.fromTemplate.length > 0) {\n (template as TemplateBase).fromTemplate(opts.fromTemplate);\n }\n const result = await Template.build(template, opts.name, {\n apiKey: opts.apiKey,\n ...(opts.cpu === undefined ? {} : { cpuCount: opts.cpu }),\n ...(opts.memoryMb === undefined ? {} : { memoryMB: opts.memoryMb }),\n ...(opts.onLog ? { onBuildLogs: opts.onLog } : {})\n });\n return { templateId: result.templateId };\n}\n\nexport async function listSandboxes(apiKey?: string): Promise<SandboxInfo[]> {\n const paginator = Sandbox.list(apiKey === undefined ? undefined : { apiKey });\n const sandboxes: SandboxInfo[] = [];\n while (paginator.hasNext) {\n sandboxes.push(...((await paginator.nextItems()) as SandboxInfo[]));\n }\n return sandboxes;\n}\n\nexport function toArrayBuffer(buffer: Buffer): ArrayBuffer {\n const output = new ArrayBuffer(buffer.byteLength);\n new Uint8Array(output).set(buffer);\n return output;\n}\n\nexport async function readableToString(stream: Readable | null): Promise<string> {\n if (stream === null) {\n return \"\";\n }\n stream.setEncoding(\"utf8\");\n const chunks: string[] = [];\n for await (const chunk of stream) {\n chunks.push(String(chunk));\n }\n return chunks.join(\"\");\n}\n", "import { createHash } from \"node:crypto\";\nimport { readdir, readFile } from \"node:fs/promises\";\nimport path from \"node:path\";\nimport type { E2bRuntime, StateManager } from \"@poe-code/poe-code-config\";\nimport { buildTemplate, type BuildLogEntry } from \"./sdk.js\";\n\nexport interface BuildE2bRuntimeTemplateInput {\n runtime: E2bRuntime;\n dockerfilePath: string;\n buildContext: string;\n state?: Pick<StateManager, \"templates\">;\n apiKey: string;\n force?: boolean;\n onLog?: (entry: BuildLogEntry) => void;\n}\n\nexport interface BuildE2bRuntimeTemplateResult {\n backend: \"e2b\";\n hash: string;\n templateId: string;\n cached: boolean;\n}\n\nconst BUILD_LOG_TAIL_SIZE = 30;\n\nexport async function buildE2bRuntimeTemplate(\n input: BuildE2bRuntimeTemplateInput\n): Promise<BuildE2bRuntimeTemplateResult> {\n const dockerfileBytes = await readFile(input.dockerfilePath);\n const buildContextFiles = await readBuildContextFiles(input.buildContext);\n const hash = hashTemplate(dockerfileBytes, buildContextFiles, input.runtime.build_args);\n const cached = input.force === true ? null : await input.state?.templates.get(\"e2b\", hash);\n\n if (cached?.template_id !== undefined) {\n return { backend: \"e2b\", hash, templateId: cached.template_id, cached: true };\n }\n\n const tail: string[] = [];\n const onLog = (entry: BuildLogEntry): void => {\n tail.push(entry.message);\n if (tail.length > BUILD_LOG_TAIL_SIZE) {\n tail.shift();\n }\n input.onLog?.(entry);\n };\n\n let built;\n try {\n built = await buildTemplate({\n apiKey: input.apiKey,\n name: `poe-code-${hash.slice(0, 32)}`,\n dockerfilePath: input.dockerfilePath,\n buildContext: input.buildContext,\n cpu: input.runtime.cpu,\n memoryMb: input.runtime.memory_mb,\n fromTemplate: input.runtime.from_template,\n onLog\n });\n } catch (error) {\n throw decorateBuildError(error, tail);\n }\n\n await input.state?.templates.put(\"e2b\", {\n hash,\n template_id: built.templateId,\n runtime_type: \"e2b\",\n dockerfile_path: input.dockerfilePath,\n built_at: new Date().toISOString()\n });\n\n return { backend: \"e2b\", hash, templateId: built.templateId, cached: false };\n}\n\nfunction decorateBuildError(error: unknown, tail: string[]): Error {\n const original = error instanceof Error ? error : new Error(String(error));\n if (tail.length === 0) {\n return original;\n }\n const decorated = new Error(`${original.message}\\n\\nLast build output:\\n${tail.join(\"\\n\")}`);\n decorated.stack = original.stack;\n (decorated as Error & { cause?: unknown }).cause = original;\n return decorated;\n}\n\nfunction hashTemplate(\n dockerfileBytes: Buffer,\n buildContextFiles: BuildContextFile[],\n buildArgs: Record<string, string>\n): string {\n const hash = createHash(\"sha256\");\n hash.update(dockerfileBytes);\n hash.update(\"\\0\");\n for (const file of buildContextFiles) {\n hash.update(file.relativePath);\n hash.update(\"\\0\");\n hash.update(file.bytes);\n hash.update(\"\\0\");\n }\n for (const [key, value] of Object.entries(buildArgs).sort(([left], [right]) =>\n left.localeCompare(right)\n )) {\n hash.update(key);\n hash.update(\"=\");\n hash.update(value);\n hash.update(\"\\0\");\n }\n return hash.digest(\"hex\");\n}\n\ninterface BuildContextFile {\n relativePath: string;\n bytes: Buffer;\n}\n\nasync function readBuildContextFiles(buildContext: string): Promise<BuildContextFile[]> {\n const files: BuildContextFile[] = [];\n await collectBuildContextFiles(buildContext, \"\", files);\n return files.sort((left, right) => left.relativePath.localeCompare(right.relativePath));\n}\n\nasync function collectBuildContextFiles(\n buildContext: string,\n relativeDir: string,\n files: BuildContextFile[]\n): Promise<void> {\n const absoluteDir = path.join(buildContext, relativeDir);\n const entries = await readdir(absoluteDir, { withFileTypes: true });\n\n for (const entry of entries) {\n const relativePath = path.join(relativeDir, entry.name);\n if (entry.isDirectory()) {\n await collectBuildContextFiles(buildContext, relativePath, files);\n continue;\n }\n if (!entry.isFile()) {\n continue;\n }\n files.push({\n relativePath: relativePath.split(path.sep).join(\"/\"),\n bytes: await readFile(path.join(buildContext, relativePath))\n });\n }\n}\n", "import { mkdtempSync, rmSync } from \"node:fs\";\nimport { readFile, writeFile } from \"node:fs/promises\";\nimport { tmpdir } from \"node:os\";\nimport path from \"node:path\";\nimport { PassThrough, Writable } from \"node:stream\";\nimport type { E2bRuntime } from \"@poe-code/poe-code-config\";\nimport type {\n LogStreamFs,\n OpenSpec,\n OpenedEnv,\n RunHandle,\n RunSpec\n} from \"@poe-code/agent-harness-tools\";\nimport { createHostRunner, type Runner } from \"@poe-code/process-runner\";\nimport { createE2bJobHandle, createE2bLogStreamFs } from \"./job-handle.js\";\nimport {\n readableToString,\n toArrayBuffer,\n type E2bCommandHandle,\n type E2bCommandResult,\n type E2bSandbox\n} from \"./sdk.js\";\n\nconst REMOTE_COMMAND_STDERR_TAIL_SIZE = 30;\n\ninterface DetachedJobContext {\n id: string;\n tool: string;\n argv: string[];\n}\n\nexport interface E2bOpenedEnv extends OpenedEnv {\n fs: LogStreamFs;\n setDetachedJobContext(context: DetachedJobContext): void;\n}\n\nexport function createOpenedE2bEnv(input: {\n sandbox: E2bSandbox;\n spec: OpenSpec;\n runtime: E2bRuntime;\n}): E2bOpenedEnv {\n const hostRunner = input.spec.hostRunner ?? createHostRunner();\n const hostWorkspaceDir = path.resolve(input.spec.cwd);\n const sandboxWorkspaceDir = normalizeSandboxWorkspaceDir(input.runtime.workspace_dir);\n let lastProcess: { started: Promise<E2bCommandHandle> } | null = null;\n let detachedJobContext: DetachedJobContext | null = null;\n const mapWorkspaceCwd = (cwd: string | undefined): string | undefined => {\n if (cwd === undefined) {\n return undefined;\n }\n if (path.isAbsolute(cwd) && path.resolve(cwd) === hostWorkspaceDir) {\n return sandboxWorkspaceDir;\n }\n return cwd;\n };\n\n const attachedJobId = (input.spec as OpenSpec & { detachedJobId?: string }).detachedJobId;\n const env: E2bOpenedEnv = {\n id: input.sandbox.sandboxId,\n job: attachedJobId\n ? createE2bJobHandle({\n sandbox: input.sandbox,\n envId: input.sandbox.sandboxId,\n jobId: attachedJobId,\n tool: input.spec.jobLabel.tool,\n argv: input.spec.jobLabel.argv,\n preserveAfterExitHours: input.runtime.preserve_after_exit_hours ?? 24\n })\n : null,\n fs: createE2bLogStreamFs(input.sandbox),\n setDetachedJobContext(context) {\n detachedJobContext = context;\n },\n async uploadWorkspace() {\n if (input.spec.runner?.sync === \"none\") {\n return { files: 0, bytes: 0, skipped: [] };\n }\n const tempDir = mkdtempSync(path.join(tmpdir(), \"poe-e2b-upload-\"));\n const archivePath = path.join(tempDir, \"workspace.tar\");\n try {\n await runOrThrow(hostRunner, {\n command: \"tar\",\n args: [\n ...input.spec.uploadIgnoreFiles.flatMap((ignored) => [\"--exclude\", ignored]),\n \"-cf\",\n archivePath,\n \"-C\",\n input.spec.cwd,\n \".\"\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n await input.sandbox.files.write(\n \"/tmp/poe-workspace-upload.tar\",\n toArrayBuffer(await readFile(archivePath))\n );\n await runRemoteOrThrow(\n input.sandbox,\n createUploadWorkspaceCommand(sandboxWorkspaceDir)\n );\n return { files: 0, bytes: 0, skipped: [] };\n } finally {\n rmSync(tempDir, { recursive: true, force: true });\n }\n },\n async downloadWorkspace(opts) {\n if (input.spec.runner?.sync === \"upload\" || input.spec.runner?.sync === \"none\") {\n return { files: 0, bytes: 0, conflicts: [] };\n }\n const tempDir = mkdtempSync(path.join(tmpdir(), \"poe-e2b-download-\"));\n const archivePath = path.join(tempDir, \"workspace.tar\");\n try {\n await runRemoteOrThrow(\n input.sandbox,\n `tar -cf /tmp/poe-workspace-download.tar -C ${shellQuote(sandboxWorkspaceDir)} .`\n );\n const archive = await input.sandbox.files.read(\"/tmp/poe-workspace-download.tar\", {\n format: \"bytes\"\n });\n await writeFile(archivePath, Buffer.from(archive));\n await runOrThrow(hostRunner, {\n command: \"tar\",\n args: [\n opts.conflictPolicy === \"refuse\" ? \"-xkf\" : \"-xf\",\n archivePath,\n \"-C\",\n input.spec.cwd\n ],\n stdout: \"pipe\",\n stderr: \"pipe\"\n });\n return { files: 0, bytes: archive.byteLength, conflicts: [] };\n } finally {\n rmSync(tempDir, { recursive: true, force: true });\n }\n },\n exec(spec) {\n const handle = runE2bCommand(input.sandbox, {\n ...spec,\n cwd: mapWorkspaceCwd(spec.cwd),\n env: resolveSandboxCommandEnv(spec.env)\n });\n lastProcess = { started: handle.started };\n return handle;\n },\n async detach() {\n if (detachedJobContext === null) {\n throw new Error(\"Cannot detach E2B environment before a job context is registered.\");\n }\n if (lastProcess === null) {\n throw new Error(\"Cannot detach E2B environment before a command is running.\");\n }\n const command = await lastProcess.started;\n const preserveAfterExitHours = input.runtime.preserve_after_exit_hours ?? 24;\n const preserveMs = preserveAfterExitHours * 60 * 60 * 1000;\n if (preserveMs > 0) {\n await input.sandbox.setTimeout(preserveMs);\n }\n return createE2bJobHandle({\n sandbox: input.sandbox,\n envId: input.sandbox.sandboxId,\n jobId: detachedJobContext.id,\n tool: detachedJobContext.tool,\n argv: detachedJobContext.argv,\n pid: command.pid,\n preserveAfterExitHours\n });\n },\n shell() {\n const shellSpec = input.spec.shellSpec;\n const command = shellSpec?.command ?? input.spec.env.SHELL ?? \"sh\";\n return runE2bPty(input.sandbox, {\n command,\n ...(shellSpec?.args ? { args: shellSpec.args } : {}),\n cwd: mapWorkspaceCwd(shellSpec?.cwd ?? input.spec.cwd),\n env: resolveSandboxCommandEnv(\n shellSpec && \"env\" in shellSpec ? shellSpec.env : input.spec.env\n ),\n stdin: \"inherit\",\n stdout: \"inherit\",\n stderr: \"inherit\",\n tty: true\n });\n },\n async close() {\n await input.sandbox.kill();\n }\n };\n\n return env;\n}\n\nfunction runE2bCommand(\n sandbox: E2bSandbox,\n spec: RunSpec\n): RunHandle & { e2bHandle: E2bCommandHandle | null; started: Promise<E2bCommandHandle> } {\n const stdout = spec.stdout === \"inherit\" ? null : new PassThrough();\n const stderr = spec.stderr === \"inherit\" ? null : new PassThrough();\n let e2bHandle: E2bCommandHandle | null = null;\n const command = shellCommand([spec.command, ...(spec.args ?? [])]);\n const started = sandbox.commands.run(command, {\n background: true,\n cwd: spec.cwd,\n envs: spec.env,\n stdin: spec.stdin === \"pipe\",\n onStdout(data) {\n stdout?.write(data);\n if (spec.stdout === \"inherit\") {\n process.stdout.write(data);\n }\n },\n onStderr(data) {\n stderr?.write(data);\n if (spec.stderr === \"inherit\") {\n process.stderr.write(data);\n }\n }\n }) as Promise<E2bCommandHandle>;\n const stdin =\n spec.stdin === \"pipe\"\n ? new Writable({\n write(chunk, _encoding, callback) {\n started\n .then((handle) =>\n sandbox.commands.sendStdin(\n handle.pid,\n Buffer.isBuffer(chunk) ? chunk : Buffer.from(String(chunk))\n )\n )\n .then(() => callback(), callback);\n },\n final(callback) {\n if (sandbox.commands.closeStdin === undefined) {\n callback();\n return;\n }\n started\n .then((handle) => sandbox.commands.closeStdin!(handle.pid))\n .then(() => callback(), callback);\n }\n })\n : null;\n const result = started\n .then((handle) => {\n e2bHandle = handle;\n return handle.wait();\n })\n .then(\n (result) => {\n stdout?.end();\n stderr?.end();\n return { exitCode: result.exitCode ?? 0 };\n },\n (error: unknown) => {\n stdout?.end();\n stderr?.end();\n if (isExitError(error)) {\n return { exitCode: error.exitCode };\n }\n return { exitCode: 1 };\n }\n );\n\n return {\n get pid() {\n return e2bHandle?.pid ?? null;\n },\n stdin,\n stdout,\n stderr,\n result,\n kill() {\n void e2bHandle?.kill();\n },\n get e2bHandle() {\n return e2bHandle;\n },\n started\n };\n}\n\nfunction runE2bPty(sandbox: E2bSandbox, spec: RunSpec): RunHandle {\n const stdout = new PassThrough();\n let handleRef: E2bCommandHandle | null = null;\n const stdin = new Writable({\n write(chunk, _encoding, callback) {\n if (handleRef === null) {\n callback(new Error(\"E2B PTY stdin is not ready.\"));\n return;\n }\n sandbox.pty\n .sendInput(handleRef.pid, Buffer.isBuffer(chunk) ? chunk : Buffer.from(String(chunk)))\n .then(() => callback(), callback);\n }\n });\n const started = sandbox.pty.create({\n cols: process.stdout.columns || 80,\n rows: process.stdout.rows || 24,\n cwd: spec.cwd,\n envs: spec.env,\n onData(data) {\n stdout.write(Buffer.from(data));\n if (spec.stdout === \"inherit\") {\n process.stdout.write(Buffer.from(data));\n }\n }\n });\n const result = started\n .then((handle) => {\n handleRef = handle;\n return handle.wait();\n })\n .then(\n (result) => {\n stdout.end();\n return { exitCode: result.exitCode ?? 0 };\n },\n () => {\n stdout.end();\n return { exitCode: 1 };\n }\n );\n\n return {\n get pid() {\n return handleRef?.pid ?? null;\n },\n stdin: spec.stdin === \"inherit\" ? process.stdin : stdin,\n stdout: spec.stdout === \"inherit\" ? null : stdout,\n stderr: null,\n result,\n kill() {\n void (handleRef === null ? undefined : sandbox.pty.kill(handleRef.pid));\n }\n };\n}\n\nasync function runRemoteOrThrow(sandbox: E2bSandbox, command: string): Promise<void> {\n const stdoutTail = createLineTail(REMOTE_COMMAND_STDERR_TAIL_SIZE);\n const stderrTail = createLineTail(REMOTE_COMMAND_STDERR_TAIL_SIZE);\n let result: E2bCommandResult | E2bCommandHandle;\n try {\n result = await sandbox.commands.run(command, {\n onStdout(data) {\n stdoutTail.push(data);\n },\n onStderr(data) {\n stderrTail.push(data);\n }\n });\n } catch (error) {\n appendRemoteCommandOutput(error, stdoutTail, stderrTail);\n if (isCommandExitError(error)) {\n throw decorateRemoteCommandError(error, command, stderrTail.values());\n }\n throw error;\n }\n appendRemoteCommandOutput(result, stdoutTail, stderrTail);\n if (\"exitCode\" in result && result.exitCode !== 0) {\n throw decorateRemoteCommandError(\n new Error(`E2B command failed with exit code ${result.exitCode}`),\n command,\n stderrTail.values()\n );\n }\n}\n\nfunction appendRemoteCommandOutput(\n source: unknown,\n stdoutTail: { push(chunk: string): void },\n stderrTail: { push(chunk: string): void }\n): void {\n if (!source || typeof source !== \"object\") {\n return;\n }\n const output = source as { stdout?: unknown; stderr?: unknown };\n if (typeof output.stdout === \"string\") {\n stdoutTail.push(output.stdout);\n }\n if (typeof output.stderr === \"string\") {\n stderrTail.push(output.stderr);\n }\n}\n\nfunction decorateRemoteCommandError(error: unknown, command: string, stderrTail: string[]): Error {\n const original = error instanceof Error ? error : new Error(String(error));\n const tail = stderrTail.length === 0 ? \"\" : `\\n\\nLast stderr output:\\n${stderrTail.join(\"\\n\")}`;\n const decorated = new Error(`E2B command failed: ${command}\\n${original.message}${tail}`);\n decorated.stack = original.stack;\n (decorated as Error & { cause?: unknown }).cause = original;\n return decorated;\n}\n\nfunction createLineTail(maxLines: number): { push(chunk: string): void; values(): string[] } {\n const lines: string[] = [];\n let pending = \"\";\n const appendLine = (line: string): void => {\n lines.push(trimTrailingCarriageReturn(line));\n while (lines.length > maxLines) {\n lines.shift();\n }\n };\n\n return {\n push(chunk) {\n pending += chunk;\n const parts = pending.split(\"\\n\");\n pending = parts.pop() ?? \"\";\n for (const line of parts) {\n appendLine(line);\n }\n },\n values() {\n const output = [...lines];\n if (pending.length > 0) {\n output.push(trimTrailingCarriageReturn(pending));\n }\n return output.slice(-maxLines);\n }\n };\n}\n\nfunction trimTrailingCarriageReturn(value: string): string {\n return value.endsWith(\"\\r\") ? value.slice(0, -1) : value;\n}\n\nasync function runOrThrow(runner: Runner, spec: RunSpec): Promise<void> {\n const handle = runner.exec(spec);\n const stderr = readableToString(handle.stderr);\n const result = await handle.result;\n if (result.exitCode !== 0) {\n throw new Error(\n `Command failed with exit code ${result.exitCode}: ${spec.command} ${(spec.args ?? []).join(\" \")}\\n${await stderr}`\n );\n }\n}\n\nfunction shellCommand(argv: string[]): string {\n return argv.map(shellQuote).join(\" \");\n}\n\nfunction shellQuote(value: string): string {\n return `'${value.replaceAll(\"'\", \"'\\\\''\")}'`;\n}\n\nfunction createUploadWorkspaceCommand(sandboxWorkspaceDir: string): string {\n const quotedWorkspaceDir = shellQuote(sandboxWorkspaceDir);\n return [\n `mkdir -p ${quotedWorkspaceDir} || { command -v sudo >/dev/null 2>&1 && sudo mkdir -p ${quotedWorkspaceDir} && sudo chown \"$(id -u):$(id -g)\" ${quotedWorkspaceDir}; }`,\n `test -w ${quotedWorkspaceDir} && tar -xf /tmp/poe-workspace-upload.tar -C ${quotedWorkspaceDir}`\n ].join(\"\\n\");\n}\n\nfunction resolveSandboxCommandEnv(\n env: Record<string, string> | undefined\n): Record<string, string> | undefined {\n if (env === undefined) {\n return undefined;\n }\n return {\n ...env,\n HOME: \"/home/user\"\n };\n}\n\nfunction normalizeSandboxWorkspaceDir(workspaceDir: string | undefined): string {\n const resolvedWorkspaceDir = workspaceDir ?? \"/workspace\";\n if (!path.posix.isAbsolute(resolvedWorkspaceDir)) {\n throw new Error(\"E2B runtime workspace_dir must be an absolute sandbox path.\");\n }\n let normalized = path.posix.normalize(resolvedWorkspaceDir);\n while (normalized.length > 1 && normalized.endsWith(\"/\")) {\n normalized = normalized.slice(0, -1);\n }\n return normalized;\n}\n\nfunction isExitError(error: unknown): error is { exitCode: number } {\n return Boolean(\n error &&\n typeof error === \"object\" &&\n typeof (error as { exitCode?: unknown }).exitCode === \"number\"\n );\n}\n\nfunction isCommandExitError(error: unknown): boolean {\n return (\n isExitError(error) ||\n Boolean(\n error &&\n typeof error === \"object\" &&\n (error as { name?: unknown }).name === \"CommandExitError\"\n )\n );\n}\n", "import path from \"node:path\";\nimport type { JobHandle, JobStatus, LogChunk } from \"@poe-code/agent-harness-tools\";\nimport { streamLogFile, waitForExit, type LogStreamFs } from \"@poe-code/agent-harness-tools\";\nimport type { E2bSandbox } from \"./sdk.js\";\n\nconst JOB_DIR = \"/tmp/poe-jobs\";\n\nexport function createE2bJobHandle(input: {\n sandbox: E2bSandbox;\n envId: string;\n jobId: string;\n tool: string;\n argv: string[];\n pid?: number;\n preserveAfterExitHours: number;\n}): JobHandle {\n const fs = createE2bLogStreamFs(input.sandbox);\n\n return {\n id: input.jobId,\n envId: input.envId,\n tool: input.tool,\n argv: input.argv,\n async status(): Promise<JobStatus> {\n const exit = await readExitCode(input.sandbox, input.jobId);\n if (exit !== null) {\n return \"exited\";\n }\n\n const processes = await input.sandbox.commands.list();\n const isRunning =\n input.pid === undefined\n ? processes.some((process) => processMentionsJob(process, input.jobId))\n : processes.some((process) => process.pid === input.pid);\n return isRunning ? \"running\" : \"lost\";\n },\n stream(opts = {}): AsyncIterable<LogChunk> {\n return streamLogFile({ fs }, input.jobId, opts);\n },\n async wait(): Promise<{ exitCode: number }> {\n const result = await waitForExit({ fs }, input.jobId);\n const preserveMs = input.preserveAfterExitHours * 60 * 60 * 1000;\n if (preserveMs > 0) {\n await input.sandbox.setTimeout(preserveMs);\n }\n return result;\n },\n async kill(): Promise<void> {\n const pids =\n input.pid === undefined\n ? (await input.sandbox.commands.list())\n .filter((process) => processMentionsJob(process, input.jobId))\n .map((process) => process.pid)\n : [input.pid];\n await Promise.all(pids.map((pid) => input.sandbox.commands.kill(pid)));\n }\n };\n}\n\nexport function createE2bLogStreamFs(sandbox: E2bSandbox): LogStreamFs {\n return {\n promises: {\n async readFile(filePath) {\n return Buffer.from(await sandbox.files.read(filePath, { format: \"bytes\" }));\n },\n async stat(filePath) {\n const result = await sandbox.commands.run(\n `stat -c %Y ${shellQuote(filePath)} 2>/dev/null || stat -f %m ${shellQuote(filePath)}`\n );\n if (!(\"stdout\" in result)) {\n throw new Error(`Unable to stat ${filePath}`);\n }\n const seconds = Number(result.stdout?.trim());\n if (!Number.isFinite(seconds)) {\n throw new Error(`Unable to stat ${filePath}`);\n }\n return { mtimeMs: seconds * 1000 };\n }\n },\n watch(filePath, listener) {\n let closed = false;\n let stop: (() => void) | null = null;\n void sandbox.files\n .watchDir(path.dirname(filePath), listener, { recursive: false })\n .then((handle) => {\n if (closed) {\n void handle.stop();\n return;\n }\n stop = () => {\n void handle.stop();\n };\n });\n return {\n close() {\n closed = true;\n stop?.();\n }\n } as ReturnType<NonNullable<LogStreamFs[\"watch\"]>>;\n }\n };\n}\n\nfunction processMentionsJob(process: { cmd: string; args: string[] }, jobId: string): boolean {\n const needle = `/tmp/poe-jobs/${jobId}`;\n return process.cmd.includes(needle) || process.args.some((arg) => arg.includes(needle));\n}\n\nfunction shellQuote(value: string): string {\n return `'${value.replaceAll(\"'\", \"'\\\\''\")}'`;\n}\n\nasync function readExitCode(sandbox: E2bSandbox, jobId: string): Promise<number | null> {\n try {\n const contents = await sandbox.files.read(`${JOB_DIR}/${jobId}.exit`);\n const exitCode = Number(contents.trim());\n return Number.isInteger(exitCode) ? exitCode : null;\n } catch {\n return null;\n }\n}\n", "import os from \"node:os\";\nimport { promises as nodeFs } from \"node:fs\";\nimport {\n defineScope,\n readMergedDocument,\n resolveConfigPath,\n resolveProjectConfigPath,\n resolveScope\n} from \"@poe-code/poe-code-config\";\nimport type { FileSystem } from \"@poe-code/config-mutations\";\n\nexport const e2bAuthScope = defineScope(\"e2b\", {\n api_key: {\n type: \"string\",\n default: \"\",\n doc: \"E2B API key\",\n env: \"E2B_API_KEY\"\n }\n});\n\nexport interface ResolveE2bApiKeyInput {\n cwd: string;\n homeDir?: string;\n fs?: FileSystem;\n env?: Record<string, string | undefined>;\n}\n\nexport async function resolveE2bApiKey(input: ResolveE2bApiKeyInput): Promise<string> {\n const homeDir = input.homeDir ?? os.homedir();\n const fs = input.fs ?? (nodeFs as unknown as FileSystem);\n const env = input.env ?? process.env;\n const document = await readMergedDocument(\n fs,\n resolveConfigPath(homeDir),\n resolveProjectConfigPath(input.cwd)\n );\n const resolved = resolveScope(e2bAuthScope.schema, document.e2b, env);\n if (resolved.api_key.length === 0) {\n throw new Error(\n \"No E2B API key. Set E2B_API_KEY or e2b.api_key in ~/.poe-code/config.json.\"\n );\n }\n return resolved.api_key;\n}\n", "import type { ExecutionEnvFactory } from \"@poe-code/agent-harness-tools\";\nimport { e2bExecutionEnvFactory as factory } from \"./factory.js\";\n\nexport const e2bExecutionEnvFactory: ExecutionEnvFactory = factory;\nexport { e2bAuthScope, resolveE2bApiKey } from \"./auth-scope.js\";\nexport {\n buildE2bRuntimeTemplate,\n type BuildE2bRuntimeTemplateInput,\n type BuildE2bRuntimeTemplateResult\n} from \"./template-build.js\";\n", "import type { OtelSink, OtelSpan, SpawnMode, SpawnResult } from \"../types.js\";\n\nexport const noopOtelSink: OtelSink = {\n startSpan: () => noopOtelSpan,\n recordException: () => undefined\n};\n\nconst noopOtelSpan: OtelSpan = {\n setAttribute: () => undefined,\n addEvent: () => undefined,\n end: () => undefined\n};\n\nexport function observeAgentSpawn(\n input: {\n agent: string;\n cwd?: string;\n mode?: SpawnMode;\n otelSink?: OtelSink;\n prompt: string;\n },\n operation: () => Promise<SpawnResult>\n): Promise<SpawnResult> {\n const span = safeStartSpan(input.otelSink, \"agent.spawn\", {\n agent: input.agent,\n mode: input.mode ?? \"yolo\",\n cwd: input.cwd ?? process.cwd()\n });\n safeAddEvent(span, \"prompt\", { prompt: input.prompt });\n\n return (async () => {\n try {\n const result = await operation();\n safeAddEvent(span, \"summary\", { summary: readSummary(result) });\n safeAddEvent(span, \"exit\", { exitCode: result.exitCode });\n return result;\n } catch (error) {\n safeRecordException(input.otelSink, span, error);\n throw error;\n } finally {\n safeEndSpan(span);\n }\n })();\n}\n\nfunction safeStartSpan(\n sink: OtelSink | undefined,\n name: string,\n attrs: Record<string, unknown>\n): OtelSpan {\n if (sink === undefined) {\n return noopOtelSpan;\n }\n\n try {\n return sink.startSpan(name, attrs);\n } catch (error) {\n warnOtelSinkFailure(\"startSpan\", error);\n return noopOtelSpan;\n }\n}\n\nfunction safeAddEvent(\n span: OtelSpan | undefined,\n name: string,\n attrs: Record<string, unknown>\n): void {\n if (span === undefined) {\n return;\n }\n\n try {\n span.addEvent(name, attrs);\n } catch (error) {\n warnOtelSinkFailure(\"addEvent\", error);\n }\n}\n\nfunction safeRecordException(sink: OtelSink | undefined, span: OtelSpan, error: unknown): void {\n if (sink === undefined) {\n return;\n }\n\n try {\n sink.recordException(span, error);\n } catch (recordError) {\n warnOtelSinkFailure(\"recordException\", recordError);\n }\n}\n\nfunction safeEndSpan(span: OtelSpan): void {\n try {\n span.end();\n } catch (error) {\n warnOtelSinkFailure(\"end\", error);\n }\n}\n\nfunction readSummary(result: SpawnResult): string {\n return result.stdout.trim() || result.stderr.trim();\n}\n\nfunction warnOtelSinkFailure(method: string, error: unknown): void {\n console.warn(`OpenTelemetry sink ${method} failed: ${readErrorMessage(error)}`);\n}\n\nfunction readErrorMessage(error: unknown): string {\n return error instanceof Error ? error.message : String(error);\n}\n", "import { spawn } from \"node:child_process\";\n\nexport interface CommandRunnerResult {\n stdout: string;\n stderr: string;\n exitCode: number;\n}\n\nexport interface CommandRunnerOptions {\n cwd?: string;\n env?: Record<string, string | undefined>;\n stdin?: string | Buffer;\n}\n\nexport type CommandRunner = (\n command: string,\n args: string[],\n options?: CommandRunnerOptions\n) => Promise<CommandRunnerResult>;\n\nexport function runCommand(\n command: string,\n args: string[],\n options?: CommandRunnerOptions\n): Promise<CommandRunnerResult> {\n return new Promise((resolve) => {\n const hasStdin = options?.stdin != null;\n const child = spawn(command, args, {\n stdio: [hasStdin ? \"pipe\" : \"ignore\", \"pipe\", \"pipe\"],\n cwd: options?.cwd,\n env: options?.env\n ? {\n ...(process.env as Record<string, string | undefined>),\n ...options.env\n }\n : undefined\n });\n let stdout = \"\";\n let stderr = \"\";\n\n if (hasStdin && child.stdin) {\n child.stdin.on(\"error\", () => {});\n child.stdin.end(options!.stdin);\n }\n\n child.stdout?.setEncoding(\"utf8\");\n child.stdout?.on(\"data\", (chunk: string | Buffer) => {\n stdout += chunk.toString();\n });\n\n child.stderr?.setEncoding(\"utf8\");\n child.stderr?.on(\"data\", (chunk: string | Buffer) => {\n stderr += chunk.toString();\n });\n\n child.on(\"error\", (error: NodeJS.ErrnoException) => {\n const exitCode =\n typeof error.code === \"number\"\n ? error.code\n : typeof error.errno === \"number\"\n ? error.errno\n : 127;\n const message =\n error instanceof Error ? error.message : String(error ?? \"error\");\n resolve({\n stdout,\n stderr: stderr ? `${stderr}${message}` : message,\n exitCode\n });\n });\n\n child.on(\"close\", (code) => {\n resolve({\n stdout,\n stderr,\n exitCode: code ?? 0\n });\n });\n });\n}\n", "import type { AdapterType } from \"./adapters/index.js\";\nimport type { RuntimeOverrideOptions } from \"@poe-code/agent-harness-tools\";\nimport type { StateManager } from \"@poe-code/poe-code-config\";\nimport type { AcpMiddleware } from \"./acp/middleware.js\";\n\nexport type SpawnMode = \"yolo\" | \"edit\" | \"read\";\n\nexport type SpawnModeConfig = string[] | { args?: string[]; env?: Record<string, string> };\n\nexport function resolveModeConfig(modeConfig: SpawnModeConfig): {\n args: string[];\n env?: Record<string, string>;\n} {\n if (Array.isArray(modeConfig)) {\n return { args: modeConfig };\n }\n return {\n args: modeConfig.args ?? [],\n env: modeConfig.env && Object.keys(modeConfig.env).length > 0 ? modeConfig.env : undefined\n };\n}\n\nexport interface McpSpawnServer {\n command: string;\n args?: string[];\n env?: Record<string, string>;\n /**\n * Maximum time in seconds the agent should wait for a single tool call\n * to this MCP server before timing out. Omit to use the agent's default.\n */\n timeout?: number;\n}\n\nexport type McpSpawnConfig = Record<string, McpSpawnServer>;\n\nexport type OtelSpan = {\n setAttribute(key: string, value: unknown): void;\n addEvent(name: string, attrs: Record<string, unknown>): void;\n end(): void;\n};\n\nexport interface OtelSink {\n startSpan(name: string, attrs: Record<string, unknown>): OtelSpan;\n recordException(span: ReturnType<OtelSink[\"startSpan\"]>, error: unknown): void;\n}\n\nexport interface SpawnOptions {\n prompt: string;\n cwd?: string;\n model?: string;\n mode?: SpawnMode;\n args?: string[];\n mcpServers?: McpSpawnConfig;\n /** Skill references to bridge into the spawned agent for this run. */\n skills?: string[];\n /** Resume a prior provider thread/session before sending the prompt. */\n resumeThreadId?: string;\n useStdin?: boolean;\n interactive?: boolean;\n signal?: AbortSignal;\n otelSink?: OtelSink;\n middlewares?: AcpMiddleware[];\n tee?: {\n stdout?: { write(chunk: string): void };\n stderr?: { write(chunk: string): void };\n };\n /**\n * Kill the spawned process after this many milliseconds of inactivity (no stdout data).\n * Resets on every chunk of stdout/stderr received. Disabled when undefined.\n */\n activityTimeoutMs?: number;\n /**\n * Full path for the spawn log file. When set, stdout (and stderr for CLI spawns)\n * are appended to this file, and the absolute path is returned in `SpawnResult.logFile`.\n * Takes precedence over `logDir` + `logFileName`.\n */\n logPath?: string;\n /**\n * Directory for the spawn log file. When set together with `logFileName`, stdout\n * (and stderr for CLI spawns) are appended to `<logDir>/<logFileName>`, and the\n * absolute path is returned in `SpawnResult.logFile`.\n */\n logDir?: string;\n /** Overrides the auto-generated log filename. Must be used together with `logDir`. */\n logFileName?: string;\n /** Per-invocation runtime/runner config overrides. */\n runtime?: RuntimeOverrideOptions[\"runtime\"];\n /** Docker image override for docker runtime. */\n runtimeImage?: string;\n /** E2B template override for e2b runtime. */\n runtimeTemplate?: string;\n /** Directory used to load runtime config/templates when different from cwd. */\n runtimeConfigCwd?: string;\n /** Run through a detached runtime job when the backend supports it. */\n detach?: boolean;\n /** Mount the local poe-code checkout into the runtime for development. */\n mountPoeCode?: boolean;\n /** Override runner workspace sync behavior. */\n runnerSync?: RuntimeOverrideOptions[\"runnerSync\"];\n}\n\nexport interface SpawnUsage {\n inputTokens: number;\n outputTokens: number;\n cachedTokens?: number;\n costUsd?: number;\n}\n\nexport interface SpawnResult {\n stdout: string;\n stderr: string;\n exitCode: number;\n durationMs?: number;\n threadId?: string;\n usage?: SpawnUsage;\n logFile?: string;\n detached?: { jobId: string; envId: string };\n}\n\nexport interface AutonomousResult {\n summary?: string;\n log?: string;\n output?: string;\n stdout?: string;\n text?: string;\n logFile?: string;\n toolCalls?: unknown[];\n sessionResult?: {\n toolCalls?: unknown[];\n };\n}\n\nexport interface SpawnLogger {\n dryRun(message: string): void;\n}\n\nexport interface SpawnContext {\n dryRun?: boolean;\n logger?: SpawnLogger;\n homeDir?: string;\n state?: StateManager;\n}\n\nexport interface StdinMode {\n omitPrompt: boolean;\n extraArgs: string[];\n}\n\nexport interface InteractiveSpawnConfig {\n defaultArgs: string[];\n defaultArgsPosition?: \"beforePrompt\" | \"afterPrompt\";\n promptFlag?: string;\n}\n\nexport interface CliSpawnConfig {\n kind: \"cli\";\n agentId: string;\n adapter: AdapterType;\n promptFlag: string;\n defaultArgs: string[];\n defaultArgsPosition?: \"beforePrompt\" | \"afterPrompt\";\n modes: Record<SpawnMode, SpawnModeConfig>;\n stdinMode?: StdinMode;\n modelFlag?: string;\n /**\n * Controls whether the provider prefix is stripped from model IDs before passing to the CLI binary.\n *\n * When `true`: \"anthropic/claude-opus-4.6\" \u2192 \"claude-opus-4.6\", \"openai/gpt-5.2\" \u2192 \"gpt-5.2\"\n * When `false`: \"anthropic/claude-opus-4.6\" stays as-is, \"openai/gpt-5.2\" stays as-is\n *\n * Most CLI binaries only accept bare model IDs (e.g. `claude --model claude-opus-4.6`),\n * so they need `true`. OpenCode routes through poe and needs the full provider path, so it uses `false`.\n */\n modelStripProviderPrefix: boolean;\n /** Transform model ID before passing to CLI. Runs after provider prefix stripping (if enabled). */\n modelTransform?: (model: string) => string;\n /**\n * Transforms MCP server config into CLI args for this agent.\n * Presence of this function declares spawn-time MCP support.\n */\n mcpArgs?: (servers: McpSpawnConfig) => string[];\n /**\n * Transforms MCP server config into env vars for this agent.\n * Use instead of `mcpArgs` when the agent reads MCP config from the environment.\n */\n mcpEnv?: (servers: McpSpawnConfig) => Record<string, string>;\n /**\n * Controls where serialized MCP args are inserted relative to the command.\n *\n * - \"beforeCommand\": before the prompt/subcommand section (e.g. `codex -c ... exec \"prompt\"`)\n * - \"beforePrompt\": after `defaultArgs` but before the prompt/model section\n * - \"afterCommand\": after `defaultArgs` (default)\n */\n mcpArgsPosition?: \"beforeCommand\" | \"beforePrompt\" | \"afterCommand\";\n /**\n * @deprecated Prefer `mcpArgsPosition`.\n * When true, MCP args are placed before the subcommand (e.g. `codex -c ... exec \"prompt\"`).\n * When false/undefined, they are placed after defaultArgs (e.g. `claude -p \"prompt\" --mcp-servers ...`).\n */\n mcpArgsBeforeCommand?: boolean;\n interactive?: InteractiveSpawnConfig;\n resume?: ResumeSpec;\n}\n\nexport interface ResumeSpec {\n /** Args injected into the live spawn for non-interactive resume. */\n args: (threadId: string, cwd: string) => string[];\n /** Position of `args` relative to the prompt token. Default `afterPrompt`. */\n position?: \"beforePrompt\" | \"afterPrompt\";\n /**\n * Optional override for the printed copy-paste resume hint (e.g. an interactive\n * shell command). When omitted, the hint composes binaryName + `args`.\n */\n hintArgs?: (threadId: string, cwd: string) => string[];\n}\n\nexport interface FileSpawnConfig {\n kind: \"file\";\n agentId: string;\n launchCommand?: string;\n launchArgs?: string[];\n}\n\nexport interface AcpSpawnConfig {\n kind: \"acp\";\n agentId: string;\n /** Args passed to the agent binary to start its ACP server (e.g. [\"acp\"]). */\n acpArgs: string[];\n /** Environment variables required by the ACP server process. */\n env?: Record<string, string>;\n /** Whether to skip the ACP authenticate step (workaround for servers that advertise but don't implement auth). */\n skipAuth?: boolean;\n /** MCP server env serializer, same as CliSpawnConfig. */\n mcpEnv?: (servers: McpSpawnConfig) => Record<string, string>;\n}\n\nexport type SpawnConfig = CliSpawnConfig | FileSpawnConfig | AcpSpawnConfig;\n", "import type { McpSpawnConfig } from \"../types.js\";\n\ninterface JsonMcpServer {\n command: string;\n args?: string[];\n env?: Record<string, string>;\n timeout?: number;\n}\n\nfunction toJsonMcpServers(servers: McpSpawnConfig): Record<string, JsonMcpServer> {\n const out: Record<string, JsonMcpServer> = {};\n\n for (const [name, server] of Object.entries(servers)) {\n const mapped: JsonMcpServer = { command: server.command };\n if (server.args && server.args.length > 0) {\n mapped.args = server.args;\n }\n if (server.env && Object.keys(server.env).length > 0) {\n mapped.env = server.env;\n }\n if (server.timeout !== undefined) {\n mapped.timeout = server.timeout;\n }\n out[name] = mapped;\n }\n\n return out;\n}\n\nfunction toTomlString(value: string): string {\n return JSON.stringify(value);\n}\n\nfunction toTomlArray(values: string[]): string {\n const serialized = values.map((value) => toTomlString(value));\n return `[${serialized.join(\", \")}]`;\n}\n\nfunction toTomlInlineTable(values: Record<string, string>): string {\n const parts: string[] = [];\n for (const [key, value] of Object.entries(values)) {\n parts.push(`${JSON.stringify(key)}=${toTomlString(value)}`);\n }\n return `{${parts.join(\", \")}}`;\n}\n\nexport function serializeJsonMcpArgs(servers: McpSpawnConfig): string[] {\n return [\"--mcp-config\", JSON.stringify({ mcpServers: toJsonMcpServers(servers) })];\n}\n\nexport function serializeOpenCodeMcpEnv(servers: McpSpawnConfig): Record<string, string> {\n const mcp: Record<\n string,\n { type: \"local\"; command: string[]; environment?: Record<string, string> }\n > = {};\n for (const [name, server] of Object.entries(servers)) {\n const entry: {\n type: \"local\";\n command: string[];\n environment?: Record<string, string>;\n } = { type: \"local\", command: [server.command, ...(server.args ?? [])] };\n if (server.env && Object.keys(server.env).length > 0) {\n entry.environment = server.env;\n }\n mcp[name] = entry;\n }\n return { OPENCODE_CONFIG_CONTENT: JSON.stringify({ mcp }) };\n}\n\nexport function serializeCodexMcpArgs(servers: McpSpawnConfig): string[] {\n const args: string[] = [];\n\n for (const [name, server] of Object.entries(servers)) {\n const prefix = `mcp_servers.${name}`;\n args.push(\"-c\", `${prefix}.command=${toTomlString(server.command)}`);\n\n if (server.args && server.args.length > 0) {\n args.push(\"-c\", `${prefix}.args=${toTomlArray(server.args)}`);\n }\n\n if (server.env && Object.keys(server.env).length > 0) {\n args.push(\"-c\", `${prefix}.env=${toTomlInlineTable(server.env)}`);\n }\n\n if (server.timeout !== undefined) {\n args.push(\"-c\", `${prefix}.timeout=${server.timeout}`);\n }\n }\n\n return args;\n}\n\nexport function serializeGooseMcpArgs(servers: McpSpawnConfig): string[] {\n return Object.values(servers).flatMap((server) => [\n \"--with-extension\",\n [server.command, ...(server.args ?? [])].join(\" \")\n ]);\n}\n", "import type { CliSpawnConfig } from \"../types.js\";\nimport { serializeJsonMcpArgs } from \"./mcp.js\";\n\nexport const claudeCodeSpawnConfig: CliSpawnConfig = {\n kind: \"cli\",\n agentId: \"claude-code\",\n // ACP adapter support: yes (adapter: \"claude\")\n adapter: \"claude\",\n promptFlag: \"-p\",\n modelFlag: \"--model\",\n modelStripProviderPrefix: true,\n modelTransform: (model) => model.replaceAll(\".\", \"-\"),\n defaultArgs: [\n \"--output-format\",\n \"stream-json\",\n \"--verbose\"\n ],\n mcpArgs: serializeJsonMcpArgs,\n modes: {\n yolo: [\"--dangerously-skip-permissions\"],\n edit: [\"--permission-mode\", \"acceptEdits\", \"--allowedTools\", \"Bash,Read,Write,Edit,Glob,Grep,NotebookEdit\"],\n read: [\"--permission-mode\", \"plan\"]\n },\n stdinMode: {\n omitPrompt: true,\n extraArgs: [\"--input-format\", \"text\"]\n },\n interactive: {\n defaultArgs: []\n },\n resume: {\n args: (threadId) => [\"--resume\", threadId]\n }\n};\n", "import type { CliSpawnConfig } from \"../types.js\";\nimport { serializeCodexMcpArgs } from \"./mcp.js\";\n\nexport const codexSpawnConfig: CliSpawnConfig = {\n kind: \"cli\",\n agentId: \"codex\",\n // ACP adapter support: yes (adapter: \"codex\")\n adapter: \"codex\",\n promptFlag: \"exec\",\n modelFlag: \"--model\",\n modelStripProviderPrefix: true,\n defaultArgs: [\"--skip-git-repo-check\", \"--json\"],\n mcpArgs: serializeCodexMcpArgs,\n mcpArgsBeforeCommand: true,\n modes: {\n yolo: [\"-s\", \"danger-full-access\"],\n edit: [\"-s\", \"workspace-write\"],\n read: [\"-s\", \"read-only\"]\n },\n stdinMode: {\n omitPrompt: true,\n extraArgs: [\"-\"]\n },\n interactive: {\n defaultArgs: [\"-a\", \"never\"]\n },\n resume: {\n args: (threadId) => [\"resume\", threadId],\n position: \"beforePrompt\",\n hintArgs: (threadId, cwd) => [\"resume\", \"-C\", cwd, threadId]\n }\n};\n", "import type { AcpSpawnConfig, CliSpawnConfig } from \"../types.js\";\nimport { serializeOpenCodeMcpEnv } from \"./mcp.js\";\n\n/**\n * OpenCode JSON output format (empirically observed)\n *\n * OpenCode can emit \"raw JSON events\" when running a prompt via:\n * - `opencode run \"<prompt>\" --format json ...`\n *\n * Key observations (OpenCode CLI v1.1.47):\n * - Output is **NDJSON / line-delimited JSON**: one JSON object per stdout line.\n * - Each line is an event object with a top-level `type` string (NOT ACP's `{ event: ... }`).\n * - Common top-level fields:\n * - `type`: `\"step_start\" | \"text\" | \"tool_use\" | \"step_finish\" | ...`\n * - `timestamp`: number (ms since epoch)\n * - `sessionID`: string (e.g. `\"ses_...\"`)\n * - `part`: object with event-specific payload\n *\n * `text` events:\n * ```ts\n * {\n * type: \"text\",\n * sessionID: \"ses_...\",\n * part: {\n * type: \"text\",\n * messageID: \"msg_...\",\n * text: \"Hello ...\",\n * time: { start: 1770000000000, end: 1770000000000 }\n * }\n * }\n * ```\n *\n * Tool calls (`tool_use`):\n * - Represented as a single event with `part.type: \"tool\"` and `state.status`.\n * - `state.input` includes tool arguments; `state.output` is the tool result string.\n * ```ts\n * {\n * type: \"tool_use\",\n * sessionID: \"ses_...\",\n * part: {\n * type: \"tool\",\n * callID: \"call_...\",\n * tool: \"bash\",\n * state: {\n * status: \"completed\",\n * input: { command: \"echo hello\", description: \"...\" },\n * output: \"hello\\n\"\n * }\n * }\n * }\n * ```\n *\n * Step boundaries:\n * - `step_start` and `step_finish` wrap a single model/tool turn.\n * - `step_finish.part.tokens` contains token accounting:\n * `{ input, output, reasoning, cache: { read, write } }`\n *\n * Negative cases / gotchas:\n * - Some failures (e.g. invalid `--model` / unknown provider) can print a non-JSON stack trace\n * before any JSON events are emitted, even with `--format json`.\n * - If `--format json` is ever removed upstream, OpenCode will need a text-mode fallback\n * (no streaming event adapter).\n */\nexport const openCodeSpawnConfig: CliSpawnConfig = {\n kind: \"cli\",\n agentId: \"opencode\",\n // ACP adapter support: yes (adapter: \"opencode\").\n // OpenCode's `--format json` emits NDJSON events with `{ type, sessionID, part }`\n // (no `{ event, ... }` field), so it needs the OpenCode adapter (not \"native\").\n adapter: \"opencode\",\n promptFlag: \"run\",\n modelFlag: \"--model\",\n modelStripProviderPrefix: false,\n modelTransform: (model) => {\n return model.startsWith(\"poe/\") ? model : `poe/${model}`;\n },\n defaultArgs: [\"--format\", \"json\"],\n modes: {\n yolo: [],\n edit: [],\n read: [\"--agent\", \"plan\"]\n },\n interactive: {\n defaultArgs: [],\n promptFlag: \"--prompt\"\n },\n resume: {\n args: (threadId) => [\"--session\", threadId],\n hintArgs: (threadId, cwd) => [cwd, \"--session\", threadId]\n },\n mcpEnv: serializeOpenCodeMcpEnv\n};\n\nexport const openCodeAcpSpawnConfig: AcpSpawnConfig = {\n kind: \"acp\",\n agentId: \"opencode\",\n acpArgs: [\"acp\"],\n skipAuth: true,\n mcpEnv: serializeOpenCodeMcpEnv,\n};\n", "import type { AcpSpawnConfig, CliSpawnConfig } from \"../types.js\";\nimport { serializeJsonMcpArgs } from \"./mcp.js\";\n\nexport const kimiSpawnConfig: CliSpawnConfig = {\n kind: \"cli\",\n agentId: \"kimi\",\n // ACP adapter support: yes (adapter: \"kimi\").\n // Kimi's `--output-format stream-json` emits OpenAI-style `{ role, content }` JSON\n // (no `{ event, ... }` field), so it needs the Kimi adapter (not \"native\").\n adapter: \"kimi\",\n promptFlag: \"-p\",\n modelStripProviderPrefix: true,\n defaultArgs: [\"--print\", \"--output-format\", \"stream-json\"],\n mcpArgs: serializeJsonMcpArgs,\n modes: {\n yolo: [\"--yolo\"],\n edit: [],\n read: []\n },\n stdinMode: {\n omitPrompt: true,\n extraArgs: [\"--input-format\", \"stream-json\"]\n },\n interactive: {\n defaultArgs: [],\n promptFlag: \"-p\"\n },\n resume: {\n args: (threadId, cwd) => [\"--session\", threadId, \"--work-dir\", cwd]\n }\n};\n\nexport const kimiAcpSpawnConfig: AcpSpawnConfig = {\n kind: \"acp\",\n agentId: \"kimi\",\n acpArgs: [\"acp\"],\n};\n", "import type { AcpSpawnConfig, CliSpawnConfig } from \"../types.js\";\nimport { serializeGooseMcpArgs } from \"./mcp.js\";\n\nconst gooseFileSecretsEnv = { GOOSE_DISABLE_KEYRING: \"1\" };\n\nexport const gooseSpawnConfig: CliSpawnConfig = {\n kind: \"cli\",\n agentId: \"goose\",\n adapter: \"native\",\n promptFlag: \"--text\",\n modelFlag: \"--model\",\n modelStripProviderPrefix: false,\n defaultArgs: [\"run\", \"--output-format\", \"stream-json\"],\n defaultArgsPosition: \"beforePrompt\",\n mcpArgs: serializeGooseMcpArgs,\n mcpArgsPosition: \"beforePrompt\",\n modes: {\n yolo: { env: { ...gooseFileSecretsEnv, GOOSE_MODE: \"auto\" } },\n edit: { env: { ...gooseFileSecretsEnv, GOOSE_MODE: \"smart_approve\" } },\n read: { env: { ...gooseFileSecretsEnv, GOOSE_MODE: \"chat\" } }\n },\n stdinMode: {\n omitPrompt: true,\n extraArgs: [\"--instructions\", \"-\"]\n },\n interactive: {\n defaultArgs: [\"session\"],\n defaultArgsPosition: \"beforePrompt\"\n },\n resume: {\n args: (threadId) => [\"--resume\", \"--session-id\", threadId],\n hintArgs: (threadId) => [\"run\", \"--resume\", \"--session-id\", threadId, \"--text\", \"continue\"]\n }\n};\n\nexport const gooseAcpSpawnConfig: AcpSpawnConfig = {\n kind: \"acp\",\n agentId: \"goose\",\n acpArgs: [\"acp\"],\n env: gooseFileSecretsEnv,\n skipAuth: true\n};\n", "import { resolveAgentId } from \"@poe-code/agent-defs\";\nimport type { AcpSpawnConfig, SpawnConfig } from \"../types.js\";\nimport { claudeCodeSpawnConfig } from \"./claude-code.js\";\nimport { codexSpawnConfig } from \"./codex.js\";\nimport { openCodeSpawnConfig, openCodeAcpSpawnConfig } from \"./opencode.js\";\nimport { kimiSpawnConfig, kimiAcpSpawnConfig } from \"./kimi.js\";\nimport { gooseSpawnConfig, gooseAcpSpawnConfig } from \"./goose.js\";\n\n// ACP adapter support (spawn streaming):\n// - Supported (has `adapter`): claude-code, codex, opencode, kimi, goose\nexport const allSpawnConfigs: readonly SpawnConfig[] = [\n claudeCodeSpawnConfig,\n codexSpawnConfig,\n openCodeSpawnConfig,\n kimiSpawnConfig,\n gooseSpawnConfig\n];\n\nconst lookup = new Map<string, SpawnConfig>();\n\nfor (const config of allSpawnConfigs) {\n lookup.set(config.agentId, config);\n}\n\nconst acpLookup = new Map<string, AcpSpawnConfig>();\nacpLookup.set(openCodeAcpSpawnConfig.agentId, openCodeAcpSpawnConfig);\nacpLookup.set(kimiAcpSpawnConfig.agentId, kimiAcpSpawnConfig);\nacpLookup.set(gooseAcpSpawnConfig.agentId, gooseAcpSpawnConfig);\n\nexport function getSpawnConfig(input: string): SpawnConfig | undefined {\n const resolvedId = resolveAgentId(input);\n if (!resolvedId) {\n return undefined;\n }\n return lookup.get(resolvedId);\n}\n\nexport function getAcpSpawnConfig(input: string): AcpSpawnConfig | undefined {\n const resolvedId = resolveAgentId(input);\n if (!resolvedId) {\n return undefined;\n }\n return acpLookup.get(resolvedId);\n}\n\nexport function supportsMcpAtSpawn(input: string): boolean {\n const config = getSpawnConfig(input);\n return (\n !!config &&\n config.kind === \"cli\" &&\n (typeof config.mcpArgs === \"function\" || typeof config.mcpEnv === \"function\")\n );\n}\n\nexport function listMcpSupportedAgents(): string[] {\n const supported: string[] = [];\n\n for (const config of allSpawnConfigs) {\n if (\n config.kind !== \"cli\" ||\n (typeof config.mcpArgs !== \"function\" && typeof config.mcpEnv !== \"function\")\n ) {\n continue;\n }\n supported.push(config.agentId);\n }\n\n return supported;\n}\n", "import \"./register-factories.js\";\nimport { mkdirSync, openSync, writeSync, closeSync } from \"node:fs\";\nimport path from \"node:path\";\nimport { runPoeCommand } from \"@poe-code/agent-harness-tools\";\nimport { resolveConfig } from \"./configs/resolve-config.js\";\nimport { getMcpArgs } from \"./mcp-args.js\";\nimport { stripModelNamespace } from \"./model-utils.js\";\nimport { observeAgentSpawn } from \"./observability/otel.js\";\nimport { createSpawnParallel } from \"./parallel.js\";\nimport { shouldSendPromptViaStdin } from \"./prompt-transport.js\";\nimport { createSpawnRetry } from \"./retry.js\";\nimport { resolveSpawnExecution } from \"./runtime.js\";\nimport { bridgeSkillsForRun, cleanupSkillsForRun } from \"./skill-bridge.js\";\nimport { spawnStreaming } from \"./acp/spawn.js\";\nimport {\n resolveModeConfig,\n type CliSpawnConfig,\n type McpSpawnConfig,\n type SpawnContext,\n type SpawnMode,\n type SpawnOptions,\n type SpawnResult,\n type StdinMode\n} from \"./types.js\";\n\nfunction createAbortError(): Error {\n const error = new Error(\"Agent spawn aborted\");\n error.name = \"AbortError\";\n return error;\n}\n\nexport function isActivityTimeoutError(error: unknown): boolean {\n return error instanceof Error && error.name === \"ActivityTimeoutError\";\n}\n\nexport interface BuildSpawnArgsOptions {\n prompt: string;\n model?: string;\n mode?: SpawnMode;\n args?: string[];\n mcpServers?: McpSpawnConfig;\n resumeThreadId?: string;\n cwd?: string;\n useStdin?: boolean;\n}\n\nexport interface BuildSpawnArgsResult {\n binaryName: string;\n args: string[];\n env?: Record<string, string>;\n}\n\nfunction resolveCliConfig(agentId: string) {\n const resolved = resolveConfig(agentId);\n\n if (!resolved.spawnConfig) {\n throw new Error(`Agent \"${resolved.agentId}\" has no spawn config.`);\n }\n\n if (resolved.spawnConfig.kind !== \"cli\") {\n throw new Error(`Agent \"${resolved.agentId}\" does not support CLI spawn.`);\n }\n\n if (!resolved.binaryName) {\n throw new Error(`Agent \"${resolved.agentId}\" has no binaryName.`);\n }\n\n return {\n agentId: resolved.agentId,\n binaryName: resolved.binaryName,\n spawnConfig: resolved.spawnConfig\n };\n}\n\nfunction getDefaultArgsPosition(config: CliSpawnConfig): \"beforePrompt\" | \"afterPrompt\" {\n return config.defaultArgsPosition ?? \"afterPrompt\";\n}\n\nfunction getMcpArgsPosition(\n config: CliSpawnConfig\n): \"beforeCommand\" | \"beforePrompt\" | \"afterCommand\" {\n if (config.mcpArgsPosition) {\n return config.mcpArgsPosition;\n }\n return config.mcpArgsBeforeCommand ? \"beforeCommand\" : \"afterCommand\";\n}\n\nfunction buildCliArgs(\n config: CliSpawnConfig,\n options: BuildSpawnArgsOptions,\n stdinMode?: StdinMode\n): { args: string[]; env?: Record<string, string> } {\n const mcpArgs = getMcpArgs(config, options.mcpServers);\n const resumeArgs = getResumeArgs(config, options);\n const defaultArgsPosition = getDefaultArgsPosition(config);\n const mcpArgsPosition = getMcpArgsPosition(config);\n const resumeArgsPosition = config.resume?.position ?? \"afterPrompt\";\n\n const args: string[] = [];\n\n if (mcpArgsPosition === \"beforeCommand\") {\n args.push(...mcpArgs);\n }\n\n if (defaultArgsPosition === \"beforePrompt\") {\n args.push(...config.defaultArgs);\n }\n\n if (mcpArgsPosition === \"beforePrompt\") {\n args.push(...mcpArgs);\n }\n\n if (stdinMode) {\n args.push(config.promptFlag);\n if (resumeArgsPosition === \"beforePrompt\") {\n args.push(...resumeArgs);\n }\n args.push(...(stdinMode.omitPrompt ? [] : [options.prompt]), ...stdinMode.extraArgs);\n } else {\n args.push(config.promptFlag);\n if (resumeArgsPosition === \"beforePrompt\") {\n args.push(...resumeArgs);\n }\n args.push(options.prompt);\n }\n\n if (options.model && config.modelFlag) {\n let model = config.modelStripProviderPrefix\n ? stripModelNamespace(options.model)\n : options.model;\n if (config.modelTransform) model = config.modelTransform(model);\n args.push(config.modelFlag, model);\n }\n\n if (defaultArgsPosition === \"afterPrompt\") {\n args.push(...config.defaultArgs);\n }\n\n if (mcpArgsPosition === \"afterCommand\") {\n args.push(...mcpArgs);\n }\n\n const mode = resolveModeConfig(config.modes[options.mode ?? \"yolo\"]);\n args.push(...mode.args);\n\n if (options.args && options.args.length > 0) {\n if (resumeArgsPosition === \"afterPrompt\") {\n args.push(...resumeArgs);\n }\n args.push(...options.args);\n } else if (resumeArgsPosition === \"afterPrompt\") {\n args.push(...resumeArgs);\n }\n\n return { args, env: mode.env };\n}\n\nfunction getResumeArgs(\n config: CliSpawnConfig,\n options: Pick<BuildSpawnArgsOptions, \"resumeThreadId\" | \"cwd\">\n): string[] {\n if (!options.resumeThreadId) {\n return [];\n }\n\n if (!config.resume) {\n throw new Error(`Agent \"${config.agentId}\" does not support resumeThreadId.`);\n }\n\n return config.resume.args(options.resumeThreadId, options.cwd ?? process.cwd());\n}\n\nexport function buildSpawnArgs(\n agentId: string,\n options: BuildSpawnArgsOptions\n): BuildSpawnArgsResult {\n const { binaryName, spawnConfig } = resolveCliConfig(agentId);\n const stdinMode = shouldSendPromptViaStdin(spawnConfig, options)\n ? spawnConfig.stdinMode\n : undefined;\n const result = buildCliArgs(spawnConfig, options, stdinMode);\n return { binaryName, args: result.args, env: result.env };\n}\n\nexport async function spawn(\n agentId: string,\n options: SpawnOptions,\n context?: SpawnContext\n): Promise<SpawnResult> {\n return observeAgentSpawn(\n {\n agent: agentId,\n cwd: options.cwd,\n mode: options.mode,\n otelSink: options.otelSink,\n prompt: options.prompt\n },\n () => runSpawn(agentId, options, context)\n );\n}\n\nasync function runSpawn(\n agentId: string,\n options: SpawnOptions,\n context?: SpawnContext\n): Promise<SpawnResult> {\n if (options.signal?.aborted) {\n throw createAbortError();\n }\n\n const { agentId: resolvedId, binaryName, spawnConfig } = resolveCliConfig(agentId);\n\n const stdinMode = shouldSendPromptViaStdin(spawnConfig, options)\n ? spawnConfig.stdinMode\n : undefined;\n\n const { args: spawnArgs, env: modeEnv } = buildCliArgs(spawnConfig, options, stdinMode);\n\n if (context?.dryRun) {\n const rendered = [binaryName, ...spawnArgs].join(\" \");\n context.logger?.dryRun(rendered);\n return { stdout: \"\", stderr: \"\", exitCode: 0 };\n }\n\n const cwd = options.cwd ?? process.cwd();\n const manifest = bridgeSkillsForRun(agentId, cwd, options.skills);\n let logFd: number | undefined;\n\n try {\n const logFilePath = resolveSpawnLogPath(options);\n logFd = logFilePath ? openSpawnLog(logFilePath) : undefined;\n\n const processEnv = modeEnv ? { ...process.env, ...modeEnv } : undefined;\n const argv = [binaryName, ...spawnArgs];\n const execution = resolveSpawnExecution({\n cwd,\n runtimeConfigCwd: options.runtimeConfigCwd,\n env: (processEnv ?? process.env) as Record<string, string>,\n argv,\n tool: resolvedId,\n runtime: {\n runtime: options.runtime,\n runtimeImage: options.runtimeImage,\n runtimeTemplate: options.runtimeTemplate,\n detach: options.detach,\n mountPoeCode: options.mountPoeCode,\n runnerSync: options.runnerSync\n },\n context,\n openSpec: {\n execution: {\n wrapForLogTee: false,\n stdin: stdinMode ? \"pipe\" : \"inherit\",\n stdout: \"pipe\",\n stderr: \"pipe\",\n env: processEnv as Record<string, string> | undefined,\n input: stdinMode ? options.prompt : undefined,\n captureOutput: true,\n activityTimeoutMs: options.activityTimeoutMs,\n onStdout(chunk: string) {\n options.tee?.stdout?.write(chunk);\n appendSpawnLog(logFd, chunk);\n },\n onStderr(chunk: string) {\n options.tee?.stderr?.write(chunk);\n appendSpawnLog(logFd, chunk);\n }\n }\n }\n });\n\n const result = await runPoeCommand({\n factory: execution.factory,\n openSpec: execution.openSpec,\n detach: execution.detach,\n state: execution.state,\n signal: options.signal\n });\n\n if (result.kind === \"detached\") {\n return {\n stdout: \"\",\n stderr: \"\",\n exitCode: 0,\n detached: { jobId: result.jobId, envId: result.envId },\n ...(logFilePath ? { logFile: logFilePath } : {})\n };\n }\n\n const captured = result as typeof result & { stdout?: string; stderr?: string };\n return {\n stdout: captured.stdout ?? \"\",\n stderr: captured.stderr ?? \"\",\n exitCode: result.exitCode,\n ...(logFilePath ? { logFile: logFilePath } : {})\n };\n } finally {\n closeSpawnLog(logFd);\n cleanupSkillsForRun(manifest);\n }\n}\n\nspawn.retry = createSpawnRetry<SpawnOptions, SpawnResult>((service, options) => {\n const handle = spawnStreaming({ ...options, agentId: service });\n return {\n events: handle.events,\n result: handle.done\n };\n});\n\nspawn.parallel = createSpawnParallel<string, SpawnOptions, SpawnResult>((service, options) => ({\n events: (async function* () {})(),\n result: spawn(service, options)\n}));\n\nfunction resolveSpawnLogPath(options: SpawnOptions): string | undefined {\n if (options.logPath) {\n return options.logPath;\n }\n if (!options.logDir || !options.logFileName) {\n return undefined;\n }\n return path.join(options.logDir, options.logFileName);\n}\n\nfunction openSpawnLog(filePath: string): number | undefined {\n try {\n mkdirSync(path.dirname(filePath), { recursive: true });\n return openSync(filePath, \"a\");\n } catch {\n return undefined;\n }\n}\n\nfunction appendSpawnLog(fd: number | undefined, chunk: string): void {\n if (fd === undefined) return;\n try {\n writeSync(fd, chunk);\n } catch {\n // ignore \u2014 logging is best-effort\n }\n}\n\nfunction closeSpawnLog(fd: number | undefined): void {\n if (fd === undefined) return;\n try {\n closeSync(fd);\n } catch {\n // ignore\n }\n}\n", "import { allAgents, resolveAgentId } from \"@poe-code/agent-defs\";\nimport type { SpawnConfig } from \"../types.js\";\nimport { getSpawnConfig } from \"./index.js\";\n\nexport interface ResolvedSpawnConfig {\n agentId: string;\n binaryName?: string;\n spawnConfig?: SpawnConfig;\n}\n\nexport function resolveConfig(agentId: string): ResolvedSpawnConfig {\n const resolvedAgentId = resolveAgentId(agentId);\n if (!resolvedAgentId) {\n throw new Error(`Unknown agent \"${agentId}\".`);\n }\n\n const agentDefinition = allAgents.find((agent) => agent.id === resolvedAgentId);\n if (!agentDefinition) {\n throw new Error(`Unknown agent \"${agentId}\".`);\n }\n\n const spawnConfig = getSpawnConfig(resolvedAgentId);\n const binaryName = agentDefinition.binaryName;\n\n return { agentId: resolvedAgentId, binaryName, spawnConfig };\n}\n", "import { listMcpSupportedAgents } from \"./configs/index.js\";\nimport type { CliSpawnConfig, McpSpawnConfig } from \"./types.js\";\n\nexport function hasMcpServers(servers?: McpSpawnConfig): servers is McpSpawnConfig {\n if (!servers) {\n return false;\n }\n return Object.keys(servers).length > 0;\n}\n\nexport function getMcpArgs(\n config: CliSpawnConfig,\n servers?: McpSpawnConfig\n): string[] {\n if (!hasMcpServers(servers)) {\n return [];\n }\n if (!config.mcpArgs && !config.mcpEnv) {\n throw new Error(formatUnsupportedMcpSpawnMessage(config.agentId));\n }\n if (!config.mcpArgs) {\n return [];\n }\n return config.mcpArgs(servers);\n}\n\nexport function getMcpEnv(\n config: CliSpawnConfig,\n servers?: McpSpawnConfig\n): Record<string, string> {\n if (!hasMcpServers(servers) || !config.mcpEnv) {\n return {};\n }\n return config.mcpEnv(servers);\n}\n\nexport function formatUnsupportedMcpSpawnMessage(agentId: string): string {\n const supported = listMcpSupportedAgents();\n const supportedText = supported.length > 0 ? supported.join(\", \") : \"(none)\";\n return (\n `Agent \"${agentId}\" does not support MCP servers at spawn time.\\n` +\n `Agents with spawn-time MCP support: ${supportedText}`\n );\n}\n", "/**\n * Strips the provider namespace prefix from a model identifier.\n * e.g., \"anthropic/claude-opus-4.6\" \u2192 \"claude-opus-4.6\"\n *\n * CLI binaries (claude, codex, opencode, kimi) only accept bare model IDs.\n * Passing a namespaced model like \"anthropic/claude-opus-4.6\" causes the\n * binary to fail with \"model not found\". This function MUST be called\n * before passing any model to a CLI binary via spawn args.\n */\nexport function stripModelNamespace(model: string): string {\n const slashIndex = model.indexOf(\"/\");\n return slashIndex === -1 ? model : model.slice(slashIndex + 1);\n}\n", "import type { AcpEvent } from \"./acp/types.js\";\nimport type { SpawnHandle } from \"./retry.js\";\n\nexport type SpawnParallelTuple<TService, TOptions> = readonly [\n service: TService,\n options: TOptions\n];\n\nexport type SpawnParallelThunk<TResult extends { exitCode: number }> = (\n signal?: AbortSignal\n) => SpawnHandle<TResult>;\n\nexport type SpawnParallelCall<\n TService,\n TOptions,\n TResult extends { exitCode: number }\n> = SpawnParallelTuple<TService, TOptions> | SpawnParallelThunk<TResult>;\n\nexport type SpawnParallelOptions = {\n maxConcurrent?: number;\n failFast?: boolean;\n signal?: AbortSignal;\n};\n\nexport class SpawnParallelError<TResult extends { exitCode: number }> extends Error {\n readonly index: number;\n readonly result: TResult;\n readonly results: Array<TResult | undefined>;\n\n constructor(index: number, result: TResult, results: Array<TResult | undefined>) {\n super(`spawn.parallel call ${index} failed with exit code ${result.exitCode}.`);\n this.name = \"SpawnParallelError\";\n this.index = index;\n this.result = result;\n this.results = results;\n }\n}\n\nexport function createSpawnParallel<\n TService,\n TOptions extends { signal?: AbortSignal },\n TResult extends { exitCode: number }\n>(\n spawnOnce: (service: TService, options: TOptions) => SpawnHandle<TResult>\n): (\n calls: Array<SpawnParallelCall<TService, TOptions, TResult>>,\n options?: SpawnParallelOptions\n) => Promise<TResult[]> {\n return async function parallel(calls, options = {}) {\n if (calls.length === 0) {\n return [];\n }\n\n const maxConcurrent = normalizeMaxConcurrent(options.maxConcurrent);\n const failFast = options.failFast ?? true;\n const group = new AbortController();\n const results: Array<TResult | undefined> = new Array(calls.length);\n const errors: unknown[] = [];\n let nextIndex = 0;\n let primaryFailure: unknown;\n\n const removeParentAbort = linkParentAbort(options.signal, group, (error) => {\n primaryFailure ??= error;\n });\n\n const worker = async () => {\n while (!primaryFailure) {\n const index = nextIndex;\n nextIndex += 1;\n\n if (index >= calls.length) {\n return;\n }\n\n try {\n const result = await runParallelCall(calls[index], spawnOnce, group.signal);\n results[index] = result;\n\n if (failFast && result.exitCode !== 0) {\n const error = new SpawnParallelError(index, result, results);\n primaryFailure ??= error;\n group.abort(error);\n return;\n }\n } catch (error) {\n if (failFast || group.signal.aborted) {\n primaryFailure ??= error;\n group.abort(error);\n return;\n }\n\n errors.push(error);\n }\n }\n };\n\n try {\n await Promise.allSettled(\n Array.from({ length: Math.min(maxConcurrent, calls.length) }, () => worker())\n );\n } finally {\n removeParentAbort();\n }\n\n if (primaryFailure) {\n throw primaryFailure;\n }\n\n if (errors.length > 0) {\n throw new AggregateError(errors, \"spawn.parallel failed before every call returned a result.\");\n }\n\n return results as TResult[];\n };\n}\n\nasync function runParallelCall<\n TService,\n TOptions extends { signal?: AbortSignal },\n TResult extends { exitCode: number }\n>(\n call: SpawnParallelCall<TService, TOptions, TResult>,\n spawnOnce: (service: TService, options: TOptions) => SpawnHandle<TResult>,\n signal: AbortSignal\n): Promise<TResult> {\n throwIfAborted(signal);\n\n if (typeof call === \"function\") {\n const handle = call(signal);\n const [result] = await Promise.all([handle.result, drainEvents(handle.events)]);\n return result;\n }\n\n if (!isSpawnTuple(call)) {\n throw new Error(\"spawn.parallel calls must be [service, options] tuples or spawn thunks.\");\n }\n\n const { options, cleanup } = withAbortSignal(call[1], signal);\n try {\n const handle = spawnOnce(call[0], options);\n const [result] = await Promise.all([handle.result, drainEvents(handle.events)]);\n return result;\n } finally {\n cleanup();\n }\n}\n\nasync function drainEvents(events: AsyncIterable<AcpEvent>): Promise<void> {\n for await (const ignoredEvent of events) {\n void ignoredEvent;\n // Drain the stream so streaming providers can complete while parallel returns results only.\n }\n}\n\nfunction normalizeMaxConcurrent(maxConcurrent: number | undefined): number {\n const value = maxConcurrent ?? 4;\n if (!Number.isInteger(value) || value < 1) {\n throw new Error(\"spawn.parallel maxConcurrent must be an integer greater than or equal to 1.\");\n }\n return value;\n}\n\nfunction isSpawnTuple<TService, TOptions>(\n call: SpawnParallelCall<TService, TOptions, { exitCode: number }>\n): call is SpawnParallelTuple<TService, TOptions> {\n return Array.isArray(call) && call.length === 2;\n}\n\nfunction withAbortSignal<TOptions extends { signal?: AbortSignal }>(\n options: TOptions,\n signal: AbortSignal\n): { options: TOptions; cleanup(): void } {\n if (!options.signal) {\n return {\n options: { ...options, signal },\n cleanup() {}\n };\n }\n\n const controller = new AbortController();\n const abort = () => {\n controller.abort();\n };\n\n if (signal.aborted || options.signal.aborted) {\n controller.abort();\n } else {\n signal.addEventListener(\"abort\", abort, { once: true });\n options.signal.addEventListener(\"abort\", abort, { once: true });\n }\n\n return {\n options: { ...options, signal: controller.signal },\n cleanup() {\n signal.removeEventListener(\"abort\", abort);\n options.signal?.removeEventListener(\"abort\", abort);\n }\n };\n}\n\nfunction linkParentAbort(\n parentSignal: AbortSignal | undefined,\n group: AbortController,\n setFailure: (error: Error) => void\n): () => void {\n if (!parentSignal) {\n return () => {};\n }\n\n const abort = () => {\n const error = createAbortError();\n setFailure(error);\n group.abort(error);\n };\n\n if (parentSignal.aborted) {\n abort();\n return () => {};\n }\n\n parentSignal.addEventListener(\"abort\", abort, { once: true });\n return () => parentSignal.removeEventListener(\"abort\", abort);\n}\n\nfunction throwIfAborted(signal: AbortSignal): void {\n if (signal.aborted) {\n throw createAbortError();\n }\n}\n\nfunction createAbortError(): Error {\n const error = new Error(\"Agent spawn parallel aborted\");\n error.name = \"AbortError\";\n return error;\n}\n", "import type { CliSpawnConfig } from \"./types.js\";\n\nexport function shouldSendPromptViaStdin(\n config: CliSpawnConfig,\n options: { prompt: string; useStdin?: boolean }\n): boolean {\n return !!config.stdinMode && (options.useStdin === true || options.prompt.includes(\"\\0\"));\n}\n", "import type { AcpEvent } from \"./acp/types.js\";\n\nexport type SpawnRetryOptions<TResult extends { exitCode: number }> = {\n maxAttempts: number;\n backoffMs: number;\n isRetryable?: (result: TResult) => boolean;\n};\n\nexport type SpawnHandle<TResult> = {\n events: AsyncIterable<AcpEvent>;\n result: Promise<TResult>;\n};\n\nexport type SpawnRetryFunction<\n TOptions extends { signal?: AbortSignal },\n TResult extends { exitCode: number }\n> = (\n service: string,\n options: TOptions,\n retryOptions: SpawnRetryOptions<TResult>\n) => SpawnHandle<TResult>;\n\ntype EventQueue<T> = AsyncIterable<T> & {\n push(value: T): void;\n close(): void;\n fail(error: unknown): void;\n};\n\nconst retryableExitCodes = new Set([1, 124, 125, 137]);\nconst maxBackoffMs = 30_000;\n\nexport function createSpawnRetry<\n TOptions extends { signal?: AbortSignal },\n TResult extends { exitCode: number }\n>(\n spawnOnce: (service: string, options: TOptions) => SpawnHandle<TResult>\n): SpawnRetryFunction<TOptions, TResult> {\n return (service, options, retryOptions) => {\n const normalizedRetryOptions = normalizeRetryOptions(retryOptions);\n const queue = createEventQueue<AcpEvent>();\n const result = runRetryingSpawn({\n service,\n options,\n retryOptions: normalizedRetryOptions,\n spawnOnce,\n emit: queue.push\n })\n .then((value) => {\n queue.close();\n return value;\n })\n .catch((error: unknown) => {\n queue.fail(error);\n throw error;\n });\n\n return {\n events: queue,\n result\n };\n };\n}\n\nexport function defaultIsRetryable(result: { exitCode: number }): boolean {\n return retryableExitCodes.has(result.exitCode);\n}\n\nexport function calculateBackoffMs(baseBackoffMs: number, completedAttempt: number): number {\n return Math.min(baseBackoffMs * 2 ** (completedAttempt - 1), maxBackoffMs);\n}\n\nfunction normalizeRetryOptions<TResult extends { exitCode: number }>(\n retryOptions: SpawnRetryOptions<TResult>\n): Required<SpawnRetryOptions<TResult>> {\n if (!Number.isInteger(retryOptions.maxAttempts) || retryOptions.maxAttempts < 1) {\n throw new Error(\"spawn.retry maxAttempts must be an integer greater than or equal to 1.\");\n }\n\n if (!Number.isFinite(retryOptions.backoffMs) || retryOptions.backoffMs < 0) {\n throw new Error(\"spawn.retry backoffMs must be a non-negative finite number.\");\n }\n\n return {\n maxAttempts: retryOptions.maxAttempts,\n backoffMs: retryOptions.backoffMs,\n isRetryable: retryOptions.isRetryable ?? defaultIsRetryable\n };\n}\n\nasync function runRetryingSpawn<\n TOptions extends { signal?: AbortSignal },\n TResult extends { exitCode: number }\n>(input: {\n service: string;\n options: TOptions;\n retryOptions: Required<SpawnRetryOptions<TResult>>;\n spawnOnce: (service: string, options: TOptions) => SpawnHandle<TResult>;\n emit: (event: AcpEvent) => void;\n}): Promise<TResult> {\n for (let attempt = 1; attempt <= input.retryOptions.maxAttempts; attempt += 1) {\n throwIfAborted(input.options.signal);\n\n const handle = input.spawnOnce(input.service, input.options);\n const events = forwardAttemptEvents(handle.events, attempt, input.emit);\n const result = await handle.result;\n await events;\n\n const isLastAttempt = attempt >= input.retryOptions.maxAttempts;\n if (result.exitCode === 0 || isLastAttempt || !input.retryOptions.isRetryable(result)) {\n return result;\n }\n\n const delayMs = calculateBackoffMs(input.retryOptions.backoffMs, attempt);\n input.emit(createWaitEvent(attempt, delayMs));\n await sleep(delayMs, input.options.signal);\n }\n\n throw new Error(\"spawn.retry reached an unreachable retry state.\");\n}\n\nasync function forwardAttemptEvents(\n events: AsyncIterable<AcpEvent>,\n attempt: number,\n emit: (event: AcpEvent) => void\n): Promise<void> {\n for await (const event of events) {\n emit(prefixEvent(event, attempt));\n }\n}\n\nfunction prefixEvent(event: AcpEvent, attempt: number): AcpEvent {\n const prefix = `attempt: ${attempt}`;\n\n if (event.event === \"agent_message\" || event.event === \"reasoning\") {\n return { ...event, text: `${prefix} ${event.text}` };\n }\n\n if (event.event === \"error\") {\n return { ...event, message: `${prefix} ${event.message}` };\n }\n\n if (event.event === \"tool_start\") {\n return { ...event, title: `${prefix} ${event.title}` };\n }\n\n if (event.event === \"tool_complete\") {\n return { ...event, path: `${prefix} ${event.path}` };\n }\n\n return {\n ...event,\n _meta: {\n ...(typeof event._meta === \"object\" && event._meta !== null ? event._meta : {}),\n attempt\n }\n };\n}\n\nfunction createWaitEvent(attempt: number, delayMs: number): AcpEvent {\n return {\n event: \"agent_message\",\n text: `attempt: ${attempt} wait ${delayMs}ms before retry`\n };\n}\n\nfunction sleep(delayMs: number, signal: AbortSignal | undefined): Promise<void> {\n throwIfAborted(signal);\n\n return new Promise((resolve, reject) => {\n const timeout = setTimeout(() => {\n signal?.removeEventListener(\"abort\", onAbort);\n resolve();\n }, delayMs);\n\n const onAbort = () => {\n clearTimeout(timeout);\n reject(createAbortError());\n };\n\n signal?.addEventListener(\"abort\", onAbort, { once: true });\n });\n}\n\nfunction throwIfAborted(signal: AbortSignal | undefined): void {\n if (signal?.aborted) {\n throw createAbortError();\n }\n}\n\nfunction createAbortError(): Error {\n const error = new Error(\"Agent spawn retry aborted\");\n error.name = \"AbortError\";\n return error;\n}\n\nfunction createEventQueue<T>(): EventQueue<T> {\n const values: T[] = [];\n const waiters: Array<{\n resolve(value: IteratorResult<T>): void;\n reject(error: unknown): void;\n }> = [];\n let closed = false;\n let failure: unknown;\n\n const next = (): Promise<IteratorResult<T>> => {\n if (values.length > 0) {\n return Promise.resolve({ value: values.shift() as T, done: false });\n }\n\n if (failure !== undefined) {\n return Promise.reject(failure);\n }\n\n if (closed) {\n return Promise.resolve({ value: undefined, done: true });\n }\n\n return new Promise((resolve, reject) => {\n waiters.push({ resolve, reject });\n });\n };\n\n return {\n push(value) {\n if (closed || failure !== undefined) {\n return;\n }\n\n const waiter = waiters.shift();\n if (waiter) {\n waiter.resolve({ value, done: false });\n return;\n }\n\n values.push(value);\n },\n close() {\n if (closed || failure !== undefined) {\n return;\n }\n\n closed = true;\n for (const waiter of waiters.splice(0)) {\n waiter.resolve({ value: undefined, done: true });\n }\n },\n fail(error) {\n if (closed || failure !== undefined) {\n return;\n }\n\n failure = error;\n for (const waiter of waiters.splice(0)) {\n waiter.reject(error);\n }\n },\n async *[Symbol.asyncIterator]() {\n while (true) {\n const item = await next();\n if (item.done) {\n return;\n }\n yield item.value;\n }\n }\n };\n}\n", "import crypto from \"node:crypto\";\nimport os from \"node:os\";\nimport {\n bridgeActiveSkills,\n cleanupBridgedSkills,\n type BridgeManifest\n} from \"@poe-code/agent-skill-config\";\nimport { logger } from \"@poe-code/design-system\";\n\nexport function bridgeSkillsForRun(\n agentId: string,\n cwd: string,\n skills: string[] | undefined\n): BridgeManifest | undefined {\n if (!skills || skills.length === 0) {\n return undefined;\n }\n\n const manifest = bridgeActiveSkills(agentId, cwd, skills, os.homedir(), crypto.randomUUID());\n for (const warning of manifest.warnings) {\n logger.warn(warning.message);\n }\n return manifest;\n}\n\nexport function cleanupSkillsForRun(manifest: BridgeManifest | undefined): void {\n if (!manifest) {\n return;\n }\n cleanupBridgedSkills(manifest);\n}\n", "import os from \"node:os\";\nimport path from \"node:path\";\nimport { resolveAgentId } from \"@poe-code/agent-defs\";\n\nexport interface AgentSkillConfig {\n globalSkillDir: string;\n localSkillDir: string;\n}\n\nexport type SkillScope = \"global\" | \"local\";\n\nconst agentSkillConfigs: Record<string, AgentSkillConfig> = {\n \"claude-code\": {\n globalSkillDir: \"~/.claude/skills\",\n localSkillDir: \".claude/skills\"\n },\n codex: {\n globalSkillDir: \"~/.codex/skills\",\n localSkillDir: \".codex/skills\"\n },\n opencode: {\n globalSkillDir: \"~/.config/opencode/skills\",\n localSkillDir: \".opencode/skills\"\n },\n goose: {\n globalSkillDir: \"~/.agents/skills\",\n localSkillDir: \".agents/skills\"\n }\n};\n\nexport const supportedAgents = Object.keys(agentSkillConfigs) as readonly string[];\n\nexport type AgentSupportStatus = \"supported\" | \"unsupported\" | \"unknown\";\n\nexport interface AgentSupportResult {\n status: AgentSupportStatus;\n input: string;\n id?: string;\n config?: AgentSkillConfig;\n}\n\nexport function resolveAgentSupport(\n input: string,\n registry: Record<string, AgentSkillConfig> = agentSkillConfigs\n): AgentSupportResult {\n const resolvedId = resolveAgentId(input);\n if (!resolvedId) {\n return { status: \"unknown\", input };\n }\n\n const config = registry[resolvedId];\n if (!config) {\n return { status: \"unsupported\", input, id: resolvedId };\n }\n\n return { status: \"supported\", input, id: resolvedId, config };\n}\n\nexport function getAgentConfig(agentId: string): AgentSkillConfig | undefined {\n const support = resolveAgentSupport(agentId);\n return support.status === \"supported\" ? support.config : undefined;\n}\n\nfunction expandHome(targetPath: string, homeDir: string = os.homedir()): string {\n if (!targetPath?.startsWith(\"~\")) {\n return targetPath;\n }\n\n if (targetPath === \"~\") {\n return homeDir;\n }\n\n // Handle ~./ -> ~/.\n if (targetPath.startsWith(\"~./\")) {\n targetPath = `~/.${targetPath.slice(3)}`;\n }\n\n let remainder = targetPath.slice(1);\n if (remainder.startsWith(\"/\") || remainder.startsWith(\"\\\\\")) {\n remainder = remainder.slice(1);\n } else if (remainder.startsWith(\".\")) {\n remainder = remainder.slice(1);\n if (remainder.startsWith(\"/\") || remainder.startsWith(\"\\\\\")) {\n remainder = remainder.slice(1);\n }\n }\n\n return remainder.length === 0 ? homeDir : path.join(homeDir, remainder);\n}\n\nexport function resolveSkillDir(\n config: AgentSkillConfig,\n scope: SkillScope,\n cwd: string,\n homeDir?: string\n): string {\n if (scope === \"global\") {\n return path.resolve(expandHome(config.globalSkillDir, homeDir));\n }\n\n return path.resolve(cwd, config.localSkillDir);\n}\n", "import { readFile, stat } from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\nimport type { TemplateLoader } from \"@poe-code/config-mutations\";\n\nconst TEMPLATE_IDS = [\"poe-generate.md\", \"terminal-pilot.md\"] as const;\ntype TemplateId = (typeof TEMPLATE_IDS)[number];\n\nconst cache = new Map<TemplateId, string>();\n\nasync function pathExists(target: string): Promise<boolean> {\n try {\n await stat(target);\n return true;\n } catch (error) {\n if (error && typeof error === \"object\" && \"code\" in error && error.code === \"ENOENT\") {\n return false;\n }\n throw error;\n }\n}\n\nasync function findPackageRoot(entryFilePath: string): Promise<string> {\n let current = path.dirname(entryFilePath);\n while (true) {\n if (await pathExists(path.join(current, \"package.json\"))) {\n return current;\n }\n const parent = path.dirname(current);\n if (parent === current) {\n throw new Error(\"Unable to locate package root for agent-skill-config templates.\");\n }\n current = parent;\n }\n}\n\nasync function resolveTemplatePath(templateId: TemplateId): Promise<string> {\n const packageRoot = await findPackageRoot(fileURLToPath(import.meta.url));\n const candidates = [\n path.join(packageRoot, \"src\", \"templates\", templateId),\n path.join(packageRoot, \"dist\", \"templates\", templateId),\n path.join(packageRoot, \"dist\", \"templates\", \"skill\", templateId)\n ];\n\n for (const candidate of candidates) {\n if (await pathExists(candidate)) {\n return candidate;\n }\n }\n\n throw new Error(`Template not found: ${templateId}`);\n}\n\nfunction isKnownTemplate(templateId: string): templateId is TemplateId {\n return (TEMPLATE_IDS as readonly string[]).includes(templateId);\n}\n\nexport async function loadTemplate(templateId: string): Promise<string> {\n if (!isKnownTemplate(templateId)) {\n throw new Error(`Template not found: ${templateId}`);\n }\n\n const cached = cache.get(templateId);\n if (cached !== undefined) {\n return cached;\n }\n\n const resolved = await resolveTemplatePath(templateId);\n const content = await readFile(resolved, \"utf8\");\n cache.set(templateId, content);\n return content;\n}\n\nexport function createTemplateLoader(): TemplateLoader {\n return loadTemplate;\n}\n", "import { statSync } from \"node:fs\";\nimport path from \"node:path\";\nimport { getAgentConfig, resolveAgentSupport, resolveSkillDir } from \"./configs.js\";\n\nexport interface SkillSource {\n kind: \"resolved\";\n ref: string;\n name: string;\n sourceAgentId?: string;\n sourcePath: string;\n scope: \"project\" | \"user\";\n}\n\nexport type SkillResolutionFailure =\n | { kind: \"malformed\"; ref: string }\n | { kind: \"unknown-agent\"; ref: string; agentInput: string }\n | { kind: \"not-found\"; ref: string; searchedPaths: string[] };\n\nexport type SkillResolution = SkillSource | SkillResolutionFailure;\n\ninterface SearchTier {\n scope: \"project\" | \"user\";\n sourcePath: string;\n}\n\nfunction isMalformedSegment(segment: string): boolean {\n return segment.length === 0 || segment !== segment.trim();\n}\n\nfunction isDirectory(targetPath: string): boolean {\n try {\n return statSync(targetPath).isDirectory();\n } catch {\n return false;\n }\n}\n\nfunction findSkill(\n ref: string,\n name: string,\n tiers: SearchTier[],\n sourceAgentId?: string\n): SkillResolution {\n for (const tier of tiers) {\n if (isDirectory(tier.sourcePath)) {\n return {\n kind: \"resolved\",\n ref,\n name,\n ...(sourceAgentId ? { sourceAgentId } : {}),\n sourcePath: tier.sourcePath,\n scope: tier.scope\n };\n }\n }\n\n return {\n kind: \"not-found\",\n ref,\n searchedPaths: tiers.map((tier) => tier.sourcePath)\n };\n}\n\nexport function resolveSkillReference(ref: string, cwd: string, homeDir: string): SkillResolution {\n const slashIndex = ref.indexOf(\"/\");\n const hasPrefix = slashIndex !== -1;\n\n if (\n ref.length === 0 ||\n ref !== ref.trim() ||\n (hasPrefix && ref.indexOf(\"/\", slashIndex + 1) !== -1)\n ) {\n return { kind: \"malformed\", ref };\n }\n\n if (!hasPrefix) {\n if (isMalformedSegment(ref)) {\n return { kind: \"malformed\", ref };\n }\n\n const tiers: SearchTier[] = [\n {\n scope: \"project\",\n sourcePath: path.resolve(cwd, \".poe-code/skills\", ref)\n },\n {\n scope: \"user\",\n sourcePath: path.resolve(homeDir, \".poe-code/skills\", ref)\n }\n ];\n\n return findSkill(ref, ref, tiers);\n }\n\n const agentInput = ref.slice(0, slashIndex);\n const name = ref.slice(slashIndex + 1);\n if (isMalformedSegment(agentInput) || isMalformedSegment(name)) {\n return { kind: \"malformed\", ref };\n }\n\n const support = resolveAgentSupport(agentInput);\n if (support.status !== \"supported\" || !support.id) {\n return { kind: \"unknown-agent\", ref, agentInput };\n }\n\n const config = getAgentConfig(support.id);\n if (!config) {\n return { kind: \"unknown-agent\", ref, agentInput };\n }\n\n const tiers: SearchTier[] = [\n {\n scope: \"project\",\n sourcePath: path.resolve(resolveSkillDir(config, \"local\", cwd), name)\n },\n {\n scope: \"user\",\n sourcePath: path.resolve(resolveSkillDir(config, \"global\", cwd, homeDir), name)\n }\n ];\n\n return findSkill(ref, name, tiers, support.id);\n}\n", "import { execFileSync } from \"node:child_process\";\nimport * as fs from \"node:fs\";\nimport path from \"node:path\";\n\nexport type GitDirRunner = (cwd: string) => string | undefined;\n\nconst markerPrefix = \"# poe-code-spawn-skills:\";\n\nfunction defaultGitDirRunner(cwd: string): string | undefined {\n try {\n return execFileSync(\"git\", [\"rev-parse\", \"--git-dir\"], {\n cwd,\n encoding: \"utf8\",\n stdio: [\"ignore\", \"pipe\", \"ignore\"]\n }).trim();\n } catch {\n return undefined;\n }\n}\n\nlet gitDirRunner: GitDirRunner = defaultGitDirRunner;\n\nexport function setGitDirRunnerForTest(runner: GitDirRunner): () => void {\n const previous = gitDirRunner;\n gitDirRunner = runner;\n return () => {\n gitDirRunner = previous;\n };\n}\n\nfunction resolveExcludePath(cwd: string): string | undefined {\n const gitDir = gitDirRunner(cwd);\n if (gitDir === undefined || gitDir.length === 0) {\n return undefined;\n }\n\n return path.join(path.isAbsolute(gitDir) ? gitDir : path.resolve(cwd, gitDir), \"info/exclude\");\n}\n\nfunction markers(runId: string): { begin: string; end: string } {\n return {\n begin: `${markerPrefix}${runId} begin`,\n end: `${markerPrefix}${runId} end`\n };\n}\n\nfunction readExcludeFile(excludePath: string): string | undefined {\n try {\n return fs.readFileSync(excludePath, \"utf8\");\n } catch (error) {\n if (isNodeError(error) && error.code === \"ENOENT\") {\n return undefined;\n }\n throw error;\n }\n}\n\nfunction isNodeError(error: unknown): error is NodeJS.ErrnoException {\n return error instanceof Error && \"code\" in error;\n}\n\nfunction removeBlock(content: string, runId: string): string {\n const { begin, end } = markers(runId);\n const lines = content.split(\"\\n\");\n const result: string[] = [];\n\n for (let index = 0; index < lines.length; index += 1) {\n if (lines[index] === begin) {\n const endIndex = lines.indexOf(end, index + 1);\n if (endIndex !== -1) {\n index = endIndex;\n continue;\n }\n }\n\n result.push(lines[index]);\n }\n\n return result.join(\"\\n\");\n}\n\nfunction appendBlock(content: string | undefined, runId: string, entries: string[]): string {\n const { begin, end } = markers(runId);\n const existing = content ?? \"\";\n const prefix = existing.length === 0 || existing.endsWith(\"\\n\") ? existing : `${existing}\\n`;\n return `${prefix}${[begin, ...entries, end, \"\"].join(\"\\n\")}`;\n}\n\nexport function appendExcludeBlock(cwd: string, runId: string, entries: string[]): void {\n const excludePath = resolveExcludePath(cwd);\n if (excludePath === undefined) {\n return;\n }\n\n fs.mkdirSync(path.dirname(excludePath), { recursive: true });\n const content = readExcludeFile(excludePath);\n fs.writeFileSync(excludePath, appendBlock(content, runId, entries), \"utf8\");\n}\n\nexport function removeExcludeBlock(cwd: string, runId: string): void {\n const excludePath = resolveExcludePath(cwd);\n if (excludePath === undefined) {\n return;\n }\n\n const content = readExcludeFile(excludePath);\n if (content === undefined) {\n return;\n }\n\n fs.writeFileSync(excludePath, removeBlock(content, runId), \"utf8\");\n}\n", "import * as fs from \"node:fs\";\nimport path from \"node:path\";\nimport {\n getAgentConfig,\n resolveAgentSupport,\n resolveSkillDir,\n supportedAgents\n} from \"./configs.js\";\nimport { appendExcludeBlock, removeExcludeBlock } from \"./git-exclude.js\";\nimport { resolveSkillReference, type SkillResolutionFailure } from \"./resolve-skill-reference.js\";\n\nexport interface BridgeEntry {\n ref: string;\n sourcePath: string;\n targetPath: string;\n createdParents: string[];\n}\n\nexport type BridgeWarningKind =\n | \"local-collision\"\n | \"global-collision\"\n | \"self-reference\"\n | \"intra-batch-collision\";\n\nexport interface BridgeWarning {\n kind: BridgeWarningKind;\n ref: string;\n sourcePath: string;\n conflictingPath: string;\n message: string;\n}\n\nexport interface BridgeManifest {\n spawnAgentId: string;\n cwd: string;\n runId: string;\n entries: BridgeEntry[];\n warnings: BridgeWarning[];\n}\n\ntype ResolvedSkill = Extract<ReturnType<typeof resolveSkillReference>, { kind: \"resolved\" }>;\n\ninterface ResolvedBridgeSource {\n ref: string;\n source: ResolvedSkill;\n targetPath: string;\n globalTargetPath: string;\n}\n\nfunction isNodeError(error: unknown): error is NodeJS.ErrnoException {\n return error instanceof Error && \"code\" in error;\n}\n\nfunction pathExists(targetPath: string): boolean {\n try {\n fs.statSync(targetPath);\n return true;\n } catch (error) {\n if (isNodeError(error) && error.code === \"ENOENT\") {\n return false;\n }\n throw error;\n }\n}\n\nfunction isDirectory(targetPath: string): boolean {\n try {\n return fs.statSync(targetPath).isDirectory();\n } catch (error) {\n if (isNodeError(error) && error.code === \"ENOENT\") {\n return false;\n }\n throw error;\n }\n}\n\nfunction formatResolutionFailureError(failures: SkillResolutionFailure[]): Error {\n const malformed = failures.filter((failure) => failure.kind === \"malformed\");\n const unknownAgent = failures.filter((failure) => failure.kind === \"unknown-agent\");\n const notFound = failures.filter((failure) => failure.kind === \"not-found\");\n const lines = [\n `Failed to bridge active skills: ${failures.length} skill reference(s) could not be resolved.`\n ];\n\n if (malformed.length > 0) {\n lines.push(\"\", \"Malformed skill references:\");\n for (const failure of malformed) {\n lines.push(`- ${failure.ref}`);\n }\n lines.push('Expected syntax: \"<name>\" or \"<agentId>/<name>\".');\n }\n\n if (unknownAgent.length > 0) {\n lines.push(\"\", \"Unknown agent references:\");\n for (const failure of unknownAgent) {\n lines.push(`- ${failure.ref} (agent token: ${failure.agentInput})`);\n }\n lines.push(`Supported agents: ${supportedAgents.join(\", \")}.`);\n }\n\n if (notFound.length > 0) {\n lines.push(\"\", \"Not found skill references.\");\n for (const failure of notFound) {\n lines.push(`- ${failure.ref}`);\n lines.push(\" searched paths:\");\n for (const searchedPath of failure.searchedPaths) {\n lines.push(` - ${searchedPath}`);\n }\n }\n }\n\n return new Error(lines.join(\"\\n\"));\n}\n\nfunction copyDirectory(sourcePath: string, targetPath: string): void {\n fs.mkdirSync(targetPath, { recursive: true });\n for (const dirent of fs.readdirSync(sourcePath, { withFileTypes: true })) {\n const childSource = path.join(sourcePath, dirent.name);\n const childTarget = path.join(targetPath, dirent.name);\n\n if (dirent.isDirectory()) {\n copyDirectory(childSource, childTarget);\n continue;\n }\n\n if (dirent.isFile()) {\n fs.copyFileSync(childSource, childTarget);\n }\n }\n}\n\nfunction collectMissingParents(targetPath: string): string[] {\n const parents: string[] = [];\n let current = path.dirname(targetPath);\n\n while (!pathExists(current)) {\n parents.push(current);\n const parent = path.dirname(current);\n if (parent === current) {\n break;\n }\n current = parent;\n }\n\n return parents.reverse();\n}\n\nfunction removeDirectoryIfEmpty(targetPath: string): void {\n try {\n fs.rmdirSync(targetPath);\n } catch (error) {\n if (\n isNodeError(error) &&\n (error.code === \"ENOENT\" || error.code === \"ENOTEMPTY\" || error.code === \"EEXIST\")\n ) {\n return;\n }\n throw error;\n }\n}\n\nfunction removeTarget(targetPath: string): void {\n fs.rmSync(targetPath, { recursive: true, force: true });\n}\n\nfunction toCwdRelative(cwd: string, targetPath: string): string {\n return path.relative(cwd, targetPath);\n}\n\nfunction warning(\n kind: BridgeWarningKind,\n ref: string,\n sourcePath: string,\n conflictingPath: string\n): BridgeWarning {\n const messages: Record<BridgeWarningKind, string> = {\n \"intra-batch-collision\": `Skipping ${ref}: an earlier bridged skill already targets ${conflictingPath}.`,\n \"local-collision\": `Skipping ${ref}: local skill already exists at ${conflictingPath}.`,\n \"global-collision\": `Skipping ${ref}: global skill already exists at ${conflictingPath}.`,\n \"self-reference\": `Skipping ${ref}: spawning agent already sees this native skill at ${conflictingPath}.`\n };\n\n return {\n kind,\n ref,\n sourcePath,\n conflictingPath,\n message: messages[kind]\n };\n}\n\nexport function bridgeActiveSkills(\n spawnAgentId: string,\n cwd: string,\n refs: string[],\n homeDir: string,\n runId: string\n): BridgeManifest {\n const spawnConfig = getAgentConfig(spawnAgentId);\n const spawnSupport = resolveAgentSupport(spawnAgentId);\n if (!spawnConfig || spawnSupport.status !== \"supported\" || !spawnSupport.id) {\n throw new Error(\n `Unsupported spawn agent \"${spawnAgentId}\". Supported agents: ${supportedAgents.join(\", \")}.`\n );\n }\n\n const targetDir = resolveSkillDir(spawnConfig, \"local\", cwd);\n const globalTargetDir = resolveSkillDir(spawnConfig, \"global\", cwd, homeDir);\n const resolutions = refs.map((ref) => resolveSkillReference(ref, cwd, homeDir));\n const failures = resolutions.filter(\n (resolution): resolution is SkillResolutionFailure => resolution.kind !== \"resolved\"\n );\n if (failures.length > 0) {\n throw formatResolutionFailureError(failures);\n }\n\n const sources: ResolvedBridgeSource[] = resolutions.map((source, index) => ({\n ref: refs[index]!,\n source: source as ResolvedSkill,\n targetPath: path.resolve(targetDir, (source as ResolvedSkill).name),\n globalTargetPath: path.resolve(globalTargetDir, (source as ResolvedSkill).name)\n }));\n\n const entries: BridgeEntry[] = [];\n const warnings: BridgeWarning[] = [];\n const claimedTargets = new Set<string>();\n\n for (const item of sources) {\n if (claimedTargets.has(item.targetPath)) {\n warnings.push(\n warning(\"intra-batch-collision\", item.ref, item.source.sourcePath, item.targetPath)\n );\n continue;\n }\n\n if (item.source.sourceAgentId === spawnSupport.id) {\n warnings.push(\n warning(\"self-reference\", item.ref, item.source.sourcePath, item.source.sourcePath)\n );\n continue;\n }\n\n if (pathExists(item.targetPath)) {\n warnings.push(warning(\"local-collision\", item.ref, item.source.sourcePath, item.targetPath));\n continue;\n }\n\n if (isDirectory(item.globalTargetPath)) {\n warnings.push(\n warning(\"global-collision\", item.ref, item.source.sourcePath, item.globalTargetPath)\n );\n continue;\n }\n\n const createdParents = collectMissingParents(item.targetPath);\n fs.mkdirSync(path.dirname(item.targetPath), { recursive: true });\n copyDirectory(item.source.sourcePath, item.targetPath);\n claimedTargets.add(item.targetPath);\n entries.push({\n ref: item.ref,\n sourcePath: item.source.sourcePath,\n targetPath: item.targetPath,\n createdParents\n });\n }\n\n if (entries.length > 0) {\n appendExcludeBlock(\n cwd,\n runId,\n entries.map((entry) => toCwdRelative(cwd, entry.targetPath))\n );\n }\n\n return {\n spawnAgentId,\n cwd,\n runId,\n entries,\n warnings\n };\n}\n\nexport function cleanupBridgedSkills(manifest: BridgeManifest): void {\n for (const entry of manifest.entries) {\n removeTarget(entry.targetPath);\n for (const parent of [...entry.createdParents].reverse()) {\n removeDirectoryIfEmpty(parent);\n }\n }\n\n removeExcludeBlock(manifest.cwd, manifest.runId);\n}\n", "export function truncate(text: string, maxLength: number): string {\n if (text.length <= maxLength) return text;\n if (maxLength <= 3) return text.slice(0, maxLength);\n return `${text.slice(0, maxLength - 3)}...`;\n}\n\nexport function isNonEmptyString(value: unknown): value is string {\n return typeof value === \"string\" && value.length > 0;\n}\n\nexport function extractThreadId(value: unknown): string | undefined {\n if (!value || typeof value !== \"object\") return;\n\n const obj = value as Record<string, unknown>;\n const maybeThreadId =\n (isNonEmptyString(obj.thread_id) && obj.thread_id) ||\n (isNonEmptyString(obj.threadId) && obj.threadId) ||\n (isNonEmptyString(obj.threadID) && obj.threadID) ||\n (isNonEmptyString(obj.session_id) && obj.session_id) ||\n (isNonEmptyString(obj.sessionId) && obj.sessionId) ||\n (isNonEmptyString(obj.sessionID) && obj.sessionID);\n\n return maybeThreadId || undefined;\n}\n", "import type { AcpEvent } from \"../acp/types.js\";\nimport { truncate, isNonEmptyString, extractThreadId } from \"./utils.js\";\n\nexport const TOOL_KIND_MAP: Record<string, string> = {\n Read: \"read\",\n Write: \"edit\",\n Edit: \"edit\",\n NotebookEdit: \"edit\",\n Bash: \"exec\",\n Glob: \"search\",\n Grep: \"search\",\n Task: \"think\"\n};\n\ntype ClaudeEvent = {\n type?: unknown;\n message?: unknown;\n thread_id?: unknown;\n threadId?: unknown;\n threadID?: unknown;\n session_id?: unknown;\n sessionId?: unknown;\n sessionID?: unknown;\n input_tokens?: unknown;\n output_tokens?: unknown;\n num_input_tokens?: unknown;\n num_output_tokens?: unknown;\n cost_usd?: unknown;\n usage?: unknown;\n};\n\ntype ClaudeMessage = {\n content?: unknown;\n};\n\ntype ClaudeContentBlock = {\n type?: unknown;\n text?: unknown;\n id?: unknown;\n name?: unknown;\n input?: unknown;\n tool_use_id?: unknown;\n content?: unknown;\n};\n\nconst TITLE_KEYS: Record<string, string[]> = {\n Bash: [\"command\"],\n Read: [\"file_path\"],\n Write: [\"file_path\"],\n Edit: [\"file_path\"],\n NotebookEdit: [\"notebook_path\"],\n Glob: [\"pattern\"],\n Grep: [\"pattern\"],\n Task: [\"description\", \"prompt\"]\n};\n\nfunction extractTitle(name: string, input: unknown): string {\n const keys = TITLE_KEYS[name];\n if (keys && input && typeof input === \"object\") {\n const obj = input as Record<string, unknown>;\n for (const key of keys) {\n const value = obj[key];\n if (typeof value === \"string\" && value.length > 0) {\n return truncate(value, 80);\n }\n }\n }\n return name;\n}\n\nexport async function* adaptClaude(\n lines: AsyncIterable<string>\n): AsyncGenerator<AcpEvent> {\n const toolKindsById = new Map<string, string>();\n let emittedSessionStart = false;\n\n for await (const rawLine of lines) {\n const line = rawLine.trim();\n if (!line) continue;\n\n // Claude Code can emit non-JSON informational lines (especially in verbose mode).\n // Ignore lines that don't look like JSON to avoid polluting output with adapter errors.\n const firstChar = line[0];\n if (firstChar !== \"{\" && firstChar !== \"[\") {\n continue;\n }\n\n let event: ClaudeEvent;\n try {\n event = JSON.parse(line) as ClaudeEvent;\n } catch (error) {\n const stack = error instanceof Error ? error.stack : undefined;\n yield {\n event: \"error\",\n message: `[adaptClaude] Malformed JSON line: ${truncate(line, 200)}`,\n stack\n };\n continue;\n }\n\n const eventType = event.type;\n if (!isNonEmptyString(eventType)) continue;\n\n if (!emittedSessionStart) {\n const threadId = extractThreadId(event);\n emittedSessionStart = true;\n yield { event: \"session_start\", threadId };\n }\n\n if (eventType === \"result\") {\n const usage = (event.usage ?? {}) as {\n input_tokens?: unknown;\n output_tokens?: unknown;\n cost_usd?: unknown;\n };\n\n const inputTokens =\n typeof usage.input_tokens === \"number\"\n ? usage.input_tokens\n : typeof event.input_tokens === \"number\"\n ? event.input_tokens\n : typeof event.num_input_tokens === \"number\"\n ? event.num_input_tokens\n : 0;\n const outputTokens =\n typeof usage.output_tokens === \"number\"\n ? usage.output_tokens\n : typeof event.output_tokens === \"number\"\n ? event.output_tokens\n : typeof event.num_output_tokens === \"number\"\n ? event.num_output_tokens\n : 0;\n const costUsd =\n typeof usage.cost_usd === \"number\"\n ? usage.cost_usd\n : typeof event.cost_usd === \"number\"\n ? event.cost_usd\n : undefined;\n\n yield { event: \"usage\", inputTokens, outputTokens, costUsd };\n continue;\n }\n\n if (eventType !== \"assistant\" && eventType !== \"user\") continue;\n\n const message = (event.message ?? null) as ClaudeMessage | null;\n if (!message || typeof message !== \"object\") continue;\n\n const content = (message.content ?? null) as unknown;\n if (!Array.isArray(content)) continue;\n\n for (const block of content) {\n const item = block as ClaudeContentBlock;\n if (!item || typeof item !== \"object\") continue;\n\n const blockType = item.type;\n if (!isNonEmptyString(blockType)) continue;\n\n if (eventType === \"assistant\") {\n if (blockType === \"text\" && isNonEmptyString(item.text)) {\n yield {\n event: \"agent_message\",\n text: item.text\n };\n continue;\n }\n\n if (blockType === \"tool_use\" && isNonEmptyString(item.id) && isNonEmptyString(item.name)) {\n const kind = TOOL_KIND_MAP[item.name] ?? \"other\";\n toolKindsById.set(item.id, kind);\n\n yield {\n event: \"tool_start\",\n id: item.id,\n kind,\n title: extractTitle(item.name, item.input),\n input: item.input\n };\n }\n\n continue;\n }\n\n if (eventType === \"user\") {\n if (!isNonEmptyString(item.tool_use_id)) continue;\n if (blockType !== \"tool_result\") continue;\n\n const kind = toolKindsById.get(item.tool_use_id);\n toolKindsById.delete(item.tool_use_id);\n\n let path: string;\n if (typeof item.content === \"string\") {\n path = item.content;\n } else {\n try {\n path = JSON.stringify(item.content);\n } catch {\n path = String(item.content);\n }\n }\n\n yield {\n event: \"tool_complete\",\n id: item.tool_use_id,\n kind,\n path\n };\n }\n }\n }\n}\n", "import type { AcpEvent } from \"../acp/types.js\";\nimport { truncate, isNonEmptyString, extractThreadId } from \"./utils.js\";\n\ntype CodexEvent = {\n type?: unknown;\n thread_id?: unknown;\n threadId?: unknown;\n threadID?: unknown;\n session_id?: unknown;\n sessionId?: unknown;\n sessionID?: unknown;\n usage?: unknown;\n item?: unknown;\n error?: unknown;\n message?: unknown;\n reason?: unknown;\n};\n\ntype CodexItem = {\n id?: unknown;\n type?: unknown;\n command?: unknown;\n path?: unknown;\n text?: unknown;\n content?: unknown;\n summary?: unknown;\n server?: unknown;\n tool?: unknown;\n arguments?: unknown;\n result?: unknown;\n};\n\nexport async function* adaptCodex(\n lines: AsyncIterable<string>\n): AsyncGenerator<AcpEvent> {\n const toolTitleById = new Map<string, string>();\n const toolKindById = new Map<string, string>();\n\n for await (const rawLine of lines) {\n const line = rawLine.trim();\n if (!line) continue;\n\n let event: CodexEvent;\n try {\n event = JSON.parse(line) as CodexEvent;\n } catch (error) {\n const stack = error instanceof Error ? error.stack : undefined;\n yield {\n event: \"error\",\n message: `[adaptCodex] Malformed JSON line: ${truncate(line, 200)}`,\n stack\n };\n continue;\n }\n\n const eventType = event.type;\n if (!isNonEmptyString(eventType)) continue;\n\n if (eventType === \"thread.started\") {\n const maybeThreadId = extractThreadId(event);\n yield { event: \"session_start\", threadId: maybeThreadId };\n continue;\n }\n\n if (eventType === \"turn.started\") {\n continue;\n }\n\n if (eventType === \"turn.completed\") {\n const usage = (event.usage ?? {}) as {\n input_tokens?: unknown;\n output_tokens?: unknown;\n cached_input_tokens?: unknown;\n };\n\n const inputTokens = typeof usage.input_tokens === \"number\" ? usage.input_tokens : 0;\n const outputTokens = typeof usage.output_tokens === \"number\" ? usage.output_tokens : 0;\n const cachedTokens =\n typeof usage.cached_input_tokens === \"number\" ? usage.cached_input_tokens : 0;\n\n yield { event: \"usage\", inputTokens, outputTokens, cachedTokens };\n continue;\n }\n\n if (eventType === \"turn.failed\") {\n const message = extractErrorMessage(event) ?? \"Turn failed\";\n yield { event: \"error\", message };\n continue;\n }\n\n const item = (event.item ?? null) as CodexItem | null;\n if (!item || typeof item !== \"object\") continue;\n\n const itemType = item.type;\n if (!isNonEmptyString(itemType)) continue;\n\n if (eventType === \"item.started\") {\n if (!isNonEmptyString(item.id)) continue;\n\n let kind: string | undefined;\n let title: string | undefined;\n\n if (itemType === \"command_execution\") {\n kind = \"exec\";\n title = truncate(isNonEmptyString(item.command) ? item.command : \"\", 80);\n } else if (itemType === \"file_edit\") {\n kind = \"edit\";\n title = isNonEmptyString(item.path) ? item.path : \"\";\n } else if (itemType === \"thinking\") {\n kind = \"think\";\n title = \"thinking...\";\n } else if (itemType === \"mcp_tool_call\") {\n const server = isNonEmptyString(item.server) ? item.server : \"unknown\";\n const tool = isNonEmptyString(item.tool) ? item.tool : \"unknown\";\n kind = \"other\";\n title = `${server}.${tool}`;\n }\n\n if (kind && title !== undefined) {\n toolTitleById.set(item.id, title);\n toolKindById.set(item.id, kind);\n yield { event: \"tool_start\", id: item.id, kind, title };\n }\n continue;\n }\n\n if (eventType === \"item.completed\") {\n if (itemType === \"agent_message\") {\n if (!isNonEmptyString(item.text)) continue;\n yield { event: \"agent_message\", text: item.text };\n continue;\n }\n\n if (itemType === \"reasoning\") {\n const text = isNonEmptyString(item.text)\n ? item.text\n : isNonEmptyString(item.content)\n ? item.content\n : isNonEmptyString(item.summary)\n ? item.summary\n : undefined;\n if (!text) continue;\n yield { event: \"reasoning\", text };\n continue;\n }\n\n if (!isNonEmptyString(item.id)) continue;\n\n if (itemType === \"command_execution\" || itemType === \"file_edit\" || itemType === \"mcp_tool_call\") {\n const kindFromStart = toolKindById.get(item.id);\n const kind =\n kindFromStart ??\n (itemType === \"command_execution\"\n ? \"exec\"\n : itemType === \"file_edit\"\n ? \"edit\"\n : \"other\");\n\n const titleFromEvent = isNonEmptyString(item.path)\n ? item.path\n : itemType === \"mcp_tool_call\"\n ? `${isNonEmptyString(item.server) ? item.server : \"unknown\"}.${isNonEmptyString(item.tool) ? item.tool : \"unknown\"}`\n : undefined;\n const path = titleFromEvent ?? toolTitleById.get(item.id) ?? \"\";\n\n toolTitleById.delete(item.id);\n toolKindById.delete(item.id);\n\n yield { event: \"tool_complete\", id: item.id, kind, path };\n }\n }\n }\n}\n\nfunction extractErrorMessage(event: CodexEvent): string | undefined {\n if (isNonEmptyString(event.message)) return event.message;\n\n const error = event.error;\n if (isNonEmptyString(error)) return error;\n if (typeof error === \"object\" && error !== null) {\n const errorObj = error as { message?: unknown };\n if (isNonEmptyString(errorObj.message)) return errorObj.message;\n }\n\n if (isNonEmptyString(event.reason)) return event.reason;\n return undefined;\n}\n", "import type { AcpEvent } from \"../acp/types.js\";\nimport { truncate, isNonEmptyString, extractThreadId } from \"./utils.js\";\n\ntype KimiEvent = {\n role?: unknown;\n content?: unknown;\n thread_id?: unknown;\n threadId?: unknown;\n threadID?: unknown;\n session_id?: unknown;\n sessionId?: unknown;\n sessionID?: unknown;\n};\n\nexport async function* adaptKimi(\n lines: AsyncIterable<string>\n): AsyncGenerator<AcpEvent> {\n let emittedSessionStart = false;\n\n for await (const rawLine of lines) {\n const line = rawLine.trim();\n if (!line) continue;\n\n let event: KimiEvent;\n try {\n event = JSON.parse(line) as KimiEvent;\n } catch (error) {\n const stack = error instanceof Error ? error.stack : undefined;\n yield {\n event: \"error\",\n message: `[adaptKimi] Malformed JSON line: ${truncate(line, 200)}`,\n stack\n };\n continue;\n }\n\n if (!event || typeof event !== \"object\") continue;\n\n if (!emittedSessionStart) {\n const threadId = extractThreadId(event);\n if (threadId) {\n emittedSessionStart = true;\n yield { event: \"session_start\", threadId };\n }\n }\n\n const role = event.role;\n if (!isNonEmptyString(role) || role !== \"assistant\") continue;\n\n const content = event.content;\n if (!isNonEmptyString(content)) continue;\n\n yield { event: \"agent_message\", text: content };\n }\n}\n", "import { truncate, isNonEmptyString } from \"./utils.js\";\n\ntype AcpEvent = { event: string } & Record<string, unknown>;\n\nexport async function* adaptNative(\n lines: AsyncIterable<string>\n): AsyncGenerator<AcpEvent> {\n for await (const rawLine of lines) {\n const line = rawLine.trim();\n if (!line) continue;\n\n let event: unknown;\n try {\n event = JSON.parse(line) as unknown;\n } catch (error) {\n const stack = error instanceof Error ? error.stack : undefined;\n yield {\n event: \"error\",\n message: `[adaptNative] Malformed JSON line: ${truncate(line, 200)}`,\n stack\n };\n continue;\n }\n\n const maybeEventType = (event as { event?: unknown } | null)?.event;\n if (!isNonEmptyString(maybeEventType)) {\n yield {\n event: \"error\",\n message: `[adaptNative] Line missing string \"event\" field: ${truncate(line, 200)}`\n };\n continue;\n }\n\n yield event as AcpEvent;\n }\n}\n", "import type { AcpEvent } from \"../acp/types.js\";\nimport { truncate, isNonEmptyString, extractThreadId } from \"./utils.js\";\n\ntype OpenCodeEvent = {\n type?: unknown;\n sessionID?: unknown;\n sessionId?: unknown;\n session_id?: unknown;\n threadId?: unknown;\n thread_id?: unknown;\n threadID?: unknown;\n part?: unknown;\n};\n\ntype OpenCodeTextPart = {\n type?: unknown;\n text?: unknown;\n};\n\ntype OpenCodeToolState = {\n status?: unknown;\n input?: unknown;\n output?: unknown;\n};\n\ntype OpenCodeToolPart = {\n type?: unknown;\n callID?: unknown;\n tool?: unknown;\n state?: unknown;\n};\n\ntype OpenCodeStepFinishPart = {\n tokens?: unknown;\n};\n\ntype OpenCodeTokens = {\n input?: unknown;\n output?: unknown;\n cache?: unknown;\n};\n\ntype OpenCodeTokenCache = {\n read?: unknown;\n write?: unknown;\n};\n\nfunction guessToolKind(toolName: string): string {\n const normalized = toolName.toLowerCase();\n\n if (normalized === \"bash\" || normalized === \"shell\" || normalized === \"sh\") return \"exec\";\n if (normalized.includes(\"read\")) return \"read\";\n if (normalized.includes(\"write\") || normalized.includes(\"edit\") || normalized.includes(\"patch\")) {\n return \"edit\";\n }\n if (\n normalized.includes(\"search\") ||\n normalized.includes(\"grep\") ||\n normalized.includes(\"glob\") ||\n normalized.includes(\"find\")\n ) {\n return \"search\";\n }\n if (normalized.includes(\"think\") || normalized.includes(\"task\")) return \"think\";\n\n return \"other\";\n}\n\nfunction safeStringify(value: unknown): string {\n if (typeof value === \"string\") return value;\n try {\n return JSON.stringify(value);\n } catch {\n return String(value);\n }\n}\n\nexport async function* adaptOpenCode(\n lines: AsyncIterable<string>\n): AsyncGenerator<AcpEvent> {\n let emittedSessionStart = false;\n const toolKindById = new Map<string, string>();\n\n for await (const rawLine of lines) {\n const line = rawLine.trim();\n if (!line) continue;\n\n let event: OpenCodeEvent;\n try {\n event = JSON.parse(line) as OpenCodeEvent;\n } catch (error) {\n const stack = error instanceof Error ? error.stack : undefined;\n yield {\n event: \"error\",\n message: `[adaptOpenCode] Malformed JSON line: ${truncate(line, 200)}`,\n stack\n };\n continue;\n }\n\n if (!event || typeof event !== \"object\") continue;\n\n const sessionID = extractThreadId(event);\n if (!emittedSessionStart && isNonEmptyString(sessionID)) {\n emittedSessionStart = true;\n yield { event: \"session_start\", threadId: sessionID };\n }\n\n const eventType = event.type;\n if (!isNonEmptyString(eventType)) continue;\n\n if (eventType === \"text\") {\n const part = (event.part ?? null) as OpenCodeTextPart | null;\n if (!part || typeof part !== \"object\") continue;\n if (!isNonEmptyString(part.text)) continue;\n yield { event: \"agent_message\", text: part.text };\n continue;\n }\n\n if (eventType === \"tool_use\") {\n const part = (event.part ?? null) as OpenCodeToolPart | null;\n if (!part || typeof part !== \"object\") continue;\n if (!isNonEmptyString(part.callID) || !isNonEmptyString(part.tool)) continue;\n\n const state = (part.state ?? null) as OpenCodeToolState | null;\n if (!state || typeof state !== \"object\") continue;\n\n const kind = guessToolKind(part.tool);\n const status = state.status;\n const terminal = status === \"completed\" || status === \"failed\";\n\n if (!toolKindById.has(part.callID)) {\n toolKindById.set(part.callID, kind);\n\n let title = part.tool;\n const maybeInput = state.input;\n if (kind === \"exec\" && maybeInput && typeof maybeInput === \"object\") {\n const command = (maybeInput as { command?: unknown }).command;\n if (isNonEmptyString(command)) {\n title = truncate(command, 80);\n }\n }\n\n yield {\n event: \"tool_start\",\n id: part.callID,\n kind,\n title,\n input: state.input\n };\n }\n\n if (terminal) {\n const kindFromStart = toolKindById.get(part.callID) ?? kind;\n toolKindById.delete(part.callID);\n\n yield {\n event: \"tool_complete\",\n id: part.callID,\n kind: kindFromStart,\n path: safeStringify(state.output)\n };\n }\n\n continue;\n }\n\n if (eventType === \"step_finish\") {\n const part = (event.part ?? null) as OpenCodeStepFinishPart | null;\n if (!part || typeof part !== \"object\") continue;\n\n const tokens = (part.tokens ?? null) as OpenCodeTokens | null;\n if (!tokens || typeof tokens !== \"object\") continue;\n\n const inputTokens = typeof tokens.input === \"number\" ? tokens.input : 0;\n const outputTokens = typeof tokens.output === \"number\" ? tokens.output : 0;\n\n const cache = (tokens.cache ?? null) as OpenCodeTokenCache | null;\n const cachedTokens =\n cache && typeof cache === \"object\" && typeof cache.read === \"number\" ? cache.read : undefined;\n\n if (inputTokens === 0 && outputTokens === 0 && cachedTokens === undefined) continue;\n\n yield { event: \"usage\", inputTokens, outputTokens, cachedTokens };\n continue;\n }\n }\n}\n", "import { adaptClaude } from \"./claude.js\";\nimport { adaptCodex } from \"./codex.js\";\nimport { adaptKimi } from \"./kimi.js\";\nimport { adaptNative } from \"./native.js\";\nimport { adaptOpenCode } from \"./opencode.js\";\nimport type { AcpEvent, SessionUpdate } from \"../acp/types.js\";\n\nexport { adaptCodex } from \"./codex.js\";\nexport { adaptClaude } from \"./claude.js\";\nexport { adaptKimi } from \"./kimi.js\";\nexport { adaptNative } from \"./native.js\";\nexport { adaptOpenCode } from \"./opencode.js\";\n\nexport type AdapterType = \"codex\" | \"claude\" | \"kimi\" | \"native\" | \"opencode\";\n\nexport type AdapterOutput = AcpEvent | SessionUpdate;\nexport type Adapter = (lines: AsyncIterable<string>) => AsyncGenerator<AdapterOutput>;\n\nconst adapters = {\n codex: adaptCodex,\n claude: adaptClaude,\n kimi: adaptKimi,\n native: adaptNative,\n opencode: adaptOpenCode\n} satisfies Record<AdapterType, Adapter>;\n\nexport function getAdapter(type: AdapterType): Adapter {\n const adapter = (adapters as Record<string, Adapter | undefined>)[type];\n if (!adapter) {\n throw new Error(`Unknown adapter \"${String(type)}\".`);\n }\n return adapter;\n}\n", "export function stampReceiveTime<E>(event: E, ts: number): E {\n if (event === null || typeof event !== \"object\") {\n return event;\n }\n\n const target = event as { _meta?: Record<string, unknown> };\n const existing = target._meta;\n if (existing && typeof existing.ts === \"number\") {\n return event;\n }\n\n target._meta = existing ? { ...existing, ts } : { ts };\n return event;\n}\n", "import type { SpawnMode, SpawnUsage } from \"../types.js\";\nimport type { AcpEvent } from \"./types.js\";\n\nexport interface SessionToolCall {\n id?: string;\n kind?: string;\n title?: string;\n input?: unknown;\n path?: string;\n}\n\nexport interface SessionResult {\n output: string;\n messages: string[];\n toolCalls: SessionToolCall[];\n}\n\nexport interface SpawnContext {\n sessionId: string;\n agent: string;\n logPath?: string;\n logDir?: string;\n logFileName?: string;\n events: AcpEvent[];\n usage: SpawnUsage;\n eventStream?: AsyncIterable<AcpEvent>;\n sessionResult?: SessionResult;\n threadId?: string;\n prompt?: string;\n model?: string;\n mode?: SpawnMode;\n cwd?: string;\n startedAt?: Date;\n logFile?: string;\n}\n\nexport type AcpMiddleware = (ctx: SpawnContext, next: () => Promise<void>) => Promise<void>;\n\nexport async function applyMiddlewares(\n middlewares: AcpMiddleware[],\n ctx: SpawnContext\n): Promise<void> {\n let index = -1;\n\n async function dispatch(position: number): Promise<void> {\n if (position <= index) {\n throw new Error(\"next() called multiple times\");\n }\n\n index = position;\n if (position === middlewares.length) {\n return;\n }\n\n const middleware = middlewares[position];\n if (typeof middleware !== \"function\") {\n throw new Error(`Invalid ACP middleware at index ${position}`);\n }\n\n await middleware(ctx, () => dispatch(position + 1));\n }\n\n await dispatch(0);\n}\n", "import \"../register-factories.js\";\nimport { runPoeCommand } from \"@poe-code/agent-harness-tools\";\nimport { getAdapter } from \"../adapters/index.js\";\nimport { stampReceiveTime } from \"./meta.js\";\nimport type { AcpEvent } from \"./types.js\";\nimport { resolveConfig } from \"../configs/resolve-config.js\";\nimport { getMcpArgs, getMcpEnv } from \"../mcp-args.js\";\nimport { stripModelNamespace } from \"../model-utils.js\";\nimport { observeAgentSpawn } from \"../observability/otel.js\";\nimport { shouldSendPromptViaStdin } from \"../prompt-transport.js\";\nimport { resolveSpawnExecution } from \"../runtime.js\";\nimport { bridgeSkillsForRun, cleanupSkillsForRun } from \"../skill-bridge.js\";\nimport {\n resolveModeConfig,\n type CliSpawnConfig,\n type SpawnOptions,\n type SpawnResult\n} from \"../types.js\";\nimport { applyMiddlewares, type SpawnContext } from \"./middleware.js\";\n\nfunction createAbortError(): Error {\n const error = new Error(\"Agent spawn aborted\");\n error.name = \"AbortError\";\n return error;\n}\n\nexport interface SpawnStreamingOptions extends SpawnOptions {\n agentId: string;\n}\n\nexport interface SpawnStreamingResult {\n events: AsyncIterable<AcpEvent>;\n done: Promise<SpawnResult>;\n}\n\nfunction isAcpEvent(value: unknown): value is AcpEvent {\n return !!value && typeof value === \"object\" && \"event\" in value;\n}\n\nfunction accumulateUsage(ctx: SpawnContext, event: AcpEvent): void {\n if (event.event !== \"usage\") {\n return;\n }\n\n const usage = event as {\n inputTokens?: unknown;\n outputTokens?: unknown;\n cachedTokens?: unknown;\n costUsd?: unknown;\n };\n\n if (typeof usage.inputTokens === \"number\" && Number.isFinite(usage.inputTokens)) {\n ctx.usage.inputTokens += usage.inputTokens;\n }\n\n if (typeof usage.outputTokens === \"number\" && Number.isFinite(usage.outputTokens)) {\n ctx.usage.outputTokens += usage.outputTokens;\n }\n\n if (typeof usage.cachedTokens === \"number\" && Number.isFinite(usage.cachedTokens)) {\n ctx.usage.cachedTokens = (ctx.usage.cachedTokens ?? 0) + usage.cachedTokens;\n }\n\n if (typeof usage.costUsd === \"number\" && Number.isFinite(usage.costUsd)) {\n ctx.usage.costUsd = (ctx.usage.costUsd ?? 0) + usage.costUsd;\n }\n}\n\nfunction createLineQueue(): {\n push(chunk: string): void;\n close(): void;\n lines(): AsyncIterable<string>;\n} {\n const lines: string[] = [];\n const waiters: Array<{\n resolve(value: IteratorResult<string>): void;\n }> = [];\n let pending = \"\";\n let closed = false;\n\n const emit = (line: string): void => {\n const waiter = waiters.shift();\n if (waiter) {\n waiter.resolve({ done: false, value: line });\n return;\n }\n lines.push(line);\n };\n\n const finishWaiters = (): void => {\n while (waiters.length > 0) {\n const waiter = waiters.shift()!;\n waiter.resolve({ done: true, value: undefined });\n }\n };\n\n return {\n push(chunk: string): void {\n if (closed) return;\n pending += chunk;\n let newlineIndex = pending.indexOf(\"\\n\");\n while (newlineIndex !== -1) {\n const raw = pending.slice(0, newlineIndex);\n emit(raw.endsWith(\"\\r\") ? raw.slice(0, -1) : raw);\n pending = pending.slice(newlineIndex + 1);\n newlineIndex = pending.indexOf(\"\\n\");\n }\n },\n close(): void {\n if (closed) return;\n if (pending.length > 0) {\n emit(pending.endsWith(\"\\r\") ? pending.slice(0, -1) : pending);\n pending = \"\";\n }\n closed = true;\n finishWaiters();\n },\n lines(): AsyncIterable<string> {\n return {\n [Symbol.asyncIterator](): AsyncIterator<string> {\n return {\n next(): Promise<IteratorResult<string>> {\n if (lines.length > 0) {\n return Promise.resolve({ done: false, value: lines.shift()! });\n }\n if (closed) {\n return Promise.resolve({ done: true, value: undefined });\n }\n return new Promise((resolve) => {\n waiters.push({ resolve });\n });\n }\n };\n }\n };\n }\n };\n}\n\nfunction getDefaultArgsPosition(config: CliSpawnConfig): \"beforePrompt\" | \"afterPrompt\" {\n return config.defaultArgsPosition ?? \"afterPrompt\";\n}\n\nfunction getMcpArgsPosition(\n config: CliSpawnConfig\n): \"beforeCommand\" | \"beforePrompt\" | \"afterCommand\" {\n if (config.mcpArgsPosition) {\n return config.mcpArgsPosition;\n }\n return config.mcpArgsBeforeCommand ? \"beforeCommand\" : \"afterCommand\";\n}\n\nfunction getResumeArgs(\n config: CliSpawnConfig,\n options: Pick<SpawnStreamingOptions, \"resumeThreadId\" | \"cwd\">\n): string[] {\n if (!options.resumeThreadId) {\n return [];\n }\n\n if (!config.resume) {\n throw new Error(`Agent \"${config.agentId}\" does not support resumeThreadId.`);\n }\n\n return config.resume.args(options.resumeThreadId, options.cwd ?? process.cwd());\n}\n\nexport function spawnStreaming(options: SpawnStreamingOptions): SpawnStreamingResult {\n if (options.signal?.aborted) {\n throw createAbortError();\n }\n\n const { agentId, binaryName, spawnConfig } = resolveConfig(options.agentId);\n\n if (spawnConfig === undefined) {\n throw new Error(`Agent \"${agentId}\" has no spawn config.`);\n }\n\n if (spawnConfig.kind !== \"cli\") {\n throw new Error(`Agent \"${agentId}\" does not support CLI spawn.`);\n }\n\n if (!binaryName) {\n throw new Error(`Agent \"${agentId}\" has no binaryName.`);\n }\n\n const mcpArgs = getMcpArgs(spawnConfig, options.mcpServers);\n const mcpEnvVars = getMcpEnv(spawnConfig, options.mcpServers);\n const resumeArgs = getResumeArgs(spawnConfig, options);\n const defaultArgsPosition = getDefaultArgsPosition(spawnConfig);\n const mcpArgsPosition = getMcpArgsPosition(spawnConfig);\n const resumeArgsPosition = spawnConfig.resume?.position ?? \"afterPrompt\";\n const args: string[] = [];\n\n if (mcpArgsPosition === \"beforeCommand\") {\n args.push(...mcpArgs);\n }\n\n if (defaultArgsPosition === \"beforePrompt\") {\n args.push(...spawnConfig.defaultArgs);\n }\n\n if (mcpArgsPosition === \"beforePrompt\") {\n args.push(...mcpArgs);\n }\n\n args.push(spawnConfig.promptFlag);\n\n if (resumeArgsPosition === \"beforePrompt\") {\n args.push(...resumeArgs);\n }\n\n const useStdin = shouldSendPromptViaStdin(spawnConfig, options);\n if (!useStdin || !spawnConfig.stdinMode?.omitPrompt) {\n args.push(options.prompt);\n }\n\n if (options.model && spawnConfig.modelFlag) {\n let model = spawnConfig.modelStripProviderPrefix\n ? stripModelNamespace(options.model)\n : options.model;\n if (spawnConfig.modelTransform) model = spawnConfig.modelTransform(model);\n args.push(spawnConfig.modelFlag, model);\n }\n\n if (defaultArgsPosition === \"afterPrompt\") {\n args.push(...spawnConfig.defaultArgs);\n }\n\n if (mcpArgsPosition === \"afterCommand\") {\n args.push(...mcpArgs);\n }\n\n const modeResolved = resolveModeConfig(spawnConfig.modes[options.mode ?? \"yolo\"]);\n args.push(...modeResolved.args);\n\n if (useStdin) {\n args.push(...spawnConfig.stdinMode!.extraArgs);\n }\n\n if (options.args && options.args.length > 0) {\n if (resumeArgsPosition === \"afterPrompt\") {\n args.push(...resumeArgs);\n }\n args.push(...options.args);\n } else if (resumeArgsPosition === \"afterPrompt\") {\n args.push(...resumeArgs);\n }\n\n const envOverrides = { ...mcpEnvVars, ...modeResolved.env };\n const processEnv =\n Object.keys(envOverrides).length > 0 ? { ...process.env, ...envOverrides } : undefined;\n const cwd = options.cwd ?? process.cwd();\n const queue = createLineQueue();\n const argv = [binaryName, ...args];\n const execution = resolveSpawnExecution({\n cwd,\n runtimeConfigCwd: options.runtimeConfigCwd,\n env: (processEnv ?? process.env) as Record<string, string>,\n argv,\n tool: agentId,\n runtime: {\n runtime: options.runtime,\n runtimeImage: options.runtimeImage,\n runtimeTemplate: options.runtimeTemplate,\n detach: options.detach,\n mountPoeCode: options.mountPoeCode,\n runnerSync: options.runnerSync\n },\n openSpec: {\n execution: {\n wrapForLogTee: false,\n stdin: \"pipe\",\n stdout: \"pipe\",\n stderr: \"pipe\",\n env: processEnv as Record<string, string> | undefined,\n input: useStdin ? options.prompt : \"\",\n captureOutput: true,\n activityTimeoutMs: options.activityTimeoutMs,\n onStdout(chunk: string) {\n queue.push(chunk);\n },\n onStderr(chunk: string) {\n if (options.tee?.stderr) options.tee.stderr.write(chunk);\n }\n }\n }\n });\n\n const result: SpawnResult = { stdout: \"\", stderr: \"\", exitCode: 1 };\n const adapter = getAdapter(spawnConfig.adapter);\n let resolveEventStreamDone: (() => void) | undefined;\n let rejectEventStreamDone: ((error: unknown) => void) | undefined;\n const eventStreamDone = new Promise<void>((resolve, reject) => {\n resolveEventStreamDone = resolve;\n rejectEventStreamDone = reject;\n });\n const eventQueue: AcpEvent[] = [];\n const waiters: Array<{\n resolve(result: IteratorResult<AcpEvent>): void;\n reject(error: unknown): void;\n }> = [];\n let eventsDone = false;\n let eventStreamError: unknown;\n const ctx: SpawnContext = {\n sessionId: \"unknown\",\n agent: agentId,\n ...(options.logPath !== undefined ? { logPath: options.logPath } : {}),\n ...(options.logDir !== undefined ? { logDir: options.logDir } : {}),\n ...(options.logFileName !== undefined ? { logFileName: options.logFileName } : {}),\n events: [],\n usage: {\n inputTokens: 0,\n outputTokens: 0\n },\n prompt: options.prompt,\n model: options.model,\n mode: options.mode,\n cwd: options.cwd ?? process.cwd(),\n startedAt: new Date()\n };\n\n const pushEvent = (event: AcpEvent): void => {\n if (eventsDone) return;\n if (event.event === \"session_start\") {\n const threadId = (event as { threadId?: unknown }).threadId;\n if (typeof threadId === \"string\" && threadId.length > 0) {\n ctx.threadId = threadId;\n ctx.sessionId = threadId;\n }\n }\n ctx.events.push(event);\n accumulateUsage(ctx, event);\n const waiter = waiters.shift();\n if (waiter) {\n waiter.resolve({ done: false, value: event });\n return;\n }\n eventQueue.push(event);\n };\n\n const completeEventStream = (): void => {\n if (eventsDone) return;\n eventsDone = true;\n while (waiters.length > 0) {\n waiters.shift()?.resolve({ done: true, value: undefined });\n }\n };\n\n const failEventStream = (error: unknown): void => {\n if (eventsDone) return;\n eventStreamError = error;\n eventsDone = true;\n while (waiters.length > 0) {\n waiters.shift()?.reject(error);\n }\n };\n\n ctx.eventStream = {\n [Symbol.asyncIterator](): AsyncIterator<AcpEvent> {\n return {\n next(): Promise<IteratorResult<AcpEvent>> {\n if (eventQueue.length > 0) {\n return Promise.resolve({ done: false, value: eventQueue.shift()! });\n }\n if (eventStreamError) {\n return Promise.reject(eventStreamError);\n }\n if (eventsDone) {\n return Promise.resolve({ done: true, value: undefined });\n }\n return new Promise((resolve, reject) => {\n waiters.push({ resolve, reject });\n });\n }\n };\n }\n };\n\n const manifest = bridgeSkillsForRun(options.agentId, cwd, options.skills);\n\n void (async () => {\n try {\n for await (const output of adapter(queue.lines())) {\n if (!isAcpEvent(output)) continue;\n pushEvent(stampReceiveTime(output, Date.now()));\n }\n completeEventStream();\n resolveEventStreamDone?.();\n } catch (error) {\n failEventStream(error);\n rejectEventStreamDone?.(error);\n }\n })();\n\n const done = (async (): Promise<SpawnResult> => {\n try {\n await applyMiddlewares(\n [\n ...(options.middlewares ?? []),\n async (_ctx, next) => {\n try {\n const runResult = await runPoeCommand({\n factory: execution.factory,\n openSpec: execution.openSpec,\n detach: execution.detach,\n state: execution.state,\n signal: options.signal\n });\n\n if (runResult.kind === \"detached\") {\n result.stdout = \"\";\n result.stderr = \"\";\n result.exitCode = 0;\n result.detached = { jobId: runResult.jobId, envId: runResult.envId };\n } else {\n result.stderr = runResult.stderr ?? \"\";\n result.exitCode = runResult.exitCode;\n }\n } finally {\n queue.close();\n }\n await eventStreamDone;\n await next();\n }\n ],\n ctx\n );\n\n return {\n ...result,\n ...(ctx.logFile && !result.logFile ? { logFile: ctx.logFile } : {})\n };\n } finally {\n cleanupSkillsForRun(manifest);\n }\n })();\n\n return {\n events: ctx.eventStream,\n done: observeAgentSpawn(\n {\n agent: agentId,\n cwd: options.cwd,\n mode: options.mode,\n otelSink: options.otelSink,\n prompt: options.prompt\n },\n () => done\n )\n };\n}\n", "import { renderAcpStream } from \"./acp/renderer.js\";\nimport type { AcpEvent } from \"./acp/types.js\";\nimport { isActivityTimeoutError } from \"./spawn.js\";\n\nconst DEFAULT_ACTIVITY_TIMEOUT_MS = 10 * 60 * 1000;\nconst DEFAULT_MAX_TIMEOUT_RETRIES = 3;\n\nexport interface StreamingSpawnReturn<TResult> {\n events: AsyncIterable<AcpEvent>;\n result: Promise<TResult>;\n}\n\nexport type StreamingSpawnFn<TOptions, TResult> = (\n service: string,\n options: TOptions\n) => StreamingSpawnReturn<TResult>;\n\nexport type AutonomousOptions<TOptions> = TOptions & {\n service: string;\n maxTimeoutRetries?: number;\n activityTimeoutMs?: number;\n};\n\n/**\n * Drive a streaming spawn end-to-end: pipe ACP events through `renderAcpStream`\n * (which routes through `withAcpWriter` if bound) and return the final result.\n * Retries on activity timeout up to `maxTimeoutRetries` attempts.\n *\n * Both the SDK `spawn.autonomous` and the superintendent loop consume this \u2014\n * callers supply a streaming spawn function whose `result` promise resolves\n * to their own result shape.\n */\nexport async function spawnAutonomous<\n TOptions extends { activityTimeoutMs?: number },\n TResult\n>(\n streamSpawn: StreamingSpawnFn<TOptions, TResult>,\n options: AutonomousOptions<TOptions>\n): Promise<TResult> {\n const {\n service,\n maxTimeoutRetries = DEFAULT_MAX_TIMEOUT_RETRIES,\n activityTimeoutMs = DEFAULT_ACTIVITY_TIMEOUT_MS,\n ...rest\n } = options;\n\n const spawnOptions = { ...rest, activityTimeoutMs } as unknown as TOptions;\n\n for (let attempt = 1; attempt <= maxTimeoutRetries; attempt += 1) {\n let result: Promise<TResult> | undefined;\n try {\n const stream = streamSpawn(service, spawnOptions);\n result = stream.result;\n // Attach to the final result immediately so a failed attempt can retry\n // without hanging behind ACP rendering that is still flushing.\n const [spawnResult] = await Promise.all([\n result,\n renderAcpStream(stream.events)\n ]);\n return spawnResult;\n } catch (error) {\n result?.catch(() => {});\n if (!isActivityTimeoutError(error) || attempt === maxTimeoutRetries) {\n throw error;\n }\n }\n }\n\n throw new Error(\"Unreachable\");\n}\n", "import path from \"node:path\";\nimport { homedir } from \"node:os\";\nimport type { Dirent } from \"node:fs\";\nimport { open, readdir } from \"node:fs/promises\";\nimport { createInterface } from \"node:readline\";\nimport type { SessionUpdate } from \"@poe-code/poe-acp-client\";\nimport { mapLegacyEventToSessionUpdates } from \"@poe-code/poe-acp-client\";\nimport { renderSessionUpdateStream } from \"./renderer.js\";\nimport type { AcpEvent } from \"./types.js\";\n\nconst DEFAULT_LOG_LIMIT = 80;\nconst JSONL_EXTENSION = \".jsonl\";\n\nexport interface LogEntry {\n path: string;\n filename: string;\n agent?: string;\n timestamp?: Date;\n}\n\ninterface ListSpawnLogsOptions {\n agent?: string;\n limit?: number;\n}\n\nfunction isDigitString(value: string, length: number): boolean {\n if (value.length !== length) return false;\n for (const char of value) {\n if (char < \"0\" || char > \"9\") return false;\n }\n return true;\n}\n\nfunction parseTimestamp(day: string, time: string, milliseconds: string): Date | undefined {\n if (!isDigitString(day, 8) || !isDigitString(time, 6) || !isDigitString(milliseconds, 3)) {\n return undefined;\n }\n\n const year = Number(day.slice(0, 4));\n const month = Number(day.slice(4, 6));\n const date = Number(day.slice(6, 8));\n const hours = Number(time.slice(0, 2));\n const minutes = Number(time.slice(2, 4));\n const seconds = Number(time.slice(4, 6));\n const millis = Number(milliseconds);\n\n const timestamp = new Date(Date.UTC(year, month - 1, date, hours, minutes, seconds, millis));\n\n if (\n Number.isNaN(timestamp.getTime()) ||\n timestamp.getUTCFullYear() !== year ||\n timestamp.getUTCMonth() !== month - 1 ||\n timestamp.getUTCDate() !== date ||\n timestamp.getUTCHours() !== hours ||\n timestamp.getUTCMinutes() !== minutes ||\n timestamp.getUTCSeconds() !== seconds ||\n timestamp.getUTCMilliseconds() !== millis\n ) {\n return undefined;\n }\n\n return timestamp;\n}\n\nfunction parseLogFilename(filename: string): { agent?: string; timestamp?: Date } {\n if (!filename.endsWith(JSONL_EXTENSION)) return {};\n\n const baseName = filename.slice(0, -JSONL_EXTENSION.length);\n const parts = baseName.split(\"-\");\n\n if (parts.length < 4) return {};\n\n const timestamp = parseTimestamp(parts[0], parts[1], parts[2]);\n const agent = parts.slice(3).join(\"-\");\n\n return {\n agent: agent.length > 0 ? agent : undefined,\n timestamp\n };\n}\n\nfunction normalizeLimit(limit: number | undefined): number {\n if (typeof limit !== \"number\" || !Number.isFinite(limit) || limit < 0) {\n return DEFAULT_LOG_LIMIT;\n }\n return Math.floor(limit);\n}\n\nfunction isSessionUpdate(parsed: unknown): parsed is SessionUpdate {\n return (\n typeof parsed === \"object\" &&\n parsed !== null &&\n \"sessionUpdate\" in parsed &&\n typeof (parsed as Record<string, unknown>).sessionUpdate === \"string\"\n );\n}\n\nfunction isLegacyEvent(parsed: unknown): parsed is AcpEvent {\n return (\n typeof parsed === \"object\" &&\n parsed !== null &&\n \"event\" in parsed &&\n typeof (parsed as Record<string, unknown>).event === \"string\"\n );\n}\n\nexport async function* readSpawnLog(filePath: string): AsyncIterable<SessionUpdate> {\n const fileHandle = await open(filePath, \"r\");\n const stream = fileHandle.createReadStream({ encoding: \"utf8\" });\n const reader = createInterface({\n input: stream,\n crlfDelay: Infinity\n });\n\n try {\n for await (const line of reader) {\n const trimmed = line.trim();\n if (trimmed.length === 0) continue;\n\n const parsed: unknown = JSON.parse(trimmed);\n\n if (isSessionUpdate(parsed)) {\n yield parsed;\n continue;\n }\n\n if (isLegacyEvent(parsed)) {\n for (const update of mapLegacyEventToSessionUpdates(parsed as { event: string } & Record<string, unknown>)) {\n yield update;\n }\n }\n }\n } finally {\n reader.close();\n if (!stream.destroyed) {\n stream.destroy();\n }\n await fileHandle.close().catch(() => {});\n }\n}\n\nexport async function listSpawnLogs(options: ListSpawnLogsOptions = {}): Promise<LogEntry[]> {\n const logDir = path.join(homedir(), \".poe-code\", \"spawn-logs\");\n const limit = normalizeLimit(options.limit);\n\n let entries: Dirent[];\n try {\n entries = await readdir(logDir, { withFileTypes: true });\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code === \"ENOENT\") return [];\n throw error;\n }\n\n const logs: LogEntry[] = [];\n\n for (const entry of entries) {\n if (!entry.isFile() || !entry.name.endsWith(JSONL_EXTENSION)) continue;\n\n const logEntry: LogEntry = {\n path: path.join(logDir, entry.name),\n filename: entry.name,\n ...parseLogFilename(entry.name)\n };\n\n if (options.agent && logEntry.agent !== options.agent) continue;\n\n logs.push(logEntry);\n }\n\n logs.sort((a, b) => (a.filename < b.filename ? 1 : a.filename > b.filename ? -1 : 0));\n return logs.slice(0, limit);\n}\n\nexport async function findLatestLog(agent?: string): Promise<string | undefined> {\n const [entry] = await listSpawnLogs({ agent, limit: 1 });\n return entry?.path;\n}\n\nexport async function pickRandomLog(agent?: string): Promise<string | undefined> {\n const entries = await listSpawnLogs({ agent });\n if (entries.length === 0) return undefined;\n return entries[Math.floor(Math.random() * entries.length)]?.path;\n}\n\nexport async function replaySpawnLog(filePath: string): Promise<void> {\n await renderSessionUpdateStream(readSpawnLog(filePath));\n}\n", "import { isAbsolute } from \"node:path\";\nimport {\n AcpTransport,\n type AcpTransportClosedEvent,\n type AcpTransportOptions,\n} from \"./acp-transport.js\";\nimport type { JsonRpcRequestOptions } from \"./jsonrpc-message-layer.js\";\nimport {\n ACP_ERROR_CODE_INVALID_PARAMS,\n ACP_ERROR_CODE_RESOURCE_NOT_FOUND,\n AcpError,\n type AgentCapabilities,\n type AuthenticateResponse,\n type AuthMethod,\n type CancelNotification,\n type ClientCapabilities,\n type ContentBlock,\n type CreateTerminalRequest,\n type CreateTerminalResponse,\n type EnvVariable,\n type Implementation,\n type InitializeResponse,\n type KillTerminalCommandRequest,\n type KillTerminalCommandResponse,\n type LoadSessionResponse,\n type McpServer,\n type NewSessionResponse,\n type PermissionOption,\n type PromptResponse,\n type RequestId,\n type SessionConfigId,\n type SessionConfigOption,\n type SessionConfigValueId,\n type RequestPermissionOutcome,\n type RequestPermissionRequest,\n type RequestPermissionResponse,\n type ReadTextFileRequest,\n type ReadTextFileResponse,\n type ProtocolVersion,\n type SessionModeId,\n type SessionNotification,\n type SessionId,\n type SetSessionModeResponse,\n type SessionUpdateNotification,\n type ToolCallUpdate,\n type TerminalOutputRequest,\n type TerminalOutputResponse,\n type WaitForTerminalExitRequest,\n type WaitForTerminalExitResponse,\n type WriteTextFileRequest,\n type WriteTextFileResponse,\n type ReleaseTerminalRequest,\n type ReleaseTerminalResponse,\n} from \"./types.js\";\n\nexport type AcpClientState = \"uninitialized\" | \"initialized\" | \"ready\";\ntype ExtensionMethod = `_${string}`;\n\nexport interface PromptTurn extends AsyncIterable<SessionUpdateNotification> {\n response: Promise<PromptResponse>;\n}\n\ninterface AsyncQueue<T> extends AsyncIterable<T>, AsyncIterator<T> {\n push(value: T): void;\n complete(): void;\n fail(error: Error): void;\n}\n\nexport interface AcpClientFsHandler {\n readTextFile?: (args: {\n sessionId: SessionId;\n path: string;\n line?: number | null;\n limit?: number | null;\n }) => string | Promise<string>;\n writeTextFile?: (args: {\n sessionId: SessionId;\n path: string;\n content: string;\n }) => void | Promise<void>;\n}\n\nexport interface AcpClientTerminalHandler {\n create: (args: {\n sessionId: SessionId;\n command: string;\n args?: string[];\n cwd?: string | null;\n env?: EnvVariable[];\n outputByteLimit?: number | null;\n }) => string | Promise<string>;\n output: (args: {\n sessionId: SessionId;\n terminalId: string;\n }) => TerminalOutputResponse | Promise<TerminalOutputResponse>;\n waitForExit: (args: {\n sessionId: SessionId;\n terminalId: string;\n }) => WaitForTerminalExitResponse | Promise<WaitForTerminalExitResponse>;\n kill: (args: { sessionId: SessionId; terminalId: string }) => void | Promise<void>;\n release: (args: {\n sessionId: SessionId;\n terminalId: string;\n }) => void | Promise<void>;\n}\n\ntype AcpClientPermissionHandler = (args: {\n toolCall: ToolCallUpdate;\n options: PermissionOption[];\n}) => RequestPermissionOutcome | Promise<RequestPermissionOutcome>;\n\nexport interface AcpClientHandlers {\n permission?: AcpClientPermissionHandler;\n fs?: AcpClientFsHandler;\n terminal?: AcpClientTerminalHandler;\n}\n\ntype AcpClientTransport = Pick<\n AcpTransport,\n \"sendRequest\" | \"sendNotification\" | \"onRequest\" | \"onNotification\"\n> &\n Partial<Pick<AcpTransport, \"dispose\" | \"closed\">>;\n\ninterface AcpClientSharedOptions {\n protocolVersion?: ProtocolVersion;\n clientCapabilities?: ClientCapabilities;\n clientInfo?: Implementation | null;\n handlers?: AcpClientHandlers;\n permissionHandler?: AcpClientPermissionHandler;\n fsHandler?: AcpClientFsHandler;\n terminalHandler?: AcpClientTerminalHandler;\n skipAuth?: boolean;\n /**\n * Automatically approve all permission requests (selects the first\n * \"allow_always\" or \"allow_once\" option). Ignored when a custom\n * `permissionHandler` is provided.\n */\n autoApprove?: boolean;\n}\n\nexport interface AcpClientProcessOptions extends AcpClientSharedOptions {\n command: string;\n args?: readonly string[];\n cwd?: string;\n env?: NodeJS.ProcessEnv;\n firstRequestId?: number;\n spawn?: AcpTransportOptions[\"spawn\"];\n}\n\nexport interface AcpClientInjectedTransportOptions extends AcpClientSharedOptions {\n transport: AcpClientTransport;\n}\n\nexport type AcpClientOptions = AcpClientProcessOptions | AcpClientInjectedTransportOptions;\n\nfunction toError(reason: unknown): Error {\n return reason instanceof Error ? reason : new Error(String(reason));\n}\n\nfunction invalidParams(message: string): AcpError {\n return new AcpError(\n ACP_ERROR_CODE_INVALID_PARAMS,\n `Invalid params: ${message}`\n );\n}\n\nfunction resourceNotFound(resource: string): AcpError {\n return new AcpError(\n ACP_ERROR_CODE_RESOURCE_NOT_FOUND,\n `Resource not found: ${resource}`\n );\n}\n\nfunction assertAbsolutePath(path: string): void {\n if (!isAbsolute(path)) {\n throw invalidParams('\"path\" must be an absolute path');\n }\n}\n\nfunction assertOneBasedLineNumber(line: number | null | undefined): void {\n if (line === null || line === undefined) {\n return;\n }\n\n if (!Number.isInteger(line) || line < 1) {\n throw invalidParams('\"line\" must be a 1-based integer');\n }\n}\n\nfunction assertExtensionMethod(method: string): asserts method is ExtensionMethod {\n if (!method.startsWith(\"_\")) {\n throw new Error('Extension method must start with \"_\"');\n }\n}\n\nfunction isInjectedTransportOptions(\n options: AcpClientOptions\n): options is AcpClientInjectedTransportOptions {\n return \"transport\" in options;\n}\n\nfunction createAsyncQueue<T>(): AsyncQueue<T> {\n const values: T[] = [];\n const waiters: Array<{\n resolve: (result: IteratorResult<T>) => void;\n reject: (error: Error) => void;\n }> = [];\n let closed = false;\n let failure: Error | null = null;\n\n const resolveOne = (value: T): boolean => {\n const waiter = waiters.shift();\n if (!waiter) {\n return false;\n }\n\n waiter.resolve({ done: false, value });\n return true;\n };\n\n const iterator: AsyncQueue<T> = {\n push(value: T): void {\n if (closed || failure) {\n return;\n }\n\n if (!resolveOne(value)) {\n values.push(value);\n }\n },\n complete(): void {\n if (closed || failure) {\n return;\n }\n\n closed = true;\n while (waiters.length > 0) {\n waiters.shift()?.resolve({ done: true, value: undefined });\n }\n },\n fail(error: Error): void {\n if (closed || failure) {\n return;\n }\n\n failure = error;\n while (waiters.length > 0) {\n waiters.shift()?.reject(error);\n }\n },\n async next(): Promise<IteratorResult<T>> {\n if (values.length > 0) {\n const value = values.shift() as T;\n return { done: false, value };\n }\n\n if (failure) {\n throw failure;\n }\n\n if (closed) {\n return { done: true, value: undefined };\n }\n\n return new Promise<IteratorResult<T>>((resolve, reject) => {\n waiters.push({ resolve, reject });\n });\n },\n async return(): Promise<IteratorResult<T>> {\n iterator.complete();\n return { done: true, value: undefined };\n },\n async throw(error: unknown): Promise<IteratorResult<T>> {\n const normalizedError = toError(error);\n iterator.fail(normalizedError);\n throw normalizedError;\n },\n [Symbol.asyncIterator](): AsyncIterator<T> {\n return iterator;\n },\n };\n\n return iterator;\n}\n\nexport class AcpClient {\n private readonly transport: AcpClientTransport;\n private readonly clientProtocolVersion: ProtocolVersion;\n private clientCapabilities?: ClientCapabilities;\n private readonly clientInfo?: Implementation | null;\n private readonly skipAuth: boolean;\n private readonly permissionHandler?: AcpClientPermissionHandler;\n private readonly fsHandler?: AcpClientFsHandler;\n private readonly terminalHandler?: AcpClientTerminalHandler;\n private readonly activePromptUpdates = new Map<\n SessionId,\n AsyncQueue<SessionUpdateNotification>\n >();\n private readonly trackedTerminalIds = new Map<SessionId, Set<string>>();\n private hasRegisteredFsReadHandler = false;\n private hasRegisteredFsWriteHandler = false;\n private hasRegisteredTerminalHandlers = false;\n private disposed = false;\n\n private lifecycleState: AcpClientState = \"uninitialized\";\n private negotiatedVersion: ProtocolVersion | null = null;\n private availableAuthMethods: AuthMethod[] = [];\n private negotiatedAgentCapabilities: AgentCapabilities | undefined;\n private negotiatedAgentInfo: Implementation | null | undefined;\n\n constructor(options: AcpClientOptions) {\n this.transport = isInjectedTransportOptions(options)\n ? options.transport\n : new AcpTransport({\n command: options.command,\n args: options.args,\n cwd: options.cwd,\n env: options.env,\n firstRequestId: options.firstRequestId,\n spawn: options.spawn,\n });\n this.clientProtocolVersion = options.protocolVersion ?? 1;\n this.clientCapabilities = options.clientCapabilities;\n this.clientInfo = options.clientInfo;\n this.skipAuth = options.skipAuth ?? false;\n this.permissionHandler = options.handlers?.permission ?? options.permissionHandler;\n this.fsHandler = options.handlers?.fs ?? options.fsHandler;\n this.terminalHandler = options.handlers?.terminal ?? options.terminalHandler;\n\n const autoApprove = options.autoApprove === true && !this.permissionHandler;\n\n this.transport.onRequest(\n \"session/request_permission\",\n async (params: RequestPermissionRequest): Promise<RequestPermissionResponse> => {\n if (this.permissionHandler) {\n const outcome = await this.permissionHandler({\n toolCall: params.toolCall,\n options: params.options,\n });\n return { outcome };\n }\n\n if (autoApprove) {\n const allow =\n params.options.find((o: PermissionOption) => o.kind === \"allow_always\") ??\n params.options.find((o: PermissionOption) => o.kind === \"allow_once\");\n if (allow) {\n return { outcome: { outcome: \"selected\", optionId: allow.optionId } };\n }\n }\n\n return { outcome: { outcome: \"cancelled\" } };\n }\n );\n\n this.registerCapabilityHandlers(this.clientCapabilities);\n\n this.transport.onNotification(\"session/update\", (params: SessionNotification) => {\n this.handleSessionUpdateNotification(params);\n });\n }\n\n get state(): AcpClientState {\n return this.lifecycleState;\n }\n\n get negotiatedProtocolVersion(): ProtocolVersion | null {\n return this.negotiatedVersion;\n }\n\n get authMethods(): AuthMethod[] {\n return [...this.availableAuthMethods];\n }\n\n get agentCapabilities(): AgentCapabilities | undefined {\n return this.negotiatedAgentCapabilities;\n }\n\n get agentInfo(): Implementation | null | undefined {\n return this.negotiatedAgentInfo;\n }\n\n get closed(): Promise<AcpTransportClosedEvent> | undefined {\n return this.transport.closed;\n }\n\n async initialize(clientCapabilities?: ClientCapabilities): Promise<InitializeResponse> {\n if (this.lifecycleState !== \"uninitialized\") {\n throw new Error(\"initialize() can only be called once.\");\n }\n\n if (clientCapabilities !== undefined) {\n this.clientCapabilities = clientCapabilities;\n this.registerCapabilityHandlers(clientCapabilities);\n }\n\n const response = await this.transport.sendRequest(\"initialize\", {\n protocolVersion: this.clientProtocolVersion,\n clientInfo: this.clientInfo,\n clientCapabilities: this.clientCapabilities,\n });\n\n const negotiatedProtocolVersion = Math.min(\n this.clientProtocolVersion,\n response.protocolVersion\n );\n\n this.negotiatedVersion = negotiatedProtocolVersion;\n this.negotiatedAgentCapabilities = response.agentCapabilities;\n this.negotiatedAgentInfo = response.agentInfo;\n this.availableAuthMethods = response.authMethods ? [...response.authMethods] : [];\n\n const requiresAuth = this.availableAuthMethods.length > 0 && !this.skipAuth;\n this.lifecycleState = requiresAuth ? \"initialized\" : \"ready\";\n\n return {\n protocolVersion: negotiatedProtocolVersion,\n ...(this.negotiatedAgentCapabilities !== undefined\n ? { agentCapabilities: this.negotiatedAgentCapabilities }\n : {}),\n ...(this.negotiatedAgentInfo !== undefined ? { agentInfo: this.negotiatedAgentInfo } : {}),\n ...(this.availableAuthMethods.length > 0 ? { authMethods: this.authMethods } : {}),\n };\n }\n\n async authenticate(methodId: string): Promise<AuthenticateResponse> {\n if (this.lifecycleState === \"uninitialized\") {\n throw new Error(\"Cannot authenticate before initialize().\");\n }\n\n if (this.lifecycleState === \"ready\") {\n throw new Error(\"Authentication is not required for this agent.\");\n }\n\n if (!this.availableAuthMethods.some((authMethod) => authMethod.id === methodId)) {\n throw new Error(`Unknown auth method \"${methodId}\".`);\n }\n\n const response = await this.transport.sendRequest(\"authenticate\", {\n methodId,\n });\n\n this.lifecycleState = \"ready\";\n return response;\n }\n\n async newSession(cwd: string, mcpServers: McpServer[]): Promise<NewSessionResponse> {\n this.assertReady(\"session/new\");\n this.assertMcpServerCapabilitySupport(mcpServers);\n\n return this.transport.sendRequest(\"session/new\", {\n cwd,\n mcpServers,\n });\n }\n\n async loadSession(\n sessionId: SessionId,\n cwd: string,\n mcpServers: McpServer[]\n ): Promise<LoadSessionResponse> {\n this.assertReady(\"session/load\");\n if (this.negotiatedAgentCapabilities?.loadSession !== true) {\n throw new Error(\n 'Cannot call \"session/load\" because the agent does not support session loading.'\n );\n }\n this.assertMcpServerCapabilitySupport(mcpServers);\n\n return this.transport.sendRequest(\"session/load\", {\n sessionId,\n cwd,\n mcpServers,\n });\n }\n\n async cancelSession(sessionId: SessionId): Promise<void> {\n this.assertReady(\"session/cancel\");\n const payload: CancelNotification = { sessionId };\n this.transport.sendNotification(\"session/cancel\", payload);\n }\n\n async setMode(\n sessionId: SessionId,\n modeId: SessionModeId\n ): Promise<SetSessionModeResponse> {\n this.assertReady(\"session/set_mode\");\n return this.transport.sendRequest(\"session/set_mode\", {\n sessionId,\n modeId,\n });\n }\n\n async setConfigOption(\n sessionId: SessionId,\n configId: SessionConfigId,\n value: SessionConfigValueId\n ): Promise<SessionConfigOption[]> {\n this.assertReady(\"session/set_config_option\");\n const response = await this.transport.sendRequest(\"session/set_config_option\", {\n sessionId,\n configId,\n value,\n });\n\n return response.configOptions;\n }\n\n prompt(sessionId: SessionId, content: ContentBlock[]): PromptTurn {\n this.assertReady(\"session/prompt\");\n this.assertPromptContentCapabilitySupport(content);\n\n if (this.activePromptUpdates.has(sessionId)) {\n throw new Error(\n `Cannot call \"session/prompt\" while another prompt is in progress for session \"${sessionId}\".`\n );\n }\n\n const updates = createAsyncQueue<SessionUpdateNotification>();\n this.activePromptUpdates.set(sessionId, updates);\n\n let requestPromise: Promise<PromptResponse>;\n try {\n requestPromise = this.transport.sendRequest(\"session/prompt\", {\n sessionId,\n prompt: content,\n });\n } catch (error) {\n const normalizedError = toError(error);\n this.activePromptUpdates.delete(sessionId);\n updates.fail(normalizedError);\n throw normalizedError;\n }\n\n const response = requestPromise\n .then((promptResponse) => {\n this.activePromptUpdates.delete(sessionId);\n updates.complete();\n return promptResponse;\n })\n .catch((error) => {\n const normalizedError = toError(error);\n this.activePromptUpdates.delete(sessionId);\n updates.fail(normalizedError);\n throw normalizedError;\n });\n\n return {\n response,\n [Symbol.asyncIterator](): AsyncIterator<SessionUpdateNotification> {\n return updates;\n },\n };\n }\n\n async sendExtRequest<TResult = unknown>(\n method: ExtensionMethod,\n params?: unknown,\n options?: JsonRpcRequestOptions\n ): Promise<TResult>;\n async sendExtRequest<TResult = unknown>(\n method: string,\n params?: unknown,\n options: JsonRpcRequestOptions = {}\n ): Promise<TResult> {\n assertExtensionMethod(method);\n return this.transport.sendRequest(method, params, options) as Promise<TResult>;\n }\n\n async sendExtNotification(method: ExtensionMethod, params?: unknown): Promise<void>;\n async sendExtNotification(method: string, params?: unknown): Promise<void> {\n assertExtensionMethod(method);\n this.transport.sendNotification(method, params);\n }\n\n onExtRequest<TMethod extends ExtensionMethod>(\n method: TMethod,\n handler: (\n params: unknown,\n context: { id: RequestId; method: TMethod }\n ) => unknown | Promise<unknown>\n ): void;\n onExtRequest(\n method: string,\n handler: (params: unknown, context: { id: RequestId; method: string }) => unknown\n ): void {\n assertExtensionMethod(method);\n this.transport.onRequest(method, handler);\n }\n\n onExtNotification<TMethod extends ExtensionMethod>(\n method: TMethod,\n handler: (params: unknown, context: { method: TMethod }) => void | Promise<void>\n ): void;\n onExtNotification(\n method: string,\n handler: (params: unknown, context: { method: string }) => void | Promise<void>\n ): void {\n assertExtensionMethod(method);\n this.transport.onNotification(method, handler);\n }\n\n async dispose(): Promise<void> {\n if (this.disposed) {\n if (this.transport.closed) {\n await this.transport.closed;\n }\n return;\n }\n\n this.disposed = true;\n const disposeReason = new Error(\"ACP client disposed\");\n for (const updates of this.activePromptUpdates.values()) {\n updates.fail(disposeReason);\n }\n this.activePromptUpdates.clear();\n\n if (typeof this.transport.dispose === \"function\") {\n this.transport.dispose(disposeReason);\n }\n\n if (this.transport.closed) {\n await this.transport.closed;\n }\n }\n\n assertReady(operation: string): void {\n if (this.lifecycleState === \"ready\") {\n return;\n }\n\n if (this.lifecycleState === \"uninitialized\") {\n throw new Error(`Cannot call \"${operation}\" before initialize().`);\n }\n\n throw new Error(`Cannot call \"${operation}\" before authentication completes.`);\n }\n\n private registerCapabilityHandlers(capabilities: ClientCapabilities | undefined): void {\n if (\n !this.hasRegisteredFsReadHandler &&\n capabilities?.fs?.readTextFile === true &&\n this.fsHandler?.readTextFile\n ) {\n const readTextFile = this.fsHandler.readTextFile;\n this.transport.onRequest(\n \"fs/read_text_file\",\n async (params: ReadTextFileRequest): Promise<ReadTextFileResponse> => {\n assertAbsolutePath(params.path);\n assertOneBasedLineNumber(params.line);\n\n const content = await readTextFile({\n sessionId: params.sessionId,\n path: params.path,\n line: params.line,\n limit: params.limit,\n });\n return { content };\n }\n );\n this.hasRegisteredFsReadHandler = true;\n }\n\n if (\n !this.hasRegisteredFsWriteHandler &&\n capabilities?.fs?.writeTextFile === true &&\n this.fsHandler?.writeTextFile\n ) {\n const writeTextFile = this.fsHandler.writeTextFile;\n this.transport.onRequest(\n \"fs/write_text_file\",\n async (params: WriteTextFileRequest): Promise<WriteTextFileResponse> => {\n assertAbsolutePath(params.path);\n\n await writeTextFile({\n sessionId: params.sessionId,\n path: params.path,\n content: params.content,\n });\n\n return {};\n }\n );\n this.hasRegisteredFsWriteHandler = true;\n }\n\n if (\n !this.hasRegisteredTerminalHandlers &&\n capabilities?.terminal === true &&\n this.terminalHandler\n ) {\n const terminalHandler = this.terminalHandler;\n this.transport.onRequest(\n \"terminal/create\",\n async (params: CreateTerminalRequest): Promise<CreateTerminalResponse> => {\n const terminalId = await terminalHandler.create({\n sessionId: params.sessionId,\n command: params.command,\n args: params.args,\n cwd: params.cwd,\n env: params.env,\n outputByteLimit: params.outputByteLimit,\n });\n this.trackTerminal(params.sessionId, terminalId);\n\n return { terminalId };\n }\n );\n\n this.transport.onRequest(\n \"terminal/output\",\n async (params: TerminalOutputRequest): Promise<TerminalOutputResponse> => {\n this.assertKnownTerminal(params.sessionId, params.terminalId);\n\n return terminalHandler.output({\n sessionId: params.sessionId,\n terminalId: params.terminalId,\n });\n }\n );\n\n this.transport.onRequest(\n \"terminal/wait_for_exit\",\n async (params: WaitForTerminalExitRequest): Promise<WaitForTerminalExitResponse> => {\n this.assertKnownTerminal(params.sessionId, params.terminalId);\n\n return terminalHandler.waitForExit({\n sessionId: params.sessionId,\n terminalId: params.terminalId,\n });\n }\n );\n\n this.transport.onRequest(\n \"terminal/kill\",\n async (params: KillTerminalCommandRequest): Promise<KillTerminalCommandResponse> => {\n this.assertKnownTerminal(params.sessionId, params.terminalId);\n\n await terminalHandler.kill({\n sessionId: params.sessionId,\n terminalId: params.terminalId,\n });\n\n return {};\n }\n );\n\n this.transport.onRequest(\n \"terminal/release\",\n async (params: ReleaseTerminalRequest): Promise<ReleaseTerminalResponse> => {\n this.assertKnownTerminal(params.sessionId, params.terminalId);\n\n await terminalHandler.release({\n sessionId: params.sessionId,\n terminalId: params.terminalId,\n });\n this.untrackTerminal(params.sessionId, params.terminalId);\n\n return {};\n }\n );\n this.hasRegisteredTerminalHandlers = true;\n }\n }\n\n private assertMcpServerCapabilitySupport(mcpServers: McpServer[]): void {\n const mcpCapabilities = this.negotiatedAgentCapabilities?.mcpCapabilities;\n\n for (const mcpServer of mcpServers) {\n if (!(\"type\" in mcpServer)) {\n continue;\n }\n\n if (mcpServer.type === \"http\" && mcpCapabilities?.http !== true) {\n throw new Error('Agent does not support MCP server type \"http\".');\n }\n\n if (mcpServer.type === \"sse\" && mcpCapabilities?.sse !== true) {\n throw new Error('Agent does not support MCP server type \"sse\".');\n }\n }\n }\n\n private handleSessionUpdateNotification(notification: SessionNotification): void {\n const activePrompt = this.activePromptUpdates.get(notification.sessionId);\n if (!activePrompt) {\n return;\n }\n\n activePrompt.push({\n jsonrpc: \"2.0\",\n method: \"session/update\",\n params: notification,\n });\n }\n\n private trackTerminal(sessionId: SessionId, terminalId: string): void {\n const sessionTerminals = this.trackedTerminalIds.get(sessionId);\n if (sessionTerminals) {\n sessionTerminals.add(terminalId);\n return;\n }\n\n this.trackedTerminalIds.set(sessionId, new Set([terminalId]));\n }\n\n private assertKnownTerminal(sessionId: SessionId, terminalId: string): void {\n const sessionTerminals = this.trackedTerminalIds.get(sessionId);\n if (sessionTerminals?.has(terminalId) === true) {\n return;\n }\n\n throw resourceNotFound(`terminal \"${terminalId}\"`);\n }\n\n private untrackTerminal(sessionId: SessionId, terminalId: string): void {\n const sessionTerminals = this.trackedTerminalIds.get(sessionId);\n if (!sessionTerminals) {\n return;\n }\n\n sessionTerminals.delete(terminalId);\n if (sessionTerminals.size === 0) {\n this.trackedTerminalIds.delete(sessionId);\n }\n }\n\n private assertPromptContentCapabilitySupport(content: ContentBlock[]): void {\n const promptCapabilities = this.negotiatedAgentCapabilities?.promptCapabilities;\n\n for (const block of content) {\n if (block.type === \"image\" && promptCapabilities?.image !== true) {\n throw new Error('Agent does not support prompt content type \"image\".');\n }\n\n if (block.type === \"audio\" && promptCapabilities?.audio !== true) {\n throw new Error('Agent does not support prompt content type \"audio\".');\n }\n\n if (block.type === \"resource\" && promptCapabilities?.embeddedContext !== true) {\n throw new Error('Agent does not support prompt content type \"resource\".');\n }\n }\n }\n}\n", "import {\n spawn as spawnChildProcess,\n type ChildProcessWithoutNullStreams,\n type SpawnOptionsWithoutStdio,\n} from \"node:child_process\";\nimport {\n JsonRpcMessageLayer,\n type JsonRpcNotificationHandler,\n type JsonRpcRequestHandler,\n type JsonRpcRequestOptions,\n} from \"./jsonrpc-message-layer.js\";\nimport type {\n AuthenticateRequest,\n AuthenticateResponse,\n CancelNotification,\n CreateTerminalRequest,\n CreateTerminalResponse,\n InitializeRequest,\n InitializeResponse,\n KillTerminalCommandRequest,\n KillTerminalCommandResponse,\n LoadSessionRequest,\n LoadSessionResponse,\n NewSessionRequest,\n NewSessionResponse,\n PromptRequest,\n PromptResponse,\n ReadTextFileRequest,\n ReadTextFileResponse,\n ReleaseTerminalRequest,\n ReleaseTerminalResponse,\n RequestId,\n RequestPermissionRequest,\n RequestPermissionResponse,\n SessionNotification,\n SetSessionConfigOptionRequest,\n SetSessionConfigOptionResponse,\n SetSessionModeRequest,\n SetSessionModeResponse,\n TerminalOutputRequest,\n TerminalOutputResponse,\n WaitForTerminalExitRequest,\n WaitForTerminalExitResponse,\n WriteTextFileRequest,\n WriteTextFileResponse,\n} from \"./types.js\";\n\ninterface AcpRequestShape<TParams, TResult> {\n params: TParams;\n result: TResult;\n}\n\nexport interface AcpAgentRequestMap {\n initialize: AcpRequestShape<InitializeRequest, InitializeResponse>;\n authenticate: AcpRequestShape<AuthenticateRequest, AuthenticateResponse>;\n \"session/new\": AcpRequestShape<NewSessionRequest, NewSessionResponse>;\n \"session/load\": AcpRequestShape<LoadSessionRequest, LoadSessionResponse>;\n \"session/prompt\": AcpRequestShape<PromptRequest, PromptResponse>;\n \"session/set_mode\": AcpRequestShape<SetSessionModeRequest, SetSessionModeResponse>;\n \"session/set_config_option\": AcpRequestShape<\n SetSessionConfigOptionRequest,\n SetSessionConfigOptionResponse\n >;\n}\n\nexport interface AcpAgentNotificationMap {\n \"session/cancel\": CancelNotification;\n}\n\nexport interface AcpClientRequestMap {\n \"session/request_permission\": AcpRequestShape<\n RequestPermissionRequest,\n RequestPermissionResponse\n >;\n \"fs/read_text_file\": AcpRequestShape<ReadTextFileRequest, ReadTextFileResponse>;\n \"fs/write_text_file\": AcpRequestShape<WriteTextFileRequest, WriteTextFileResponse>;\n \"terminal/create\": AcpRequestShape<CreateTerminalRequest, CreateTerminalResponse>;\n \"terminal/output\": AcpRequestShape<TerminalOutputRequest, TerminalOutputResponse>;\n \"terminal/wait_for_exit\": AcpRequestShape<\n WaitForTerminalExitRequest,\n WaitForTerminalExitResponse\n >;\n \"terminal/kill\": AcpRequestShape<\n KillTerminalCommandRequest,\n KillTerminalCommandResponse\n >;\n \"terminal/release\": AcpRequestShape<ReleaseTerminalRequest, ReleaseTerminalResponse>;\n}\n\nexport interface AcpClientNotificationMap {\n \"session/update\": SessionNotification;\n}\n\ntype ExtensionMethod = `_${string}`;\n\nfunction assertExtensionMethod(method: string): asserts method is ExtensionMethod {\n if (!method.startsWith(\"_\")) {\n throw new Error('Extension method must start with \"_\"');\n }\n}\n\ntype SpawnFunction = (\n command: string,\n args?: ReadonlyArray<string>,\n options?: SpawnOptionsWithoutStdio\n) => ChildProcessWithoutNullStreams;\n\nexport interface AcpTransportOptions {\n command: string;\n args?: readonly string[];\n cwd?: string;\n env?: NodeJS.ProcessEnv;\n firstRequestId?: number;\n spawn?: SpawnFunction;\n}\n\nexport interface AcpTransportClosedEvent {\n code: number | null;\n signal: NodeJS.Signals | null;\n reason: Error;\n stderr: string;\n}\n\nexport class AcpTransport {\n readonly closed: Promise<AcpTransportClosedEvent>;\n\n private readonly command: string;\n private readonly child: ChildProcessWithoutNullStreams;\n private readonly layer: JsonRpcMessageLayer;\n private readonly stderrChunks: string[] = [];\n private resolveClosed: ((value: AcpTransportClosedEvent) => void) | null = null;\n private closeEvent: AcpTransportClosedEvent | null = null;\n private closeReason: Error | null = null;\n\n constructor(options: AcpTransportOptions) {\n const {\n command,\n args = [],\n cwd,\n env,\n firstRequestId,\n spawn = spawnChildProcess,\n } = options;\n\n this.command = command;\n this.closed = new Promise<AcpTransportClosedEvent>((resolve) => {\n this.resolveClosed = resolve;\n });\n\n this.child = spawn(command, [...args], {\n cwd,\n env,\n stdio: [\"pipe\", \"pipe\", \"pipe\"],\n });\n\n this.child.stderr.setEncoding(\"utf8\");\n this.child.stderr.on(\"data\", (chunk) => {\n this.stderrChunks.push(String(chunk));\n });\n\n this.child.stdin.on(\"error\", (error) => {\n const reason = error instanceof Error ? error : new Error(String(error));\n this.close(reason, this.child.exitCode ?? null, this.child.signalCode ?? null);\n });\n\n this.layer = new JsonRpcMessageLayer({\n input: this.child.stdout,\n output: this.child.stdin,\n firstRequestId,\n });\n\n this.child.once(\"error\", (error) => {\n const reason = error instanceof Error ? error : new Error(String(error));\n this.close(reason, this.child.exitCode ?? null, this.child.signalCode ?? null);\n });\n\n this.child.once(\"close\", (code, signal) => {\n const reason =\n this.closeReason ??\n new Error(\n `ACP transport closed (command \"${this.command}\", code: ${code ?? \"null\"}${\n signal ? `, signal: ${signal}` : \"\"\n })`\n );\n this.close(reason, code ?? null, signal ?? null);\n });\n }\n\n sendRequest<TMethod extends keyof AcpAgentRequestMap>(\n method: TMethod,\n params: AcpAgentRequestMap[TMethod][\"params\"],\n options?: JsonRpcRequestOptions\n ): Promise<AcpAgentRequestMap[TMethod][\"result\"]>;\n sendRequest<TResult = unknown>(\n method: string,\n params?: unknown,\n options?: JsonRpcRequestOptions\n ): Promise<TResult>;\n sendRequest(\n method: string,\n params?: unknown,\n options: JsonRpcRequestOptions = {}\n ): Promise<unknown> {\n return this.layer.sendRequest(method, params, options);\n }\n\n sendExtRequest<TResult = unknown>(\n method: ExtensionMethod,\n params?: unknown,\n options?: JsonRpcRequestOptions\n ): Promise<TResult>;\n sendExtRequest<TResult = unknown>(\n method: string,\n params?: unknown,\n options: JsonRpcRequestOptions = {}\n ): Promise<TResult> {\n assertExtensionMethod(method);\n return this.layer.sendRequest(method, params, options) as Promise<TResult>;\n }\n\n sendNotification<TMethod extends keyof AcpAgentNotificationMap>(\n method: TMethod,\n params: AcpAgentNotificationMap[TMethod]\n ): void;\n sendNotification(method: string, params?: unknown): void;\n sendNotification(method: string, params?: unknown): void {\n this.layer.sendNotification(method, params);\n }\n\n sendExtNotification(method: ExtensionMethod, params?: unknown): void;\n sendExtNotification(method: string, params?: unknown): void;\n sendExtNotification(method: string, params?: unknown): void {\n assertExtensionMethod(method);\n this.layer.sendNotification(method, params);\n }\n\n onRequest<TMethod extends keyof AcpClientRequestMap>(\n method: TMethod,\n handler: (\n params: AcpClientRequestMap[TMethod][\"params\"],\n context: { id: RequestId; method: TMethod }\n ) =>\n | AcpClientRequestMap[TMethod][\"result\"]\n | Promise<AcpClientRequestMap[TMethod][\"result\"]>\n ): void;\n onRequest(method: string, handler: JsonRpcRequestHandler): void;\n onRequest(method: string, handler: JsonRpcRequestHandler): void {\n this.layer.onRequest(method, handler);\n }\n\n onExtRequest<TMethod extends ExtensionMethod>(\n method: TMethod,\n handler: (\n params: unknown,\n context: { id: RequestId; method: TMethod }\n ) => unknown | Promise<unknown>\n ): void;\n onExtRequest(method: string, handler: JsonRpcRequestHandler): void;\n onExtRequest(method: string, handler: JsonRpcRequestHandler): void {\n assertExtensionMethod(method);\n this.layer.onRequest(method, handler);\n }\n\n onNotification<TMethod extends keyof AcpClientNotificationMap>(\n method: TMethod,\n handler: (\n params: AcpClientNotificationMap[TMethod],\n context: { method: TMethod }\n ) => void | Promise<void>\n ): void;\n onNotification(method: string, handler: JsonRpcNotificationHandler): void;\n onNotification(method: string, handler: JsonRpcNotificationHandler): void {\n this.layer.onNotification(method, handler);\n }\n\n onExtNotification<TMethod extends ExtensionMethod>(\n method: TMethod,\n handler: (params: unknown, context: { method: TMethod }) => void | Promise<void>\n ): void;\n onExtNotification(method: string, handler: JsonRpcNotificationHandler): void;\n onExtNotification(method: string, handler: JsonRpcNotificationHandler): void {\n assertExtensionMethod(method);\n this.layer.onNotification(method, handler);\n }\n\n getStderrOutput(): string {\n return this.stderrChunks.join(\"\");\n }\n\n pendingRequestCount(): number {\n return this.layer.pendingRequestCount();\n }\n\n dispose(reason: Error = new Error(\"ACP transport disposed\")): void {\n if (this.closeEvent !== null) {\n return;\n }\n\n this.closeReason = reason;\n this.layer.dispose(reason);\n\n if (!this.child.stdin.destroyed && !this.child.stdin.writableEnded) {\n this.child.stdin.end();\n }\n\n if (this.child.exitCode !== null || this.child.signalCode !== null) {\n this.close(reason, this.child.exitCode, this.child.signalCode);\n return;\n }\n\n const killed = this.child.kill();\n if (!killed) {\n this.close(reason, this.child.exitCode, this.child.signalCode);\n }\n }\n\n private close(reason: Error, code: number | null, signal: NodeJS.Signals | null): void {\n if (this.closeEvent !== null) {\n return;\n }\n\n this.layer.dispose(reason);\n this.closeEvent = {\n code,\n signal,\n reason,\n stderr: this.getStderrOutput(),\n };\n this.resolveClosed?.(this.closeEvent);\n this.resolveClosed = null;\n }\n}\n", "import * as fsPromises from \"node:fs/promises\";\nimport { homedir } from \"node:os\";\nimport { join } from \"node:path\";\nimport {\n extractToolCallSummariesFromSessionUpdateStream,\n extractUsageFromSessionUpdateStream,\n type ToolCallSummary,\n} from \"./stream-helpers.js\";\nimport type { Cost, SessionUpdate, SessionUpdateNotification, UsageUpdate } from \"./types.js\";\n\ntype SessionUpdateStreamItem = SessionUpdateNotification | SessionUpdate;\n\nexport type RunExitStatus = \"success\" | \"failed\";\n\nexport interface RunReportUsage {\n used: number;\n size: number;\n updates: number;\n cost?: Cost | null;\n}\n\nexport interface RunReportError {\n message: string;\n toolCallId?: string;\n}\n\nexport interface RunReport {\n runId: string;\n startTime: string;\n endTime: string;\n exitStatus: RunExitStatus;\n toolCalls: ToolCallSummary[];\n usage: RunReportUsage;\n errors: RunReportError[];\n}\n\nexport interface GenerateRunReportOptions {\n runId?: string;\n startTime?: string | Date;\n endTime?: string | Date;\n exitStatus?: RunExitStatus;\n errors?: string[];\n now?: () => Date;\n}\n\nexport type RunReportFileSystem = {\n mkdir(path: string, options?: { recursive?: boolean }): Promise<void>;\n writeFile(\n path: string,\n data: string,\n options?: { encoding?: BufferEncoding },\n ): Promise<void>;\n};\n\nexport interface SaveRunReportOptions {\n fs?: RunReportFileSystem;\n homeDir?: string;\n now?: () => Date;\n}\n\nexport interface SavedRunReportPaths {\n reportsDir: string;\n jsonPath: string;\n summaryPath: string;\n}\n\nexport async function generateRunReportFromSessionUpdateStream(\n stream: AsyncIterable<SessionUpdateStreamItem> | Iterable<SessionUpdateStreamItem>,\n options: GenerateRunReportOptions = {},\n): Promise<RunReport> {\n const now = options.now ?? (() => new Date());\n\n const bufferedEntries: SessionUpdateStreamItem[] = [];\n let runIdFromStream: string | undefined;\n\n for await (const entry of stream) {\n bufferedEntries.push(entry);\n if (runIdFromStream) {\n continue;\n }\n\n if (isSessionUpdateNotification(entry)) {\n const sessionId = toNonEmptyString(entry.params.sessionId);\n if (sessionId) {\n runIdFromStream = sessionId;\n }\n }\n }\n\n const runId = toNonEmptyString(options.runId) ?? runIdFromStream;\n if (!runId) {\n throw new Error(\"Run id is required via options.runId or session/update stream items\");\n }\n\n const startTime = normalizeTime(options.startTime, now);\n const endTime = normalizeTime(options.endTime, now);\n\n const toolCalls = await extractToolCallSummariesFromSessionUpdateStream(bufferedEntries);\n const usageUpdates = await extractUsageFromSessionUpdateStream(bufferedEntries);\n\n const usage = summarizeUsage(usageUpdates);\n const errors = collectErrors(toolCalls, options.errors);\n const exitStatus = options.exitStatus ?? (errors.length > 0 ? \"failed\" : \"success\");\n\n return {\n runId,\n startTime,\n endTime,\n exitStatus,\n toolCalls,\n usage,\n errors,\n };\n}\n\nexport function formatRunReportSummary(report: RunReport): string {\n const lines = [\n `Run ID: ${report.runId}`,\n `Start time: ${report.startTime}`,\n `End time: ${report.endTime}`,\n `Duration: ${toDuration(report.startTime, report.endTime)}`,\n `Exit status: ${report.exitStatus}`,\n `Tool count: ${report.toolCalls.length}`,\n `Token usage: ${report.usage.used}/${report.usage.size}`,\n `Error count: ${report.errors.length}`,\n ];\n\n if (report.usage.cost) {\n lines.push(`Cost: ${report.usage.cost.amount} ${report.usage.cost.currency}`);\n }\n\n return lines.join(\"\\n\");\n}\n\nexport async function saveRunReport(\n report: RunReport,\n options: SaveRunReportOptions = {},\n): Promise<SavedRunReportPaths> {\n const fs = options.fs ?? fsPromises;\n const now = options.now ?? (() => new Date());\n\n const reportsDir = join(options.homeDir ?? homedir(), \".poe-code\", \"reports\");\n await fs.mkdir(reportsDir, { recursive: true });\n\n const timestamp = toTimestampForFileName(now());\n const safeRunId = toSafeFileSegment(report.runId);\n const baseFileName = `${timestamp}-${safeRunId}`;\n\n const jsonPath = join(reportsDir, `${baseFileName}.json`);\n const summaryPath = join(reportsDir, `${baseFileName}.txt`);\n\n await fs.writeFile(jsonPath, JSON.stringify(report, null, 2), { encoding: \"utf8\" });\n await fs.writeFile(summaryPath, formatRunReportSummary(report), { encoding: \"utf8\" });\n\n return {\n reportsDir,\n jsonPath,\n summaryPath,\n };\n}\n\nfunction isSessionUpdateNotification(entry: SessionUpdateStreamItem): entry is SessionUpdateNotification {\n return (\n typeof (entry as SessionUpdateNotification).jsonrpc === \"string\" &&\n (entry as SessionUpdateNotification).method === \"session/update\"\n );\n}\n\nfunction normalizeTime(value: string | Date | undefined, now: () => Date): string {\n if (value instanceof Date) {\n return value.toISOString();\n }\n\n if (typeof value === \"string\" && value.length > 0) {\n const parsed = new Date(value);\n if (!Number.isNaN(parsed.getTime())) {\n return parsed.toISOString();\n }\n }\n\n return now().toISOString();\n}\n\nfunction summarizeUsage(updates: readonly UsageUpdate[]): RunReportUsage {\n let used = 0;\n let size = 0;\n let cost: Cost | null | undefined;\n\n for (const update of updates) {\n used += update.used;\n size += update.size;\n\n if (update.cost !== undefined) {\n cost = update.cost;\n }\n }\n\n const usage: RunReportUsage = {\n used,\n size,\n updates: updates.length,\n };\n\n if (cost !== undefined) {\n usage.cost = cost;\n }\n\n return usage;\n}\n\nfunction collectErrors(\n toolCalls: readonly ToolCallSummary[],\n additionalErrors: readonly string[] | undefined,\n): RunReportError[] {\n const errors: RunReportError[] = [];\n\n for (const toolCall of toolCalls) {\n if (toolCall.status !== \"failed\") {\n continue;\n }\n\n errors.push({\n toolCallId: toolCall.toolCallId,\n message: toErrorMessage(toolCall),\n });\n }\n\n if (additionalErrors) {\n for (const message of additionalErrors) {\n const text = toNonEmptyString(message);\n if (text) {\n errors.push({ message: text });\n }\n }\n }\n\n return errors;\n}\n\nfunction toErrorMessage(toolCall: ToolCallSummary): string {\n if (typeof toolCall.rawOutput === \"string\" && toolCall.rawOutput.length > 0) {\n return toolCall.rawOutput;\n }\n\n if (toolCall.rawOutput instanceof Error && toolCall.rawOutput.message.length > 0) {\n return toolCall.rawOutput.message;\n }\n\n if (toolCall.rawOutput !== undefined && toolCall.rawOutput !== null) {\n const encoded = trySerialize(toolCall.rawOutput);\n if (encoded) {\n return encoded;\n }\n }\n\n return `${toolCall.title} failed`;\n}\n\nfunction trySerialize(value: unknown): string | undefined {\n try {\n const serialized = JSON.stringify(value);\n if (typeof serialized === \"string\" && serialized.length > 0) {\n return serialized;\n }\n } catch {\n return undefined;\n }\n\n return undefined;\n}\n\nfunction toDuration(startTime: string, endTime: string): string {\n const startMs = Date.parse(startTime);\n const endMs = Date.parse(endTime);\n\n if (Number.isNaN(startMs) || Number.isNaN(endMs) || endMs < startMs) {\n return \"unknown\";\n }\n\n const seconds = (endMs - startMs) / 1000;\n return `${Number(seconds.toFixed(3))}s`;\n}\n\nfunction toSafeFileSegment(value: string): string {\n let output = \"\";\n\n for (const char of value) {\n if (isAsciiLetterOrDigit(char) || char === \"-\" || char === \"_\") {\n output += char;\n continue;\n }\n\n output += \"-\";\n }\n\n return output.length > 0 ? output : \"run\";\n}\n\nfunction isAsciiLetterOrDigit(value: string): boolean {\n const code = value.charCodeAt(0);\n return (\n (code >= 48 && code <= 57) ||\n (code >= 65 && code <= 90) ||\n (code >= 97 && code <= 122)\n );\n}\n\nfunction toTimestampForFileName(value: Date): string {\n return [\n String(value.getUTCFullYear()),\n pad(value.getUTCMonth() + 1, 2),\n pad(value.getUTCDate(), 2),\n ].join(\"\")\n + \"-\"\n + [\n pad(value.getUTCHours(), 2),\n pad(value.getUTCMinutes(), 2),\n pad(value.getUTCSeconds(), 2),\n ].join(\"\")\n + \"-\"\n + pad(value.getUTCMilliseconds(), 3);\n}\n\nfunction pad(value: number, size: number): string {\n const text = String(value);\n if (text.length >= size) {\n return text;\n }\n\n return `${\"0\".repeat(size - text.length)}${text}`;\n}\n\nfunction toNonEmptyString(value: unknown): string | undefined {\n if (typeof value !== \"string\" || value.length === 0) {\n return undefined;\n }\n\n return value;\n}\n", "import path from \"node:path\";\nimport { homedir } from \"node:os\";\nimport { mkdir, open, type FileHandle } from \"node:fs/promises\";\nimport type { AcpEvent } from \"../types.js\";\nimport type { AcpMiddleware, SpawnContext } from \"../middleware.js\";\n\nfunction pad(value: number, width: number): string {\n return String(value).padStart(width, \"0\");\n}\n\nfunction formatTimestamp(date: Date): { day: string; time: string; milliseconds: string } {\n const day = `${date.getUTCFullYear()}${pad(date.getUTCMonth() + 1, 2)}${pad(date.getUTCDate(), 2)}`;\n const time = `${pad(date.getUTCHours(), 2)}${pad(date.getUTCMinutes(), 2)}${pad(date.getUTCSeconds(), 2)}`;\n const milliseconds = pad(date.getUTCMilliseconds(), 3);\n return { day, time, milliseconds };\n}\n\nfunction normalizeAgent(agent: string): string {\n let normalized = \"\";\n for (const char of agent) {\n const code = char.charCodeAt(0);\n const isLower = code >= 97 && code <= 122;\n const isUpper = code >= 65 && code <= 90;\n const isDigit = code >= 48 && code <= 57;\n\n if (isLower || isUpper || isDigit || char === \"-\" || char === \"_\") {\n normalized += char;\n } else {\n normalized += \"-\";\n }\n }\n\n return normalized.length > 0 ? normalized : \"agent\";\n}\n\nfunction resolveStartedAt(value: Date | undefined): Date {\n if (!(value instanceof Date) || Number.isNaN(value.getTime())) {\n return new Date();\n }\n\n return value;\n}\n\nfunction resolveLogFilePath(ctx: SpawnContext): string {\n if (ctx.logPath) {\n return ctx.logPath;\n }\n const baseDir = ctx.logDir ?? path.join(homedir(), \".poe-code\", \"spawn-logs\");\n if (ctx.logFileName) {\n return path.join(baseDir, ctx.logFileName);\n }\n const startedAt = resolveStartedAt(ctx.startedAt);\n const { day, time, milliseconds } = formatTimestamp(startedAt);\n const fileName = `${day}-${time}-${milliseconds}-${normalizeAgent(ctx.agent)}.jsonl`;\n return path.join(baseDir, fileName);\n}\n\nclass SpawnLogWriter {\n private fileHandle: FileHandle | undefined;\n\n private isDisabled = false;\n\n readonly filePath: string;\n\n private readonly logDirPath: string;\n\n constructor(ctx: SpawnContext) {\n this.filePath = resolveLogFilePath(ctx);\n this.logDirPath = path.dirname(this.filePath);\n }\n\n async writeEvent(event: AcpEvent): Promise<void> {\n if (this.isDisabled) {\n return;\n }\n\n try {\n await this.ensureOpen();\n if (!this.fileHandle) {\n return;\n }\n\n const meta = (event as { _meta?: Record<string, unknown> })._meta;\n const toLog = meta?.raw ?? event;\n await this.fileHandle.appendFile(`${JSON.stringify(toLog)}\\n`, \"utf8\");\n } catch {\n this.isDisabled = true;\n await this.close();\n }\n }\n\n async close(): Promise<void> {\n if (!this.fileHandle) {\n return;\n }\n\n try {\n await this.fileHandle.close();\n } catch {\n // Ignore close errors to avoid disrupting event processing.\n } finally {\n this.fileHandle = undefined;\n }\n }\n\n private async ensureOpen(): Promise<void> {\n if (this.fileHandle || this.isDisabled) {\n return;\n }\n\n try {\n await mkdir(this.logDirPath, { recursive: true });\n this.fileHandle = await open(this.filePath, \"a\");\n } catch {\n this.isDisabled = true;\n }\n }\n}\n\nasync function writePreloadedEvents(writer: SpawnLogWriter, events: AcpEvent[]): Promise<void> {\n for (const event of events) {\n await writer.writeEvent(event);\n }\n}\n\nexport const spawnLog: AcpMiddleware = async (ctx, next) => {\n await next();\n\n const source = ctx.eventStream;\n const writer = new SpawnLogWriter(ctx);\n ctx.logFile = writer.filePath;\n\n await writePreloadedEvents(writer, ctx.events);\n\n if (!source) {\n await writer.close();\n return;\n }\n\n ctx.eventStream = (async function* () {\n try {\n for await (const event of source) {\n await writer.writeEvent(event);\n yield event;\n }\n } finally {\n await writer.close();\n }\n })();\n};\n", "import type {\n CommandRunner,\n CommandRunnerOptions,\n CommandRunnerResult\n} from \"@poe-code/agent-spawn\";\nimport { buildSpawnArgs } from \"@poe-code/agent-spawn\";\nimport { createBinaryExistsDetectors } from \"@poe-code/agent-harness-tools\";\n\nexport type {\n CommandRunner,\n CommandRunnerOptions,\n CommandRunnerResult\n} from \"@poe-code/agent-spawn\";\n\nexport function formatCommandRunnerResult(\n result: CommandRunnerResult\n): string {\n const stdout =\n result.stdout.length > 0 ? result.stdout : \"<empty>\";\n const stderr =\n result.stderr.length > 0 ? result.stderr : \"<empty>\";\n return `stdout:\\n${stdout}\\nstderr:\\n${stderr}`;\n}\n\nexport interface RunAndMatchOutputOptions {\n command: string;\n args: string[];\n expectedOutput: string;\n commandOptions?: CommandRunnerOptions;\n skipOnDryRun?: boolean;\n}\n\nexport function describeCommandExpectation(\n command: string,\n args: string[],\n expectedOutput: string\n): string {\n return `${renderCommandLine(command, args)} (expecting \"${expectedOutput}\")`;\n}\n\nexport interface CommandExpectationCheckOptions\n extends RunAndMatchOutputOptions {\n id: string;\n}\n\nexport function createCommandExpectationCheck(\n options: CommandExpectationCheckOptions\n): CommandCheck {\n return {\n id: options.id,\n description: describeCommandExpectation(\n options.command,\n options.args,\n options.expectedOutput\n ),\n async run(context) {\n await runAndMatchOutput(context, options);\n }\n };\n}\n\nexport async function runAndMatchOutput(\n context: CommandCheckContext,\n options: RunAndMatchOutputOptions\n): Promise<void> {\n const rendered = renderCommandLine(options.command, options.args);\n if (options.skipOnDryRun !== false && context.isDryRun) {\n if (context.logDryRun) {\n context.logDryRun(\n `Dry run: ${rendered} (expecting \"${options.expectedOutput}\")`\n );\n }\n return;\n }\n\n const result = options.commandOptions\n ? await context.runCommand(options.command, options.args, options.commandOptions)\n : await context.runCommand(options.command, options.args);\n if (result.exitCode !== 0) {\n const detail = formatCommandRunnerResult(result);\n throw new Error(\n [`Command ${rendered} failed with exit code ${result.exitCode}.`, detail].join(\"\\n\")\n );\n }\n\n if (!stdoutMatchesExpected(result.stdout, options.expectedOutput)) {\n const detail = formatCommandRunnerResult(result);\n const received = result.stdout.trim();\n throw new Error(\n [\n `Command ${rendered} failed: expected \"${options.expectedOutput}\" but received \"${received}\".`,\n detail\n ].join(\"\\n\")\n );\n }\n}\n\nexport function stdoutMatchesExpected(stdout: string, expected: string): boolean {\n const trimmed = stdout.trim();\n if (trimmed === expected) {\n return true;\n }\n\n const lines = stdout\n .split(/\\r?\\n/)\n .map((line) => line.trim())\n .filter((line) => line.length > 0);\n\n if (lines.some((line) => line === expected)) {\n return true;\n }\n\n for (const line of lines) {\n if (line[0] !== \"{\") continue;\n try {\n const parsed = JSON.parse(line) as { type?: string; result?: string };\n if (parsed.type === \"result\" && parsed.result === expected) {\n return true;\n }\n } catch {\n continue;\n }\n }\n\n return false;\n}\n\nfunction renderCommandLine(command: string, args: string[]): string {\n return [command, ...args].map(quoteIfNeeded).join(\" \").trim();\n}\n\nfunction quoteIfNeeded(value: string): string {\n if (value.length === 0) {\n return '\"\"';\n }\n if (needsQuoting(value)) {\n return `\"${value.replaceAll('\"', '\\\\\"')}\"`;\n }\n return value;\n}\n\nfunction needsQuoting(value: string): boolean {\n return (\n value.includes(\" \") ||\n value.includes(\"\\t\") ||\n value.includes(\"\\n\")\n );\n}\n\nexport interface CommandCheckContext {\n isDryRun: boolean;\n runCommand: CommandRunner;\n logDryRun?: (message: string) => void;\n}\n\nexport interface CommandCheck {\n id: string;\n description?: string;\n run(context: CommandCheckContext): Promise<void>;\n}\n\nexport function createSpawnHealthCheck(\n agentId: string,\n options: { model?: string; expectedOutput: string }\n): CommandCheck {\n const prompt = `Output exactly: ${options.expectedOutput}`;\n const { binaryName, args, env: modeEnv } = buildSpawnArgs(agentId, {\n prompt,\n model: options.model,\n mode: \"yolo\"\n });\n return {\n id: `${agentId}-cli-health`,\n description: `spawn ${agentId} (expecting \"${options.expectedOutput}\")`,\n async run(context) {\n if (context.isDryRun) {\n context.logDryRun?.(\n `Dry run: ${[binaryName, ...args].join(\" \")} (expecting \"${options.expectedOutput}\")`\n );\n return;\n }\n\n const result = modeEnv\n ? await context.runCommand(binaryName, args, { env: modeEnv })\n : await context.runCommand(binaryName, args);\n\n if (result.exitCode !== 0) {\n throw new Error(\n `spawn ${agentId} failed with exit code ${result.exitCode}.\\n${formatCommandRunnerResult(result)}`\n );\n }\n\n if (!result.stdout.includes(options.expectedOutput)) {\n throw new Error(\n `spawn ${agentId}: expected \"${options.expectedOutput}\" in stdout.\\n${formatCommandRunnerResult(result)}`\n );\n }\n }\n };\n}\n\n/**\n * Creates a check that detects if a binary exists using multiple fallback methods.\n * This is useful in Docker/containerized environments where PATH may not be updated after npm install.\n *\n * @param binaryName - The name of the binary to check for (e.g., \"claude\", \"codex\")\n * @param id - Unique identifier for the check\n * @param description - Human-readable description of what's being checked\n * @returns A CommandCheck that verifies the binary using multiple detection methods\n */\nexport function createBinaryExistsCheck(\n binaryName: string,\n id: string,\n description: string\n): CommandCheck {\n return {\n id,\n description,\n async run({ runCommand }) {\n for (const detector of createBinaryExistsDetectors(binaryName)) {\n const result = await runCommand(detector.command, detector.args);\n if (detector.validate(result)) {\n return;\n }\n }\n\n throw new Error(`${binaryName} CLI binary not found on PATH.`);\n }\n };\n}\n", "import type {\n CommandRunner,\n CommandCheckContext,\n CommandCheck\n} from \"../utils/command-checks.js\";\n\nexport interface InstallContext {\n isDryRun: boolean;\n runCommand: CommandRunner;\n logger: (message: string) => void;\n platform: NodeJS.Platform;\n}\n\nexport interface InstallCommand {\n id: string;\n command: string;\n args: string[];\n platforms?: NodeJS.Platform[];\n}\n\nexport interface ServiceInstallDefinition {\n id: string;\n summary: string;\n check: CommandCheck;\n steps: InstallCommand[];\n postChecks?: CommandCheck[];\n successMessage?: string;\n}\n\nexport async function runServiceInstall(\n definition: ServiceInstallDefinition,\n context: InstallContext\n): Promise<boolean> {\n const checkContext: CommandCheckContext = {\n isDryRun: context.isDryRun,\n runCommand: context.runCommand\n };\n\n let needsInstall = false;\n try {\n await definition.check.run(checkContext);\n context.logger(`${definition.summary} already installed.`);\n } catch (error) {\n const detail =\n error instanceof Error ? error.message : String(error);\n context.logger(`${definition.summary} not detected: ${detail}`);\n needsInstall = true;\n }\n\n if (!needsInstall) {\n return false;\n }\n\n if (context.isDryRun) {\n logInstallDryRun(definition, context);\n return true;\n }\n\n const platformSteps = filterStepsByPlatform(definition.steps, context.platform);\n for (const step of platformSteps) {\n await runInstallStep(step, context);\n }\n\n await definition.check.run(checkContext);\n\n if (definition.postChecks) {\n for (const postCheck of definition.postChecks) {\n await postCheck.run(checkContext);\n }\n }\n\n context.logger(\n definition.successMessage ?? `${definition.summary} installed.`\n );\n return true;\n}\n\nfunction describeInstallCommand(step: InstallCommand): string {\n return `[${step.id}] ${formatCommand(step.command, step.args)}`;\n}\n\nfunction formatCommand(command: string, args: string[]): string {\n return [command, ...args.map(quoteIfNeeded)].join(\" \");\n}\n\nfunction quoteIfNeeded(value: string): string {\n if (value.length === 0) {\n return '\"\"';\n }\n if (value.includes(\" \") || value.includes(\"\\t\") || value.includes(\"\\n\")) {\n return `\"${value.replaceAll('\"', '\\\\\"')}\"`;\n }\n return value;\n}\n\nfunction filterStepsByPlatform(\n steps: InstallCommand[],\n platform: NodeJS.Platform\n): InstallCommand[] {\n return steps.filter(\n (step) => !step.platforms || step.platforms.includes(platform)\n );\n}\n\nfunction logInstallDryRun(\n definition: ServiceInstallDefinition,\n context: InstallContext\n): void {\n context.logger(`Dry run: would install ${definition.summary}.`);\n const platformSteps = filterStepsByPlatform(definition.steps, context.platform);\n for (const step of platformSteps) {\n context.logger(`Dry run: ${describeInstallCommand(step)}`);\n }\n}\n\nasync function runInstallStep(\n step: InstallCommand,\n context: InstallContext\n): Promise<void> {\n context.logger(`Running ${describeInstallCommand(step)}`);\n const result = await context.runCommand(step.command, step.args);\n if (result.exitCode !== 0) {\n const stderr = result.stderr.trim();\n const suffix = stderr.length > 0 ? `: ${stderr}` : \"\";\n throw new Error(\n `${describeInstallCommand(step)} failed with exit code ${result.exitCode}${suffix}`\n );\n }\n}\n", "import type {\n ProviderService,\n ProviderContext,\n ProviderBranding,\n ProviderConfigurePrompts,\n ProviderIsolatedEnv\n} from \"../cli/service-registry.js\";\nimport {\n runMutations,\n type Mutation,\n type MutationObservers\n} from \"@poe-code/config-mutations\";\nimport {\n runServiceInstall,\n type ServiceInstallDefinition\n} from \"../services/service-install.js\";\n// Template imports are lazy to avoid breaking tsc output when imported\n// by generate-bin-wrappers.mjs (Node.js can't resolve .mustache as ESM modules)\nconst templateImports: Record<string, () => Promise<{ default: string }>> = {\n \"py-poe-spawn/env.mustache\": () => import(\"../templates/py-poe-spawn/env.mustache\"),\n \"py-poe-spawn/main.py.mustache\": () => import(\"../templates/py-poe-spawn/main.py.mustache\"),\n \"py-poe-spawn/requirements.txt.mustache\": () => import(\"../templates/py-poe-spawn/requirements.txt.mustache\"),\n \"codex/config.toml.mustache\": () => import(\"../templates/codex/config.toml.mustache\"),\n};\n\nasync function loadTemplate(templateId: string): Promise<string> {\n const loader = templateImports[templateId];\n if (!loader) {\n throw new Error(`Template not found: ${templateId}`);\n }\n const module = await loader();\n return module.default;\n}\n\ninterface ManifestVersionDefinition {\n configure: Mutation[];\n unconfigure?: Mutation[];\n}\n\nexport interface ServiceRunOptions {\n observers?: MutationObservers;\n}\n\ninterface CreateProviderOptions<\n ConfigureOptions,\n UnconfigureOptions,\n SpawnOptions\n> {\n name: string;\n aliases?: string[];\n label: string;\n id: string;\n summary: string;\n branding?: ProviderBranding;\n disabled?: boolean;\n supportsStdinPrompt?: boolean;\n supportsMcpSpawn?: boolean;\n requiresProvider?: boolean;\n configurePrompts?: ProviderConfigurePrompts;\n postConfigureMessages?: string[];\n extendConfigurePayload?: ProviderService<\n ConfigureOptions,\n UnconfigureOptions,\n SpawnOptions\n >[\"extendConfigurePayload\"];\n isolatedEnv?: ProviderIsolatedEnv;\n manifest: ManifestVersionDefinition;\n install?: ServiceInstallDefinition;\n test?: ProviderService<ConfigureOptions, UnconfigureOptions, SpawnOptions>[\"test\"];\n spawn?: ProviderService<\n ConfigureOptions,\n UnconfigureOptions,\n SpawnOptions\n >[\"spawn\"];\n}\n\nexport function createProvider<\n ConfigureOptions = any,\n UnconfigureOptions = ConfigureOptions,\n SpawnOptions = any\n>(\n opts: CreateProviderOptions<ConfigureOptions, UnconfigureOptions, SpawnOptions>\n): ProviderService<ConfigureOptions, UnconfigureOptions, SpawnOptions> {\n const provider: ProviderService<\n ConfigureOptions,\n UnconfigureOptions,\n SpawnOptions\n > = {\n id: opts.id,\n summary: opts.summary,\n name: opts.name,\n aliases: opts.aliases,\n label: opts.label,\n branding: opts.branding,\n disabled: opts.disabled,\n supportsStdinPrompt: opts.supportsStdinPrompt,\n supportsMcpSpawn: opts.supportsMcpSpawn,\n requiresProvider: opts.requiresProvider ?? true,\n configurePrompts: opts.configurePrompts,\n postConfigureMessages: opts.postConfigureMessages,\n extendConfigurePayload: opts.extendConfigurePayload,\n isolatedEnv: opts.isolatedEnv,\n async configure(context, runOptions) {\n await runMutations(opts.manifest.configure, {\n fs: context.fs,\n homeDir: context.env.homeDir,\n observers: runOptions?.observers,\n templates: loadTemplate,\n pathMapper: context.pathMapper\n }, context.options as Record<string, unknown>);\n context.command.flushDryRun({ emitIfEmpty: false });\n },\n async unconfigure(context, runOptions) {\n if (!opts.manifest.unconfigure) {\n return false;\n }\n const result = await runMutations(opts.manifest.unconfigure, {\n fs: context.fs,\n homeDir: context.env.homeDir,\n observers: runOptions?.observers,\n templates: loadTemplate,\n pathMapper: context.pathMapper\n }, context.options as Record<string, unknown>);\n context.command.flushDryRun({ emitIfEmpty: false });\n return result.changed;\n }\n };\n\n if (opts.install) {\n provider.install = createInstallRunner(opts.install);\n }\n\n if (opts.test) {\n provider.test = opts.test;\n }\n\n if (opts.spawn) {\n provider.spawn = opts.spawn;\n }\n\n return provider;\n}\n\nfunction createInstallRunner(definition: ServiceInstallDefinition) {\n return async (context: ProviderContext): Promise<void> => {\n await runServiceInstall(definition, {\n isDryRun: context.logger.context.dryRun,\n runCommand: context.command.runCommand,\n logger: (message) => context.logger.verbose(message),\n platform: context.env.platform\n });\n };\n}\n", "export const FRONTIER_MODELS = [\n \"anthropic/claude-opus-4.7\",\n \"anthropic/claude-sonnet-4.6\",\n \"openai/gpt-5.3-codex\",\n \"openai/gpt-5.5\",\n \"google/gemini-3.1-pro\"\n] as const;\n\nexport const DEFAULT_FRONTIER_MODEL = \"anthropic/claude-opus-4.7\";\n\nexport const DEFAULT_TEXT_MODEL = \"anthropic/claude-sonnet-4.6\";\nexport const DEFAULT_IMAGE_BOT = \"google/nano-banana-pro\";\nexport const DEFAULT_AUDIO_BOT = \"elevenlabs/elevenlabs-v3\";\nexport const DEFAULT_VIDEO_BOT = \"google/veo-3.1\";\n\nexport const CLAUDE_CODE_VARIANTS = {\n haiku: \"anthropic/claude-haiku-4.5\",\n sonnet: \"anthropic/claude-sonnet-4.6\",\n opus: \"anthropic/claude-opus-4.7\"\n} as const;\n\nexport const DEFAULT_CLAUDE_CODE_MODEL = CLAUDE_CODE_VARIANTS.sonnet;\n\n/**\n * Extracts the model ID from a namespaced model slug (lowercase).\n * e.g., \"anthropic/claude-sonnet-4.6\" -> \"claude-sonnet-4.6\"\n */\nexport function stripModelNamespace(model: string): string {\n const slashIndex = model.indexOf(\"/\");\n const id = slashIndex === -1 ? model : model.slice(slashIndex + 1);\n return id.toLowerCase();\n}\n\nexport const DEFAULT_CODEX_MODEL = \"openai/gpt-5.5\";\n\nexport const KIMI_MODELS = [\n \"novitaai/kimi-k2.5\",\n \"novitaai/kimi-k2-thinking\",\n \"novitaai/kimi-k2.5-fw\",\n] as const;\nexport const DEFAULT_KIMI_MODEL = KIMI_MODELS[0];\n\nexport const GOOSE_MODELS = FRONTIER_MODELS;\nexport const DEFAULT_GOOSE_MODEL = DEFAULT_FRONTIER_MODEL;\n\nexport const DEFAULT_REASONING = \"medium\";\nexport const PROVIDER_NAME = \"poe\";\nexport const FEEDBACK_URL = \"https://github.com/poe-platform/poe-code/issues\";\n", "import type { CliEnvironment } from \"../cli/environment.js\";\nimport {\n createBinaryExistsCheck,\n createSpawnHealthCheck\n} from \"../utils/command-checks.js\";\nimport { type ServiceInstallDefinition } from \"../services/service-install.js\";\nimport {\n configMutation,\n fileMutation,\n templateMutation,\n type ConfigObject,\n isConfigObject\n} from \"@poe-code/config-mutations\";\nimport { createProvider } from \"./create-provider.js\";\nimport {\n DEFAULT_CODEX_MODEL,\n DEFAULT_REASONING,\n PROVIDER_NAME,\n stripModelNamespace\n} from \"../cli/constants.js\";\nimport { codexAgent } from \"@poe-code/agent-defs\";\nimport type { ActiveProvider } from \"../cli/commands/shared.js\";\n\ntype CodexConfigureContext = {\n env: CliEnvironment;\n provider: ActiveProvider;\n model: string;\n reasoningEffort: string;\n timestamp?: () => string;\n};\n\ntype CodexUnconfigureContext = {\n env: CliEnvironment;\n provider?: { id: string };\n};\n\nconst PROFILE_KEYWORDS = [\"opus\", \"sonnet\", \"haiku\", \"codex\", \"pro\"] as const;\n\nexport function deriveCodexProfileName(model: string): string {\n const stripped = stripModelNamespace(model);\n const parts = stripped.split(/[-_.]/);\n for (const keyword of PROFILE_KEYWORDS) {\n if (parts.includes(keyword)) return keyword;\n }\n return stripped;\n}\n\nfunction resolveCodexConfigModel(options: CodexConfigureContext): string {\n const model = options.model ?? DEFAULT_CODEX_MODEL;\n return options.provider?.modelInput?.kind === \"freeform\" ? model : stripModelNamespace(model);\n}\n\nexport const CODEX_INSTALL_DEFINITION: ServiceInstallDefinition = {\n id: \"codex\",\n summary: \"Codex CLI\",\n check: createBinaryExistsCheck(\n \"codex\",\n \"codex-cli-binary\",\n \"Codex CLI binary must exist\"\n ),\n steps: [\n {\n id: \"install-codex-cli-npm\",\n command: \"npm\",\n args: [\"install\", \"-g\", \"@openai/codex\"]\n }\n ],\n successMessage: \"Installed Codex CLI via npm.\"\n};\n\nfunction deriveProviderIdFromDocument(document: ConfigObject): string | undefined {\n if (typeof document[\"model_provider\"] === \"string\") {\n return document[\"model_provider\"] as string;\n }\n const profiles = document[\"profiles\"];\n if (isConfigObject(profiles)) {\n for (const name of Object.keys(profiles)) {\n const profile = profiles[name];\n if (isConfigObject(profile) && typeof profile[\"model_provider\"] === \"string\") {\n return profile[\"model_provider\"] as string;\n }\n }\n }\n const providers = document[\"model_providers\"];\n if (isConfigObject(providers)) {\n const keys = Object.keys(providers);\n if (keys.length > 0) {\n return keys[0]!;\n }\n }\n return undefined;\n}\n\nfunction stripCodexConfiguration(\n document: ConfigObject,\n providerId?: string\n): { changed: boolean; empty: boolean } {\n if (!isConfigObject(document)) {\n return { changed: false, empty: false };\n }\n\n const id = providerId ?? deriveProviderIdFromDocument(document);\n if (!id) {\n return { changed: false, empty: false };\n }\n\n let changed = false;\n\n // Handle flat (legacy) config: top-level model_provider matches provider\n if (document[\"model_provider\"] === id) {\n delete document[\"model_provider\"];\n delete document[\"model\"];\n delete document[\"model_reasoning_effort\"];\n delete document[\"model_verbosity\"];\n changed = true;\n }\n\n // Handle profile-based config\n const profiles = document[\"profiles\"];\n if (isConfigObject(profiles)) {\n for (const name of Object.keys(profiles)) {\n const profile = profiles[name];\n if (isConfigObject(profile) && profile[\"model_provider\"] === id) {\n delete profiles[name];\n changed = true;\n }\n }\n if (isTableEmpty(profiles)) {\n delete document[\"profiles\"];\n }\n }\n\n // Clean up model_providers entry for this provider\n const providers = document[\"model_providers\"];\n if (isConfigObject(providers) && id in providers) {\n delete providers[id];\n if (isTableEmpty(providers)) {\n delete document[\"model_providers\"];\n }\n changed = true;\n }\n\n return {\n changed,\n empty: isTableEmpty(document)\n };\n}\n\nfunction isTableEmpty(value: unknown): value is ConfigObject {\n return isConfigObject(value) && Object.keys(value).length === 0;\n}\n\nexport const codexService = createProvider<\n CodexConfigureContext,\n CodexUnconfigureContext\n>({\n ...codexAgent,\n supportsStdinPrompt: true,\n configurePrompts: {\n model: {\n label: \"Codex model\",\n defaultValue: DEFAULT_CODEX_MODEL\n },\n reasoningEffort: {\n label: \"Codex reasoning effort\",\n defaultValue: DEFAULT_REASONING\n }\n },\n isolatedEnv: {\n agentBinary: codexAgent.binaryName!,\n configProbe: { kind: \"isolatedFile\", relativePath: \"config.toml\" },\n env: {\n CODEX_HOME: { kind: \"isolatedDir\" },\n XDG_CONFIG_HOME: { kind: \"isolatedDir\" }\n }\n },\n test(context) {\n return context.runCheck(\n createSpawnHealthCheck(\"codex\", {\n model: context.model ?? DEFAULT_CODEX_MODEL,\n expectedOutput: \"CODEX_OK\"\n })\n );\n },\n manifest: {\n configure: [\n fileMutation.ensureDirectory({ path: \"~/.codex\" }),\n fileMutation.backup({ target: \"~/.codex/config.toml\" }),\n configMutation.transform({\n target: \"~/.codex/config.toml\",\n transform: (document, ctx) => {\n const options = ctx as unknown as CodexConfigureContext;\n const result = stripCodexConfiguration(document as ConfigObject, options.provider?.id);\n return { changed: result.changed, content: result.empty ? null : document };\n }\n }),\n templateMutation.mergeToml({\n target: \"~/.codex/config.toml\",\n templateId: \"codex/config.toml.mustache\",\n context: (ctx) => {\n const options = ctx as unknown as CodexConfigureContext;\n const model = resolveCodexConfigModel(options);\n return {\n apiKey: options.provider?.credential,\n baseUrl: options.provider?.baseUrl ?? \"\",\n model,\n providerId: options.provider?.id ?? PROVIDER_NAME,\n reasoningEffort: options.reasoningEffort,\n profileName: deriveCodexProfileName(model)\n };\n }\n })\n ],\n unconfigure: [\n configMutation.transform({\n target: \"~/.codex/config.toml\",\n transform: (document, ctx) => {\n const options = ctx as unknown as CodexUnconfigureContext;\n const result = stripCodexConfiguration(document as ConfigObject, options.provider?.id);\n if (!result.changed) {\n return { changed: false, content: document };\n }\n return {\n changed: true,\n content: result.empty ? null : document\n };\n }\n })\n ]\n },\n install: CODEX_INSTALL_DEFINITION\n});\n\nexport const provider = codexService;\n"],
5
+ "mappings": "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",
6
6
  "names": ["spawnChildProcess", "fsPromises", "path", "fsPromises", "execSync", "path", "randomBytes", "path", "resolve", "path", "cached", "randomBytes", "path", "path", "message", "error", "resolve", "path", "fs", "stat", "path", "parseDocument", "TASK_SCHEMA_ID", "path", "shellQuote", "fs", "stat", "error", "throwIfAborted", "text", "sleep", "resolve", "randomBytes", "readStream", "resolve", "remove", "error", "createAbortError", "randomBytes", "existsSync", "os", "path", "isRecord", "path", "path", "fs", "error", "path", "parseDocument", "path", "path", "text", "open", "text", "spacing", "message", "open", "frame", "close", "lookup", "spawn", "process", "AsyncLocalStorage", "parseDocument", "error", "path", "parse", "merge", "prune", "parse", "merge", "prune", "isConfigObject", "parse", "serialize", "merge", "prune", "parseYaml", "isConfigObject", "parse", "serialize", "merge", "prune", "detectFormat", "path", "path", "error", "readFileIfExists", "fs", "fs", "isConfigObject", "error", "stat", "readFileIfExists", "detectFormat", "error", "isConfigObject", "fs", "path", "error", "isRecord", "fs", "path", "isRecord", "path", "error", "message", "path", "isRecord", "path", "EMPTY_DOCUMENT", "path", "provider", "provider", "provider", "EMPTY_DOCUMENT", "os", "path", "nodeFs", "error", "fs", "path", "error", "stat", "remove", "isRecord", "path", "fs", "path", "error", "remove", "isRecord", "fs", "os", "existsSync", "createHash", "nodeFs", "path", "path", "createHash", "readFile", "path", "readFile", "cached", "error", "createHash", "path", "mkdtempSync", "rmSync", "readFile", "tmpdir", "path", "PassThrough", "Writable", "path", "JOB_DIR", "fs", "process", "shellQuote", "path", "path", "mkdtempSync", "tmpdir", "runOrThrow", "readFile", "rmSync", "shellQuote", "PassThrough", "Writable", "result", "error", "os", "nodeFs", "os", "fs", "nodeFs", "path", "e2bExecutionEnvFactory", "e2bExecutionEnvFactory", "spawnChildProcess", "resolve", "error", "spawn", "lookup", "mkdirSync", "path", "error", "throwIfAborted", "createAbortError", "error", "throwIfAborted", "sleep", "resolve", "createAbortError", "os", "os", "path", "supportedAgents", "expandHome", "os", "path", "readFile", "stat", "path", "path", "tiers", "path", "path", "path", "error", "isNodeError", "fs", "path", "isNodeError", "error", "pathExists", "isDirectory", "supportedAgents", "path", "os", "warning", "text", "error", "message", "path", "error", "message", "text", "path", "error", "error", "error", "createAbortError", "error", "resolve", "createAbortError", "error", "getDefaultArgsPosition", "getMcpArgsPosition", "getResumeArgs", "spawn", "createAbortError", "path", "mkdirSync", "path", "homedir", "open", "readdir", "spawnChildProcess", "fsPromises", "path", "homedir", "open", "runCommand", "error", "step", "formatCommand", "provider", "message", "stripModelNamespace", "stripModelNamespace", "isConfigObject"]
7
7
  }