oh-my-codex 0.16.1 → 0.16.3

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 (247) hide show
  1. package/Cargo.lock +5 -5
  2. package/Cargo.toml +1 -1
  3. package/README.md +2 -2
  4. package/dist/cli/__tests__/doctor-warning-copy.test.js +37 -1
  5. package/dist/cli/__tests__/doctor-warning-copy.test.js.map +1 -1
  6. package/dist/cli/__tests__/explore.test.js +2 -2
  7. package/dist/cli/__tests__/explore.test.js.map +1 -1
  8. package/dist/cli/__tests__/index.test.js +173 -3
  9. package/dist/cli/__tests__/index.test.js.map +1 -1
  10. package/dist/cli/__tests__/launch-fallback.test.js +58 -0
  11. package/dist/cli/__tests__/launch-fallback.test.js.map +1 -1
  12. package/dist/cli/__tests__/ralph.test.js +1 -0
  13. package/dist/cli/__tests__/ralph.test.js.map +1 -1
  14. package/dist/cli/__tests__/setup-hooks-shared-ownership.test.js +8 -0
  15. package/dist/cli/__tests__/setup-hooks-shared-ownership.test.js.map +1 -1
  16. package/dist/cli/__tests__/setup-install-mode.test.js +82 -2
  17. package/dist/cli/__tests__/setup-install-mode.test.js.map +1 -1
  18. package/dist/cli/__tests__/setup-scope.test.js +12 -0
  19. package/dist/cli/__tests__/setup-scope.test.js.map +1 -1
  20. package/dist/cli/__tests__/team.test.js +161 -0
  21. package/dist/cli/__tests__/team.test.js.map +1 -1
  22. package/dist/cli/__tests__/ultragoal.test.js +14 -9
  23. package/dist/cli/__tests__/ultragoal.test.js.map +1 -1
  24. package/dist/cli/__tests__/uninstall.test.js +44 -2
  25. package/dist/cli/__tests__/uninstall.test.js.map +1 -1
  26. package/dist/cli/__tests__/update.test.js +109 -19
  27. package/dist/cli/__tests__/update.test.js.map +1 -1
  28. package/dist/cli/doctor.d.ts.map +1 -1
  29. package/dist/cli/doctor.js +17 -0
  30. package/dist/cli/doctor.js.map +1 -1
  31. package/dist/cli/explore.d.ts.map +1 -1
  32. package/dist/cli/explore.js +3 -4
  33. package/dist/cli/explore.js.map +1 -1
  34. package/dist/cli/index.d.ts.map +1 -1
  35. package/dist/cli/index.js +34 -4
  36. package/dist/cli/index.js.map +1 -1
  37. package/dist/cli/setup.d.ts.map +1 -1
  38. package/dist/cli/setup.js +72 -6
  39. package/dist/cli/setup.js.map +1 -1
  40. package/dist/cli/team.d.ts.map +1 -1
  41. package/dist/cli/team.js +54 -15
  42. package/dist/cli/team.js.map +1 -1
  43. package/dist/cli/ultragoal.d.ts +1 -1
  44. package/dist/cli/ultragoal.d.ts.map +1 -1
  45. package/dist/cli/ultragoal.js +26 -8
  46. package/dist/cli/ultragoal.js.map +1 -1
  47. package/dist/cli/uninstall.d.ts.map +1 -1
  48. package/dist/cli/uninstall.js +68 -5
  49. package/dist/cli/uninstall.js.map +1 -1
  50. package/dist/cli/update.d.ts +10 -2
  51. package/dist/cli/update.d.ts.map +1 -1
  52. package/dist/cli/update.js +99 -5
  53. package/dist/cli/update.js.map +1 -1
  54. package/dist/config/__tests__/codex-hooks.test.js +269 -2
  55. package/dist/config/__tests__/codex-hooks.test.js.map +1 -1
  56. package/dist/config/__tests__/generator-idempotent.test.js +60 -2
  57. package/dist/config/__tests__/generator-idempotent.test.js.map +1 -1
  58. package/dist/config/__tests__/generator-notify.test.js +59 -1
  59. package/dist/config/__tests__/generator-notify.test.js.map +1 -1
  60. package/dist/config/__tests__/wiki-config-contract.test.js +2 -1
  61. package/dist/config/__tests__/wiki-config-contract.test.js.map +1 -1
  62. package/dist/config/codex-hooks.d.ts +52 -4
  63. package/dist/config/codex-hooks.d.ts.map +1 -1
  64. package/dist/config/codex-hooks.js +268 -7
  65. package/dist/config/codex-hooks.js.map +1 -1
  66. package/dist/config/generator.d.ts +13 -1
  67. package/dist/config/generator.d.ts.map +1 -1
  68. package/dist/config/generator.js +207 -12
  69. package/dist/config/generator.js.map +1 -1
  70. package/dist/hooks/__tests__/keyword-detector.test.js +37 -25
  71. package/dist/hooks/__tests__/keyword-detector.test.js.map +1 -1
  72. package/dist/hooks/__tests__/notify-fallback-watcher.test.js +29 -1
  73. package/dist/hooks/__tests__/notify-fallback-watcher.test.js.map +1 -1
  74. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js +20 -4
  75. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js.map +1 -1
  76. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js +1 -0
  77. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js.map +1 -1
  78. package/dist/hooks/__tests__/notify-hook-non-omx-guard.test.d.ts +2 -0
  79. package/dist/hooks/__tests__/notify-hook-non-omx-guard.test.d.ts.map +1 -0
  80. package/dist/hooks/__tests__/notify-hook-non-omx-guard.test.js +52 -0
  81. package/dist/hooks/__tests__/notify-hook-non-omx-guard.test.js.map +1 -0
  82. package/dist/hooks/__tests__/notify-hook-ralph-resume.test.js +148 -0
  83. package/dist/hooks/__tests__/notify-hook-ralph-resume.test.js.map +1 -1
  84. package/dist/hooks/__tests__/notify-hook-session-scope.test.js +3 -0
  85. package/dist/hooks/__tests__/notify-hook-session-scope.test.js.map +1 -1
  86. package/dist/hooks/__tests__/wiki-docs-contract.test.js +5 -4
  87. package/dist/hooks/__tests__/wiki-docs-contract.test.js.map +1 -1
  88. package/dist/hooks/keyword-detector.d.ts.map +1 -1
  89. package/dist/hooks/keyword-detector.js +2 -4
  90. package/dist/hooks/keyword-detector.js.map +1 -1
  91. package/dist/mcp/__tests__/state-server.test.js +145 -6
  92. package/dist/mcp/__tests__/state-server.test.js.map +1 -1
  93. package/dist/mcp/__tests__/wiki-server.test.js +97 -1
  94. package/dist/mcp/__tests__/wiki-server.test.js.map +1 -1
  95. package/dist/mcp/wiki-server.d.ts.map +1 -1
  96. package/dist/mcp/wiki-server.js +11 -2
  97. package/dist/mcp/wiki-server.js.map +1 -1
  98. package/dist/planning/__tests__/artifacts.test.js +64 -0
  99. package/dist/planning/__tests__/artifacts.test.js.map +1 -1
  100. package/dist/planning/__tests__/ready-context-pack-role-refs.test.d.ts +2 -0
  101. package/dist/planning/__tests__/ready-context-pack-role-refs.test.d.ts.map +1 -0
  102. package/dist/planning/__tests__/ready-context-pack-role-refs.test.js +90 -0
  103. package/dist/planning/__tests__/ready-context-pack-role-refs.test.js.map +1 -0
  104. package/dist/planning/artifacts.d.ts +7 -2
  105. package/dist/planning/artifacts.d.ts.map +1 -1
  106. package/dist/planning/artifacts.js +62 -8
  107. package/dist/planning/artifacts.js.map +1 -1
  108. package/dist/planning/context-pack-status.d.ts +6 -0
  109. package/dist/planning/context-pack-status.d.ts.map +1 -1
  110. package/dist/planning/context-pack-status.js +25 -0
  111. package/dist/planning/context-pack-status.js.map +1 -1
  112. package/dist/ralph/persistence.d.ts +1 -1
  113. package/dist/ralph/persistence.d.ts.map +1 -1
  114. package/dist/ralph/persistence.js +8 -2
  115. package/dist/ralph/persistence.js.map +1 -1
  116. package/dist/scripts/__tests__/codex-native-hook.test.js +190 -1
  117. package/dist/scripts/__tests__/codex-native-hook.test.js.map +1 -1
  118. package/dist/scripts/codex-execution-surface.d.ts +1 -1
  119. package/dist/scripts/codex-execution-surface.d.ts.map +1 -1
  120. package/dist/scripts/codex-execution-surface.js.map +1 -1
  121. package/dist/scripts/codex-native-hook.d.ts +1 -1
  122. package/dist/scripts/codex-native-hook.d.ts.map +1 -1
  123. package/dist/scripts/codex-native-hook.js +18 -3
  124. package/dist/scripts/codex-native-hook.js.map +1 -1
  125. package/dist/scripts/notify-dispatcher.d.ts +7 -0
  126. package/dist/scripts/notify-dispatcher.d.ts.map +1 -0
  127. package/dist/scripts/notify-dispatcher.js +58 -0
  128. package/dist/scripts/notify-dispatcher.js.map +1 -0
  129. package/dist/scripts/notify-fallback-watcher.js +4 -0
  130. package/dist/scripts/notify-fallback-watcher.js.map +1 -1
  131. package/dist/scripts/notify-hook/ralph-session-resume.d.ts.map +1 -1
  132. package/dist/scripts/notify-hook/ralph-session-resume.js +96 -8
  133. package/dist/scripts/notify-hook/ralph-session-resume.js.map +1 -1
  134. package/dist/scripts/notify-hook/state-io.d.ts.map +1 -1
  135. package/dist/scripts/notify-hook/state-io.js +6 -2
  136. package/dist/scripts/notify-hook/state-io.js.map +1 -1
  137. package/dist/scripts/notify-hook/visual-verdict.js +3 -3
  138. package/dist/scripts/notify-hook/visual-verdict.js.map +1 -1
  139. package/dist/scripts/notify-hook.js +124 -0
  140. package/dist/scripts/notify-hook.js.map +1 -1
  141. package/dist/state/__tests__/operations.test.js +79 -0
  142. package/dist/state/__tests__/operations.test.js.map +1 -1
  143. package/dist/state/__tests__/skill-active.test.js +10 -18
  144. package/dist/state/__tests__/skill-active.test.js.map +1 -1
  145. package/dist/state/operations.d.ts.map +1 -1
  146. package/dist/state/operations.js +1 -20
  147. package/dist/state/operations.js.map +1 -1
  148. package/dist/state/skill-active.d.ts +1 -0
  149. package/dist/state/skill-active.d.ts.map +1 -1
  150. package/dist/state/skill-active.js +28 -18
  151. package/dist/state/skill-active.js.map +1 -1
  152. package/dist/state/workflow-transition-reconcile.d.ts.map +1 -1
  153. package/dist/state/workflow-transition-reconcile.js +1 -0
  154. package/dist/state/workflow-transition-reconcile.js.map +1 -1
  155. package/dist/team/__tests__/approved-execution.test.js +45 -1
  156. package/dist/team/__tests__/approved-execution.test.js.map +1 -1
  157. package/dist/team/__tests__/runtime.test.js +173 -19
  158. package/dist/team/__tests__/runtime.test.js.map +1 -1
  159. package/dist/team/__tests__/worker-bootstrap.test.js +37 -0
  160. package/dist/team/__tests__/worker-bootstrap.test.js.map +1 -1
  161. package/dist/team/approved-execution.d.ts +1 -0
  162. package/dist/team/approved-execution.d.ts.map +1 -1
  163. package/dist/team/approved-execution.js +50 -0
  164. package/dist/team/approved-execution.js.map +1 -1
  165. package/dist/team/delivery-log.d.ts.map +1 -1
  166. package/dist/team/delivery-log.js +8 -1
  167. package/dist/team/delivery-log.js.map +1 -1
  168. package/dist/team/runtime.d.ts.map +1 -1
  169. package/dist/team/runtime.js +104 -18
  170. package/dist/team/runtime.js.map +1 -1
  171. package/dist/team/state/mailbox.d.ts +1 -0
  172. package/dist/team/state/mailbox.d.ts.map +1 -1
  173. package/dist/team/state/mailbox.js +10 -1
  174. package/dist/team/state/mailbox.js.map +1 -1
  175. package/dist/team/state-root.js +1 -1
  176. package/dist/team/state-root.js.map +1 -1
  177. package/dist/team/state.d.ts.map +1 -1
  178. package/dist/team/state.js +2 -2
  179. package/dist/team/state.js.map +1 -1
  180. package/dist/team/worker-bootstrap.d.ts +7 -2
  181. package/dist/team/worker-bootstrap.d.ts.map +1 -1
  182. package/dist/team/worker-bootstrap.js +17 -4
  183. package/dist/team/worker-bootstrap.js.map +1 -1
  184. package/dist/ultragoal/__tests__/artifacts.test.js +81 -7
  185. package/dist/ultragoal/__tests__/artifacts.test.js.map +1 -1
  186. package/dist/ultragoal/__tests__/docs-contract.test.js +8 -0
  187. package/dist/ultragoal/__tests__/docs-contract.test.js.map +1 -1
  188. package/dist/ultragoal/artifacts.d.ts +4 -0
  189. package/dist/ultragoal/artifacts.d.ts.map +1 -1
  190. package/dist/ultragoal/artifacts.js +72 -4
  191. package/dist/ultragoal/artifacts.js.map +1 -1
  192. package/dist/utils/paths.d.ts +3 -1
  193. package/dist/utils/paths.d.ts.map +1 -1
  194. package/dist/utils/paths.js +6 -2
  195. package/dist/utils/paths.js.map +1 -1
  196. package/dist/wiki/__tests__/ingest.test.js +35 -1
  197. package/dist/wiki/__tests__/ingest.test.js.map +1 -1
  198. package/dist/wiki/__tests__/lint.test.js +14 -1
  199. package/dist/wiki/__tests__/lint.test.js.map +1 -1
  200. package/dist/wiki/__tests__/query.test.js +28 -3
  201. package/dist/wiki/__tests__/query.test.js.map +1 -1
  202. package/dist/wiki/__tests__/session-hooks.test.js +30 -2
  203. package/dist/wiki/__tests__/session-hooks.test.js.map +1 -1
  204. package/dist/wiki/__tests__/storage.test.js +62 -22
  205. package/dist/wiki/__tests__/storage.test.js.map +1 -1
  206. package/dist/wiki/index.d.ts +2 -2
  207. package/dist/wiki/index.d.ts.map +1 -1
  208. package/dist/wiki/index.js +2 -2
  209. package/dist/wiki/index.js.map +1 -1
  210. package/dist/wiki/ingest.js +2 -2
  211. package/dist/wiki/ingest.js.map +1 -1
  212. package/dist/wiki/lifecycle.d.ts +5 -0
  213. package/dist/wiki/lifecycle.d.ts.map +1 -1
  214. package/dist/wiki/lifecycle.js +31 -4
  215. package/dist/wiki/lifecycle.js.map +1 -1
  216. package/dist/wiki/lint.d.ts.map +1 -1
  217. package/dist/wiki/lint.js +12 -8
  218. package/dist/wiki/lint.js.map +1 -1
  219. package/dist/wiki/query.d.ts.map +1 -1
  220. package/dist/wiki/query.js +3 -2
  221. package/dist/wiki/query.js.map +1 -1
  222. package/dist/wiki/storage.d.ts +4 -0
  223. package/dist/wiki/storage.d.ts.map +1 -1
  224. package/dist/wiki/storage.js +54 -18
  225. package/dist/wiki/storage.js.map +1 -1
  226. package/package.json +1 -1
  227. package/plugins/oh-my-codex/.codex-plugin/plugin.json +1 -1
  228. package/plugins/oh-my-codex/skills/deep-interview/SKILL.md +2 -2
  229. package/plugins/oh-my-codex/skills/plan/SKILL.md +4 -4
  230. package/plugins/oh-my-codex/skills/ralplan/SKILL.md +2 -2
  231. package/plugins/oh-my-codex/skills/ultragoal/SKILL.md +11 -7
  232. package/plugins/oh-my-codex/skills/wiki/SKILL.md +5 -5
  233. package/prompts/planner.md +1 -1
  234. package/skills/deep-interview/SKILL.md +2 -2
  235. package/skills/plan/SKILL.md +4 -4
  236. package/skills/ralplan/SKILL.md +2 -2
  237. package/skills/ultragoal/SKILL.md +11 -7
  238. package/skills/wiki/SKILL.md +5 -5
  239. package/src/scripts/__tests__/codex-native-hook.test.ts +218 -1
  240. package/src/scripts/codex-execution-surface.ts +2 -0
  241. package/src/scripts/codex-native-hook.ts +22 -3
  242. package/src/scripts/notify-dispatcher.ts +74 -0
  243. package/src/scripts/notify-fallback-watcher.ts +6 -2
  244. package/src/scripts/notify-hook/ralph-session-resume.ts +117 -8
  245. package/src/scripts/notify-hook/state-io.ts +4 -2
  246. package/src/scripts/notify-hook/visual-verdict.ts +3 -3
  247. package/src/scripts/notify-hook.ts +116 -0
