@renxqoo/renx-code 0.0.9 → 0.0.12

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 (286) hide show
  1. package/README.md +31 -143
  2. package/bin/renx.cjs +79 -42
  3. package/bin/renx.exe +0 -0
  4. package/package.json +10 -28
  5. package/src/App.tsx +0 -297
  6. package/src/agent/runtime/event-format.ts +0 -258
  7. package/src/agent/runtime/model-types.ts +0 -13
  8. package/src/agent/runtime/runtime.context-usage.test.ts +0 -192
  9. package/src/agent/runtime/runtime.error-handling.test.ts +0 -235
  10. package/src/agent/runtime/runtime.simple.test.ts +0 -16
  11. package/src/agent/runtime/runtime.test.ts +0 -296
  12. package/src/agent/runtime/runtime.ts +0 -875
  13. package/src/agent/runtime/runtime.usage-forwarding.test.ts +0 -228
  14. package/src/agent/runtime/source-modules.test.ts +0 -38
  15. package/src/agent/runtime/source-modules.ts +0 -370
  16. package/src/agent/runtime/tool-call-buffer.test.ts +0 -65
  17. package/src/agent/runtime/tool-call-buffer.ts +0 -60
  18. package/src/agent/runtime/tool-confirmation.test.ts +0 -56
  19. package/src/agent/runtime/tool-confirmation.ts +0 -15
  20. package/src/agent/runtime/types.ts +0 -99
  21. package/src/commands/slash-commands.test.ts +0 -216
  22. package/src/commands/slash-commands.ts +0 -64
  23. package/src/components/chat/assistant-reply.test.tsx +0 -47
  24. package/src/components/chat/assistant-reply.tsx +0 -136
  25. package/src/components/chat/assistant-segment.test.ts +0 -99
  26. package/src/components/chat/assistant-segment.tsx +0 -125
  27. package/src/components/chat/assistant-tool-group.tsx +0 -900
  28. package/src/components/chat/code-block.test.tsx +0 -206
  29. package/src/components/chat/code-block.tsx +0 -313
  30. package/src/components/chat/prompt-card.tsx +0 -81
  31. package/src/components/chat/segment-groups.test.ts +0 -52
  32. package/src/components/chat/segment-groups.ts +0 -106
  33. package/src/components/chat/turn-item.tsx +0 -39
  34. package/src/components/conversation-panel.tsx +0 -43
  35. package/src/components/file-mention-menu.tsx +0 -77
  36. package/src/components/file-picker-dialog.tsx +0 -206
  37. package/src/components/footer-hints.tsx +0 -75
  38. package/src/components/model-picker-dialog.tsx +0 -248
  39. package/src/components/prompt.tsx +0 -233
  40. package/src/components/slash-command-menu.tsx +0 -65
  41. package/src/components/tool-confirm-dialog-content.test.ts +0 -103
  42. package/src/components/tool-confirm-dialog-content.ts +0 -186
  43. package/src/components/tool-confirm-dialog.tsx +0 -187
  44. package/src/components/tool-display-config.ts +0 -119
  45. package/src/context-usage-regressions.test.ts +0 -26
  46. package/src/files/attachment-capabilities.test.ts +0 -30
  47. package/src/files/attachment-capabilities.ts +0 -50
  48. package/src/files/attachment-content.ts +0 -153
  49. package/src/files/file-mention-query.test.ts +0 -34
  50. package/src/files/file-mention-query.ts +0 -32
  51. package/src/files/prompt-display.ts +0 -13
  52. package/src/files/types.ts +0 -5
  53. package/src/files/workspace-files.ts +0 -61
  54. package/src/hooks/agent-event-handlers.test.ts +0 -207
  55. package/src/hooks/agent-event-handlers.ts +0 -196
  56. package/src/hooks/chat-local-replies.fixed.test.ts +0 -119
  57. package/src/hooks/chat-local-replies.test.ts +0 -153
  58. package/src/hooks/chat-local-replies.ts +0 -63
  59. package/src/hooks/turn-updater.test.ts +0 -70
  60. package/src/hooks/turn-updater.ts +0 -166
  61. package/src/hooks/use-agent-chat.context.test.ts +0 -10
  62. package/src/hooks/use-agent-chat.status.test.ts +0 -14
  63. package/src/hooks/use-agent-chat.test.ts +0 -80
  64. package/src/hooks/use-agent-chat.ts +0 -621
  65. package/src/hooks/use-file-mention-menu.ts +0 -196
  66. package/src/hooks/use-file-picker.ts +0 -185
  67. package/src/hooks/use-model-picker.ts +0 -196
  68. package/src/hooks/use-slash-command-menu.ts +0 -154
  69. package/src/index.tsx +0 -55
  70. package/src/runtime/clipboard.test.ts +0 -43
  71. package/src/runtime/clipboard.ts +0 -89
  72. package/src/runtime/exit.test.ts +0 -177
  73. package/src/runtime/exit.ts +0 -98
  74. package/src/runtime/runtime-support.test.ts +0 -31
  75. package/src/runtime/terminal-theme.test.ts +0 -55
  76. package/src/runtime/terminal-theme.ts +0 -196
  77. package/src/types/chat.ts +0 -32
  78. package/src/types/message-content.ts +0 -48
  79. package/src/ui/open-code-theme.ts +0 -176
  80. package/src/ui/opencode-markdown.ts +0 -211
  81. package/src/ui/theme.simple.test.ts +0 -52
  82. package/src/ui/theme.test.ts +0 -151
  83. package/src/ui/theme.ts +0 -152
  84. package/src/utils/time.test.ts +0 -144
  85. package/src/utils/time.ts +0 -7
  86. package/tsconfig.json +0 -30
  87. package/vendor/agent-root/src/agent/ENTERPRISE_ACCEPTANCE_CHECKLIST.md +0 -95
  88. package/vendor/agent-root/src/agent/ENTERPRISE_REALTIME.html +0 -1345
  89. package/vendor/agent-root/src/agent/ENTERPRISE_REALTIME.md +0 -1353
  90. package/vendor/agent-root/src/agent/ERROR_CONTRACT.md +0 -60
  91. package/vendor/agent-root/src/agent/TEST_COVERAGE_ANALYSIS.md +0 -278
  92. package/vendor/agent-root/src/agent/__test__/error-contract.test.ts +0 -72
  93. package/vendor/agent-root/src/agent/__test__/types.test.ts +0 -137
  94. package/vendor/agent-root/src/agent/agent/__test__/abort-runtime.test.ts +0 -83
  95. package/vendor/agent-root/src/agent/agent/__test__/callback-safety.test.ts +0 -34
  96. package/vendor/agent-root/src/agent/agent/__test__/compaction.test.ts +0 -323
  97. package/vendor/agent-root/src/agent/agent/__test__/concurrency.test.ts +0 -290
  98. package/vendor/agent-root/src/agent/agent/__test__/error-normalizer.test.ts +0 -377
  99. package/vendor/agent-root/src/agent/agent/__test__/error.test.ts +0 -212
  100. package/vendor/agent-root/src/agent/agent/__test__/fault-injection.test.ts +0 -295
  101. package/vendor/agent-root/src/agent/agent/__test__/index.test.ts +0 -3607
  102. package/vendor/agent-root/src/agent/agent/__test__/logger.test.ts +0 -35
  103. package/vendor/agent-root/src/agent/agent/__test__/message-utils.test.ts +0 -517
  104. package/vendor/agent-root/src/agent/agent/__test__/telemetry.test.ts +0 -97
  105. package/vendor/agent-root/src/agent/agent/__test__/timeout-budget.test.ts +0 -479
  106. package/vendor/agent-root/src/agent/agent/__test__/tool-call-merge.test.ts +0 -80
  107. package/vendor/agent-root/src/agent/agent/__test__/tool-execution-ledger.test.ts +0 -76
  108. package/vendor/agent-root/src/agent/agent/__test__/write-buffer.test.ts +0 -173
  109. package/vendor/agent-root/src/agent/agent/__test__/write-file-session.test.ts +0 -109
  110. package/vendor/agent-root/src/agent/agent/abort-runtime.ts +0 -71
  111. package/vendor/agent-root/src/agent/agent/callback-safety.ts +0 -33
  112. package/vendor/agent-root/src/agent/agent/compaction.ts +0 -291
  113. package/vendor/agent-root/src/agent/agent/concurrency.ts +0 -103
  114. package/vendor/agent-root/src/agent/agent/error-normalizer.ts +0 -190
  115. package/vendor/agent-root/src/agent/agent/error.ts +0 -198
  116. package/vendor/agent-root/src/agent/agent/index.ts +0 -1772
  117. package/vendor/agent-root/src/agent/agent/logger.ts +0 -65
  118. package/vendor/agent-root/src/agent/agent/message-utils.ts +0 -101
  119. package/vendor/agent-root/src/agent/agent/stream-events.ts +0 -61
  120. package/vendor/agent-root/src/agent/agent/telemetry.ts +0 -123
  121. package/vendor/agent-root/src/agent/agent/timeout-budget.ts +0 -227
  122. package/vendor/agent-root/src/agent/agent/tool-call-merge.ts +0 -111
  123. package/vendor/agent-root/src/agent/agent/tool-execution-ledger.ts +0 -164
  124. package/vendor/agent-root/src/agent/agent/write-buffer.ts +0 -188
  125. package/vendor/agent-root/src/agent/agent/write-file-session.ts +0 -238
  126. package/vendor/agent-root/src/agent/app/__test__/agent-app-service.test.ts +0 -1053
  127. package/vendor/agent-root/src/agent/app/__test__/minimal-agent-application.test.ts +0 -158
  128. package/vendor/agent-root/src/agent/app/__test__/sqlite-agent-app-store.test.ts +0 -437
  129. package/vendor/agent-root/src/agent/app/agent-app-service.ts +0 -748
  130. package/vendor/agent-root/src/agent/app/contracts.ts +0 -109
  131. package/vendor/agent-root/src/agent/app/index.ts +0 -5
  132. package/vendor/agent-root/src/agent/app/minimal-agent-application.ts +0 -151
  133. package/vendor/agent-root/src/agent/app/ports.ts +0 -72
  134. package/vendor/agent-root/src/agent/app/sqlite-agent-app-store.ts +0 -1182
  135. package/vendor/agent-root/src/agent/app/sqlite-client.ts +0 -177
  136. package/vendor/agent-root/src/agent/docs/cli-app-layer/00-README.md +0 -36
  137. package/vendor/agent-root/src/agent/docs/cli-app-layer/01-scope-and-goals.md +0 -33
  138. package/vendor/agent-root/src/agent/docs/cli-app-layer/02-architecture-overview.md +0 -40
  139. package/vendor/agent-root/src/agent/docs/cli-app-layer/03-domain-model-and-contracts.md +0 -91
  140. package/vendor/agent-root/src/agent/docs/cli-app-layer/04-ports-and-interfaces.md +0 -116
  141. package/vendor/agent-root/src/agent/docs/cli-app-layer/05-run-orchestration-and-state-machine.md +0 -52
  142. package/vendor/agent-root/src/agent/docs/cli-app-layer/06-cli-commands-and-ux.md +0 -53
  143. package/vendor/agent-root/src/agent/docs/cli-app-layer/07-storage-design-local.md +0 -52
  144. package/vendor/agent-root/src/agent/docs/cli-app-layer/08-error-and-observability.md +0 -40
  145. package/vendor/agent-root/src/agent/docs/cli-app-layer/09-security-and-policy-boundary.md +0 -19
  146. package/vendor/agent-root/src/agent/docs/cli-app-layer/10-test-plan-and-acceptance.md +0 -28
  147. package/vendor/agent-root/src/agent/docs/cli-app-layer/11-implementation-phases.md +0 -26
  148. package/vendor/agent-root/src/agent/docs/cli-app-layer/12-open-questions-and-risks.md +0 -30
  149. package/vendor/agent-root/src/agent/docs/cli-app-layer/13-sqlite-schema-fields-and-rationale.md +0 -567
  150. package/vendor/agent-root/src/agent/docs/cli-app-layer/14-project-flow-mermaid.md +0 -583
  151. package/vendor/agent-root/src/agent/docs/cli-app-layer/15-openclaw-style-project-blueprint.md +0 -972
  152. package/vendor/agent-root/src/agent/error-contract.ts +0 -154
  153. package/vendor/agent-root/src/agent/prompts/system.ts +0 -246
  154. package/vendor/agent-root/src/agent/prompts/system1.ts +0 -208
  155. package/vendor/agent-root/src/agent/storage/__test__/file-history-store.test.ts +0 -98
  156. package/vendor/agent-root/src/agent/storage/file-history-store.ts +0 -313
  157. package/vendor/agent-root/src/agent/storage/file-storage-config.ts +0 -94
  158. package/vendor/agent-root/src/agent/storage/file-system.ts +0 -31
  159. package/vendor/agent-root/src/agent/storage/file-write-service.ts +0 -21
  160. package/vendor/agent-root/src/agent/tool/__test__/base-tool.test.ts +0 -413
  161. package/vendor/agent-root/src/agent/tool/__test__/bash-policy.test.ts +0 -356
  162. package/vendor/agent-root/src/agent/tool/__test__/bash.mocked-coverage.test.ts +0 -375
  163. package/vendor/agent-root/src/agent/tool/__test__/bash.test.ts +0 -372
  164. package/vendor/agent-root/src/agent/tool/__test__/error.test.ts +0 -108
  165. package/vendor/agent-root/src/agent/tool/__test__/file-edit-tool.test.ts +0 -258
  166. package/vendor/agent-root/src/agent/tool/__test__/file-history-tools.test.ts +0 -121
  167. package/vendor/agent-root/src/agent/tool/__test__/file-read-tool.test.ts +0 -210
  168. package/vendor/agent-root/src/agent/tool/__test__/glob.test.ts +0 -139
  169. package/vendor/agent-root/src/agent/tool/__test__/grep.mocked-coverage.test.ts +0 -456
  170. package/vendor/agent-root/src/agent/tool/__test__/grep.test.ts +0 -192
  171. package/vendor/agent-root/src/agent/tool/__test__/lsp.test.ts +0 -300
  172. package/vendor/agent-root/src/agent/tool/__test__/outside-workspace-confirmation.test.ts +0 -214
  173. package/vendor/agent-root/src/agent/tool/__test__/path-security.test.ts +0 -336
  174. package/vendor/agent-root/src/agent/tool/__test__/skill-loader.test.ts +0 -494
  175. package/vendor/agent-root/src/agent/tool/__test__/skill-parser.test.ts +0 -543
  176. package/vendor/agent-root/src/agent/tool/__test__/skill-tool.test.ts +0 -172
  177. package/vendor/agent-root/src/agent/tool/__test__/task-concurrency-and-version.test.ts +0 -116
  178. package/vendor/agent-root/src/agent/tool/__test__/task-create-get-list-update.test.ts +0 -267
  179. package/vendor/agent-root/src/agent/tool/__test__/task-create.test.ts +0 -519
  180. package/vendor/agent-root/src/agent/tool/__test__/task-errors.test.ts +0 -225
  181. package/vendor/agent-root/src/agent/tool/__test__/task-output-blocking.test.ts +0 -223
  182. package/vendor/agent-root/src/agent/tool/__test__/task-output.test.ts +0 -184
  183. package/vendor/agent-root/src/agent/tool/__test__/task-parent-abort.test.ts +0 -287
  184. package/vendor/agent-root/src/agent/tool/__test__/task-real-runner-adapter.test.ts +0 -190
  185. package/vendor/agent-root/src/agent/tool/__test__/task-run-lifecycle.test.ts +0 -352
  186. package/vendor/agent-root/src/agent/tool/__test__/task-store-runner-branches.test.ts +0 -395
  187. package/vendor/agent-root/src/agent/tool/__test__/task-store.test.ts +0 -391
  188. package/vendor/agent-root/src/agent/tool/__test__/task-subagent-config-integration.test.ts +0 -176
  189. package/vendor/agent-root/src/agent/tool/__test__/task-subagent-config.test.ts +0 -68
  190. package/vendor/agent-root/src/agent/tool/__test__/task-tools-core-edges.test.ts +0 -630
  191. package/vendor/agent-root/src/agent/tool/__test__/task-tools-runtime-edges.test.ts +0 -732
  192. package/vendor/agent-root/src/agent/tool/__test__/task-types.test.ts +0 -494
  193. package/vendor/agent-root/src/agent/tool/__test__/task-utils-branches.test.ts +0 -175
  194. package/vendor/agent-root/src/agent/tool/__test__/tool-manager.test.ts +0 -505
  195. package/vendor/agent-root/src/agent/tool/__test__/types.test.ts +0 -55
  196. package/vendor/agent-root/src/agent/tool/__test__/web-fetch.test.ts +0 -244
  197. package/vendor/agent-root/src/agent/tool/__test__/web-search.test.ts +0 -290
  198. package/vendor/agent-root/src/agent/tool/__test__/write-file.test.ts +0 -368
  199. package/vendor/agent-root/src/agent/tool/base-tool.ts +0 -345
  200. package/vendor/agent-root/src/agent/tool/bash-policy.ts +0 -636
  201. package/vendor/agent-root/src/agent/tool/bash.ts +0 -688
  202. package/vendor/agent-root/src/agent/tool/error.ts +0 -131
  203. package/vendor/agent-root/src/agent/tool/file-edit-tool.ts +0 -264
  204. package/vendor/agent-root/src/agent/tool/file-history-list.ts +0 -103
  205. package/vendor/agent-root/src/agent/tool/file-history-restore.ts +0 -149
  206. package/vendor/agent-root/src/agent/tool/file-read-tool.ts +0 -211
  207. package/vendor/agent-root/src/agent/tool/glob.ts +0 -171
  208. package/vendor/agent-root/src/agent/tool/grep.ts +0 -496
  209. package/vendor/agent-root/src/agent/tool/lsp.ts +0 -481
  210. package/vendor/agent-root/src/agent/tool/path-security.ts +0 -117
  211. package/vendor/agent-root/src/agent/tool/search/common.ts +0 -153
  212. package/vendor/agent-root/src/agent/tool/skill/index.ts +0 -13
  213. package/vendor/agent-root/src/agent/tool/skill/loader.ts +0 -229
  214. package/vendor/agent-root/src/agent/tool/skill/parser.ts +0 -124
  215. package/vendor/agent-root/src/agent/tool/skill/types.ts +0 -27
  216. package/vendor/agent-root/src/agent/tool/skill-tool.ts +0 -143
  217. package/vendor/agent-root/src/agent/tool/task-create.ts +0 -186
  218. package/vendor/agent-root/src/agent/tool/task-errors.ts +0 -42
  219. package/vendor/agent-root/src/agent/tool/task-get.ts +0 -116
  220. package/vendor/agent-root/src/agent/tool/task-graph.ts +0 -78
  221. package/vendor/agent-root/src/agent/tool/task-list.ts +0 -141
  222. package/vendor/agent-root/src/agent/tool/task-mock-runner-adapter.ts +0 -232
  223. package/vendor/agent-root/src/agent/tool/task-output.ts +0 -223
  224. package/vendor/agent-root/src/agent/tool/task-parent-abort.ts +0 -115
  225. package/vendor/agent-root/src/agent/tool/task-real-runner-adapter.ts +0 -336
  226. package/vendor/agent-root/src/agent/tool/task-runner-adapter.ts +0 -55
  227. package/vendor/agent-root/src/agent/tool/task-stop.ts +0 -187
  228. package/vendor/agent-root/src/agent/tool/task-store.ts +0 -217
  229. package/vendor/agent-root/src/agent/tool/task-subagent-config.ts +0 -149
  230. package/vendor/agent-root/src/agent/tool/task-types.ts +0 -264
  231. package/vendor/agent-root/src/agent/tool/task-update.ts +0 -315
  232. package/vendor/agent-root/src/agent/tool/task.ts +0 -209
  233. package/vendor/agent-root/src/agent/tool/tool-manager.ts +0 -361
  234. package/vendor/agent-root/src/agent/tool/tool-prompts.ts +0 -242
  235. package/vendor/agent-root/src/agent/tool/types.ts +0 -116
  236. package/vendor/agent-root/src/agent/tool/web-fetch.ts +0 -227
  237. package/vendor/agent-root/src/agent/tool/web-search.ts +0 -208
  238. package/vendor/agent-root/src/agent/tool/write-file.ts +0 -497
  239. package/vendor/agent-root/src/agent/types.ts +0 -232
  240. package/vendor/agent-root/src/agent/utils/__tests__/index.test.ts +0 -18
  241. package/vendor/agent-root/src/agent/utils/__tests__/message-utils.test.ts +0 -610
  242. package/vendor/agent-root/src/agent/utils/__tests__/message.test.ts +0 -223
  243. package/vendor/agent-root/src/agent/utils/__tests__/token.test.ts +0 -42
  244. package/vendor/agent-root/src/agent/utils/index.ts +0 -16
  245. package/vendor/agent-root/src/agent/utils/message.ts +0 -171
  246. package/vendor/agent-root/src/agent/utils/token.ts +0 -28
  247. package/vendor/agent-root/src/config/__tests__/load-config-to-env.test.ts +0 -238
  248. package/vendor/agent-root/src/config/__tests__/loader.test.ts +0 -361
  249. package/vendor/agent-root/src/config/__tests__/runtime.test.ts +0 -88
  250. package/vendor/agent-root/src/config/index.ts +0 -55
  251. package/vendor/agent-root/src/config/loader.ts +0 -494
  252. package/vendor/agent-root/src/config/paths.ts +0 -30
  253. package/vendor/agent-root/src/config/runtime.ts +0 -163
  254. package/vendor/agent-root/src/config/types.ts +0 -96
  255. package/vendor/agent-root/src/logger/index.ts +0 -57
  256. package/vendor/agent-root/src/logger/logger.ts +0 -819
  257. package/vendor/agent-root/src/logger/types.ts +0 -150
  258. package/vendor/agent-root/src/providers/__tests__/errors.test.ts +0 -441
  259. package/vendor/agent-root/src/providers/__tests__/index.test.ts +0 -16
  260. package/vendor/agent-root/src/providers/__tests__/openai-compatible.options.test.ts +0 -318
  261. package/vendor/agent-root/src/providers/__tests__/openai-compatible.test.ts +0 -600
  262. package/vendor/agent-root/src/providers/__tests__/registry.test.ts +0 -523
  263. package/vendor/agent-root/src/providers/__tests__/responses-adapter.test.ts +0 -298
  264. package/vendor/agent-root/src/providers/adapters/__tests__/anthropic.test.ts +0 -354
  265. package/vendor/agent-root/src/providers/adapters/__tests__/kimi.test.ts +0 -58
  266. package/vendor/agent-root/src/providers/adapters/__tests__/standard.test.ts +0 -261
  267. package/vendor/agent-root/src/providers/adapters/anthropic.ts +0 -572
  268. package/vendor/agent-root/src/providers/adapters/base.ts +0 -131
  269. package/vendor/agent-root/src/providers/adapters/kimi.ts +0 -48
  270. package/vendor/agent-root/src/providers/adapters/responses.ts +0 -732
  271. package/vendor/agent-root/src/providers/adapters/standard.ts +0 -120
  272. package/vendor/agent-root/src/providers/http/__tests__/client.timeout.test.ts +0 -313
  273. package/vendor/agent-root/src/providers/http/client.ts +0 -289
  274. package/vendor/agent-root/src/providers/http/stream-parser.ts +0 -109
  275. package/vendor/agent-root/src/providers/index.ts +0 -76
  276. package/vendor/agent-root/src/providers/kimi-headers.ts +0 -177
  277. package/vendor/agent-root/src/providers/openai-compatible.ts +0 -387
  278. package/vendor/agent-root/src/providers/registry/model-config.ts +0 -477
  279. package/vendor/agent-root/src/providers/registry/provider-factory.ts +0 -127
  280. package/vendor/agent-root/src/providers/registry.ts +0 -135
  281. package/vendor/agent-root/src/providers/types/api.ts +0 -284
  282. package/vendor/agent-root/src/providers/types/config.ts +0 -58
  283. package/vendor/agent-root/src/providers/types/errors.ts +0 -323
  284. package/vendor/agent-root/src/providers/types/index.ts +0 -72
  285. package/vendor/agent-root/src/providers/types/provider.ts +0 -45
  286. package/vendor/agent-root/src/providers/types/registry.ts +0 -68
