claude-code-workflow 6.1.4 → 6.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (437) hide show
  1. package/.claude/CLAUDE.md +10 -0
  2. package/.claude/agents/action-planning-agent.md +857 -778
  3. package/.claude/agents/cli-execution-agent.md +266 -269
  4. package/.claude/agents/cli-explore-agent.md +2 -2
  5. package/.claude/agents/cli-lite-planning-agent.md +142 -92
  6. package/.claude/agents/cli-planning-agent.md +4 -4
  7. package/.claude/agents/code-developer.md +7 -6
  8. package/.claude/agents/conceptual-planning-agent.md +2 -2
  9. package/.claude/agents/context-search-agent.md +31 -32
  10. package/.claude/agents/doc-generator.md +4 -4
  11. package/.claude/agents/memory-bridge.md +93 -93
  12. package/.claude/agents/test-context-search-agent.md +8 -7
  13. package/.claude/agents/test-fix-agent.md +7 -6
  14. package/.claude/commands/clean.md +516 -0
  15. package/.claude/commands/memory/compact.md +383 -0
  16. package/.claude/commands/memory/docs-full-cli.md +471 -471
  17. package/.claude/commands/memory/docs-related-cli.md +386 -386
  18. package/.claude/commands/memory/docs.md +615 -615
  19. package/.claude/commands/memory/load.md +5 -5
  20. package/.claude/commands/memory/tech-research-rules.md +310 -0
  21. package/.claude/commands/memory/update-full.md +332 -332
  22. package/.claude/commands/memory/workflow-skill-memory.md +4 -4
  23. package/.claude/commands/task/create.md +151 -151
  24. package/.claude/commands/version.md +254 -254
  25. package/.claude/commands/workflow/brainstorm/api-designer.md +587 -585
  26. package/.claude/commands/workflow/brainstorm/artifacts.md +1 -0
  27. package/.claude/commands/workflow/brainstorm/auto-parallel.md +443 -443
  28. package/.claude/commands/workflow/brainstorm/data-architect.md +220 -220
  29. package/.claude/commands/workflow/brainstorm/product-manager.md +200 -200
  30. package/.claude/commands/workflow/brainstorm/product-owner.md +200 -200
  31. package/.claude/commands/workflow/brainstorm/scrum-master.md +200 -200
  32. package/.claude/commands/workflow/brainstorm/subject-matter-expert.md +200 -200
  33. package/.claude/commands/workflow/brainstorm/system-architect.md +389 -387
  34. package/.claude/commands/workflow/brainstorm/ui-designer.md +221 -221
  35. package/.claude/commands/workflow/brainstorm/ux-expert.md +221 -221
  36. package/.claude/commands/workflow/debug.md +321 -0
  37. package/.claude/commands/workflow/execute.md +13 -0
  38. package/.claude/commands/workflow/init.md +165 -164
  39. package/.claude/commands/workflow/lite-execute.md +119 -13
  40. package/.claude/commands/workflow/lite-fix.md +623 -621
  41. package/.claude/commands/workflow/lite-plan.md +610 -592
  42. package/.claude/commands/workflow/plan.md +5 -5
  43. package/.claude/commands/workflow/review-module-cycle.md +2 -0
  44. package/.claude/commands/workflow/review-session-cycle.md +2 -0
  45. package/.claude/commands/workflow/review.md +297 -291
  46. package/.claude/commands/workflow/session/complete.md +153 -500
  47. package/.claude/commands/workflow/session/list.md +95 -95
  48. package/.claude/commands/workflow/session/resume.md +60 -60
  49. package/.claude/commands/workflow/session/start.md +199 -199
  50. package/.claude/commands/workflow/tdd-plan.md +3 -3
  51. package/.claude/commands/workflow/tdd-verify.md +23 -9
  52. package/.claude/commands/workflow/test-cycle-execute.md +2 -0
  53. package/.claude/commands/workflow/test-fix-gen.md +699 -699
  54. package/.claude/commands/workflow/tools/conflict-resolution.md +104 -18
  55. package/.claude/commands/workflow/tools/context-gather.md +436 -434
  56. package/.claude/commands/workflow/tools/task-generate-agent.md +490 -291
  57. package/.claude/commands/workflow/tools/task-generate-tdd.md +18 -10
  58. package/.claude/commands/workflow/tools/test-concept-enhanced.md +2 -1
  59. package/.claude/commands/workflow/tools/test-context-gather.md +1 -0
  60. package/.claude/commands/workflow/tools/test-task-generate.md +1 -0
  61. package/.claude/commands/workflow/ui-design/import-from-code.md +9 -6
  62. package/.claude/skills/command-guide/SKILL.md +5 -5
  63. package/.claude/skills/command-guide/index/all-commands.json +1 -1
  64. package/.claude/skills/command-guide/index/by-category.json +1 -1
  65. package/.claude/skills/command-guide/index/by-use-case.json +1 -1
  66. package/.claude/skills/command-guide/reference/agents/action-planning-agent.md +857 -778
  67. package/.claude/skills/command-guide/reference/agents/cli-execution-agent.md +266 -269
  68. package/.claude/skills/command-guide/reference/agents/cli-explore-agent.md +2 -2
  69. package/.claude/skills/command-guide/reference/agents/cli-lite-planning-agent.md +142 -92
  70. package/.claude/skills/command-guide/reference/agents/cli-planning-agent.md +4 -4
  71. package/.claude/skills/command-guide/reference/agents/code-developer.md +7 -6
  72. package/.claude/skills/command-guide/reference/agents/conceptual-planning-agent.md +2 -2
  73. package/.claude/skills/command-guide/reference/agents/context-search-agent.md +31 -32
  74. package/.claude/skills/command-guide/reference/agents/doc-generator.md +4 -4
  75. package/.claude/skills/command-guide/reference/agents/memory-bridge.md +93 -93
  76. package/.claude/skills/command-guide/reference/agents/test-context-search-agent.md +8 -7
  77. package/.claude/skills/command-guide/reference/agents/test-fix-agent.md +7 -6
  78. package/.claude/skills/command-guide/reference/commands/memory/docs-full-cli.md +471 -471
  79. package/.claude/skills/command-guide/reference/commands/memory/docs-related-cli.md +386 -386
  80. package/.claude/skills/command-guide/reference/commands/memory/docs.md +17 -16
  81. package/.claude/skills/command-guide/reference/commands/memory/load.md +5 -5
  82. package/.claude/skills/command-guide/reference/commands/memory/tech-research.md +194 -357
  83. package/.claude/skills/command-guide/reference/commands/memory/update-full.md +332 -332
  84. package/.claude/skills/command-guide/reference/commands/memory/workflow-skill-memory.md +4 -4
  85. package/.claude/skills/command-guide/reference/commands/task/create.md +151 -151
  86. package/.claude/skills/command-guide/reference/commands/version.md +254 -254
  87. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/api-designer.md +585 -585
  88. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/auto-parallel.md +443 -443
  89. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/data-architect.md +220 -220
  90. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-manager.md +200 -200
  91. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-owner.md +200 -200
  92. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/scrum-master.md +200 -200
  93. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/subject-matter-expert.md +200 -200
  94. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/system-architect.md +387 -387
  95. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ui-designer.md +221 -221
  96. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ux-expert.md +221 -221
  97. package/.claude/skills/command-guide/reference/commands/workflow/execute.md +25 -20
  98. package/.claude/skills/command-guide/reference/commands/workflow/init.md +164 -164
  99. package/.claude/skills/command-guide/reference/commands/workflow/lite-execute.md +748 -686
  100. package/.claude/skills/command-guide/reference/commands/workflow/lite-fix.md +664 -621
  101. package/.claude/skills/command-guide/reference/commands/workflow/lite-plan.md +645 -592
  102. package/.claude/skills/command-guide/reference/commands/workflow/plan.md +5 -5
  103. package/.claude/skills/command-guide/reference/commands/workflow/review.md +25 -18
  104. package/.claude/skills/command-guide/reference/commands/workflow/session/complete.md +547 -500
  105. package/.claude/skills/command-guide/reference/commands/workflow/session/list.md +45 -27
  106. package/.claude/skills/command-guide/reference/commands/workflow/session/resume.md +35 -19
  107. package/.claude/skills/command-guide/reference/commands/workflow/session/start.md +90 -33
  108. package/.claude/skills/command-guide/reference/commands/workflow/tdd-plan.md +3 -3
  109. package/.claude/skills/command-guide/reference/commands/workflow/tdd-verify.md +23 -9
  110. package/.claude/skills/command-guide/reference/commands/workflow/test-fix-gen.md +699 -699
  111. package/.claude/skills/command-guide/reference/commands/workflow/tools/conflict-resolution.md +103 -17
  112. package/.claude/skills/command-guide/reference/commands/workflow/tools/context-gather.md +434 -434
  113. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-agent.md +487 -291
  114. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-tdd.md +17 -10
  115. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-concept-enhanced.md +1 -1
  116. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/import-from-code.md +6 -6
  117. package/.claude/workflows/chinese-response.md +38 -0
  118. package/.claude/workflows/cli-templates/prompts/rules/rule-api.txt +122 -0
  119. package/.claude/workflows/cli-templates/prompts/rules/rule-components.txt +122 -0
  120. package/.claude/workflows/cli-templates/prompts/rules/rule-config.txt +89 -0
  121. package/.claude/workflows/cli-templates/prompts/rules/rule-core.txt +60 -0
  122. package/.claude/workflows/cli-templates/prompts/rules/rule-patterns.txt +70 -0
  123. package/.claude/workflows/cli-templates/prompts/rules/rule-testing.txt +81 -0
  124. package/.claude/workflows/cli-templates/prompts/rules/tech-rules-agent-prompt.txt +89 -0
  125. package/.claude/workflows/cli-templates/prompts/workflow/gemini-solution-design.txt +131 -131
  126. package/.claude/workflows/cli-templates/prompts/workflow/skill-conflict-patterns.txt +5 -9
  127. package/.claude/workflows/cli-templates/prompts/workflow/skill-lessons-learned.txt +5 -9
  128. package/.claude/workflows/cli-templates/protocols/analysis-protocol.md +112 -0
  129. package/.claude/workflows/cli-templates/protocols/write-protocol.md +201 -0
  130. package/.claude/workflows/cli-templates/schemas/conflict-resolution-schema.json +137 -0
  131. package/.claude/workflows/cli-templates/schemas/debug-log-json-schema.json +127 -0
  132. package/.claude/workflows/cli-templates/schemas/fix-plan-json-schema.json +25 -0
  133. package/.claude/workflows/cli-templates/schemas/plan-json-schema.json +25 -0
  134. package/.claude/workflows/cli-tools-usage.md +526 -0
  135. package/{CLAUDE.md → .claude/workflows/coding-philosophy.md} +24 -45
  136. package/.claude/workflows/context-tools.md +84 -0
  137. package/.claude/workflows/file-modification.md +64 -0
  138. package/.claude/workflows/tool-strategy.md +216 -79
  139. package/.claude/workflows/windows-platform.md +16 -0
  140. package/.claude/workflows/workflow-architecture.md +942 -942
  141. package/.codex/AGENTS.md +63 -330
  142. package/.codex/prompts/debug.md +318 -0
  143. package/.codex/prompts/execute.md +273 -0
  144. package/.codex/prompts/lite-execute.md +164 -0
  145. package/.codex/prompts/lite-plan.md +469 -0
  146. package/.codex/prompts.zip +0 -0
  147. package/.gemini/GEMINI.md +25 -164
  148. package/.qwen/QWEN.md +0 -139
  149. package/README.md +29 -9
  150. package/ccw/README.md +30 -6
  151. package/ccw/bin/ccw-mcp.js +7 -0
  152. package/ccw/bin/ccw.js +9 -9
  153. package/ccw/package.json +65 -47
  154. package/ccw/src/.workflow/.cli-history/history.db +0 -0
  155. package/ccw/src/.workflow/.cli-history/history.db-shm +0 -0
  156. package/ccw/src/.workflow/.cli-history/history.db-wal +0 -0
  157. package/ccw/src/cli.ts +244 -0
  158. package/ccw/src/commands/cli.ts +740 -0
  159. package/ccw/src/commands/core-memory.ts +770 -0
  160. package/ccw/src/commands/hook.ts +315 -0
  161. package/ccw/src/commands/install.ts +519 -0
  162. package/ccw/src/commands/{list.js → list.ts} +1 -1
  163. package/ccw/src/commands/memory.ts +1090 -0
  164. package/ccw/src/commands/{serve.js → serve.ts} +14 -5
  165. package/ccw/src/commands/session-path-resolver.ts +372 -0
  166. package/ccw/src/commands/session.ts +1141 -0
  167. package/ccw/src/commands/{stop.js → stop.ts} +16 -6
  168. package/ccw/src/commands/tool.ts +201 -0
  169. package/ccw/src/commands/{uninstall.js → uninstall.ts} +89 -40
  170. package/ccw/src/commands/{upgrade.js → upgrade.ts} +68 -23
  171. package/ccw/src/commands/{view.js → view.ts} +22 -8
  172. package/ccw/src/config/storage-paths.ts +670 -0
  173. package/ccw/src/core/cache-manager.ts +294 -0
  174. package/ccw/src/core/claude-freshness.ts +319 -0
  175. package/ccw/src/core/core-memory-store.ts +1528 -0
  176. package/ccw/src/core/{dashboard-generator-patch.js → dashboard-generator-patch.ts} +18 -0
  177. package/ccw/src/core/{dashboard-generator.js → dashboard-generator.ts} +69 -12
  178. package/ccw/src/core/data-aggregator.ts +584 -0
  179. package/ccw/src/core/history-importer.ts +625 -0
  180. package/ccw/src/core/{lite-scanner.js → lite-scanner-complete.ts} +162 -66
  181. package/ccw/src/core/lite-scanner.ts +469 -0
  182. package/ccw/src/core/{manifest.js → manifest.ts} +104 -34
  183. package/ccw/src/core/memory-embedder-bridge.ts +262 -0
  184. package/ccw/src/core/memory-store.ts +978 -0
  185. package/ccw/src/core/routes/ccw-routes.ts +96 -0
  186. package/ccw/src/core/routes/claude-routes.ts +1183 -0
  187. package/ccw/src/core/routes/cli-routes.ts +561 -0
  188. package/ccw/src/core/routes/codexlens-routes.ts +806 -0
  189. package/ccw/src/core/routes/core-memory-routes.ts +605 -0
  190. package/ccw/src/core/routes/files-routes.ts +428 -0
  191. package/ccw/src/core/routes/graph-routes.md +164 -0
  192. package/ccw/src/core/routes/graph-routes.ts +626 -0
  193. package/ccw/src/core/routes/help-routes.ts +308 -0
  194. package/ccw/src/core/routes/hooks-routes.ts +405 -0
  195. package/ccw/src/core/routes/mcp-routes.ts +1271 -0
  196. package/ccw/src/core/routes/mcp-routes.ts.backup +550 -0
  197. package/ccw/src/core/routes/mcp-templates-db.ts +268 -0
  198. package/ccw/src/core/routes/memory-routes.ts +1206 -0
  199. package/ccw/src/core/routes/rules-routes.ts +526 -0
  200. package/ccw/src/core/routes/session-routes.ts +467 -0
  201. package/ccw/src/core/routes/skills-routes.ts +599 -0
  202. package/ccw/src/core/routes/status-routes.ts +57 -0
  203. package/ccw/src/core/routes/system-routes.ts +427 -0
  204. package/ccw/src/core/server.ts +431 -0
  205. package/ccw/src/core/session-clustering-service.ts +1258 -0
  206. package/ccw/src/core/session-scanner.ts +283 -0
  207. package/ccw/src/core/websocket.ts +190 -0
  208. package/ccw/src/{index.js → index.ts} +1 -0
  209. package/ccw/src/mcp-server/index.ts +186 -0
  210. package/ccw/src/templates/assets/css/github-dark.min.css +10 -0
  211. package/ccw/src/templates/assets/css/github.min.css +10 -0
  212. package/ccw/src/templates/assets/js/cytoscape.min.js +32 -0
  213. package/ccw/src/templates/assets/js/d3.min.js +2 -0
  214. package/ccw/src/templates/assets/js/highlight.min.js +1244 -0
  215. package/ccw/src/templates/assets/js/lucide.min.js +12 -0
  216. package/ccw/src/templates/assets/js/marked.min.js +69 -0
  217. package/ccw/src/templates/assets/js/tailwind.js +83 -0
  218. package/ccw/src/templates/dashboard-css/01-base.css +11 -0
  219. package/ccw/src/templates/dashboard-css/02-session.css +22 -0
  220. package/ccw/src/templates/dashboard-css/04-lite-tasks.css +10 -0
  221. package/ccw/src/templates/dashboard-css/06-cards.css +10 -4
  222. package/ccw/src/templates/dashboard-css/07-managers.css +1178 -7
  223. package/ccw/src/templates/dashboard-css/09-explorer.css +23 -12
  224. package/ccw/src/templates/dashboard-css/10-cli-status.css +337 -0
  225. package/ccw/src/templates/dashboard-css/11-cli-history.css +271 -0
  226. package/ccw/src/templates/dashboard-css/12-cli-legacy.css +796 -0
  227. package/ccw/src/templates/dashboard-css/13-cli-ccw.css +199 -0
  228. package/ccw/src/templates/dashboard-css/14-cli-modals.css +258 -0
  229. package/ccw/src/templates/dashboard-css/15-cli-endpoints.css +305 -0
  230. package/ccw/src/templates/dashboard-css/16-cli-session.css +241 -0
  231. package/ccw/src/templates/dashboard-css/17-cli-conversation.css +283 -0
  232. package/ccw/src/templates/dashboard-css/18-cli-settings.css +160 -0
  233. package/ccw/src/templates/dashboard-css/19-cli-native-session.css +496 -0
  234. package/ccw/src/templates/dashboard-css/20-cli-taskqueue.css +188 -0
  235. package/ccw/src/templates/dashboard-css/21-cli-toolmgmt.css +310 -0
  236. package/ccw/src/templates/dashboard-css/22-cli-semantic.css +240 -0
  237. package/ccw/src/templates/dashboard-css/23-memory.css +2390 -0
  238. package/ccw/src/templates/dashboard-css/24-prompt-history.css +1089 -0
  239. package/ccw/src/templates/dashboard-css/25-skills-rules.css +326 -0
  240. package/ccw/src/templates/dashboard-css/26-claude-manager.css +908 -0
  241. package/ccw/src/templates/dashboard-css/27-graph-explorer.css +1678 -0
  242. package/ccw/src/templates/dashboard-css/28-mcp-manager.css +748 -0
  243. package/ccw/src/templates/dashboard-css/29-help.css +264 -0
  244. package/ccw/src/templates/dashboard-css/30-core-memory.css +1700 -0
  245. package/ccw/src/templates/dashboard-js/api.js +162 -142
  246. package/ccw/src/templates/dashboard-js/components/carousel.js +4 -4
  247. package/ccw/src/templates/dashboard-js/components/cli-history.js +876 -0
  248. package/ccw/src/templates/dashboard-js/components/cli-status.js +978 -0
  249. package/ccw/src/templates/dashboard-js/components/global-notifications.js +508 -219
  250. package/ccw/src/templates/dashboard-js/components/hook-manager.js +1277 -282
  251. package/ccw/src/templates/dashboard-js/components/index-manager.js +302 -0
  252. package/ccw/src/templates/dashboard-js/components/mcp-manager.js +718 -27
  253. package/ccw/src/templates/dashboard-js/components/modals.js +66 -0
  254. package/ccw/src/templates/dashboard-js/components/navigation.js +80 -12
  255. package/ccw/src/templates/dashboard-js/components/notifications.js +758 -194
  256. package/ccw/src/templates/dashboard-js/components/storage-manager.js +478 -0
  257. package/ccw/src/templates/dashboard-js/components/tabs-other.js +157 -6
  258. package/ccw/src/templates/dashboard-js/components/task-queue-sidebar.js +716 -0
  259. package/ccw/src/templates/dashboard-js/help-i18n.js +272 -0
  260. package/ccw/src/templates/dashboard-js/i18n.js +2807 -0
  261. package/ccw/src/templates/dashboard-js/main.js +15 -0
  262. package/ccw/src/templates/dashboard-js/state.js +243 -42
  263. package/ccw/src/templates/dashboard-js/utils.js +47 -1
  264. package/ccw/src/templates/dashboard-js/views/claude-manager.js +912 -0
  265. package/ccw/src/templates/dashboard-js/views/cli-manager.js +2272 -0
  266. package/ccw/src/templates/dashboard-js/views/codexlens-manager.js +964 -0
  267. package/ccw/src/templates/dashboard-js/views/core-memory-clusters.js +503 -0
  268. package/ccw/src/templates/dashboard-js/views/core-memory.js +782 -0
  269. package/ccw/src/templates/dashboard-js/views/explorer.js +888 -852
  270. package/ccw/src/templates/dashboard-js/views/graph-explorer.js +1157 -0
  271. package/ccw/src/templates/dashboard-js/views/help.js +856 -0
  272. package/ccw/src/templates/dashboard-js/views/history.js +337 -0
  273. package/ccw/src/templates/dashboard-js/views/home.js +61 -15
  274. package/ccw/src/templates/dashboard-js/views/hook-manager.js +311 -43
  275. package/ccw/src/templates/dashboard-js/views/lite-tasks.js +204 -28
  276. package/ccw/src/templates/dashboard-js/views/mcp-manager.js +2187 -411
  277. package/ccw/src/templates/dashboard-js/views/mcp-manager.js.backup +1729 -0
  278. package/ccw/src/templates/dashboard-js/views/mcp-manager.js.new +928 -0
  279. package/ccw/src/templates/dashboard-js/views/memory.js +1221 -0
  280. package/ccw/src/templates/dashboard-js/views/prompt-history.js +713 -0
  281. package/ccw/src/templates/dashboard-js/views/rules-manager.js +828 -0
  282. package/ccw/src/templates/dashboard-js/views/session-detail.js +54 -53
  283. package/ccw/src/templates/dashboard-js/views/skills-manager.js +819 -0
  284. package/ccw/src/templates/dashboard.html +185 -85
  285. package/ccw/src/templates/hooks-config-example.json +60 -0
  286. package/ccw/src/tools/classify-folders.ts +245 -0
  287. package/ccw/src/tools/cli-config-manager.ts +268 -0
  288. package/ccw/src/tools/cli-executor.ts +2014 -0
  289. package/ccw/src/tools/cli-history-store.ts +1195 -0
  290. package/ccw/src/tools/codex-lens.ts +1141 -0
  291. package/ccw/src/tools/{convert-tokens-to-css.js → convert-tokens-to-css.ts} +73 -23
  292. package/ccw/src/tools/core-memory.ts +444 -0
  293. package/ccw/src/tools/detect-changed-modules.ts +325 -0
  294. package/ccw/src/tools/{discover-design-files.js → discover-design-files.ts} +74 -24
  295. package/ccw/src/tools/edit-file.ts +568 -0
  296. package/ccw/src/tools/{generate-module-docs.js → generate-module-docs.ts} +207 -185
  297. package/ccw/src/tools/{get-modules-by-depth.js → get-modules-by-depth.ts} +120 -79
  298. package/ccw/src/tools/index.ts +370 -0
  299. package/ccw/src/tools/native-session-discovery.ts +795 -0
  300. package/ccw/src/tools/notifier.ts +129 -0
  301. package/ccw/src/tools/read-file.ts +410 -0
  302. package/ccw/src/tools/resume-strategy.ts +345 -0
  303. package/ccw/src/tools/session-content-parser.ts +619 -0
  304. package/ccw/src/tools/session-manager.ts +1026 -0
  305. package/ccw/src/tools/smart-context.ts +228 -0
  306. package/ccw/src/tools/smart-search.ts +2065 -0
  307. package/ccw/src/tools/smart-search.ts.backup +1233 -0
  308. package/ccw/src/tools/storage-manager.ts +455 -0
  309. package/ccw/src/tools/write-file.ts +222 -0
  310. package/ccw/src/types/config.ts +11 -0
  311. package/ccw/src/types/index.ts +3 -0
  312. package/ccw/src/types/session.ts +25 -0
  313. package/ccw/src/types/tool.ts +41 -0
  314. package/ccw/src/utils/{browser-launcher.js → browser-launcher.ts} +10 -8
  315. package/ccw/src/utils/file-utils.ts +48 -0
  316. package/ccw/src/utils/{path-resolver.js → path-resolver.ts} +114 -78
  317. package/ccw/src/utils/path-validator.ts +153 -0
  318. package/ccw/src/utils/{ui.js → ui.ts} +32 -25
  319. package/codex-lens/pyproject.toml +48 -0
  320. package/codex-lens/src/codexlens/.workflow/.cli-history/history.db +0 -0
  321. package/codex-lens/src/codexlens/__init__.py +28 -0
  322. package/codex-lens/src/codexlens/__main__.py +14 -0
  323. package/codex-lens/src/codexlens/__pycache__/__init__.cpython-313.pyc +0 -0
  324. package/codex-lens/src/codexlens/__pycache__/__main__.cpython-313.pyc +0 -0
  325. package/codex-lens/src/codexlens/__pycache__/config.cpython-313.pyc +0 -0
  326. package/codex-lens/src/codexlens/__pycache__/entities.cpython-313.pyc +0 -0
  327. package/codex-lens/src/codexlens/__pycache__/errors.cpython-313.pyc +0 -0
  328. package/codex-lens/src/codexlens/cli/__init__.py +27 -0
  329. package/codex-lens/src/codexlens/cli/__pycache__/__init__.cpython-313.pyc +0 -0
  330. package/codex-lens/src/codexlens/cli/__pycache__/commands.cpython-313.pyc +0 -0
  331. package/codex-lens/src/codexlens/cli/__pycache__/embedding_manager.cpython-313.pyc +0 -0
  332. package/codex-lens/src/codexlens/cli/__pycache__/model_manager.cpython-313.pyc +0 -0
  333. package/codex-lens/src/codexlens/cli/__pycache__/output.cpython-313.pyc +0 -0
  334. package/codex-lens/src/codexlens/cli/commands.py +1931 -0
  335. package/codex-lens/src/codexlens/cli/embedding_manager.py +620 -0
  336. package/codex-lens/src/codexlens/cli/model_manager.py +289 -0
  337. package/codex-lens/src/codexlens/cli/output.py +124 -0
  338. package/codex-lens/src/codexlens/config.py +201 -0
  339. package/codex-lens/src/codexlens/entities.py +121 -0
  340. package/codex-lens/src/codexlens/errors.py +55 -0
  341. package/codex-lens/src/codexlens/indexing/README.md +77 -0
  342. package/codex-lens/src/codexlens/indexing/__init__.py +4 -0
  343. package/codex-lens/src/codexlens/indexing/__pycache__/__init__.cpython-313.pyc +0 -0
  344. package/codex-lens/src/codexlens/indexing/__pycache__/symbol_extractor.cpython-313.pyc +0 -0
  345. package/codex-lens/src/codexlens/indexing/symbol_extractor.py +243 -0
  346. package/codex-lens/src/codexlens/parsers/__init__.py +8 -0
  347. package/codex-lens/src/codexlens/parsers/__pycache__/__init__.cpython-313.pyc +0 -0
  348. package/codex-lens/src/codexlens/parsers/__pycache__/encoding.cpython-313.pyc +0 -0
  349. package/codex-lens/src/codexlens/parsers/__pycache__/factory.cpython-313.pyc +0 -0
  350. package/codex-lens/src/codexlens/parsers/__pycache__/tokenizer.cpython-313.pyc +0 -0
  351. package/codex-lens/src/codexlens/parsers/__pycache__/treesitter_parser.cpython-313.pyc +0 -0
  352. package/codex-lens/src/codexlens/parsers/encoding.py +202 -0
  353. package/codex-lens/src/codexlens/parsers/factory.py +256 -0
  354. package/codex-lens/src/codexlens/parsers/tokenizer.py +98 -0
  355. package/codex-lens/src/codexlens/parsers/treesitter_parser.py +335 -0
  356. package/codex-lens/src/codexlens/search/__init__.py +15 -0
  357. package/codex-lens/src/codexlens/search/__pycache__/__init__.cpython-313.pyc +0 -0
  358. package/codex-lens/src/codexlens/search/__pycache__/chain_search.cpython-313.pyc +0 -0
  359. package/codex-lens/src/codexlens/search/__pycache__/enrichment.cpython-313.pyc +0 -0
  360. package/codex-lens/src/codexlens/search/__pycache__/hybrid_search.cpython-313.pyc +0 -0
  361. package/codex-lens/src/codexlens/search/__pycache__/query_parser.cpython-313.pyc +0 -0
  362. package/codex-lens/src/codexlens/search/__pycache__/ranking.cpython-313.pyc +0 -0
  363. package/codex-lens/src/codexlens/search/chain_search.py +647 -0
  364. package/codex-lens/src/codexlens/search/enrichment.py +150 -0
  365. package/codex-lens/src/codexlens/search/hybrid_search.py +313 -0
  366. package/codex-lens/src/codexlens/search/query_parser.py +242 -0
  367. package/codex-lens/src/codexlens/search/ranking.py +274 -0
  368. package/codex-lens/src/codexlens/semantic/__init__.py +39 -0
  369. package/codex-lens/src/codexlens/semantic/__pycache__/__init__.cpython-313.pyc +0 -0
  370. package/codex-lens/src/codexlens/semantic/__pycache__/ann_index.cpython-313.pyc +0 -0
  371. package/codex-lens/src/codexlens/semantic/__pycache__/chunker.cpython-313.pyc +0 -0
  372. package/codex-lens/src/codexlens/semantic/__pycache__/code_extractor.cpython-313.pyc +0 -0
  373. package/codex-lens/src/codexlens/semantic/__pycache__/embedder.cpython-313.pyc +0 -0
  374. package/codex-lens/src/codexlens/semantic/__pycache__/graph_analyzer.cpython-313.pyc +0 -0
  375. package/codex-lens/src/codexlens/semantic/__pycache__/llm_enhancer.cpython-313.pyc +0 -0
  376. package/codex-lens/src/codexlens/semantic/__pycache__/vector_store.cpython-313.pyc +0 -0
  377. package/codex-lens/src/codexlens/semantic/ann_index.py +414 -0
  378. package/codex-lens/src/codexlens/semantic/chunker.py +448 -0
  379. package/codex-lens/src/codexlens/semantic/code_extractor.py +274 -0
  380. package/codex-lens/src/codexlens/semantic/embedder.py +185 -0
  381. package/codex-lens/src/codexlens/semantic/vector_store.py +955 -0
  382. package/codex-lens/src/codexlens/storage/__init__.py +29 -0
  383. package/codex-lens/src/codexlens/storage/__pycache__/__init__.cpython-313.pyc +0 -0
  384. package/codex-lens/src/codexlens/storage/__pycache__/dir_index.cpython-313.pyc +0 -0
  385. package/codex-lens/src/codexlens/storage/__pycache__/file_cache.cpython-313.pyc +0 -0
  386. package/codex-lens/src/codexlens/storage/__pycache__/index_tree.cpython-313.pyc +0 -0
  387. package/codex-lens/src/codexlens/storage/__pycache__/migration_manager.cpython-313.pyc +0 -0
  388. package/codex-lens/src/codexlens/storage/__pycache__/path_mapper.cpython-313.pyc +0 -0
  389. package/codex-lens/src/codexlens/storage/__pycache__/registry.cpython-313.pyc +0 -0
  390. package/codex-lens/src/codexlens/storage/__pycache__/sqlite_store.cpython-313.pyc +0 -0
  391. package/codex-lens/src/codexlens/storage/__pycache__/sqlite_utils.cpython-313.pyc +0 -0
  392. package/codex-lens/src/codexlens/storage/dir_index.py +1850 -0
  393. package/codex-lens/src/codexlens/storage/file_cache.py +32 -0
  394. package/codex-lens/src/codexlens/storage/index_tree.py +776 -0
  395. package/codex-lens/src/codexlens/storage/migration_manager.py +154 -0
  396. package/codex-lens/src/codexlens/storage/migrations/__init__.py +1 -0
  397. package/codex-lens/src/codexlens/storage/migrations/__pycache__/__init__.cpython-313.pyc +0 -0
  398. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_001_normalize_keywords.cpython-313.pyc +0 -0
  399. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_002_add_token_metadata.cpython-313.pyc +0 -0
  400. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_003_code_relationships.cpython-313.pyc +0 -0
  401. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_004_dual_fts.cpython-313.pyc +0 -0
  402. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_005_cleanup_unused_fields.cpython-313.pyc +0 -0
  403. package/codex-lens/src/codexlens/storage/migrations/migration_001_normalize_keywords.py +123 -0
  404. package/codex-lens/src/codexlens/storage/migrations/migration_002_add_token_metadata.py +48 -0
  405. package/codex-lens/src/codexlens/storage/migrations/migration_004_dual_fts.py +232 -0
  406. package/codex-lens/src/codexlens/storage/migrations/migration_005_cleanup_unused_fields.py +196 -0
  407. package/codex-lens/src/codexlens/storage/path_mapper.py +274 -0
  408. package/codex-lens/src/codexlens/storage/registry.py +670 -0
  409. package/codex-lens/src/codexlens/storage/sqlite_store.py +576 -0
  410. package/codex-lens/src/codexlens/storage/sqlite_utils.py +64 -0
  411. package/package.json +4 -1
  412. package/.claude/commands/memory/tech-research.md +0 -477
  413. package/.claude/scripts/classify-folders.sh +0 -39
  414. package/.claude/scripts/convert_tokens_to_css.sh +0 -229
  415. package/.claude/scripts/detect_changed_modules.sh +0 -161
  416. package/.claude/scripts/discover-design-files.sh +0 -87
  417. package/.claude/scripts/extract-animations.js +0 -243
  418. package/.claude/scripts/extract-computed-styles.js +0 -118
  419. package/.claude/scripts/extract-layout-structure.js +0 -411
  420. package/.claude/scripts/generate_module_docs.sh +0 -717
  421. package/.claude/scripts/get_modules_by_depth.sh +0 -170
  422. package/.claude/scripts/ui-generate-preview.sh +0 -395
  423. package/.claude/scripts/ui-instantiate-prototypes.sh +0 -815
  424. package/.claude/scripts/update_module_claude.sh +0 -337
  425. package/.claude/workflows/context-search-strategy.md +0 -77
  426. package/.claude/workflows/intelligent-tools-strategy.md +0 -662
  427. package/ccw/src/cli.js +0 -119
  428. package/ccw/src/commands/install.js +0 -324
  429. package/ccw/src/commands/tool.js +0 -138
  430. package/ccw/src/core/data-aggregator.js +0 -409
  431. package/ccw/src/core/server.js +0 -2063
  432. package/ccw/src/core/session-scanner.js +0 -235
  433. package/ccw/src/tools/classify-folders.js +0 -204
  434. package/ccw/src/tools/detect-changed-modules.js +0 -288
  435. package/ccw/src/tools/edit-file.js +0 -266
  436. package/ccw/src/tools/index.js +0 -176
  437. package/ccw/src/utils/file-utils.js +0 -48