package/dist/cli/index.js CHANGED
@@ -5,7 +5,7 @@
5
5
  import { execFileSync, spawn } from "child_process";
6
6
  import { basename, dirname, join, posix, win32 } from "path";
7
7
  import { existsSync, mkdirSync, readFileSync, rmSync, statSync, writeFileSync } from "fs";
8
- import { copyFile, cp, lstat, mkdir, readdir, rm, symlink } from "fs/promises";
8
+ import { copyFile, cp, lstat, mkdir, readFile, readdir, rm, symlink, writeFile } from "fs/promises";
9
9
  import { constants as osConstants, homedir } from "os";
10
10
  import { setup, SETUP_SCOPES } from "./setup.js";
11
11
  import { uninstall } from "./uninstall.js";
@@ -46,7 +46,7 @@ import { readSessionState, writeSessionStart, writeSessionEnd, resetSessionMetri
46
46
  import { buildClientAttachedReconcileHookName, buildReconcileHudResizeArgs, buildRegisterClientAttachedReconcileArgs, buildRegisterResizeHookArgs, buildResizeHookName, buildResizeHookTarget, buildScheduleDelayedHudResizeArgs, buildUnregisterClientAttachedReconcileArgs, buildUnregisterResizeHookArgs, enableMouseScrolling, isMsysOrGitBash, isNativeWindows, isTmuxAvailable, mitigateCopyModeUnderlineArtifacts, } from "../team/tmux-session.js";
47
47
  import { getPackageRoot } from "../utils/package.js";
48
48
  import { codexConfigPath, omxRoot, rememberOmxLaunchContext, resolveOmxEntryPath } from "../utils/paths.js";
49
- import { cleanCodexModelAvailabilityNuxIfNeeded, repairConfigIfNeeded } from "../config/generator.js";
49
+ import { cleanCodexModelAvailabilityNuxIfNeeded, repairConfigIfNeeded, upsertManagedCodexHookTrustState } from "../config/generator.js";
50
50
  import { HUD_TMUX_HEIGHT_LINES } from "../hud/constants.js";
51
51
  import { OMX_TMUX_HUD_OWNER_ENV } from "../hud/reconcile.js";
52
52
  import { createHudWatchPane as createSharedHudWatchPane, killTmuxPane as killSharedTmuxPane, listCurrentWindowHudPaneIds, parsePaneIdFromTmuxOutput, } from "../hud/tmux.js";
@@ -447,12 +447,20 @@ export async function prepareRuntimeCodexHomeForProjectLaunch(cwd, sessionId, pr
447
447
  continue;
448
448
  const source = join(projectCodexHome, entry.name);
449
449
  const destination = join(runtimeCodexHome, entry.name);
450
- if (entry.name === "config.toml") {
450
+ if (entry.name === "config.toml" || entry.name === "hooks.json") {
451
451
  await copyFile(source, destination);
452
452
  continue;
453
453
  }
454
454
  await linkOrCopyCodexHomeEntry(source, destination);
455
455
  }
456
+ const runtimeConfigPath = join(runtimeCodexHome, "config.toml");
457
+ const runtimeHooksPath = join(runtimeCodexHome, "hooks.json");
458
+ if (existsSync(runtimeConfigPath) && existsSync(runtimeHooksPath)) {
459
+ const runtimeConfig = await readFile(runtimeConfigPath, "utf-8");
460
+ if (runtimeConfig.includes("# OMX-owned Codex hook trust state")) {
461
+ await writeFile(runtimeConfigPath, upsertManagedCodexHookTrustState(runtimeConfig, getPackageRoot(), runtimeHooksPath), "utf-8");
462
+ }
463
+ }
456
464
  return runtimeCodexHome;
457
465
  }
458
466
  function resolveProjectSqliteHomeForLaunch(projectCodexHome, env) {
@@ -658,6 +666,9 @@ function runCodexBlocking(cwd, launchArgs, codexEnv) {
658
666
  if (result.signal) {
659
667
  console.error(`[omx] codex exited due to signal ${result.signal}`);
660
668
  }
669
+ else if (typeof result.status === "number") {
670
+ console.error(`[omx] codex exited with code ${result.status}`);
671
+ }
661
672
  }
662
673
  }
663
674
  export function buildHudPaneCleanupTargets(existingPaneIds, createdPaneId, leaderPaneId) {
@@ -1759,15 +1770,30 @@ function buildDetachedSessionLeaderCommand(cwd, sessionName, codexCmd, sessionId
1759
1770
  'exec 3<&- 2>/dev/null || true;',
1760
1771
  buildTmuxExtendedKeysReleaseShellSnippet(cwd),
1761
1772
  detachedPostLaunchHelper,
1762
- 'if [ "$status" -lt 128 ]; then',
1773
+ 'if [ "$status" -eq 0 ]; then',
1763
1774
  `tmux kill-session -t "${escapeShellDoubleQuotedValue(sessionName)}" >/dev/null 2>&1 || true;`,
1764
1775
  "fi;",
1765
1776
  "exit $status;",
1766
1777
  "};",
1767
1778
  "trap omx_detached_session_cleanup 0 INT TERM HUP;",
1779
+ "omx_codex_started_at=$(date +%s 2>/dev/null || printf 0);",
1768
1780
  `${codexCmd} <&3 &`,
1769
1781
  "omx_codex_pid=$!;",
1770
1782
  'wait "$omx_codex_pid";',
1783
+ "omx_codex_status=$?;",
1784
+ "omx_codex_finished_at=$(date +%s 2>/dev/null || printf 0);",
1785
+ 'omx_codex_elapsed=$((omx_codex_finished_at - omx_codex_started_at));',
1786
+ 'if [ "$omx_codex_status" -eq 0 ] && [ "$omx_codex_elapsed" -le 2 ]; then',
1787
+ 'printf "\\n[omx] codex exited immediately with code 0 during startup. The detached tmux session is being kept open so any output above remains visible. Press Enter to close this OMX session.\\n" >&2;',
1788
+ 'IFS= read -r _omx_close || true;',
1789
+ 'elif [ "$omx_codex_status" -gt 0 ] && [ "$omx_codex_status" -lt 128 ] && [ "$omx_codex_elapsed" -le 2 ]; then',
1790
+ 'printf "\\n[omx] codex exited with code %s during startup. The detached tmux session is being kept open so the error above remains visible. Press Enter to close this OMX session.\\n" "$omx_codex_status" >&2;',
1791
+ 'IFS= read -r _omx_close || true;',
1792
+ 'elif [ "$omx_codex_status" -gt 0 ] && [ "$omx_codex_status" -lt 128 ]; then',
1793
+ 'printf "\\n[omx] codex exited with code %s. The detached tmux session is being kept open so the error above remains visible. Press Enter to close this OMX session.\\n" "$omx_codex_status" >&2;',
1794
+ 'IFS= read -r _omx_close || true;',
1795
+ "fi;",
1796
+ 'exit "$omx_codex_status";',
1771
1797
  ].join(" ");
1772
1798
  return `/bin/sh -c ${quoteShellArg(wrapped)}`;
1773
1799
  }
@@ -2265,6 +2291,10 @@ export async function cleanupPostLaunchModeStateFiles(cwd, sessionId, dependenci
2265
2291
  result.state.active = false;
2266
2292
  result.state.current_phase = "cancelled";
2267
2293
  result.state.completed_at = completedAt;
2294
+ if (mode === "ralph") {
2295
+ result.state.interrupted_at = completedAt;
2296
+ result.state.stop_reason = cleanPostLaunchString(result.state.stop_reason) || "session_exit";
2297
+ }
2268
2298
  await writeFile(path, JSON.stringify(result.state, null, 2));
2269
2299
  if (isTrackedWorkflowMode(mode)) {
2270
2300
  await syncCanonicalSkillStateForMode({