@@ -1,217 +0,0 @@
1
- import * as fs from 'node:fs/promises';
2
- import * as path from 'node:path';
3
- import * as os from 'node:os';
4
- import { randomUUID } from 'node:crypto';
5
- import { createEmptyNamespaceState, safeJsonClone, type TaskNamespaceState } from './task-types';
6
-
7
- interface NamespaceLockState {
8
- locked: boolean;
9
- waiters: Array<() => void>;
10
- }
11
-
12
- export interface TaskStoreOptions {
13
- baseDir?: string;
14
- now?: () => number;
15
- }
16
-
17
- export class TaskStore {
18
- readonly baseDir: string;
19
-
20
- private readonly now: () => number;
21
- private readonly namespaceCache = new Map<string, TaskNamespaceState>();
22
- private readonly lockStates = new Map<string, NamespaceLockState>();
23
- private initialized = false;
24
-
25
- constructor(options: TaskStoreOptions = {}) {
26
- this.baseDir = path.resolve(options.baseDir || path.join(os.homedir(), '.renx', 'task'));
27
- this.now = options.now || Date.now;
28
- }
29
-
30
- async getState(namespaceInput?: string): Promise<TaskNamespaceState> {
31
- const namespace = this.normalizeNamespace(namespaceInput);
32
- await this.ensureInitialized();
33
- const state = await this.readNamespaceState(namespace);
34
- return safeJsonClone(state);
35
- }
36
-
37
- async updateState<T>(
38
- namespaceInput: string | undefined,
39
- updater: (state: TaskNamespaceState) => Promise<T> | T
40
- ): Promise<{ state: TaskNamespaceState; result: T }> {
41
- const namespace = this.normalizeNamespace(namespaceInput);
42
- await this.ensureInitialized();
43
- await this.acquireNamespaceLock(namespace);
44
-
45
- try {
46
- const current = await this.readNamespaceState(namespace);
47
- const working = safeJsonClone(current);
48
- const result = await updater(working);
49
- working.updatedAt = this.now();
50
- await this.writeNamespaceState(namespace, working);
51
- this.namespaceCache.set(namespace, safeJsonClone(working));
52
- return {
53
- state: safeJsonClone(working),
54
- result,
55
- };
56
- } finally {
57
- this.releaseNamespaceLock(namespace);
58
- }
59
- }
60
-
61
- normalizeNamespace(namespaceInput?: string): string {
62
- const raw = (namespaceInput || 'default').trim();
63
- if (!raw) {
64
- return 'default';
65
- }
66
- if (!/^[a-zA-Z0-9._-]+$/.test(raw)) {
67
- throw new Error('TASK_INVALID_NAMESPACE: namespace allows only [a-zA-Z0-9._-]');
68
- }
69
- return raw;
70
- }
71
-
72
- getNamespaceFilePath(namespace: string): string {
73
- return path.join(this.baseDir, `${namespace}.json`);
74
- }
75
-
76
- private async ensureInitialized(): Promise<void> {
77
- if (this.initialized) {
78
- return;
79
- }
80
- await fs.mkdir(this.baseDir, { recursive: true });
81
- this.initialized = true;
82
- }
83
-
84
- private async readNamespaceState(namespace: string): Promise<TaskNamespaceState> {
85
- const cached = this.namespaceCache.get(namespace);
86
- if (cached) {
87
- return safeJsonClone(cached);
88
- }
89
-
90
- const filePath = this.getNamespaceFilePath(namespace);
91
- try {
92
- const raw = await fs.readFile(filePath, 'utf8');
93
- const parsed = JSON.parse(raw) as Partial<TaskNamespaceState>;
94
- const hydrated = this.hydrateState(namespace, parsed);
95
- this.namespaceCache.set(namespace, safeJsonClone(hydrated));
96
- return hydrated;
97
- } catch (error) {
98
- const nodeError = error as NodeJS.ErrnoException;
99
- if (nodeError?.code !== 'ENOENT') {
100
- throw new Error(
101
- `TASK_STORE_IO_ERROR: failed to load namespace ${namespace}: ${nodeError.message}`
102
- );
103
- }
104
- const emptyState = createEmptyNamespaceState(namespace);
105
- this.namespaceCache.set(namespace, safeJsonClone(emptyState));
106
- await this.writeNamespaceState(namespace, emptyState);
107
- return emptyState;
108
- }
109
- }
110
-
111
- private hydrateState(
112
- namespace: string,
113
- partial: Partial<TaskNamespaceState>
114
- ): TaskNamespaceState {
115
- const base = createEmptyNamespaceState(namespace);
116
- const merged: TaskNamespaceState = {
117
- ...base,
118
- ...partial,
119
- namespace,
120
- tasks: partial.tasks || {},
121
- agentRuns: partial.agentRuns || {},
122
- graph: {
123
- adjacency: partial.graph?.adjacency || {},
124
- reverse: partial.graph?.reverse || {},
125
- },
126
- updatedAt: typeof partial.updatedAt === 'number' ? partial.updatedAt : base.updatedAt,
127
- schemaVersion: 1,
128
- };
129
-
130
- for (const taskId of Object.keys(merged.tasks)) {
131
- if (!merged.graph.adjacency[taskId]) {
132
- merged.graph.adjacency[taskId] = [];
133
- }
134
- if (!merged.graph.reverse[taskId]) {
135
- merged.graph.reverse[taskId] = [];
136
- }
137
- }
138
-
139
- return merged;
140
- }
141
-
142
- private async writeNamespaceState(namespace: string, state: TaskNamespaceState): Promise<void> {
143
- const filePath = this.getNamespaceFilePath(namespace);
144
- const dirPath = path.dirname(filePath);
145
- await fs.mkdir(dirPath, { recursive: true });
146
- const tmpPath = `${filePath}.tmp.${randomUUID().slice(0, 8)}`;
147
- const json = `${JSON.stringify(state, null, 2)}\n`;
148
- await fs.writeFile(tmpPath, json, 'utf8');
149
-
150
- try {
151
- await fs.rename(tmpPath, filePath);
152
- } catch (error) {
153
- const nodeError = error as NodeJS.ErrnoException;
154
- if (nodeError.code === 'EPERM' && process.platform === 'win32') {
155
- await fs.copyFile(tmpPath, filePath);
156
- await fs.unlink(tmpPath).catch(() => undefined);
157
- return;
158
- }
159
- throw error;
160
- }
161
- }
162
-
163
- private async acquireNamespaceLock(namespace: string): Promise<void> {
164
- let lockState = this.lockStates.get(namespace);
165
- if (!lockState) {
166
- lockState = {
167
- locked: false,
168
- waiters: [],
169
- };
170
- this.lockStates.set(namespace, lockState);
171
- }
172
-
173
- if (!lockState.locked) {
174
- lockState.locked = true;
175
- return;
176
- }
177
-
178
- await new Promise<void>((resolve) => {
179
- lockState?.waiters.push(resolve);
180
- });
181
- }
182
-
183
- private releaseNamespaceLock(namespace: string): void {
184
- const lockState = this.lockStates.get(namespace);
185
- if (!lockState) {
186
- return;
187
- }
188
-
189
- const next = lockState.waiters.shift();
190
- if (next) {
191
- next();
192
- return;
193
- }
194
-
195
- lockState.locked = false;
196
- }
197
- }
198
-
199
- let globalTaskStore: TaskStore | null = null;
200
- let globalTaskStoreKey = '';
201
-
202
- export function getTaskStore(options: TaskStoreOptions = {}): TaskStore {
203
- const baseDir = path.resolve(options.baseDir || path.join(os.homedir(), '.renx', 'task'));
204
- if (!globalTaskStore || globalTaskStoreKey !== baseDir) {
205
- globalTaskStore = new TaskStore({
206
- ...options,
207
- baseDir,
208
- });
209
- globalTaskStoreKey = baseDir;
210
- }
211
- return globalTaskStore;
212
- }
213
-
214
- export function resetTaskStoreSingleton(): void {
215
- globalTaskStore = null;
216
- globalTaskStoreKey = '';
217
- }
@@ -1,149 +0,0 @@
1
- import type { SubagentType } from './task-types';
2
-
3
- export interface TaskSubagentConfig {
4
- tools: string[];
5
- systemPrompt: string;
6
- }
7
-
8
- const TOOLSET = {
9
- bash: ['bash'],
10
- readOnly: ['glob', 'grep', 'file_read', 'file_history_list', 'skill'],
11
- restore: ['glob', 'file_read', 'file_history_list', 'file_history_restore'],
12
- general: [
13
- 'bash',
14
- 'glob',
15
- 'grep',
16
- 'file_read',
17
- 'file_edit',
18
- 'write_file',
19
- 'file_history_list',
20
- 'file_history_restore',
21
- 'skill',
22
- ],
23
- findSkills: ['skill', 'bash'],
24
- } as const;
25
-
26
- const SYSTEM_PROMPTS: Record<SubagentType, string> = {
27
- Bash: `You are a shell execution specialist.
28
- Run safe, minimal commands and report exact outcomes.
29
- Prefer non-interactive commands and always surface stderr on failure.`,
30
- 'general-purpose': `You are a general software engineering subagent.
31
- Use tools pragmatically, verify key changes, and keep responses concise and evidence-based.`,
32
- Explore: `You are a codebase exploration specialist.
33
- Use glob/grep/file_read to find relevant implementation details quickly and accurately.`,
34
- Restore: `You are a file restoration specialist.
35
- Your job is to restore one or more files from saved history with minimal risk.
36
-
37
- Workflow:
38
- 1. Prefer exact absolute file paths provided by the parent agent.
39
- 2. If the parent already gave an absolute path, do not search broadly unless the path fails.
40
- 3. Use file_history_list to inspect available saved versions for that file.
41
- 4. Unless the parent specifies a versionId, restore the latest saved version.
42
- 5. Use file_history_restore to perform the rollback.
43
- 6. Read the file after restoring to confirm the content changed as expected.
44
-
45
- Rules:
46
- - Prefer absolute file paths.
47
- - If only a file path is needed and the parent supplied one, that is sufficient.
48
- - Do not use file_edit or write_file.
49
- - Do not modify unrelated files.
50
- - Report exactly which file path was restored and which versionId was used.`,
51
- Plan: `You are a planning specialist.
52
- Produce concrete implementation plans with clear steps, risks, and acceptance criteria.`,
53
- 'research-agent': `You are a research-focused subagent.
54
- Collect evidence from available files and synthesize concise, structured findings.`,
55
- 'find-skills': `
56
- ## Role
57
- You are a **Skill Discovery and Installation Specialist**.
58
- Your goal is to **help the parent agent quickly and reliably find the correct skill required to complete a task.**
59
- ## Workflow
60
- 1. **Check local skills first**
61
- Use the \`skill\` tool to read local skills using **exact or likely names**.
62
- 2. **If the skill is missing or insufficient**
63
- Use the \`skill\` tool to load the **\`find-skills\`** skill and follow its workflow to:
64
- * search skills using **exact or likely names**
65
- * discover candidates
66
- * install the appropriate skill
67
- 3. **If \`find-skills\` is missing**
68
- Use \`bash\` only for the required installation command:
69
- \`\`\`bash
70
- npx skills add https://github.com/vercel-labs/skills --skill find-skills
71
- \`\`\`
72
- After installation, retry using the \`skill\` tool.
73
- 4. **Verify after installation**
74
- Run the \`skill\` tool again to confirm the target skill is **readable and available**.
75
- ## Critical Rules
76
- * **Never invent skill content**
77
- * Only report **actual tool results**
78
- * Do not assume a skill exists
79
- * Always **verify after installation**
80
- ## Output Format (Markdown required)
81
- Your response must include:
82
- ### Skill Status
83
- * Found locally
84
- * Found remotely and installed
85
- * Still missing
86
- ### Recommended Skill
87
- * Skill name
88
- * Why it fits the task
89
- ### Next Step
90
- What the parent agent should do next.
91
- Keep the response **concise, clear, and action-oriented**.
92
- `,
93
- };
94
-
95
- const TASK_SUBAGENT_CONFIGS: Record<SubagentType, TaskSubagentConfig> = {
96
- Bash: {
97
- tools: [...TOOLSET.bash],
98
- systemPrompt: SYSTEM_PROMPTS.Bash,
99
- },
100
- 'general-purpose': {
101
- tools: [...TOOLSET.general],
102
- systemPrompt: SYSTEM_PROMPTS['general-purpose'],
103
- },
104
- Explore: {
105
- tools: [...TOOLSET.readOnly],
106
- systemPrompt: SYSTEM_PROMPTS.Explore,
107
- },
108
- Restore: {
109
- tools: [...TOOLSET.restore],
110
- systemPrompt: SYSTEM_PROMPTS.Restore,
111
- },
112
- Plan: {
113
- tools: [...TOOLSET.readOnly],
114
- systemPrompt: SYSTEM_PROMPTS.Plan,
115
- },
116
- 'research-agent': {
117
- tools: [...TOOLSET.readOnly],
118
- systemPrompt: SYSTEM_PROMPTS['research-agent'],
119
- },
120
- 'find-skills': {
121
- tools: [...TOOLSET.findSkills],
122
- systemPrompt: SYSTEM_PROMPTS['find-skills'],
123
- },
124
- };
125
-
126
- export function getTaskSubagentConfig(subagentType: SubagentType): TaskSubagentConfig {
127
- const config = TASK_SUBAGENT_CONFIGS[subagentType];
128
- return {
129
- tools: [...config.tools],
130
- systemPrompt: config.systemPrompt,
131
- };
132
- }
133
-
134
- export function resolveTaskSubagentTools(
135
- subagentType: SubagentType,
136
- requestedTools?: string[]
137
- ): string[] {
138
- const defaults = getTaskSubagentConfig(subagentType).tools;
139
- if (!requestedTools || requestedTools.length === 0) {
140
- return defaults;
141
- }
142
-
143
- const defaultSet = new Set(defaults);
144
- const narrowed = requestedTools.filter((tool) => defaultSet.has(tool));
145
- if (narrowed.length === 0) {
146
- return defaults;
147
- }
148
- return narrowed;
149
- }
@@ -1,264 +0,0 @@
1
- import { randomUUID } from 'node:crypto';
2
-
3
- export const TASK_STATUS_VALUES = [
4
- 'pending',
5
- 'in_progress',
6
- 'completed',
7
- 'cancelled',
8
- 'failed',
9
- ] as const;
10
-
11
- export type TaskStatus = (typeof TASK_STATUS_VALUES)[number];
12
-
13
- export const TASK_PRIORITY_VALUES = ['critical', 'high', 'normal', 'low'] as const;
14
-
15
- export type TaskPriority = (typeof TASK_PRIORITY_VALUES)[number];
16
-
17
- export const AGENT_RUN_STATUS_VALUES = [
18
- 'queued',
19
- 'running',
20
- 'completed',
21
- 'failed',
22
- 'cancelled',
23
- 'paused',
24
- 'timed_out',
25
- ] as const;
26
-
27
- export type AgentRunStatus = (typeof AGENT_RUN_STATUS_VALUES)[number];
28
-
29
- export const SUBAGENT_TYPE_VALUES = [
30
- 'Bash',
31
- 'general-purpose',
32
- 'Explore',
33
- 'Restore',
34
- 'Plan',
35
- 'research-agent',
36
- 'find-skills',
37
- ] as const;
38
-
39
- export type SubagentType = (typeof SUBAGENT_TYPE_VALUES)[number];
40
-
41
- export interface TaskCheckpoint {
42
- id: string;
43
- name: string;
44
- completed: boolean;
45
- completedAt?: number;
46
- }
47
-
48
- export interface TaskTag {
49
- name: string;
50
- color?: string;
51
- category?: string;
52
- }
53
-
54
- export interface RetryConfig {
55
- maxRetries: number;
56
- retryDelayMs: number;
57
- backoffMultiplier: number;
58
- retryOn: string[];
59
- }
60
-
61
- export interface TaskHistoryEntry {
62
- timestamp: number;
63
- action: string;
64
- fromStatus?: TaskStatus;
65
- toStatus?: TaskStatus;
66
- actor?: string | null;
67
- reason?: string;
68
- metadata?: Record<string, unknown>;
69
- }
70
-
71
- export interface TaskEntity {
72
- id: string;
73
- subject: string;
74
- description: string;
75
- activeForm: string;
76
- status: TaskStatus;
77
- priority: TaskPriority;
78
- owner: string | null;
79
- blockedBy: string[];
80
- blocks: string[];
81
- progress: number;
82
- checkpoints: TaskCheckpoint[];
83
- retryConfig: RetryConfig;
84
- retryCount: number;
85
- lastError?: string;
86
- lastErrorAt?: number;
87
- timeoutMs?: number;
88
- tags: TaskTag[];
89
- metadata: Record<string, unknown>;
90
- history: TaskHistoryEntry[];
91
- agentId?: string;
92
- createdAt: number;
93
- updatedAt: number;
94
- startedAt?: number;
95
- completedAt?: number;
96
- cancelledAt?: number;
97
- version: number;
98
- }
99
-
100
- export interface AgentRunEntity {
101
- agentId: string;
102
- status: AgentRunStatus;
103
- subagentType: SubagentType;
104
- prompt: string;
105
- description?: string;
106
- model?: 'sonnet' | 'opus' | 'haiku';
107
- maxTurns?: number;
108
- allowedTools?: string[];
109
- linkedTaskId?: string;
110
- output?: string;
111
- error?: string;
112
- progress?: number;
113
- createdAt: number;
114
- startedAt?: number;
115
- endedAt?: number;
116
- updatedAt: number;
117
- outputFile?: string;
118
- metadata: Record<string, unknown>;
119
- version: number;
120
- }
121
-
122
- export interface DependencyGraphState {
123
- adjacency: Record<string, string[]>;
124
- reverse: Record<string, string[]>;
125
- }
126
-
127
- export interface TaskNamespaceState {
128
- namespace: string;
129
- tasks: Record<string, TaskEntity>;
130
- agentRuns: Record<string, AgentRunEntity>;
131
- graph: DependencyGraphState;
132
- updatedAt: number;
133
- schemaVersion: 1;
134
- }
135
-
136
- export interface CanStartResult {
137
- canStart: boolean;
138
- reason?: string;
139
- }
140
-
141
- export const DEFAULT_RETRY_CONFIG: RetryConfig = {
142
- maxRetries: 3,
143
- retryDelayMs: 5000,
144
- backoffMultiplier: 2,
145
- retryOn: ['timeout', 'network_error'],
146
- };
147
-
148
- export const VALID_TASK_TRANSITIONS: Record<TaskStatus, TaskStatus[]> = {
149
- pending: ['in_progress', 'cancelled'],
150
- in_progress: ['completed', 'pending', 'cancelled', 'failed'],
151
- completed: [],
152
- cancelled: [],
153
- failed: ['pending'],
154
- };
155
-
156
- export function createTaskId(): string {
157
- return `task_${Date.now()}_${randomUUID().slice(0, 8)}`;
158
- }
159
-
160
- export function createAgentId(): string {
161
- return `agent_${Date.now()}_${randomUUID().slice(0, 8)}`;
162
- }
163
-
164
- export function isTaskTerminal(status: TaskStatus): boolean {
165
- return status === 'completed' || status === 'cancelled';
166
- }
167
-
168
- export function isTaskFinal(status: TaskStatus): boolean {
169
- return status === 'completed' || status === 'cancelled' || status === 'failed';
170
- }
171
-
172
- export function isAgentRunTerminal(status: AgentRunStatus): boolean {
173
- return (
174
- status === 'completed' ||
175
- status === 'failed' ||
176
- status === 'cancelled' ||
177
- status === 'timed_out'
178
- );
179
- }
180
-
181
- export function validateTaskTransition(from: TaskStatus, to: TaskStatus): boolean {
182
- if (from === to) {
183
- return true;
184
- }
185
- return VALID_TASK_TRANSITIONS[from].includes(to);
186
- }
187
-
188
- export function createEmptyNamespaceState(namespace: string): TaskNamespaceState {
189
- return {
190
- namespace,
191
- tasks: {},
192
- agentRuns: {},
193
- graph: {
194
- adjacency: {},
195
- reverse: {},
196
- },
197
- updatedAt: Date.now(),
198
- schemaVersion: 1,
199
- };
200
- }
201
-
202
- export function evaluateTaskCanStart(
203
- task: TaskEntity,
204
- allTasks: Record<string, TaskEntity>
205
- ): CanStartResult {
206
- if (task.status !== 'pending') {
207
- return {
208
- canStart: false,
209
- reason: `Task status is ${task.status}, expected pending`,
210
- };
211
- }
212
-
213
- if (task.owner) {
214
- return {
215
- canStart: false,
216
- reason: `Task is already owned by ${task.owner}`,
217
- };
218
- }
219
-
220
- const cancelledBlockers: string[] = [];
221
- const failedBlockers: string[] = [];
222
- const incompleteBlockers: string[] = [];
223
-
224
- for (const blockerId of task.blockedBy) {
225
- const blocker = allTasks[blockerId];
226
- if (!blocker) {
227
- incompleteBlockers.push(blockerId);
228
- continue;
229
- }
230
- if (blocker.status === 'cancelled') {
231
- cancelledBlockers.push(blockerId);
232
- continue;
233
- }
234
- if (blocker.status === 'failed') {
235
- failedBlockers.push(blockerId);
236
- continue;
237
- }
238
- if (blocker.status !== 'completed') {
239
- incompleteBlockers.push(blockerId);
240
- }
241
- }
242
-
243
- if (cancelledBlockers.length > 0 || failedBlockers.length > 0) {
244
- return {
245
- canStart: false,
246
- reason:
247
- `Blocked by cancelled/failed dependencies: ` +
248
- `${[...cancelledBlockers, ...failedBlockers].join(', ')}`,
249
- };
250
- }
251
-
252
- if (incompleteBlockers.length > 0) {
253
- return {
254
- canStart: false,
255
- reason: `Blocked by incomplete dependencies: ${incompleteBlockers.join(', ')}`,
256
- };
257
- }
258
-
259
- return { canStart: true };
260
- }
261
-
262
- export function safeJsonClone<T>(value: T): T {
263
- return JSON.parse(JSON.stringify(value)) as T;
264
- }