@@ -0,0 +1,619 @@
1
+ /**
2
+ * Session Content Parser - Parses native CLI tool session files
3
+ * Supports Gemini/Qwen JSON and Codex JSONL formats
4
+ */
5
+
6
+ import { readFileSync, existsSync } from 'fs';
7
+
8
+ // Standardized conversation turn
9
+ export interface ParsedTurn {
10
+ turnNumber: number;
11
+ timestamp: string;
12
+ role: 'user' | 'assistant';
13
+ content: string;
14
+ thoughts?: string[]; // Assistant reasoning/thoughts
15
+ toolCalls?: ToolCallInfo[]; // Tool calls made
16
+ tokens?: TokenInfo; // Token usage
17
+ }
18
+
19
+ export interface ToolCallInfo {
20
+ name: string;
21
+ arguments?: string;
22
+ output?: string;
23
+ }
24
+
25
+ export interface TokenInfo {
26
+ input?: number;
27
+ output?: number;
28
+ cached?: number;
29
+ total?: number;
30
+ }
31
+
32
+ // Full parsed session
33
+ export interface ParsedSession {
34
+ sessionId: string;
35
+ tool: string;
36
+ projectHash?: string;
37
+ workingDir?: string;
38
+ startTime: string;
39
+ lastUpdated: string;
40
+ turns: ParsedTurn[];
41
+ totalTokens?: TokenInfo;
42
+ model?: string;
43
+ }
44
+
45
+ // Gemini/Qwen session file structure
46
+ interface GeminiQwenSession {
47
+ sessionId: string;
48
+ projectHash: string;
49
+ startTime: string;
50
+ lastUpdated: string;
51
+ messages: GeminiQwenMessage[];
52
+ }
53
+
54
+ interface GeminiQwenMessage {
55
+ id: string;
56
+ timestamp: string;
57
+ type: 'user' | 'gemini' | 'qwen';
58
+ content: string;
59
+ thoughts?: Array<{ subject: string; description: string; timestamp: string }>;
60
+ tokens?: {
61
+ input: number;
62
+ output: number;
63
+ cached?: number;
64
+ thoughts?: number;
65
+ tool?: number;
66
+ total: number;
67
+ };
68
+ model?: string;
69
+ }
70
+
71
+ // Codex JSONL line types
72
+ interface CodexSessionMeta {
73
+ timestamp: string;
74
+ type: 'session_meta';
75
+ payload: {
76
+ id: string;
77
+ timestamp: string;
78
+ cwd: string;
79
+ cli_version?: string;
80
+ model_provider?: string;
81
+ };
82
+ }
83
+
84
+ interface CodexResponseItem {
85
+ timestamp: string;
86
+ type: 'response_item';
87
+ payload: {
88
+ type: string;
89
+ role?: string;
90
+ content?: Array<{ type: string; text?: string }>;
91
+ name?: string;
92
+ arguments?: string;
93
+ call_id?: string;
94
+ output?: string;
95
+ summary?: string[];
96
+ };
97
+ }
98
+
99
+ interface CodexEventMsg {
100
+ timestamp: string;
101
+ type: 'event_msg';
102
+ payload: {
103
+ type: string;
104
+ info?: {
105
+ total_token_usage?: {
106
+ input_tokens: number;
107
+ output_tokens: number;
108
+ total_tokens: number;
109
+ };
110
+ };
111
+ };
112
+ }
113
+
114
+ type CodexLine = CodexSessionMeta | CodexResponseItem | CodexEventMsg;
115
+
116
+ // Qwen new JSONL format
117
+ interface QwenJSONLEntry {
118
+ uuid: string;
119
+ parentUuid: string | null;
120
+ sessionId: string;
121
+ timestamp: string;
122
+ type: 'user' | 'assistant' | 'system';
123
+ cwd?: string;
124
+ version?: string;
125
+ gitBranch?: string;
126
+ model?: string;
127
+ subtype?: string; // e.g., 'ui_telemetry'
128
+ message?: {
129
+ role: string;
130
+ parts: Array<{ text?: string }>;
131
+ };
132
+ usageMetadata?: {
133
+ promptTokenCount: number;
134
+ candidatesTokenCount: number;
135
+ thoughtsTokenCount?: number;
136
+ totalTokenCount: number;
137
+ cachedContentTokenCount?: number;
138
+ };
139
+ systemPayload?: {
140
+ uiEvent?: {
141
+ model?: string;
142
+ input_token_count?: number;
143
+ output_token_count?: number;
144
+ cached_content_token_count?: number;
145
+ thoughts_token_count?: number;
146
+ tool_token_count?: number;
147
+ total_token_count?: number;
148
+ };
149
+ };
150
+ }
151
+
152
+ /**
153
+ * Detect if content is JSONL or JSON format
154
+ */
155
+ function isJSONL(content: string): boolean {
156
+ const trimmed = content.trim();
157
+ // JSON starts with { or [, but JSONL has multiple lines each starting with {
158
+ if (trimmed.startsWith('[')) return false; // JSON array
159
+ if (!trimmed.startsWith('{')) return false;
160
+
161
+ // Check if first line is complete JSON
162
+ const firstLine = trimmed.split('\n')[0];
163
+ try {
164
+ JSON.parse(firstLine);
165
+ // If multiple lines each parse as JSON, it's JSONL
166
+ const lines = trimmed.split('\n').filter(l => l.trim());
167
+ if (lines.length > 1) {
168
+ // Try to parse second line
169
+ JSON.parse(lines[1]);
170
+ return true; // Multiple lines of JSON = JSONL
171
+ }
172
+ return false; // Single JSON object
173
+ } catch {
174
+ return false;
175
+ }
176
+ }
177
+
178
+ /**
179
+ * Parse a native session file and return standardized conversation data
180
+ */
181
+ export function parseSessionFile(filePath: string, tool: string): ParsedSession | null {
182
+ if (!existsSync(filePath)) {
183
+ return null;
184
+ }
185
+
186
+ try {
187
+ const content = readFileSync(filePath, 'utf8');
188
+
189
+ switch (tool) {
190
+ case 'gemini':
191
+ return parseGeminiQwenSession(content, tool);
192
+ case 'qwen':
193
+ // Qwen can be either JSON (legacy) or JSONL (new format)
194
+ if (isJSONL(content)) {
195
+ return parseQwenJSONLSession(content);
196
+ }
197
+ return parseGeminiQwenSession(content, tool);
198
+ case 'codex':
199
+ return parseCodexSession(content);
200
+ default:
201
+ return null;
202
+ }
203
+ } catch (error) {
204
+ console.error(`Failed to parse session file ${filePath}:`, error);
205
+ return null;
206
+ }
207
+ }
208
+
209
+ /**
210
+ * Parse Gemini or Qwen JSON session file
211
+ */
212
+ function parseGeminiQwenSession(content: string, tool: string): ParsedSession {
213
+ const session: GeminiQwenSession = JSON.parse(content);
214
+ const turns: ParsedTurn[] = [];
215
+ let turnNumber = 0;
216
+ let totalTokens: TokenInfo = { input: 0, output: 0, cached: 0, total: 0 };
217
+ let model: string | undefined;
218
+
219
+ for (const msg of session.messages) {
220
+ if (msg.type === 'user') {
221
+ turnNumber++;
222
+ turns.push({
223
+ turnNumber,
224
+ timestamp: msg.timestamp,
225
+ role: 'user',
226
+ content: msg.content
227
+ });
228
+ } else if (msg.type === 'gemini' || msg.type === 'qwen') {
229
+ // Find the corresponding user turn
230
+ const userTurn = turns.find(t => t.turnNumber === turnNumber && t.role === 'user');
231
+
232
+ // Extract thoughts
233
+ const thoughts = msg.thoughts?.map(t => `${t.subject}: ${t.description}`) || [];
234
+
235
+ turns.push({
236
+ turnNumber,
237
+ timestamp: msg.timestamp,
238
+ role: 'assistant',
239
+ content: msg.content,
240
+ thoughts: thoughts.length > 0 ? thoughts : undefined,
241
+ tokens: msg.tokens ? {
242
+ input: msg.tokens.input,
243
+ output: msg.tokens.output,
244
+ cached: msg.tokens.cached,
245
+ total: msg.tokens.total
246
+ } : undefined
247
+ });
248
+
249
+ // Accumulate tokens
250
+ if (msg.tokens) {
251
+ totalTokens.input = (totalTokens.input || 0) + msg.tokens.input;
252
+ totalTokens.output = (totalTokens.output || 0) + msg.tokens.output;
253
+ totalTokens.cached = (totalTokens.cached || 0) + (msg.tokens.cached || 0);
254
+ totalTokens.total = (totalTokens.total || 0) + msg.tokens.total;
255
+ }
256
+
257
+ if (msg.model) {
258
+ model = msg.model;
259
+ }
260
+ }
261
+ }
262
+
263
+ return {
264
+ sessionId: session.sessionId,
265
+ tool,
266
+ projectHash: session.projectHash,
267
+ startTime: session.startTime,
268
+ lastUpdated: session.lastUpdated,
269
+ turns,
270
+ totalTokens,
271
+ model
272
+ };
273
+ }
274
+
275
+ /**
276
+ * Parse Qwen JSONL session file (new format)
277
+ */
278
+ function parseQwenJSONLSession(content: string): ParsedSession {
279
+ const lines = content.split('\n').filter(l => l.trim());
280
+ const turns: ParsedTurn[] = [];
281
+
282
+ let sessionId = '';
283
+ let workingDir = '';
284
+ let startTime = '';
285
+ let lastUpdated = '';
286
+ let model: string | undefined;
287
+ let totalTokens: TokenInfo = { input: 0, output: 0, cached: 0, total: 0 };
288
+ let currentTurn = 0;
289
+
290
+ for (const line of lines) {
291
+ try {
292
+ const entry: QwenJSONLEntry = JSON.parse(line);
293
+ lastUpdated = entry.timestamp;
294
+
295
+ // Get session info from first entry
296
+ if (!sessionId && entry.sessionId) {
297
+ sessionId = entry.sessionId;
298
+ }
299
+ if (!workingDir && entry.cwd) {
300
+ workingDir = entry.cwd;
301
+ }
302
+ if (!startTime) {
303
+ startTime = entry.timestamp;
304
+ }
305
+
306
+ if (entry.type === 'user' && entry.message) {
307
+ // User message
308
+ currentTurn++;
309
+ const textContent = entry.message.parts
310
+ .map(p => p.text || '')
311
+ .filter(t => t)
312
+ .join('\n');
313
+
314
+ turns.push({
315
+ turnNumber: currentTurn,
316
+ timestamp: entry.timestamp,
317
+ role: 'user',
318
+ content: textContent
319
+ });
320
+ } else if (entry.type === 'assistant' && entry.message) {
321
+ // Assistant response
322
+ const textContent = entry.message.parts
323
+ .map(p => p.text || '')
324
+ .filter(t => t)
325
+ .join('\n');
326
+
327
+ const tokens = entry.usageMetadata ? {
328
+ input: entry.usageMetadata.promptTokenCount,
329
+ output: entry.usageMetadata.candidatesTokenCount,
330
+ cached: entry.usageMetadata.cachedContentTokenCount || 0,
331
+ total: entry.usageMetadata.totalTokenCount
332
+ } : undefined;
333
+
334
+ turns.push({
335
+ turnNumber: currentTurn,
336
+ timestamp: entry.timestamp,
337
+ role: 'assistant',
338
+ content: textContent,
339
+ tokens
340
+ });
341
+
342
+ // Accumulate tokens
343
+ if (tokens) {
344
+ totalTokens.input = (totalTokens.input || 0) + tokens.input;
345
+ totalTokens.output = (totalTokens.output || 0) + tokens.output;
346
+ totalTokens.cached = (totalTokens.cached || 0) + (tokens.cached || 0);
347
+ totalTokens.total = (totalTokens.total || 0) + tokens.total;
348
+ }
349
+
350
+ if (entry.model) {
351
+ model = entry.model;
352
+ }
353
+ } else if (entry.type === 'system' && entry.subtype === 'ui_telemetry') {
354
+ // Telemetry event - extract model info if available
355
+ if (entry.systemPayload?.uiEvent?.model && !model) {
356
+ model = entry.systemPayload.uiEvent.model;
357
+ }
358
+ }
359
+ } catch {
360
+ // Skip invalid lines
361
+ }
362
+ }
363
+
364
+ return {
365
+ sessionId,
366
+ tool: 'qwen',
367
+ workingDir,
368
+ startTime,
369
+ lastUpdated,
370
+ turns,
371
+ totalTokens,
372
+ model
373
+ };
374
+ }
375
+
376
+ /**
377
+ * Parse Codex JSONL session file
378
+ */
379
+ function parseCodexSession(content: string): ParsedSession {
380
+ const lines = content.split('\n').filter(l => l.trim());
381
+ const turns: ParsedTurn[] = [];
382
+
383
+ let sessionId = '';
384
+ let workingDir = '';
385
+ let startTime = '';
386
+ let lastUpdated = '';
387
+ let model: string | undefined;
388
+ let totalTokens: TokenInfo = { input: 0, output: 0, total: 0 };
389
+
390
+ let currentTurn = 0;
391
+ let currentToolCalls: ToolCallInfo[] = [];
392
+ let pendingToolCalls: Map<string, ToolCallInfo> = new Map();
393
+
394
+ for (const line of lines) {
395
+ try {
396
+ const parsed: CodexLine = JSON.parse(line);
397
+ lastUpdated = parsed.timestamp;
398
+
399
+ if (parsed.type === 'session_meta') {
400
+ const meta = parsed as CodexSessionMeta;
401
+ sessionId = meta.payload.id;
402
+ workingDir = meta.payload.cwd;
403
+ startTime = meta.payload.timestamp;
404
+ } else if (parsed.type === 'response_item') {
405
+ const item = parsed as CodexResponseItem;
406
+
407
+ if (item.payload.type === 'message' && item.payload.role === 'user') {
408
+ // User message
409
+ currentTurn++;
410
+ const textContent = item.payload.content
411
+ ?.filter(c => c.type === 'input_text')
412
+ .map(c => c.text)
413
+ .join('\n') || '';
414
+
415
+ turns.push({
416
+ turnNumber: currentTurn,
417
+ timestamp: parsed.timestamp,
418
+ role: 'user',
419
+ content: textContent
420
+ });
421
+
422
+ // Reset tool calls for new turn
423
+ currentToolCalls = [];
424
+ pendingToolCalls.clear();
425
+ } else if (item.payload.type === 'function_call') {
426
+ // Tool call
427
+ const toolCall: ToolCallInfo = {
428
+ name: item.payload.name || 'unknown',
429
+ arguments: item.payload.arguments
430
+ };
431
+ if (item.payload.call_id) {
432
+ pendingToolCalls.set(item.payload.call_id, toolCall);
433
+ }
434
+ currentToolCalls.push(toolCall);
435
+ } else if (item.payload.type === 'function_call_output') {
436
+ // Tool result
437
+ if (item.payload.call_id && pendingToolCalls.has(item.payload.call_id)) {
438
+ const toolCall = pendingToolCalls.get(item.payload.call_id)!;
439
+ toolCall.output = item.payload.output;
440
+ }
441
+ } else if (item.payload.type === 'message' && item.payload.role === 'assistant') {
442
+ // Assistant message (final response)
443
+ const textContent = item.payload.content
444
+ ?.filter(c => c.type === 'output_text' || c.type === 'text')
445
+ .map(c => c.text)
446
+ .join('\n') || '';
447
+
448
+ if (textContent) {
449
+ turns.push({
450
+ turnNumber: currentTurn,
451
+ timestamp: parsed.timestamp,
452
+ role: 'assistant',
453
+ content: textContent,
454
+ toolCalls: currentToolCalls.length > 0 ? [...currentToolCalls] : undefined
455
+ });
456
+ }
457
+ } else if (item.payload.type === 'reasoning') {
458
+ // Reasoning (may be encrypted, extract summary if available)
459
+ const summary = item.payload.summary;
460
+ if (summary && summary.length > 0) {
461
+ // Add reasoning summary to the last assistant turn
462
+ const lastAssistantTurn = turns.findLast(t => t.role === 'assistant');
463
+ if (lastAssistantTurn) {
464
+ lastAssistantTurn.thoughts = summary;
465
+ }
466
+ }
467
+ }
468
+ } else if (parsed.type === 'event_msg') {
469
+ const event = parsed as CodexEventMsg;
470
+ if (event.payload.type === 'token_count' && event.payload.info?.total_token_usage) {
471
+ const usage = event.payload.info.total_token_usage;
472
+ totalTokens = {
473
+ input: usage.input_tokens,
474
+ output: usage.output_tokens,
475
+ total: usage.total_tokens
476
+ };
477
+ }
478
+ }
479
+ } catch {
480
+ // Skip invalid lines
481
+ }
482
+ }
483
+
484
+ // If we have tool calls but no final assistant message, create one
485
+ if (currentToolCalls.length > 0) {
486
+ const lastTurn = turns[turns.length - 1];
487
+ if (lastTurn && lastTurn.role === 'user') {
488
+ // Find if there's already an assistant response for this turn
489
+ const hasAssistant = turns.some(t => t.turnNumber === currentTurn && t.role === 'assistant');
490
+ if (!hasAssistant) {
491
+ turns.push({
492
+ turnNumber: currentTurn,
493
+ timestamp: lastUpdated,
494
+ role: 'assistant',
495
+ content: '[Tool execution completed]',
496
+ toolCalls: currentToolCalls
497
+ });
498
+ }
499
+ }
500
+ }
501
+
502
+ return {
503
+ sessionId,
504
+ tool: 'codex',
505
+ workingDir,
506
+ startTime,
507
+ lastUpdated,
508
+ turns,
509
+ totalTokens,
510
+ model
511
+ };
512
+ }
513
+
514
+ /**
515
+ * Get conversation as formatted text
516
+ */
517
+ export function formatConversation(session: ParsedSession, options?: {
518
+ includeThoughts?: boolean;
519
+ includeToolCalls?: boolean;
520
+ includeTokens?: boolean;
521
+ maxContentLength?: number;
522
+ }): string {
523
+ const {
524
+ includeThoughts = false,
525
+ includeToolCalls = false,
526
+ includeTokens = false,
527
+ maxContentLength = 4096
528
+ } = options || {};
529
+
530
+ const lines: string[] = [];
531
+
532
+ lines.push(`=== Session: ${session.sessionId} ===`);
533
+ lines.push(`Tool: ${session.tool}`);
534
+ lines.push(`Started: ${session.startTime}`);
535
+ lines.push(`Updated: ${session.lastUpdated}`);
536
+ if (session.model) {
537
+ lines.push(`Model: ${session.model}`);
538
+ }
539
+ lines.push('');
540
+
541
+ for (const turn of session.turns) {
542
+ const roleLabel = turn.role === 'user' ? 'USER' : 'ASSISTANT';
543
+ lines.push(`--- Turn ${turn.turnNumber} [${roleLabel}] ---`);
544
+
545
+ const content = turn.content.length > maxContentLength
546
+ ? turn.content.substring(0, maxContentLength) + '\n[truncated]'
547
+ : turn.content;
548
+ lines.push(content);
549
+
550
+ if (includeThoughts && turn.thoughts && turn.thoughts.length > 0) {
551
+ lines.push('');
552
+ lines.push('Thoughts:');
553
+ for (const thought of turn.thoughts) {
554
+ lines.push(` - ${thought}`);
555
+ }
556
+ }
557
+
558
+ if (includeToolCalls && turn.toolCalls && turn.toolCalls.length > 0) {
559
+ lines.push('');
560
+ lines.push('Tool Calls:');
561
+ for (const tc of turn.toolCalls) {
562
+ lines.push(` - ${tc.name}`);
563
+ if (tc.output) {
564
+ const output = tc.output.length > 200
565
+ ? tc.output.substring(0, 200) + '...'
566
+ : tc.output;
567
+ lines.push(` Output: ${output}`);
568
+ }
569
+ }
570
+ }
571
+
572
+ if (includeTokens && turn.tokens) {
573
+ lines.push(`Tokens: ${turn.tokens.total} (in: ${turn.tokens.input}, out: ${turn.tokens.output})`);
574
+ }
575
+
576
+ lines.push('');
577
+ }
578
+
579
+ if (session.totalTokens) {
580
+ lines.push(`=== Total Tokens: ${session.totalTokens.total} ===`);
581
+ }
582
+
583
+ return lines.join('\n');
584
+ }
585
+
586
+ /**
587
+ * Extract just user prompts and assistant responses as simple pairs
588
+ */
589
+ export function extractConversationPairs(session: ParsedSession): Array<{
590
+ turn: number;
591
+ userPrompt: string;
592
+ assistantResponse: string;
593
+ timestamp: string;
594
+ }> {
595
+ const pairs: Array<{
596
+ turn: number;
597
+ userPrompt: string;
598
+ assistantResponse: string;
599
+ timestamp: string;
600
+ }> = [];
601
+
602
+ const turnNumbers = [...new Set(session.turns.map(t => t.turnNumber))];
603
+
604
+ for (const turnNum of turnNumbers) {
605
+ const userTurn = session.turns.find(t => t.turnNumber === turnNum && t.role === 'user');
606
+ const assistantTurn = session.turns.find(t => t.turnNumber === turnNum && t.role === 'assistant');
607
+
608
+ if (userTurn) {
609
+ pairs.push({
610
+ turn: turnNum,
611
+ userPrompt: userTurn.content,
612
+ assistantResponse: assistantTurn?.content || '',
613
+ timestamp: userTurn.timestamp
614
+ });
615
+ }
616
+ }
617
+
618
+ return pairs;
619
+ }