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,428 @@
1
+ // @ts-nocheck
2
+ /**
3
+ * Files Routes Module
4
+ * Handles all file browsing related API endpoints
5
+ */
6
+ import type { IncomingMessage, ServerResponse } from 'http';
7
+ import { existsSync, readFileSync, readdirSync, statSync } from 'fs';
8
+ import { join } from 'path';
9
+
10
+ export interface RouteContext {
11
+ pathname: string;
12
+ url: URL;
13
+ req: IncomingMessage;
14
+ res: ServerResponse;
15
+ initialPath: string;
16
+ handlePostRequest: (req: IncomingMessage, res: ServerResponse, handler: (body: unknown) => Promise<any>) => void;
17
+ broadcastToClients: (data: unknown) => void;
18
+ }
19
+
20
+ // ========================================
21
+ // Constants
22
+ // ========================================
23
+
24
+ // Directories to always exclude from file tree
25
+ const EXPLORER_EXCLUDE_DIRS = [
26
+ '.git', '__pycache__', 'node_modules', '.venv', 'venv', 'env',
27
+ 'dist', 'build', '.cache', '.pytest_cache', '.mypy_cache',
28
+ 'coverage', '.nyc_output', 'logs', 'tmp', 'temp', '.next',
29
+ '.nuxt', '.output', '.turbo', '.parcel-cache'
30
+ ];
31
+
32
+ // File extensions to language mapping for syntax highlighting
33
+ const EXT_TO_LANGUAGE = {
34
+ '.js': 'javascript',
35
+ '.jsx': 'javascript',
36
+ '.ts': 'typescript',
37
+ '.tsx': 'typescript',
38
+ '.py': 'python',
39
+ '.rb': 'ruby',
40
+ '.java': 'java',
41
+ '.go': 'go',
42
+ '.rs': 'rust',
43
+ '.c': 'c',
44
+ '.cpp': 'cpp',
45
+ '.h': 'c',
46
+ '.hpp': 'cpp',
47
+ '.cs': 'csharp',
48
+ '.php': 'php',
49
+ '.swift': 'swift',
50
+ '.kt': 'kotlin',
51
+ '.scala': 'scala',
52
+ '.sh': 'bash',
53
+ '.bash': 'bash',
54
+ '.zsh': 'bash',
55
+ '.ps1': 'powershell',
56
+ '.sql': 'sql',
57
+ '.html': 'html',
58
+ '.htm': 'html',
59
+ '.css': 'css',
60
+ '.scss': 'scss',
61
+ '.sass': 'sass',
62
+ '.less': 'less',
63
+ '.json': 'json',
64
+ '.xml': 'xml',
65
+ '.yaml': 'yaml',
66
+ '.yml': 'yaml',
67
+ '.toml': 'toml',
68
+ '.ini': 'ini',
69
+ '.cfg': 'ini',
70
+ '.conf': 'nginx',
71
+ '.md': 'markdown',
72
+ '.markdown': 'markdown',
73
+ '.txt': 'plaintext',
74
+ '.log': 'plaintext',
75
+ '.env': 'bash',
76
+ '.dockerfile': 'dockerfile',
77
+ '.vue': 'html',
78
+ '.svelte': 'html'
79
+ };
80
+
81
+ // ========================================
82
+ // Helper Functions
83
+ // ========================================
84
+
85
+ /**
86
+ * Parse .gitignore file and return patterns
87
+ * @param {string} gitignorePath - Path to .gitignore file
88
+ * @returns {string[]} Array of gitignore patterns
89
+ */
90
+ function parseGitignore(gitignorePath) {
91
+ try {
92
+ if (!existsSync(gitignorePath)) return [];
93
+ const content = readFileSync(gitignorePath, 'utf8');
94
+ return content
95
+ .split('\n')
96
+ .map(line => line.trim())
97
+ .filter(line => line && !line.startsWith('#'));
98
+ } catch {
99
+ return [];
100
+ }
101
+ }
102
+
103
+ /**
104
+ * Check if a file/directory should be ignored based on gitignore patterns
105
+ * Simple pattern matching (supports basic glob patterns)
106
+ * @param {string} name - File or directory name
107
+ * @param {string[]} patterns - Gitignore patterns
108
+ * @param {boolean} isDirectory - Whether the entry is a directory
109
+ * @returns {boolean}
110
+ */
111
+ function shouldIgnore(name, patterns, isDirectory) {
112
+ // Always exclude certain directories
113
+ if (isDirectory && EXPLORER_EXCLUDE_DIRS.includes(name)) {
114
+ return true;
115
+ }
116
+
117
+ // Skip hidden files/directories (starting with .)
118
+ if (name.startsWith('.') && name !== '.claude' && name !== '.workflow') {
119
+ return true;
120
+ }
121
+
122
+ for (const pattern of patterns) {
123
+ let p = pattern;
124
+
125
+ // Handle negation patterns (we skip them for simplicity)
126
+ if (p.startsWith('!')) continue;
127
+
128
+ // Handle directory-only patterns
129
+ if (p.endsWith('/')) {
130
+ if (!isDirectory) continue;
131
+ p = p.slice(0, -1);
132
+ }
133
+
134
+ // Simple pattern matching
135
+ if (p === name) return true;
136
+
137
+ // Handle wildcard patterns
138
+ if (p.includes('*')) {
139
+ const regex = new RegExp('^' + p.replace(/\./g, '\\.').replace(/\*/g, '.*') + '$');
140
+ if (regex.test(name)) return true;
141
+ }
142
+
143
+ // Handle extension patterns like *.log
144
+ if (p.startsWith('*.')) {
145
+ const ext = p.slice(1);
146
+ if (name.endsWith(ext)) return true;
147
+ }
148
+ }
149
+
150
+ return false;
151
+ }
152
+
153
+ /**
154
+ * List directory files with .gitignore filtering
155
+ * @param {string} dirPath - Directory path to list
156
+ * @returns {Promise<Object>}
157
+ */
158
+ async function listDirectoryFiles(dirPath) {
159
+ try {
160
+ // Normalize path
161
+ let normalizedPath = dirPath.replace(/\\/g, '/');
162
+ if (normalizedPath.match(/^\/[a-zA-Z]\//)) {
163
+ normalizedPath = normalizedPath.charAt(1).toUpperCase() + ':' + normalizedPath.slice(2);
164
+ }
165
+
166
+ if (!existsSync(normalizedPath)) {
167
+ return { error: 'Directory not found', files: [] };
168
+ }
169
+
170
+ if (!statSync(normalizedPath).isDirectory()) {
171
+ return { error: 'Not a directory', files: [] };
172
+ }
173
+
174
+ // Parse .gitignore patterns
175
+ const gitignorePath = join(normalizedPath, '.gitignore');
176
+ const gitignorePatterns = parseGitignore(gitignorePath);
177
+
178
+ // Read directory entries
179
+ const entries = readdirSync(normalizedPath, { withFileTypes: true });
180
+
181
+ const files = [];
182
+ for (const entry of entries) {
183
+ const isDirectory = entry.isDirectory();
184
+
185
+ // Check if should be ignored
186
+ if (shouldIgnore(entry.name, gitignorePatterns, isDirectory)) {
187
+ continue;
188
+ }
189
+
190
+ const entryPath = join(normalizedPath, entry.name);
191
+ const fileInfo = {
192
+ name: entry.name,
193
+ type: isDirectory ? 'directory' : 'file',
194
+ path: entryPath.replace(/\\/g, '/')
195
+ };
196
+
197
+ // Check if directory has CLAUDE.md
198
+ if (isDirectory) {
199
+ const claudeMdPath = join(entryPath, 'CLAUDE.md');
200
+ fileInfo.hasClaudeMd = existsSync(claudeMdPath);
201
+ }
202
+
203
+ files.push(fileInfo);
204
+ }
205
+
206
+ // Sort: directories first, then alphabetically
207
+ files.sort((a, b) => {
208
+ if (a.type === 'directory' && b.type !== 'directory') return -1;
209
+ if (a.type !== 'directory' && b.type === 'directory') return 1;
210
+ return a.name.localeCompare(b.name);
211
+ });
212
+
213
+ return {
214
+ path: normalizedPath.replace(/\\/g, '/'),
215
+ files,
216
+ gitignorePatterns
217
+ };
218
+ } catch (error: unknown) {
219
+ console.error('Error listing directory:', error);
220
+ return { error: (error as Error).message, files: [] };
221
+ }
222
+ }
223
+
224
+ /**
225
+ * Get file content for preview
226
+ * @param {string} filePath - Path to file
227
+ * @returns {Promise<Object>}
228
+ */
229
+ async function getFileContent(filePath) {
230
+ try {
231
+ // Normalize path
232
+ let normalizedPath = filePath.replace(/\\/g, '/');
233
+ if (normalizedPath.match(/^\/[a-zA-Z]\//)) {
234
+ normalizedPath = normalizedPath.charAt(1).toUpperCase() + ':' + normalizedPath.slice(2);
235
+ }
236
+
237
+ if (!existsSync(normalizedPath)) {
238
+ return { error: 'File not found' };
239
+ }
240
+
241
+ const stats = statSync(normalizedPath);
242
+ if (stats.isDirectory()) {
243
+ return { error: 'Cannot read directory' };
244
+ }
245
+
246
+ // Check file size (limit to 1MB for preview)
247
+ if (stats.size > 1024 * 1024) {
248
+ return { error: 'File too large for preview (max 1MB)', size: stats.size };
249
+ }
250
+
251
+ // Read file content
252
+ const content = readFileSync(normalizedPath, 'utf8');
253
+ const ext = normalizedPath.substring(normalizedPath.lastIndexOf('.')).toLowerCase();
254
+ const language = EXT_TO_LANGUAGE[ext] || 'plaintext';
255
+ const isMarkdown = ext === '.md' || ext === '.markdown';
256
+ const fileName = normalizedPath.split('/').pop();
257
+
258
+ return {
259
+ content,
260
+ language,
261
+ isMarkdown,
262
+ fileName,
263
+ path: normalizedPath,
264
+ size: stats.size,
265
+ lines: content.split('\n').length
266
+ };
267
+ } catch (error: unknown) {
268
+ console.error('Error reading file:', error);
269
+ return { error: (error as Error).message };
270
+ }
271
+ }
272
+
273
+ /**
274
+ * Trigger update-module-claude tool (async execution)
275
+ * @param {string} targetPath - Directory path to update
276
+ * @param {string} tool - CLI tool to use (gemini, qwen, codex, claude)
277
+ * @param {string} strategy - Update strategy (single-layer, multi-layer)
278
+ * @returns {Promise<Object>}
279
+ */
280
+ async function triggerUpdateClaudeMd(targetPath, tool, strategy) {
281
+ const { spawn } = await import('child_process');
282
+
283
+ // Normalize path
284
+ let normalizedPath = targetPath.replace(/\\/g, '/');
285
+ if (normalizedPath.match(/^\/[a-zA-Z]\//)) {
286
+ normalizedPath = normalizedPath.charAt(1).toUpperCase() + ':' + normalizedPath.slice(2);
287
+ }
288
+
289
+ if (!existsSync(normalizedPath)) {
290
+ return { error: 'Directory not found' };
291
+ }
292
+
293
+ if (!statSync(normalizedPath).isDirectory()) {
294
+ return { error: 'Not a directory' };
295
+ }
296
+
297
+ // Build ccw tool command with JSON parameters
298
+ const params = JSON.stringify({
299
+ strategy,
300
+ path: normalizedPath,
301
+ tool
302
+ });
303
+
304
+ console.log(`[Explorer] Running async: ccw tool exec update_module_claude with ${tool} (${strategy})`);
305
+
306
+ return new Promise((resolve) => {
307
+ const isWindows = process.platform === 'win32';
308
+
309
+ // Spawn the process
310
+ const child = spawn('ccw', ['tool', 'exec', 'update_module_claude', params], {
311
+ cwd: normalizedPath,
312
+ shell: isWindows,
313
+ stdio: ['ignore', 'pipe', 'pipe']
314
+ });
315
+
316
+ let stdout = '';
317
+ let stderr = '';
318
+
319
+ child.stdout.on('data', (data) => {
320
+ stdout += data.toString();
321
+ });
322
+
323
+ child.stderr.on('data', (data) => {
324
+ stderr += data.toString();
325
+ });
326
+
327
+ child.on('close', (code) => {
328
+ if (code === 0) {
329
+ // Parse the JSON output from the tool
330
+ let result;
331
+ try {
332
+ result = JSON.parse(stdout);
333
+ } catch {
334
+ result = { output: stdout };
335
+ }
336
+
337
+ if (result.success === false || result.error) {
338
+ resolve({
339
+ success: false,
340
+ error: result.error || result.message || 'Update failed',
341
+ output: stdout
342
+ });
343
+ } else {
344
+ resolve({
345
+ success: true,
346
+ message: result.message || `CLAUDE.md updated successfully using ${tool} (${strategy})`,
347
+ output: stdout,
348
+ path: normalizedPath
349
+ });
350
+ }
351
+ } else {
352
+ resolve({
353
+ success: false,
354
+ error: stderr || `Process exited with code ${code}`,
355
+ output: stdout + stderr
356
+ });
357
+ }
358
+ });
359
+
360
+ child.on('error', (error) => {
361
+ console.error('Error spawning process:', error);
362
+ resolve({
363
+ success: false,
364
+ error: (error as Error).message,
365
+ output: ''
366
+ });
367
+ });
368
+
369
+ // Timeout after 5 minutes
370
+ setTimeout(() => {
371
+ child.kill();
372
+ resolve({
373
+ success: false,
374
+ error: 'Timeout: Process took longer than 5 minutes',
375
+ output: stdout
376
+ });
377
+ }, 300000);
378
+ });
379
+ }
380
+
381
+ // ========================================
382
+ // Route Handler
383
+ // ========================================
384
+
385
+ /**
386
+ * Handle files routes
387
+ * @returns true if route was handled, false otherwise
388
+ */
389
+ export async function handleFilesRoutes(ctx: RouteContext): Promise<boolean> {
390
+ const { pathname, url, req, res, initialPath, handlePostRequest } = ctx;
391
+
392
+ // API: List directory files with .gitignore filtering (Explorer view)
393
+ if (pathname === '/api/files') {
394
+ const dirPath = url.searchParams.get('path') || initialPath;
395
+ const filesData = await listDirectoryFiles(dirPath);
396
+ res.writeHead(200, { 'Content-Type': 'application/json' });
397
+ res.end(JSON.stringify(filesData));
398
+ return true;
399
+ }
400
+
401
+ // API: Get file content for preview (Explorer view)
402
+ if (pathname === '/api/file-content') {
403
+ const filePath = url.searchParams.get('path');
404
+ if (!filePath) {
405
+ res.writeHead(400, { 'Content-Type': 'application/json' });
406
+ res.end(JSON.stringify({ error: 'File path is required' }));
407
+ return true;
408
+ }
409
+ const fileData = await getFileContent(filePath);
410
+ res.writeHead(fileData.error ? 404 : 200, { 'Content-Type': 'application/json' });
411
+ res.end(JSON.stringify(fileData));
412
+ return true;
413
+ }
414
+
415
+ // API: Update CLAUDE.md using CLI tools (Explorer view)
416
+ if (pathname === '/api/update-claude-md' && req.method === 'POST') {
417
+ handlePostRequest(req, res, async (body) => {
418
+ const { path: targetPath, tool = 'gemini', strategy = 'single-layer' } = body;
419
+ if (!targetPath) {
420
+ return { error: 'path is required', status: 400 };
421
+ }
422
+ return await triggerUpdateClaudeMd(targetPath, tool, strategy);
423
+ });
424
+ return true;
425
+ }
426
+
427
+ return false;
428
+ }
@@ -0,0 +1,164 @@
1
+ # Graph Routes API Documentation
2
+
3
+ ## Overview
4
+ The Graph Routes module provides REST API endpoints for querying and visualizing code structure data from CodexLens indices. It exposes symbols and their relationships as graph nodes and edges.
5
+
6
+ ## Endpoints
7
+
8
+ ### GET /api/graph/nodes
9
+ Query all symbols from the CodexLens SQLite database and return them as graph nodes.
10
+
11
+ **Query Parameters:**
12
+ - `path` (optional): Project path. Defaults to server's initial path.
13
+
14
+ **Response:**
15
+ ```json
16
+ {
17
+ "nodes": [
18
+ {
19
+ "id": "src/file.ts:functionName:10",
20
+ "name": "functionName",
21
+ "type": "FUNCTION",
22
+ "file": "src/file.ts",
23
+ "line": 10
24
+ }
25
+ ]
26
+ }
27
+ ```
28
+
29
+ **Node Types:**
30
+ - `FUNCTION`: Functions and procedures
31
+ - `CLASS`: Classes, interfaces, and type definitions
32
+ - `METHOD`: Class methods
33
+ - `VARIABLE`: Variables and constants
34
+ - `MODULE`: Module-level definitions
35
+
36
+ ---
37
+
38
+ ### GET /api/graph/edges
39
+ Query all code relationships from the CodexLens SQLite database and return them as graph edges.
40
+
41
+ **Query Parameters:**
42
+ - `path` (optional): Project path. Defaults to server's initial path.
43
+
44
+ **Response:**
45
+ ```json
46
+ {
47
+ "edges": [
48
+ {
49
+ "source": "src/file.ts:caller:10",
50
+ "target": "module.callee",
51
+ "type": "CALLS",
52
+ "sourceLine": 10,
53
+ "sourceFile": "src/file.ts"
54
+ }
55
+ ]
56
+ }
57
+ ```
58
+
59
+ **Edge Types:**
60
+ - `CALLS`: Function/method invocations
61
+ - `IMPORTS`: Import/require relationships
62
+ - `INHERITS`: Class inheritance
63
+
64
+ ---
65
+
66
+ ### GET /api/graph/impact
67
+ Get impact analysis for a symbol - determines what code is affected if this symbol changes.
68
+
69
+ **Query Parameters:**
70
+ - `path` (optional): Project path. Defaults to server's initial path.
71
+ - `symbol` (required): Symbol ID in format `file:name:line`
72
+
73
+ **Response:**
74
+ ```json
75
+ {
76
+ "directDependents": [
77
+ "src/other.ts:caller:20",
78
+ "src/another.ts:user:35"
79
+ ],
80
+ "affectedFiles": [
81
+ "src/other.ts",
82
+ "src/another.ts"
83
+ ]
84
+ }
85
+ ```
86
+
87
+ ---
88
+
89
+ ## Implementation Details
90
+
91
+ ### PathMapper
92
+ Maps source code paths to CodexLens index database paths following the storage structure:
93
+ - Windows: `D:\path\to\project` → `~/.codexlens/indexes/D/path/to/project/_index.db`
94
+ - Unix: `/home/user/project` → `~/.codexlens/indexes/home/user/project/_index.db`
95
+
96
+ ### Database Schema
97
+ Queries two main tables:
98
+ 1. **symbols** - Code symbol definitions
99
+ - `id`, `file_id`, `name`, `kind`, `start_line`, `end_line`
100
+ 2. **code_relationships** - Inter-symbol dependencies
101
+ - `id`, `source_symbol_id`, `target_qualified_name`, `relationship_type`, `source_line`, `target_file`
102
+
103
+ ### Error Handling
104
+ - Returns empty arrays (`[]`) if index database doesn't exist
105
+ - Returns 500 with error message on database query failures
106
+ - Returns 400 if required parameters are missing
107
+
108
+ ### Type Mappings
109
+
110
+ **Symbol Kinds → Node Types:**
111
+ ```typescript
112
+ {
113
+ 'function' → 'FUNCTION',
114
+ 'class' → 'CLASS',
115
+ 'method' → 'METHOD',
116
+ 'variable' → 'VARIABLE',
117
+ 'module' → 'MODULE',
118
+ 'interface' → 'CLASS',
119
+ 'type' → 'CLASS'
120
+ }
121
+ ```
122
+
123
+ **Relationship Types → Edge Types:**
124
+ ```typescript
125
+ {
126
+ 'call' → 'CALLS',
127
+ 'import' → 'IMPORTS',
128
+ 'inherits' → 'INHERITS',
129
+ 'uses' → 'CALLS'
130
+ }
131
+ ```
132
+
133
+ ---
134
+
135
+ ## Usage Examples
136
+
137
+ ### Fetch All Nodes
138
+ ```bash
139
+ curl "http://localhost:3000/api/graph/nodes?path=/path/to/project"
140
+ ```
141
+
142
+ ### Fetch All Edges
143
+ ```bash
144
+ curl "http://localhost:3000/api/graph/edges?path=/path/to/project"
145
+ ```
146
+
147
+ ### Analyze Impact
148
+ ```bash
149
+ curl "http://localhost:3000/api/graph/impact?path=/path/to/project&symbol=src/file.ts:functionName:10"
150
+ ```
151
+
152
+ ---
153
+
154
+ ## Integration with CodexLens
155
+
156
+ This module requires:
157
+ 1. CodexLens to be installed and initialized (`/api/codexlens/init`)
158
+ 2. Project to be indexed (creates `_index.db` files)
159
+ 3. better-sqlite3 package for direct database access
160
+
161
+ ## Dependencies
162
+ - `better-sqlite3`: Direct SQLite database access
163
+ - `codex-lens`: Python package providing the indexing infrastructure
164
+ - `path`, `fs`, `os`: Node.js built-in modules for file system operations