@jstn-sdk/rcs 0.1.0

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 (2781) hide show
  1. package/.agents/plugins/marketplace.json +20 -0
  2. package/Cargo.lock +174 -0
  3. package/Cargo.toml +23 -0
  4. package/README.md +403 -0
  5. package/crates/rcs-explore/Cargo.toml +11 -0
  6. package/crates/rcs-explore/src/main.rs +2061 -0
  7. package/crates/rcs-mux/Cargo.toml +11 -0
  8. package/crates/rcs-mux/src/lib.rs +91 -0
  9. package/crates/rcs-mux/src/tmux.rs +282 -0
  10. package/crates/rcs-mux/src/types.rs +306 -0
  11. package/crates/rcs-runtime/Cargo.toml +17 -0
  12. package/crates/rcs-runtime/src/main.rs +125 -0
  13. package/crates/rcs-runtime/tests/execution.rs +212 -0
  14. package/crates/rcs-runtime-core/Cargo.toml +13 -0
  15. package/crates/rcs-runtime-core/src/authority.rs +239 -0
  16. package/crates/rcs-runtime-core/src/dispatch.rs +330 -0
  17. package/crates/rcs-runtime-core/src/engine.rs +853 -0
  18. package/crates/rcs-runtime-core/src/lib.rs +653 -0
  19. package/crates/rcs-runtime-core/src/mailbox.rs +261 -0
  20. package/crates/rcs-runtime-core/src/replay.rs +104 -0
  21. package/crates/rcs-sparkshell/Cargo.lock +7 -0
  22. package/crates/rcs-sparkshell/Cargo.toml +14 -0
  23. package/crates/rcs-sparkshell/src/codex_bridge.rs +454 -0
  24. package/crates/rcs-sparkshell/src/error.rs +45 -0
  25. package/crates/rcs-sparkshell/src/exec.rs +115 -0
  26. package/crates/rcs-sparkshell/src/main.rs +334 -0
  27. package/crates/rcs-sparkshell/src/prompt.rs +342 -0
  28. package/crates/rcs-sparkshell/src/registry/c_cpp.rs +9 -0
  29. package/crates/rcs-sparkshell/src/registry/csharp.rs +10 -0
  30. package/crates/rcs-sparkshell/src/registry/generic_shell.rs +11 -0
  31. package/crates/rcs-sparkshell/src/registry/git.rs +10 -0
  32. package/crates/rcs-sparkshell/src/registry/go.rs +9 -0
  33. package/crates/rcs-sparkshell/src/registry/java_kotlin.rs +9 -0
  34. package/crates/rcs-sparkshell/src/registry/mod.rs +85 -0
  35. package/crates/rcs-sparkshell/src/registry/node_js.rs +9 -0
  36. package/crates/rcs-sparkshell/src/registry/python.rs +9 -0
  37. package/crates/rcs-sparkshell/src/registry/ruby.rs +9 -0
  38. package/crates/rcs-sparkshell/src/registry/rust.rs +9 -0
  39. package/crates/rcs-sparkshell/src/registry/swift.rs +10 -0
  40. package/crates/rcs-sparkshell/src/test_support.rs +10 -0
  41. package/crates/rcs-sparkshell/src/threshold.rs +75 -0
  42. package/crates/rcs-sparkshell/tests/execution.rs +521 -0
  43. package/crates/rcs-sparkshell/tests/registry.rs +99 -0
  44. package/dist/adapt/__tests__/foundation.test.d.ts +2 -0
  45. package/dist/adapt/__tests__/foundation.test.d.ts.map +1 -0
  46. package/dist/adapt/__tests__/foundation.test.js +171 -0
  47. package/dist/adapt/__tests__/foundation.test.js.map +1 -0
  48. package/dist/adapt/__tests__/hermes.test.d.ts +2 -0
  49. package/dist/adapt/__tests__/hermes.test.d.ts.map +1 -0
  50. package/dist/adapt/__tests__/hermes.test.js +137 -0
  51. package/dist/adapt/__tests__/hermes.test.js.map +1 -0
  52. package/dist/adapt/contracts.d.ts +157 -0
  53. package/dist/adapt/contracts.d.ts.map +1 -0
  54. package/dist/adapt/contracts.js +10 -0
  55. package/dist/adapt/contracts.js.map +1 -0
  56. package/dist/adapt/hermes.d.ts +83 -0
  57. package/dist/adapt/hermes.d.ts.map +1 -0
  58. package/dist/adapt/hermes.js +371 -0
  59. package/dist/adapt/hermes.js.map +1 -0
  60. package/dist/adapt/index.d.ts +14 -0
  61. package/dist/adapt/index.d.ts.map +1 -0
  62. package/dist/adapt/index.js +293 -0
  63. package/dist/adapt/index.js.map +1 -0
  64. package/dist/adapt/openclaw.d.ts +7 -0
  65. package/dist/adapt/openclaw.d.ts.map +1 -0
  66. package/dist/adapt/openclaw.js +299 -0
  67. package/dist/adapt/openclaw.js.map +1 -0
  68. package/dist/adapt/paths.d.ts +3 -0
  69. package/dist/adapt/paths.d.ts.map +1 -0
  70. package/dist/adapt/paths.js +15 -0
  71. package/dist/adapt/paths.js.map +1 -0
  72. package/dist/adapt/registry.d.ts +4 -0
  73. package/dist/adapt/registry.d.ts.map +1 -0
  74. package/dist/adapt/registry.js +48 -0
  75. package/dist/adapt/registry.js.map +1 -0
  76. package/dist/agents/__tests__/definitions.test.d.ts +2 -0
  77. package/dist/agents/__tests__/definitions.test.d.ts.map +1 -0
  78. package/dist/agents/__tests__/definitions.test.js +62 -0
  79. package/dist/agents/__tests__/definitions.test.js.map +1 -0
  80. package/dist/agents/__tests__/native-config.test.d.ts +2 -0
  81. package/dist/agents/__tests__/native-config.test.d.ts.map +1 -0
  82. package/dist/agents/__tests__/native-config.test.js +278 -0
  83. package/dist/agents/__tests__/native-config.test.js.map +1 -0
  84. package/dist/agents/definitions.d.ts +25 -0
  85. package/dist/agents/definitions.d.ts.map +1 -0
  86. package/dist/agents/definitions.js +327 -0
  87. package/dist/agents/definitions.js.map +1 -0
  88. package/dist/agents/native-config.d.ts +51 -0
  89. package/dist/agents/native-config.d.ts.map +1 -0
  90. package/dist/agents/native-config.js +265 -0
  91. package/dist/agents/native-config.js.map +1 -0
  92. package/dist/agents/policy.d.ts +10 -0
  93. package/dist/agents/policy.d.ts.map +1 -0
  94. package/dist/agents/policy.js +61 -0
  95. package/dist/agents/policy.js.map +1 -0
  96. package/dist/autoresearch/__tests__/contracts.test.d.ts +2 -0
  97. package/dist/autoresearch/__tests__/contracts.test.d.ts.map +1 -0
  98. package/dist/autoresearch/__tests__/contracts.test.js +127 -0
  99. package/dist/autoresearch/__tests__/contracts.test.js.map +1 -0
  100. package/dist/autoresearch/__tests__/runtime-parity-extra.test.d.ts +2 -0
  101. package/dist/autoresearch/__tests__/runtime-parity-extra.test.d.ts.map +1 -0
  102. package/dist/autoresearch/__tests__/runtime-parity-extra.test.js +356 -0
  103. package/dist/autoresearch/__tests__/runtime-parity-extra.test.js.map +1 -0
  104. package/dist/autoresearch/__tests__/runtime.test.d.ts +2 -0
  105. package/dist/autoresearch/__tests__/runtime.test.d.ts.map +1 -0
  106. package/dist/autoresearch/__tests__/runtime.test.js +218 -0
  107. package/dist/autoresearch/__tests__/runtime.test.js.map +1 -0
  108. package/dist/autoresearch/__tests__/skill-validation.test.d.ts +2 -0
  109. package/dist/autoresearch/__tests__/skill-validation.test.d.ts.map +1 -0
  110. package/dist/autoresearch/__tests__/skill-validation.test.js +91 -0
  111. package/dist/autoresearch/__tests__/skill-validation.test.js.map +1 -0
  112. package/dist/autoresearch/contracts.d.ts +31 -0
  113. package/dist/autoresearch/contracts.d.ts.map +1 -0
  114. package/dist/autoresearch/contracts.js +197 -0
  115. package/dist/autoresearch/contracts.js.map +1 -0
  116. package/dist/autoresearch/runtime.d.ts +132 -0
  117. package/dist/autoresearch/runtime.d.ts.map +1 -0
  118. package/dist/autoresearch/runtime.js +1075 -0
  119. package/dist/autoresearch/runtime.js.map +1 -0
  120. package/dist/autoresearch/skill-validation.d.ts +13 -0
  121. package/dist/autoresearch/skill-validation.d.ts.map +1 -0
  122. package/dist/autoresearch/skill-validation.js +165 -0
  123. package/dist/autoresearch/skill-validation.js.map +1 -0
  124. package/dist/catalog/__tests__/generator.test.d.ts +2 -0
  125. package/dist/catalog/__tests__/generator.test.d.ts.map +1 -0
  126. package/dist/catalog/__tests__/generator.test.js +49 -0
  127. package/dist/catalog/__tests__/generator.test.js.map +1 -0
  128. package/dist/catalog/__tests__/plugin-bundle-ssot.test.d.ts +2 -0
  129. package/dist/catalog/__tests__/plugin-bundle-ssot.test.d.ts.map +1 -0
  130. package/dist/catalog/__tests__/plugin-bundle-ssot.test.js +83 -0
  131. package/dist/catalog/__tests__/plugin-bundle-ssot.test.js.map +1 -0
  132. package/dist/catalog/__tests__/schema.test.d.ts +2 -0
  133. package/dist/catalog/__tests__/schema.test.d.ts.map +1 -0
  134. package/dist/catalog/__tests__/schema.test.js +91 -0
  135. package/dist/catalog/__tests__/schema.test.js.map +1 -0
  136. package/dist/catalog/installable.d.ts +5 -0
  137. package/dist/catalog/installable.d.ts.map +1 -0
  138. package/dist/catalog/installable.js +13 -0
  139. package/dist/catalog/installable.js.map +1 -0
  140. package/dist/catalog/reader.d.ts +19 -0
  141. package/dist/catalog/reader.d.ts.map +1 -0
  142. package/dist/catalog/reader.js +63 -0
  143. package/dist/catalog/reader.js.map +1 -0
  144. package/dist/catalog/schema.d.ts +32 -0
  145. package/dist/catalog/schema.d.ts.map +1 -0
  146. package/dist/catalog/schema.js +107 -0
  147. package/dist/catalog/schema.js.map +1 -0
  148. package/dist/catalog/skill-mirror.d.ts +20 -0
  149. package/dist/catalog/skill-mirror.d.ts.map +1 -0
  150. package/dist/catalog/skill-mirror.js +104 -0
  151. package/dist/catalog/skill-mirror.js.map +1 -0
  152. package/dist/cli/__tests__/adapt-help.test.d.ts +2 -0
  153. package/dist/cli/__tests__/adapt-help.test.d.ts.map +1 -0
  154. package/dist/cli/__tests__/adapt-help.test.js +37 -0
  155. package/dist/cli/__tests__/adapt-help.test.js.map +1 -0
  156. package/dist/cli/__tests__/adapt.test.d.ts +2 -0
  157. package/dist/cli/__tests__/adapt.test.d.ts.map +1 -0
  158. package/dist/cli/__tests__/adapt.test.js +62 -0
  159. package/dist/cli/__tests__/adapt.test.js.map +1 -0
  160. package/dist/cli/__tests__/agents-init.test.d.ts +2 -0
  161. package/dist/cli/__tests__/agents-init.test.d.ts.map +1 -0
  162. package/dist/cli/__tests__/agents-init.test.js +184 -0
  163. package/dist/cli/__tests__/agents-init.test.js.map +1 -0
  164. package/dist/cli/__tests__/agents.test.d.ts +2 -0
  165. package/dist/cli/__tests__/agents.test.d.ts.map +1 -0
  166. package/dist/cli/__tests__/agents.test.js +137 -0
  167. package/dist/cli/__tests__/agents.test.js.map +1 -0
  168. package/dist/cli/__tests__/ask.test.d.ts +2 -0
  169. package/dist/cli/__tests__/ask.test.d.ts.map +1 -0
  170. package/dist/cli/__tests__/ask.test.js +265 -0
  171. package/dist/cli/__tests__/ask.test.js.map +1 -0
  172. package/dist/cli/__tests__/autoresearch-guided.test.d.ts +2 -0
  173. package/dist/cli/__tests__/autoresearch-guided.test.d.ts.map +1 -0
  174. package/dist/cli/__tests__/autoresearch-guided.test.js +365 -0
  175. package/dist/cli/__tests__/autoresearch-guided.test.js.map +1 -0
  176. package/dist/cli/__tests__/autoresearch.test.d.ts +2 -0
  177. package/dist/cli/__tests__/autoresearch.test.d.ts.map +1 -0
  178. package/dist/cli/__tests__/autoresearch.test.js +203 -0
  179. package/dist/cli/__tests__/autoresearch.test.js.map +1 -0
  180. package/dist/cli/__tests__/catalog-contract.test.d.ts +2 -0
  181. package/dist/cli/__tests__/catalog-contract.test.d.ts.map +1 -0
  182. package/dist/cli/__tests__/catalog-contract.test.js +18 -0
  183. package/dist/cli/__tests__/catalog-contract.test.js.map +1 -0
  184. package/dist/cli/__tests__/cleanup.test.d.ts +2 -0
  185. package/dist/cli/__tests__/cleanup.test.d.ts.map +1 -0
  186. package/dist/cli/__tests__/cleanup.test.js +419 -0
  187. package/dist/cli/__tests__/cleanup.test.js.map +1 -0
  188. package/dist/cli/__tests__/codex-plugin-layout.test.d.ts +2 -0
  189. package/dist/cli/__tests__/codex-plugin-layout.test.d.ts.map +1 -0
  190. package/dist/cli/__tests__/codex-plugin-layout.test.js +210 -0
  191. package/dist/cli/__tests__/codex-plugin-layout.test.js.map +1 -0
  192. package/dist/cli/__tests__/doctor-context-window-warning.test.d.ts +2 -0
  193. package/dist/cli/__tests__/doctor-context-window-warning.test.d.ts.map +1 -0
  194. package/dist/cli/__tests__/doctor-context-window-warning.test.js +122 -0
  195. package/dist/cli/__tests__/doctor-context-window-warning.test.js.map +1 -0
  196. package/dist/cli/__tests__/doctor-invalid-config.test.d.ts +2 -0
  197. package/dist/cli/__tests__/doctor-invalid-config.test.d.ts.map +1 -0
  198. package/dist/cli/__tests__/doctor-invalid-config.test.js +52 -0
  199. package/dist/cli/__tests__/doctor-invalid-config.test.js.map +1 -0
  200. package/dist/cli/__tests__/doctor-team.test.d.ts +2 -0
  201. package/dist/cli/__tests__/doctor-team.test.d.ts.map +1 -0
  202. package/dist/cli/__tests__/doctor-team.test.js +299 -0
  203. package/dist/cli/__tests__/doctor-team.test.js.map +1 -0
  204. package/dist/cli/__tests__/doctor-warning-copy.test.d.ts +2 -0
  205. package/dist/cli/__tests__/doctor-warning-copy.test.d.ts.map +1 -0
  206. package/dist/cli/__tests__/doctor-warning-copy.test.js +438 -0
  207. package/dist/cli/__tests__/doctor-warning-copy.test.js.map +1 -0
  208. package/dist/cli/__tests__/error-handling-warnings.test.d.ts +2 -0
  209. package/dist/cli/__tests__/error-handling-warnings.test.d.ts.map +1 -0
  210. package/dist/cli/__tests__/error-handling-warnings.test.js +52 -0
  211. package/dist/cli/__tests__/error-handling-warnings.test.js.map +1 -0
  212. package/dist/cli/__tests__/exec.test.d.ts +2 -0
  213. package/dist/cli/__tests__/exec.test.d.ts.map +1 -0
  214. package/dist/cli/__tests__/exec.test.js +213 -0
  215. package/dist/cli/__tests__/exec.test.js.map +1 -0
  216. package/dist/cli/__tests__/explore-windows-diagnostics.test.d.ts +2 -0
  217. package/dist/cli/__tests__/explore-windows-diagnostics.test.d.ts.map +1 -0
  218. package/dist/cli/__tests__/explore-windows-diagnostics.test.js +17 -0
  219. package/dist/cli/__tests__/explore-windows-diagnostics.test.js.map +1 -0
  220. package/dist/cli/__tests__/explore.test.d.ts +2 -0
  221. package/dist/cli/__tests__/explore.test.d.ts.map +1 -0
  222. package/dist/cli/__tests__/explore.test.js +1090 -0
  223. package/dist/cli/__tests__/explore.test.js.map +1 -0
  224. package/dist/cli/__tests__/hooks.test.d.ts +2 -0
  225. package/dist/cli/__tests__/hooks.test.d.ts.map +1 -0
  226. package/dist/cli/__tests__/hooks.test.js +55 -0
  227. package/dist/cli/__tests__/hooks.test.js.map +1 -0
  228. package/dist/cli/__tests__/index.test.d.ts +2 -0
  229. package/dist/cli/__tests__/index.test.d.ts.map +1 -0
  230. package/dist/cli/__tests__/index.test.js +2259 -0
  231. package/dist/cli/__tests__/index.test.js.map +1 -0
  232. package/dist/cli/__tests__/launch-fallback.test.d.ts +2 -0
  233. package/dist/cli/__tests__/launch-fallback.test.d.ts.map +1 -0
  234. package/dist/cli/__tests__/launch-fallback.test.js +661 -0
  235. package/dist/cli/__tests__/launch-fallback.test.js.map +1 -0
  236. package/dist/cli/__tests__/lifecycle-notifications.test.d.ts +2 -0
  237. package/dist/cli/__tests__/lifecycle-notifications.test.d.ts.map +1 -0
  238. package/dist/cli/__tests__/lifecycle-notifications.test.js +48 -0
  239. package/dist/cli/__tests__/lifecycle-notifications.test.js.map +1 -0
  240. package/dist/cli/__tests__/list.test.d.ts +2 -0
  241. package/dist/cli/__tests__/list.test.d.ts.map +1 -0
  242. package/dist/cli/__tests__/list.test.js +38 -0
  243. package/dist/cli/__tests__/list.test.js.map +1 -0
  244. package/dist/cli/__tests__/mcp-parity.test.d.ts +2 -0
  245. package/dist/cli/__tests__/mcp-parity.test.d.ts.map +1 -0
  246. package/dist/cli/__tests__/mcp-parity.test.js +228 -0
  247. package/dist/cli/__tests__/mcp-parity.test.js.map +1 -0
  248. package/dist/cli/__tests__/mcp-serve.test.d.ts +2 -0
  249. package/dist/cli/__tests__/mcp-serve.test.d.ts.map +1 -0
  250. package/dist/cli/__tests__/mcp-serve.test.js +64 -0
  251. package/dist/cli/__tests__/mcp-serve.test.js.map +1 -0
  252. package/dist/cli/__tests__/native-assets.test.d.ts +2 -0
  253. package/dist/cli/__tests__/native-assets.test.d.ts.map +1 -0
  254. package/dist/cli/__tests__/native-assets.test.js +308 -0
  255. package/dist/cli/__tests__/native-assets.test.js.map +1 -0
  256. package/dist/cli/__tests__/native-hook-dispatch-contract.test.d.ts +2 -0
  257. package/dist/cli/__tests__/native-hook-dispatch-contract.test.d.ts.map +1 -0
  258. package/dist/cli/__tests__/native-hook-dispatch-contract.test.js +11 -0
  259. package/dist/cli/__tests__/native-hook-dispatch-contract.test.js.map +1 -0
  260. package/dist/cli/__tests__/nested-help-routing.test.d.ts +2 -0
  261. package/dist/cli/__tests__/nested-help-routing.test.d.ts.map +1 -0
  262. package/dist/cli/__tests__/nested-help-routing.test.js +96 -0
  263. package/dist/cli/__tests__/nested-help-routing.test.js.map +1 -0
  264. package/dist/cli/__tests__/package-bin-contract.test.d.ts +2 -0
  265. package/dist/cli/__tests__/package-bin-contract.test.d.ts.map +1 -0
  266. package/dist/cli/__tests__/package-bin-contract.test.js +177 -0
  267. package/dist/cli/__tests__/package-bin-contract.test.js.map +1 -0
  268. package/dist/cli/__tests__/packaged-explore-harness-lock.d.ts +3 -0
  269. package/dist/cli/__tests__/packaged-explore-harness-lock.d.ts.map +1 -0
  270. package/dist/cli/__tests__/packaged-explore-harness-lock.js +67 -0
  271. package/dist/cli/__tests__/packaged-explore-harness-lock.js.map +1 -0
  272. package/dist/cli/__tests__/packaged-script-resolution.test.d.ts +2 -0
  273. package/dist/cli/__tests__/packaged-script-resolution.test.d.ts.map +1 -0
  274. package/dist/cli/__tests__/packaged-script-resolution.test.js +19 -0
  275. package/dist/cli/__tests__/packaged-script-resolution.test.js.map +1 -0
  276. package/dist/cli/__tests__/prompt-skill-sanitization.test.d.ts +2 -0
  277. package/dist/cli/__tests__/prompt-skill-sanitization.test.d.ts.map +1 -0
  278. package/dist/cli/__tests__/prompt-skill-sanitization.test.js +48 -0
  279. package/dist/cli/__tests__/prompt-skill-sanitization.test.js.map +1 -0
  280. package/dist/cli/__tests__/question.test.d.ts +2 -0
  281. package/dist/cli/__tests__/question.test.d.ts.map +1 -0
  282. package/dist/cli/__tests__/question.test.js +633 -0
  283. package/dist/cli/__tests__/question.test.js.map +1 -0
  284. package/dist/cli/__tests__/ralph-deslop-contract.test.d.ts +2 -0
  285. package/dist/cli/__tests__/ralph-deslop-contract.test.d.ts.map +1 -0
  286. package/dist/cli/__tests__/ralph-deslop-contract.test.js +28 -0
  287. package/dist/cli/__tests__/ralph-deslop-contract.test.js.map +1 -0
  288. package/dist/cli/__tests__/ralph-prd-deep-interview.test.d.ts +2 -0
  289. package/dist/cli/__tests__/ralph-prd-deep-interview.test.d.ts.map +1 -0
  290. package/dist/cli/__tests__/ralph-prd-deep-interview.test.js +24 -0
  291. package/dist/cli/__tests__/ralph-prd-deep-interview.test.js.map +1 -0
  292. package/dist/cli/__tests__/ralph-prd-smoke.test.d.ts +2 -0
  293. package/dist/cli/__tests__/ralph-prd-smoke.test.d.ts.map +1 -0
  294. package/dist/cli/__tests__/ralph-prd-smoke.test.js +167 -0
  295. package/dist/cli/__tests__/ralph-prd-smoke.test.js.map +1 -0
  296. package/dist/cli/__tests__/ralph.test.d.ts +2 -0
  297. package/dist/cli/__tests__/ralph.test.d.ts.map +1 -0
  298. package/dist/cli/__tests__/ralph.test.js +256 -0
  299. package/dist/cli/__tests__/ralph.test.js.map +1 -0
  300. package/dist/cli/__tests__/resume.test.d.ts +2 -0
  301. package/dist/cli/__tests__/resume.test.d.ts.map +1 -0
  302. package/dist/cli/__tests__/resume.test.js +84 -0
  303. package/dist/cli/__tests__/resume.test.js.map +1 -0
  304. package/dist/cli/__tests__/session-scoped-runtime.test.d.ts +2 -0
  305. package/dist/cli/__tests__/session-scoped-runtime.test.d.ts.map +1 -0
  306. package/dist/cli/__tests__/session-scoped-runtime.test.js +146 -0
  307. package/dist/cli/__tests__/session-scoped-runtime.test.js.map +1 -0
  308. package/dist/cli/__tests__/session-search-help.test.d.ts +2 -0
  309. package/dist/cli/__tests__/session-search-help.test.d.ts.map +1 -0
  310. package/dist/cli/__tests__/session-search-help.test.js +76 -0
  311. package/dist/cli/__tests__/session-search-help.test.js.map +1 -0
  312. package/dist/cli/__tests__/session-search.test.d.ts +2 -0
  313. package/dist/cli/__tests__/session-search.test.d.ts.map +1 -0
  314. package/dist/cli/__tests__/session-search.test.js +77 -0
  315. package/dist/cli/__tests__/session-search.test.js.map +1 -0
  316. package/dist/cli/__tests__/setup-agents-overwrite.test.d.ts +2 -0
  317. package/dist/cli/__tests__/setup-agents-overwrite.test.d.ts.map +1 -0
  318. package/dist/cli/__tests__/setup-agents-overwrite.test.js +457 -0
  319. package/dist/cli/__tests__/setup-agents-overwrite.test.js.map +1 -0
  320. package/dist/cli/__tests__/setup-gh-star.test.d.ts +2 -0
  321. package/dist/cli/__tests__/setup-gh-star.test.d.ts.map +1 -0
  322. package/dist/cli/__tests__/setup-gh-star.test.js +67 -0
  323. package/dist/cli/__tests__/setup-gh-star.test.js.map +1 -0
  324. package/dist/cli/__tests__/setup-hooks-shared-ownership.test.d.ts +2 -0
  325. package/dist/cli/__tests__/setup-hooks-shared-ownership.test.d.ts.map +1 -0
  326. package/dist/cli/__tests__/setup-hooks-shared-ownership.test.js +189 -0
  327. package/dist/cli/__tests__/setup-hooks-shared-ownership.test.js.map +1 -0
  328. package/dist/cli/__tests__/setup-install-mode.test.d.ts +2 -0
  329. package/dist/cli/__tests__/setup-install-mode.test.d.ts.map +1 -0
  330. package/dist/cli/__tests__/setup-install-mode.test.js +873 -0
  331. package/dist/cli/__tests__/setup-install-mode.test.js.map +1 -0
  332. package/dist/cli/__tests__/setup-prompts-overwrite.test.d.ts +2 -0
  333. package/dist/cli/__tests__/setup-prompts-overwrite.test.d.ts.map +1 -0
  334. package/dist/cli/__tests__/setup-prompts-overwrite.test.js +191 -0
  335. package/dist/cli/__tests__/setup-prompts-overwrite.test.js.map +1 -0
  336. package/dist/cli/__tests__/setup-refresh.test.d.ts +2 -0
  337. package/dist/cli/__tests__/setup-refresh.test.d.ts.map +1 -0
  338. package/dist/cli/__tests__/setup-refresh.test.js +591 -0
  339. package/dist/cli/__tests__/setup-refresh.test.js.map +1 -0
  340. package/dist/cli/__tests__/setup-scope.test.d.ts +2 -0
  341. package/dist/cli/__tests__/setup-scope.test.d.ts.map +1 -0
  342. package/dist/cli/__tests__/setup-scope.test.js +340 -0
  343. package/dist/cli/__tests__/setup-scope.test.js.map +1 -0
  344. package/dist/cli/__tests__/setup-skill-validation.test.d.ts +2 -0
  345. package/dist/cli/__tests__/setup-skill-validation.test.d.ts.map +1 -0
  346. package/dist/cli/__tests__/setup-skill-validation.test.js +44 -0
  347. package/dist/cli/__tests__/setup-skill-validation.test.js.map +1 -0
  348. package/dist/cli/__tests__/setup-skills-overwrite.test.d.ts +2 -0
  349. package/dist/cli/__tests__/setup-skills-overwrite.test.d.ts.map +1 -0
  350. package/dist/cli/__tests__/setup-skills-overwrite.test.js +295 -0
  351. package/dist/cli/__tests__/setup-skills-overwrite.test.js.map +1 -0
  352. package/dist/cli/__tests__/sidecar.test.d.ts +2 -0
  353. package/dist/cli/__tests__/sidecar.test.d.ts.map +1 -0
  354. package/dist/cli/__tests__/sidecar.test.js +24 -0
  355. package/dist/cli/__tests__/sidecar.test.js.map +1 -0
  356. package/dist/cli/__tests__/sparkshell-cli.test.d.ts +2 -0
  357. package/dist/cli/__tests__/sparkshell-cli.test.d.ts.map +1 -0
  358. package/dist/cli/__tests__/sparkshell-cli.test.js +400 -0
  359. package/dist/cli/__tests__/sparkshell-cli.test.js.map +1 -0
  360. package/dist/cli/__tests__/sparkshell-packaging.test.d.ts +2 -0
  361. package/dist/cli/__tests__/sparkshell-packaging.test.d.ts.map +1 -0
  362. package/dist/cli/__tests__/sparkshell-packaging.test.js +74 -0
  363. package/dist/cli/__tests__/sparkshell-packaging.test.js.map +1 -0
  364. package/dist/cli/__tests__/star-prompt.test.d.ts +2 -0
  365. package/dist/cli/__tests__/star-prompt.test.d.ts.map +1 -0
  366. package/dist/cli/__tests__/star-prompt.test.js +172 -0
  367. package/dist/cli/__tests__/star-prompt.test.js.map +1 -0
  368. package/dist/cli/__tests__/state.test.d.ts +2 -0
  369. package/dist/cli/__tests__/state.test.d.ts.map +1 -0
  370. package/dist/cli/__tests__/state.test.js +46 -0
  371. package/dist/cli/__tests__/state.test.js.map +1 -0
  372. package/dist/cli/__tests__/team-decompose.test.d.ts +2 -0
  373. package/dist/cli/__tests__/team-decompose.test.d.ts.map +1 -0
  374. package/dist/cli/__tests__/team-decompose.test.js +133 -0
  375. package/dist/cli/__tests__/team-decompose.test.js.map +1 -0
  376. package/dist/cli/__tests__/team.test.d.ts +2 -0
  377. package/dist/cli/__tests__/team.test.d.ts.map +1 -0
  378. package/dist/cli/__tests__/team.test.js +1820 -0
  379. package/dist/cli/__tests__/team.test.js.map +1 -0
  380. package/dist/cli/__tests__/uninstall.test.d.ts +2 -0
  381. package/dist/cli/__tests__/uninstall.test.d.ts.map +1 -0
  382. package/dist/cli/__tests__/uninstall.test.js +766 -0
  383. package/dist/cli/__tests__/uninstall.test.js.map +1 -0
  384. package/dist/cli/__tests__/update.test.d.ts +2 -0
  385. package/dist/cli/__tests__/update.test.d.ts.map +1 -0
  386. package/dist/cli/__tests__/update.test.js +589 -0
  387. package/dist/cli/__tests__/update.test.js.map +1 -0
  388. package/dist/cli/__tests__/version-sync-contract.test.d.ts +2 -0
  389. package/dist/cli/__tests__/version-sync-contract.test.d.ts.map +1 -0
  390. package/dist/cli/__tests__/version-sync-contract.test.js +41 -0
  391. package/dist/cli/__tests__/version-sync-contract.test.js.map +1 -0
  392. package/dist/cli/__tests__/version.test.d.ts +2 -0
  393. package/dist/cli/__tests__/version.test.d.ts.map +1 -0
  394. package/dist/cli/__tests__/version.test.js +21 -0
  395. package/dist/cli/__tests__/version.test.js.map +1 -0
  396. package/dist/cli/__tests__/windows-popup-loop-contract.test.d.ts +2 -0
  397. package/dist/cli/__tests__/windows-popup-loop-contract.test.d.ts.map +1 -0
  398. package/dist/cli/__tests__/windows-popup-loop-contract.test.js +31 -0
  399. package/dist/cli/__tests__/windows-popup-loop-contract.test.js.map +1 -0
  400. package/dist/cli/adapt.d.ts +6 -0
  401. package/dist/cli/adapt.d.ts.map +1 -0
  402. package/dist/cli/adapt.js +135 -0
  403. package/dist/cli/adapt.js.map +1 -0
  404. package/dist/cli/agents-init.d.ts +14 -0
  405. package/dist/cli/agents-init.d.ts.map +1 -0
  406. package/dist/cli/agents-init.js +274 -0
  407. package/dist/cli/agents-init.js.map +1 -0
  408. package/dist/cli/agents.d.ts +14 -0
  409. package/dist/cli/agents.d.ts.map +1 -0
  410. package/dist/cli/agents.js +267 -0
  411. package/dist/cli/agents.js.map +1 -0
  412. package/dist/cli/ask.d.ts +13 -0
  413. package/dist/cli/ask.d.ts.map +1 -0
  414. package/dist/cli/ask.js +178 -0
  415. package/dist/cli/ask.js.map +1 -0
  416. package/dist/cli/autoresearch-guided.d.ts +43 -0
  417. package/dist/cli/autoresearch-guided.d.ts.map +1 -0
  418. package/dist/cli/autoresearch-guided.js +282 -0
  419. package/dist/cli/autoresearch-guided.js.map +1 -0
  420. package/dist/cli/autoresearch-intake.d.ts +62 -0
  421. package/dist/cli/autoresearch-intake.d.ts.map +1 -0
  422. package/dist/cli/autoresearch-intake.js +336 -0
  423. package/dist/cli/autoresearch-intake.js.map +1 -0
  424. package/dist/cli/autoresearch.d.ts +16 -0
  425. package/dist/cli/autoresearch.d.ts.map +1 -0
  426. package/dist/cli/autoresearch.js +91 -0
  427. package/dist/cli/autoresearch.js.map +1 -0
  428. package/dist/cli/catalog-contract.d.ts +10 -0
  429. package/dist/cli/catalog-contract.d.ts.map +1 -0
  430. package/dist/cli/catalog-contract.js +34 -0
  431. package/dist/cli/catalog-contract.js.map +1 -0
  432. package/dist/cli/cleanup.d.ts +56 -0
  433. package/dist/cli/cleanup.d.ts.map +1 -0
  434. package/dist/cli/cleanup.js +400 -0
  435. package/dist/cli/cleanup.js.map +1 -0
  436. package/dist/cli/codex-home.d.ts +7 -0
  437. package/dist/cli/codex-home.d.ts.map +1 -0
  438. package/dist/cli/codex-home.js +26 -0
  439. package/dist/cli/codex-home.js.map +1 -0
  440. package/dist/cli/constants.d.ts +11 -0
  441. package/dist/cli/constants.d.ts.map +1 -0
  442. package/dist/cli/constants.js +11 -0
  443. package/dist/cli/constants.js.map +1 -0
  444. package/dist/cli/doctor.d.ts +18 -0
  445. package/dist/cli/doctor.d.ts.map +1 -0
  446. package/dist/cli/doctor.js +1072 -0
  447. package/dist/cli/doctor.js.map +1 -0
  448. package/dist/cli/explore.d.ts +30 -0
  449. package/dist/cli/explore.d.ts.map +1 -0
  450. package/dist/cli/explore.js +404 -0
  451. package/dist/cli/explore.js.map +1 -0
  452. package/dist/cli/hooks.d.ts +4 -0
  453. package/dist/cli/hooks.d.ts.map +1 -0
  454. package/dist/cli/hooks.js +201 -0
  455. package/dist/cli/hooks.js.map +1 -0
  456. package/dist/cli/index.d.ts +138 -0
  457. package/dist/cli/index.d.ts.map +1 -0
  458. package/dist/cli/index.js +3117 -0
  459. package/dist/cli/index.js.map +1 -0
  460. package/dist/cli/list.d.ts +2 -0
  461. package/dist/cli/list.d.ts.map +1 -0
  462. package/dist/cli/list.js +40 -0
  463. package/dist/cli/list.js.map +1 -0
  464. package/dist/cli/mcp-parity.d.ts +22 -0
  465. package/dist/cli/mcp-parity.d.ts.map +1 -0
  466. package/dist/cli/mcp-parity.js +251 -0
  467. package/dist/cli/mcp-parity.js.map +1 -0
  468. package/dist/cli/mcp-serve.d.ts +13 -0
  469. package/dist/cli/mcp-serve.d.ts.map +1 -0
  470. package/dist/cli/mcp-serve.js +71 -0
  471. package/dist/cli/mcp-serve.js.map +1 -0
  472. package/dist/cli/native-assets.d.ts +51 -0
  473. package/dist/cli/native-assets.d.ts.map +1 -0
  474. package/dist/cli/native-assets.js +379 -0
  475. package/dist/cli/native-assets.js.map +1 -0
  476. package/dist/cli/plugin-marketplace.d.ts +13 -0
  477. package/dist/cli/plugin-marketplace.d.ts.map +1 -0
  478. package/dist/cli/plugin-marketplace.js +75 -0
  479. package/dist/cli/plugin-marketplace.js.map +1 -0
  480. package/dist/cli/question.d.ts +3 -0
  481. package/dist/cli/question.d.ts.map +1 -0
  482. package/dist/cli/question.js +227 -0
  483. package/dist/cli/question.js.map +1 -0
  484. package/dist/cli/ralph.d.ts +17 -0
  485. package/dist/cli/ralph.d.ts.map +1 -0
  486. package/dist/cli/ralph.js +313 -0
  487. package/dist/cli/ralph.js.map +1 -0
  488. package/dist/cli/rcs.d.ts +3 -0
  489. package/dist/cli/rcs.d.ts.map +1 -0
  490. package/dist/cli/rcs.js +127 -0
  491. package/dist/cli/rcs.js.map +1 -0
  492. package/dist/cli/session-search.d.ts +8 -0
  493. package/dist/cli/session-search.d.ts.map +1 -0
  494. package/dist/cli/session-search.js +138 -0
  495. package/dist/cli/session-search.js.map +1 -0
  496. package/dist/cli/setup-preferences.d.ts +20 -0
  497. package/dist/cli/setup-preferences.d.ts.map +1 -0
  498. package/dist/cli/setup-preferences.js +71 -0
  499. package/dist/cli/setup-preferences.js.map +1 -0
  500. package/dist/cli/setup.d.ts +55 -0
  501. package/dist/cli/setup.d.ts.map +1 -0
  502. package/dist/cli/setup.js +2056 -0
  503. package/dist/cli/setup.js.map +1 -0
  504. package/dist/cli/sparkshell.d.ts +33 -0
  505. package/dist/cli/sparkshell.d.ts.map +1 -0
  506. package/dist/cli/sparkshell.js +272 -0
  507. package/dist/cli/sparkshell.js.map +1 -0
  508. package/dist/cli/star-prompt.d.ts +31 -0
  509. package/dist/cli/star-prompt.d.ts.map +1 -0
  510. package/dist/cli/star-prompt.js +97 -0
  511. package/dist/cli/star-prompt.js.map +1 -0
  512. package/dist/cli/state.d.ts +8 -0
  513. package/dist/cli/state.d.ts.map +1 -0
  514. package/dist/cli/state.js +71 -0
  515. package/dist/cli/state.js.map +1 -0
  516. package/dist/cli/team.d.ts +42 -0
  517. package/dist/cli/team.d.ts.map +1 -0
  518. package/dist/cli/team.js +1293 -0
  519. package/dist/cli/team.js.map +1 -0
  520. package/dist/cli/tmux-hook.d.ts +3 -0
  521. package/dist/cli/tmux-hook.d.ts.map +1 -0
  522. package/dist/cli/tmux-hook.js +386 -0
  523. package/dist/cli/tmux-hook.js.map +1 -0
  524. package/dist/cli/uninstall.d.ts +13 -0
  525. package/dist/cli/uninstall.d.ts.map +1 -0
  526. package/dist/cli/uninstall.js +402 -0
  527. package/dist/cli/uninstall.js.map +1 -0
  528. package/dist/cli/update.d.ts +56 -0
  529. package/dist/cli/update.d.ts.map +1 -0
  530. package/dist/cli/update.js +333 -0
  531. package/dist/cli/update.js.map +1 -0
  532. package/dist/cli/version.d.ts +2 -0
  533. package/dist/cli/version.d.ts.map +1 -0
  534. package/dist/cli/version.js +17 -0
  535. package/dist/cli/version.js.map +1 -0
  536. package/dist/compat/__tests__/doctor-contract.test.d.ts +2 -0
  537. package/dist/compat/__tests__/doctor-contract.test.d.ts.map +1 -0
  538. package/dist/compat/__tests__/doctor-contract.test.js +108 -0
  539. package/dist/compat/__tests__/doctor-contract.test.js.map +1 -0
  540. package/dist/compat/__tests__/rust-runtime-compat.test.d.ts +2 -0
  541. package/dist/compat/__tests__/rust-runtime-compat.test.d.ts.map +1 -0
  542. package/dist/compat/__tests__/rust-runtime-compat.test.js +218 -0
  543. package/dist/compat/__tests__/rust-runtime-compat.test.js.map +1 -0
  544. package/dist/config/__tests__/codex-hooks.test.d.ts +2 -0
  545. package/dist/config/__tests__/codex-hooks.test.d.ts.map +1 -0
  546. package/dist/config/__tests__/codex-hooks.test.js +77 -0
  547. package/dist/config/__tests__/codex-hooks.test.js.map +1 -0
  548. package/dist/config/__tests__/generator-idempotent.test.d.ts +2 -0
  549. package/dist/config/__tests__/generator-idempotent.test.d.ts.map +1 -0
  550. package/dist/config/__tests__/generator-idempotent.test.js +882 -0
  551. package/dist/config/__tests__/generator-idempotent.test.js.map +1 -0
  552. package/dist/config/__tests__/generator-notify.test.d.ts +2 -0
  553. package/dist/config/__tests__/generator-notify.test.d.ts.map +1 -0
  554. package/dist/config/__tests__/generator-notify.test.js +343 -0
  555. package/dist/config/__tests__/generator-notify.test.js.map +1 -0
  556. package/dist/config/__tests__/generator-status-line-presets.test.d.ts +2 -0
  557. package/dist/config/__tests__/generator-status-line-presets.test.d.ts.map +1 -0
  558. package/dist/config/__tests__/generator-status-line-presets.test.js +203 -0
  559. package/dist/config/__tests__/generator-status-line-presets.test.js.map +1 -0
  560. package/dist/config/__tests__/mcp-registry.test.d.ts +2 -0
  561. package/dist/config/__tests__/mcp-registry.test.d.ts.map +1 -0
  562. package/dist/config/__tests__/mcp-registry.test.js +190 -0
  563. package/dist/config/__tests__/mcp-registry.test.js.map +1 -0
  564. package/dist/config/__tests__/models.test.d.ts +2 -0
  565. package/dist/config/__tests__/models.test.d.ts.map +1 -0
  566. package/dist/config/__tests__/models.test.js +224 -0
  567. package/dist/config/__tests__/models.test.js.map +1 -0
  568. package/dist/config/__tests__/wiki-config-contract.test.d.ts +2 -0
  569. package/dist/config/__tests__/wiki-config-contract.test.d.ts.map +1 -0
  570. package/dist/config/__tests__/wiki-config-contract.test.js +19 -0
  571. package/dist/config/__tests__/wiki-config-contract.test.js.map +1 -0
  572. package/dist/config/codex-hooks.d.ts +21 -0
  573. package/dist/config/codex-hooks.d.ts.map +1 -0
  574. package/dist/config/codex-hooks.js +198 -0
  575. package/dist/config/codex-hooks.js.map +1 -0
  576. package/dist/config/generator.d.ts +87 -0
  577. package/dist/config/generator.d.ts.map +1 -0
  578. package/dist/config/generator.js +1127 -0
  579. package/dist/config/generator.js.map +1 -0
  580. package/dist/config/mcp-registry.d.ts +35 -0
  581. package/dist/config/mcp-registry.d.ts.map +1 -0
  582. package/dist/config/mcp-registry.js +159 -0
  583. package/dist/config/mcp-registry.js.map +1 -0
  584. package/dist/config/models.d.ts +74 -0
  585. package/dist/config/models.d.ts.map +1 -0
  586. package/dist/config/models.js +214 -0
  587. package/dist/config/models.js.map +1 -0
  588. package/dist/config/rcs-first-party-mcp.d.ts +18 -0
  589. package/dist/config/rcs-first-party-mcp.d.ts.map +1 -0
  590. package/dist/config/rcs-first-party-mcp.js +76 -0
  591. package/dist/config/rcs-first-party-mcp.js.map +1 -0
  592. package/dist/document-refresh/__tests__/enforcer.test.d.ts +2 -0
  593. package/dist/document-refresh/__tests__/enforcer.test.d.ts.map +1 -0
  594. package/dist/document-refresh/__tests__/enforcer.test.js +128 -0
  595. package/dist/document-refresh/__tests__/enforcer.test.js.map +1 -0
  596. package/dist/document-refresh/config.d.ts +9 -0
  597. package/dist/document-refresh/config.d.ts.map +1 -0
  598. package/dist/document-refresh/config.js +70 -0
  599. package/dist/document-refresh/config.js.map +1 -0
  600. package/dist/document-refresh/enforcer.d.ts +43 -0
  601. package/dist/document-refresh/enforcer.d.ts.map +1 -0
  602. package/dist/document-refresh/enforcer.js +329 -0
  603. package/dist/document-refresh/enforcer.js.map +1 -0
  604. package/dist/exec/followup.d.ts +44 -0
  605. package/dist/exec/followup.d.ts.map +1 -0
  606. package/dist/exec/followup.js +349 -0
  607. package/dist/exec/followup.js.map +1 -0
  608. package/dist/hooks/__tests__/agents-overlay.test.d.ts +8 -0
  609. package/dist/hooks/__tests__/agents-overlay.test.d.ts.map +1 -0
  610. package/dist/hooks/__tests__/agents-overlay.test.js +644 -0
  611. package/dist/hooks/__tests__/agents-overlay.test.js.map +1 -0
  612. package/dist/hooks/__tests__/analyze-routing-contract.test.d.ts +2 -0
  613. package/dist/hooks/__tests__/analyze-routing-contract.test.d.ts.map +1 -0
  614. package/dist/hooks/__tests__/analyze-routing-contract.test.js +45 -0
  615. package/dist/hooks/__tests__/analyze-routing-contract.test.js.map +1 -0
  616. package/dist/hooks/__tests__/analyze-skill-contract.test.d.ts +2 -0
  617. package/dist/hooks/__tests__/analyze-skill-contract.test.d.ts.map +1 -0
  618. package/dist/hooks/__tests__/analyze-skill-contract.test.js +48 -0
  619. package/dist/hooks/__tests__/analyze-skill-contract.test.js.map +1 -0
  620. package/dist/hooks/__tests__/anti-slop-workflow.test.d.ts +2 -0
  621. package/dist/hooks/__tests__/anti-slop-workflow.test.d.ts.map +1 -0
  622. package/dist/hooks/__tests__/anti-slop-workflow.test.js +146 -0
  623. package/dist/hooks/__tests__/anti-slop-workflow.test.js.map +1 -0
  624. package/dist/hooks/__tests__/autopilot-skill-contract.test.d.ts +2 -0
  625. package/dist/hooks/__tests__/autopilot-skill-contract.test.d.ts.map +1 -0
  626. package/dist/hooks/__tests__/autopilot-skill-contract.test.js +37 -0
  627. package/dist/hooks/__tests__/autopilot-skill-contract.test.js.map +1 -0
  628. package/dist/hooks/__tests__/clawhip-event-contract.test.d.ts +2 -0
  629. package/dist/hooks/__tests__/clawhip-event-contract.test.d.ts.map +1 -0
  630. package/dist/hooks/__tests__/clawhip-event-contract.test.js +37 -0
  631. package/dist/hooks/__tests__/clawhip-event-contract.test.js.map +1 -0
  632. package/dist/hooks/__tests__/code-review-skill-contract.test.d.ts +2 -0
  633. package/dist/hooks/__tests__/code-review-skill-contract.test.d.ts.map +1 -0
  634. package/dist/hooks/__tests__/code-review-skill-contract.test.js +56 -0
  635. package/dist/hooks/__tests__/code-review-skill-contract.test.js.map +1 -0
  636. package/dist/hooks/__tests__/codebase-map.test.d.ts +8 -0
  637. package/dist/hooks/__tests__/codebase-map.test.d.ts.map +1 -0
  638. package/dist/hooks/__tests__/codebase-map.test.js +218 -0
  639. package/dist/hooks/__tests__/codebase-map.test.js.map +1 -0
  640. package/dist/hooks/__tests__/consensus-execution-handoff.test.d.ts +18 -0
  641. package/dist/hooks/__tests__/consensus-execution-handoff.test.d.ts.map +1 -0
  642. package/dist/hooks/__tests__/consensus-execution-handoff.test.js +234 -0
  643. package/dist/hooks/__tests__/consensus-execution-handoff.test.js.map +1 -0
  644. package/dist/hooks/__tests__/debugger-log-recency-contract.test.d.ts +2 -0
  645. package/dist/hooks/__tests__/debugger-log-recency-contract.test.d.ts.map +1 -0
  646. package/dist/hooks/__tests__/debugger-log-recency-contract.test.js +20 -0
  647. package/dist/hooks/__tests__/debugger-log-recency-contract.test.js.map +1 -0
  648. package/dist/hooks/__tests__/deep-interview-contract.test.d.ts +2 -0
  649. package/dist/hooks/__tests__/deep-interview-contract.test.d.ts.map +1 -0
  650. package/dist/hooks/__tests__/deep-interview-contract.test.js +213 -0
  651. package/dist/hooks/__tests__/deep-interview-contract.test.js.map +1 -0
  652. package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.d.ts +2 -0
  653. package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.d.ts.map +1 -0
  654. package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.js +43 -0
  655. package/dist/hooks/__tests__/explicit-terminal-stop-docs-contract.test.js.map +1 -0
  656. package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.d.ts +2 -0
  657. package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.d.ts.map +1 -0
  658. package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.js +38 -0
  659. package/dist/hooks/__tests__/explicit-terminal-stop-model-docs-contract.test.js.map +1 -0
  660. package/dist/hooks/__tests__/explore-routing.test.d.ts +2 -0
  661. package/dist/hooks/__tests__/explore-routing.test.d.ts.map +1 -0
  662. package/dist/hooks/__tests__/explore-routing.test.js +43 -0
  663. package/dist/hooks/__tests__/explore-routing.test.js.map +1 -0
  664. package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.d.ts +2 -0
  665. package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.d.ts.map +1 -0
  666. package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.js +69 -0
  667. package/dist/hooks/__tests__/explore-sparkshell-guidance-contract.test.js.map +1 -0
  668. package/dist/hooks/__tests__/keyword-detector.test.d.ts +2 -0
  669. package/dist/hooks/__tests__/keyword-detector.test.d.ts.map +1 -0
  670. package/dist/hooks/__tests__/keyword-detector.test.js +1716 -0
  671. package/dist/hooks/__tests__/keyword-detector.test.js.map +1 -0
  672. package/dist/hooks/__tests__/notify-fallback-watcher.test.d.ts +2 -0
  673. package/dist/hooks/__tests__/notify-fallback-watcher.test.d.ts.map +1 -0
  674. package/dist/hooks/__tests__/notify-fallback-watcher.test.js +3898 -0
  675. package/dist/hooks/__tests__/notify-fallback-watcher.test.js.map +1 -0
  676. package/dist/hooks/__tests__/notify-hook-all-workers-idle.test.d.ts +2 -0
  677. package/dist/hooks/__tests__/notify-hook-all-workers-idle.test.d.ts.map +1 -0
  678. package/dist/hooks/__tests__/notify-hook-all-workers-idle.test.js +786 -0
  679. package/dist/hooks/__tests__/notify-hook-all-workers-idle.test.js.map +1 -0
  680. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.d.ts +2 -0
  681. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.d.ts.map +1 -0
  682. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js +2397 -0
  683. package/dist/hooks/__tests__/notify-hook-auto-nudge.test.js.map +1 -0
  684. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.d.ts +2 -0
  685. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.d.ts.map +1 -0
  686. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js +160 -0
  687. package/dist/hooks/__tests__/notify-hook-cross-worktree-heartbeat.test.js.map +1 -0
  688. package/dist/hooks/__tests__/notify-hook-managed-tmux.test.d.ts +2 -0
  689. package/dist/hooks/__tests__/notify-hook-managed-tmux.test.d.ts.map +1 -0
  690. package/dist/hooks/__tests__/notify-hook-managed-tmux.test.js +1178 -0
  691. package/dist/hooks/__tests__/notify-hook-managed-tmux.test.js.map +1 -0
  692. package/dist/hooks/__tests__/notify-hook-modules.test.d.ts +9 -0
  693. package/dist/hooks/__tests__/notify-hook-modules.test.d.ts.map +1 -0
  694. package/dist/hooks/__tests__/notify-hook-modules.test.js +529 -0
  695. package/dist/hooks/__tests__/notify-hook-modules.test.js.map +1 -0
  696. package/dist/hooks/__tests__/notify-hook-native-dispatch-contract.test.d.ts +2 -0
  697. package/dist/hooks/__tests__/notify-hook-native-dispatch-contract.test.d.ts.map +1 -0
  698. package/dist/hooks/__tests__/notify-hook-native-dispatch-contract.test.js +14 -0
  699. package/dist/hooks/__tests__/notify-hook-native-dispatch-contract.test.js.map +1 -0
  700. package/dist/hooks/__tests__/notify-hook-ralph-resume.test.d.ts +2 -0
  701. package/dist/hooks/__tests__/notify-hook-ralph-resume.test.d.ts.map +1 -0
  702. package/dist/hooks/__tests__/notify-hook-ralph-resume.test.js +682 -0
  703. package/dist/hooks/__tests__/notify-hook-ralph-resume.test.js.map +1 -0
  704. package/dist/hooks/__tests__/notify-hook-regression-205.test.d.ts +9 -0
  705. package/dist/hooks/__tests__/notify-hook-regression-205.test.d.ts.map +1 -0
  706. package/dist/hooks/__tests__/notify-hook-regression-205.test.js +255 -0
  707. package/dist/hooks/__tests__/notify-hook-regression-205.test.js.map +1 -0
  708. package/dist/hooks/__tests__/notify-hook-session-idle-dedupe.test.d.ts +2 -0
  709. package/dist/hooks/__tests__/notify-hook-session-idle-dedupe.test.d.ts.map +1 -0
  710. package/dist/hooks/__tests__/notify-hook-session-idle-dedupe.test.js +162 -0
  711. package/dist/hooks/__tests__/notify-hook-session-idle-dedupe.test.js.map +1 -0
  712. package/dist/hooks/__tests__/notify-hook-session-scope.test.d.ts +2 -0
  713. package/dist/hooks/__tests__/notify-hook-session-scope.test.d.ts.map +1 -0
  714. package/dist/hooks/__tests__/notify-hook-session-scope.test.js +301 -0
  715. package/dist/hooks/__tests__/notify-hook-session-scope.test.js.map +1 -0
  716. package/dist/hooks/__tests__/notify-hook-team-dispatch.test.d.ts +2 -0
  717. package/dist/hooks/__tests__/notify-hook-team-dispatch.test.d.ts.map +1 -0
  718. package/dist/hooks/__tests__/notify-hook-team-dispatch.test.js +1510 -0
  719. package/dist/hooks/__tests__/notify-hook-team-dispatch.test.js.map +1 -0
  720. package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.d.ts +2 -0
  721. package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.d.ts.map +1 -0
  722. package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.js +2879 -0
  723. package/dist/hooks/__tests__/notify-hook-team-leader-nudge.test.js.map +1 -0
  724. package/dist/hooks/__tests__/notify-hook-team-tmux-guard.test.d.ts +2 -0
  725. package/dist/hooks/__tests__/notify-hook-team-tmux-guard.test.d.ts.map +1 -0
  726. package/dist/hooks/__tests__/notify-hook-team-tmux-guard.test.js +228 -0
  727. package/dist/hooks/__tests__/notify-hook-team-tmux-guard.test.js.map +1 -0
  728. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.d.ts +2 -0
  729. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.d.ts.map +1 -0
  730. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.js +35 -0
  731. package/dist/hooks/__tests__/notify-hook-team-worker-fail-closed.test.js.map +1 -0
  732. package/dist/hooks/__tests__/notify-hook-tmux-heal.test.d.ts +2 -0
  733. package/dist/hooks/__tests__/notify-hook-tmux-heal.test.d.ts.map +1 -0
  734. package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js +1589 -0
  735. package/dist/hooks/__tests__/notify-hook-tmux-heal.test.js.map +1 -0
  736. package/dist/hooks/__tests__/notify-hook-tmux-scrollback.test.d.ts +10 -0
  737. package/dist/hooks/__tests__/notify-hook-tmux-scrollback.test.d.ts.map +1 -0
  738. package/dist/hooks/__tests__/notify-hook-tmux-scrollback.test.js +0 -0
  739. package/dist/hooks/__tests__/notify-hook-tmux-scrollback.test.js.map +1 -0
  740. package/dist/hooks/__tests__/notify-hook-visual-verdict.test.d.ts +11 -0
  741. package/dist/hooks/__tests__/notify-hook-visual-verdict.test.d.ts.map +1 -0
  742. package/dist/hooks/__tests__/notify-hook-visual-verdict.test.js +266 -0
  743. package/dist/hooks/__tests__/notify-hook-visual-verdict.test.js.map +1 -0
  744. package/dist/hooks/__tests__/notify-hook-worker-idle.test.d.ts +2 -0
  745. package/dist/hooks/__tests__/notify-hook-worker-idle.test.d.ts.map +1 -0
  746. package/dist/hooks/__tests__/notify-hook-worker-idle.test.js +895 -0
  747. package/dist/hooks/__tests__/notify-hook-worker-idle.test.js.map +1 -0
  748. package/dist/hooks/__tests__/openclaw-setup-contract.test.d.ts +2 -0
  749. package/dist/hooks/__tests__/openclaw-setup-contract.test.d.ts.map +1 -0
  750. package/dist/hooks/__tests__/openclaw-setup-contract.test.js +61 -0
  751. package/dist/hooks/__tests__/openclaw-setup-contract.test.js.map +1 -0
  752. package/dist/hooks/__tests__/pre-context-gate-skills.test.d.ts +2 -0
  753. package/dist/hooks/__tests__/pre-context-gate-skills.test.d.ts.map +1 -0
  754. package/dist/hooks/__tests__/pre-context-gate-skills.test.js +40 -0
  755. package/dist/hooks/__tests__/pre-context-gate-skills.test.js.map +1 -0
  756. package/dist/hooks/__tests__/prompt-guidance-catalog.test.d.ts +2 -0
  757. package/dist/hooks/__tests__/prompt-guidance-catalog.test.d.ts.map +1 -0
  758. package/dist/hooks/__tests__/prompt-guidance-catalog.test.js +11 -0
  759. package/dist/hooks/__tests__/prompt-guidance-catalog.test.js.map +1 -0
  760. package/dist/hooks/__tests__/prompt-guidance-contract.test.d.ts +2 -0
  761. package/dist/hooks/__tests__/prompt-guidance-contract.test.d.ts.map +1 -0
  762. package/dist/hooks/__tests__/prompt-guidance-contract.test.js +38 -0
  763. package/dist/hooks/__tests__/prompt-guidance-contract.test.js.map +1 -0
  764. package/dist/hooks/__tests__/prompt-guidance-fragments.test.d.ts +2 -0
  765. package/dist/hooks/__tests__/prompt-guidance-fragments.test.d.ts.map +1 -0
  766. package/dist/hooks/__tests__/prompt-guidance-fragments.test.js +48 -0
  767. package/dist/hooks/__tests__/prompt-guidance-fragments.test.js.map +1 -0
  768. package/dist/hooks/__tests__/prompt-guidance-scenarios.test.d.ts +2 -0
  769. package/dist/hooks/__tests__/prompt-guidance-scenarios.test.d.ts.map +1 -0
  770. package/dist/hooks/__tests__/prompt-guidance-scenarios.test.js +11 -0
  771. package/dist/hooks/__tests__/prompt-guidance-scenarios.test.js.map +1 -0
  772. package/dist/hooks/__tests__/prompt-guidance-test-helpers.d.ts +5 -0
  773. package/dist/hooks/__tests__/prompt-guidance-test-helpers.d.ts.map +1 -0
  774. package/dist/hooks/__tests__/prompt-guidance-test-helpers.js +34 -0
  775. package/dist/hooks/__tests__/prompt-guidance-test-helpers.js.map +1 -0
  776. package/dist/hooks/__tests__/prompt-guidance-wave-two.test.d.ts +2 -0
  777. package/dist/hooks/__tests__/prompt-guidance-wave-two.test.d.ts.map +1 -0
  778. package/dist/hooks/__tests__/prompt-guidance-wave-two.test.js +65 -0
  779. package/dist/hooks/__tests__/prompt-guidance-wave-two.test.js.map +1 -0
  780. package/dist/hooks/__tests__/prompt-orchestration-boundary.test.d.ts +2 -0
  781. package/dist/hooks/__tests__/prompt-orchestration-boundary.test.d.ts.map +1 -0
  782. package/dist/hooks/__tests__/prompt-orchestration-boundary.test.js +38 -0
  783. package/dist/hooks/__tests__/prompt-orchestration-boundary.test.js.map +1 -0
  784. package/dist/hooks/__tests__/prompt-refactor-contract.test.d.ts +2 -0
  785. package/dist/hooks/__tests__/prompt-refactor-contract.test.d.ts.map +1 -0
  786. package/dist/hooks/__tests__/prompt-refactor-contract.test.js +22 -0
  787. package/dist/hooks/__tests__/prompt-refactor-contract.test.js.map +1 -0
  788. package/dist/hooks/__tests__/prompt-team-routing.test.d.ts +2 -0
  789. package/dist/hooks/__tests__/prompt-team-routing.test.d.ts.map +1 -0
  790. package/dist/hooks/__tests__/prompt-team-routing.test.js +49 -0
  791. package/dist/hooks/__tests__/prompt-team-routing.test.js.map +1 -0
  792. package/dist/hooks/__tests__/session.test.d.ts +2 -0
  793. package/dist/hooks/__tests__/session.test.d.ts.map +1 -0
  794. package/dist/hooks/__tests__/session.test.js +322 -0
  795. package/dist/hooks/__tests__/session.test.js.map +1 -0
  796. package/dist/hooks/__tests__/skill-guidance-contract.test.d.ts +2 -0
  797. package/dist/hooks/__tests__/skill-guidance-contract.test.d.ts.map +1 -0
  798. package/dist/hooks/__tests__/skill-guidance-contract.test.js +29 -0
  799. package/dist/hooks/__tests__/skill-guidance-contract.test.js.map +1 -0
  800. package/dist/hooks/__tests__/task-size-detector.test.d.ts +2 -0
  801. package/dist/hooks/__tests__/task-size-detector.test.d.ts.map +1 -0
  802. package/dist/hooks/__tests__/task-size-detector.test.js +330 -0
  803. package/dist/hooks/__tests__/task-size-detector.test.js.map +1 -0
  804. package/dist/hooks/__tests__/team-runtime-gating-docs-contract.test.d.ts +2 -0
  805. package/dist/hooks/__tests__/team-runtime-gating-docs-contract.test.d.ts.map +1 -0
  806. package/dist/hooks/__tests__/team-runtime-gating-docs-contract.test.js +28 -0
  807. package/dist/hooks/__tests__/team-runtime-gating-docs-contract.test.js.map +1 -0
  808. package/dist/hooks/__tests__/tmux-hook-engine-types-sync.test.d.ts +2 -0
  809. package/dist/hooks/__tests__/tmux-hook-engine-types-sync.test.d.ts.map +1 -0
  810. package/dist/hooks/__tests__/tmux-hook-engine-types-sync.test.js +24 -0
  811. package/dist/hooks/__tests__/tmux-hook-engine-types-sync.test.js.map +1 -0
  812. package/dist/hooks/__tests__/tmux-hook-engine.test.d.ts +2 -0
  813. package/dist/hooks/__tests__/tmux-hook-engine.test.d.ts.map +1 -0
  814. package/dist/hooks/__tests__/tmux-hook-engine.test.js +403 -0
  815. package/dist/hooks/__tests__/tmux-hook-engine.test.js.map +1 -0
  816. package/dist/hooks/__tests__/triage-config.test.d.ts +2 -0
  817. package/dist/hooks/__tests__/triage-config.test.d.ts.map +1 -0
  818. package/dist/hooks/__tests__/triage-config.test.js +211 -0
  819. package/dist/hooks/__tests__/triage-config.test.js.map +1 -0
  820. package/dist/hooks/__tests__/triage-heuristic.test.d.ts +2 -0
  821. package/dist/hooks/__tests__/triage-heuristic.test.d.ts.map +1 -0
  822. package/dist/hooks/__tests__/triage-heuristic.test.js +285 -0
  823. package/dist/hooks/__tests__/triage-heuristic.test.js.map +1 -0
  824. package/dist/hooks/__tests__/triage-state.test.d.ts +2 -0
  825. package/dist/hooks/__tests__/triage-state.test.d.ts.map +1 -0
  826. package/dist/hooks/__tests__/triage-state.test.js +426 -0
  827. package/dist/hooks/__tests__/triage-state.test.js.map +1 -0
  828. package/dist/hooks/__tests__/visual-ralph-skill.test.d.ts +2 -0
  829. package/dist/hooks/__tests__/visual-ralph-skill.test.d.ts.map +1 -0
  830. package/dist/hooks/__tests__/visual-ralph-skill.test.js +44 -0
  831. package/dist/hooks/__tests__/visual-ralph-skill.test.js.map +1 -0
  832. package/dist/hooks/__tests__/visual-verdict-loop.test.d.ts +2 -0
  833. package/dist/hooks/__tests__/visual-verdict-loop.test.d.ts.map +1 -0
  834. package/dist/hooks/__tests__/visual-verdict-loop.test.js +35 -0
  835. package/dist/hooks/__tests__/visual-verdict-loop.test.js.map +1 -0
  836. package/dist/hooks/__tests__/wiki-docs-contract.test.d.ts +2 -0
  837. package/dist/hooks/__tests__/wiki-docs-contract.test.d.ts.map +1 -0
  838. package/dist/hooks/__tests__/wiki-docs-contract.test.js +34 -0
  839. package/dist/hooks/__tests__/wiki-docs-contract.test.js.map +1 -0
  840. package/dist/hooks/agents-overlay.d.ts +51 -0
  841. package/dist/hooks/agents-overlay.d.ts.map +1 -0
  842. package/dist/hooks/agents-overlay.js +557 -0
  843. package/dist/hooks/agents-overlay.js.map +1 -0
  844. package/dist/hooks/code-simplifier/__tests__/index.test.d.ts +2 -0
  845. package/dist/hooks/code-simplifier/__tests__/index.test.d.ts.map +1 -0
  846. package/dist/hooks/code-simplifier/__tests__/index.test.js +187 -0
  847. package/dist/hooks/code-simplifier/__tests__/index.test.js.map +1 -0
  848. package/dist/hooks/code-simplifier/index.d.ts +80 -0
  849. package/dist/hooks/code-simplifier/index.d.ts.map +1 -0
  850. package/dist/hooks/code-simplifier/index.js +172 -0
  851. package/dist/hooks/code-simplifier/index.js.map +1 -0
  852. package/dist/hooks/codebase-map.d.ts +23 -0
  853. package/dist/hooks/codebase-map.d.ts.map +1 -0
  854. package/dist/hooks/codebase-map.js +233 -0
  855. package/dist/hooks/codebase-map.js.map +1 -0
  856. package/dist/hooks/explore-routing.d.ts +5 -0
  857. package/dist/hooks/explore-routing.d.ts.map +1 -0
  858. package/dist/hooks/explore-routing.js +47 -0
  859. package/dist/hooks/explore-routing.js.map +1 -0
  860. package/dist/hooks/extensibility/__tests__/dispatcher.test.d.ts +2 -0
  861. package/dist/hooks/extensibility/__tests__/dispatcher.test.d.ts.map +1 -0
  862. package/dist/hooks/extensibility/__tests__/dispatcher.test.js +242 -0
  863. package/dist/hooks/extensibility/__tests__/dispatcher.test.js.map +1 -0
  864. package/dist/hooks/extensibility/__tests__/events.test.d.ts +2 -0
  865. package/dist/hooks/extensibility/__tests__/events.test.d.ts.map +1 -0
  866. package/dist/hooks/extensibility/__tests__/events.test.js +125 -0
  867. package/dist/hooks/extensibility/__tests__/events.test.js.map +1 -0
  868. package/dist/hooks/extensibility/__tests__/example-hook-plugins.test.d.ts +2 -0
  869. package/dist/hooks/extensibility/__tests__/example-hook-plugins.test.d.ts.map +1 -0
  870. package/dist/hooks/extensibility/__tests__/example-hook-plugins.test.js +153 -0
  871. package/dist/hooks/extensibility/__tests__/example-hook-plugins.test.js.map +1 -0
  872. package/dist/hooks/extensibility/__tests__/loader.test.d.ts +2 -0
  873. package/dist/hooks/extensibility/__tests__/loader.test.d.ts.map +1 -0
  874. package/dist/hooks/extensibility/__tests__/loader.test.js +254 -0
  875. package/dist/hooks/extensibility/__tests__/loader.test.js.map +1 -0
  876. package/dist/hooks/extensibility/__tests__/logging.test.d.ts +2 -0
  877. package/dist/hooks/extensibility/__tests__/logging.test.d.ts.map +1 -0
  878. package/dist/hooks/extensibility/__tests__/logging.test.js +74 -0
  879. package/dist/hooks/extensibility/__tests__/logging.test.js.map +1 -0
  880. package/dist/hooks/extensibility/__tests__/plugin-runner.test.d.ts +2 -0
  881. package/dist/hooks/extensibility/__tests__/plugin-runner.test.d.ts.map +1 -0
  882. package/dist/hooks/extensibility/__tests__/plugin-runner.test.js +202 -0
  883. package/dist/hooks/extensibility/__tests__/plugin-runner.test.js.map +1 -0
  884. package/dist/hooks/extensibility/__tests__/runtime.test.d.ts +2 -0
  885. package/dist/hooks/extensibility/__tests__/runtime.test.d.ts.map +1 -0
  886. package/dist/hooks/extensibility/__tests__/runtime.test.js +198 -0
  887. package/dist/hooks/extensibility/__tests__/runtime.test.js.map +1 -0
  888. package/dist/hooks/extensibility/__tests__/sdk-public-surface.test.d.ts +2 -0
  889. package/dist/hooks/extensibility/__tests__/sdk-public-surface.test.d.ts.map +1 -0
  890. package/dist/hooks/extensibility/__tests__/sdk-public-surface.test.js +32 -0
  891. package/dist/hooks/extensibility/__tests__/sdk-public-surface.test.js.map +1 -0
  892. package/dist/hooks/extensibility/__tests__/sdk.test.d.ts +2 -0
  893. package/dist/hooks/extensibility/__tests__/sdk.test.d.ts.map +1 -0
  894. package/dist/hooks/extensibility/__tests__/sdk.test.js +479 -0
  895. package/dist/hooks/extensibility/__tests__/sdk.test.js.map +1 -0
  896. package/dist/hooks/extensibility/dispatcher.d.ts +4 -0
  897. package/dist/hooks/extensibility/dispatcher.d.ts.map +1 -0
  898. package/dist/hooks/extensibility/dispatcher.js +285 -0
  899. package/dist/hooks/extensibility/dispatcher.js.map +1 -0
  900. package/dist/hooks/extensibility/events.d.ts +18 -0
  901. package/dist/hooks/extensibility/events.d.ts.map +1 -0
  902. package/dist/hooks/extensibility/events.js +53 -0
  903. package/dist/hooks/extensibility/events.js.map +1 -0
  904. package/dist/hooks/extensibility/index.d.ts +6 -0
  905. package/dist/hooks/extensibility/index.d.ts.map +1 -0
  906. package/dist/hooks/extensibility/index.js +6 -0
  907. package/dist/hooks/extensibility/index.js.map +1 -0
  908. package/dist/hooks/extensibility/loader.d.ts +14 -0
  909. package/dist/hooks/extensibility/loader.d.ts.map +1 -0
  910. package/dist/hooks/extensibility/loader.js +117 -0
  911. package/dist/hooks/extensibility/loader.js.map +1 -0
  912. package/dist/hooks/extensibility/logging.d.ts +4 -0
  913. package/dist/hooks/extensibility/logging.d.ts.map +1 -0
  914. package/dist/hooks/extensibility/logging.js +21 -0
  915. package/dist/hooks/extensibility/logging.js.map +1 -0
  916. package/dist/hooks/extensibility/plugin-runner.d.ts +2 -0
  917. package/dist/hooks/extensibility/plugin-runner.d.ts.map +1 -0
  918. package/dist/hooks/extensibility/plugin-runner.js +69 -0
  919. package/dist/hooks/extensibility/plugin-runner.js.map +1 -0
  920. package/dist/hooks/extensibility/runtime.d.ts +3 -0
  921. package/dist/hooks/extensibility/runtime.d.ts.map +1 -0
  922. package/dist/hooks/extensibility/runtime.js +42 -0
  923. package/dist/hooks/extensibility/runtime.js.map +1 -0
  924. package/dist/hooks/extensibility/sdk/logging.d.ts +6 -0
  925. package/dist/hooks/extensibility/sdk/logging.d.ts.map +1 -0
  926. package/dist/hooks/extensibility/sdk/logging.js +32 -0
  927. package/dist/hooks/extensibility/sdk/logging.js.map +1 -0
  928. package/dist/hooks/extensibility/sdk/paths.d.ts +7 -0
  929. package/dist/hooks/extensibility/sdk/paths.d.ts.map +1 -0
  930. package/dist/hooks/extensibility/sdk/paths.js +22 -0
  931. package/dist/hooks/extensibility/sdk/paths.js.map +1 -0
  932. package/dist/hooks/extensibility/sdk/plugin-state.d.ts +5 -0
  933. package/dist/hooks/extensibility/sdk/plugin-state.d.ts.map +1 -0
  934. package/dist/hooks/extensibility/sdk/plugin-state.js +66 -0
  935. package/dist/hooks/extensibility/sdk/plugin-state.js.map +1 -0
  936. package/dist/hooks/extensibility/sdk/runtime-state.d.ts +3 -0
  937. package/dist/hooks/extensibility/sdk/runtime-state.d.ts.map +1 -0
  938. package/dist/hooks/extensibility/sdk/runtime-state.js +47 -0
  939. package/dist/hooks/extensibility/sdk/runtime-state.js.map +1 -0
  940. package/dist/hooks/extensibility/sdk/tmux.d.ts +10 -0
  941. package/dist/hooks/extensibility/sdk/tmux.d.ts.map +1 -0
  942. package/dist/hooks/extensibility/sdk/tmux.js +181 -0
  943. package/dist/hooks/extensibility/sdk/tmux.js.map +1 -0
  944. package/dist/hooks/extensibility/sdk.d.ts +11 -0
  945. package/dist/hooks/extensibility/sdk.d.ts.map +1 -0
  946. package/dist/hooks/extensibility/sdk.js +21 -0
  947. package/dist/hooks/extensibility/sdk.js.map +1 -0
  948. package/dist/hooks/extensibility/types.d.ts +175 -0
  949. package/dist/hooks/extensibility/types.d.ts.map +1 -0
  950. package/dist/hooks/extensibility/types.js +2 -0
  951. package/dist/hooks/extensibility/types.js.map +1 -0
  952. package/dist/hooks/keyword-detector.d.ts +163 -0
  953. package/dist/hooks/keyword-detector.d.ts.map +1 -0
  954. package/dist/hooks/keyword-detector.js +920 -0
  955. package/dist/hooks/keyword-detector.js.map +1 -0
  956. package/dist/hooks/keyword-registry.d.ts +15 -0
  957. package/dist/hooks/keyword-registry.d.ts.map +1 -0
  958. package/dist/hooks/keyword-registry.js +78 -0
  959. package/dist/hooks/keyword-registry.js.map +1 -0
  960. package/dist/hooks/prompt-guidance-contract.d.ts +20 -0
  961. package/dist/hooks/prompt-guidance-contract.d.ts.map +1 -0
  962. package/dist/hooks/prompt-guidance-contract.js +321 -0
  963. package/dist/hooks/prompt-guidance-contract.js.map +1 -0
  964. package/dist/hooks/session.d.ts +72 -0
  965. package/dist/hooks/session.d.ts.map +1 -0
  966. package/dist/hooks/session.js +332 -0
  967. package/dist/hooks/session.js.map +1 -0
  968. package/dist/hooks/task-size-detector.d.ts +72 -0
  969. package/dist/hooks/task-size-detector.d.ts.map +1 -0
  970. package/dist/hooks/task-size-detector.js +202 -0
  971. package/dist/hooks/task-size-detector.js.map +1 -0
  972. package/dist/hooks/triage-config.d.ts +33 -0
  973. package/dist/hooks/triage-config.d.ts.map +1 -0
  974. package/dist/hooks/triage-config.js +87 -0
  975. package/dist/hooks/triage-config.js.map +1 -0
  976. package/dist/hooks/triage-heuristic.d.ts +20 -0
  977. package/dist/hooks/triage-heuristic.d.ts.map +1 -0
  978. package/dist/hooks/triage-heuristic.js +287 -0
  979. package/dist/hooks/triage-heuristic.js.map +1 -0
  980. package/dist/hooks/triage-state.d.ts +63 -0
  981. package/dist/hooks/triage-state.d.ts.map +1 -0
  982. package/dist/hooks/triage-state.js +139 -0
  983. package/dist/hooks/triage-state.js.map +1 -0
  984. package/dist/hud/__tests__/authority.test.d.ts +2 -0
  985. package/dist/hud/__tests__/authority.test.d.ts.map +1 -0
  986. package/dist/hud/__tests__/authority.test.js +56 -0
  987. package/dist/hud/__tests__/authority.test.js.map +1 -0
  988. package/dist/hud/__tests__/colors.test.d.ts +2 -0
  989. package/dist/hud/__tests__/colors.test.d.ts.map +1 -0
  990. package/dist/hud/__tests__/colors.test.js +92 -0
  991. package/dist/hud/__tests__/colors.test.js.map +1 -0
  992. package/dist/hud/__tests__/hud-tmux-injection.test.d.ts +10 -0
  993. package/dist/hud/__tests__/hud-tmux-injection.test.d.ts.map +1 -0
  994. package/dist/hud/__tests__/hud-tmux-injection.test.js +150 -0
  995. package/dist/hud/__tests__/hud-tmux-injection.test.js.map +1 -0
  996. package/dist/hud/__tests__/index.test.d.ts +2 -0
  997. package/dist/hud/__tests__/index.test.d.ts.map +1 -0
  998. package/dist/hud/__tests__/index.test.js +180 -0
  999. package/dist/hud/__tests__/index.test.js.map +1 -0
  1000. package/dist/hud/__tests__/reconcile.test.d.ts +2 -0
  1001. package/dist/hud/__tests__/reconcile.test.d.ts.map +1 -0
  1002. package/dist/hud/__tests__/reconcile.test.js +125 -0
  1003. package/dist/hud/__tests__/reconcile.test.js.map +1 -0
  1004. package/dist/hud/__tests__/render.test.d.ts +2 -0
  1005. package/dist/hud/__tests__/render.test.d.ts.map +1 -0
  1006. package/dist/hud/__tests__/render.test.js +573 -0
  1007. package/dist/hud/__tests__/render.test.js.map +1 -0
  1008. package/dist/hud/__tests__/state.test.d.ts +2 -0
  1009. package/dist/hud/__tests__/state.test.d.ts.map +1 -0
  1010. package/dist/hud/__tests__/state.test.js +618 -0
  1011. package/dist/hud/__tests__/state.test.js.map +1 -0
  1012. package/dist/hud/__tests__/types.test.d.ts +2 -0
  1013. package/dist/hud/__tests__/types.test.d.ts.map +1 -0
  1014. package/dist/hud/__tests__/types.test.js +79 -0
  1015. package/dist/hud/__tests__/types.test.js.map +1 -0
  1016. package/dist/hud/__tests__/watch.test.d.ts +2 -0
  1017. package/dist/hud/__tests__/watch.test.d.ts.map +1 -0
  1018. package/dist/hud/__tests__/watch.test.js +63 -0
  1019. package/dist/hud/__tests__/watch.test.js.map +1 -0
  1020. package/dist/hud/authority.d.ts +17 -0
  1021. package/dist/hud/authority.d.ts.map +1 -0
  1022. package/dist/hud/authority.js +55 -0
  1023. package/dist/hud/authority.js.map +1 -0
  1024. package/dist/hud/colors.d.ts +19 -0
  1025. package/dist/hud/colors.d.ts.map +1 -0
  1026. package/dist/hud/colors.js +56 -0
  1027. package/dist/hud/colors.js.map +1 -0
  1028. package/dist/hud/constants.d.ts +5 -0
  1029. package/dist/hud/constants.d.ts.map +1 -0
  1030. package/dist/hud/constants.js +5 -0
  1031. package/dist/hud/constants.js.map +1 -0
  1032. package/dist/hud/index.d.ts +54 -0
  1033. package/dist/hud/index.d.ts.map +1 -0
  1034. package/dist/hud/index.js +239 -0
  1035. package/dist/hud/index.js.map +1 -0
  1036. package/dist/hud/reconcile.d.ts +25 -0
  1037. package/dist/hud/reconcile.d.ts.map +1 -0
  1038. package/dist/hud/reconcile.js +73 -0
  1039. package/dist/hud/reconcile.js.map +1 -0
  1040. package/dist/hud/render.d.ts +14 -0
  1041. package/dist/hud/render.d.ts.map +1 -0
  1042. package/dist/hud/render.js +312 -0
  1043. package/dist/hud/render.js.map +1 -0
  1044. package/dist/hud/state.d.ts +26 -0
  1045. package/dist/hud/state.d.ts.map +1 -0
  1046. package/dist/hud/state.js +385 -0
  1047. package/dist/hud/state.js.map +1 -0
  1048. package/dist/hud/tmux.d.ts +27 -0
  1049. package/dist/hud/tmux.d.ts.map +1 -0
  1050. package/dist/hud/tmux.js +139 -0
  1051. package/dist/hud/tmux.js.map +1 -0
  1052. package/dist/hud/types.d.ts +130 -0
  1053. package/dist/hud/types.d.ts.map +1 -0
  1054. package/dist/hud/types.js +14 -0
  1055. package/dist/hud/types.js.map +1 -0
  1056. package/dist/index.d.ts +19 -0
  1057. package/dist/index.d.ts.map +1 -0
  1058. package/dist/index.js +19 -0
  1059. package/dist/index.js.map +1 -0
  1060. package/dist/mcp/__tests__/bootstrap.test.d.ts +2 -0
  1061. package/dist/mcp/__tests__/bootstrap.test.d.ts.map +1 -0
  1062. package/dist/mcp/__tests__/bootstrap.test.js +207 -0
  1063. package/dist/mcp/__tests__/bootstrap.test.js.map +1 -0
  1064. package/dist/mcp/__tests__/code-intel-server.test.d.ts +2 -0
  1065. package/dist/mcp/__tests__/code-intel-server.test.d.ts.map +1 -0
  1066. package/dist/mcp/__tests__/code-intel-server.test.js +70 -0
  1067. package/dist/mcp/__tests__/code-intel-server.test.js.map +1 -0
  1068. package/dist/mcp/__tests__/memory-server.test.d.ts +2 -0
  1069. package/dist/mcp/__tests__/memory-server.test.d.ts.map +1 -0
  1070. package/dist/mcp/__tests__/memory-server.test.js +36 -0
  1071. package/dist/mcp/__tests__/memory-server.test.js.map +1 -0
  1072. package/dist/mcp/__tests__/memory-validation.test.d.ts +2 -0
  1073. package/dist/mcp/__tests__/memory-validation.test.d.ts.map +1 -0
  1074. package/dist/mcp/__tests__/memory-validation.test.js +29 -0
  1075. package/dist/mcp/__tests__/memory-validation.test.js.map +1 -0
  1076. package/dist/mcp/__tests__/path-traversal.test.d.ts +2 -0
  1077. package/dist/mcp/__tests__/path-traversal.test.d.ts.map +1 -0
  1078. package/dist/mcp/__tests__/path-traversal.test.js +83 -0
  1079. package/dist/mcp/__tests__/path-traversal.test.js.map +1 -0
  1080. package/dist/mcp/__tests__/server-lifecycle.test.d.ts +2 -0
  1081. package/dist/mcp/__tests__/server-lifecycle.test.d.ts.map +1 -0
  1082. package/dist/mcp/__tests__/server-lifecycle.test.js +260 -0
  1083. package/dist/mcp/__tests__/server-lifecycle.test.js.map +1 -0
  1084. package/dist/mcp/__tests__/state-paths.test.d.ts +2 -0
  1085. package/dist/mcp/__tests__/state-paths.test.d.ts.map +1 -0
  1086. package/dist/mcp/__tests__/state-paths.test.js +209 -0
  1087. package/dist/mcp/__tests__/state-paths.test.js.map +1 -0
  1088. package/dist/mcp/__tests__/state-server-ralph-phase.test.d.ts +2 -0
  1089. package/dist/mcp/__tests__/state-server-ralph-phase.test.d.ts.map +1 -0
  1090. package/dist/mcp/__tests__/state-server-ralph-phase.test.js +109 -0
  1091. package/dist/mcp/__tests__/state-server-ralph-phase.test.js.map +1 -0
  1092. package/dist/mcp/__tests__/state-server-schema.test.d.ts +2 -0
  1093. package/dist/mcp/__tests__/state-server-schema.test.d.ts.map +1 -0
  1094. package/dist/mcp/__tests__/state-server-schema.test.js +29 -0
  1095. package/dist/mcp/__tests__/state-server-schema.test.js.map +1 -0
  1096. package/dist/mcp/__tests__/state-server-team-tools.test.d.ts +2 -0
  1097. package/dist/mcp/__tests__/state-server-team-tools.test.d.ts.map +1 -0
  1098. package/dist/mcp/__tests__/state-server-team-tools.test.js +35 -0
  1099. package/dist/mcp/__tests__/state-server-team-tools.test.js.map +1 -0
  1100. package/dist/mcp/__tests__/state-server.test.d.ts +2 -0
  1101. package/dist/mcp/__tests__/state-server.test.d.ts.map +1 -0
  1102. package/dist/mcp/__tests__/state-server.test.js +965 -0
  1103. package/dist/mcp/__tests__/state-server.test.js.map +1 -0
  1104. package/dist/mcp/__tests__/trace-server.test.d.ts +2 -0
  1105. package/dist/mcp/__tests__/trace-server.test.d.ts.map +1 -0
  1106. package/dist/mcp/__tests__/trace-server.test.js +119 -0
  1107. package/dist/mcp/__tests__/trace-server.test.js.map +1 -0
  1108. package/dist/mcp/__tests__/wiki-server.test.d.ts +2 -0
  1109. package/dist/mcp/__tests__/wiki-server.test.d.ts.map +1 -0
  1110. package/dist/mcp/__tests__/wiki-server.test.js +30 -0
  1111. package/dist/mcp/__tests__/wiki-server.test.js.map +1 -0
  1112. package/dist/mcp/bootstrap.d.ts +39 -0
  1113. package/dist/mcp/bootstrap.d.ts.map +1 -0
  1114. package/dist/mcp/bootstrap.js +335 -0
  1115. package/dist/mcp/bootstrap.js.map +1 -0
  1116. package/dist/mcp/code-intel-server.d.ts +333 -0
  1117. package/dist/mcp/code-intel-server.d.ts.map +1 -0
  1118. package/dist/mcp/code-intel-server.js +605 -0
  1119. package/dist/mcp/code-intel-server.js.map +1 -0
  1120. package/dist/mcp/memory-server.d.ts +201 -0
  1121. package/dist/mcp/memory-server.d.ts.map +1 -0
  1122. package/dist/mcp/memory-server.js +441 -0
  1123. package/dist/mcp/memory-server.js.map +1 -0
  1124. package/dist/mcp/memory-validation.d.ts +9 -0
  1125. package/dist/mcp/memory-validation.d.ts.map +1 -0
  1126. package/dist/mcp/memory-validation.js +11 -0
  1127. package/dist/mcp/memory-validation.js.map +1 -0
  1128. package/dist/mcp/state-paths.d.ts +42 -0
  1129. package/dist/mcp/state-paths.d.ts.map +1 -0
  1130. package/dist/mcp/state-paths.js +290 -0
  1131. package/dist/mcp/state-paths.js.map +1 -0
  1132. package/dist/mcp/state-server.d.ts +222 -0
  1133. package/dist/mcp/state-server.d.ts.map +1 -0
  1134. package/dist/mcp/state-server.js +181 -0
  1135. package/dist/mcp/state-server.js.map +1 -0
  1136. package/dist/mcp/trace-server.d.ts +81 -0
  1137. package/dist/mcp/trace-server.d.ts.map +1 -0
  1138. package/dist/mcp/trace-server.js +271 -0
  1139. package/dist/mcp/trace-server.js.map +1 -0
  1140. package/dist/mcp/wiki-server.d.ts +181 -0
  1141. package/dist/mcp/wiki-server.d.ts.map +1 -0
  1142. package/dist/mcp/wiki-server.js +235 -0
  1143. package/dist/mcp/wiki-server.js.map +1 -0
  1144. package/dist/modes/__tests__/base-autoresearch-contract.test.d.ts +2 -0
  1145. package/dist/modes/__tests__/base-autoresearch-contract.test.d.ts.map +1 -0
  1146. package/dist/modes/__tests__/base-autoresearch-contract.test.js +123 -0
  1147. package/dist/modes/__tests__/base-autoresearch-contract.test.js.map +1 -0
  1148. package/dist/modes/__tests__/base-multi-state-compat.test.d.ts +2 -0
  1149. package/dist/modes/__tests__/base-multi-state-compat.test.d.ts.map +1 -0
  1150. package/dist/modes/__tests__/base-multi-state-compat.test.js +38 -0
  1151. package/dist/modes/__tests__/base-multi-state-compat.test.js.map +1 -0
  1152. package/dist/modes/__tests__/base-ralph-contract.test.d.ts +2 -0
  1153. package/dist/modes/__tests__/base-ralph-contract.test.d.ts.map +1 -0
  1154. package/dist/modes/__tests__/base-ralph-contract.test.js +64 -0
  1155. package/dist/modes/__tests__/base-ralph-contract.test.js.map +1 -0
  1156. package/dist/modes/__tests__/base-session-scope.test.d.ts +2 -0
  1157. package/dist/modes/__tests__/base-session-scope.test.d.ts.map +1 -0
  1158. package/dist/modes/__tests__/base-session-scope.test.js +98 -0
  1159. package/dist/modes/__tests__/base-session-scope.test.js.map +1 -0
  1160. package/dist/modes/__tests__/base-tmux-pane.test.d.ts +2 -0
  1161. package/dist/modes/__tests__/base-tmux-pane.test.d.ts.map +1 -0
  1162. package/dist/modes/__tests__/base-tmux-pane.test.js +39 -0
  1163. package/dist/modes/__tests__/base-tmux-pane.test.js.map +1 -0
  1164. package/dist/modes/base.d.ts +56 -0
  1165. package/dist/modes/base.d.ts.map +1 -0
  1166. package/dist/modes/base.js +241 -0
  1167. package/dist/modes/base.js.map +1 -0
  1168. package/dist/notifications/__tests__/config.test.d.ts +2 -0
  1169. package/dist/notifications/__tests__/config.test.d.ts.map +1 -0
  1170. package/dist/notifications/__tests__/config.test.js +269 -0
  1171. package/dist/notifications/__tests__/config.test.js.map +1 -0
  1172. package/dist/notifications/__tests__/custom-alias-enablement.test.d.ts +2 -0
  1173. package/dist/notifications/__tests__/custom-alias-enablement.test.d.ts.map +1 -0
  1174. package/dist/notifications/__tests__/custom-alias-enablement.test.js +84 -0
  1175. package/dist/notifications/__tests__/custom-alias-enablement.test.js.map +1 -0
  1176. package/dist/notifications/__tests__/dispatch-cooldown.test.d.ts +5 -0
  1177. package/dist/notifications/__tests__/dispatch-cooldown.test.d.ts.map +1 -0
  1178. package/dist/notifications/__tests__/dispatch-cooldown.test.js +100 -0
  1179. package/dist/notifications/__tests__/dispatch-cooldown.test.js.map +1 -0
  1180. package/dist/notifications/__tests__/dispatcher.test.d.ts +2 -0
  1181. package/dist/notifications/__tests__/dispatcher.test.d.ts.map +1 -0
  1182. package/dist/notifications/__tests__/dispatcher.test.js +202 -0
  1183. package/dist/notifications/__tests__/dispatcher.test.js.map +1 -0
  1184. package/dist/notifications/__tests__/formatter.test.d.ts +2 -0
  1185. package/dist/notifications/__tests__/formatter.test.d.ts.map +1 -0
  1186. package/dist/notifications/__tests__/formatter.test.js +270 -0
  1187. package/dist/notifications/__tests__/formatter.test.js.map +1 -0
  1188. package/dist/notifications/__tests__/hook-config.test.d.ts +5 -0
  1189. package/dist/notifications/__tests__/hook-config.test.d.ts.map +1 -0
  1190. package/dist/notifications/__tests__/hook-config.test.js +139 -0
  1191. package/dist/notifications/__tests__/hook-config.test.js.map +1 -0
  1192. package/dist/notifications/__tests__/idle-cooldown.test.d.ts +5 -0
  1193. package/dist/notifications/__tests__/idle-cooldown.test.d.ts.map +1 -0
  1194. package/dist/notifications/__tests__/idle-cooldown.test.js +209 -0
  1195. package/dist/notifications/__tests__/idle-cooldown.test.js.map +1 -0
  1196. package/dist/notifications/__tests__/index.test.d.ts +2 -0
  1197. package/dist/notifications/__tests__/index.test.d.ts.map +1 -0
  1198. package/dist/notifications/__tests__/index.test.js +188 -0
  1199. package/dist/notifications/__tests__/index.test.js.map +1 -0
  1200. package/dist/notifications/__tests__/lifecycle-dedupe.test.d.ts +2 -0
  1201. package/dist/notifications/__tests__/lifecycle-dedupe.test.d.ts.map +1 -0
  1202. package/dist/notifications/__tests__/lifecycle-dedupe.test.js +86 -0
  1203. package/dist/notifications/__tests__/lifecycle-dedupe.test.js.map +1 -0
  1204. package/dist/notifications/__tests__/notifier.test.d.ts +2 -0
  1205. package/dist/notifications/__tests__/notifier.test.d.ts.map +1 -0
  1206. package/dist/notifications/__tests__/notifier.test.js +239 -0
  1207. package/dist/notifications/__tests__/notifier.test.js.map +1 -0
  1208. package/dist/notifications/__tests__/profiles.test.d.ts +2 -0
  1209. package/dist/notifications/__tests__/profiles.test.d.ts.map +1 -0
  1210. package/dist/notifications/__tests__/profiles.test.js +404 -0
  1211. package/dist/notifications/__tests__/profiles.test.js.map +1 -0
  1212. package/dist/notifications/__tests__/reply-config.test.d.ts +2 -0
  1213. package/dist/notifications/__tests__/reply-config.test.d.ts.map +1 -0
  1214. package/dist/notifications/__tests__/reply-config.test.js +79 -0
  1215. package/dist/notifications/__tests__/reply-config.test.js.map +1 -0
  1216. package/dist/notifications/__tests__/reply-listener.test.d.ts +2 -0
  1217. package/dist/notifications/__tests__/reply-listener.test.d.ts.map +1 -0
  1218. package/dist/notifications/__tests__/reply-listener.test.js +723 -0
  1219. package/dist/notifications/__tests__/reply-listener.test.js.map +1 -0
  1220. package/dist/notifications/__tests__/session-idle-tail-dedupe.test.d.ts +2 -0
  1221. package/dist/notifications/__tests__/session-idle-tail-dedupe.test.d.ts.map +1 -0
  1222. package/dist/notifications/__tests__/session-idle-tail-dedupe.test.js +93 -0
  1223. package/dist/notifications/__tests__/session-idle-tail-dedupe.test.js.map +1 -0
  1224. package/dist/notifications/__tests__/session-registry.test.d.ts +2 -0
  1225. package/dist/notifications/__tests__/session-registry.test.d.ts.map +1 -0
  1226. package/dist/notifications/__tests__/session-registry.test.js +234 -0
  1227. package/dist/notifications/__tests__/session-registry.test.js.map +1 -0
  1228. package/dist/notifications/__tests__/session-status.test.d.ts +2 -0
  1229. package/dist/notifications/__tests__/session-status.test.d.ts.map +1 -0
  1230. package/dist/notifications/__tests__/session-status.test.js +249 -0
  1231. package/dist/notifications/__tests__/session-status.test.js.map +1 -0
  1232. package/dist/notifications/__tests__/temp-mode.test.d.ts +2 -0
  1233. package/dist/notifications/__tests__/temp-mode.test.d.ts.map +1 -0
  1234. package/dist/notifications/__tests__/temp-mode.test.js +172 -0
  1235. package/dist/notifications/__tests__/temp-mode.test.js.map +1 -0
  1236. package/dist/notifications/__tests__/template-engine.test.d.ts +5 -0
  1237. package/dist/notifications/__tests__/template-engine.test.d.ts.map +1 -0
  1238. package/dist/notifications/__tests__/template-engine.test.js +158 -0
  1239. package/dist/notifications/__tests__/template-engine.test.js.map +1 -0
  1240. package/dist/notifications/__tests__/tmux-detector.test.d.ts +2 -0
  1241. package/dist/notifications/__tests__/tmux-detector.test.d.ts.map +1 -0
  1242. package/dist/notifications/__tests__/tmux-detector.test.js +208 -0
  1243. package/dist/notifications/__tests__/tmux-detector.test.js.map +1 -0
  1244. package/dist/notifications/__tests__/tmux.test.d.ts +2 -0
  1245. package/dist/notifications/__tests__/tmux.test.d.ts.map +1 -0
  1246. package/dist/notifications/__tests__/tmux.test.js +285 -0
  1247. package/dist/notifications/__tests__/tmux.test.js.map +1 -0
  1248. package/dist/notifications/__tests__/verbosity.test.d.ts +2 -0
  1249. package/dist/notifications/__tests__/verbosity.test.d.ts.map +1 -0
  1250. package/dist/notifications/__tests__/verbosity.test.js +237 -0
  1251. package/dist/notifications/__tests__/verbosity.test.js.map +1 -0
  1252. package/dist/notifications/config.d.ts +65 -0
  1253. package/dist/notifications/config.d.ts.map +1 -0
  1254. package/dist/notifications/config.js +612 -0
  1255. package/dist/notifications/config.js.map +1 -0
  1256. package/dist/notifications/dispatch-cooldown.d.ts +36 -0
  1257. package/dist/notifications/dispatch-cooldown.d.ts.map +1 -0
  1258. package/dist/notifications/dispatch-cooldown.js +109 -0
  1259. package/dist/notifications/dispatch-cooldown.js.map +1 -0
  1260. package/dist/notifications/dispatcher.d.ts +15 -0
  1261. package/dist/notifications/dispatcher.d.ts.map +1 -0
  1262. package/dist/notifications/dispatcher.js +410 -0
  1263. package/dist/notifications/dispatcher.js.map +1 -0
  1264. package/dist/notifications/formatter.d.ts +30 -0
  1265. package/dist/notifications/formatter.d.ts.map +1 -0
  1266. package/dist/notifications/formatter.js +234 -0
  1267. package/dist/notifications/formatter.js.map +1 -0
  1268. package/dist/notifications/hook-config-types.d.ts +43 -0
  1269. package/dist/notifications/hook-config-types.d.ts.map +1 -0
  1270. package/dist/notifications/hook-config-types.js +8 -0
  1271. package/dist/notifications/hook-config-types.js.map +1 -0
  1272. package/dist/notifications/hook-config.d.ts +40 -0
  1273. package/dist/notifications/hook-config.d.ts.map +1 -0
  1274. package/dist/notifications/hook-config.js +127 -0
  1275. package/dist/notifications/hook-config.js.map +1 -0
  1276. package/dist/notifications/idle-cooldown.d.ts +61 -0
  1277. package/dist/notifications/idle-cooldown.d.ts.map +1 -0
  1278. package/dist/notifications/idle-cooldown.js +207 -0
  1279. package/dist/notifications/idle-cooldown.js.map +1 -0
  1280. package/dist/notifications/index.d.ts +40 -0
  1281. package/dist/notifications/index.d.ts.map +1 -0
  1282. package/dist/notifications/index.js +228 -0
  1283. package/dist/notifications/index.js.map +1 -0
  1284. package/dist/notifications/lifecycle-dedupe.d.ts +8 -0
  1285. package/dist/notifications/lifecycle-dedupe.d.ts.map +1 -0
  1286. package/dist/notifications/lifecycle-dedupe.js +112 -0
  1287. package/dist/notifications/lifecycle-dedupe.js.map +1 -0
  1288. package/dist/notifications/notifier.d.ts +44 -0
  1289. package/dist/notifications/notifier.d.ts.map +1 -0
  1290. package/dist/notifications/notifier.js +151 -0
  1291. package/dist/notifications/notifier.js.map +1 -0
  1292. package/dist/notifications/reply-listener.d.ts +123 -0
  1293. package/dist/notifications/reply-listener.d.ts.map +1 -0
  1294. package/dist/notifications/reply-listener.js +846 -0
  1295. package/dist/notifications/reply-listener.js.map +1 -0
  1296. package/dist/notifications/session-registry.d.ts +26 -0
  1297. package/dist/notifications/session-registry.d.ts.map +1 -0
  1298. package/dist/notifications/session-registry.js +293 -0
  1299. package/dist/notifications/session-registry.js.map +1 -0
  1300. package/dist/notifications/session-status.d.ts +25 -0
  1301. package/dist/notifications/session-status.d.ts.map +1 -0
  1302. package/dist/notifications/session-status.js +202 -0
  1303. package/dist/notifications/session-status.js.map +1 -0
  1304. package/dist/notifications/temp-contract.d.ts +22 -0
  1305. package/dist/notifications/temp-contract.d.ts.map +1 -0
  1306. package/dist/notifications/temp-contract.js +147 -0
  1307. package/dist/notifications/temp-contract.js.map +1 -0
  1308. package/dist/notifications/template-engine.d.ts +34 -0
  1309. package/dist/notifications/template-engine.d.ts.map +1 -0
  1310. package/dist/notifications/template-engine.js +249 -0
  1311. package/dist/notifications/template-engine.js.map +1 -0
  1312. package/dist/notifications/tmux-detector.d.ts +59 -0
  1313. package/dist/notifications/tmux-detector.d.ts.map +1 -0
  1314. package/dist/notifications/tmux-detector.js +129 -0
  1315. package/dist/notifications/tmux-detector.js.map +1 -0
  1316. package/dist/notifications/tmux.d.ts +44 -0
  1317. package/dist/notifications/tmux.d.ts.map +1 -0
  1318. package/dist/notifications/tmux.js +293 -0
  1319. package/dist/notifications/tmux.js.map +1 -0
  1320. package/dist/notifications/types.d.ts +224 -0
  1321. package/dist/notifications/types.d.ts.map +1 -0
  1322. package/dist/notifications/types.js +9 -0
  1323. package/dist/notifications/types.js.map +1 -0
  1324. package/dist/openclaw/__tests__/config.test.d.ts +6 -0
  1325. package/dist/openclaw/__tests__/config.test.d.ts.map +1 -0
  1326. package/dist/openclaw/__tests__/config.test.js +344 -0
  1327. package/dist/openclaw/__tests__/config.test.js.map +1 -0
  1328. package/dist/openclaw/__tests__/dispatcher.test.d.ts +5 -0
  1329. package/dist/openclaw/__tests__/dispatcher.test.d.ts.map +1 -0
  1330. package/dist/openclaw/__tests__/dispatcher.test.js +169 -0
  1331. package/dist/openclaw/__tests__/dispatcher.test.js.map +1 -0
  1332. package/dist/openclaw/__tests__/index.test.d.ts +6 -0
  1333. package/dist/openclaw/__tests__/index.test.d.ts.map +1 -0
  1334. package/dist/openclaw/__tests__/index.test.js +382 -0
  1335. package/dist/openclaw/__tests__/index.test.js.map +1 -0
  1336. package/dist/openclaw/config.d.ts +59 -0
  1337. package/dist/openclaw/config.d.ts.map +1 -0
  1338. package/dist/openclaw/config.js +400 -0
  1339. package/dist/openclaw/config.js.map +1 -0
  1340. package/dist/openclaw/dispatcher.d.ts +72 -0
  1341. package/dist/openclaw/dispatcher.d.ts.map +1 -0
  1342. package/dist/openclaw/dispatcher.js +259 -0
  1343. package/dist/openclaw/dispatcher.js.map +1 -0
  1344. package/dist/openclaw/index.d.ts +29 -0
  1345. package/dist/openclaw/index.d.ts.map +1 -0
  1346. package/dist/openclaw/index.js +149 -0
  1347. package/dist/openclaw/index.js.map +1 -0
  1348. package/dist/openclaw/types.d.ts +123 -0
  1349. package/dist/openclaw/types.d.ts.map +1 -0
  1350. package/dist/openclaw/types.js +12 -0
  1351. package/dist/openclaw/types.js.map +1 -0
  1352. package/dist/pipeline/__tests__/orchestrator.test.d.ts +2 -0
  1353. package/dist/pipeline/__tests__/orchestrator.test.d.ts.map +1 -0
  1354. package/dist/pipeline/__tests__/orchestrator.test.js +505 -0
  1355. package/dist/pipeline/__tests__/orchestrator.test.js.map +1 -0
  1356. package/dist/pipeline/__tests__/stages.test.d.ts +2 -0
  1357. package/dist/pipeline/__tests__/stages.test.d.ts.map +1 -0
  1358. package/dist/pipeline/__tests__/stages.test.js +754 -0
  1359. package/dist/pipeline/__tests__/stages.test.js.map +1 -0
  1360. package/dist/pipeline/index.d.ts +19 -0
  1361. package/dist/pipeline/index.d.ts.map +1 -0
  1362. package/dist/pipeline/index.js +14 -0
  1363. package/dist/pipeline/index.js.map +1 -0
  1364. package/dist/pipeline/orchestrator.d.ts +51 -0
  1365. package/dist/pipeline/orchestrator.d.ts.map +1 -0
  1366. package/dist/pipeline/orchestrator.js +324 -0
  1367. package/dist/pipeline/orchestrator.js.map +1 -0
  1368. package/dist/pipeline/review-verdict.d.ts +3 -0
  1369. package/dist/pipeline/review-verdict.d.ts.map +1 -0
  1370. package/dist/pipeline/review-verdict.js +14 -0
  1371. package/dist/pipeline/review-verdict.js.map +1 -0
  1372. package/dist/pipeline/stages/code-review.d.ts +33 -0
  1373. package/dist/pipeline/stages/code-review.d.ts.map +1 -0
  1374. package/dist/pipeline/stages/code-review.js +51 -0
  1375. package/dist/pipeline/stages/code-review.js.map +1 -0
  1376. package/dist/pipeline/stages/ralph-verify.d.ts +53 -0
  1377. package/dist/pipeline/stages/ralph-verify.d.ts.map +1 -0
  1378. package/dist/pipeline/stages/ralph-verify.js +89 -0
  1379. package/dist/pipeline/stages/ralph-verify.js.map +1 -0
  1380. package/dist/pipeline/stages/ralplan.d.ts +25 -0
  1381. package/dist/pipeline/stages/ralplan.d.ts.map +1 -0
  1382. package/dist/pipeline/stages/ralplan.js +107 -0
  1383. package/dist/pipeline/stages/ralplan.js.map +1 -0
  1384. package/dist/pipeline/stages/team-exec.d.ts +50 -0
  1385. package/dist/pipeline/stages/team-exec.d.ts.map +1 -0
  1386. package/dist/pipeline/stages/team-exec.js +263 -0
  1387. package/dist/pipeline/stages/team-exec.js.map +1 -0
  1388. package/dist/pipeline/types.d.ts +122 -0
  1389. package/dist/pipeline/types.d.ts.map +1 -0
  1390. package/dist/pipeline/types.js +8 -0
  1391. package/dist/pipeline/types.js.map +1 -0
  1392. package/dist/planning/__tests__/artifacts.test.d.ts +2 -0
  1393. package/dist/planning/__tests__/artifacts.test.d.ts.map +1 -0
  1394. package/dist/planning/__tests__/artifacts.test.js +544 -0
  1395. package/dist/planning/__tests__/artifacts.test.js.map +1 -0
  1396. package/dist/planning/artifact-names.d.ts +13 -0
  1397. package/dist/planning/artifact-names.d.ts.map +1 -0
  1398. package/dist/planning/artifact-names.js +108 -0
  1399. package/dist/planning/artifact-names.js.map +1 -0
  1400. package/dist/planning/artifacts.d.ts +61 -0
  1401. package/dist/planning/artifacts.d.ts.map +1 -0
  1402. package/dist/planning/artifacts.js +308 -0
  1403. package/dist/planning/artifacts.js.map +1 -0
  1404. package/dist/question/__tests__/client.test.d.ts +2 -0
  1405. package/dist/question/__tests__/client.test.d.ts.map +1 -0
  1406. package/dist/question/__tests__/client.test.js +90 -0
  1407. package/dist/question/__tests__/client.test.js.map +1 -0
  1408. package/dist/question/__tests__/deep-interview.test.d.ts +2 -0
  1409. package/dist/question/__tests__/deep-interview.test.d.ts.map +1 -0
  1410. package/dist/question/__tests__/deep-interview.test.js +209 -0
  1411. package/dist/question/__tests__/deep-interview.test.js.map +1 -0
  1412. package/dist/question/__tests__/policy.test.d.ts +2 -0
  1413. package/dist/question/__tests__/policy.test.d.ts.map +1 -0
  1414. package/dist/question/__tests__/policy.test.js +107 -0
  1415. package/dist/question/__tests__/policy.test.js.map +1 -0
  1416. package/dist/question/__tests__/renderer.test.d.ts +2 -0
  1417. package/dist/question/__tests__/renderer.test.d.ts.map +1 -0
  1418. package/dist/question/__tests__/renderer.test.js +707 -0
  1419. package/dist/question/__tests__/renderer.test.js.map +1 -0
  1420. package/dist/question/__tests__/state.test.d.ts +2 -0
  1421. package/dist/question/__tests__/state.test.d.ts.map +1 -0
  1422. package/dist/question/__tests__/state.test.js +102 -0
  1423. package/dist/question/__tests__/state.test.js.map +1 -0
  1424. package/dist/question/__tests__/types.test.d.ts +2 -0
  1425. package/dist/question/__tests__/types.test.d.ts.map +1 -0
  1426. package/dist/question/__tests__/types.test.js +65 -0
  1427. package/dist/question/__tests__/types.test.js.map +1 -0
  1428. package/dist/question/__tests__/ui.test.d.ts +2 -0
  1429. package/dist/question/__tests__/ui.test.d.ts.map +1 -0
  1430. package/dist/question/__tests__/ui.test.js +446 -0
  1431. package/dist/question/__tests__/ui.test.js.map +1 -0
  1432. package/dist/question/client.d.ts +64 -0
  1433. package/dist/question/client.d.ts.map +1 -0
  1434. package/dist/question/client.js +77 -0
  1435. package/dist/question/client.js.map +1 -0
  1436. package/dist/question/deep-interview.d.ts +31 -0
  1437. package/dist/question/deep-interview.d.ts.map +1 -0
  1438. package/dist/question/deep-interview.js +196 -0
  1439. package/dist/question/deep-interview.js.map +1 -0
  1440. package/dist/question/policy.d.ts +18 -0
  1441. package/dist/question/policy.d.ts.map +1 -0
  1442. package/dist/question/policy.js +77 -0
  1443. package/dist/question/policy.js.map +1 -0
  1444. package/dist/question/renderer.d.ts +46 -0
  1445. package/dist/question/renderer.d.ts.map +1 -0
  1446. package/dist/question/renderer.js +498 -0
  1447. package/dist/question/renderer.js.map +1 -0
  1448. package/dist/question/state.d.ts +21 -0
  1449. package/dist/question/state.d.ts.map +1 -0
  1450. package/dist/question/state.js +121 -0
  1451. package/dist/question/state.js.map +1 -0
  1452. package/dist/question/types.d.ts +91 -0
  1453. package/dist/question/types.d.ts.map +1 -0
  1454. package/dist/question/types.js +117 -0
  1455. package/dist/question/types.js.map +1 -0
  1456. package/dist/question/ui.d.ts +53 -0
  1457. package/dist/question/ui.d.ts.map +1 -0
  1458. package/dist/question/ui.js +435 -0
  1459. package/dist/question/ui.js.map +1 -0
  1460. package/dist/ralph/__tests__/persistence.test.d.ts +2 -0
  1461. package/dist/ralph/__tests__/persistence.test.d.ts.map +1 -0
  1462. package/dist/ralph/__tests__/persistence.test.js +116 -0
  1463. package/dist/ralph/__tests__/persistence.test.js.map +1 -0
  1464. package/dist/ralph/contract.d.ts +17 -0
  1465. package/dist/ralph/contract.d.ts.map +1 -0
  1466. package/dist/ralph/contract.js +108 -0
  1467. package/dist/ralph/contract.js.map +1 -0
  1468. package/dist/ralph/persistence.d.ts +29 -0
  1469. package/dist/ralph/persistence.d.ts.map +1 -0
  1470. package/dist/ralph/persistence.js +267 -0
  1471. package/dist/ralph/persistence.js.map +1 -0
  1472. package/dist/ralplan/__tests__/runtime.test.d.ts +2 -0
  1473. package/dist/ralplan/__tests__/runtime.test.d.ts.map +1 -0
  1474. package/dist/ralplan/__tests__/runtime.test.js +165 -0
  1475. package/dist/ralplan/__tests__/runtime.test.js.map +1 -0
  1476. package/dist/ralplan/runtime.d.ts +52 -0
  1477. package/dist/ralplan/runtime.d.ts.map +1 -0
  1478. package/dist/ralplan/runtime.js +202 -0
  1479. package/dist/ralplan/runtime.js.map +1 -0
  1480. package/dist/runtime/__tests__/bridge.test.d.ts +2 -0
  1481. package/dist/runtime/__tests__/bridge.test.d.ts.map +1 -0
  1482. package/dist/runtime/__tests__/bridge.test.js +194 -0
  1483. package/dist/runtime/__tests__/bridge.test.js.map +1 -0
  1484. package/dist/runtime/__tests__/run-loop.test.d.ts +2 -0
  1485. package/dist/runtime/__tests__/run-loop.test.d.ts.map +1 -0
  1486. package/dist/runtime/__tests__/run-loop.test.js +35 -0
  1487. package/dist/runtime/__tests__/run-loop.test.js.map +1 -0
  1488. package/dist/runtime/__tests__/run-outcome.test.d.ts +2 -0
  1489. package/dist/runtime/__tests__/run-outcome.test.d.ts.map +1 -0
  1490. package/dist/runtime/__tests__/run-outcome.test.js +102 -0
  1491. package/dist/runtime/__tests__/run-outcome.test.js.map +1 -0
  1492. package/dist/runtime/__tests__/run-state.test.d.ts +2 -0
  1493. package/dist/runtime/__tests__/run-state.test.d.ts.map +1 -0
  1494. package/dist/runtime/__tests__/run-state.test.js +37 -0
  1495. package/dist/runtime/__tests__/run-state.test.js.map +1 -0
  1496. package/dist/runtime/bridge.d.ts +214 -0
  1497. package/dist/runtime/bridge.d.ts.map +1 -0
  1498. package/dist/runtime/bridge.js +223 -0
  1499. package/dist/runtime/bridge.js.map +1 -0
  1500. package/dist/runtime/run-loop.d.ts +45 -0
  1501. package/dist/runtime/run-loop.d.ts.map +1 -0
  1502. package/dist/runtime/run-loop.js +51 -0
  1503. package/dist/runtime/run-loop.js.map +1 -0
  1504. package/dist/runtime/run-outcome.d.ts +46 -0
  1505. package/dist/runtime/run-outcome.d.ts.map +1 -0
  1506. package/dist/runtime/run-outcome.js +285 -0
  1507. package/dist/runtime/run-outcome.js.map +1 -0
  1508. package/dist/runtime/run-state.d.ts +40 -0
  1509. package/dist/runtime/run-state.d.ts.map +1 -0
  1510. package/dist/runtime/run-state.js +120 -0
  1511. package/dist/runtime/run-state.js.map +1 -0
  1512. package/dist/runtime/terminal-lifecycle.d.ts +11 -0
  1513. package/dist/runtime/terminal-lifecycle.d.ts.map +1 -0
  1514. package/dist/runtime/terminal-lifecycle.js +52 -0
  1515. package/dist/runtime/terminal-lifecycle.js.map +1 -0
  1516. package/dist/scripts/__tests__/codex-native-hook.test.d.ts +2 -0
  1517. package/dist/scripts/__tests__/codex-native-hook.test.d.ts.map +1 -0
  1518. package/dist/scripts/__tests__/codex-native-hook.test.js +6788 -0
  1519. package/dist/scripts/__tests__/codex-native-hook.test.js.map +1 -0
  1520. package/dist/scripts/__tests__/generate-release-body.test.d.ts +2 -0
  1521. package/dist/scripts/__tests__/generate-release-body.test.d.ts.map +1 -0
  1522. package/dist/scripts/__tests__/generate-release-body.test.js +233 -0
  1523. package/dist/scripts/__tests__/generate-release-body.test.js.map +1 -0
  1524. package/dist/scripts/__tests__/hook-derived-watcher.test.d.ts +2 -0
  1525. package/dist/scripts/__tests__/hook-derived-watcher.test.d.ts.map +1 -0
  1526. package/dist/scripts/__tests__/hook-derived-watcher.test.js +195 -0
  1527. package/dist/scripts/__tests__/hook-derived-watcher.test.js.map +1 -0
  1528. package/dist/scripts/__tests__/postinstall.test.d.ts +2 -0
  1529. package/dist/scripts/__tests__/postinstall.test.d.ts.map +1 -0
  1530. package/dist/scripts/__tests__/postinstall.test.js +92 -0
  1531. package/dist/scripts/__tests__/postinstall.test.js.map +1 -0
  1532. package/dist/scripts/__tests__/prompt-inventory.test.d.ts +2 -0
  1533. package/dist/scripts/__tests__/prompt-inventory.test.d.ts.map +1 -0
  1534. package/dist/scripts/__tests__/prompt-inventory.test.js +56 -0
  1535. package/dist/scripts/__tests__/prompt-inventory.test.js.map +1 -0
  1536. package/dist/scripts/__tests__/run-test-files.test.d.ts +2 -0
  1537. package/dist/scripts/__tests__/run-test-files.test.d.ts.map +1 -0
  1538. package/dist/scripts/__tests__/run-test-files.test.js +62 -0
  1539. package/dist/scripts/__tests__/run-test-files.test.js.map +1 -0
  1540. package/dist/scripts/__tests__/smoke-packed-install.test.d.ts +2 -0
  1541. package/dist/scripts/__tests__/smoke-packed-install.test.d.ts.map +1 -0
  1542. package/dist/scripts/__tests__/smoke-packed-install.test.js +135 -0
  1543. package/dist/scripts/__tests__/smoke-packed-install.test.js.map +1 -0
  1544. package/dist/scripts/__tests__/test-reply-listener-live.test.d.ts +2 -0
  1545. package/dist/scripts/__tests__/test-reply-listener-live.test.d.ts.map +1 -0
  1546. package/dist/scripts/__tests__/test-reply-listener-live.test.js +82 -0
  1547. package/dist/scripts/__tests__/test-reply-listener-live.test.js.map +1 -0
  1548. package/dist/scripts/__tests__/verify-native-agents.test.d.ts +2 -0
  1549. package/dist/scripts/__tests__/verify-native-agents.test.d.ts.map +1 -0
  1550. package/dist/scripts/__tests__/verify-native-agents.test.js +166 -0
  1551. package/dist/scripts/__tests__/verify-native-agents.test.js.map +1 -0
  1552. package/dist/scripts/build-explore-harness.d.ts +3 -0
  1553. package/dist/scripts/build-explore-harness.d.ts.map +1 -0
  1554. package/dist/scripts/build-explore-harness.js +50 -0
  1555. package/dist/scripts/build-explore-harness.js.map +1 -0
  1556. package/dist/scripts/build-sparkshell.d.ts +2 -0
  1557. package/dist/scripts/build-sparkshell.d.ts.map +1 -0
  1558. package/dist/scripts/build-sparkshell.js +46 -0
  1559. package/dist/scripts/build-sparkshell.js.map +1 -0
  1560. package/dist/scripts/check-runtime-syntax.d.ts +3 -0
  1561. package/dist/scripts/check-runtime-syntax.d.ts.map +1 -0
  1562. package/dist/scripts/check-runtime-syntax.js +57 -0
  1563. package/dist/scripts/check-runtime-syntax.js.map +1 -0
  1564. package/dist/scripts/check-version-sync.d.ts +3 -0
  1565. package/dist/scripts/check-version-sync.d.ts.map +1 -0
  1566. package/dist/scripts/check-version-sync.js +49 -0
  1567. package/dist/scripts/check-version-sync.js.map +1 -0
  1568. package/dist/scripts/cleanup-explore-harness.d.ts +3 -0
  1569. package/dist/scripts/cleanup-explore-harness.d.ts.map +1 -0
  1570. package/dist/scripts/cleanup-explore-harness.js +16 -0
  1571. package/dist/scripts/cleanup-explore-harness.js.map +1 -0
  1572. package/dist/scripts/codex-execution-surface.d.ts +16 -0
  1573. package/dist/scripts/codex-execution-surface.d.ts.map +1 -0
  1574. package/dist/scripts/codex-execution-surface.js +42 -0
  1575. package/dist/scripts/codex-execution-surface.js.map +1 -0
  1576. package/dist/scripts/codex-native-hook.d.ts +25 -0
  1577. package/dist/scripts/codex-native-hook.d.ts.map +1 -0
  1578. package/dist/scripts/codex-native-hook.js +1879 -0
  1579. package/dist/scripts/codex-native-hook.js.map +1 -0
  1580. package/dist/scripts/codex-native-pre-post.d.ts +39 -0
  1581. package/dist/scripts/codex-native-pre-post.d.ts.map +1 -0
  1582. package/dist/scripts/codex-native-pre-post.js +824 -0
  1583. package/dist/scripts/codex-native-pre-post.js.map +1 -0
  1584. package/dist/scripts/eval/eval-candidate-handoff.d.ts +2 -0
  1585. package/dist/scripts/eval/eval-candidate-handoff.d.ts.map +1 -0
  1586. package/dist/scripts/eval/eval-candidate-handoff.js +11 -0
  1587. package/dist/scripts/eval/eval-candidate-handoff.js.map +1 -0
  1588. package/dist/scripts/eval/eval-cli-discoverability.d.ts +3 -0
  1589. package/dist/scripts/eval/eval-cli-discoverability.d.ts.map +1 -0
  1590. package/dist/scripts/eval/eval-cli-discoverability.js +37 -0
  1591. package/dist/scripts/eval/eval-cli-discoverability.js.map +1 -0
  1592. package/dist/scripts/eval/eval-fresh-run-tagging.d.ts +2 -0
  1593. package/dist/scripts/eval/eval-fresh-run-tagging.d.ts.map +1 -0
  1594. package/dist/scripts/eval/eval-fresh-run-tagging.js +11 -0
  1595. package/dist/scripts/eval/eval-fresh-run-tagging.js.map +1 -0
  1596. package/dist/scripts/eval/eval-help-consistency.d.ts +2 -0
  1597. package/dist/scripts/eval/eval-help-consistency.d.ts.map +1 -0
  1598. package/dist/scripts/eval/eval-help-consistency.js +12 -0
  1599. package/dist/scripts/eval/eval-help-consistency.js.map +1 -0
  1600. package/dist/scripts/eval/eval-in-action-cat-shellout-demo.d.ts +2 -0
  1601. package/dist/scripts/eval/eval-in-action-cat-shellout-demo.d.ts.map +1 -0
  1602. package/dist/scripts/eval/eval-in-action-cat-shellout-demo.js +31 -0
  1603. package/dist/scripts/eval/eval-in-action-cat-shellout-demo.js.map +1 -0
  1604. package/dist/scripts/eval/eval-parity-smoke.d.ts +2 -0
  1605. package/dist/scripts/eval/eval-parity-smoke.d.ts.map +1 -0
  1606. package/dist/scripts/eval/eval-parity-smoke.js +23 -0
  1607. package/dist/scripts/eval/eval-parity-smoke.js.map +1 -0
  1608. package/dist/scripts/eval/eval-parity-sweep.d.ts +2 -0
  1609. package/dist/scripts/eval/eval-parity-sweep.d.ts.map +1 -0
  1610. package/dist/scripts/eval/eval-parity-sweep.js +29 -0
  1611. package/dist/scripts/eval/eval-parity-sweep.js.map +1 -0
  1612. package/dist/scripts/eval/eval-resume-dirty-guard.d.ts +2 -0
  1613. package/dist/scripts/eval/eval-resume-dirty-guard.d.ts.map +1 -0
  1614. package/dist/scripts/eval/eval-resume-dirty-guard.js +11 -0
  1615. package/dist/scripts/eval/eval-resume-dirty-guard.js.map +1 -0
  1616. package/dist/scripts/eval/eval-security-path-traversal.d.ts +3 -0
  1617. package/dist/scripts/eval/eval-security-path-traversal.d.ts.map +1 -0
  1618. package/dist/scripts/eval/eval-security-path-traversal.js +35 -0
  1619. package/dist/scripts/eval/eval-security-path-traversal.js.map +1 -0
  1620. package/dist/scripts/fixtures/ask-advisor-stub.d.ts +3 -0
  1621. package/dist/scripts/fixtures/ask-advisor-stub.d.ts.map +1 -0
  1622. package/dist/scripts/fixtures/ask-advisor-stub.js +13 -0
  1623. package/dist/scripts/fixtures/ask-advisor-stub.js.map +1 -0
  1624. package/dist/scripts/generate-catalog-docs.d.ts +3 -0
  1625. package/dist/scripts/generate-catalog-docs.d.ts.map +1 -0
  1626. package/dist/scripts/generate-catalog-docs.js +99 -0
  1627. package/dist/scripts/generate-catalog-docs.js.map +1 -0
  1628. package/dist/scripts/generate-native-release-manifest.d.ts +3 -0
  1629. package/dist/scripts/generate-native-release-manifest.d.ts.map +1 -0
  1630. package/dist/scripts/generate-native-release-manifest.js +107 -0
  1631. package/dist/scripts/generate-native-release-manifest.js.map +1 -0
  1632. package/dist/scripts/generate-release-body.d.ts +35 -0
  1633. package/dist/scripts/generate-release-body.d.ts.map +1 -0
  1634. package/dist/scripts/generate-release-body.js +278 -0
  1635. package/dist/scripts/generate-release-body.js.map +1 -0
  1636. package/dist/scripts/hook-derived-watcher.d.ts +3 -0
  1637. package/dist/scripts/hook-derived-watcher.d.ts.map +1 -0
  1638. package/dist/scripts/hook-derived-watcher.js +556 -0
  1639. package/dist/scripts/hook-derived-watcher.js.map +1 -0
  1640. package/dist/scripts/notify-fallback-watcher.d.ts +3 -0
  1641. package/dist/scripts/notify-fallback-watcher.d.ts.map +1 -0
  1642. package/dist/scripts/notify-fallback-watcher.js +1755 -0
  1643. package/dist/scripts/notify-fallback-watcher.js.map +1 -0
  1644. package/dist/scripts/notify-hook/__tests__/operational-events.test.d.ts +2 -0
  1645. package/dist/scripts/notify-hook/__tests__/operational-events.test.d.ts.map +1 -0
  1646. package/dist/scripts/notify-hook/__tests__/operational-events.test.js +24 -0
  1647. package/dist/scripts/notify-hook/__tests__/operational-events.test.js.map +1 -0
  1648. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.d.ts +2 -0
  1649. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.d.ts.map +1 -0
  1650. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.js +153 -0
  1651. package/dist/scripts/notify-hook/__tests__/team-worker-posttooluse.test.js.map +1 -0
  1652. package/dist/scripts/notify-hook/active-team.d.ts +9 -0
  1653. package/dist/scripts/notify-hook/active-team.d.ts.map +1 -0
  1654. package/dist/scripts/notify-hook/active-team.js +45 -0
  1655. package/dist/scripts/notify-hook/active-team.js.map +1 -0
  1656. package/dist/scripts/notify-hook/auto-nudge.d.ts +96 -0
  1657. package/dist/scripts/notify-hook/auto-nudge.d.ts.map +1 -0
  1658. package/dist/scripts/notify-hook/auto-nudge.js +696 -0
  1659. package/dist/scripts/notify-hook/auto-nudge.js.map +1 -0
  1660. package/dist/scripts/notify-hook/log.d.ts +6 -0
  1661. package/dist/scripts/notify-hook/log.d.ts.map +1 -0
  1662. package/dist/scripts/notify-hook/log.js +22 -0
  1663. package/dist/scripts/notify-hook/log.js.map +1 -0
  1664. package/dist/scripts/notify-hook/managed-tmux.d.ts +21 -0
  1665. package/dist/scripts/notify-hook/managed-tmux.d.ts.map +1 -0
  1666. package/dist/scripts/notify-hook/managed-tmux.js +556 -0
  1667. package/dist/scripts/notify-hook/managed-tmux.js.map +1 -0
  1668. package/dist/scripts/notify-hook/operational-events.d.ts +14 -0
  1669. package/dist/scripts/notify-hook/operational-events.d.ts.map +1 -0
  1670. package/dist/scripts/notify-hook/operational-events.js +255 -0
  1671. package/dist/scripts/notify-hook/operational-events.js.map +1 -0
  1672. package/dist/scripts/notify-hook/orchestration-intent.d.ts +18 -0
  1673. package/dist/scripts/notify-hook/orchestration-intent.d.ts.map +1 -0
  1674. package/dist/scripts/notify-hook/orchestration-intent.js +72 -0
  1675. package/dist/scripts/notify-hook/orchestration-intent.js.map +1 -0
  1676. package/dist/scripts/notify-hook/payload-parser.d.ts +13 -0
  1677. package/dist/scripts/notify-hook/payload-parser.d.ts.map +1 -0
  1678. package/dist/scripts/notify-hook/payload-parser.js +134 -0
  1679. package/dist/scripts/notify-hook/payload-parser.js.map +1 -0
  1680. package/dist/scripts/notify-hook/process-runner.d.ts +9 -0
  1681. package/dist/scripts/notify-hook/process-runner.d.ts.map +1 -0
  1682. package/dist/scripts/notify-hook/process-runner.js +102 -0
  1683. package/dist/scripts/notify-hook/process-runner.js.map +1 -0
  1684. package/dist/scripts/notify-hook/ralph-session-resume.d.ts +22 -0
  1685. package/dist/scripts/notify-hook/ralph-session-resume.d.ts.map +1 -0
  1686. package/dist/scripts/notify-hook/ralph-session-resume.js +300 -0
  1687. package/dist/scripts/notify-hook/ralph-session-resume.js.map +1 -0
  1688. package/dist/scripts/notify-hook/state-io.d.ts +21 -0
  1689. package/dist/scripts/notify-hook/state-io.d.ts.map +1 -0
  1690. package/dist/scripts/notify-hook/state-io.js +144 -0
  1691. package/dist/scripts/notify-hook/state-io.js.map +1 -0
  1692. package/dist/scripts/notify-hook/team-dispatch.d.ts +36 -0
  1693. package/dist/scripts/notify-hook/team-dispatch.d.ts.map +1 -0
  1694. package/dist/scripts/notify-hook/team-dispatch.js +1065 -0
  1695. package/dist/scripts/notify-hook/team-dispatch.js.map +1 -0
  1696. package/dist/scripts/notify-hook/team-leader-nudge.d.ts +23 -0
  1697. package/dist/scripts/notify-hook/team-leader-nudge.d.ts.map +1 -0
  1698. package/dist/scripts/notify-hook/team-leader-nudge.js +1055 -0
  1699. package/dist/scripts/notify-hook/team-leader-nudge.js.map +1 -0
  1700. package/dist/scripts/notify-hook/team-tmux-guard.d.ts +14 -0
  1701. package/dist/scripts/notify-hook/team-tmux-guard.d.ts.map +1 -0
  1702. package/dist/scripts/notify-hook/team-tmux-guard.js +161 -0
  1703. package/dist/scripts/notify-hook/team-tmux-guard.js.map +1 -0
  1704. package/dist/scripts/notify-hook/team-worker-posttooluse.d.ts +34 -0
  1705. package/dist/scripts/notify-hook/team-worker-posttooluse.d.ts.map +1 -0
  1706. package/dist/scripts/notify-hook/team-worker-posttooluse.js +434 -0
  1707. package/dist/scripts/notify-hook/team-worker-posttooluse.js.map +1 -0
  1708. package/dist/scripts/notify-hook/team-worker.d.ts +33 -0
  1709. package/dist/scripts/notify-hook/team-worker.d.ts.map +1 -0
  1710. package/dist/scripts/notify-hook/team-worker.js +697 -0
  1711. package/dist/scripts/notify-hook/team-worker.js.map +1 -0
  1712. package/dist/scripts/notify-hook/tmux-injection.d.ts +8 -0
  1713. package/dist/scripts/notify-hook/tmux-injection.d.ts.map +1 -0
  1714. package/dist/scripts/notify-hook/tmux-injection.js +578 -0
  1715. package/dist/scripts/notify-hook/tmux-injection.js.map +1 -0
  1716. package/dist/scripts/notify-hook/utils.d.ts +9 -0
  1717. package/dist/scripts/notify-hook/utils.d.ts.map +1 -0
  1718. package/dist/scripts/notify-hook/utils.js +36 -0
  1719. package/dist/scripts/notify-hook/utils.js.map +1 -0
  1720. package/dist/scripts/notify-hook/visual-verdict.d.ts +29 -0
  1721. package/dist/scripts/notify-hook/visual-verdict.d.ts.map +1 -0
  1722. package/dist/scripts/notify-hook/visual-verdict.js +145 -0
  1723. package/dist/scripts/notify-hook/visual-verdict.js.map +1 -0
  1724. package/dist/scripts/notify-hook.d.ts +20 -0
  1725. package/dist/scripts/notify-hook.d.ts.map +1 -0
  1726. package/dist/scripts/notify-hook.js +716 -0
  1727. package/dist/scripts/notify-hook.js.map +1 -0
  1728. package/dist/scripts/postinstall.d.ts +18 -0
  1729. package/dist/scripts/postinstall.d.ts.map +1 -0
  1730. package/dist/scripts/postinstall.js +66 -0
  1731. package/dist/scripts/postinstall.js.map +1 -0
  1732. package/dist/scripts/prompt-inventory.d.ts +29 -0
  1733. package/dist/scripts/prompt-inventory.d.ts.map +1 -0
  1734. package/dist/scripts/prompt-inventory.js +178 -0
  1735. package/dist/scripts/prompt-inventory.js.map +1 -0
  1736. package/dist/scripts/run-provider-advisor.d.ts +3 -0
  1737. package/dist/scripts/run-provider-advisor.d.ts.map +1 -0
  1738. package/dist/scripts/run-provider-advisor.js +171 -0
  1739. package/dist/scripts/run-provider-advisor.js.map +1 -0
  1740. package/dist/scripts/run-test-files.d.ts +2 -0
  1741. package/dist/scripts/run-test-files.d.ts.map +1 -0
  1742. package/dist/scripts/run-test-files.js +71 -0
  1743. package/dist/scripts/run-test-files.js.map +1 -0
  1744. package/dist/scripts/smoke-packed-install.d.ts +18 -0
  1745. package/dist/scripts/smoke-packed-install.d.ts.map +1 -0
  1746. package/dist/scripts/smoke-packed-install.js +144 -0
  1747. package/dist/scripts/smoke-packed-install.js.map +1 -0
  1748. package/dist/scripts/sync-plugin-mirror.d.ts +14 -0
  1749. package/dist/scripts/sync-plugin-mirror.d.ts.map +1 -0
  1750. package/dist/scripts/sync-plugin-mirror.js +282 -0
  1751. package/dist/scripts/sync-plugin-mirror.js.map +1 -0
  1752. package/dist/scripts/sync-prompt-guidance-fragments.d.ts +3 -0
  1753. package/dist/scripts/sync-prompt-guidance-fragments.d.ts.map +1 -0
  1754. package/dist/scripts/sync-prompt-guidance-fragments.js +50 -0
  1755. package/dist/scripts/sync-prompt-guidance-fragments.js.map +1 -0
  1756. package/dist/scripts/team-hardening-benchmark.d.ts +3 -0
  1757. package/dist/scripts/team-hardening-benchmark.d.ts.map +1 -0
  1758. package/dist/scripts/team-hardening-benchmark.js +91 -0
  1759. package/dist/scripts/team-hardening-benchmark.js.map +1 -0
  1760. package/dist/scripts/test-reply-listener-live.d.ts +24 -0
  1761. package/dist/scripts/test-reply-listener-live.d.ts.map +1 -0
  1762. package/dist/scripts/test-reply-listener-live.js +138 -0
  1763. package/dist/scripts/test-reply-listener-live.js.map +1 -0
  1764. package/dist/scripts/test-sparkshell.d.ts +2 -0
  1765. package/dist/scripts/test-sparkshell.d.ts.map +1 -0
  1766. package/dist/scripts/test-sparkshell.js +25 -0
  1767. package/dist/scripts/test-sparkshell.js.map +1 -0
  1768. package/dist/scripts/tmux-hook-engine.d.ts +45 -0
  1769. package/dist/scripts/tmux-hook-engine.d.ts.map +1 -0
  1770. package/dist/scripts/tmux-hook-engine.js +313 -0
  1771. package/dist/scripts/tmux-hook-engine.js.map +1 -0
  1772. package/dist/scripts/verify-native-agents.d.ts +16 -0
  1773. package/dist/scripts/verify-native-agents.d.ts.map +1 -0
  1774. package/dist/scripts/verify-native-agents.js +188 -0
  1775. package/dist/scripts/verify-native-agents.js.map +1 -0
  1776. package/dist/scripts/verify-native-release-assets.d.ts +3 -0
  1777. package/dist/scripts/verify-native-release-assets.d.ts.map +1 -0
  1778. package/dist/scripts/verify-native-release-assets.js +62 -0
  1779. package/dist/scripts/verify-native-release-assets.js.map +1 -0
  1780. package/dist/session-history/__tests__/search.test.d.ts +2 -0
  1781. package/dist/session-history/__tests__/search.test.d.ts.map +1 -0
  1782. package/dist/session-history/__tests__/search.test.js +150 -0
  1783. package/dist/session-history/__tests__/search.test.js.map +1 -0
  1784. package/dist/session-history/search.d.ts +31 -0
  1785. package/dist/session-history/search.d.ts.map +1 -0
  1786. package/dist/session-history/search.js +331 -0
  1787. package/dist/session-history/search.js.map +1 -0
  1788. package/dist/sidecar/__tests__/boundary.test.d.ts +2 -0
  1789. package/dist/sidecar/__tests__/boundary.test.d.ts.map +1 -0
  1790. package/dist/sidecar/__tests__/boundary.test.js +48 -0
  1791. package/dist/sidecar/__tests__/boundary.test.js.map +1 -0
  1792. package/dist/sidecar/__tests__/collector.test.d.ts +2 -0
  1793. package/dist/sidecar/__tests__/collector.test.d.ts.map +1 -0
  1794. package/dist/sidecar/__tests__/collector.test.js +162 -0
  1795. package/dist/sidecar/__tests__/collector.test.js.map +1 -0
  1796. package/dist/sidecar/__tests__/render.test.d.ts +2 -0
  1797. package/dist/sidecar/__tests__/render.test.d.ts.map +1 -0
  1798. package/dist/sidecar/__tests__/render.test.js +67 -0
  1799. package/dist/sidecar/__tests__/render.test.js.map +1 -0
  1800. package/dist/sidecar/__tests__/tmux.test.d.ts +2 -0
  1801. package/dist/sidecar/__tests__/tmux.test.d.ts.map +1 -0
  1802. package/dist/sidecar/__tests__/tmux.test.js +30 -0
  1803. package/dist/sidecar/__tests__/tmux.test.js.map +1 -0
  1804. package/dist/sidecar/__tests__/watch.test.d.ts +2 -0
  1805. package/dist/sidecar/__tests__/watch.test.d.ts.map +1 -0
  1806. package/dist/sidecar/__tests__/watch.test.js +42 -0
  1807. package/dist/sidecar/__tests__/watch.test.js.map +1 -0
  1808. package/dist/sidecar/collector.d.ts +4 -0
  1809. package/dist/sidecar/collector.d.ts.map +1 -0
  1810. package/dist/sidecar/collector.js +377 -0
  1811. package/dist/sidecar/collector.js.map +1 -0
  1812. package/dist/sidecar/index.d.ts +25 -0
  1813. package/dist/sidecar/index.d.ts.map +1 -0
  1814. package/dist/sidecar/index.js +165 -0
  1815. package/dist/sidecar/index.js.map +1 -0
  1816. package/dist/sidecar/render.d.ts +3 -0
  1817. package/dist/sidecar/render.d.ts.map +1 -0
  1818. package/dist/sidecar/render.js +72 -0
  1819. package/dist/sidecar/render.js.map +1 -0
  1820. package/dist/sidecar/tmux.d.ts +13 -0
  1821. package/dist/sidecar/tmux.d.ts.map +1 -0
  1822. package/dist/sidecar/tmux.js +44 -0
  1823. package/dist/sidecar/tmux.js.map +1 -0
  1824. package/dist/sidecar/types.d.ts +125 -0
  1825. package/dist/sidecar/types.d.ts.map +1 -0
  1826. package/dist/sidecar/types.js +2 -0
  1827. package/dist/sidecar/types.js.map +1 -0
  1828. package/dist/state/__tests__/mode-state-context.test.d.ts +2 -0
  1829. package/dist/state/__tests__/mode-state-context.test.d.ts.map +1 -0
  1830. package/dist/state/__tests__/mode-state-context.test.js +35 -0
  1831. package/dist/state/__tests__/mode-state-context.test.js.map +1 -0
  1832. package/dist/state/__tests__/operations-ralph-phase.test.d.ts +2 -0
  1833. package/dist/state/__tests__/operations-ralph-phase.test.d.ts.map +1 -0
  1834. package/dist/state/__tests__/operations-ralph-phase.test.js +103 -0
  1835. package/dist/state/__tests__/operations-ralph-phase.test.js.map +1 -0
  1836. package/dist/state/__tests__/operations.test.d.ts +2 -0
  1837. package/dist/state/__tests__/operations.test.d.ts.map +1 -0
  1838. package/dist/state/__tests__/operations.test.js +439 -0
  1839. package/dist/state/__tests__/operations.test.js.map +1 -0
  1840. package/dist/state/__tests__/path-traversal.test.d.ts +2 -0
  1841. package/dist/state/__tests__/path-traversal.test.d.ts.map +1 -0
  1842. package/dist/state/__tests__/path-traversal.test.js +49 -0
  1843. package/dist/state/__tests__/path-traversal.test.js.map +1 -0
  1844. package/dist/state/__tests__/skill-active.test.d.ts +2 -0
  1845. package/dist/state/__tests__/skill-active.test.d.ts.map +1 -0
  1846. package/dist/state/__tests__/skill-active.test.js +160 -0
  1847. package/dist/state/__tests__/skill-active.test.js.map +1 -0
  1848. package/dist/state/__tests__/workflow-transition.test.d.ts +2 -0
  1849. package/dist/state/__tests__/workflow-transition.test.d.ts.map +1 -0
  1850. package/dist/state/__tests__/workflow-transition.test.js +77 -0
  1851. package/dist/state/__tests__/workflow-transition.test.js.map +1 -0
  1852. package/dist/state/mode-state-context.d.ts +12 -0
  1853. package/dist/state/mode-state-context.d.ts.map +1 -0
  1854. package/dist/state/mode-state-context.js +28 -0
  1855. package/dist/state/mode-state-context.js.map +1 -0
  1856. package/dist/state/operations.d.ts +11 -0
  1857. package/dist/state/operations.d.ts.map +1 -0
  1858. package/dist/state/operations.js +363 -0
  1859. package/dist/state/operations.js.map +1 -0
  1860. package/dist/state/paths.d.ts +3 -0
  1861. package/dist/state/paths.d.ts.map +1 -0
  1862. package/dist/state/paths.js +2 -0
  1863. package/dist/state/paths.js.map +1 -0
  1864. package/dist/state/skill-active.d.ts +55 -0
  1865. package/dist/state/skill-active.d.ts.map +1 -0
  1866. package/dist/state/skill-active.js +269 -0
  1867. package/dist/state/skill-active.js.map +1 -0
  1868. package/dist/state/workflow-transition-reconcile.d.ts +15 -0
  1869. package/dist/state/workflow-transition-reconcile.d.ts.map +1 -0
  1870. package/dist/state/workflow-transition-reconcile.js +113 -0
  1871. package/dist/state/workflow-transition-reconcile.js.map +1 -0
  1872. package/dist/state/workflow-transition.d.ts +22 -0
  1873. package/dist/state/workflow-transition.d.ts.map +1 -0
  1874. package/dist/state/workflow-transition.js +191 -0
  1875. package/dist/state/workflow-transition.js.map +1 -0
  1876. package/dist/subagents/__tests__/tracker.test.d.ts +2 -0
  1877. package/dist/subagents/__tests__/tracker.test.d.ts.map +1 -0
  1878. package/dist/subagents/__tests__/tracker.test.js +47 -0
  1879. package/dist/subagents/__tests__/tracker.test.js.map +1 -0
  1880. package/dist/subagents/tracker.d.ts +52 -0
  1881. package/dist/subagents/tracker.d.ts.map +1 -0
  1882. package/dist/subagents/tracker.js +175 -0
  1883. package/dist/subagents/tracker.js.map +1 -0
  1884. package/dist/team/__tests__/allocation-policy.test.d.ts +2 -0
  1885. package/dist/team/__tests__/allocation-policy.test.d.ts.map +1 -0
  1886. package/dist/team/__tests__/allocation-policy.test.js +111 -0
  1887. package/dist/team/__tests__/allocation-policy.test.js.map +1 -0
  1888. package/dist/team/__tests__/api-interop.test.d.ts +2 -0
  1889. package/dist/team/__tests__/api-interop.test.d.ts.map +1 -0
  1890. package/dist/team/__tests__/api-interop.test.js +2262 -0
  1891. package/dist/team/__tests__/api-interop.test.js.map +1 -0
  1892. package/dist/team/__tests__/commit-hygiene.test.d.ts +2 -0
  1893. package/dist/team/__tests__/commit-hygiene.test.d.ts.map +1 -0
  1894. package/dist/team/__tests__/commit-hygiene.test.js +93 -0
  1895. package/dist/team/__tests__/commit-hygiene.test.js.map +1 -0
  1896. package/dist/team/__tests__/cross-rebase-smoke.test.d.ts +2 -0
  1897. package/dist/team/__tests__/cross-rebase-smoke.test.d.ts.map +1 -0
  1898. package/dist/team/__tests__/cross-rebase-smoke.test.js +161 -0
  1899. package/dist/team/__tests__/cross-rebase-smoke.test.js.map +1 -0
  1900. package/dist/team/__tests__/current-task-baseline.test.d.ts +2 -0
  1901. package/dist/team/__tests__/current-task-baseline.test.d.ts.map +1 -0
  1902. package/dist/team/__tests__/current-task-baseline.test.js +87 -0
  1903. package/dist/team/__tests__/current-task-baseline.test.js.map +1 -0
  1904. package/dist/team/__tests__/delegation-policy.test.d.ts +2 -0
  1905. package/dist/team/__tests__/delegation-policy.test.d.ts.map +1 -0
  1906. package/dist/team/__tests__/delegation-policy.test.js +69 -0
  1907. package/dist/team/__tests__/delegation-policy.test.js.map +1 -0
  1908. package/dist/team/__tests__/delivery-e2e-smoke.test.d.ts +2 -0
  1909. package/dist/team/__tests__/delivery-e2e-smoke.test.d.ts.map +1 -0
  1910. package/dist/team/__tests__/delivery-e2e-smoke.test.js +679 -0
  1911. package/dist/team/__tests__/delivery-e2e-smoke.test.js.map +1 -0
  1912. package/dist/team/__tests__/events.test.d.ts +2 -0
  1913. package/dist/team/__tests__/events.test.d.ts.map +1 -0
  1914. package/dist/team/__tests__/events.test.js +313 -0
  1915. package/dist/team/__tests__/events.test.js.map +1 -0
  1916. package/dist/team/__tests__/followup-planner.test.d.ts +2 -0
  1917. package/dist/team/__tests__/followup-planner.test.d.ts.map +1 -0
  1918. package/dist/team/__tests__/followup-planner.test.js +84 -0
  1919. package/dist/team/__tests__/followup-planner.test.js.map +1 -0
  1920. package/dist/team/__tests__/hardening-e2e.test.d.ts +2 -0
  1921. package/dist/team/__tests__/hardening-e2e.test.d.ts.map +1 -0
  1922. package/dist/team/__tests__/hardening-e2e.test.js +98 -0
  1923. package/dist/team/__tests__/hardening-e2e.test.js.map +1 -0
  1924. package/dist/team/__tests__/hook-primary-e2e-contract.test.d.ts +2 -0
  1925. package/dist/team/__tests__/hook-primary-e2e-contract.test.d.ts.map +1 -0
  1926. package/dist/team/__tests__/hook-primary-e2e-contract.test.js +78 -0
  1927. package/dist/team/__tests__/hook-primary-e2e-contract.test.js.map +1 -0
  1928. package/dist/team/__tests__/idle-nudge.test.d.ts +2 -0
  1929. package/dist/team/__tests__/idle-nudge.test.d.ts.map +1 -0
  1930. package/dist/team/__tests__/idle-nudge.test.js +230 -0
  1931. package/dist/team/__tests__/idle-nudge.test.js.map +1 -0
  1932. package/dist/team/__tests__/leader-activity.test.d.ts +2 -0
  1933. package/dist/team/__tests__/leader-activity.test.d.ts.map +1 -0
  1934. package/dist/team/__tests__/leader-activity.test.js +261 -0
  1935. package/dist/team/__tests__/leader-activity.test.js.map +1 -0
  1936. package/dist/team/__tests__/mcp-comm.test.d.ts +2 -0
  1937. package/dist/team/__tests__/mcp-comm.test.d.ts.map +1 -0
  1938. package/dist/team/__tests__/mcp-comm.test.js +289 -0
  1939. package/dist/team/__tests__/mcp-comm.test.js.map +1 -0
  1940. package/dist/team/__tests__/model-contract.test.d.ts +2 -0
  1941. package/dist/team/__tests__/model-contract.test.d.ts.map +1 -0
  1942. package/dist/team/__tests__/model-contract.test.js +171 -0
  1943. package/dist/team/__tests__/model-contract.test.js.map +1 -0
  1944. package/dist/team/__tests__/orchestrator.test.d.ts +2 -0
  1945. package/dist/team/__tests__/orchestrator.test.d.ts.map +1 -0
  1946. package/dist/team/__tests__/orchestrator.test.js +111 -0
  1947. package/dist/team/__tests__/orchestrator.test.js.map +1 -0
  1948. package/dist/team/__tests__/phase-controller.test.d.ts +2 -0
  1949. package/dist/team/__tests__/phase-controller.test.d.ts.map +1 -0
  1950. package/dist/team/__tests__/phase-controller.test.js +50 -0
  1951. package/dist/team/__tests__/phase-controller.test.js.map +1 -0
  1952. package/dist/team/__tests__/rebalance-policy.test.d.ts +2 -0
  1953. package/dist/team/__tests__/rebalance-policy.test.d.ts.map +1 -0
  1954. package/dist/team/__tests__/rebalance-policy.test.js +168 -0
  1955. package/dist/team/__tests__/rebalance-policy.test.js.map +1 -0
  1956. package/dist/team/__tests__/repo-aware-decomposition.test.d.ts +2 -0
  1957. package/dist/team/__tests__/repo-aware-decomposition.test.d.ts.map +1 -0
  1958. package/dist/team/__tests__/repo-aware-decomposition.test.js +136 -0
  1959. package/dist/team/__tests__/repo-aware-decomposition.test.js.map +1 -0
  1960. package/dist/team/__tests__/role-router.test.d.ts +2 -0
  1961. package/dist/team/__tests__/role-router.test.d.ts.map +1 -0
  1962. package/dist/team/__tests__/role-router.test.js +263 -0
  1963. package/dist/team/__tests__/role-router.test.js.map +1 -0
  1964. package/dist/team/__tests__/runtime-cli.test.d.ts +2 -0
  1965. package/dist/team/__tests__/runtime-cli.test.d.ts.map +1 -0
  1966. package/dist/team/__tests__/runtime-cli.test.js +304 -0
  1967. package/dist/team/__tests__/runtime-cli.test.js.map +1 -0
  1968. package/dist/team/__tests__/runtime.test.d.ts +2 -0
  1969. package/dist/team/__tests__/runtime.test.d.ts.map +1 -0
  1970. package/dist/team/__tests__/runtime.test.js +5734 -0
  1971. package/dist/team/__tests__/runtime.test.js.map +1 -0
  1972. package/dist/team/__tests__/scaling.test.d.ts +2 -0
  1973. package/dist/team/__tests__/scaling.test.d.ts.map +1 -0
  1974. package/dist/team/__tests__/scaling.test.js +1005 -0
  1975. package/dist/team/__tests__/scaling.test.js.map +1 -0
  1976. package/dist/team/__tests__/shutdown-fallback.test.d.ts +2 -0
  1977. package/dist/team/__tests__/shutdown-fallback.test.d.ts.map +1 -0
  1978. package/dist/team/__tests__/shutdown-fallback.test.js +125 -0
  1979. package/dist/team/__tests__/shutdown-fallback.test.js.map +1 -0
  1980. package/dist/team/__tests__/state-root.test.d.ts +2 -0
  1981. package/dist/team/__tests__/state-root.test.d.ts.map +1 -0
  1982. package/dist/team/__tests__/state-root.test.js +195 -0
  1983. package/dist/team/__tests__/state-root.test.js.map +1 -0
  1984. package/dist/team/__tests__/state.test.d.ts +2 -0
  1985. package/dist/team/__tests__/state.test.d.ts.map +1 -0
  1986. package/dist/team/__tests__/state.test.js +1859 -0
  1987. package/dist/team/__tests__/state.test.js.map +1 -0
  1988. package/dist/team/__tests__/team-identity.test.d.ts +2 -0
  1989. package/dist/team/__tests__/team-identity.test.d.ts.map +1 -0
  1990. package/dist/team/__tests__/team-identity.test.js +166 -0
  1991. package/dist/team/__tests__/team-identity.test.js.map +1 -0
  1992. package/dist/team/__tests__/team-ops-contract.test.d.ts +2 -0
  1993. package/dist/team/__tests__/team-ops-contract.test.d.ts.map +1 -0
  1994. package/dist/team/__tests__/team-ops-contract.test.js +96 -0
  1995. package/dist/team/__tests__/team-ops-contract.test.js.map +1 -0
  1996. package/dist/team/__tests__/tmux-claude-workers-demo.test.d.ts +2 -0
  1997. package/dist/team/__tests__/tmux-claude-workers-demo.test.d.ts.map +1 -0
  1998. package/dist/team/__tests__/tmux-claude-workers-demo.test.js +191 -0
  1999. package/dist/team/__tests__/tmux-claude-workers-demo.test.js.map +1 -0
  2000. package/dist/team/__tests__/tmux-session.test.d.ts +2 -0
  2001. package/dist/team/__tests__/tmux-session.test.d.ts.map +1 -0
  2002. package/dist/team/__tests__/tmux-session.test.js +3785 -0
  2003. package/dist/team/__tests__/tmux-session.test.js.map +1 -0
  2004. package/dist/team/__tests__/tmux-test-fixture.d.ts +20 -0
  2005. package/dist/team/__tests__/tmux-test-fixture.d.ts.map +1 -0
  2006. package/dist/team/__tests__/tmux-test-fixture.js +152 -0
  2007. package/dist/team/__tests__/tmux-test-fixture.js.map +1 -0
  2008. package/dist/team/__tests__/tmux-test-fixture.test.d.ts +2 -0
  2009. package/dist/team/__tests__/tmux-test-fixture.test.d.ts.map +1 -0
  2010. package/dist/team/__tests__/tmux-test-fixture.test.js +113 -0
  2011. package/dist/team/__tests__/tmux-test-fixture.test.js.map +1 -0
  2012. package/dist/team/__tests__/worker-bootstrap.test.d.ts +2 -0
  2013. package/dist/team/__tests__/worker-bootstrap.test.d.ts.map +1 -0
  2014. package/dist/team/__tests__/worker-bootstrap.test.js +685 -0
  2015. package/dist/team/__tests__/worker-bootstrap.test.js.map +1 -0
  2016. package/dist/team/__tests__/worker-runtime-identity.test.d.ts +2 -0
  2017. package/dist/team/__tests__/worker-runtime-identity.test.d.ts.map +1 -0
  2018. package/dist/team/__tests__/worker-runtime-identity.test.js +250 -0
  2019. package/dist/team/__tests__/worker-runtime-identity.test.js.map +1 -0
  2020. package/dist/team/__tests__/worktree.test.d.ts +2 -0
  2021. package/dist/team/__tests__/worktree.test.d.ts.map +1 -0
  2022. package/dist/team/__tests__/worktree.test.js +317 -0
  2023. package/dist/team/__tests__/worktree.test.js.map +1 -0
  2024. package/dist/team/allocation-policy.d.ts +29 -0
  2025. package/dist/team/allocation-policy.d.ts.map +1 -0
  2026. package/dist/team/allocation-policy.js +153 -0
  2027. package/dist/team/allocation-policy.js.map +1 -0
  2028. package/dist/team/api-interop.d.ts +20 -0
  2029. package/dist/team/api-interop.d.ts.map +1 -0
  2030. package/dist/team/api-interop.js +1083 -0
  2031. package/dist/team/api-interop.js.map +1 -0
  2032. package/dist/team/commit-hygiene.d.ts +79 -0
  2033. package/dist/team/commit-hygiene.d.ts.map +1 -0
  2034. package/dist/team/commit-hygiene.js +364 -0
  2035. package/dist/team/commit-hygiene.js.map +1 -0
  2036. package/dist/team/contracts.d.ts +26 -0
  2037. package/dist/team/contracts.d.ts.map +1 -0
  2038. package/dist/team/contracts.js +103 -0
  2039. package/dist/team/contracts.js.map +1 -0
  2040. package/dist/team/current-task-baseline.d.ts +32 -0
  2041. package/dist/team/current-task-baseline.d.ts.map +1 -0
  2042. package/dist/team/current-task-baseline.js +85 -0
  2043. package/dist/team/current-task-baseline.js.map +1 -0
  2044. package/dist/team/dag-schema.d.ts +38 -0
  2045. package/dist/team/dag-schema.d.ts.map +1 -0
  2046. package/dist/team/dag-schema.js +221 -0
  2047. package/dist/team/dag-schema.js.map +1 -0
  2048. package/dist/team/delegation-policy.d.ts +3 -0
  2049. package/dist/team/delegation-policy.d.ts.map +1 -0
  2050. package/dist/team/delegation-policy.js +82 -0
  2051. package/dist/team/delegation-policy.js.map +1 -0
  2052. package/dist/team/delivery-log.d.ts +14 -0
  2053. package/dist/team/delivery-log.d.ts.map +1 -0
  2054. package/dist/team/delivery-log.js +35 -0
  2055. package/dist/team/delivery-log.js.map +1 -0
  2056. package/dist/team/followup-planner.d.ts +44 -0
  2057. package/dist/team/followup-planner.d.ts.map +1 -0
  2058. package/dist/team/followup-planner.js +200 -0
  2059. package/dist/team/followup-planner.js.map +1 -0
  2060. package/dist/team/idle-nudge.d.ts +53 -0
  2061. package/dist/team/idle-nudge.d.ts.map +1 -0
  2062. package/dist/team/idle-nudge.js +141 -0
  2063. package/dist/team/idle-nudge.js.map +1 -0
  2064. package/dist/team/leader-activity.d.ts +15 -0
  2065. package/dist/team/leader-activity.d.ts.map +1 -0
  2066. package/dist/team/leader-activity.js +224 -0
  2067. package/dist/team/leader-activity.js.map +1 -0
  2068. package/dist/team/mcp-comm.d.ts +73 -0
  2069. package/dist/team/mcp-comm.d.ts.map +1 -0
  2070. package/dist/team/mcp-comm.js +314 -0
  2071. package/dist/team/mcp-comm.js.map +1 -0
  2072. package/dist/team/model-contract.d.ts +26 -0
  2073. package/dist/team/model-contract.d.ts.map +1 -0
  2074. package/dist/team/model-contract.js +204 -0
  2075. package/dist/team/model-contract.js.map +1 -0
  2076. package/dist/team/orchestrator.d.ts +47 -0
  2077. package/dist/team/orchestrator.d.ts.map +1 -0
  2078. package/dist/team/orchestrator.js +131 -0
  2079. package/dist/team/orchestrator.js.map +1 -0
  2080. package/dist/team/pane-status.d.ts +149 -0
  2081. package/dist/team/pane-status.d.ts.map +1 -0
  2082. package/dist/team/pane-status.js +558 -0
  2083. package/dist/team/pane-status.js.map +1 -0
  2084. package/dist/team/phase-controller.d.ts +12 -0
  2085. package/dist/team/phase-controller.d.ts.map +1 -0
  2086. package/dist/team/phase-controller.js +142 -0
  2087. package/dist/team/phase-controller.js.map +1 -0
  2088. package/dist/team/progress-evidence.d.ts +2 -0
  2089. package/dist/team/progress-evidence.d.ts.map +1 -0
  2090. package/dist/team/progress-evidence.js +77 -0
  2091. package/dist/team/progress-evidence.js.map +1 -0
  2092. package/dist/team/rebalance-policy.d.ts +19 -0
  2093. package/dist/team/rebalance-policy.d.ts.map +1 -0
  2094. package/dist/team/rebalance-policy.js +48 -0
  2095. package/dist/team/rebalance-policy.js.map +1 -0
  2096. package/dist/team/reminder-intents.d.ts +11 -0
  2097. package/dist/team/reminder-intents.d.ts.map +1 -0
  2098. package/dist/team/reminder-intents.js +40 -0
  2099. package/dist/team/reminder-intents.js.map +1 -0
  2100. package/dist/team/repo-aware-decomposition.d.ts +63 -0
  2101. package/dist/team/repo-aware-decomposition.d.ts.map +1 -0
  2102. package/dist/team/repo-aware-decomposition.js +231 -0
  2103. package/dist/team/repo-aware-decomposition.js.map +1 -0
  2104. package/dist/team/role-router.d.ts +32 -0
  2105. package/dist/team/role-router.d.ts.map +1 -0
  2106. package/dist/team/role-router.js +298 -0
  2107. package/dist/team/role-router.js.map +1 -0
  2108. package/dist/team/runtime-cli.d.ts +74 -0
  2109. package/dist/team/runtime-cli.d.ts.map +1 -0
  2110. package/dist/team/runtime-cli.js +363 -0
  2111. package/dist/team/runtime-cli.js.map +1 -0
  2112. package/dist/team/runtime.d.ts +154 -0
  2113. package/dist/team/runtime.d.ts.map +1 -0
  2114. package/dist/team/runtime.js +3925 -0
  2115. package/dist/team/runtime.js.map +1 -0
  2116. package/dist/team/scaling.d.ts +59 -0
  2117. package/dist/team/scaling.d.ts.map +1 -0
  2118. package/dist/team/scaling.js +598 -0
  2119. package/dist/team/scaling.js.map +1 -0
  2120. package/dist/team/state/approvals.d.ts +25 -0
  2121. package/dist/team/state/approvals.d.ts.map +1 -0
  2122. package/dist/team/state/approvals.js +31 -0
  2123. package/dist/team/state/approvals.js.map +1 -0
  2124. package/dist/team/state/config.d.ts +2 -0
  2125. package/dist/team/state/config.d.ts.map +1 -0
  2126. package/dist/team/state/config.js +2 -0
  2127. package/dist/team/state/config.js.map +1 -0
  2128. package/dist/team/state/dispatch-lock.d.ts +3 -0
  2129. package/dist/team/state/dispatch-lock.d.ts.map +1 -0
  2130. package/dist/team/state/dispatch-lock.js +81 -0
  2131. package/dist/team/state/dispatch-lock.js.map +1 -0
  2132. package/dist/team/state/dispatch.d.ts +69 -0
  2133. package/dist/team/state/dispatch.d.ts.map +1 -0
  2134. package/dist/team/state/dispatch.js +308 -0
  2135. package/dist/team/state/dispatch.js.map +1 -0
  2136. package/dist/team/state/events.d.ts +26 -0
  2137. package/dist/team/state/events.d.ts.map +1 -0
  2138. package/dist/team/state/events.js +145 -0
  2139. package/dist/team/state/events.js.map +1 -0
  2140. package/dist/team/state/index.d.ts +11 -0
  2141. package/dist/team/state/index.d.ts.map +1 -0
  2142. package/dist/team/state/index.js +11 -0
  2143. package/dist/team/state/index.js.map +1 -0
  2144. package/dist/team/state/io.d.ts +2 -0
  2145. package/dist/team/state/io.d.ts.map +1 -0
  2146. package/dist/team/state/io.js +2 -0
  2147. package/dist/team/state/io.js.map +1 -0
  2148. package/dist/team/state/locks.d.ts +16 -0
  2149. package/dist/team/state/locks.d.ts.map +1 -0
  2150. package/dist/team/state/locks.js +201 -0
  2151. package/dist/team/state/locks.js.map +1 -0
  2152. package/dist/team/state/mailbox.d.ts +42 -0
  2153. package/dist/team/state/mailbox.d.ts.map +1 -0
  2154. package/dist/team/state/mailbox.js +213 -0
  2155. package/dist/team/state/mailbox.js.map +1 -0
  2156. package/dist/team/state/monitor.d.ts +108 -0
  2157. package/dist/team/state/monitor.d.ts.map +1 -0
  2158. package/dist/team/state/monitor.js +193 -0
  2159. package/dist/team/state/monitor.js.map +1 -0
  2160. package/dist/team/state/shutdown.d.ts +2 -0
  2161. package/dist/team/state/shutdown.d.ts.map +1 -0
  2162. package/dist/team/state/shutdown.js +2 -0
  2163. package/dist/team/state/shutdown.js.map +1 -0
  2164. package/dist/team/state/summary.d.ts +2 -0
  2165. package/dist/team/state/summary.d.ts.map +1 -0
  2166. package/dist/team/state/summary.js +2 -0
  2167. package/dist/team/state/summary.js.map +1 -0
  2168. package/dist/team/state/tasks.d.ts +53 -0
  2169. package/dist/team/state/tasks.d.ts.map +1 -0
  2170. package/dist/team/state/tasks.js +260 -0
  2171. package/dist/team/state/tasks.js.map +1 -0
  2172. package/dist/team/state/types.d.ts +336 -0
  2173. package/dist/team/state/types.d.ts.map +1 -0
  2174. package/dist/team/state/types.js +3 -0
  2175. package/dist/team/state/types.js.map +1 -0
  2176. package/dist/team/state/workers.d.ts +2 -0
  2177. package/dist/team/state/workers.d.ts.map +1 -0
  2178. package/dist/team/state/workers.js +2 -0
  2179. package/dist/team/state/workers.js.map +1 -0
  2180. package/dist/team/state-root.d.ts +40 -0
  2181. package/dist/team/state-root.d.ts.map +1 -0
  2182. package/dist/team/state-root.js +293 -0
  2183. package/dist/team/state-root.js.map +1 -0
  2184. package/dist/team/state.d.ts +455 -0
  2185. package/dist/team/state.d.ts.map +1 -0
  2186. package/dist/team/state.js +1436 -0
  2187. package/dist/team/state.js.map +1 -0
  2188. package/dist/team/team-identity.d.ts +26 -0
  2189. package/dist/team/team-identity.d.ts.map +1 -0
  2190. package/dist/team/team-identity.js +169 -0
  2191. package/dist/team/team-identity.js.map +1 -0
  2192. package/dist/team/team-ops.d.ts +66 -0
  2193. package/dist/team/team-ops.d.ts.map +1 -0
  2194. package/dist/team/team-ops.js +79 -0
  2195. package/dist/team/team-ops.js.map +1 -0
  2196. package/dist/team/tmux-session.d.ts +186 -0
  2197. package/dist/team/tmux-session.d.ts.map +1 -0
  2198. package/dist/team/tmux-session.js +1770 -0
  2199. package/dist/team/tmux-session.js.map +1 -0
  2200. package/dist/team/worker-bootstrap.d.ts +85 -0
  2201. package/dist/team/worker-bootstrap.d.ts.map +1 -0
  2202. package/dist/team/worker-bootstrap.js +767 -0
  2203. package/dist/team/worker-bootstrap.js.map +1 -0
  2204. package/dist/team/worktree.d.ts +69 -0
  2205. package/dist/team/worktree.d.ts.map +1 -0
  2206. package/dist/team/worktree.js +437 -0
  2207. package/dist/team/worktree.js.map +1 -0
  2208. package/dist/utils/__tests__/agents-md.test.d.ts +2 -0
  2209. package/dist/utils/__tests__/agents-md.test.d.ts.map +1 -0
  2210. package/dist/utils/__tests__/agents-md.test.js +52 -0
  2211. package/dist/utils/__tests__/agents-md.test.js.map +1 -0
  2212. package/dist/utils/__tests__/agents-model-table.test.d.ts +2 -0
  2213. package/dist/utils/__tests__/agents-model-table.test.d.ts.map +1 -0
  2214. package/dist/utils/__tests__/agents-model-table.test.js +104 -0
  2215. package/dist/utils/__tests__/agents-model-table.test.js.map +1 -0
  2216. package/dist/utils/__tests__/dep-versions.test.d.ts +2 -0
  2217. package/dist/utils/__tests__/dep-versions.test.d.ts.map +1 -0
  2218. package/dist/utils/__tests__/dep-versions.test.js +46 -0
  2219. package/dist/utils/__tests__/dep-versions.test.js.map +1 -0
  2220. package/dist/utils/__tests__/package.test.d.ts +2 -0
  2221. package/dist/utils/__tests__/package.test.d.ts.map +1 -0
  2222. package/dist/utils/__tests__/package.test.js +21 -0
  2223. package/dist/utils/__tests__/package.test.js.map +1 -0
  2224. package/dist/utils/__tests__/paths.test.d.ts +2 -0
  2225. package/dist/utils/__tests__/paths.test.d.ts.map +1 -0
  2226. package/dist/utils/__tests__/paths.test.js +541 -0
  2227. package/dist/utils/__tests__/paths.test.js.map +1 -0
  2228. package/dist/utils/__tests__/platform-command.test.d.ts +2 -0
  2229. package/dist/utils/__tests__/platform-command.test.d.ts.map +1 -0
  2230. package/dist/utils/__tests__/platform-command.test.js +410 -0
  2231. package/dist/utils/__tests__/platform-command.test.js.map +1 -0
  2232. package/dist/utils/__tests__/repo-deps.test.d.ts +2 -0
  2233. package/dist/utils/__tests__/repo-deps.test.d.ts.map +1 -0
  2234. package/dist/utils/__tests__/repo-deps.test.js +71 -0
  2235. package/dist/utils/__tests__/repo-deps.test.js.map +1 -0
  2236. package/dist/utils/agents-md.d.ts +8 -0
  2237. package/dist/utils/agents-md.d.ts.map +1 -0
  2238. package/dist/utils/agents-md.js +57 -0
  2239. package/dist/utils/agents-md.js.map +1 -0
  2240. package/dist/utils/agents-model-table.d.ts +16 -0
  2241. package/dist/utils/agents-model-table.d.ts.map +1 -0
  2242. package/dist/utils/agents-model-table.js +88 -0
  2243. package/dist/utils/agents-model-table.js.map +1 -0
  2244. package/dist/utils/git-layout.d.ts +8 -0
  2245. package/dist/utils/git-layout.d.ts.map +1 -0
  2246. package/dist/utils/git-layout.js +58 -0
  2247. package/dist/utils/git-layout.js.map +1 -0
  2248. package/dist/utils/package.d.ts +9 -0
  2249. package/dist/utils/package.d.ts.map +1 -0
  2250. package/dist/utils/package.js +31 -0
  2251. package/dist/utils/package.js.map +1 -0
  2252. package/dist/utils/paths.d.ts +84 -0
  2253. package/dist/utils/paths.d.ts.map +1 -0
  2254. package/dist/utils/paths.js +263 -0
  2255. package/dist/utils/paths.js.map +1 -0
  2256. package/dist/utils/platform-command.d.ts +26 -0
  2257. package/dist/utils/platform-command.d.ts.map +1 -0
  2258. package/dist/utils/platform-command.js +270 -0
  2259. package/dist/utils/platform-command.js.map +1 -0
  2260. package/dist/utils/repo-deps.d.ts +20 -0
  2261. package/dist/utils/repo-deps.d.ts.map +1 -0
  2262. package/dist/utils/repo-deps.js +78 -0
  2263. package/dist/utils/repo-deps.js.map +1 -0
  2264. package/dist/utils/safe-json.d.ts +3 -0
  2265. package/dist/utils/safe-json.d.ts.map +1 -0
  2266. package/dist/utils/safe-json.js +19 -0
  2267. package/dist/utils/safe-json.js.map +1 -0
  2268. package/dist/utils/sleep.d.ts +3 -0
  2269. package/dist/utils/sleep.d.ts.map +1 -0
  2270. package/dist/utils/sleep.js +24 -0
  2271. package/dist/utils/sleep.js.map +1 -0
  2272. package/dist/verification/__tests__/ci-rust-gates.test.d.ts +2 -0
  2273. package/dist/verification/__tests__/ci-rust-gates.test.d.ts.map +1 -0
  2274. package/dist/verification/__tests__/ci-rust-gates.test.js +89 -0
  2275. package/dist/verification/__tests__/ci-rust-gates.test.js.map +1 -0
  2276. package/dist/verification/__tests__/dev-merge-issue-close-workflow.test.d.ts +2 -0
  2277. package/dist/verification/__tests__/dev-merge-issue-close-workflow.test.d.ts.map +1 -0
  2278. package/dist/verification/__tests__/dev-merge-issue-close-workflow.test.js +54 -0
  2279. package/dist/verification/__tests__/dev-merge-issue-close-workflow.test.js.map +1 -0
  2280. package/dist/verification/__tests__/explore-harness-release-workflow.test.d.ts +2 -0
  2281. package/dist/verification/__tests__/explore-harness-release-workflow.test.d.ts.map +1 -0
  2282. package/dist/verification/__tests__/explore-harness-release-workflow.test.js +73 -0
  2283. package/dist/verification/__tests__/explore-harness-release-workflow.test.js.map +1 -0
  2284. package/dist/verification/__tests__/native-release-manifest.test.d.ts +2 -0
  2285. package/dist/verification/__tests__/native-release-manifest.test.d.ts.map +1 -0
  2286. package/dist/verification/__tests__/native-release-manifest.test.js +80 -0
  2287. package/dist/verification/__tests__/native-release-manifest.test.js.map +1 -0
  2288. package/dist/verification/__tests__/pr-check-workflow.test.d.ts +2 -0
  2289. package/dist/verification/__tests__/pr-check-workflow.test.d.ts.map +1 -0
  2290. package/dist/verification/__tests__/pr-check-workflow.test.js +27 -0
  2291. package/dist/verification/__tests__/pr-check-workflow.test.js.map +1 -0
  2292. package/dist/verification/__tests__/ralph-persistence-gate.test.d.ts +2 -0
  2293. package/dist/verification/__tests__/ralph-persistence-gate.test.d.ts.map +1 -0
  2294. package/dist/verification/__tests__/ralph-persistence-gate.test.js +55 -0
  2295. package/dist/verification/__tests__/ralph-persistence-gate.test.js.map +1 -0
  2296. package/dist/verification/__tests__/rust-runtime-thin-adapter-gate.test.d.ts +2 -0
  2297. package/dist/verification/__tests__/rust-runtime-thin-adapter-gate.test.d.ts.map +1 -0
  2298. package/dist/verification/__tests__/rust-runtime-thin-adapter-gate.test.js +32 -0
  2299. package/dist/verification/__tests__/rust-runtime-thin-adapter-gate.test.js.map +1 -0
  2300. package/dist/verification/__tests__/verifier.test.d.ts +2 -0
  2301. package/dist/verification/__tests__/verifier.test.d.ts.map +1 -0
  2302. package/dist/verification/__tests__/verifier.test.js +113 -0
  2303. package/dist/verification/__tests__/verifier.test.js.map +1 -0
  2304. package/dist/verification/verifier.d.ts +37 -0
  2305. package/dist/verification/verifier.d.ts.map +1 -0
  2306. package/dist/verification/verifier.js +100 -0
  2307. package/dist/verification/verifier.js.map +1 -0
  2308. package/dist/visual/__tests__/verdict.test.d.ts +2 -0
  2309. package/dist/visual/__tests__/verdict.test.d.ts.map +1 -0
  2310. package/dist/visual/__tests__/verdict.test.js +81 -0
  2311. package/dist/visual/__tests__/verdict.test.js.map +1 -0
  2312. package/dist/visual/constants.d.ts +4 -0
  2313. package/dist/visual/constants.d.ts.map +1 -0
  2314. package/dist/visual/constants.js +3 -0
  2315. package/dist/visual/constants.js.map +1 -0
  2316. package/dist/visual/verdict.d.ts +17 -0
  2317. package/dist/visual/verdict.d.ts.map +1 -0
  2318. package/dist/visual/verdict.js +61 -0
  2319. package/dist/visual/verdict.js.map +1 -0
  2320. package/dist/wiki/__tests__/cjk-tokenize.test.d.ts +12 -0
  2321. package/dist/wiki/__tests__/cjk-tokenize.test.d.ts.map +1 -0
  2322. package/dist/wiki/__tests__/cjk-tokenize.test.js +139 -0
  2323. package/dist/wiki/__tests__/cjk-tokenize.test.js.map +1 -0
  2324. package/dist/wiki/__tests__/crlf-parse.test.d.ts +2 -0
  2325. package/dist/wiki/__tests__/crlf-parse.test.d.ts.map +1 -0
  2326. package/dist/wiki/__tests__/crlf-parse.test.js +24 -0
  2327. package/dist/wiki/__tests__/crlf-parse.test.js.map +1 -0
  2328. package/dist/wiki/__tests__/escape-newline.test.d.ts +2 -0
  2329. package/dist/wiki/__tests__/escape-newline.test.d.ts.map +1 -0
  2330. package/dist/wiki/__tests__/escape-newline.test.js +45 -0
  2331. package/dist/wiki/__tests__/escape-newline.test.js.map +1 -0
  2332. package/dist/wiki/__tests__/ingest.test.d.ts +5 -0
  2333. package/dist/wiki/__tests__/ingest.test.d.ts.map +1 -0
  2334. package/dist/wiki/__tests__/ingest.test.js +181 -0
  2335. package/dist/wiki/__tests__/ingest.test.js.map +1 -0
  2336. package/dist/wiki/__tests__/lint.test.d.ts +5 -0
  2337. package/dist/wiki/__tests__/lint.test.d.ts.map +1 -0
  2338. package/dist/wiki/__tests__/lint.test.js +163 -0
  2339. package/dist/wiki/__tests__/lint.test.js.map +1 -0
  2340. package/dist/wiki/__tests__/query.test.d.ts +5 -0
  2341. package/dist/wiki/__tests__/query.test.d.ts.map +1 -0
  2342. package/dist/wiki/__tests__/query.test.js +141 -0
  2343. package/dist/wiki/__tests__/query.test.js.map +1 -0
  2344. package/dist/wiki/__tests__/reserved-file-guard.test.d.ts +2 -0
  2345. package/dist/wiki/__tests__/reserved-file-guard.test.d.ts.map +1 -0
  2346. package/dist/wiki/__tests__/reserved-file-guard.test.js +44 -0
  2347. package/dist/wiki/__tests__/reserved-file-guard.test.js.map +1 -0
  2348. package/dist/wiki/__tests__/session-hooks.test.d.ts +5 -0
  2349. package/dist/wiki/__tests__/session-hooks.test.d.ts.map +1 -0
  2350. package/dist/wiki/__tests__/session-hooks.test.js +36 -0
  2351. package/dist/wiki/__tests__/session-hooks.test.js.map +1 -0
  2352. package/dist/wiki/__tests__/slug-nonascii.test.d.ts +2 -0
  2353. package/dist/wiki/__tests__/slug-nonascii.test.d.ts.map +1 -0
  2354. package/dist/wiki/__tests__/slug-nonascii.test.js +30 -0
  2355. package/dist/wiki/__tests__/slug-nonascii.test.js.map +1 -0
  2356. package/dist/wiki/__tests__/storage.test.d.ts +5 -0
  2357. package/dist/wiki/__tests__/storage.test.d.ts.map +1 -0
  2358. package/dist/wiki/__tests__/storage.test.js +278 -0
  2359. package/dist/wiki/__tests__/storage.test.js.map +1 -0
  2360. package/dist/wiki/__tests__/test-helpers.d.ts +31 -0
  2361. package/dist/wiki/__tests__/test-helpers.d.ts.map +1 -0
  2362. package/dist/wiki/__tests__/test-helpers.js +108 -0
  2363. package/dist/wiki/__tests__/test-helpers.js.map +1 -0
  2364. package/dist/wiki/index.d.ts +14 -0
  2365. package/dist/wiki/index.d.ts.map +1 -0
  2366. package/dist/wiki/index.js +17 -0
  2367. package/dist/wiki/index.js.map +1 -0
  2368. package/dist/wiki/ingest.d.ts +20 -0
  2369. package/dist/wiki/ingest.d.ts.map +1 -0
  2370. package/dist/wiki/ingest.js +115 -0
  2371. package/dist/wiki/ingest.js.map +1 -0
  2372. package/dist/wiki/lifecycle.d.ts +20 -0
  2373. package/dist/wiki/lifecycle.d.ts.map +1 -0
  2374. package/dist/wiki/lifecycle.js +212 -0
  2375. package/dist/wiki/lifecycle.js.map +1 -0
  2376. package/dist/wiki/lint.d.ts +25 -0
  2377. package/dist/wiki/lint.d.ts.map +1 -0
  2378. package/dist/wiki/lint.js +166 -0
  2379. package/dist/wiki/lint.js.map +1 -0
  2380. package/dist/wiki/query.d.ts +36 -0
  2381. package/dist/wiki/query.d.ts.map +1 -0
  2382. package/dist/wiki/query.js +138 -0
  2383. package/dist/wiki/query.js.map +1 -0
  2384. package/dist/wiki/storage.d.ts +33 -0
  2385. package/dist/wiki/storage.d.ts.map +1 -0
  2386. package/dist/wiki/storage.js +322 -0
  2387. package/dist/wiki/storage.js.map +1 -0
  2388. package/dist/wiki/types.d.ts +83 -0
  2389. package/dist/wiki/types.d.ts.map +1 -0
  2390. package/dist/wiki/types.js +15 -0
  2391. package/dist/wiki/types.js.map +1 -0
  2392. package/docs/STATE_MODEL.md +280 -0
  2393. package/docs/adapt.md +49 -0
  2394. package/docs/agents.html +96 -0
  2395. package/docs/benchmarks/tetris-benchmark-comparison-20260306.png +0 -0
  2396. package/docs/clawhip-event-contract.md +83 -0
  2397. package/docs/codex-native-hooks.md +153 -0
  2398. package/docs/contracts/autoresearch-command-contract.md +106 -0
  2399. package/docs/contracts/autoresearch-command-review.md +97 -0
  2400. package/docs/contracts/autoresearch-ux-deep-interview-review.md +114 -0
  2401. package/docs/contracts/explicit-terminal-stop-model.md +96 -0
  2402. package/docs/contracts/multi-state-transition-contract.md +115 -0
  2403. package/docs/contracts/multi-state-transition-review.md +134 -0
  2404. package/docs/contracts/mux-operation-space.md +49 -0
  2405. package/docs/contracts/ralph-cancel-contract.md +23 -0
  2406. package/docs/contracts/ralph-state-contract.md +95 -0
  2407. package/docs/contracts/repo-aware-team-dag-decomposition.md +98 -0
  2408. package/docs/contracts/runtime-authority-backlog-replay-readiness.md +40 -0
  2409. package/docs/contracts/runtime-command-event-snapshot-schema.md +133 -0
  2410. package/docs/contracts/rust-runtime-thin-adapter-contract.md +69 -0
  2411. package/docs/contracts/team-delivery-state-contract.md +95 -0
  2412. package/docs/contracts/team-runtime-state-contract.md +48 -0
  2413. package/docs/contracts/team-startup-dispatch-latency.md +114 -0
  2414. package/docs/getting-started.html +91 -0
  2415. package/docs/guidance-schema.md +69 -0
  2416. package/docs/hooks-extension.md +146 -0
  2417. package/docs/index.html +117 -0
  2418. package/docs/integrations.html +59 -0
  2419. package/docs/interop-team-mutation-contract.md +98 -0
  2420. package/docs/issues/team-ralph-followup-team.md +38 -0
  2421. package/docs/migration-mainline-post-v0.4.4.md +90 -0
  2422. package/docs/openclaw-integration.de.md +44 -0
  2423. package/docs/openclaw-integration.es.md +44 -0
  2424. package/docs/openclaw-integration.fr.md +44 -0
  2425. package/docs/openclaw-integration.it.md +44 -0
  2426. package/docs/openclaw-integration.ja.md +44 -0
  2427. package/docs/openclaw-integration.ko.md +82 -0
  2428. package/docs/openclaw-integration.md +378 -0
  2429. package/docs/openclaw-integration.pt.md +44 -0
  2430. package/docs/openclaw-integration.ru.md +44 -0
  2431. package/docs/openclaw-integration.tr.md +44 -0
  2432. package/docs/openclaw-integration.uk.md +44 -0
  2433. package/docs/openclaw-integration.vi.md +44 -0
  2434. package/docs/openclaw-integration.zh-TW.md +44 -0
  2435. package/docs/openclaw-integration.zh.md +44 -0
  2436. package/docs/plugin-bundle-ssot.md +52 -0
  2437. package/docs/prompt-guidance-contract.md +233 -0
  2438. package/docs/prompt-guidance-fragments/core-operating-principles.md +16 -0
  2439. package/docs/prompt-guidance-fragments/core-verification-and-sequencing.md +6 -0
  2440. package/docs/prompt-guidance-fragments/executor-constraints.md +13 -0
  2441. package/docs/prompt-guidance-fragments/executor-output.md +1 -0
  2442. package/docs/prompt-guidance-fragments/executor-shared.md +7 -0
  2443. package/docs/prompt-guidance-fragments/leader-specialist-routing.md +6 -0
  2444. package/docs/prompt-guidance-fragments/planner-constraints.md +12 -0
  2445. package/docs/prompt-guidance-fragments/planner-investigation.md +1 -0
  2446. package/docs/prompt-guidance-fragments/planner-output.md +1 -0
  2447. package/docs/prompt-guidance-fragments/planner-shared.md +7 -0
  2448. package/docs/prompt-guidance-fragments/verifier-constraints.md +10 -0
  2449. package/docs/prompt-guidance-fragments/verifier-investigation.md +1 -0
  2450. package/docs/prompt-guidance-fragments/verifier-shared.md +4 -0
  2451. package/docs/prompt-migration-changelog.md +152 -0
  2452. package/docs/prs/dev-deprecate-team-ralph.md +100 -0
  2453. package/docs/prs/dev-fix-ralph-live-pane-invariant.md +34 -0
  2454. package/docs/prs/dev-issue-715-team-brain-role-split.md +22 -0
  2455. package/docs/prs/dev-team-ralph-workflow-positioning.md +38 -0
  2456. package/docs/prs/experimental-dev-omx-sparkshell.md +56 -0
  2457. package/docs/qa/ci-speedups-after-prompt-worker-fix.md +91 -0
  2458. package/docs/qa/deep-interview-phase-1-validation.md +117 -0
  2459. package/docs/qa/explore-sparkshell-heavy-manual-stress.md +244 -0
  2460. package/docs/qa/ralph-persistence-gate.md +59 -0
  2461. package/docs/qa/recent-bug-regression-hardening-2026-04-11.md +24 -0
  2462. package/docs/qa/release-no-publish-0.15.0.md +33 -0
  2463. package/docs/qa/release-readiness-0.11.13.md +39 -0
  2464. package/docs/qa/release-readiness-0.12.0.md +80 -0
  2465. package/docs/qa/release-readiness-0.12.1.md +33 -0
  2466. package/docs/qa/release-readiness-0.12.2.md +33 -0
  2467. package/docs/qa/release-readiness-0.12.3.md +30 -0
  2468. package/docs/qa/release-readiness-0.12.5.md +69 -0
  2469. package/docs/qa/release-readiness-0.12.6.md +59 -0
  2470. package/docs/qa/release-readiness-0.13.0.md +64 -0
  2471. package/docs/qa/release-readiness-0.13.1.md +39 -0
  2472. package/docs/qa/release-readiness-0.14.0.md +55 -0
  2473. package/docs/qa/release-readiness-0.14.1.md +44 -0
  2474. package/docs/qa/release-readiness-0.14.2.md +65 -0
  2475. package/docs/qa/release-readiness-0.14.3.md +42 -0
  2476. package/docs/qa/release-readiness-0.14.4.md +40 -0
  2477. package/docs/qa/release-readiness-0.15.0.md +65 -0
  2478. package/docs/qa/release-readiness-0.15.1.md +44 -0
  2479. package/docs/qa/release-readiness-0.8.1.md +37 -0
  2480. package/docs/qa/release-readiness-0.8.2.md +39 -0
  2481. package/docs/qa/release-readiness-0.8.3.md +43 -0
  2482. package/docs/qa/release-readiness-0.8.4.md +39 -0
  2483. package/docs/qa/release-readiness-0.9.0.md +78 -0
  2484. package/docs/qa/release-readiness-0.9.1.md +43 -0
  2485. package/docs/qa/release-readiness-follow-up.md +26 -0
  2486. package/docs/qa/remaining-suite-drift-2026-03-19.md +105 -0
  2487. package/docs/qa/research-specialist-eval-surface-2026-04-18.md +42 -0
  2488. package/docs/qa/runtime-team-seam-audit-2026-04-01.md +128 -0
  2489. package/docs/qa/rust-runtime-thin-adapter-gate.md +40 -0
  2490. package/docs/qa-plan-0.4.2.md +85 -0
  2491. package/docs/qa-report-0.4.2.md +55 -0
  2492. package/docs/readme/README.de.md +27 -0
  2493. package/docs/readme/README.el.md +27 -0
  2494. package/docs/readme/README.es.md +27 -0
  2495. package/docs/readme/README.fr.md +27 -0
  2496. package/docs/readme/README.it.md +27 -0
  2497. package/docs/readme/README.ja.md +27 -0
  2498. package/docs/readme/README.ko.md +27 -0
  2499. package/docs/readme/README.md +53 -0
  2500. package/docs/readme/README.pl.md +27 -0
  2501. package/docs/readme/README.pt.md +27 -0
  2502. package/docs/readme/README.ru.md +27 -0
  2503. package/docs/readme/README.tr.md +27 -0
  2504. package/docs/readme/README.uk.md +27 -0
  2505. package/docs/readme/README.vi.md +27 -0
  2506. package/docs/readme/README.zh-TW.md +27 -0
  2507. package/docs/readme/README.zh.md +27 -0
  2508. package/docs/reference/player-psychology-command-surfaces.md +30 -0
  2509. package/docs/reference/player-psychology-framework.md +64 -0
  2510. package/docs/reference/project-wiki.md +79 -0
  2511. package/docs/reference/psychology-example-mastery-combat.md +7 -0
  2512. package/docs/reference/psychology-example-simulator-farming.md +7 -0
  2513. package/docs/reference/psychology-example-social-roleplay.md +7 -0
  2514. package/docs/reference/psychology-rubric-healthy-retention.md +13 -0
  2515. package/docs/reference/psychology-rubric-mastery-depth.md +11 -0
  2516. package/docs/reference/psychology-rubric-progression-clarity.md +12 -0
  2517. package/docs/reference/psychology-rubric-social-value-vs-spam.md +11 -0
  2518. package/docs/reference/psychology-rubric-status-visibility.md +11 -0
  2519. package/docs/reference/ralph-parity-matrix.md +25 -0
  2520. package/docs/reference/ralph-upstream-baseline.md +34 -0
  2521. package/docs/reference/rcs-config-schema-routing.md +264 -0
  2522. package/docs/reference/roblox-pre-action-protocol.md +122 -0
  2523. package/docs/reference/team-allocation-rebalance-policy.md +60 -0
  2524. package/docs/release-body-0.9.0.md +104 -0
  2525. package/docs/release-body-0.9.1.md +41 -0
  2526. package/docs/release-notes-v0.1.0.md +53 -0
  2527. package/docs/reports/macos-m1-high-cpu-usage-2026-04-16.md +78 -0
  2528. package/docs/reports/open-prs-dev-readiness-2026-04-09.md +45 -0
  2529. package/docs/runtime-model-metadata-cleanup.md +37 -0
  2530. package/docs/shared/agent-tiers.md +56 -0
  2531. package/docs/shared/omx-character-spark-initiative.jpg +0 -0
  2532. package/docs/skills.html +132 -0
  2533. package/docs/style.css +179 -0
  2534. package/docs/troubleshooting.md +120 -0
  2535. package/docs/wiki-feature.md +35 -0
  2536. package/package.json +108 -0
  2537. package/plugins/roblox-ai-os-creator-skills/.app.json +3 -0
  2538. package/plugins/roblox-ai-os-creator-skills/.codex-plugin/plugin.json +30 -0
  2539. package/plugins/roblox-ai-os-creator-skills/.mcp.json +44 -0
  2540. package/plugins/roblox-ai-os-creator-skills/docs/reference/player-psychology-command-surfaces.md +30 -0
  2541. package/plugins/roblox-ai-os-creator-skills/docs/reference/player-psychology-framework.md +64 -0
  2542. package/plugins/roblox-ai-os-creator-skills/docs/reference/psychology-example-mastery-combat.md +7 -0
  2543. package/plugins/roblox-ai-os-creator-skills/docs/reference/psychology-example-simulator-farming.md +7 -0
  2544. package/plugins/roblox-ai-os-creator-skills/docs/reference/psychology-example-social-roleplay.md +7 -0
  2545. package/plugins/roblox-ai-os-creator-skills/docs/reference/psychology-rubric-healthy-retention.md +13 -0
  2546. package/plugins/roblox-ai-os-creator-skills/docs/reference/psychology-rubric-mastery-depth.md +11 -0
  2547. package/plugins/roblox-ai-os-creator-skills/docs/reference/psychology-rubric-progression-clarity.md +12 -0
  2548. package/plugins/roblox-ai-os-creator-skills/docs/reference/psychology-rubric-social-value-vs-spam.md +11 -0
  2549. package/plugins/roblox-ai-os-creator-skills/docs/reference/psychology-rubric-status-visibility.md +11 -0
  2550. package/plugins/roblox-ai-os-creator-skills/docs/reference/roblox-pre-action-protocol.md +122 -0
  2551. package/plugins/roblox-ai-os-creator-skills/skills/ai-slop-cleaner/SKILL.md +139 -0
  2552. package/plugins/roblox-ai-os-creator-skills/skills/analyze/SKILL.md +148 -0
  2553. package/plugins/roblox-ai-os-creator-skills/skills/ask-claude/SKILL.md +61 -0
  2554. package/plugins/roblox-ai-os-creator-skills/skills/ask-gemini/SKILL.md +61 -0
  2555. package/plugins/roblox-ai-os-creator-skills/skills/autoforge/SKILL.md +18 -0
  2556. package/plugins/roblox-ai-os-creator-skills/skills/autopilot/SKILL.md +163 -0
  2557. package/plugins/roblox-ai-os-creator-skills/skills/autoresearch/SKILL.md +68 -0
  2558. package/plugins/roblox-ai-os-creator-skills/skills/blueprint/SKILL.md +22 -0
  2559. package/plugins/roblox-ai-os-creator-skills/skills/blueprint-loop/SKILL.md +19 -0
  2560. package/plugins/roblox-ai-os-creator-skills/skills/blueprint-psych/SKILL.md +21 -0
  2561. package/plugins/roblox-ai-os-creator-skills/skills/blueprint-retention/SKILL.md +15 -0
  2562. package/plugins/roblox-ai-os-creator-skills/skills/blueprint-social/SKILL.md +15 -0
  2563. package/plugins/roblox-ai-os-creator-skills/skills/brief/SKILL.md +27 -0
  2564. package/plugins/roblox-ai-os-creator-skills/skills/brief-audience/SKILL.md +19 -0
  2565. package/plugins/roblox-ai-os-creator-skills/skills/brief-motivation/SKILL.md +22 -0
  2566. package/plugins/roblox-ai-os-creator-skills/skills/cancel/SKILL.md +399 -0
  2567. package/plugins/roblox-ai-os-creator-skills/skills/code-review/SKILL.md +290 -0
  2568. package/plugins/roblox-ai-os-creator-skills/skills/configure-notifications/SKILL.md +287 -0
  2569. package/plugins/roblox-ai-os-creator-skills/skills/crew/SKILL.md +10 -0
  2570. package/plugins/roblox-ai-os-creator-skills/skills/deep-interview/SKILL.md +468 -0
  2571. package/plugins/roblox-ai-os-creator-skills/skills/doctor/SKILL.md +239 -0
  2572. package/plugins/roblox-ai-os-creator-skills/skills/forge/SKILL.md +30 -0
  2573. package/plugins/roblox-ai-os-creator-skills/skills/forge-community/SKILL.md +16 -0
  2574. package/plugins/roblox-ai-os-creator-skills/skills/forge-daily-loop/SKILL.md +15 -0
  2575. package/plugins/roblox-ai-os-creator-skills/skills/forge-event-loop/SKILL.md +15 -0
  2576. package/plugins/roblox-ai-os-creator-skills/skills/forge-fomo/SKILL.md +16 -0
  2577. package/plugins/roblox-ai-os-creator-skills/skills/forge-mastery/SKILL.md +16 -0
  2578. package/plugins/roblox-ai-os-creator-skills/skills/forge-progression/SKILL.md +16 -0
  2579. package/plugins/roblox-ai-os-creator-skills/skills/forge-reward-loop/SKILL.md +19 -0
  2580. package/plugins/roblox-ai-os-creator-skills/skills/forge-status/SKILL.md +17 -0
  2581. package/plugins/roblox-ai-os-creator-skills/skills/help/SKILL.md +75 -0
  2582. package/plugins/roblox-ai-os-creator-skills/skills/hud/SKILL.md +98 -0
  2583. package/plugins/roblox-ai-os-creator-skills/skills/note/SKILL.md +62 -0
  2584. package/plugins/roblox-ai-os-creator-skills/skills/pipeline/SKILL.md +86 -0
  2585. package/plugins/roblox-ai-os-creator-skills/skills/plan/SKILL.md +277 -0
  2586. package/plugins/roblox-ai-os-creator-skills/skills/ralph/SKILL.md +269 -0
  2587. package/plugins/roblox-ai-os-creator-skills/skills/ralplan/SKILL.md +162 -0
  2588. package/plugins/roblox-ai-os-creator-skills/skills/rcs-setup/SKILL.md +135 -0
  2589. package/plugins/roblox-ai-os-creator-skills/skills/security-review/SKILL.md +300 -0
  2590. package/plugins/roblox-ai-os-creator-skills/skills/skill/SKILL.md +835 -0
  2591. package/plugins/roblox-ai-os-creator-skills/skills/team/SKILL.md +510 -0
  2592. package/plugins/roblox-ai-os-creator-skills/skills/trace/SKILL.md +33 -0
  2593. package/plugins/roblox-ai-os-creator-skills/skills/ultraqa/SKILL.md +143 -0
  2594. package/plugins/roblox-ai-os-creator-skills/skills/ultrawork/SKILL.md +175 -0
  2595. package/plugins/roblox-ai-os-creator-skills/skills/visual-ralph/SKILL.md +153 -0
  2596. package/plugins/roblox-ai-os-creator-skills/skills/visual-verdict/SKILL.md +76 -0
  2597. package/plugins/roblox-ai-os-creator-skills/skills/wiki/SKILL.md +57 -0
  2598. package/plugins/roblox-ai-os-creator-skills/skills/worker/SKILL.md +106 -0
  2599. package/plugins/roblox-ai-os-creator-skills/templates/psychology/dopamine-loop-map.md +13 -0
  2600. package/plugins/roblox-ai-os-creator-skills/templates/psychology/event-fomo-design-sheet.md +11 -0
  2601. package/plugins/roblox-ai-os-creator-skills/templates/psychology/player-motivation-profile.md +14 -0
  2602. package/plugins/roblox-ai-os-creator-skills/templates/psychology/retention-design-sheet.md +12 -0
  2603. package/plugins/roblox-ai-os-creator-skills/templates/psychology/social-mechanic-spec.md +11 -0
  2604. package/plugins/roblox-ai-os-creator-skills/templates/roblox/pre-action-plan.md +84 -0
  2605. package/prompts/analyst.md +135 -0
  2606. package/prompts/api-reviewer.md +113 -0
  2607. package/prompts/architect.md +111 -0
  2608. package/prompts/build-fixer.md +115 -0
  2609. package/prompts/code-reviewer.md +137 -0
  2610. package/prompts/code-simplifier.md +134 -0
  2611. package/prompts/critic.md +80 -0
  2612. package/prompts/debugger.md +117 -0
  2613. package/prompts/dependency-expert.md +129 -0
  2614. package/prompts/designer.md +126 -0
  2615. package/prompts/executor.md +108 -0
  2616. package/prompts/explore-harness.md +64 -0
  2617. package/prompts/explore.md +85 -0
  2618. package/prompts/git-master.md +114 -0
  2619. package/prompts/information-architect.md +226 -0
  2620. package/prompts/performance-reviewer.md +109 -0
  2621. package/prompts/planner.md +110 -0
  2622. package/prompts/product-analyst.md +304 -0
  2623. package/prompts/product-manager.md +245 -0
  2624. package/prompts/qa-tester.md +124 -0
  2625. package/prompts/quality-reviewer.md +123 -0
  2626. package/prompts/quality-strategist.md +274 -0
  2627. package/prompts/researcher.md +98 -0
  2628. package/prompts/security-reviewer.md +143 -0
  2629. package/prompts/sisyphus-lite.md +111 -0
  2630. package/prompts/style-reviewer.md +102 -0
  2631. package/prompts/team-executor.md +57 -0
  2632. package/prompts/team-orchestrator.md +8 -0
  2633. package/prompts/test-engineer.md +130 -0
  2634. package/prompts/ux-researcher.md +327 -0
  2635. package/prompts/verifier.md +85 -0
  2636. package/prompts/vision.md +98 -0
  2637. package/prompts/writer.md +109 -0
  2638. package/skills/ai-slop-cleaner/SKILL.md +139 -0
  2639. package/skills/analyze/SKILL.md +148 -0
  2640. package/skills/ask-claude/SKILL.md +61 -0
  2641. package/skills/ask-gemini/SKILL.md +61 -0
  2642. package/skills/autoforge/SKILL.md +18 -0
  2643. package/skills/autopilot/SKILL.md +163 -0
  2644. package/skills/autoresearch/SKILL.md +68 -0
  2645. package/skills/blueprint/SKILL.md +22 -0
  2646. package/skills/blueprint-loop/SKILL.md +19 -0
  2647. package/skills/blueprint-psych/SKILL.md +21 -0
  2648. package/skills/blueprint-retention/SKILL.md +15 -0
  2649. package/skills/blueprint-social/SKILL.md +15 -0
  2650. package/skills/brief/SKILL.md +27 -0
  2651. package/skills/brief-audience/SKILL.md +19 -0
  2652. package/skills/brief-motivation/SKILL.md +22 -0
  2653. package/skills/build-fix/SKILL.md +145 -0
  2654. package/skills/cancel/SKILL.md +399 -0
  2655. package/skills/code-review/SKILL.md +290 -0
  2656. package/skills/configure-notifications/SKILL.md +287 -0
  2657. package/skills/crew/SKILL.md +10 -0
  2658. package/skills/deep-interview/SKILL.md +468 -0
  2659. package/skills/deepsearch/SKILL.md +38 -0
  2660. package/skills/doctor/SKILL.md +239 -0
  2661. package/skills/ecomode/SKILL.md +114 -0
  2662. package/skills/forge/SKILL.md +30 -0
  2663. package/skills/forge-community/SKILL.md +16 -0
  2664. package/skills/forge-daily-loop/SKILL.md +15 -0
  2665. package/skills/forge-event-loop/SKILL.md +15 -0
  2666. package/skills/forge-fomo/SKILL.md +16 -0
  2667. package/skills/forge-mastery/SKILL.md +16 -0
  2668. package/skills/forge-progression/SKILL.md +16 -0
  2669. package/skills/forge-reward-loop/SKILL.md +19 -0
  2670. package/skills/forge-status/SKILL.md +17 -0
  2671. package/skills/frontend-ui-ux/SKILL.md +34 -0
  2672. package/skills/git-master/SKILL.md +29 -0
  2673. package/skills/help/SKILL.md +75 -0
  2674. package/skills/hud/SKILL.md +98 -0
  2675. package/skills/note/SKILL.md +62 -0
  2676. package/skills/pipeline/SKILL.md +86 -0
  2677. package/skills/plan/SKILL.md +277 -0
  2678. package/skills/ralph/SKILL.md +269 -0
  2679. package/skills/ralph-init/SKILL.md +46 -0
  2680. package/skills/ralplan/SKILL.md +162 -0
  2681. package/skills/rcs-setup/SKILL.md +135 -0
  2682. package/skills/review/SKILL.md +38 -0
  2683. package/skills/security-review/SKILL.md +300 -0
  2684. package/skills/skill/SKILL.md +835 -0
  2685. package/skills/swarm/SKILL.md +25 -0
  2686. package/skills/tdd/SKILL.md +106 -0
  2687. package/skills/team/SKILL.md +510 -0
  2688. package/skills/trace/SKILL.md +33 -0
  2689. package/skills/ultraqa/SKILL.md +143 -0
  2690. package/skills/ultrawork/SKILL.md +175 -0
  2691. package/skills/visual-ralph/SKILL.md +153 -0
  2692. package/skills/visual-verdict/SKILL.md +76 -0
  2693. package/skills/web-clone/SKILL.md +24 -0
  2694. package/skills/wiki/SKILL.md +57 -0
  2695. package/skills/worker/SKILL.md +106 -0
  2696. package/src/scripts/__tests__/codex-native-hook.test.ts +8498 -0
  2697. package/src/scripts/__tests__/generate-release-body.test.ts +275 -0
  2698. package/src/scripts/__tests__/hook-derived-watcher.test.ts +241 -0
  2699. package/src/scripts/__tests__/postinstall.test.ts +113 -0
  2700. package/src/scripts/__tests__/prompt-inventory.test.ts +64 -0
  2701. package/src/scripts/__tests__/run-test-files.test.ts +72 -0
  2702. package/src/scripts/__tests__/smoke-packed-install.test.ts +155 -0
  2703. package/src/scripts/__tests__/test-reply-listener-live.test.ts +101 -0
  2704. package/src/scripts/__tests__/verify-native-agents.test.ts +204 -0
  2705. package/src/scripts/ask-claude.sh +17 -0
  2706. package/src/scripts/ask-gemini.sh +14 -0
  2707. package/src/scripts/build-explore-harness.ts +54 -0
  2708. package/src/scripts/build-sparkshell.ts +52 -0
  2709. package/src/scripts/check-runtime-syntax.ts +63 -0
  2710. package/src/scripts/check-version-sync.ts +50 -0
  2711. package/src/scripts/cleanup-explore-harness.ts +17 -0
  2712. package/src/scripts/codex-execution-surface.ts +73 -0
  2713. package/src/scripts/codex-native-hook.ts +2531 -0
  2714. package/src/scripts/codex-native-pre-post.ts +945 -0
  2715. package/src/scripts/demo-claude-workers.sh +241 -0
  2716. package/src/scripts/demo-team-e2e.sh +181 -0
  2717. package/src/scripts/eval/eval-adaptive-sort-optimization.py +24 -0
  2718. package/src/scripts/eval/eval-candidate-handoff.ts +8 -0
  2719. package/src/scripts/eval/eval-cli-discoverability.ts +40 -0
  2720. package/src/scripts/eval/eval-fresh-run-tagging.ts +8 -0
  2721. package/src/scripts/eval/eval-help-consistency.ts +11 -0
  2722. package/src/scripts/eval/eval-in-action-cat-shellout-demo.ts +31 -0
  2723. package/src/scripts/eval/eval-ml-kaggle-model-optimization.py +29 -0
  2724. package/src/scripts/eval/eval-noisy-bayesopt-highdim.py +44 -0
  2725. package/src/scripts/eval/eval-noisy-latent-subspace-discovery.py +44 -0
  2726. package/src/scripts/eval/eval-parity-smoke.ts +20 -0
  2727. package/src/scripts/eval/eval-parity-sweep.ts +26 -0
  2728. package/src/scripts/eval/eval-resume-dirty-guard.ts +8 -0
  2729. package/src/scripts/eval/eval-security-path-traversal.ts +38 -0
  2730. package/src/scripts/fixtures/ask-advisor-stub.ts +12 -0
  2731. package/src/scripts/generate-catalog-docs.ts +112 -0
  2732. package/src/scripts/generate-native-release-manifest.ts +147 -0
  2733. package/src/scripts/generate-release-body.ts +327 -0
  2734. package/src/scripts/hook-derived-watcher.ts +648 -0
  2735. package/src/scripts/notify-fallback-watcher.ts +2011 -0
  2736. package/src/scripts/notify-hook/__tests__/operational-events.test.ts +24 -0
  2737. package/src/scripts/notify-hook/__tests__/team-worker-posttooluse.test.ts +180 -0
  2738. package/src/scripts/notify-hook/active-team.ts +55 -0
  2739. package/src/scripts/notify-hook/auto-nudge.ts +756 -0
  2740. package/src/scripts/notify-hook/log.ts +30 -0
  2741. package/src/scripts/notify-hook/managed-tmux.ts +586 -0
  2742. package/src/scripts/notify-hook/operational-events.ts +282 -0
  2743. package/src/scripts/notify-hook/orchestration-intent.ts +82 -0
  2744. package/src/scripts/notify-hook/payload-parser.ts +143 -0
  2745. package/src/scripts/notify-hook/process-runner.ts +109 -0
  2746. package/src/scripts/notify-hook/ralph-session-resume.ts +362 -0
  2747. package/src/scripts/notify-hook/state-io.ts +182 -0
  2748. package/src/scripts/notify-hook/team-dispatch.ts +1142 -0
  2749. package/src/scripts/notify-hook/team-leader-nudge.ts +1100 -0
  2750. package/src/scripts/notify-hook/team-tmux-guard.ts +187 -0
  2751. package/src/scripts/notify-hook/team-worker-posttooluse.ts +536 -0
  2752. package/src/scripts/notify-hook/team-worker.ts +700 -0
  2753. package/src/scripts/notify-hook/tmux-injection.ts +617 -0
  2754. package/src/scripts/notify-hook/utils.ts +31 -0
  2755. package/src/scripts/notify-hook/visual-verdict.ts +158 -0
  2756. package/src/scripts/notify-hook.ts +778 -0
  2757. package/src/scripts/postinstall-bootstrap.js +23 -0
  2758. package/src/scripts/postinstall.ts +107 -0
  2759. package/src/scripts/prompt-inventory.ts +218 -0
  2760. package/src/scripts/run-autoresearch-showcase.sh +75 -0
  2761. package/src/scripts/run-provider-advisor.ts +205 -0
  2762. package/src/scripts/run-test-files.ts +87 -0
  2763. package/src/scripts/smoke-packed-install.ts +186 -0
  2764. package/src/scripts/sync-plugin-mirror.ts +412 -0
  2765. package/src/scripts/sync-prompt-guidance-fragments.ts +55 -0
  2766. package/src/scripts/team-hardening-benchmark.ts +90 -0
  2767. package/src/scripts/test-reply-listener-live.ts +188 -0
  2768. package/src/scripts/test-sparkshell.ts +29 -0
  2769. package/src/scripts/tmux-hook-engine.ts +349 -0
  2770. package/src/scripts/verify-native-agents.ts +245 -0
  2771. package/src/scripts/verify-native-release-assets.ts +68 -0
  2772. package/templates/AGENTS.md +347 -0
  2773. package/templates/catalog-manifest.json +614 -0
  2774. package/templates/model-instructions/explore-lightweight-AGENTS.md +11 -0
  2775. package/templates/model-instructions/sparkshell-lightweight-AGENTS.md +10 -0
  2776. package/templates/psychology/dopamine-loop-map.md +13 -0
  2777. package/templates/psychology/event-fomo-design-sheet.md +11 -0
  2778. package/templates/psychology/player-motivation-profile.md +14 -0
  2779. package/templates/psychology/retention-design-sheet.md +12 -0
  2780. package/templates/psychology/social-mechanic-spec.md +11 -0
  2781. package/templates/roblox/pre-action-plan.md +84 -0
@@ -0,0 +1,1879 @@
1
+ import { execFileSync } from "child_process";
2
+ import { closeSync, existsSync, openSync, readFileSync, readSync } from "fs";
3
+ import { mkdir, readFile, readdir, writeFile } from "fs/promises";
4
+ import { join, relative, resolve } from "path";
5
+ import { pathToFileURL } from "url";
6
+ import { readModeState, readModeStateForSession, updateModeState } from "../modes/base.js";
7
+ import { listActiveSkills, readVisibleSkillActiveState, } from "../state/skill-active.js";
8
+ import { readSubagentSessionSummary, recordSubagentTurnForSession, } from "../subagents/tracker.js";
9
+ import { resolveCanonicalTeamStateRoot, resolveWorkerNotifyTeamStateRootPath } from "../team/state-root.js";
10
+ import { appendToLog, isSessionStateUsable, readSessionState, readUsableSessionState, reconcileNativeSessionStart, } from "../hooks/session.js";
11
+ import { appendTeamEvent, readTeamLeaderAttention, readTeamManifestV2, readTeamPhase, writeTeamLeaderAttention, writeTeamPhase, } from "../team/state.js";
12
+ import { rcsNotepadPath, rcsProjectMemoryPath } from "../utils/paths.js";
13
+ import { findGitLayout } from "../utils/git-layout.js";
14
+ import { getStateFilePath, getStatePath } from "../mcp/state-paths.js";
15
+ import { detectKeywords, detectPrimaryKeyword, recordSkillActivation, } from "../hooks/keyword-detector.js";
16
+ import { detectNativeStopStallPattern, loadAutoNudgeConfig, normalizeAutoNudgeSignatureText, resolveEffectiveAutoNudgeResponse, } from "./notify-hook/auto-nudge.js";
17
+ import { buildNativePostToolUseOutput, buildNativePreToolUseOutput, detectMcpTransportFailure, } from "./codex-native-pre-post.js";
18
+ import { handleTeamWorkerPostToolUseSuccess } from "./notify-hook/team-worker-posttooluse.js";
19
+ import { resolveCodexExecutionSurface, } from "./codex-execution-surface.js";
20
+ import { buildNativeHookEvent, } from "../hooks/extensibility/events.js";
21
+ import { dispatchHookEvent } from "../hooks/extensibility/dispatcher.js";
22
+ import { reconcileHudForPromptSubmit } from "../hud/reconcile.js";
23
+ import { onSessionStart as buildWikiSessionStartContext } from "../wiki/lifecycle.js";
24
+ import { readAutoresearchCompletionStatus, readAutoresearchModeState } from "../autoresearch/skill-validation.js";
25
+ import { readRunState } from "../runtime/run-state.js";
26
+ import { getRunContinuationSnapshot, shouldContinueRun } from "../runtime/run-loop.js";
27
+ import { triagePrompt } from "../hooks/triage-heuristic.js";
28
+ import { readTriageConfig } from "../hooks/triage-config.js";
29
+ import { readTriageState, writeTriageState, shouldSuppressFollowup, promptSignature, } from "../hooks/triage-state.js";
30
+ import { isPendingDeepInterviewQuestionEnforcement, reconcileDeepInterviewQuestionEnforcementFromAnsweredRecords, } from "../question/deep-interview.js";
31
+ import { buildDocumentRefreshAdvisoryOutput, evaluateFinalHandoffDocumentRefresh, isFinalHandoffDocumentRefreshCandidate, } from "../document-refresh/enforcer.js";
32
+ import { buildExecFollowupStopOutput } from "../exec/followup.js";
33
+ const TERMINAL_MODE_PHASES = new Set(["complete", "completed", "failed", "cancelled"]);
34
+ const SKILL_STOP_BLOCKERS = new Set(["ralplan"]);
35
+ const TEAM_TERMINAL_TASK_STATUSES = new Set(["completed", "failed"]);
36
+ const TEAM_WORKER_STOP_ACTIVE_STATES = new Set(["working", "blocked"]);
37
+ const NATIVE_STOP_STATE_FILE = "native-stop-state.json";
38
+ const STABLE_FINAL_RECOMMENDATION_PATTERNS = [
39
+ /^\s*(?:launch|release|ship)-?ready\s*:\s*(?:yes|no)\b[^\n\r]*/im,
40
+ /^\s*ready to release\s*:\s*(?:yes|no)\b[^\n\r]*/im,
41
+ /^\s*(?:final\s+)?recommendation\s*:\s*(?:yes|no|ship|hold|release|do not release|proceed|do not proceed)\b[^\n\r]*/im,
42
+ /^\s*decision\s*:\s*(?:yes|no|ship|hold|release|do not release|proceed|do not proceed)\b[^\n\r]*/im,
43
+ ];
44
+ const RELEASE_READINESS_FINALIZE_SYSTEM_MESSAGE = "RCS release-readiness detected a stable final recommendation with no active worker tasks; emit one concise final decision summary and finalize.";
45
+ const EXECUTION_HANDOFF_PATTERNS = [
46
+ /^(?:好|好的|行|可以|那就|那现在)?[,,\s]*(?:开始|继续|直接)\s*(?:执行|优化|实现|修改|修复)(?=$|\s|[,,。.!!??])/u,
47
+ /(?:按照|按|基于)(?:这个|上述|当前)?\s*(?:plan|计划|方案).{0,16}(?:开始|继续|直接)?\s*(?:执行|优化|实现|修改|修复)/u,
48
+ /(?:不用|别|不要).{0,6}讨论/u,
49
+ /\b(?:start|begin|go ahead(?: and)?|proceed(?: now)?)\s+(?:to\s+)?(?:implement|execute|apply|fix)\b/i,
50
+ /\b(?:according to|based on)\s+(?:the|this|that)\s+plan\b.{0,20}\b(?:start|begin|proceed(?: now)?|go ahead(?: and)?)\b/i,
51
+ ];
52
+ const SHORT_FOLLOWUP_PRIORITY_PATTERNS = [
53
+ /^(?:继续|接着|然后|那就|那现在|还有(?:一个)?问题|这些优化都做了么|这些都做了么|现在呢|本轮|当前轮|这一轮)/u,
54
+ /(?:按照|按|基于)(?:这个|上述|当前)?(?:plan|计划|方案)/u,
55
+ /\b(?:follow up|latest request|this turn|current turn|newest request)\b/i,
56
+ ];
57
+ const MAX_SESSION_META_LINE_BYTES = 256 * 1024;
58
+ function safeString(value) {
59
+ return typeof value === "string" ? value : "";
60
+ }
61
+ function safeObject(value) {
62
+ return value && typeof value === "object" ? value : {};
63
+ }
64
+ function readBoundedFirstLineSync(path) {
65
+ const fd = openSync(path, "r");
66
+ try {
67
+ const chunks = [];
68
+ const buffer = Buffer.alloc(Math.min(8192, MAX_SESSION_META_LINE_BYTES));
69
+ let totalBytesRead = 0;
70
+ while (totalBytesRead < MAX_SESSION_META_LINE_BYTES) {
71
+ const bytesToRead = Math.min(buffer.length, MAX_SESSION_META_LINE_BYTES - totalBytesRead);
72
+ const bytesRead = readSync(fd, buffer, 0, bytesToRead, totalBytesRead);
73
+ if (bytesRead <= 0)
74
+ break;
75
+ totalBytesRead += bytesRead;
76
+ const chunk = buffer.subarray(0, bytesRead);
77
+ const newlineOffset = chunk.indexOf(0x0a);
78
+ if (newlineOffset >= 0) {
79
+ chunks.push(Buffer.from(chunk.subarray(0, newlineOffset)));
80
+ break;
81
+ }
82
+ chunks.push(Buffer.from(chunk));
83
+ }
84
+ return Buffer.concat(chunks).toString("utf-8").replace(/\r$/, "");
85
+ }
86
+ finally {
87
+ closeSync(fd);
88
+ }
89
+ }
90
+ function readNativeSubagentSessionStartMetadata(transcriptPath) {
91
+ const normalizedPath = transcriptPath.trim();
92
+ if (!normalizedPath)
93
+ return null;
94
+ try {
95
+ const firstLine = readBoundedFirstLineSync(normalizedPath).trim();
96
+ if (!firstLine)
97
+ return null;
98
+ const firstRecord = safeObject(JSON.parse(firstLine));
99
+ if (safeString(firstRecord.type) !== "session_meta")
100
+ return null;
101
+ const payload = safeObject(firstRecord.payload);
102
+ const source = safeObject(payload.source);
103
+ const subagent = safeObject(source.subagent);
104
+ const threadSpawn = safeObject(subagent.thread_spawn);
105
+ const parentThreadId = safeString(threadSpawn.parent_thread_id).trim();
106
+ if (!parentThreadId)
107
+ return null;
108
+ const agentNickname = safeString(threadSpawn.agent_nickname ?? payload.agent_nickname).trim();
109
+ const agentRole = safeString(threadSpawn.agent_role ?? payload.agent_role).trim();
110
+ return {
111
+ parentThreadId,
112
+ ...(agentNickname ? { agentNickname } : {}),
113
+ ...(agentRole ? { agentRole } : {}),
114
+ };
115
+ }
116
+ catch {
117
+ return null;
118
+ }
119
+ }
120
+ async function recordNativeSubagentSessionStart(cwd, canonicalSessionId, childSessionId, metadata, transcriptPath) {
121
+ const trackingSessionIds = [...new Set([
122
+ canonicalSessionId.trim(),
123
+ metadata.parentThreadId.trim(),
124
+ ].filter(Boolean))];
125
+ for (const sessionId of trackingSessionIds) {
126
+ await recordSubagentTurnForSession(cwd, {
127
+ sessionId,
128
+ threadId: metadata.parentThreadId,
129
+ }).catch(() => { });
130
+ await recordSubagentTurnForSession(cwd, {
131
+ sessionId,
132
+ threadId: childSessionId,
133
+ mode: metadata.agentRole,
134
+ }).catch(() => { });
135
+ }
136
+ await appendToLog(cwd, {
137
+ event: "subagent_session_start",
138
+ session_id: canonicalSessionId,
139
+ native_owner_session_id: metadata.parentThreadId,
140
+ native_session_id: childSessionId,
141
+ parent_thread_id: metadata.parentThreadId,
142
+ ...(metadata.agentNickname ? { agent_nickname: metadata.agentNickname } : {}),
143
+ ...(metadata.agentRole ? { agent_role: metadata.agentRole } : {}),
144
+ ...(transcriptPath ? { transcript_path: transcriptPath } : {}),
145
+ timestamp: new Date().toISOString(),
146
+ }).catch(() => { });
147
+ }
148
+ async function nativeSubagentSessionStartBelongsToCanonicalSession(cwd, canonicalSessionId, currentSessionState, metadata) {
149
+ const parentThreadId = metadata.parentThreadId.trim();
150
+ if (!parentThreadId)
151
+ return false;
152
+ const currentNativeSessionId = safeString(currentSessionState?.native_session_id).trim();
153
+ if (currentNativeSessionId && currentNativeSessionId === parentThreadId) {
154
+ return true;
155
+ }
156
+ const summary = await readSubagentSessionSummary(cwd, canonicalSessionId).catch(() => null);
157
+ if (!summary)
158
+ return false;
159
+ if (summary.leaderThreadId === parentThreadId)
160
+ return true;
161
+ return summary.allThreadIds.includes(parentThreadId);
162
+ }
163
+ async function recordIgnoredNativeSubagentSessionStart(cwd, canonicalSessionId, childSessionId, metadata, transcriptPath) {
164
+ await appendToLog(cwd, {
165
+ event: "subagent_session_start_ignored",
166
+ reason: "parent_not_in_canonical_session",
167
+ session_id: canonicalSessionId,
168
+ native_session_id: childSessionId,
169
+ parent_thread_id: metadata.parentThreadId,
170
+ ...(metadata.agentNickname ? { agent_nickname: metadata.agentNickname } : {}),
171
+ ...(metadata.agentRole ? { agent_role: metadata.agentRole } : {}),
172
+ ...(transcriptPath ? { transcript_path: transcriptPath } : {}),
173
+ timestamp: new Date().toISOString(),
174
+ }).catch(() => { });
175
+ }
176
+ function safePositiveInteger(value) {
177
+ if (typeof value === "number" && Number.isInteger(value) && value > 0)
178
+ return value;
179
+ if (typeof value === "string" && value.trim() !== "") {
180
+ const parsed = Number.parseInt(value.trim(), 10);
181
+ if (Number.isInteger(parsed) && parsed > 0)
182
+ return parsed;
183
+ }
184
+ return null;
185
+ }
186
+ function normalizePromptSignalText(text) {
187
+ return text.trim().replace(/\s+/g, " ");
188
+ }
189
+ function looksLikeExecutionHandoffPrompt(prompt) {
190
+ const normalized = normalizePromptSignalText(prompt);
191
+ if (!normalized)
192
+ return false;
193
+ return EXECUTION_HANDOFF_PATTERNS.some((pattern) => pattern.test(normalized));
194
+ }
195
+ function looksLikeShortFollowupPrompt(prompt) {
196
+ const normalized = normalizePromptSignalText(prompt);
197
+ if (!normalized)
198
+ return false;
199
+ if (looksLikeExecutionHandoffPrompt(normalized))
200
+ return true;
201
+ if (normalized.length > 240)
202
+ return false;
203
+ return SHORT_FOLLOWUP_PRIORITY_PATTERNS.some((pattern) => pattern.test(normalized));
204
+ }
205
+ function buildPromptPriorityMessage(prompt) {
206
+ if (looksLikeExecutionHandoffPrompt(prompt)) {
207
+ return "Newest user input is an execution handoff for the current task. Treat it as authorization to act now against the latest approved plan/request. Do not restate the prior plan unless the user explicitly asks for a recap or status update.";
208
+ }
209
+ if (looksLikeShortFollowupPrompt(prompt)) {
210
+ return "Newest user input is a same-thread follow-up. Answer that latest follow-up directly and prefer it over older unresolved prompts when choosing what to do next.";
211
+ }
212
+ return null;
213
+ }
214
+ function readHookEventName(payload) {
215
+ const raw = safeString(payload.hook_event_name
216
+ ?? payload.hookEventName
217
+ ?? payload.event
218
+ ?? payload.name).trim();
219
+ if (raw === "SessionStart"
220
+ || raw === "PreToolUse"
221
+ || raw === "PostToolUse"
222
+ || raw === "UserPromptSubmit"
223
+ || raw === "Stop") {
224
+ return raw;
225
+ }
226
+ return null;
227
+ }
228
+ export function mapCodexHookEventToRcsEvent(hookEventName) {
229
+ switch (hookEventName) {
230
+ case "SessionStart":
231
+ return "session-start";
232
+ case "PreToolUse":
233
+ return "pre-tool-use";
234
+ case "PostToolUse":
235
+ return "post-tool-use";
236
+ case "UserPromptSubmit":
237
+ return "keyword-detector";
238
+ case "Stop":
239
+ return "stop";
240
+ default:
241
+ return null;
242
+ }
243
+ }
244
+ function readPromptText(payload) {
245
+ const candidates = [
246
+ payload.prompt,
247
+ payload.user_prompt,
248
+ payload.userPrompt,
249
+ ];
250
+ for (const candidate of candidates) {
251
+ const value = safeString(candidate).trim();
252
+ if (value)
253
+ return value;
254
+ }
255
+ return "";
256
+ }
257
+ function sanitizePayloadForHookContext(payload, hookEventName, canonicalSessionId = "") {
258
+ const sanitized = { ...payload };
259
+ if (hookEventName === "UserPromptSubmit") {
260
+ delete sanitized.prompt;
261
+ delete sanitized.input;
262
+ delete sanitized.user_prompt;
263
+ delete sanitized.userPrompt;
264
+ delete sanitized.text;
265
+ return sanitized;
266
+ }
267
+ if (hookEventName === "Stop") {
268
+ delete sanitized.stop_hook_active;
269
+ delete sanitized.stopHookActive;
270
+ delete sanitized.sessionId;
271
+ sanitized.session_id = canonicalSessionId.trim() || safeString(payload.session_id ?? payload.sessionId).trim();
272
+ }
273
+ return sanitized;
274
+ }
275
+ function buildBaseContext(cwd, payload, hookEventName, canonicalSessionId = "") {
276
+ return {
277
+ cwd,
278
+ project_path: cwd,
279
+ transcript_path: safeString(payload.transcript_path ?? payload.transcriptPath) || null,
280
+ source: safeString(payload.source),
281
+ payload: sanitizePayloadForHookContext(payload, hookEventName, canonicalSessionId),
282
+ };
283
+ }
284
+ async function readJsonIfExists(path) {
285
+ if (!existsSync(path))
286
+ return null;
287
+ try {
288
+ return JSON.parse(await readFile(path, "utf-8"));
289
+ }
290
+ catch {
291
+ return null;
292
+ }
293
+ }
294
+ function isNonTerminalPhase(value) {
295
+ const phase = safeString(value).trim().toLowerCase();
296
+ return phase !== "" && !TERMINAL_MODE_PHASES.has(phase);
297
+ }
298
+ function formatPhase(value, fallback = "active") {
299
+ const phase = safeString(value).trim();
300
+ return phase || fallback;
301
+ }
302
+ async function readActiveAutoresearchState(cwd, sessionId) {
303
+ const normalizedSessionId = sessionId?.trim() || undefined;
304
+ if (!normalizedSessionId)
305
+ return null;
306
+ const state = await readAutoresearchModeState(cwd, normalizedSessionId);
307
+ if (state?.active !== true)
308
+ return null;
309
+ if (!isNonTerminalPhase(state.current_phase ?? state.currentPhase ?? 'executing'))
310
+ return null;
311
+ return state;
312
+ }
313
+ function isRalphStartingPhase(state) {
314
+ return safeString(state.current_phase ?? state.currentPhase).trim().toLowerCase() === "starting";
315
+ }
316
+ function hasValue(values, value) {
317
+ return value !== "" && values.some((candidate) => candidate === value);
318
+ }
319
+ function activeRalphStateMatchesStopOwner(state, context) {
320
+ const ownerRcsSessionId = safeString(state.owner_rcs_session_id).trim();
321
+ if (ownerRcsSessionId && ownerRcsSessionId !== context.sessionId) {
322
+ return false;
323
+ }
324
+ const stateSessionId = safeString(state.session_id).trim();
325
+ if (!ownerRcsSessionId && stateSessionId && stateSessionId !== context.sessionId) {
326
+ return false;
327
+ }
328
+ const codexOwnerSessionId = safeString(state.owner_codex_session_id).trim();
329
+ if (codexOwnerSessionId) {
330
+ const stopCodexSessionIds = [
331
+ context.payloadSessionId,
332
+ context.currentNativeSessionId,
333
+ context.sessionId,
334
+ ].filter(Boolean);
335
+ if (!hasValue(stopCodexSessionIds, codexOwnerSessionId))
336
+ return false;
337
+ }
338
+ const stateThreadId = safeString(state.owner_codex_thread_id ?? state.thread_id).trim();
339
+ if (stateThreadId && context.threadId && stateThreadId !== context.threadId) {
340
+ return false;
341
+ }
342
+ const statePaneId = safeString(state.tmux_pane_id).trim();
343
+ if (statePaneId && context.tmuxPaneId && statePaneId !== context.tmuxPaneId) {
344
+ return false;
345
+ }
346
+ return true;
347
+ }
348
+ function shouldHonorCanonicalTerminalRunState(runState, mode) {
349
+ if (!runState)
350
+ return false;
351
+ const runMode = safeString(runState.mode).trim();
352
+ if (runMode && runMode !== mode)
353
+ return false;
354
+ return getRunContinuationSnapshot(runState)?.terminal === true;
355
+ }
356
+ async function readCanonicalTerminalRunStateForStop(cwd, sessionId, mode) {
357
+ if (!safeString(sessionId).trim())
358
+ return null;
359
+ const runState = await readRunState(cwd, sessionId).catch(() => null);
360
+ const runRecord = runState;
361
+ return shouldHonorCanonicalTerminalRunState(runRecord, mode) ? runRecord : null;
362
+ }
363
+ async function isVisibleRalphActiveForSession(cwd, sessionId) {
364
+ const canonicalState = await readVisibleSkillActiveState(cwd, sessionId);
365
+ if (!canonicalState)
366
+ return false;
367
+ return listActiveSkills(canonicalState).some((entry) => (entry.skill === "ralph"
368
+ && matchesSkillStopContext(entry, canonicalState, sessionId, "")));
369
+ }
370
+ async function readActiveRalphState(stateDir, preferredSessionId, ownerContext) {
371
+ const cwd = resolve(stateDir, "..", "..");
372
+ const [rawSessionInfo, usableSessionInfo] = await Promise.all([
373
+ readSessionState(cwd),
374
+ readUsableSessionState(cwd),
375
+ ]);
376
+ const currentRcsSessionId = safeString(usableSessionInfo?.session_id).trim();
377
+ const currentNativeSessionId = safeString(usableSessionInfo?.native_session_id).trim();
378
+ const staleCurrentSessionId = rawSessionInfo && !isSessionStateUsable(rawSessionInfo, cwd)
379
+ ? safeString(rawSessionInfo.session_id).trim()
380
+ : "";
381
+ const sessionCandidates = [...new Set([
382
+ safeString(preferredSessionId).trim(),
383
+ currentRcsSessionId,
384
+ ].filter(Boolean))];
385
+ // Ralph Stop stays authoritative-scope-only once the Stop payload is session-bound.
386
+ // That is intentionally stricter than generic state MCP reads: do not scan sibling
387
+ // session scopes or fall back to root when a current/explicit session is in play.
388
+ for (const sessionId of sessionCandidates) {
389
+ if (staleCurrentSessionId && sessionId === staleCurrentSessionId) {
390
+ continue;
391
+ }
392
+ if (await readCanonicalTerminalRunStateForStop(cwd, sessionId, "ralph")) {
393
+ continue;
394
+ }
395
+ const sessionScopedPath = getStateFilePath("ralph-state.json", cwd, sessionId);
396
+ const sessionScoped = await readJsonIfExists(sessionScopedPath);
397
+ if (sessionScoped?.active === true
398
+ && isRalphStartingPhase(sessionScoped)
399
+ && !(await isVisibleRalphActiveForSession(cwd, sessionId))) {
400
+ continue;
401
+ }
402
+ if (sessionScoped?.active === true
403
+ && shouldContinueRun(sessionScoped)
404
+ && activeRalphStateMatchesStopOwner(sessionScoped, {
405
+ sessionId,
406
+ payloadSessionId: safeString(ownerContext?.payloadSessionId).trim(),
407
+ threadId: safeString(ownerContext?.threadId).trim(),
408
+ currentNativeSessionId,
409
+ tmuxPaneId: safeString(ownerContext?.tmuxPaneId).trim(),
410
+ })) {
411
+ return { state: sessionScoped, path: sessionScopedPath };
412
+ }
413
+ }
414
+ if (sessionCandidates.length > 0)
415
+ return null;
416
+ const directPath = join(stateDir, "ralph-state.json");
417
+ const direct = await readJsonIfExists(directPath);
418
+ if (direct?.active === true && shouldContinueRun(direct)) {
419
+ return { state: direct, path: directPath };
420
+ }
421
+ return null;
422
+ }
423
+ function readParentPid(pid) {
424
+ try {
425
+ if (process.platform === "linux") {
426
+ const stat = readFileSync(`/proc/${pid}/stat`, "utf-8");
427
+ const commandEnd = stat.lastIndexOf(")");
428
+ if (commandEnd === -1)
429
+ return null;
430
+ const remainder = stat.slice(commandEnd + 1).trim();
431
+ const fields = remainder.split(/\s+/);
432
+ const ppid = Number(fields[1]);
433
+ return Number.isFinite(ppid) && ppid > 0 ? ppid : null;
434
+ }
435
+ const raw = execFileSync("ps", ["-o", "ppid=", "-p", String(pid)], {
436
+ encoding: "utf-8",
437
+ stdio: ["ignore", "pipe", "ignore"],
438
+ }).trim();
439
+ const ppid = Number.parseInt(raw, 10);
440
+ return Number.isFinite(ppid) && ppid > 0 ? ppid : null;
441
+ }
442
+ catch {
443
+ return null;
444
+ }
445
+ }
446
+ function readProcessCommand(pid) {
447
+ try {
448
+ if (process.platform === "linux") {
449
+ return readFileSync(`/proc/${pid}/cmdline`, "utf-8")
450
+ .replace(/\u0000+/g, " ")
451
+ .trim();
452
+ }
453
+ return execFileSync("ps", ["-o", "command=", "-p", String(pid)], {
454
+ encoding: "utf-8",
455
+ stdio: ["ignore", "pipe", "ignore"],
456
+ }).trim();
457
+ }
458
+ catch {
459
+ return "";
460
+ }
461
+ }
462
+ function looksLikeShellCommand(command) {
463
+ return /(^|[\/\s])(bash|zsh|sh|dash|fish|ksh)(\s|$)/i.test(command);
464
+ }
465
+ function looksLikeCodexCommand(command) {
466
+ if (/codex-native-hook(?:\.js)?/i.test(command))
467
+ return false;
468
+ return /\bcodex(?:\.js)?\b/i.test(command);
469
+ }
470
+ export function resolveSessionOwnerPidFromAncestry(startPid, options = {}) {
471
+ const readParent = options.readParentPid ?? readParentPid;
472
+ const readCommand = options.readProcessCommand ?? readProcessCommand;
473
+ const lineage = [];
474
+ let currentPid = startPid;
475
+ for (let i = 0; i < 6 && Number.isInteger(currentPid) && currentPid > 1; i += 1) {
476
+ const command = readCommand(currentPid);
477
+ lineage.push({ pid: currentPid, command });
478
+ const nextPid = readParent(currentPid);
479
+ if (!nextPid || nextPid === currentPid)
480
+ break;
481
+ currentPid = nextPid;
482
+ }
483
+ const codexAncestor = lineage.find((entry) => looksLikeCodexCommand(entry.command));
484
+ if (codexAncestor)
485
+ return codexAncestor.pid;
486
+ if (lineage.length >= 2 && looksLikeShellCommand(lineage[0]?.command || "")) {
487
+ return lineage[1].pid;
488
+ }
489
+ if (lineage.length >= 1)
490
+ return lineage[0].pid;
491
+ return null;
492
+ }
493
+ function resolveSessionOwnerPid(payload) {
494
+ const explicitPid = [
495
+ payload.session_pid,
496
+ payload.sessionPid,
497
+ payload.codex_pid,
498
+ payload.codexPid,
499
+ payload.parent_pid,
500
+ payload.parentPid,
501
+ ]
502
+ .map(safePositiveInteger)
503
+ .find((value) => value !== null);
504
+ if (explicitPid)
505
+ return explicitPid;
506
+ const resolved = resolveSessionOwnerPidFromAncestry(process.ppid);
507
+ if (resolved)
508
+ return resolved;
509
+ return process.pid;
510
+ }
511
+ function tryReadGitValue(cwd, args) {
512
+ try {
513
+ const value = execFileSync("git", args, {
514
+ cwd,
515
+ encoding: "utf-8",
516
+ stdio: ["ignore", "pipe", "ignore"],
517
+ windowsHide: true,
518
+ }).trim();
519
+ return value || null;
520
+ }
521
+ catch {
522
+ return null;
523
+ }
524
+ }
525
+ function localExcludeAlreadyIgnoresRcsPath(cwd) {
526
+ const layout = findGitLayout(cwd);
527
+ if (!layout)
528
+ return false;
529
+ const excludePath = join(layout.gitDir, "info", "exclude");
530
+ try {
531
+ const lines = readFileSync(excludePath, "utf-8")
532
+ .split(/\r?\n/)
533
+ .map((line) => line.trim())
534
+ .filter((line) => line && !line.startsWith("#"));
535
+ return lines.includes(".rcs/") || lines.includes(".rcs");
536
+ }
537
+ catch {
538
+ return false;
539
+ }
540
+ }
541
+ function isPathIgnoredByGit(cwd, path) {
542
+ try {
543
+ execFileSync("git", ["check-ignore", "-q", path], {
544
+ cwd,
545
+ stdio: ["ignore", "ignore", "ignore"],
546
+ windowsHide: true,
547
+ });
548
+ return true;
549
+ }
550
+ catch {
551
+ return false;
552
+ }
553
+ }
554
+ async function ensureRcsLocalIgnoreEntry(cwd) {
555
+ const repoRoot = tryReadGitValue(cwd, ["rev-parse", "--show-toplevel"]);
556
+ if (!repoRoot)
557
+ return { changed: false };
558
+ if (localExcludeAlreadyIgnoresRcsPath(repoRoot) || isPathIgnoredByGit(repoRoot, ".rcs/")) {
559
+ return { changed: false };
560
+ }
561
+ const excludePathValue = tryReadGitValue(repoRoot, ["rev-parse", "--git-path", "info/exclude"]);
562
+ if (!excludePathValue)
563
+ return { changed: false };
564
+ const excludePath = resolve(repoRoot, excludePathValue);
565
+ const existing = existsSync(excludePath)
566
+ ? await readFile(excludePath, "utf-8")
567
+ : "";
568
+ const lines = existing.split(/\r?\n/).map((line) => line.trim());
569
+ if (lines.includes(".rcs/")) {
570
+ return { changed: false, excludePath };
571
+ }
572
+ const next = `${existing}${existing.endsWith("\n") || existing.length === 0 ? "" : "\n"}.rcs/\n`;
573
+ await writeFile(excludePath, next);
574
+ return { changed: true, excludePath };
575
+ }
576
+ async function buildSessionStartContext(cwd, sessionId, options = {}) {
577
+ const sections = [];
578
+ sections.push(buildExecutionEnvironmentSection(cwd, {
579
+ hookEventName: options.hookEventName,
580
+ payload: options.payload,
581
+ canonicalSessionId: options.canonicalSessionId,
582
+ nativeSessionId: options.nativeSessionId,
583
+ }));
584
+ const localIgnoreResult = await ensureRcsLocalIgnoreEntry(cwd);
585
+ if (localIgnoreResult.changed) {
586
+ sections.push(`Added .rcs/ to ${localIgnoreResult.excludePath} to keep local RCS state out of source control without mutating tracked repo ignores.`);
587
+ }
588
+ const modeSummaries = [];
589
+ for (const mode of ["ralph", "autopilot", "ultrawork", "ultraqa", "ralplan", "deep-interview", "team"]) {
590
+ const state = await readJsonIfExists(getStatePath(mode, cwd, sessionId));
591
+ if (state?.active !== true || !isNonTerminalPhase(state.current_phase))
592
+ continue;
593
+ if (mode === "team") {
594
+ const teamName = safeString(state.team_name).trim();
595
+ if (teamName) {
596
+ const phase = await readTeamPhase(teamName, cwd);
597
+ const canonicalPhase = phase?.current_phase ?? state.current_phase;
598
+ if (isNonTerminalPhase(canonicalPhase)) {
599
+ modeSummaries.push(`- team (${teamName}) phase: ${formatPhase(canonicalPhase)}`);
600
+ }
601
+ continue;
602
+ }
603
+ }
604
+ modeSummaries.push(`- ${mode} phase: ${formatPhase(state.current_phase)}`);
605
+ }
606
+ if (modeSummaries.length > 0) {
607
+ sections.push(["[Active RCS modes]", ...modeSummaries].join("\n"));
608
+ }
609
+ const projectMemory = await readJsonIfExists(rcsProjectMemoryPath(cwd));
610
+ if (projectMemory) {
611
+ const directives = Array.isArray(projectMemory.directives) ? projectMemory.directives : [];
612
+ const notes = Array.isArray(projectMemory.notes) ? projectMemory.notes : [];
613
+ const techStack = safeString(projectMemory.techStack).trim();
614
+ const conventions = safeString(projectMemory.conventions).trim();
615
+ const build = safeString(projectMemory.build).trim();
616
+ const summary = [];
617
+ if (techStack)
618
+ summary.push(`- stack: ${techStack}`);
619
+ if (conventions)
620
+ summary.push(`- conventions: ${conventions}`);
621
+ if (build)
622
+ summary.push(`- build: ${build}`);
623
+ if (directives.length > 0) {
624
+ const firstDirective = directives[0];
625
+ const directive = safeString(firstDirective.directive).trim();
626
+ if (directive)
627
+ summary.push(`- directive: ${directive}`);
628
+ }
629
+ if (notes.length > 0) {
630
+ const firstNote = notes[0];
631
+ const note = safeString(firstNote.content).trim();
632
+ if (note)
633
+ summary.push(`- note: ${note}`);
634
+ }
635
+ if (summary.length > 0) {
636
+ sections.push(["[Project memory]", ...summary].join("\n"));
637
+ }
638
+ }
639
+ if (existsSync(rcsNotepadPath(cwd))) {
640
+ try {
641
+ const notepad = await readFile(rcsNotepadPath(cwd), "utf-8");
642
+ const header = "## PRIORITY";
643
+ const idx = notepad.indexOf(header);
644
+ if (idx >= 0) {
645
+ const nextHeader = notepad.indexOf("\n## ", idx + header.length);
646
+ const section = (nextHeader < 0
647
+ ? notepad.slice(idx + header.length)
648
+ : notepad.slice(idx + header.length, nextHeader))
649
+ .split(/\r?\n/)
650
+ .map((line) => line.trim())
651
+ .filter(Boolean)
652
+ .join(" ");
653
+ if (section) {
654
+ sections.push(`[Priority notes]\n- ${section.slice(0, 220)}`);
655
+ }
656
+ }
657
+ }
658
+ catch {
659
+ // best effort only
660
+ }
661
+ }
662
+ const wikiContext = buildWikiSessionStartContext({ cwd });
663
+ if (wikiContext.additionalContext) {
664
+ sections.push(wikiContext.additionalContext);
665
+ }
666
+ const subagentSummary = await readSubagentSessionSummary(cwd, sessionId).catch(() => null);
667
+ if (subagentSummary && subagentSummary.activeSubagentThreadIds.length > 0) {
668
+ sections.push(`[Subagents]\n- active subagent threads: ${subagentSummary.activeSubagentThreadIds.length}`);
669
+ }
670
+ return sections.length > 0 ? sections.join("\n\n") : null;
671
+ }
672
+ function resolveExecutionEnvironment(cwd, options = {}) {
673
+ const executionSurface = resolveCodexExecutionSurface(cwd, options);
674
+ const leaderPaneHint = resolveQuestionLeaderPaneHint(cwd, options.payload);
675
+ const questionBridgeHint = leaderPaneHint
676
+ ? `tmux return bridge recorded at ${leaderPaneHint}, but this process is not attached to tmux; prefer native/user-input fallback unless running from an attached tmux pane`
677
+ : "not available from this outside-tmux surface; use native structured input when available or ask one concise plain-text question";
678
+ if (executionSurface.transport === "attached-tmux") {
679
+ return {
680
+ kind: "attached-tmux-runtime",
681
+ launcher: executionSurface.launcher,
682
+ transport: executionSurface.transport,
683
+ surface: "attached tmux runtime - tmux",
684
+ tmuxWorkflowGuidance: "rcs team, rcs hud, and rcs question are directly usable in this session",
685
+ questionGuidance: "visible temporary renderer available from the current pane; primary success JSON is answers[]",
686
+ teamRuntimeInstruction: "Use the durable RCS team runtime via `rcs team ...` for coordinated execution; do not replace it with in-process fanout.",
687
+ teamHelpInstruction: "If you need runtime syntax, run `rcs team --help` yourself.",
688
+ deepInterviewInstruction: "Deep-interview must ask each interview round via `rcs question`; do not fall back to `request_user_input` or plain-text questioning. This session is already attached to tmux, so `rcs question` can open its temporary renderer directly over the leader pane. After starting `rcs question` in a background terminal, wait for that terminal to finish and read the JSON answer before continuing the interview. Prefer `answers[0].answer` / `answers[]`; use legacy `answer` only as fallback. Deep-interview remains one question per round, so do not batch multiple interview rounds into one `questions[]` form. Stop remains blocked while a deep-interview question obligation is pending.",
689
+ leaderPaneHint,
690
+ };
691
+ }
692
+ if (leaderPaneHint) {
693
+ const isNativeOutsideTmux = executionSurface.launcher === "native";
694
+ return {
695
+ kind: "outside-tmux-with-bridge",
696
+ launcher: executionSurface.launcher,
697
+ transport: executionSurface.transport,
698
+ surface: isNativeOutsideTmux
699
+ ? "native-hook / Codex App outside tmux with tmux return bridge"
700
+ : "direct CLI outside tmux with tmux return bridge",
701
+ tmuxWorkflowGuidance: "rcs team and rcs hud need an attached tmux RCS CLI shell from this surface; rcs question can use the detected bridge",
702
+ questionGuidance: questionBridgeHint,
703
+ teamRuntimeInstruction: isNativeOutsideTmux
704
+ ? "This session is native-hook / Codex App outside tmux; `rcs team` is a CLI/tmux runtime surface, not directly available here. Launch RCS CLI from an attached tmux shell first; do not replace it with in-process fanout."
705
+ : "This session is direct CLI outside tmux with a tmux return bridge for `rcs question`; prompt-side `$team` does not auto-start the durable tmux team runtime here. If you intentionally want the runtime, run `rcs team ...` yourself from shell instead of replacing it with in-process fanout.",
706
+ teamHelpInstruction: isNativeOutsideTmux
707
+ ? "If you need runtime syntax, run `rcs team --help` from an attached tmux RCS CLI shell."
708
+ : "If you need runtime syntax, run `rcs team --help` yourself from shell.",
709
+ deepInterviewInstruction: `Deep-interview is active, but this session is not attached to tmux. Do not invoke \`rcs question\`, \`rcs hud\`, or \`rcs team\` from this surface. Ask each interview round through the native structured question tool when available; otherwise ask exactly one concise plain-text question and wait for the answer. A tmux return bridge (${leaderPaneHint}) is recorded for explicit attached-tmux recovery only, not for default Codex App/native fallback.`,
710
+ leaderPaneHint,
711
+ };
712
+ }
713
+ const isNativeOutsideTmux = executionSurface.launcher === "native" && executionSurface.transport === "outside-tmux";
714
+ const surface = isNativeOutsideTmux
715
+ ? "native-hook / Codex App outside tmux"
716
+ : "direct CLI outside tmux";
717
+ const teamRuntimeInstruction = isNativeOutsideTmux
718
+ ? "This session is native-hook / Codex App outside tmux; `rcs team` is a CLI/tmux runtime surface, not directly available here. Launch RCS CLI from an attached tmux shell first; do not replace it with in-process fanout."
719
+ : "This session is direct CLI outside tmux; prompt-side `$team` does not auto-start the durable tmux team runtime here. If you intentionally want the runtime, run `rcs team ...` yourself from shell instead of replacing it with in-process fanout.";
720
+ const teamHelpInstruction = isNativeOutsideTmux
721
+ ? "If you need runtime syntax, run `rcs team --help` from an attached tmux RCS CLI shell rather than from Codex App/native outside-tmux context."
722
+ : "If you need runtime syntax, run `rcs team --help` yourself from shell.";
723
+ return {
724
+ kind: isNativeOutsideTmux ? "native-outside-tmux" : "direct-cli-outside-tmux",
725
+ launcher: executionSurface.launcher,
726
+ transport: executionSurface.transport,
727
+ surface,
728
+ tmuxWorkflowGuidance: "rcs team, rcs hud, and rcs question need an attached tmux RCS CLI shell or preserved question bridge from this surface",
729
+ questionGuidance: questionBridgeHint,
730
+ teamRuntimeInstruction,
731
+ teamHelpInstruction,
732
+ deepInterviewInstruction: "Deep-interview is active, but this session is not attached to tmux. Do not invoke `rcs question`, `rcs hud`, or `rcs team` from this surface. Ask each interview round through the native structured question tool when available; otherwise ask exactly one concise plain-text question and wait for the answer. Stop gating still applies to the interview, but no tmux question obligation should be created outside tmux.",
733
+ leaderPaneHint: "",
734
+ };
735
+ }
736
+ function buildExecutionEnvironmentSection(cwd, options = {}) {
737
+ const environment = resolveExecutionEnvironment(cwd, options);
738
+ return [
739
+ "[Execution environment]",
740
+ `- surface: ${environment.surface}`,
741
+ `- rcs runtime surfaces: ${environment.tmuxWorkflowGuidance}`,
742
+ `- rcs question: ${environment.questionGuidance}`,
743
+ ].join("\n");
744
+ }
745
+ function resolveQuestionLeaderPaneHint(cwd, payload) {
746
+ const payloadSessionId = safeString(payload?.session_id).trim();
747
+ const envSessionId = safeString(process.env.RCS_SESSION_ID || process.env.CODEX_SESSION_ID || process.env.SESSION_ID).trim();
748
+ const sessionId = payloadSessionId || envSessionId;
749
+ const candidatePaths = [
750
+ ...(sessionId ? [getStatePath('deep-interview', cwd, sessionId), getStatePath('ralplan', cwd, sessionId), getStatePath('ralph', cwd, sessionId)] : []),
751
+ getStatePath('deep-interview', cwd),
752
+ getStatePath('ralplan', cwd),
753
+ getStatePath('ralph', cwd),
754
+ ];
755
+ for (const path of candidatePaths) {
756
+ try {
757
+ if (!existsSync(path))
758
+ continue;
759
+ const parsed = JSON.parse(readFileSync(path, 'utf-8'));
760
+ const pane = safeString(parsed?.tmux_pane_id).trim();
761
+ if (/^%\d+$/.test(pane))
762
+ return pane;
763
+ }
764
+ catch {
765
+ // best effort only
766
+ }
767
+ }
768
+ const envPane = safeString(process.env.TMUX_PANE).trim();
769
+ return /^%\d+$/.test(envPane) ? envPane : '';
770
+ }
771
+ function buildDeepInterviewQuestionBridgeInstruction(cwd, payload) {
772
+ return resolveExecutionEnvironment(cwd, {
773
+ hookEventName: "UserPromptSubmit",
774
+ payload,
775
+ nativeSessionId: safeString(payload?.session_id ?? payload?.sessionId).trim(),
776
+ }).deepInterviewInstruction;
777
+ }
778
+ function buildTeamRuntimeInstruction(cwd, payload) {
779
+ return resolveExecutionEnvironment(cwd, {
780
+ hookEventName: "UserPromptSubmit",
781
+ payload,
782
+ nativeSessionId: safeString(payload?.session_id ?? payload?.sessionId).trim(),
783
+ }).teamRuntimeInstruction;
784
+ }
785
+ function buildTeamHelpInstruction(cwd, payload) {
786
+ return resolveExecutionEnvironment(cwd, {
787
+ hookEventName: "UserPromptSubmit",
788
+ payload,
789
+ nativeSessionId: safeString(payload?.session_id ?? payload?.sessionId).trim(),
790
+ }).teamHelpInstruction;
791
+ }
792
+ function buildNativeOutsideTmuxTeamPromptBlockState(prompt, cwd, payload, sessionId, threadId, turnId) {
793
+ const match = detectPrimaryKeyword(prompt);
794
+ if (match?.skill !== "team")
795
+ return null;
796
+ const environment = resolveExecutionEnvironment(cwd, {
797
+ hookEventName: "UserPromptSubmit",
798
+ payload,
799
+ canonicalSessionId: sessionId ?? "",
800
+ nativeSessionId: safeString(payload.session_id ?? payload.sessionId).trim(),
801
+ });
802
+ if (!(environment.launcher === "native" && environment.transport === "outside-tmux"))
803
+ return null;
804
+ const nowIso = new Date().toISOString();
805
+ return {
806
+ version: 1,
807
+ active: false,
808
+ skill: "team",
809
+ keyword: match.keyword,
810
+ phase: "planning",
811
+ activated_at: nowIso,
812
+ updated_at: nowIso,
813
+ source: "keyword-detector",
814
+ session_id: sessionId,
815
+ thread_id: threadId,
816
+ turn_id: turnId,
817
+ active_skills: [],
818
+ transition_error: "Codex App/native outside-tmux sessions cannot activate the tmux-only `team` workflow directly. Launch RCS CLI from an attached tmux shell first, then run `rcs team ...` there.",
819
+ };
820
+ }
821
+ function buildAdditionalContextMessage(prompt, skillState, cwd = process.cwd(), payload) {
822
+ if (!prompt)
823
+ return null;
824
+ const promptPriorityMessage = buildPromptPriorityMessage(prompt);
825
+ const matches = detectKeywords(prompt);
826
+ const match = detectPrimaryKeyword(prompt);
827
+ if (!match)
828
+ return promptPriorityMessage;
829
+ const detectedKeywordMessage = matches.length > 1
830
+ ? `RCS native UserPromptSubmit detected workflow keywords ${matches.map((entry) => `"${entry.keyword}" -> ${entry.skill}`).join(", ")}.`
831
+ : `RCS native UserPromptSubmit detected workflow keyword "${match.keyword}" -> ${match.skill}.`;
832
+ const activeSkills = Array.isArray(skillState?.active_skills)
833
+ ? skillState.active_skills.map((entry) => entry.skill)
834
+ : [];
835
+ const deferredSkills = Array.isArray(skillState?.deferred_skills)
836
+ ? skillState.deferred_skills
837
+ : [];
838
+ const teamDetected = activeSkills.includes("team");
839
+ const ralphPromptActivationNote = skillState?.initialized_mode === "ralph"
840
+ ? "Prompt-side `$ralph` activation seeds Ralph workflow state only; it does not invoke `rcs ralph`. Use `rcs ralph --prd ...` only when you explicitly want the PRD-gated CLI startup path."
841
+ : null;
842
+ const deepInterviewPromptActivationNote = skillState?.initialized_mode === "deep-interview"
843
+ ? buildDeepInterviewQuestionBridgeInstruction(cwd, payload)
844
+ : null;
845
+ const ultraworkPromptActivationNote = skillState?.initialized_mode === "ultrawork"
846
+ ? "Ultrawork protocol: ground the task before editing, define pass/fail acceptance criteria, keep shared-file work local, and use direct-tool plus background evidence lanes only for truly independent work. Direct ultrawork provides lightweight verification only; Ralph owns persistence and the full verified-completion promise."
847
+ : null;
848
+ const combinedTransitionMessage = (() => {
849
+ if (!skillState?.transition_message)
850
+ return null;
851
+ if (matches.length <= 1 || activeSkills.length <= 1)
852
+ return skillState.transition_message;
853
+ const source = skillState.transition_message.match(/^mode transiting: (.+?) -> /)?.[1];
854
+ if (!source)
855
+ return skillState.transition_message;
856
+ return `mode transiting: ${source} -> ${activeSkills.join(" + ")}`;
857
+ })();
858
+ if (skillState?.transition_error) {
859
+ return [
860
+ `RCS native UserPromptSubmit denied workflow keyword "${match.keyword}" -> ${match.skill}.`,
861
+ skillState.transition_error,
862
+ promptPriorityMessage,
863
+ 'Follow AGENTS.md routing and preserve workflow transition and planning-safety rules.',
864
+ ].join(' ');
865
+ }
866
+ if (skillState?.transition_message) {
867
+ return [
868
+ detectedKeywordMessage,
869
+ combinedTransitionMessage,
870
+ activeSkills.length > 1 ? `active skills: ${activeSkills.join(", ")}.` : null,
871
+ deferredSkills.length > 0
872
+ ? `planning preserved over simultaneous execution follow-up; deferred skills: ${deferredSkills.join(", ")}.`
873
+ : null,
874
+ promptPriorityMessage,
875
+ skillState.initialized_mode && skillState.initialized_state_path
876
+ ? `skill: ${skillState.initialized_mode} activated and initial state initialized at ${skillState.initialized_state_path}; write subsequent updates via rcs_state MCP.`
877
+ : null,
878
+ teamDetected
879
+ ? buildTeamRuntimeInstruction(cwd, payload)
880
+ : null,
881
+ teamDetected ? buildTeamHelpInstruction(cwd, payload) : null,
882
+ 'Follow AGENTS.md routing and preserve workflow transition and planning-safety rules.',
883
+ ].filter(Boolean).join(' ');
884
+ }
885
+ if (teamDetected) {
886
+ const initializedStateMessage = skillState?.initialized_mode && skillState.initialized_state_path
887
+ ? `skill: ${skillState.initialized_mode} activated and initial state initialized at ${skillState.initialized_state_path}; write subsequent updates via rcs_state MCP.`
888
+ : null;
889
+ return [
890
+ detectedKeywordMessage,
891
+ activeSkills.length > 1 ? `active skills: ${activeSkills.join(", ")}.` : null,
892
+ deferredSkills.length > 0
893
+ ? `planning preserved over simultaneous execution follow-up; deferred skills: ${deferredSkills.join(", ")}.`
894
+ : null,
895
+ promptPriorityMessage,
896
+ initializedStateMessage,
897
+ deepInterviewPromptActivationNote,
898
+ ultraworkPromptActivationNote,
899
+ buildTeamRuntimeInstruction(cwd, payload),
900
+ buildTeamHelpInstruction(cwd, payload),
901
+ "Follow AGENTS.md routing and preserve workflow transition and planning-safety rules.",
902
+ ].filter(Boolean).join(" ");
903
+ }
904
+ if (skillState?.initialized_mode && skillState.initialized_state_path) {
905
+ return [
906
+ detectedKeywordMessage,
907
+ activeSkills.length > 1 ? `active skills: ${activeSkills.join(", ")}.` : null,
908
+ deferredSkills.length > 0
909
+ ? `planning preserved over simultaneous execution follow-up; deferred skills: ${deferredSkills.join(", ")}.`
910
+ : null,
911
+ promptPriorityMessage,
912
+ `skill: ${skillState.initialized_mode} activated and initial state initialized at ${skillState.initialized_state_path}; write subsequent updates via rcs_state MCP.`,
913
+ deepInterviewPromptActivationNote,
914
+ ultraworkPromptActivationNote,
915
+ ralphPromptActivationNote,
916
+ "Follow AGENTS.md routing and preserve workflow transition and planning-safety rules.",
917
+ ].join(" ");
918
+ }
919
+ return [detectedKeywordMessage, promptPriorityMessage, "Follow AGENTS.md routing and preserve workflow transition and planning-safety rules."].filter(Boolean).join(" ");
920
+ }
921
+ function parseTeamWorkerEnv(rawValue) {
922
+ const match = /^([a-z0-9][a-z0-9-]{0,29})\/(worker-\d+)$/.exec(rawValue.trim());
923
+ if (!match)
924
+ return null;
925
+ return {
926
+ teamName: match[1] || "",
927
+ workerName: match[2] || "",
928
+ };
929
+ }
930
+ async function resolveTeamStateDirForWorkerContext(cwd, workerContext) {
931
+ return resolveWorkerNotifyTeamStateRootPath(cwd, workerContext, process.env);
932
+ }
933
+ async function buildTeamWorkerStopOutput(cwd) {
934
+ const workerContext = parseTeamWorkerEnv(safeString(process.env.RCS_TEAM_INTERNAL_WORKER || process.env.RCS_TEAM_WORKER));
935
+ if (!workerContext)
936
+ return null;
937
+ const stateDir = await resolveTeamStateDirForWorkerContext(cwd, workerContext);
938
+ if (!stateDir)
939
+ return null;
940
+ const workerRoot = join(stateDir, "team", workerContext.teamName, "workers", workerContext.workerName);
941
+ const [identity, status] = await Promise.all([
942
+ readJsonIfExists(join(workerRoot, "identity.json")),
943
+ readJsonIfExists(join(workerRoot, "status.json")),
944
+ ]);
945
+ const workerState = safeString(status?.state).trim().toLowerCase();
946
+ if (!TEAM_WORKER_STOP_ACTIVE_STATES.has(workerState))
947
+ return null;
948
+ const candidateTaskIds = new Set();
949
+ const currentTaskId = safeString(status?.current_task_id).trim();
950
+ if (currentTaskId)
951
+ candidateTaskIds.add(currentTaskId);
952
+ const assignedTasks = Array.isArray(identity?.assigned_tasks) ? identity?.assigned_tasks : [];
953
+ for (const taskId of assignedTasks) {
954
+ const normalized = safeString(taskId).trim();
955
+ if (normalized)
956
+ candidateTaskIds.add(normalized);
957
+ }
958
+ for (const taskId of candidateTaskIds) {
959
+ const task = await readJsonIfExists(join(stateDir, "team", workerContext.teamName, "tasks", `task-${taskId}.json`));
960
+ const statusValue = safeString(task?.status).trim().toLowerCase();
961
+ if (!statusValue || TEAM_TERMINAL_TASK_STATUSES.has(statusValue))
962
+ continue;
963
+ return {
964
+ decision: "block",
965
+ reason: `RCS team worker ${workerContext.workerName} is still assigned non-terminal task ${taskId} (${statusValue}); continue the current assigned task or report a concrete blocker before stopping.`,
966
+ stopReason: `team_worker_${workerContext.workerName}_${taskId}_${statusValue}`,
967
+ systemMessage: `RCS team worker ${workerContext.workerName} is still assigned task ${taskId} (${statusValue}).`,
968
+ };
969
+ }
970
+ return null;
971
+ }
972
+ function hasTeamWorkerContext() {
973
+ return parseTeamWorkerEnv(safeString(process.env.RCS_TEAM_INTERNAL_WORKER || process.env.RCS_TEAM_WORKER)) !== null;
974
+ }
975
+ function isStopExempt(payload) {
976
+ const candidates = [
977
+ payload.stop_reason,
978
+ payload.stopReason,
979
+ payload.reason,
980
+ payload.exit_reason,
981
+ payload.exitReason,
982
+ ]
983
+ .map((value) => safeString(value).toLowerCase())
984
+ .filter(Boolean);
985
+ return candidates.some((value) => value.includes("cancel")
986
+ || value.includes("abort")
987
+ || value.includes("context")
988
+ || value.includes("compact")
989
+ || value.includes("limit"));
990
+ }
991
+ async function buildModeBasedStopOutput(mode, cwd, sessionId) {
992
+ const state = sessionId
993
+ ? await readModeStateForSession(mode, sessionId, cwd)
994
+ : await readModeState(mode, cwd);
995
+ if (!state || !shouldContinueRun(state))
996
+ return null;
997
+ const phase = formatPhase(state.current_phase);
998
+ return {
999
+ decision: "block",
1000
+ reason: `RCS ${mode} is still active (phase: ${phase}); continue the task and gather fresh verification evidence before stopping.`,
1001
+ stopReason: `${mode}_${phase}`,
1002
+ systemMessage: `RCS ${mode} is still active (phase: ${phase}).`,
1003
+ };
1004
+ }
1005
+ async function readTeamModeStateForStop(cwd, sessionId) {
1006
+ const normalizedSessionId = safeString(sessionId).trim();
1007
+ if (!normalizedSessionId) {
1008
+ return await readModeState("team", cwd);
1009
+ }
1010
+ const scopedState = await readStopSessionPinnedState("team-state.json", cwd, normalizedSessionId);
1011
+ if (scopedState)
1012
+ return scopedState;
1013
+ const rootState = await readJsonIfExists(join(cwd, ".rcs", "state", "team-state.json"));
1014
+ if (rootState?.active !== true)
1015
+ return null;
1016
+ const ownerSessionId = safeString(rootState.session_id).trim();
1017
+ if (ownerSessionId && ownerSessionId !== normalizedSessionId) {
1018
+ return null;
1019
+ }
1020
+ return rootState;
1021
+ }
1022
+ async function buildTeamStopOutput(cwd, sessionId) {
1023
+ if (await readCanonicalTerminalRunStateForStop(cwd, sessionId, "team")) {
1024
+ return null;
1025
+ }
1026
+ const teamState = await readTeamModeStateForStop(cwd, sessionId);
1027
+ if (teamState?.active !== true)
1028
+ return null;
1029
+ const teamName = safeString(teamState.team_name).trim();
1030
+ if (teamName) {
1031
+ const canonicalTeamDir = join(resolveCanonicalTeamStateRoot(cwd), "team", teamName);
1032
+ if (!existsSync(canonicalTeamDir)) {
1033
+ return null;
1034
+ }
1035
+ }
1036
+ const coarsePhase = teamState.current_phase;
1037
+ const canonicalPhase = teamName ? (await readTeamPhase(teamName, cwd))?.current_phase ?? coarsePhase : coarsePhase;
1038
+ if (!isNonTerminalPhase(canonicalPhase))
1039
+ return null;
1040
+ return buildTeamStopOutputForPhase(teamName, formatPhase(canonicalPhase));
1041
+ }
1042
+ function buildTeamStopReason(teamName, phase) {
1043
+ const teamContext = teamName ? ` (${teamName})` : "";
1044
+ return `RCS team pipeline is still active${teamContext} at phase ${phase}; continue coordinating until the team reaches a terminal phase. If system-generated worker auto-checkpoint commits exist, rewrite them into Lore-format final commits before merge/finalization.`;
1045
+ }
1046
+ function buildTeamStopOutputForPhase(teamName, phase) {
1047
+ return {
1048
+ decision: "block",
1049
+ reason: buildTeamStopReason(teamName, phase),
1050
+ stopReason: `team_${phase}`,
1051
+ systemMessage: `RCS team pipeline is still active at phase ${phase}.`,
1052
+ };
1053
+ }
1054
+ function extractStableFinalRecommendationSummary(message) {
1055
+ for (const pattern of STABLE_FINAL_RECOMMENDATION_PATTERNS) {
1056
+ const match = pattern.exec(message);
1057
+ if (!match)
1058
+ continue;
1059
+ const summary = match[0]?.trim().replace(/\s+/g, " ");
1060
+ if (!summary)
1061
+ continue;
1062
+ return /[.!?]$/.test(summary) ? summary : `${summary}.`;
1063
+ }
1064
+ return "";
1065
+ }
1066
+ function buildStableFinalRecommendationStopSignature(payload, teamName, summary) {
1067
+ const sessionId = readPayloadSessionId(payload) || "no-session";
1068
+ const threadId = readPayloadThreadId(payload) || "no-thread";
1069
+ const normalizedSummary = normalizeAutoNudgeSignatureText(summary) || summary.toLowerCase();
1070
+ return ["release-readiness-finalize", sessionId, threadId, teamName, normalizedSummary].join("|");
1071
+ }
1072
+ function hasReleaseReadinessMode(payload) {
1073
+ const mode = safeString(payload.mode).trim().toLowerCase();
1074
+ return mode === "release-readiness";
1075
+ }
1076
+ async function hasReleaseReadinessStopMarker(cwd, sessionId, teamName) {
1077
+ if (!sessionId)
1078
+ return false;
1079
+ const markerState = await readStopSessionPinnedState("release-readiness-state.json", cwd, sessionId);
1080
+ if (markerState?.active !== true || markerState.stable_final_recommendation_emitted !== true) {
1081
+ return false;
1082
+ }
1083
+ const markerTeamName = safeString(markerState.team_name).trim();
1084
+ if (markerTeamName && markerTeamName !== teamName)
1085
+ return false;
1086
+ const markerSessionId = safeString(markerState.session_id).trim();
1087
+ if (markerSessionId && markerSessionId !== sessionId)
1088
+ return false;
1089
+ return true;
1090
+ }
1091
+ function readPayloadSessionId(payload) {
1092
+ return safeString(payload.session_id ?? payload.sessionId).trim();
1093
+ }
1094
+ function readPayloadThreadId(payload) {
1095
+ return safeString(payload.thread_id ?? payload.threadId).trim();
1096
+ }
1097
+ function readPayloadTurnId(payload) {
1098
+ return safeString(payload.turn_id ?? payload.turnId).trim();
1099
+ }
1100
+ async function resolveInternalSessionIdForPayload(cwd, payloadSessionId) {
1101
+ const currentSession = await readUsableSessionState(cwd);
1102
+ const canonicalSessionId = safeString(currentSession?.session_id).trim();
1103
+ if (!canonicalSessionId)
1104
+ return payloadSessionId;
1105
+ const nativeSessionId = safeString(currentSession?.native_session_id).trim();
1106
+ if (!payloadSessionId)
1107
+ return canonicalSessionId;
1108
+ if (payloadSessionId === canonicalSessionId)
1109
+ return canonicalSessionId;
1110
+ if (nativeSessionId && payloadSessionId === nativeSessionId)
1111
+ return canonicalSessionId;
1112
+ return payloadSessionId;
1113
+ }
1114
+ async function readStopSessionPinnedState(fileName, cwd, sessionId) {
1115
+ const statePath = getStateFilePath(fileName, cwd, sessionId || undefined);
1116
+ return readJsonIfExists(statePath);
1117
+ }
1118
+ function matchesSkillStopContext(entry, state, sessionId, threadId) {
1119
+ const entrySessionId = safeString(entry.session_id ?? state.session_id).trim();
1120
+ const entryThreadId = safeString(entry.thread_id ?? state.thread_id).trim();
1121
+ if (sessionId && entrySessionId && entrySessionId !== sessionId)
1122
+ return false;
1123
+ if (sessionId && !entrySessionId && threadId && entryThreadId && entryThreadId !== threadId) {
1124
+ return false;
1125
+ }
1126
+ return true;
1127
+ }
1128
+ function modeStateMatchesSkillStopContext(state, cwd, sessionId) {
1129
+ const stateSessionId = safeString(state.owner_rcs_session_id
1130
+ ?? state.session_id
1131
+ ?? state.codex_session_id
1132
+ ?? state.owner_codex_session_id).trim();
1133
+ if (sessionId && stateSessionId && stateSessionId !== sessionId)
1134
+ return false;
1135
+ const stateCwd = safeString(state.cwd
1136
+ ?? state.workingDirectory
1137
+ ?? state.working_directory
1138
+ ?? state.project_path).trim();
1139
+ if (stateCwd) {
1140
+ try {
1141
+ if (resolve(stateCwd) !== resolve(cwd))
1142
+ return false;
1143
+ }
1144
+ catch {
1145
+ return false;
1146
+ }
1147
+ }
1148
+ return true;
1149
+ }
1150
+ async function readBlockingSkillForStop(cwd, sessionId, threadId, requiredSkill) {
1151
+ const canonicalState = await readVisibleSkillActiveState(cwd, sessionId);
1152
+ const visibleEntries = canonicalState ? listActiveSkills(canonicalState) : [];
1153
+ const candidateSkills = requiredSkill
1154
+ ? [requiredSkill]
1155
+ : [...SKILL_STOP_BLOCKERS];
1156
+ for (const skill of candidateSkills) {
1157
+ const terminalRunState = await readCanonicalTerminalRunStateForStop(cwd, sessionId, skill);
1158
+ if (terminalRunState)
1159
+ continue;
1160
+ const modeState = await readStopSessionPinnedState(`${skill}-state.json`, cwd, sessionId);
1161
+ if (!modeState || modeState.active !== true)
1162
+ continue;
1163
+ if (!modeStateMatchesSkillStopContext(modeState, cwd, sessionId))
1164
+ continue;
1165
+ const modeSnapshot = getRunContinuationSnapshot(modeState);
1166
+ if (modeSnapshot?.terminal === true)
1167
+ continue;
1168
+ const phase = formatPhase(modeState.current_phase, formatPhase(visibleEntries.find((entry) => entry.skill === skill)?.phase, "planning"));
1169
+ if (TERMINAL_MODE_PHASES.has(phase.toLowerCase()) || phase === "completing") {
1170
+ continue;
1171
+ }
1172
+ if (!canonicalState) {
1173
+ return { skill, phase };
1174
+ }
1175
+ const blocker = visibleEntries.find((entry) => (entry.skill === skill
1176
+ && matchesSkillStopContext(entry, canonicalState, sessionId, threadId)));
1177
+ if (!blocker)
1178
+ continue;
1179
+ return {
1180
+ skill,
1181
+ phase: formatPhase(modeState.current_phase ?? blocker.phase ?? canonicalState.phase, "planning"),
1182
+ };
1183
+ }
1184
+ return null;
1185
+ }
1186
+ async function readStopAutoNudgePhase(cwd, sessionId, threadId) {
1187
+ const normalizedSessionId = sessionId.trim();
1188
+ if (normalizedSessionId) {
1189
+ const scopedModeState = await readStopSessionPinnedState("deep-interview-state.json", cwd, normalizedSessionId);
1190
+ if (scopedModeState?.active === true
1191
+ && safeString(scopedModeState.current_phase).trim().toLowerCase() === "intent-first") {
1192
+ return "planning";
1193
+ }
1194
+ }
1195
+ else {
1196
+ const rootModeState = await readJsonIfExists(join(cwd, ".rcs", "state", "deep-interview-state.json"));
1197
+ if (rootModeState?.active === true
1198
+ && safeString(rootModeState.current_phase).trim().toLowerCase() === "intent-first") {
1199
+ return "planning";
1200
+ }
1201
+ }
1202
+ if (!normalizedSessionId)
1203
+ return "";
1204
+ const canonicalState = await readVisibleSkillActiveState(cwd, normalizedSessionId);
1205
+ const visibleEntries = canonicalState ? listActiveSkills(canonicalState) : [];
1206
+ const deepInterview = visibleEntries.find((entry) => (entry.skill === "deep-interview"
1207
+ && matchesSkillStopContext(entry, canonicalState ?? {}, normalizedSessionId, threadId)));
1208
+ if (!deepInterview)
1209
+ return "";
1210
+ const modeState = await readStopSessionPinnedState("deep-interview-state.json", cwd, normalizedSessionId);
1211
+ if (!modeState || modeState.active !== true)
1212
+ return "";
1213
+ const modePhase = safeString(modeState.current_phase).trim().toLowerCase();
1214
+ return modePhase === "intent-first" ? "planning" : "";
1215
+ }
1216
+ async function buildDeepInterviewQuestionStopOutput(cwd, sessionId, threadId) {
1217
+ await reconcileDeepInterviewQuestionEnforcementFromAnsweredRecords(cwd, sessionId);
1218
+ const modeState = await readStopSessionPinnedState("deep-interview-state.json", cwd, sessionId);
1219
+ if (!modeState)
1220
+ return null;
1221
+ const questionEnforcement = safeObject(modeState.question_enforcement);
1222
+ const hasPendingQuestionObligation = isPendingDeepInterviewQuestionEnforcement(questionEnforcement);
1223
+ if (modeState.active !== true && !hasPendingQuestionObligation)
1224
+ return null;
1225
+ const phase = formatPhase(modeState.current_phase, "planning");
1226
+ if (TERMINAL_MODE_PHASES.has(phase.toLowerCase()) || phase === "completing") {
1227
+ return null;
1228
+ }
1229
+ const canonicalState = await readVisibleSkillActiveState(cwd, sessionId);
1230
+ if (canonicalState) {
1231
+ const blocker = listActiveSkills(canonicalState).find((entry) => (entry.skill === "deep-interview"
1232
+ && matchesSkillStopContext(entry, canonicalState, sessionId, threadId)));
1233
+ if (!blocker)
1234
+ return null;
1235
+ }
1236
+ if (!hasPendingQuestionObligation) {
1237
+ return null;
1238
+ }
1239
+ const obligationId = safeString(questionEnforcement.obligation_id).trim();
1240
+ if (!obligationId)
1241
+ return null;
1242
+ const systemMessage = `RCS deep-interview is still active (phase: ${phase}) and requires a structured question via rcs question before stopping; read the returned answers[] JSON before continuing.`;
1243
+ return {
1244
+ obligationId,
1245
+ output: {
1246
+ decision: "block",
1247
+ reason: `Deep interview is still active (phase: ${phase}) and has a pending structured question obligation; use \`rcs question\` before stopping.`,
1248
+ stopReason: "deep_interview_question_required",
1249
+ systemMessage,
1250
+ },
1251
+ };
1252
+ }
1253
+ function resolveRepeatableStopSessionId(payload, canonicalSessionId) {
1254
+ return canonicalSessionId?.trim() || readPayloadSessionId(payload) || "";
1255
+ }
1256
+ function buildRepeatableStopSignature(payload, kind, detail = "", canonicalSessionId) {
1257
+ const sessionId = resolveRepeatableStopSessionId(payload, canonicalSessionId) || "no-session";
1258
+ const threadId = readPayloadThreadId(payload) || "no-thread";
1259
+ const turnId = readPayloadTurnId(payload);
1260
+ const normalizedDetail = normalizeAutoNudgeSignatureText(detail) || safeString(detail).trim().toLowerCase();
1261
+ const transcriptPath = safeString(payload.transcript_path ?? payload.transcriptPath).trim() || "no-transcript";
1262
+ const lastAssistantMessage = normalizeAutoNudgeSignatureText(payload.last_assistant_message ?? payload.lastAssistantMessage) || "no-message";
1263
+ if (turnId) {
1264
+ return [
1265
+ kind,
1266
+ sessionId,
1267
+ threadId,
1268
+ turnId,
1269
+ transcriptPath,
1270
+ lastAssistantMessage,
1271
+ normalizedDetail || "no-detail",
1272
+ ].join("|");
1273
+ }
1274
+ return [
1275
+ kind,
1276
+ sessionId,
1277
+ threadId,
1278
+ transcriptPath,
1279
+ lastAssistantMessage,
1280
+ normalizedDetail || "no-detail",
1281
+ ].join("|");
1282
+ }
1283
+ function formatStopStatePath(cwd, statePath) {
1284
+ const relativePath = relative(cwd, statePath);
1285
+ if (!relativePath || relativePath.startsWith(".."))
1286
+ return statePath;
1287
+ return relativePath.replace(/\\/g, "/");
1288
+ }
1289
+ function readNativeStopSessionKey(payload, canonicalSessionId) {
1290
+ return resolveRepeatableStopSessionId(payload, canonicalSessionId) || readPayloadThreadId(payload) || "global";
1291
+ }
1292
+ function readPreviousNativeStopSignature(state, sessionKey) {
1293
+ const sessions = safeObject(state.sessions);
1294
+ const sessionState = safeObject(sessions[sessionKey]);
1295
+ return safeString(sessionState.last_signature).trim();
1296
+ }
1297
+ async function persistNativeStopSignature(stateDir, payload, signature, canonicalSessionId) {
1298
+ if (!signature)
1299
+ return;
1300
+ const statePath = join(stateDir, NATIVE_STOP_STATE_FILE);
1301
+ const state = await readJsonIfExists(statePath) ?? {};
1302
+ const sessions = safeObject(state.sessions);
1303
+ const sessionKey = readNativeStopSessionKey(payload, canonicalSessionId);
1304
+ sessions[sessionKey] = {
1305
+ ...safeObject(sessions[sessionKey]),
1306
+ last_signature: signature,
1307
+ updated_at: new Date().toISOString(),
1308
+ };
1309
+ await mkdir(stateDir, { recursive: true });
1310
+ await writeFile(statePath, JSON.stringify({
1311
+ ...state,
1312
+ sessions,
1313
+ }, null, 2));
1314
+ }
1315
+ async function maybeReturnRepeatableStopOutput(payload, stateDir, signature, output, canonicalSessionId, options = {}) {
1316
+ if (!output)
1317
+ return null;
1318
+ const stopHookActive = payload.stop_hook_active === true || payload.stopHookActive === true;
1319
+ if (stopHookActive && options.allowRepeatDuringStopHook !== true) {
1320
+ const state = await readJsonIfExists(join(stateDir, NATIVE_STOP_STATE_FILE)) ?? {};
1321
+ const previousSignature = readPreviousNativeStopSignature(state, readNativeStopSessionKey(payload, canonicalSessionId));
1322
+ if (!signature || previousSignature === signature) {
1323
+ return null;
1324
+ }
1325
+ }
1326
+ await persistNativeStopSignature(stateDir, payload, signature, canonicalSessionId);
1327
+ return output;
1328
+ }
1329
+ async function returnPersistentStopBlock(payload, stateDir, signatureKind, signatureValue, output, canonicalSessionId, options = { allowRepeatDuringStopHook: true }) {
1330
+ return await maybeReturnRepeatableStopOutput(payload, stateDir, buildRepeatableStopSignature(payload, signatureKind, signatureValue, canonicalSessionId), output, canonicalSessionId, options);
1331
+ }
1332
+ async function findCanonicalActiveTeamForSession(cwd, sessionId) {
1333
+ if (!sessionId.trim())
1334
+ return null;
1335
+ const teamsRoot = join(resolveCanonicalTeamStateRoot(cwd), "team");
1336
+ if (!existsSync(teamsRoot))
1337
+ return null;
1338
+ const entries = await readdir(teamsRoot, { withFileTypes: true }).catch(() => []);
1339
+ for (const entry of entries) {
1340
+ if (!entry.isDirectory())
1341
+ continue;
1342
+ const teamName = entry.name.trim();
1343
+ if (!teamName)
1344
+ continue;
1345
+ const [manifest, phaseState] = await Promise.all([
1346
+ readTeamManifestV2(teamName, cwd),
1347
+ readTeamPhase(teamName, cwd),
1348
+ ]);
1349
+ if (!manifest || !phaseState)
1350
+ continue;
1351
+ const ownerSessionId = (manifest.leader?.session_id ?? "").trim();
1352
+ if (ownerSessionId && ownerSessionId !== sessionId.trim())
1353
+ continue;
1354
+ if (!isNonTerminalPhase(phaseState.current_phase))
1355
+ continue;
1356
+ return {
1357
+ teamName,
1358
+ phase: formatPhase(phaseState.current_phase),
1359
+ };
1360
+ }
1361
+ return null;
1362
+ }
1363
+ async function resolveActiveTeamNameForStop(cwd, sessionId) {
1364
+ const directState = await readTeamModeStateForStop(cwd, sessionId);
1365
+ const directTeamName = safeString(directState?.team_name).trim();
1366
+ if (directState?.active === true && directTeamName)
1367
+ return directTeamName;
1368
+ const canonicalTeam = await findCanonicalActiveTeamForSession(cwd, sessionId);
1369
+ return canonicalTeam?.teamName ?? "";
1370
+ }
1371
+ async function maybeBuildReleaseReadinessFinalizeStopOutput(payload, cwd, stateDir, sessionId) {
1372
+ if (!sessionId)
1373
+ return { matched: false, output: null };
1374
+ const teamName = await resolveActiveTeamNameForStop(cwd, sessionId);
1375
+ if (!teamName)
1376
+ return { matched: false, output: null };
1377
+ const explicitReleaseReadinessContext = hasReleaseReadinessMode(payload)
1378
+ || await hasReleaseReadinessStopMarker(cwd, sessionId, teamName);
1379
+ if (!explicitReleaseReadinessContext) {
1380
+ return { matched: false, output: null };
1381
+ }
1382
+ const summary = extractStableFinalRecommendationSummary(safeString(payload.last_assistant_message ?? payload.lastAssistantMessage));
1383
+ if (!summary)
1384
+ return { matched: false, output: null };
1385
+ const leaderAttention = await readTeamLeaderAttention(teamName, cwd);
1386
+ if (!leaderAttention
1387
+ || leaderAttention.leader_decision_state !== "done_waiting_on_leader"
1388
+ || leaderAttention.work_remaining !== false) {
1389
+ return { matched: false, output: null };
1390
+ }
1391
+ const signature = buildStableFinalRecommendationStopSignature(payload, teamName, summary);
1392
+ const output = await maybeReturnRepeatableStopOutput(payload, stateDir, signature, {
1393
+ decision: "block",
1394
+ reason: `Stable final recommendation already reached with no active worker tasks. Emit exactly one concise final decision summary aligned to "${summary}" with no filler or residual acknowledgements (for example "yes"), then stop.`,
1395
+ stopReason: "release_readiness_auto_finalize",
1396
+ systemMessage: RELEASE_READINESS_FINALIZE_SYSTEM_MESSAGE,
1397
+ }, sessionId);
1398
+ return { matched: true, output };
1399
+ }
1400
+ async function buildSkillStopOutput(cwd, sessionId, threadId) {
1401
+ const blocker = await readBlockingSkillForStop(cwd, sessionId, threadId);
1402
+ if (!blocker)
1403
+ return null;
1404
+ const subagentSummary = await readSubagentSessionSummary(cwd, sessionId).catch(() => null);
1405
+ if (subagentSummary && subagentSummary.activeSubagentThreadIds.length > 0) {
1406
+ return null;
1407
+ }
1408
+ return {
1409
+ decision: "block",
1410
+ reason: `RCS skill ${blocker.skill} is still active (phase: ${blocker.phase}); continue until the current ${blocker.skill} workflow reaches a terminal state.`,
1411
+ stopReason: `skill_${blocker.skill}_${blocker.phase}`,
1412
+ systemMessage: `RCS skill ${blocker.skill} is still active (phase: ${blocker.phase}).`,
1413
+ };
1414
+ }
1415
+ async function findActiveTeamForTransportFailure(cwd, sessionId) {
1416
+ const teamState = await readModeStateForSession("team", sessionId, cwd);
1417
+ if (teamState?.active === true) {
1418
+ const teamName = safeString(teamState.team_name).trim();
1419
+ const coarsePhase = formatPhase(teamState.current_phase);
1420
+ if (teamName) {
1421
+ const canonicalPhase = (await readTeamPhase(teamName, cwd))?.current_phase ?? coarsePhase;
1422
+ if (isNonTerminalPhase(canonicalPhase)) {
1423
+ return { teamName, phase: formatPhase(canonicalPhase) };
1424
+ }
1425
+ }
1426
+ }
1427
+ return await findCanonicalActiveTeamForSession(cwd, sessionId);
1428
+ }
1429
+ async function markTeamTransportFailure(cwd, payload) {
1430
+ const canonicalSessionId = await resolveInternalSessionIdForPayload(cwd, readPayloadSessionId(payload));
1431
+ const activeTeam = await findActiveTeamForTransportFailure(cwd, canonicalSessionId);
1432
+ if (!activeTeam)
1433
+ return;
1434
+ const nowIso = new Date().toISOString();
1435
+ const existingPhase = await readTeamPhase(activeTeam.teamName, cwd);
1436
+ const currentPhase = existingPhase?.current_phase ?? activeTeam.phase;
1437
+ if (!isNonTerminalPhase(currentPhase))
1438
+ return;
1439
+ await writeTeamPhase(activeTeam.teamName, {
1440
+ current_phase: "failed",
1441
+ max_fix_attempts: existingPhase?.max_fix_attempts ?? 3,
1442
+ current_fix_attempt: existingPhase?.current_fix_attempt ?? 0,
1443
+ transitions: [
1444
+ ...(existingPhase?.transitions ?? []),
1445
+ {
1446
+ from: formatPhase(currentPhase),
1447
+ to: "failed",
1448
+ at: nowIso,
1449
+ reason: "mcp_transport_dead",
1450
+ },
1451
+ ],
1452
+ updated_at: nowIso,
1453
+ }, cwd);
1454
+ const existingAttention = await readTeamLeaderAttention(activeTeam.teamName, cwd);
1455
+ await writeTeamLeaderAttention(activeTeam.teamName, {
1456
+ team_name: activeTeam.teamName,
1457
+ updated_at: nowIso,
1458
+ source: "notify_hook",
1459
+ leader_decision_state: existingAttention?.leader_decision_state ?? "still_actionable",
1460
+ leader_attention_pending: true,
1461
+ leader_attention_reason: "mcp_transport_dead",
1462
+ attention_reasons: [
1463
+ ...new Set([...(existingAttention?.attention_reasons ?? []), "mcp_transport_dead"]),
1464
+ ],
1465
+ leader_stale: existingAttention?.leader_stale ?? false,
1466
+ leader_session_active: existingAttention?.leader_session_active ?? true,
1467
+ leader_session_id: existingAttention?.leader_session_id ?? (canonicalSessionId || null),
1468
+ leader_session_stopped_at: existingAttention?.leader_session_stopped_at ?? null,
1469
+ unread_leader_message_count: existingAttention?.unread_leader_message_count ?? 0,
1470
+ work_remaining: existingAttention?.work_remaining ?? true,
1471
+ stalled_for_ms: existingAttention?.stalled_for_ms ?? null,
1472
+ }, cwd);
1473
+ await appendTeamEvent(activeTeam.teamName, {
1474
+ type: "leader_attention",
1475
+ worker: "leader-fixed",
1476
+ reason: "mcp_transport_dead",
1477
+ metadata: {
1478
+ phase_before: formatPhase(currentPhase),
1479
+ },
1480
+ }, cwd).catch(() => { });
1481
+ try {
1482
+ await updateModeState("team", {
1483
+ current_phase: "failed",
1484
+ error: "mcp_transport_dead",
1485
+ last_turn_at: nowIso,
1486
+ }, cwd, canonicalSessionId || undefined);
1487
+ }
1488
+ catch {
1489
+ // Canonical team state already carries the preserved failure for coarse-state-missing sessions.
1490
+ }
1491
+ }
1492
+ async function buildStopHookOutput(payload, cwd, stateDir) {
1493
+ if (isStopExempt(payload)) {
1494
+ return null;
1495
+ }
1496
+ const sessionId = readPayloadSessionId(payload);
1497
+ const canonicalSessionId = await resolveInternalSessionIdForPayload(cwd, sessionId);
1498
+ const threadId = readPayloadThreadId(payload);
1499
+ const execFollowupOutput = await buildExecFollowupStopOutput(cwd, canonicalSessionId);
1500
+ if (execFollowupOutput)
1501
+ return execFollowupOutput;
1502
+ const ralphState = await readActiveRalphState(stateDir, canonicalSessionId, {
1503
+ payloadSessionId: sessionId,
1504
+ threadId,
1505
+ tmuxPaneId: safeString(process.env.TMUX_PANE).trim(),
1506
+ });
1507
+ if (!ralphState) {
1508
+ const autoresearchState = await readActiveAutoresearchState(cwd, canonicalSessionId);
1509
+ if (autoresearchState) {
1510
+ const completion = await readAutoresearchCompletionStatus(cwd, canonicalSessionId.trim());
1511
+ if (!completion.complete) {
1512
+ const currentPhase = safeString(autoresearchState.current_phase ?? autoresearchState.currentPhase).trim() || 'executing';
1513
+ const systemMessage = `RCS autoresearch is still active (phase: ${currentPhase}); continue until validator evidence is complete before stopping.`;
1514
+ return await maybeReturnRepeatableStopOutput(payload, stateDir, buildRepeatableStopSignature(payload, 'autoresearch-stop', `${currentPhase}|${completion.reason}`, canonicalSessionId), {
1515
+ decision: 'block',
1516
+ reason: systemMessage,
1517
+ stopReason: `autoresearch_${currentPhase}`,
1518
+ systemMessage,
1519
+ }, canonicalSessionId, { allowRepeatDuringStopHook: true });
1520
+ }
1521
+ }
1522
+ const teamWorkerOutput = await buildTeamWorkerStopOutput(cwd);
1523
+ if (hasTeamWorkerContext() && teamWorkerOutput) {
1524
+ return await returnPersistentStopBlock(payload, stateDir, "team-worker-stop", safeString(teamWorkerOutput.stopReason), teamWorkerOutput, canonicalSessionId, { allowRepeatDuringStopHook: false });
1525
+ }
1526
+ const autopilotOutput = await buildModeBasedStopOutput("autopilot", cwd, canonicalSessionId);
1527
+ if (autopilotOutput) {
1528
+ return await returnPersistentStopBlock(payload, stateDir, "autopilot-stop", safeString(autopilotOutput.stopReason), autopilotOutput, canonicalSessionId, { allowRepeatDuringStopHook: false });
1529
+ }
1530
+ const ultraworkOutput = await buildModeBasedStopOutput("ultrawork", cwd, canonicalSessionId);
1531
+ if (ultraworkOutput) {
1532
+ return await returnPersistentStopBlock(payload, stateDir, "ultrawork-stop", safeString(ultraworkOutput.stopReason), ultraworkOutput, canonicalSessionId, { allowRepeatDuringStopHook: false });
1533
+ }
1534
+ const ultraqaOutput = await buildModeBasedStopOutput("ultraqa", cwd, canonicalSessionId);
1535
+ if (ultraqaOutput) {
1536
+ return await returnPersistentStopBlock(payload, stateDir, "ultraqa-stop", safeString(ultraqaOutput.stopReason), ultraqaOutput, canonicalSessionId);
1537
+ }
1538
+ const releaseReadinessFinalizeResult = await maybeBuildReleaseReadinessFinalizeStopOutput(payload, cwd, stateDir, canonicalSessionId);
1539
+ if (releaseReadinessFinalizeResult.matched)
1540
+ return releaseReadinessFinalizeResult.output;
1541
+ const teamOutput = await buildTeamStopOutput(cwd, canonicalSessionId);
1542
+ if (teamOutput) {
1543
+ return await returnPersistentStopBlock(payload, stateDir, "team-stop", safeString(teamOutput.stopReason), teamOutput, canonicalSessionId);
1544
+ }
1545
+ if (canonicalSessionId) {
1546
+ const deepInterviewQuestionOutput = await buildDeepInterviewQuestionStopOutput(cwd, canonicalSessionId, threadId);
1547
+ if (deepInterviewQuestionOutput) {
1548
+ return await returnPersistentStopBlock(payload, stateDir, "deep-interview-question-stop", deepInterviewQuestionOutput.obligationId, deepInterviewQuestionOutput.output, canonicalSessionId);
1549
+ }
1550
+ const canonicalTeam = await readCanonicalTerminalRunStateForStop(cwd, canonicalSessionId, "team")
1551
+ ? null
1552
+ : await findCanonicalActiveTeamForSession(cwd, canonicalSessionId);
1553
+ if (canonicalTeam) {
1554
+ const canonicalTeamOutput = buildTeamStopOutputForPhase(canonicalTeam.teamName, canonicalTeam.phase);
1555
+ const repeatedCanonicalTeamOutput = await returnPersistentStopBlock(payload, stateDir, "team-stop", `${canonicalTeam.teamName}|${canonicalTeam.phase}`, canonicalTeamOutput, canonicalSessionId);
1556
+ if (repeatedCanonicalTeamOutput)
1557
+ return repeatedCanonicalTeamOutput;
1558
+ }
1559
+ const skillOutput = await buildSkillStopOutput(cwd, canonicalSessionId, threadId);
1560
+ if (skillOutput) {
1561
+ return await returnPersistentStopBlock(payload, stateDir, "skill-stop", safeString(skillOutput.stopReason), skillOutput, canonicalSessionId);
1562
+ }
1563
+ }
1564
+ const lastAssistantMessage = safeString(payload.last_assistant_message ?? payload.lastAssistantMessage);
1565
+ const autoNudgeConfig = await loadAutoNudgeConfig();
1566
+ const autoNudgePhase = await readStopAutoNudgePhase(cwd, canonicalSessionId, threadId);
1567
+ if (autoNudgeConfig.enabled
1568
+ && detectNativeStopStallPattern(lastAssistantMessage, autoNudgeConfig.patterns, autoNudgePhase)) {
1569
+ const effectiveResponse = resolveEffectiveAutoNudgeResponse(autoNudgeConfig.response);
1570
+ return await returnPersistentStopBlock(payload, stateDir, "auto-nudge", lastAssistantMessage, {
1571
+ decision: "block",
1572
+ reason: effectiveResponse,
1573
+ stopReason: "auto_nudge",
1574
+ systemMessage: "RCS native Stop detected a stall/permission-style handoff and continued the turn automatically.",
1575
+ }, canonicalSessionId);
1576
+ }
1577
+ if (isFinalHandoffDocumentRefreshCandidate(lastAssistantMessage)) {
1578
+ const documentRefreshWarning = evaluateFinalHandoffDocumentRefresh(cwd, lastAssistantMessage);
1579
+ if (documentRefreshWarning) {
1580
+ return await maybeReturnRepeatableStopOutput(payload, stateDir, buildRepeatableStopSignature(payload, "document-refresh-stop", documentRefreshWarning.triggeringPaths.join("|"), canonicalSessionId), buildDocumentRefreshAdvisoryOutput(documentRefreshWarning, "Stop"), canonicalSessionId, { allowRepeatDuringStopHook: false });
1581
+ }
1582
+ }
1583
+ return null;
1584
+ }
1585
+ const currentPhase = safeString(ralphState.state.current_phase).trim() || "executing";
1586
+ const blockingPath = formatStopStatePath(cwd, ralphState.path);
1587
+ const stopReason = `ralph_${currentPhase}`;
1588
+ const systemMessage = `RCS Ralph is still active (phase: ${currentPhase}; state: ${blockingPath}); continue the task and gather fresh verification evidence before stopping.`;
1589
+ return await returnPersistentStopBlock(payload, stateDir, "ralph-stop", currentPhase, {
1590
+ decision: "block",
1591
+ reason: systemMessage,
1592
+ stopReason,
1593
+ systemMessage,
1594
+ }, canonicalSessionId);
1595
+ }
1596
+ export async function dispatchCodexNativeHook(payload, options = {}) {
1597
+ const hookEventName = readHookEventName(payload);
1598
+ const cwd = options.cwd ?? (safeString(payload.cwd).trim() || process.cwd());
1599
+ const stateDir = join(cwd, ".rcs", "state");
1600
+ await mkdir(stateDir, { recursive: true });
1601
+ const rcsEventName = mapCodexHookEventToRcsEvent(hookEventName);
1602
+ let skillState = null;
1603
+ let triageAdditionalContext = null;
1604
+ const nativeSessionId = safeString(payload.session_id ?? payload.sessionId).trim();
1605
+ const threadId = safeString(payload.thread_id ?? payload.threadId).trim();
1606
+ const turnId = safeString(payload.turn_id ?? payload.turnId).trim();
1607
+ const currentSessionState = await readUsableSessionState(cwd);
1608
+ let canonicalSessionId = safeString(currentSessionState?.session_id).trim();
1609
+ let resolvedNativeSessionId = nativeSessionId;
1610
+ let skipCanonicalSessionStartContext = false;
1611
+ if (hookEventName === "SessionStart" && nativeSessionId) {
1612
+ const transcriptPath = safeString(payload.transcript_path ?? payload.transcriptPath).trim();
1613
+ const subagentSessionStart = readNativeSubagentSessionStartMetadata(transcriptPath);
1614
+ if (subagentSessionStart && canonicalSessionId) {
1615
+ const belongsToCanonicalSession = await nativeSubagentSessionStartBelongsToCanonicalSession(cwd, canonicalSessionId, currentSessionState, subagentSessionStart);
1616
+ if (belongsToCanonicalSession) {
1617
+ resolvedNativeSessionId = nativeSessionId;
1618
+ await recordNativeSubagentSessionStart(cwd, canonicalSessionId, nativeSessionId, subagentSessionStart, transcriptPath);
1619
+ }
1620
+ else {
1621
+ skipCanonicalSessionStartContext = true;
1622
+ resolvedNativeSessionId =
1623
+ safeString(currentSessionState?.native_session_id).trim() || nativeSessionId;
1624
+ await recordIgnoredNativeSubagentSessionStart(cwd, canonicalSessionId, nativeSessionId, subagentSessionStart, transcriptPath);
1625
+ }
1626
+ }
1627
+ else {
1628
+ const sessionState = await reconcileNativeSessionStart(cwd, nativeSessionId, {
1629
+ pid: options.sessionOwnerPid ?? resolveSessionOwnerPid(payload),
1630
+ });
1631
+ canonicalSessionId = safeString(sessionState.session_id).trim();
1632
+ resolvedNativeSessionId = safeString(sessionState.native_session_id).trim() || nativeSessionId;
1633
+ }
1634
+ }
1635
+ else if (!canonicalSessionId) {
1636
+ canonicalSessionId = safeString(currentSessionState?.session_id).trim();
1637
+ }
1638
+ if (hookEventName === "Stop") {
1639
+ const stopCanonicalSessionId = await resolveInternalSessionIdForPayload(cwd, readPayloadSessionId(payload));
1640
+ if (stopCanonicalSessionId) {
1641
+ canonicalSessionId = stopCanonicalSessionId;
1642
+ }
1643
+ if (canonicalSessionId && safeString(currentSessionState?.session_id).trim() === canonicalSessionId) {
1644
+ resolvedNativeSessionId =
1645
+ safeString(currentSessionState?.native_session_id).trim() || resolvedNativeSessionId;
1646
+ }
1647
+ }
1648
+ const eventSessionId = canonicalSessionId || nativeSessionId || undefined;
1649
+ const sessionIdForState = canonicalSessionId || nativeSessionId;
1650
+ let outputJson = null;
1651
+ if (hookEventName === "UserPromptSubmit") {
1652
+ const prompt = readPromptText(payload);
1653
+ if (prompt) {
1654
+ skillState = buildNativeOutsideTmuxTeamPromptBlockState(prompt, cwd, payload, sessionIdForState, threadId || undefined, turnId || undefined) ?? await recordSkillActivation({
1655
+ stateDir,
1656
+ text: prompt,
1657
+ sessionId: sessionIdForState,
1658
+ threadId,
1659
+ turnId,
1660
+ });
1661
+ }
1662
+ // --- Triage classifier (advisory-only, non-keyword prompts) ---
1663
+ if (prompt && skillState === null) {
1664
+ try {
1665
+ if (readTriageConfig().enabled) {
1666
+ const normalized = prompt.trim().toLowerCase();
1667
+ const previous = readTriageState({ cwd, sessionId: sessionIdForState || null });
1668
+ const suppress = shouldSuppressFollowup({
1669
+ previous,
1670
+ currentPrompt: normalized,
1671
+ currentHasKeyword: false,
1672
+ });
1673
+ if (!suppress) {
1674
+ const decision = triagePrompt(prompt);
1675
+ const nowIso = new Date().toISOString();
1676
+ const effectiveTurnId = turnId || nowIso;
1677
+ if (decision.lane === "HEAVY") {
1678
+ triageAdditionalContext =
1679
+ "RCS native UserPromptSubmit triage detected a multi-step goal with no workflow keyword. This is advisory prompt-routing context only; it did not activate autopilot or initialize workflow state. Prefer the existing autopilot-style workflow if AGENTS.md/runtime conditions allow it, unless newer user context narrows or opts out.";
1680
+ const newState = {
1681
+ version: 1,
1682
+ last_triage: {
1683
+ lane: "HEAVY",
1684
+ destination: "autopilot",
1685
+ reason: decision.reason,
1686
+ prompt_signature: promptSignature(normalized),
1687
+ turn_id: effectiveTurnId,
1688
+ created_at: nowIso,
1689
+ },
1690
+ suppress_followup: true,
1691
+ };
1692
+ writeTriageState({ cwd, sessionId: sessionIdForState || null, state: newState });
1693
+ }
1694
+ else if (decision.lane === "LIGHT") {
1695
+ if (decision.destination === "explore") {
1696
+ triageAdditionalContext =
1697
+ "RCS native UserPromptSubmit triage detected a read-only/question-shaped request with no workflow keyword. This is advisory prompt-routing context only. Prefer the explore role surface rather than escalating to autopilot.";
1698
+ }
1699
+ else if (decision.destination === "executor") {
1700
+ triageAdditionalContext =
1701
+ "RCS native UserPromptSubmit triage detected a narrow edit-shaped request with no workflow keyword. This is advisory prompt-routing context only. Prefer the executor role surface rather than autopilot.";
1702
+ }
1703
+ else if (decision.destination === "designer") {
1704
+ triageAdditionalContext =
1705
+ "RCS native UserPromptSubmit triage detected a visual/style request with no workflow keyword. This is advisory prompt-routing context only. Prefer the designer role surface.";
1706
+ }
1707
+ else if (decision.destination === "researcher") {
1708
+ triageAdditionalContext =
1709
+ "RCS native UserPromptSubmit triage detected an external documentation/reference research request with no workflow keyword. This is advisory prompt-routing context only. Prefer the researcher role surface rather than repo-local explore or autopilot.";
1710
+ }
1711
+ if (triageAdditionalContext !== null) {
1712
+ const dest = decision.destination;
1713
+ const newState = {
1714
+ version: 1,
1715
+ last_triage: {
1716
+ lane: "LIGHT",
1717
+ destination: dest,
1718
+ reason: decision.reason,
1719
+ prompt_signature: promptSignature(normalized),
1720
+ turn_id: effectiveTurnId,
1721
+ created_at: nowIso,
1722
+ },
1723
+ suppress_followup: true,
1724
+ };
1725
+ writeTriageState({ cwd, sessionId: sessionIdForState || null, state: newState });
1726
+ }
1727
+ }
1728
+ // lane === "PASS": no context, no state write
1729
+ }
1730
+ }
1731
+ }
1732
+ catch {
1733
+ // Swallow all triage errors; never break the hook
1734
+ triageAdditionalContext = null;
1735
+ }
1736
+ }
1737
+ const reconcileHudForPromptSubmitFn = options.reconcileHudForPromptSubmitFn ?? reconcileHudForPromptSubmit;
1738
+ await reconcileHudForPromptSubmitFn(cwd, { sessionId: canonicalSessionId || sessionIdForState || undefined }).catch(() => { });
1739
+ }
1740
+ if (rcsEventName && !skipCanonicalSessionStartContext) {
1741
+ const baseContext = buildBaseContext(cwd, payload, hookEventName, canonicalSessionId);
1742
+ if (resolvedNativeSessionId) {
1743
+ baseContext.native_session_id = resolvedNativeSessionId;
1744
+ baseContext.codex_session_id = resolvedNativeSessionId;
1745
+ }
1746
+ if (canonicalSessionId) {
1747
+ baseContext.rcs_session_id = canonicalSessionId;
1748
+ }
1749
+ const event = buildNativeHookEvent(rcsEventName, baseContext, {
1750
+ session_id: eventSessionId,
1751
+ thread_id: threadId || undefined,
1752
+ turn_id: turnId || undefined,
1753
+ mode: safeString(payload.mode).trim() || undefined,
1754
+ });
1755
+ await dispatchHookEvent(event, { cwd });
1756
+ }
1757
+ if ((hookEventName === "SessionStart" && !skipCanonicalSessionStartContext) || hookEventName === "UserPromptSubmit") {
1758
+ const additionalContext = hookEventName === "SessionStart"
1759
+ ? await buildSessionStartContext(cwd, canonicalSessionId || nativeSessionId, {
1760
+ hookEventName,
1761
+ payload,
1762
+ canonicalSessionId,
1763
+ nativeSessionId: resolvedNativeSessionId || nativeSessionId,
1764
+ })
1765
+ : (buildAdditionalContextMessage(readPromptText(payload), skillState, cwd, payload) ?? triageAdditionalContext);
1766
+ if (additionalContext) {
1767
+ outputJson = {
1768
+ hookSpecificOutput: {
1769
+ hookEventName,
1770
+ additionalContext,
1771
+ },
1772
+ };
1773
+ }
1774
+ }
1775
+ else if (hookEventName === "PreToolUse") {
1776
+ outputJson = buildNativePreToolUseOutput(payload);
1777
+ }
1778
+ else if (hookEventName === "PostToolUse") {
1779
+ if (detectMcpTransportFailure(payload)) {
1780
+ await markTeamTransportFailure(cwd, payload);
1781
+ }
1782
+ outputJson = buildNativePostToolUseOutput(payload);
1783
+ await handleTeamWorkerPostToolUseSuccess(payload, cwd);
1784
+ }
1785
+ else if (hookEventName === "Stop") {
1786
+ outputJson = await buildStopHookOutput(payload, cwd, stateDir);
1787
+ }
1788
+ return {
1789
+ hookEventName,
1790
+ rcsEventName,
1791
+ skillState,
1792
+ outputJson,
1793
+ };
1794
+ }
1795
+ export function isCodexNativeHookMainModule(moduleUrl, argv1) {
1796
+ if (!argv1)
1797
+ return false;
1798
+ return moduleUrl === pathToFileURL(argv1).href;
1799
+ }
1800
+ async function readStdinJson() {
1801
+ const chunks = [];
1802
+ for await (const chunk of process.stdin) {
1803
+ chunks.push(Buffer.isBuffer(chunk) ? chunk : Buffer.from(String(chunk)));
1804
+ }
1805
+ const raw = Buffer.concat(chunks).toString("utf-8").trim();
1806
+ if (!raw) {
1807
+ return { payload: {}, parseError: null };
1808
+ }
1809
+ try {
1810
+ return {
1811
+ payload: safeObject(JSON.parse(raw)),
1812
+ parseError: null,
1813
+ };
1814
+ }
1815
+ catch (error) {
1816
+ return {
1817
+ payload: {},
1818
+ parseError: error instanceof Error ? error : new Error(String(error)),
1819
+ };
1820
+ }
1821
+ }
1822
+ function writeNativeHookJsonStdout(output) {
1823
+ process.stdout.write(`${JSON.stringify(output)}\n`);
1824
+ }
1825
+ function isStopDispatchFailureTestTrigger(payload) {
1826
+ return process.env.NODE_ENV === "test"
1827
+ && process.env.RCS_NATIVE_HOOK_TEST_THROW_STOP_DISPATCH === "1"
1828
+ && readHookEventName(payload) === "Stop";
1829
+ }
1830
+ function buildStopDispatchFailureOutput(error) {
1831
+ const detail = error instanceof Error ? error.message : String(error);
1832
+ const reason = "RCS native Stop hook failed before normal continuation handling. Continue once more, preserve runtime state, inspect the hook logs, and retry with a valid Stop JSON response.";
1833
+ return {
1834
+ decision: "block",
1835
+ reason,
1836
+ stopReason: "native_stop_dispatch_failure",
1837
+ systemMessage: `${reason} Failure: ${detail}`,
1838
+ };
1839
+ }
1840
+ export async function runCodexNativeHookCli() {
1841
+ const { payload, parseError } = await readStdinJson();
1842
+ if (parseError) {
1843
+ writeNativeHookJsonStdout({
1844
+ decision: "block",
1845
+ reason: "RCS native hook received malformed JSON input. Preserve runtime state, inspect the emitting hook payload yourself, and retry with valid JSON.",
1846
+ hookSpecificOutput: {
1847
+ hookEventName: "Unknown",
1848
+ additionalContext: `stdin JSON parsing failed inside codex-native-hook: ${parseError.message}. Emit valid JSON from the native hook caller before retrying.`,
1849
+ },
1850
+ });
1851
+ return;
1852
+ }
1853
+ try {
1854
+ if (isStopDispatchFailureTestTrigger(payload)) {
1855
+ throw new Error("test-induced Stop dispatch failure");
1856
+ }
1857
+ const result = await dispatchCodexNativeHook(payload);
1858
+ if (result.outputJson) {
1859
+ writeNativeHookJsonStdout(result.outputJson);
1860
+ }
1861
+ else if (result.hookEventName === "Stop") {
1862
+ writeNativeHookJsonStdout({});
1863
+ }
1864
+ }
1865
+ catch (error) {
1866
+ if (readHookEventName(payload) !== "Stop") {
1867
+ throw error;
1868
+ }
1869
+ process.stderr.write(`[rcs] codex-native Stop hook dispatch failed: ${error instanceof Error ? error.message : String(error)}\n`);
1870
+ writeNativeHookJsonStdout(buildStopDispatchFailureOutput(error));
1871
+ }
1872
+ }
1873
+ if (isCodexNativeHookMainModule(import.meta.url, process.argv[1])) {
1874
+ runCodexNativeHookCli().catch((error) => {
1875
+ process.stderr.write(`[rcs] codex-native-hook failed: ${error instanceof Error ? error.message : String(error)}\n`);
1876
+ process.exitCode = 1;
1877
+ });
1878
+ }
1879
+ //# sourceMappingURL=codex-native-hook.js.map