claude-code-workflow 6.1.3 → 6.2.1
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.
- package/README.md +145 -274
- package/bin/ccw-mcp.js +7 -0
- package/bin/ccw.js +10 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +219 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/cli.d.ts +32 -0
- package/dist/commands/cli.d.ts.map +1 -0
- package/dist/commands/cli.js +619 -0
- package/dist/commands/cli.js.map +1 -0
- package/dist/commands/core-memory.d.ts +32 -0
- package/dist/commands/core-memory.d.ts.map +1 -0
- package/dist/commands/core-memory.js +640 -0
- package/dist/commands/core-memory.js.map +1 -0
- package/dist/commands/hook.d.ts +16 -0
- package/dist/commands/hook.d.ts.map +1 -0
- package/dist/commands/hook.js +276 -0
- package/dist/commands/hook.js.map +1 -0
- package/dist/commands/install.d.ts +12 -0
- package/dist/commands/install.d.ts.map +1 -0
- package/dist/commands/install.js +443 -0
- package/dist/commands/install.js.map +1 -0
- package/dist/commands/list.d.ts +5 -0
- package/dist/commands/list.d.ts.map +1 -0
- package/dist/commands/list.js +32 -0
- package/dist/commands/list.js.map +1 -0
- package/dist/commands/memory.d.ts +57 -0
- package/dist/commands/memory.d.ts.map +1 -0
- package/dist/commands/memory.js +890 -0
- package/dist/commands/memory.js.map +1 -0
- package/dist/commands/serve.d.ts +12 -0
- package/dist/commands/serve.d.ts.map +1 -0
- package/dist/commands/serve.js +63 -0
- package/dist/commands/serve.js.map +1 -0
- package/dist/commands/session-path-resolver.d.ts +45 -0
- package/dist/commands/session-path-resolver.d.ts.map +1 -0
- package/dist/commands/session-path-resolver.js +302 -0
- package/dist/commands/session-path-resolver.js.map +1 -0
- package/dist/commands/session.d.ts +12 -0
- package/dist/commands/session.d.ts.map +1 -0
- package/dist/commands/session.js +954 -0
- package/dist/commands/session.js.map +1 -0
- package/dist/commands/stop.d.ts +11 -0
- package/dist/commands/stop.d.ts.map +1 -0
- package/dist/commands/stop.js +96 -0
- package/dist/commands/stop.js.map +1 -0
- package/dist/commands/tool.d.ts +29 -0
- package/dist/commands/tool.d.ts.map +1 -0
- package/dist/commands/tool.js +173 -0
- package/dist/commands/tool.js.map +1 -0
- package/dist/commands/uninstall.d.ts +9 -0
- package/dist/commands/uninstall.d.ts.map +1 -0
- package/dist/commands/uninstall.js +239 -0
- package/dist/commands/uninstall.js.map +1 -0
- package/dist/commands/upgrade.d.ts +10 -0
- package/dist/commands/upgrade.d.ts.map +1 -0
- package/dist/commands/upgrade.js +288 -0
- package/dist/commands/upgrade.js.map +1 -0
- package/dist/commands/view.d.ts +14 -0
- package/dist/commands/view.d.ts.map +1 -0
- package/dist/commands/view.js +100 -0
- package/dist/commands/view.js.map +1 -0
- package/dist/config/storage-paths.d.ts +184 -0
- package/dist/config/storage-paths.d.ts.map +1 -0
- package/dist/config/storage-paths.js +536 -0
- package/dist/config/storage-paths.js.map +1 -0
- package/dist/core/cache-manager.d.ts +80 -0
- package/dist/core/cache-manager.d.ts.map +1 -0
- package/dist/core/cache-manager.js +260 -0
- package/dist/core/cache-manager.js.map +1 -0
- package/dist/core/claude-freshness.d.ts +53 -0
- package/dist/core/claude-freshness.d.ts.map +1 -0
- package/dist/core/claude-freshness.js +232 -0
- package/dist/core/claude-freshness.js.map +1 -0
- package/dist/core/core-memory-store.d.ts +320 -0
- package/dist/core/core-memory-store.d.ts.map +1 -0
- package/dist/core/core-memory-store.js +1177 -0
- package/dist/core/core-memory-store.js.map +1 -0
- package/dist/core/dashboard-generator-patch.d.ts +2 -0
- package/dist/core/dashboard-generator-patch.d.ts.map +1 -0
- package/dist/core/dashboard-generator-patch.js +48 -0
- package/dist/core/dashboard-generator-patch.js.map +1 -0
- package/dist/core/dashboard-generator.d.ts +8 -0
- package/dist/core/dashboard-generator.d.ts.map +1 -0
- package/dist/core/dashboard-generator.js +695 -0
- package/dist/core/dashboard-generator.js.map +1 -0
- package/dist/core/data-aggregator.d.ts +145 -0
- package/dist/core/data-aggregator.d.ts.map +1 -0
- package/dist/core/data-aggregator.js +416 -0
- package/dist/core/data-aggregator.js.map +1 -0
- package/dist/core/history-importer.d.ts +102 -0
- package/dist/core/history-importer.d.ts.map +1 -0
- package/dist/core/history-importer.js +493 -0
- package/dist/core/history-importer.js.map +1 -0
- package/dist/core/lite-scanner-complete.d.ts +81 -0
- package/dist/core/lite-scanner-complete.d.ts.map +1 -0
- package/dist/core/lite-scanner-complete.js +368 -0
- package/dist/core/lite-scanner-complete.js.map +1 -0
- package/dist/core/lite-scanner.d.ts +81 -0
- package/dist/core/lite-scanner.d.ts.map +1 -0
- package/dist/core/lite-scanner.js +368 -0
- package/dist/core/lite-scanner.js.map +1 -0
- package/dist/core/manifest.d.ts +88 -0
- package/dist/core/manifest.d.ts.map +1 -0
- package/dist/core/manifest.js +214 -0
- package/dist/core/manifest.js.map +1 -0
- package/dist/core/memory-embedder-bridge.d.ts +83 -0
- package/dist/core/memory-embedder-bridge.d.ts.map +1 -0
- package/dist/core/memory-embedder-bridge.js +181 -0
- package/dist/core/memory-embedder-bridge.js.map +1 -0
- package/dist/core/memory-store.d.ts +249 -0
- package/dist/core/memory-store.d.ts.map +1 -0
- package/dist/core/memory-store.js +781 -0
- package/dist/core/memory-store.js.map +1 -0
- package/dist/core/routes/ccw-routes.d.ts +20 -0
- package/dist/core/routes/ccw-routes.d.ts.map +1 -0
- package/dist/core/routes/ccw-routes.js +70 -0
- package/dist/core/routes/ccw-routes.js.map +1 -0
- package/dist/core/routes/claude-routes.d.ts +19 -0
- package/dist/core/routes/claude-routes.d.ts.map +1 -0
- package/dist/core/routes/claude-routes.js +1017 -0
- package/dist/core/routes/claude-routes.js.map +1 -0
- package/dist/core/routes/cli-routes.d.ts +20 -0
- package/dist/core/routes/cli-routes.d.ts.map +1 -0
- package/dist/core/routes/cli-routes.js +468 -0
- package/dist/core/routes/cli-routes.js.map +1 -0
- package/dist/core/routes/codexlens-routes.d.ts +20 -0
- package/dist/core/routes/codexlens-routes.d.ts.map +1 -0
- package/dist/core/routes/codexlens-routes.js +754 -0
- package/dist/core/routes/codexlens-routes.js.map +1 -0
- package/dist/core/routes/core-memory-routes.d.ts +21 -0
- package/dist/core/routes/core-memory-routes.d.ts.map +1 -0
- package/dist/core/routes/core-memory-routes.js +520 -0
- package/dist/core/routes/core-memory-routes.js.map +1 -0
- package/dist/core/routes/files-routes.d.ts +20 -0
- package/dist/core/routes/files-routes.d.ts.map +1 -0
- package/dist/core/routes/files-routes.js +374 -0
- package/dist/core/routes/files-routes.js.map +1 -0
- package/dist/core/routes/graph-routes.d.ts +20 -0
- package/dist/core/routes/graph-routes.d.ts.map +1 -0
- package/dist/core/routes/graph-routes.js +517 -0
- package/dist/core/routes/graph-routes.js.map +1 -0
- package/dist/core/routes/help-routes.d.ts +20 -0
- package/dist/core/routes/help-routes.d.ts.map +1 -0
- package/dist/core/routes/help-routes.js +250 -0
- package/dist/core/routes/help-routes.js.map +1 -0
- package/dist/core/routes/hooks-routes.d.ts +21 -0
- package/dist/core/routes/hooks-routes.d.ts.map +1 -0
- package/dist/core/routes/hooks-routes.js +346 -0
- package/dist/core/routes/hooks-routes.js.map +1 -0
- package/dist/core/routes/mcp-routes.d.ts +20 -0
- package/dist/core/routes/mcp-routes.d.ts.map +1 -0
- package/dist/core/routes/mcp-routes.js +1129 -0
- package/dist/core/routes/mcp-routes.js.map +1 -0
- package/dist/core/routes/mcp-templates-db.d.ts +54 -0
- package/dist/core/routes/mcp-templates-db.d.ts.map +1 -0
- package/dist/core/routes/mcp-templates-db.js +226 -0
- package/dist/core/routes/mcp-templates-db.js.map +1 -0
- package/dist/core/routes/memory-routes.d.ts +21 -0
- package/dist/core/routes/memory-routes.d.ts.map +1 -0
- package/dist/core/routes/memory-routes.js +1095 -0
- package/dist/core/routes/memory-routes.js.map +1 -0
- package/dist/core/routes/rules-routes.d.ts +20 -0
- package/dist/core/routes/rules-routes.d.ts.map +1 -0
- package/dist/core/routes/rules-routes.js +442 -0
- package/dist/core/routes/rules-routes.js.map +1 -0
- package/dist/core/routes/session-routes.d.ts +20 -0
- package/dist/core/routes/session-routes.d.ts.map +1 -0
- package/dist/core/routes/session-routes.js +423 -0
- package/dist/core/routes/session-routes.js.map +1 -0
- package/dist/core/routes/skills-routes.d.ts +20 -0
- package/dist/core/routes/skills-routes.d.ts.map +1 -0
- package/dist/core/routes/skills-routes.js +533 -0
- package/dist/core/routes/skills-routes.js.map +1 -0
- package/dist/core/routes/status-routes.d.ts +20 -0
- package/dist/core/routes/status-routes.d.ts.map +1 -0
- package/dist/core/routes/status-routes.js +38 -0
- package/dist/core/routes/status-routes.js.map +1 -0
- package/dist/core/routes/system-routes.d.ts +22 -0
- package/dist/core/routes/system-routes.d.ts.map +1 -0
- package/dist/core/routes/system-routes.js +354 -0
- package/dist/core/routes/system-routes.js.map +1 -0
- package/dist/core/server.d.ts +17 -0
- package/dist/core/server.d.ts.map +1 -0
- package/dist/core/server.js +386 -0
- package/dist/core/server.js.map +1 -0
- package/dist/core/session-clustering-service.d.ts +153 -0
- package/dist/core/session-clustering-service.d.ts.map +1 -0
- package/dist/core/session-clustering-service.js +1065 -0
- package/dist/core/session-clustering-service.js.map +1 -0
- package/dist/core/session-scanner.d.ts +32 -0
- package/dist/core/session-scanner.d.ts.map +1 -0
- package/dist/core/session-scanner.js +253 -0
- package/dist/core/session-scanner.js.map +1 -0
- package/dist/core/websocket.d.ts +23 -0
- package/dist/core/websocket.d.ts.map +1 -0
- package/dist/core/websocket.js +168 -0
- package/dist/core/websocket.js.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +10 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp-server/index.d.ts +7 -0
- package/dist/mcp-server/index.d.ts.map +1 -0
- package/dist/mcp-server/index.js +157 -0
- package/dist/mcp-server/index.js.map +1 -0
- package/dist/tools/classify-folders.d.ts +26 -0
- package/dist/tools/classify-folders.d.ts.map +1 -0
- package/dist/tools/classify-folders.js +201 -0
- package/dist/tools/classify-folders.js.map +1 -0
- package/dist/tools/cli-config-manager.d.ts +62 -0
- package/dist/tools/cli-config-manager.d.ts.map +1 -0
- package/dist/tools/cli-config-manager.js +221 -0
- package/dist/tools/cli-config-manager.js.map +1 -0
- package/dist/tools/cli-executor.d.ts +373 -0
- package/dist/tools/cli-executor.d.ts.map +1 -0
- package/dist/tools/cli-executor.js +1625 -0
- package/dist/tools/cli-executor.js.map +1 -0
- package/dist/tools/cli-history-store.d.ts +330 -0
- package/dist/tools/cli-history-store.d.ts.map +1 -0
- package/dist/tools/cli-history-store.js +916 -0
- package/dist/tools/cli-history-store.js.map +1 -0
- package/dist/tools/codex-lens.d.ts +118 -0
- package/dist/tools/codex-lens.d.ts.map +1 -0
- package/dist/tools/codex-lens.js +962 -0
- package/dist/tools/codex-lens.js.map +1 -0
- package/dist/tools/convert-tokens-to-css.d.ts +14 -0
- package/dist/tools/convert-tokens-to-css.d.ts.map +1 -0
- package/dist/tools/convert-tokens-to-css.js +244 -0
- package/dist/tools/convert-tokens-to-css.js.map +1 -0
- package/dist/tools/core-memory.d.ts +66 -0
- package/dist/tools/core-memory.d.ts.map +1 -0
- package/dist/tools/core-memory.js +324 -0
- package/dist/tools/core-memory.js.map +1 -0
- package/dist/tools/detect-changed-modules.d.ts +24 -0
- package/dist/tools/detect-changed-modules.d.ts.map +1 -0
- package/dist/tools/detect-changed-modules.js +277 -0
- package/dist/tools/detect-changed-modules.js.map +1 -0
- package/dist/tools/discover-design-files.d.ts +36 -0
- package/dist/tools/discover-design-files.d.ts.map +1 -0
- package/dist/tools/discover-design-files.js +147 -0
- package/dist/tools/discover-design-files.js.map +1 -0
- package/dist/tools/edit-file.d.ts +28 -0
- package/dist/tools/edit-file.d.ts.map +1 -0
- package/dist/tools/edit-file.js +479 -0
- package/dist/tools/edit-file.js.map +1 -0
- package/dist/tools/generate-module-docs.d.ts +22 -0
- package/dist/tools/generate-module-docs.d.ts.map +1 -0
- package/dist/tools/generate-module-docs.js +379 -0
- package/dist/tools/generate-module-docs.js.map +1 -0
- package/dist/tools/get-modules-by-depth.d.ts +15 -0
- package/dist/tools/get-modules-by-depth.d.ts.map +1 -0
- package/dist/tools/get-modules-by-depth.js +296 -0
- package/dist/tools/get-modules-by-depth.js.map +1 -0
- package/dist/tools/index.d.ts +55 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +304 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/native-session-discovery.d.ts +97 -0
- package/dist/tools/native-session-discovery.d.ts.map +1 -0
- package/dist/tools/native-session-discovery.js +700 -0
- package/dist/tools/native-session-discovery.js.map +1 -0
- package/dist/tools/notifier.d.ts +50 -0
- package/dist/tools/notifier.d.ts.map +1 -0
- package/dist/tools/notifier.js +90 -0
- package/dist/tools/notifier.js.map +1 -0
- package/dist/tools/read-file.d.ts +32 -0
- package/dist/tools/read-file.d.ts.map +1 -0
- package/dist/tools/read-file.js +329 -0
- package/dist/tools/read-file.js.map +1 -0
- package/dist/tools/resume-strategy.d.ts +48 -0
- package/dist/tools/resume-strategy.d.ts.map +1 -0
- package/dist/tools/resume-strategy.js +248 -0
- package/dist/tools/resume-strategy.js.map +1 -0
- package/dist/tools/session-content-parser.d.ts +58 -0
- package/dist/tools/session-content-parser.d.ts.map +1 -0
- package/dist/tools/session-content-parser.js +420 -0
- package/dist/tools/session-content-parser.js.map +1 -0
- package/dist/tools/session-manager.d.ts +9 -0
- package/dist/tools/session-manager.d.ts.map +1 -0
- package/dist/tools/session-manager.js +834 -0
- package/dist/tools/session-manager.js.map +1 -0
- package/dist/tools/smart-context.d.ts +35 -0
- package/dist/tools/smart-context.d.ts.map +1 -0
- package/dist/tools/smart-context.js +182 -0
- package/dist/tools/smart-context.js.map +1 -0
- package/dist/tools/smart-search.d.ts +105 -0
- package/dist/tools/smart-search.d.ts.map +1 -0
- package/dist/tools/smart-search.js +1753 -0
- package/dist/tools/smart-search.js.map +1 -0
- package/dist/tools/storage-manager.d.ts +114 -0
- package/dist/tools/storage-manager.d.ts.map +1 -0
- package/dist/tools/storage-manager.js +392 -0
- package/dist/tools/storage-manager.js.map +1 -0
- package/dist/tools/ui-generate-preview.d.ts +39 -0
- package/dist/tools/ui-generate-preview.d.ts.map +1 -0
- package/dist/tools/ui-generate-preview.js +300 -0
- package/dist/tools/ui-generate-preview.js.map +1 -0
- package/dist/tools/ui-instantiate-prototypes.d.ts +75 -0
- package/dist/tools/ui-instantiate-prototypes.d.ts.map +1 -0
- package/dist/tools/ui-instantiate-prototypes.js +256 -0
- package/dist/tools/ui-instantiate-prototypes.js.map +1 -0
- package/dist/tools/update-module-claude.d.ts +80 -0
- package/dist/tools/update-module-claude.d.ts.map +1 -0
- package/dist/tools/update-module-claude.js +351 -0
- package/dist/tools/update-module-claude.js.map +1 -0
- package/dist/tools/write-file.d.ts +19 -0
- package/dist/tools/write-file.d.ts.map +1 -0
- package/dist/tools/write-file.js +193 -0
- package/dist/tools/write-file.js.map +1 -0
- package/dist/types/config.d.ts +11 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +4 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/session.d.ts +20 -0
- package/dist/types/session.d.ts.map +1 -0
- package/dist/types/session.js +2 -0
- package/dist/types/session.js.map +1 -0
- package/dist/types/tool.d.ts +36 -0
- package/dist/types/tool.d.ts.map +1 -0
- package/dist/types/tool.js +11 -0
- package/dist/types/tool.js.map +1 -0
- package/dist/utils/browser-launcher.d.ts +13 -0
- package/dist/utils/browser-launcher.d.ts.map +1 -0
- package/dist/utils/browser-launcher.js +60 -0
- package/dist/utils/browser-launcher.js.map +1 -0
- package/dist/utils/file-utils.d.ts +25 -0
- package/dist/utils/file-utils.d.ts.map +1 -0
- package/dist/utils/file-utils.js +48 -0
- package/dist/utils/file-utils.js.map +1 -0
- package/dist/utils/path-resolver.d.ts +80 -0
- package/dist/utils/path-resolver.d.ts.map +1 -0
- package/dist/utils/path-resolver.js +260 -0
- package/dist/utils/path-resolver.js.map +1 -0
- package/dist/utils/path-validator.d.ts +49 -0
- package/dist/utils/path-validator.d.ts.map +1 -0
- package/dist/utils/path-validator.js +123 -0
- package/dist/utils/path-validator.js.map +1 -0
- package/dist/utils/ui.d.ts +62 -0
- package/dist/utils/ui.d.ts.map +1 -0
- package/dist/utils/ui.js +129 -0
- package/dist/utils/ui.js.map +1 -0
- package/package.json +65 -67
- package/src/.workflow/.cli-history/history.db +0 -0
- package/src/.workflow/.cli-history/history.db-shm +0 -0
- package/src/.workflow/.cli-history/history.db-wal +0 -0
- package/src/cli.ts +244 -0
- package/src/commands/cli.ts +740 -0
- package/src/commands/core-memory.ts +770 -0
- package/src/commands/hook.ts +315 -0
- package/src/commands/install.ts +519 -0
- package/src/commands/list.ts +37 -0
- package/src/commands/memory.ts +1090 -0
- package/src/commands/serve.ts +76 -0
- package/src/commands/session-path-resolver.ts +372 -0
- package/src/commands/session.ts +1141 -0
- package/src/commands/stop.ts +111 -0
- package/src/commands/tool.ts +201 -0
- package/src/commands/uninstall.ts +287 -0
- package/src/commands/upgrade.ts +352 -0
- package/src/commands/view.ts +119 -0
- package/src/config/storage-paths.ts +670 -0
- package/src/core/cache-manager.ts +294 -0
- package/src/core/claude-freshness.ts +319 -0
- package/src/core/core-memory-store.ts +1528 -0
- package/src/core/dashboard-generator-patch.ts +47 -0
- package/src/core/dashboard-generator.ts +739 -0
- package/src/core/data-aggregator.ts +584 -0
- package/src/core/history-importer.ts +625 -0
- package/src/core/lite-scanner-complete.ts +469 -0
- package/src/core/lite-scanner.ts +469 -0
- package/src/core/manifest.ts +271 -0
- package/src/core/memory-embedder-bridge.ts +262 -0
- package/src/core/memory-store.ts +978 -0
- package/src/core/routes/ccw-routes.ts +96 -0
- package/src/core/routes/claude-routes.ts +1183 -0
- package/src/core/routes/cli-routes.ts +561 -0
- package/src/core/routes/codexlens-routes.ts +806 -0
- package/src/core/routes/core-memory-routes.ts +605 -0
- package/src/core/routes/files-routes.ts +428 -0
- package/src/core/routes/graph-routes.md +164 -0
- package/src/core/routes/graph-routes.ts +626 -0
- package/src/core/routes/help-routes.ts +308 -0
- package/src/core/routes/hooks-routes.ts +405 -0
- package/src/core/routes/mcp-routes.ts +1271 -0
- package/src/core/routes/mcp-routes.ts.backup +550 -0
- package/src/core/routes/mcp-templates-db.ts +268 -0
- package/src/core/routes/memory-routes.ts +1206 -0
- package/src/core/routes/rules-routes.ts +526 -0
- package/src/core/routes/session-routes.ts +467 -0
- package/src/core/routes/skills-routes.ts +599 -0
- package/src/core/routes/status-routes.ts +57 -0
- package/src/core/routes/system-routes.ts +427 -0
- package/src/core/server.ts +431 -0
- package/src/core/session-clustering-service.ts +1258 -0
- package/src/core/session-scanner.ts +283 -0
- package/src/core/websocket.ts +190 -0
- package/src/index.ts +10 -0
- package/src/mcp-server/index.ts +186 -0
- package/src/templates/assets/css/github-dark.min.css +10 -0
- package/src/templates/assets/css/github.min.css +10 -0
- package/src/templates/assets/js/cytoscape.min.js +32 -0
- package/src/templates/assets/js/d3.min.js +2 -0
- package/src/templates/assets/js/highlight.min.js +1244 -0
- package/src/templates/assets/js/lucide.min.js +12 -0
- package/src/templates/assets/js/marked.min.js +69 -0
- package/src/templates/assets/js/tailwind.js +83 -0
- package/src/templates/dashboard-css/01-base.css +302 -0
- package/src/templates/dashboard-css/02-session.css +748 -0
- package/src/templates/dashboard-css/04-lite-tasks.css +1181 -0
- package/src/templates/dashboard-css/06-cards.css +1576 -0
- package/src/templates/dashboard-css/07-managers.css +2107 -0
- package/src/templates/dashboard-css/09-explorer.css +1408 -0
- package/src/templates/dashboard-css/10-cli-status.css +337 -0
- package/src/templates/dashboard-css/11-cli-history.css +271 -0
- package/src/templates/dashboard-css/12-cli-legacy.css +796 -0
- package/src/templates/dashboard-css/13-cli-ccw.css +199 -0
- package/src/templates/dashboard-css/14-cli-modals.css +258 -0
- package/src/templates/dashboard-css/15-cli-endpoints.css +305 -0
- package/src/templates/dashboard-css/16-cli-session.css +241 -0
- package/src/templates/dashboard-css/17-cli-conversation.css +283 -0
- package/src/templates/dashboard-css/18-cli-settings.css +160 -0
- package/src/templates/dashboard-css/19-cli-native-session.css +496 -0
- package/src/templates/dashboard-css/20-cli-taskqueue.css +188 -0
- package/src/templates/dashboard-css/21-cli-toolmgmt.css +310 -0
- package/src/templates/dashboard-css/22-cli-semantic.css +240 -0
- package/src/templates/dashboard-css/23-memory.css +2390 -0
- package/src/templates/dashboard-css/24-prompt-history.css +1089 -0
- package/src/templates/dashboard-css/25-skills-rules.css +326 -0
- package/src/templates/dashboard-css/26-claude-manager.css +908 -0
- package/src/templates/dashboard-css/27-graph-explorer.css +1678 -0
- package/src/templates/dashboard-css/28-mcp-manager.css +748 -0
- package/src/templates/dashboard-css/29-help.css +264 -0
- package/src/templates/dashboard-css/30-core-memory.css +1700 -0
- package/src/templates/dashboard-js/api.js +220 -0
- package/src/templates/dashboard-js/components/carousel.js +398 -0
- package/src/templates/dashboard-js/components/cli-history.js +876 -0
- package/src/templates/dashboard-js/components/cli-status.js +978 -0
- package/src/templates/dashboard-js/components/global-notifications.js +508 -0
- package/src/templates/dashboard-js/components/hook-manager.js +1278 -0
- package/src/templates/dashboard-js/components/index-manager.js +302 -0
- package/src/templates/dashboard-js/components/mcp-manager.js +1219 -0
- package/src/templates/dashboard-js/components/modals.js +326 -0
- package/src/templates/dashboard-js/components/navigation.js +313 -0
- package/src/templates/dashboard-js/components/notifications.js +758 -0
- package/src/templates/dashboard-js/components/storage-manager.js +478 -0
- package/src/templates/dashboard-js/components/tabs-other.js +424 -0
- package/src/templates/dashboard-js/components/task-queue-sidebar.js +716 -0
- package/src/templates/dashboard-js/help-i18n.js +272 -0
- package/src/templates/dashboard-js/i18n.js +2807 -0
- package/src/templates/dashboard-js/main.js +87 -0
- package/src/templates/dashboard-js/state.js +243 -0
- package/src/templates/dashboard-js/utils.js +199 -0
- package/src/templates/dashboard-js/views/claude-manager.js +912 -0
- package/src/templates/dashboard-js/views/cli-manager.js +2272 -0
- package/src/templates/dashboard-js/views/codexlens-manager.js +964 -0
- package/src/templates/dashboard-js/views/core-memory-clusters.js +503 -0
- package/src/templates/dashboard-js/views/core-memory.js +782 -0
- package/src/templates/dashboard-js/views/explorer.js +888 -0
- package/src/templates/dashboard-js/views/graph-explorer.js +1157 -0
- package/src/templates/dashboard-js/views/help.js +856 -0
- package/src/templates/dashboard-js/views/history.js +337 -0
- package/src/templates/dashboard-js/views/home.js +243 -0
- package/src/templates/dashboard-js/views/hook-manager.js +660 -0
- package/src/templates/dashboard-js/views/lite-tasks.js +861 -0
- package/src/templates/dashboard-js/views/mcp-manager.js +2187 -0
- package/src/templates/dashboard-js/views/mcp-manager.js.backup +1729 -0
- package/src/templates/dashboard-js/views/mcp-manager.js.new +928 -0
- package/src/templates/dashboard-js/views/memory.js +1221 -0
- package/src/templates/dashboard-js/views/prompt-history.js +713 -0
- package/src/templates/dashboard-js/views/rules-manager.js +828 -0
- package/src/templates/dashboard-js/views/session-detail.js +781 -0
- package/src/templates/dashboard-js/views/skills-manager.js +819 -0
- package/src/templates/dashboard.html +831 -0
- package/src/templates/hooks-config-example.json +60 -0
- package/src/tools/classify-folders.ts +245 -0
- package/src/tools/cli-config-manager.ts +268 -0
- package/src/tools/cli-executor.ts +2014 -0
- package/src/tools/cli-history-store.ts +1195 -0
- package/src/tools/codex-lens.ts +1141 -0
- package/src/tools/convert-tokens-to-css.ts +300 -0
- package/src/tools/core-memory.ts +444 -0
- package/src/tools/detect-changed-modules.ts +325 -0
- package/src/tools/discover-design-files.ts +184 -0
- package/src/tools/edit-file.ts +568 -0
- package/src/tools/generate-module-docs.ts +438 -0
- package/src/tools/get-modules-by-depth.ts +349 -0
- package/src/tools/index.ts +370 -0
- package/src/tools/native-session-discovery.ts +795 -0
- package/src/tools/notifier.ts +129 -0
- package/src/tools/read-file.ts +410 -0
- package/src/tools/resume-strategy.ts +345 -0
- package/src/tools/session-content-parser.ts +619 -0
- package/src/tools/session-manager.ts +1026 -0
- package/src/tools/smart-context.ts +228 -0
- package/src/tools/smart-search.ts +2065 -0
- package/src/tools/smart-search.ts.backup +1233 -0
- package/src/tools/storage-manager.ts +455 -0
- package/src/tools/write-file.ts +222 -0
- package/src/types/config.ts +11 -0
- package/src/types/index.ts +3 -0
- package/src/types/session.ts +25 -0
- package/src/types/tool.ts +41 -0
- package/src/utils/browser-launcher.ts +62 -0
- package/src/utils/file-utils.ts +48 -0
- package/src/utils/path-resolver.ts +315 -0
- package/src/utils/path-validator.ts +153 -0
- package/src/utils/ui.ts +155 -0
- package/.claude/agents/action-planning-agent.md +0 -778
- package/.claude/agents/cli-execution-agent.md +0 -270
- package/.claude/agents/cli-explore-agent.md +0 -182
- package/.claude/agents/cli-lite-planning-agent.md +0 -396
- package/.claude/agents/cli-planning-agent.md +0 -558
- package/.claude/agents/code-developer.md +0 -310
- package/.claude/agents/conceptual-planning-agent.md +0 -308
- package/.claude/agents/context-search-agent.md +0 -582
- package/.claude/agents/doc-generator.md +0 -330
- package/.claude/agents/memory-bridge.md +0 -94
- package/.claude/agents/test-context-search-agent.md +0 -399
- package/.claude/agents/test-fix-agent.md +0 -343
- package/.claude/agents/ui-design-agent.md +0 -593
- package/.claude/agents/universal-executor.md +0 -131
- package/.claude/commands/cli/cli-init.md +0 -440
- package/.claude/commands/enhance-prompt.md +0 -93
- package/.claude/commands/memory/code-map-memory.md +0 -687
- package/.claude/commands/memory/docs-full-cli.md +0 -471
- package/.claude/commands/memory/docs-related-cli.md +0 -386
- package/.claude/commands/memory/docs.md +0 -615
- package/.claude/commands/memory/load-skill-memory.md +0 -182
- package/.claude/commands/memory/load.md +0 -240
- package/.claude/commands/memory/skill-memory.md +0 -525
- package/.claude/commands/memory/style-skill-memory.md +0 -396
- package/.claude/commands/memory/tech-research.md +0 -477
- package/.claude/commands/memory/update-full.md +0 -332
- package/.claude/commands/memory/update-related.md +0 -332
- package/.claude/commands/memory/workflow-skill-memory.md +0 -517
- package/.claude/commands/task/breakdown.md +0 -204
- package/.claude/commands/task/create.md +0 -152
- package/.claude/commands/task/execute.md +0 -270
- package/.claude/commands/task/replan.md +0 -437
- package/.claude/commands/version.md +0 -254
- package/.claude/commands/workflow/action-plan-verify.md +0 -447
- package/.claude/commands/workflow/brainstorm/api-designer.md +0 -585
- package/.claude/commands/workflow/brainstorm/artifacts.md +0 -452
- package/.claude/commands/workflow/brainstorm/auto-parallel.md +0 -443
- package/.claude/commands/workflow/brainstorm/data-architect.md +0 -220
- package/.claude/commands/workflow/brainstorm/product-manager.md +0 -200
- package/.claude/commands/workflow/brainstorm/product-owner.md +0 -200
- package/.claude/commands/workflow/brainstorm/scrum-master.md +0 -200
- package/.claude/commands/workflow/brainstorm/subject-matter-expert.md +0 -200
- package/.claude/commands/workflow/brainstorm/synthesis.md +0 -398
- package/.claude/commands/workflow/brainstorm/system-architect.md +0 -387
- package/.claude/commands/workflow/brainstorm/ui-designer.md +0 -221
- package/.claude/commands/workflow/brainstorm/ux-expert.md +0 -221
- package/.claude/commands/workflow/execute.md +0 -460
- package/.claude/commands/workflow/init.md +0 -164
- package/.claude/commands/workflow/lite-execute.md +0 -686
- package/.claude/commands/workflow/lite-fix.md +0 -621
- package/.claude/commands/workflow/lite-plan.md +0 -592
- package/.claude/commands/workflow/plan.md +0 -551
- package/.claude/commands/workflow/replan.md +0 -515
- package/.claude/commands/workflow/review-fix.md +0 -606
- package/.claude/commands/workflow/review-module-cycle.md +0 -765
- package/.claude/commands/workflow/review-session-cycle.md +0 -776
- package/.claude/commands/workflow/review.md +0 -291
- package/.claude/commands/workflow/session/complete.md +0 -500
- package/.claude/commands/workflow/session/list.md +0 -96
- package/.claude/commands/workflow/session/resume.md +0 -61
- package/.claude/commands/workflow/session/start.md +0 -200
- package/.claude/commands/workflow/tdd-plan.md +0 -460
- package/.claude/commands/workflow/tdd-verify.md +0 -386
- package/.claude/commands/workflow/test-cycle-execute.md +0 -498
- package/.claude/commands/workflow/test-fix-gen.md +0 -699
- package/.claude/commands/workflow/test-gen.md +0 -529
- package/.claude/commands/workflow/tools/conflict-resolution.md +0 -680
- package/.claude/commands/workflow/tools/context-gather.md +0 -434
- package/.claude/commands/workflow/tools/task-generate-agent.md +0 -291
- package/.claude/commands/workflow/tools/task-generate-tdd.md +0 -518
- package/.claude/commands/workflow/tools/tdd-coverage-analysis.md +0 -309
- package/.claude/commands/workflow/tools/test-concept-enhanced.md +0 -163
- package/.claude/commands/workflow/tools/test-context-gather.md +0 -235
- package/.claude/commands/workflow/tools/test-task-generate.md +0 -256
- package/.claude/commands/workflow/ui-design/animation-extract.md +0 -1150
- package/.claude/commands/workflow/ui-design/codify-style.md +0 -652
- package/.claude/commands/workflow/ui-design/design-sync.md +0 -454
- package/.claude/commands/workflow/ui-design/explore-auto.md +0 -678
- package/.claude/commands/workflow/ui-design/generate.md +0 -504
- package/.claude/commands/workflow/ui-design/imitate-auto.md +0 -745
- package/.claude/commands/workflow/ui-design/import-from-code.md +0 -537
- package/.claude/commands/workflow/ui-design/layout-extract.md +0 -788
- package/.claude/commands/workflow/ui-design/reference-page-generator.md +0 -356
- package/.claude/commands/workflow/ui-design/style-extract.md +0 -773
- package/.claude/scripts/classify-folders.sh +0 -39
- package/.claude/scripts/convert_tokens_to_css.sh +0 -229
- package/.claude/scripts/detect_changed_modules.sh +0 -161
- package/.claude/scripts/discover-design-files.sh +0 -87
- package/.claude/scripts/extract-animations.js +0 -243
- package/.claude/scripts/extract-computed-styles.js +0 -118
- package/.claude/scripts/extract-layout-structure.js +0 -411
- package/.claude/scripts/generate_module_docs.sh +0 -717
- package/.claude/scripts/get_modules_by_depth.sh +0 -170
- package/.claude/scripts/ui-generate-preview.sh +0 -395
- package/.claude/scripts/ui-instantiate-prototypes.sh +0 -815
- package/.claude/scripts/update_module_claude.sh +0 -337
- package/.claude/skills/command-guide/SKILL.md +0 -388
- package/.claude/skills/command-guide/UPDATE-GUIDELINE.md +0 -592
- package/.claude/skills/command-guide/guides/cli-tools-guide.md +0 -410
- package/.claude/skills/command-guide/guides/examples.md +0 -537
- package/.claude/skills/command-guide/guides/getting-started.md +0 -242
- package/.claude/skills/command-guide/guides/implementation-details.md +0 -1010
- package/.claude/skills/command-guide/guides/index-structure.md +0 -326
- package/.claude/skills/command-guide/guides/troubleshooting.md +0 -92
- package/.claude/skills/command-guide/guides/ui-design-workflow-guide.md +0 -316
- package/.claude/skills/command-guide/guides/workflow-patterns.md +0 -662
- package/.claude/skills/command-guide/index/all-commands.json +0 -772
- package/.claude/skills/command-guide/index/by-category.json +0 -800
- package/.claude/skills/command-guide/index/by-use-case.json +0 -786
- package/.claude/skills/command-guide/index/command-relationships.json +0 -307
- package/.claude/skills/command-guide/index/essential-commands.json +0 -112
- package/.claude/skills/command-guide/reference/agents/action-planning-agent.md +0 -778
- package/.claude/skills/command-guide/reference/agents/cli-execution-agent.md +0 -270
- package/.claude/skills/command-guide/reference/agents/cli-explore-agent.md +0 -182
- package/.claude/skills/command-guide/reference/agents/cli-lite-planning-agent.md +0 -396
- package/.claude/skills/command-guide/reference/agents/cli-planning-agent.md +0 -558
- package/.claude/skills/command-guide/reference/agents/code-developer.md +0 -310
- package/.claude/skills/command-guide/reference/agents/conceptual-planning-agent.md +0 -308
- package/.claude/skills/command-guide/reference/agents/context-search-agent.md +0 -582
- package/.claude/skills/command-guide/reference/agents/doc-generator.md +0 -330
- package/.claude/skills/command-guide/reference/agents/memory-bridge.md +0 -94
- package/.claude/skills/command-guide/reference/agents/test-context-search-agent.md +0 -399
- package/.claude/skills/command-guide/reference/agents/test-fix-agent.md +0 -343
- package/.claude/skills/command-guide/reference/agents/ui-design-agent.md +0 -593
- package/.claude/skills/command-guide/reference/agents/universal-executor.md +0 -131
- package/.claude/skills/command-guide/reference/commands/cli/cli-init.md +0 -440
- package/.claude/skills/command-guide/reference/commands/enhance-prompt.md +0 -93
- package/.claude/skills/command-guide/reference/commands/memory/code-map-memory.md +0 -687
- package/.claude/skills/command-guide/reference/commands/memory/docs-full-cli.md +0 -471
- package/.claude/skills/command-guide/reference/commands/memory/docs-related-cli.md +0 -386
- package/.claude/skills/command-guide/reference/commands/memory/docs.md +0 -615
- package/.claude/skills/command-guide/reference/commands/memory/load-skill-memory.md +0 -182
- package/.claude/skills/command-guide/reference/commands/memory/load.md +0 -240
- package/.claude/skills/command-guide/reference/commands/memory/skill-memory.md +0 -525
- package/.claude/skills/command-guide/reference/commands/memory/style-skill-memory.md +0 -396
- package/.claude/skills/command-guide/reference/commands/memory/tech-research.md +0 -477
- package/.claude/skills/command-guide/reference/commands/memory/update-full.md +0 -332
- package/.claude/skills/command-guide/reference/commands/memory/update-related.md +0 -332
- package/.claude/skills/command-guide/reference/commands/memory/workflow-skill-memory.md +0 -517
- package/.claude/skills/command-guide/reference/commands/task/breakdown.md +0 -204
- package/.claude/skills/command-guide/reference/commands/task/create.md +0 -152
- package/.claude/skills/command-guide/reference/commands/task/execute.md +0 -270
- package/.claude/skills/command-guide/reference/commands/task/replan.md +0 -437
- package/.claude/skills/command-guide/reference/commands/version.md +0 -254
- package/.claude/skills/command-guide/reference/commands/workflow/action-plan-verify.md +0 -447
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/api-designer.md +0 -585
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/artifacts.md +0 -452
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/auto-parallel.md +0 -443
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/data-architect.md +0 -220
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-manager.md +0 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-owner.md +0 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/scrum-master.md +0 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/subject-matter-expert.md +0 -200
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/synthesis.md +0 -398
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/system-architect.md +0 -387
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ui-designer.md +0 -221
- package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ux-expert.md +0 -221
- package/.claude/skills/command-guide/reference/commands/workflow/execute.md +0 -460
- package/.claude/skills/command-guide/reference/commands/workflow/init.md +0 -164
- package/.claude/skills/command-guide/reference/commands/workflow/lite-execute.md +0 -686
- package/.claude/skills/command-guide/reference/commands/workflow/lite-fix.md +0 -621
- package/.claude/skills/command-guide/reference/commands/workflow/lite-plan.md +0 -592
- package/.claude/skills/command-guide/reference/commands/workflow/plan.md +0 -551
- package/.claude/skills/command-guide/reference/commands/workflow/replan.md +0 -515
- package/.claude/skills/command-guide/reference/commands/workflow/review-fix.md +0 -606
- package/.claude/skills/command-guide/reference/commands/workflow/review-module-cycle.md +0 -765
- package/.claude/skills/command-guide/reference/commands/workflow/review-session-cycle.md +0 -776
- package/.claude/skills/command-guide/reference/commands/workflow/review.md +0 -291
- package/.claude/skills/command-guide/reference/commands/workflow/session/complete.md +0 -500
- package/.claude/skills/command-guide/reference/commands/workflow/session/list.md +0 -96
- package/.claude/skills/command-guide/reference/commands/workflow/session/resume.md +0 -61
- package/.claude/skills/command-guide/reference/commands/workflow/session/start.md +0 -200
- package/.claude/skills/command-guide/reference/commands/workflow/tdd-plan.md +0 -460
- package/.claude/skills/command-guide/reference/commands/workflow/tdd-verify.md +0 -386
- package/.claude/skills/command-guide/reference/commands/workflow/test-cycle-execute.md +0 -498
- package/.claude/skills/command-guide/reference/commands/workflow/test-fix-gen.md +0 -699
- package/.claude/skills/command-guide/reference/commands/workflow/test-gen.md +0 -529
- package/.claude/skills/command-guide/reference/commands/workflow/tools/conflict-resolution.md +0 -680
- package/.claude/skills/command-guide/reference/commands/workflow/tools/context-gather.md +0 -434
- package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-agent.md +0 -291
- package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-tdd.md +0 -518
- package/.claude/skills/command-guide/reference/commands/workflow/tools/tdd-coverage-analysis.md +0 -309
- package/.claude/skills/command-guide/reference/commands/workflow/tools/test-concept-enhanced.md +0 -163
- package/.claude/skills/command-guide/reference/commands/workflow/tools/test-context-gather.md +0 -235
- package/.claude/skills/command-guide/reference/commands/workflow/tools/test-task-generate.md +0 -256
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/animation-extract.md +0 -1150
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/codify-style.md +0 -652
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/design-sync.md +0 -454
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/explore-auto.md +0 -678
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/generate.md +0 -504
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/imitate-auto.md +0 -745
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/import-from-code.md +0 -537
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/layout-extract.md +0 -788
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/reference-page-generator.md +0 -356
- package/.claude/skills/command-guide/reference/commands/workflow/ui-design/style-extract.md +0 -773
- package/.claude/skills/command-guide/scripts/analyze_commands.py +0 -502
- package/.claude/skills/command-guide/scripts/update-index.sh +0 -130
- package/.claude/skills/command-guide/templates/issue-bug.md +0 -104
- package/.claude/skills/command-guide/templates/issue-diagnosis.md +0 -275
- package/.claude/skills/command-guide/templates/issue-feature.md +0 -97
- package/.claude/skills/command-guide/templates/issue-question.md +0 -141
- package/.claude/skills/prompt-enhancer/SKILL.md +0 -124
- package/.claude/workflows/_template-compare-matrix.html +0 -692
- package/.claude/workflows/cli-templates/fix-plan-template.json +0 -75
- package/.claude/workflows/cli-templates/fix-progress-template.json +0 -48
- package/.claude/workflows/cli-templates/memory/style-skill-memory/skill-md-template.md +0 -299
- package/.claude/workflows/cli-templates/planning-roles/data-architect.md +0 -120
- package/.claude/workflows/cli-templates/planning-roles/product-manager.md +0 -119
- package/.claude/workflows/cli-templates/planning-roles/product-owner.md +0 -261
- package/.claude/workflows/cli-templates/planning-roles/scrum-master.md +0 -186
- package/.claude/workflows/cli-templates/planning-roles/subject-matter-expert.md +0 -281
- package/.claude/workflows/cli-templates/planning-roles/synthesis-role.md +0 -414
- package/.claude/workflows/cli-templates/planning-roles/system-architect.md +0 -106
- package/.claude/workflows/cli-templates/planning-roles/test-strategist.md +0 -124
- package/.claude/workflows/cli-templates/planning-roles/ui-designer.md +0 -379
- package/.claude/workflows/cli-templates/planning-roles/ux-expert.md +0 -240
- package/.claude/workflows/cli-templates/prompts/analysis/01-diagnose-bug-root-cause.txt +0 -127
- package/.claude/workflows/cli-templates/prompts/analysis/01-trace-code-execution.txt +0 -115
- package/.claude/workflows/cli-templates/prompts/analysis/02-analyze-code-patterns.txt +0 -37
- package/.claude/workflows/cli-templates/prompts/analysis/02-analyze-technical-document.txt +0 -33
- package/.claude/workflows/cli-templates/prompts/analysis/02-review-architecture.txt +0 -29
- package/.claude/workflows/cli-templates/prompts/analysis/02-review-code-quality.txt +0 -28
- package/.claude/workflows/cli-templates/prompts/analysis/03-analyze-performance.txt +0 -29
- package/.claude/workflows/cli-templates/prompts/analysis/03-assess-security-risks.txt +0 -29
- package/.claude/workflows/cli-templates/prompts/analysis/03-review-quality-standards.txt +0 -29
- package/.claude/workflows/cli-templates/prompts/development/02-generate-tests.txt +0 -70
- package/.claude/workflows/cli-templates/prompts/development/02-implement-component-ui.txt +0 -55
- package/.claude/workflows/cli-templates/prompts/development/02-implement-feature.txt +0 -58
- package/.claude/workflows/cli-templates/prompts/development/02-refactor-codebase.txt +0 -55
- package/.claude/workflows/cli-templates/prompts/development/03-debug-runtime-issues.txt +0 -55
- package/.claude/workflows/cli-templates/prompts/documentation/api.txt +0 -15
- package/.claude/workflows/cli-templates/prompts/documentation/folder-navigation.txt +0 -27
- package/.claude/workflows/cli-templates/prompts/documentation/module-readme.txt +0 -49
- package/.claude/workflows/cli-templates/prompts/documentation/project-architecture.txt +0 -41
- package/.claude/workflows/cli-templates/prompts/documentation/project-examples.txt +0 -35
- package/.claude/workflows/cli-templates/prompts/documentation/project-readme.txt +0 -35
- package/.claude/workflows/cli-templates/prompts/memory/02-document-module-structure.txt +0 -165
- package/.claude/workflows/cli-templates/prompts/planning/01-plan-architecture-design.txt +0 -109
- package/.claude/workflows/cli-templates/prompts/planning/02-breakdown-task-steps.txt +0 -30
- package/.claude/workflows/cli-templates/prompts/planning/02-design-component-spec.txt +0 -28
- package/.claude/workflows/cli-templates/prompts/planning/03-evaluate-concept-feasibility.txt +0 -127
- package/.claude/workflows/cli-templates/prompts/planning/03-plan-migration-strategy.txt +0 -30
- package/.claude/workflows/cli-templates/prompts/tech/tech-module-format.txt +0 -359
- package/.claude/workflows/cli-templates/prompts/tech/tech-skill-index.txt +0 -185
- package/.claude/workflows/cli-templates/prompts/test/test-concept-analysis.txt +0 -179
- package/.claude/workflows/cli-templates/prompts/universal/00-universal-creative-style.txt +0 -95
- package/.claude/workflows/cli-templates/prompts/universal/00-universal-rigorous-style.txt +0 -92
- package/.claude/workflows/cli-templates/prompts/verification/codex-technical.txt +0 -28
- package/.claude/workflows/cli-templates/prompts/verification/cross-validation.txt +0 -28
- package/.claude/workflows/cli-templates/prompts/verification/gemini-strategic.txt +0 -27
- package/.claude/workflows/cli-templates/prompts/workflow/analysis-results-structure.txt +0 -224
- package/.claude/workflows/cli-templates/prompts/workflow/codex-feasibility-validation.txt +0 -176
- package/.claude/workflows/cli-templates/prompts/workflow/gemini-solution-design.txt +0 -131
- package/.claude/workflows/cli-templates/prompts/workflow/impl-plan-template.txt +0 -286
- package/.claude/workflows/cli-templates/prompts/workflow/skill-aggregation.txt +0 -172
- package/.claude/workflows/cli-templates/prompts/workflow/skill-conflict-patterns.txt +0 -98
- package/.claude/workflows/cli-templates/prompts/workflow/skill-index.txt +0 -224
- package/.claude/workflows/cli-templates/prompts/workflow/skill-lessons-learned.txt +0 -98
- package/.claude/workflows/cli-templates/prompts/workflow/skill-sessions-timeline.txt +0 -53
- package/.claude/workflows/cli-templates/prompts/workflow/task-json-agent-mode.txt +0 -123
- package/.claude/workflows/cli-templates/prompts/workflow/task-json-cli-mode.txt +0 -182
- package/.claude/workflows/cli-templates/schemas/diagnosis-json-schema.json +0 -234
- package/.claude/workflows/cli-templates/schemas/explore-json-schema.json +0 -124
- package/.claude/workflows/cli-templates/schemas/fix-plan-json-schema.json +0 -273
- package/.claude/workflows/cli-templates/schemas/plan-json-schema.json +0 -219
- package/.claude/workflows/cli-templates/schemas/project-json-schema.json +0 -221
- package/.claude/workflows/cli-templates/schemas/review-deep-dive-results-schema.json +0 -82
- package/.claude/workflows/cli-templates/schemas/review-dimension-results-schema.json +0 -51
- package/.claude/workflows/cli-templates/tech-stacks/go-dev.md +0 -91
- package/.claude/workflows/cli-templates/tech-stacks/java-dev.md +0 -107
- package/.claude/workflows/cli-templates/tech-stacks/javascript-dev.md +0 -58
- package/.claude/workflows/cli-templates/tech-stacks/python-dev.md +0 -79
- package/.claude/workflows/cli-templates/tech-stacks/react-dev.md +0 -103
- package/.claude/workflows/cli-templates/tech-stacks/typescript-dev.md +0 -83
- package/.claude/workflows/cli-templates/ui-design/systems/animation-tokens.json +0 -247
- package/.claude/workflows/cli-templates/ui-design/systems/design-tokens.json +0 -342
- package/.claude/workflows/cli-templates/ui-design/systems/layout-templates.json +0 -145
- package/.claude/workflows/context-search-strategy.md +0 -77
- package/.claude/workflows/intelligent-tools-strategy.md +0 -662
- package/.claude/workflows/review-directory-specification.md +0 -336
- package/.claude/workflows/task-core.md +0 -214
- package/.claude/workflows/tool-strategy.md +0 -79
- package/.claude/workflows/workflow-architecture.md +0 -942
- package/.codex/AGENTS.md +0 -330
- package/.gemini/GEMINI.md +0 -164
- package/.qwen/QWEN.md +0 -164
- package/CLAUDE.md +0 -91
- package/LICENSE +0 -21
- package/ccw/README.md +0 -121
- package/ccw/bin/ccw.js +0 -10
- package/ccw/package.json +0 -47
- package/ccw/src/cli.js +0 -119
- package/ccw/src/commands/install.js +0 -324
- package/ccw/src/commands/list.js +0 -37
- package/ccw/src/commands/serve.js +0 -67
- package/ccw/src/commands/stop.js +0 -101
- package/ccw/src/commands/tool.js +0 -138
- package/ccw/src/commands/uninstall.js +0 -238
- package/ccw/src/commands/upgrade.js +0 -307
- package/ccw/src/commands/view.js +0 -105
- package/ccw/src/core/dashboard-generator-patch.js +0 -29
- package/ccw/src/core/dashboard-generator.js +0 -682
- package/ccw/src/core/data-aggregator.js +0 -409
- package/ccw/src/core/lite-scanner.js +0 -314
- package/ccw/src/core/manifest.js +0 -201
- package/ccw/src/core/server.js +0 -2063
- package/ccw/src/core/session-scanner.js +0 -235
- package/ccw/src/index.js +0 -9
- package/ccw/src/templates/dashboard-css/01-base.css +0 -291
- package/ccw/src/templates/dashboard-css/02-session.css +0 -726
- package/ccw/src/templates/dashboard-css/04-lite-tasks.css +0 -843
- package/ccw/src/templates/dashboard-css/06-cards.css +0 -1570
- package/ccw/src/templates/dashboard-css/07-managers.css +0 -936
- package/ccw/src/templates/dashboard-css/09-explorer.css +0 -1397
- package/ccw/src/templates/dashboard-js/api.js +0 -200
- package/ccw/src/templates/dashboard-js/components/carousel.js +0 -398
- package/ccw/src/templates/dashboard-js/components/global-notifications.js +0 -219
- package/ccw/src/templates/dashboard-js/components/hook-manager.js +0 -283
- package/ccw/src/templates/dashboard-js/components/mcp-manager.js +0 -528
- package/ccw/src/templates/dashboard-js/components/modals.js +0 -260
- package/ccw/src/templates/dashboard-js/components/navigation.js +0 -245
- package/ccw/src/templates/dashboard-js/components/notifications.js +0 -194
- package/ccw/src/templates/dashboard-js/components/tabs-other.js +0 -273
- package/ccw/src/templates/dashboard-js/main.js +0 -72
- package/ccw/src/templates/dashboard-js/state.js +0 -42
- package/ccw/src/templates/dashboard-js/utils.js +0 -153
- package/ccw/src/templates/dashboard-js/views/explorer.js +0 -852
- package/ccw/src/templates/dashboard-js/views/home.js +0 -197
- package/ccw/src/templates/dashboard-js/views/hook-manager.js +0 -392
- package/ccw/src/templates/dashboard-js/views/lite-tasks.js +0 -395
- package/ccw/src/templates/dashboard-js/views/mcp-manager.js +0 -411
- package/ccw/src/templates/dashboard-js/views/session-detail.js +0 -780
- package/ccw/src/templates/dashboard.html +0 -731
- package/ccw/src/tools/classify-folders.js +0 -204
- package/ccw/src/tools/convert-tokens-to-css.js +0 -250
- package/ccw/src/tools/detect-changed-modules.js +0 -288
- package/ccw/src/tools/discover-design-files.js +0 -134
- package/ccw/src/tools/edit-file.js +0 -266
- package/ccw/src/tools/generate-module-docs.js +0 -416
- package/ccw/src/tools/get-modules-by-depth.js +0 -308
- package/ccw/src/tools/index.js +0 -176
- package/ccw/src/utils/browser-launcher.js +0 -60
- package/ccw/src/utils/file-utils.js +0 -48
- package/ccw/src/utils/path-resolver.js +0 -279
- package/ccw/src/utils/ui.js +0 -148
- /package/{ccw/src → src}/templates/dashboard-css/03-tasks.css +0 -0
- /package/{ccw/src → src}/templates/dashboard-css/05-context.css +0 -0
- /package/{ccw/src → src}/templates/dashboard-css/08-review.css +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/components/_conflict_tab.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/components/_exp_helpers.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/components/_review_tab.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/components/flowchart.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/components/sidebar.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/components/tabs-context.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/components/task-drawer-core.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/components/task-drawer-renderers.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/components/theme.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/components/version-check.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/views/fix-session.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/views/project-overview.js +0 -0
- /package/{ccw/src → src}/templates/dashboard-js/views/review-session.js +0 -0
- /package/{ccw/src → src}/templates/review-cycle-dashboard.html +0 -0
- /package/{ccw/src → src}/templates/workflow-dashboard.html +0 -0
- /package/{ccw/src → src}/tools/ui-generate-preview.js +0 -0
- /package/{ccw/src → src}/tools/ui-instantiate-prototypes.js +0 -0
- /package/{ccw/src → src}/tools/update-module-claude.js +0 -0
|
@@ -0,0 +1,1233 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Smart Search Tool - Unified intelligent search with CodexLens integration
|
|
3
|
+
*
|
|
4
|
+
* Features:
|
|
5
|
+
* - Intent classification with automatic mode selection
|
|
6
|
+
* - CodexLens integration (init, hybrid, vector, semantic)
|
|
7
|
+
* - Ripgrep fallback for exact mode
|
|
8
|
+
* - Index status checking and warnings
|
|
9
|
+
* - Multi-backend search routing with RRF ranking
|
|
10
|
+
*
|
|
11
|
+
* Actions:
|
|
12
|
+
* - init: Initialize CodexLens index
|
|
13
|
+
* - search: Intelligent search with auto mode selection
|
|
14
|
+
* - status: Check index status
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
import { z } from 'zod';
|
|
18
|
+
import type { ToolSchema, ToolResult } from '../types/tool.js';
|
|
19
|
+
import { spawn, execSync } from 'child_process';
|
|
20
|
+
import {
|
|
21
|
+
ensureReady as ensureCodexLensReady,
|
|
22
|
+
executeCodexLens,
|
|
23
|
+
} from './codex-lens.js';
|
|
24
|
+
import type { ProgressInfo } from './codex-lens.js';
|
|
25
|
+
|
|
26
|
+
// Define Zod schema for validation
|
|
27
|
+
const ParamsSchema = z.object({
|
|
28
|
+
action: z.enum(['init', 'search', 'search_files', 'status']).default('search'),
|
|
29
|
+
query: z.string().optional(),
|
|
30
|
+
mode: z.enum(['auto', 'hybrid', 'exact', 'ripgrep', 'priority']).default('auto'),
|
|
31
|
+
output_mode: z.enum(['full', 'files_only', 'count']).default('full'),
|
|
32
|
+
path: z.string().optional(),
|
|
33
|
+
paths: z.array(z.string()).default([]),
|
|
34
|
+
contextLines: z.number().default(0),
|
|
35
|
+
maxResults: z.number().default(10),
|
|
36
|
+
includeHidden: z.boolean().default(false),
|
|
37
|
+
languages: z.array(z.string()).optional(),
|
|
38
|
+
limit: z.number().default(10),
|
|
39
|
+
enrich: z.boolean().default(false),
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
type Params = z.infer<typeof ParamsSchema>;
|
|
43
|
+
|
|
44
|
+
// Search mode constants
|
|
45
|
+
const SEARCH_MODES = ['auto', 'hybrid', 'exact', 'ripgrep', 'priority'] as const;
|
|
46
|
+
|
|
47
|
+
// Classification confidence threshold
|
|
48
|
+
const CONFIDENCE_THRESHOLD = 0.7;
|
|
49
|
+
|
|
50
|
+
interface Classification {
|
|
51
|
+
mode: string;
|
|
52
|
+
confidence: number;
|
|
53
|
+
reasoning: string;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
interface ExactMatch {
|
|
57
|
+
file: string;
|
|
58
|
+
line: number;
|
|
59
|
+
column: number;
|
|
60
|
+
content: string;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
interface RelationshipInfo {
|
|
64
|
+
type: string; // 'calls', 'imports', 'called_by', 'imported_by'
|
|
65
|
+
direction: 'outgoing' | 'incoming';
|
|
66
|
+
target?: string; // Target symbol name (for outgoing)
|
|
67
|
+
source?: string; // Source symbol name (for incoming)
|
|
68
|
+
file: string; // File path
|
|
69
|
+
line?: number; // Line number
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
interface SemanticMatch {
|
|
73
|
+
file: string;
|
|
74
|
+
score: number;
|
|
75
|
+
content: string;
|
|
76
|
+
symbol: string | null;
|
|
77
|
+
relationships?: RelationshipInfo[];
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
interface GraphMatch {
|
|
81
|
+
file: string;
|
|
82
|
+
symbols: unknown;
|
|
83
|
+
relationships: unknown[];
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
interface SearchMetadata {
|
|
87
|
+
mode?: string;
|
|
88
|
+
backend?: string;
|
|
89
|
+
count?: number;
|
|
90
|
+
query?: string;
|
|
91
|
+
classified_as?: string;
|
|
92
|
+
confidence?: number;
|
|
93
|
+
reasoning?: string;
|
|
94
|
+
embeddings_coverage_percent?: number;
|
|
95
|
+
warning?: string;
|
|
96
|
+
note?: string;
|
|
97
|
+
index_status?: 'indexed' | 'not_indexed' | 'partial';
|
|
98
|
+
fallback_history?: string[];
|
|
99
|
+
// Init action specific
|
|
100
|
+
action?: string;
|
|
101
|
+
path?: string;
|
|
102
|
+
progress?: {
|
|
103
|
+
stage: string;
|
|
104
|
+
message: string;
|
|
105
|
+
percent: number;
|
|
106
|
+
filesProcessed?: number;
|
|
107
|
+
totalFiles?: number;
|
|
108
|
+
};
|
|
109
|
+
progressHistory?: ProgressInfo[];
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
interface SearchResult {
|
|
113
|
+
success: boolean;
|
|
114
|
+
results?: ExactMatch[] | SemanticMatch[] | GraphMatch[] | unknown;
|
|
115
|
+
output?: string;
|
|
116
|
+
metadata?: SearchMetadata;
|
|
117
|
+
error?: string;
|
|
118
|
+
status?: unknown;
|
|
119
|
+
message?: string;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
interface IndexStatus {
|
|
123
|
+
indexed: boolean;
|
|
124
|
+
has_embeddings: boolean;
|
|
125
|
+
file_count?: number;
|
|
126
|
+
embeddings_coverage_percent?: number;
|
|
127
|
+
warning?: string;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
/**
|
|
131
|
+
* Strip ANSI color codes from string (for JSON parsing)
|
|
132
|
+
*/
|
|
133
|
+
function stripAnsi(str: string): string {
|
|
134
|
+
return str.replace(/\x1b\[[0-9;]*m/g, '');
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Check if CodexLens index exists for current directory
|
|
139
|
+
* @param path - Directory path to check
|
|
140
|
+
* @returns Index status
|
|
141
|
+
*/
|
|
142
|
+
async function checkIndexStatus(path: string = '.'): Promise<IndexStatus> {
|
|
143
|
+
try {
|
|
144
|
+
const result = await executeCodexLens(['status', '--json'], { cwd: path });
|
|
145
|
+
|
|
146
|
+
if (!result.success) {
|
|
147
|
+
return {
|
|
148
|
+
indexed: false,
|
|
149
|
+
has_embeddings: false,
|
|
150
|
+
warning: 'No CodexLens index found. Run smart_search(action="init") to create index for better search results.',
|
|
151
|
+
};
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
// Parse status output
|
|
155
|
+
try {
|
|
156
|
+
// Strip ANSI color codes from JSON output
|
|
157
|
+
const cleanOutput = stripAnsi(result.output || '{}');
|
|
158
|
+
const parsed = JSON.parse(cleanOutput);
|
|
159
|
+
// Handle both direct and nested response formats (status returns {success, result: {...}})
|
|
160
|
+
const status = parsed.result || parsed;
|
|
161
|
+
const indexed = status.projects_count > 0 || status.total_files > 0;
|
|
162
|
+
|
|
163
|
+
// Get embeddings coverage from comprehensive status
|
|
164
|
+
const embeddingsData = status.embeddings || {};
|
|
165
|
+
const embeddingsCoverage = embeddingsData.coverage_percent || 0;
|
|
166
|
+
const has_embeddings = embeddingsCoverage >= 50; // Threshold: 50%
|
|
167
|
+
|
|
168
|
+
let warning: string | undefined;
|
|
169
|
+
if (!indexed) {
|
|
170
|
+
warning = 'No CodexLens index found. Run smart_search(action="init") to create index for better search results.';
|
|
171
|
+
} else if (embeddingsCoverage === 0) {
|
|
172
|
+
warning = 'Index exists but no embeddings generated. Run: codexlens embeddings-generate --recursive';
|
|
173
|
+
} else if (embeddingsCoverage < 50) {
|
|
174
|
+
warning = `Embeddings coverage is ${embeddingsCoverage.toFixed(1)}% (below 50%). Hybrid search will use exact mode. Run: codexlens embeddings-generate --recursive`;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
return {
|
|
178
|
+
indexed,
|
|
179
|
+
has_embeddings,
|
|
180
|
+
file_count: status.total_files,
|
|
181
|
+
embeddings_coverage_percent: embeddingsCoverage,
|
|
182
|
+
warning,
|
|
183
|
+
};
|
|
184
|
+
} catch {
|
|
185
|
+
return {
|
|
186
|
+
indexed: false,
|
|
187
|
+
has_embeddings: false,
|
|
188
|
+
warning: 'Failed to parse index status',
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
} catch {
|
|
192
|
+
return {
|
|
193
|
+
indexed: false,
|
|
194
|
+
has_embeddings: false,
|
|
195
|
+
warning: 'CodexLens not available',
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
/**
|
|
201
|
+
* Detection heuristics for intent classification
|
|
202
|
+
*/
|
|
203
|
+
|
|
204
|
+
/**
|
|
205
|
+
* Detect literal string query (simple alphanumeric or quoted strings)
|
|
206
|
+
*/
|
|
207
|
+
function detectLiteral(query: string): boolean {
|
|
208
|
+
return /^[a-zA-Z0-9_-]+$/.test(query) || /^["'].*["']$/.test(query);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
/**
|
|
212
|
+
* Detect regex pattern (contains regex metacharacters)
|
|
213
|
+
*/
|
|
214
|
+
function detectRegex(query: string): boolean {
|
|
215
|
+
return /[.*+?^${}()|[\]\\]/.test(query);
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
/**
|
|
219
|
+
* Detect natural language query (sentence structure, questions, multi-word phrases)
|
|
220
|
+
*/
|
|
221
|
+
function detectNaturalLanguage(query: string): boolean {
|
|
222
|
+
return query.split(/\s+/).length >= 3 || /\?$/.test(query);
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
/**
|
|
226
|
+
* Detect file path query (path separators, file extensions)
|
|
227
|
+
*/
|
|
228
|
+
function detectFilePath(query: string): boolean {
|
|
229
|
+
return /[/\\]/.test(query) || /\.[a-z]{2,4}$/i.test(query);
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
/**
|
|
233
|
+
* Detect relationship query (import, export, dependency keywords)
|
|
234
|
+
*/
|
|
235
|
+
function detectRelationship(query: string): boolean {
|
|
236
|
+
return /(import|export|uses?|depends?|calls?|extends?)\s/i.test(query);
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
/**
|
|
240
|
+
* Classify query intent and recommend search mode
|
|
241
|
+
* Simple mapping: hybrid (NL + index + embeddings) | exact (index or insufficient embeddings) | ripgrep (no index)
|
|
242
|
+
* @param query - Search query string
|
|
243
|
+
* @param hasIndex - Whether CodexLens index exists
|
|
244
|
+
* @param hasSufficientEmbeddings - Whether embeddings coverage >= 50%
|
|
245
|
+
* @returns Classification result
|
|
246
|
+
*/
|
|
247
|
+
function classifyIntent(query: string, hasIndex: boolean = false, hasSufficientEmbeddings: boolean = false): Classification {
|
|
248
|
+
// Detect query patterns
|
|
249
|
+
const isNaturalLanguage = detectNaturalLanguage(query);
|
|
250
|
+
|
|
251
|
+
// Simple decision tree
|
|
252
|
+
let mode: string;
|
|
253
|
+
let confidence: number;
|
|
254
|
+
|
|
255
|
+
if (!hasIndex) {
|
|
256
|
+
// No index: use ripgrep
|
|
257
|
+
mode = 'ripgrep';
|
|
258
|
+
confidence = 1.0;
|
|
259
|
+
} else if (isNaturalLanguage && hasSufficientEmbeddings) {
|
|
260
|
+
// Natural language + sufficient embeddings: use hybrid
|
|
261
|
+
mode = 'hybrid';
|
|
262
|
+
confidence = 0.9;
|
|
263
|
+
} else {
|
|
264
|
+
// Simple query OR insufficient embeddings: use exact
|
|
265
|
+
mode = 'exact';
|
|
266
|
+
confidence = 0.8;
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
// Build reasoning string
|
|
270
|
+
const detectedPatterns: string[] = [];
|
|
271
|
+
if (detectLiteral(query)) detectedPatterns.push('literal');
|
|
272
|
+
if (detectRegex(query)) detectedPatterns.push('regex');
|
|
273
|
+
if (detectNaturalLanguage(query)) detectedPatterns.push('natural language');
|
|
274
|
+
if (detectFilePath(query)) detectedPatterns.push('file path');
|
|
275
|
+
if (detectRelationship(query)) detectedPatterns.push('relationship');
|
|
276
|
+
|
|
277
|
+
const reasoning = `Query classified as ${mode} (confidence: ${confidence.toFixed(2)}, detected: ${detectedPatterns.join(', ')}, index: ${hasIndex ? 'available' : 'not available'}, embeddings: ${hasSufficientEmbeddings ? 'sufficient' : 'insufficient'})`;
|
|
278
|
+
|
|
279
|
+
return { mode, confidence, reasoning };
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
/**
|
|
283
|
+
* Check if a tool is available in PATH
|
|
284
|
+
* @param toolName - Tool executable name
|
|
285
|
+
* @returns True if available
|
|
286
|
+
*/
|
|
287
|
+
function checkToolAvailability(toolName: string): boolean {
|
|
288
|
+
try {
|
|
289
|
+
const isWindows = process.platform === 'win32';
|
|
290
|
+
const command = isWindows ? 'where' : 'which';
|
|
291
|
+
execSync(`${command} ${toolName}`, { stdio: 'ignore' });
|
|
292
|
+
return true;
|
|
293
|
+
} catch {
|
|
294
|
+
return false;
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
/**
|
|
299
|
+
* Build ripgrep command arguments
|
|
300
|
+
* @param params - Search parameters
|
|
301
|
+
* @returns Command and arguments
|
|
302
|
+
*/
|
|
303
|
+
function buildRipgrepCommand(params: {
|
|
304
|
+
query: string;
|
|
305
|
+
paths: string[];
|
|
306
|
+
contextLines: number;
|
|
307
|
+
maxResults: number;
|
|
308
|
+
includeHidden: boolean;
|
|
309
|
+
}): { command: string; args: string[] } {
|
|
310
|
+
const { query, paths = ['.'], contextLines = 0, maxResults = 10, includeHidden = false } = params;
|
|
311
|
+
|
|
312
|
+
const args = [
|
|
313
|
+
'-n', // Show line numbers
|
|
314
|
+
'--color=never', // Disable color output
|
|
315
|
+
'--json', // Output in JSON format
|
|
316
|
+
];
|
|
317
|
+
|
|
318
|
+
// Add context lines if specified
|
|
319
|
+
if (contextLines > 0) {
|
|
320
|
+
args.push('-C', contextLines.toString());
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
// Add max results limit
|
|
324
|
+
if (maxResults > 0) {
|
|
325
|
+
args.push('--max-count', maxResults.toString());
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
// Include hidden files if specified
|
|
329
|
+
if (includeHidden) {
|
|
330
|
+
args.push('--hidden');
|
|
331
|
+
}
|
|
332
|
+
|
|
333
|
+
// Use literal/fixed string matching for exact mode
|
|
334
|
+
args.push('-F', query);
|
|
335
|
+
|
|
336
|
+
// Add search paths
|
|
337
|
+
args.push(...paths);
|
|
338
|
+
|
|
339
|
+
return { command: 'rg', args };
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
/**
|
|
343
|
+
* Action: init - Initialize CodexLens index (FTS only, no embeddings)
|
|
344
|
+
* For semantic/vector search, use ccw view dashboard or codexlens CLI directly
|
|
345
|
+
*/
|
|
346
|
+
async function executeInitAction(params: Params): Promise<SearchResult> {
|
|
347
|
+
const { path = '.', languages } = params;
|
|
348
|
+
|
|
349
|
+
// Check CodexLens availability
|
|
350
|
+
const readyStatus = await ensureCodexLensReady();
|
|
351
|
+
if (!readyStatus.ready) {
|
|
352
|
+
return {
|
|
353
|
+
success: false,
|
|
354
|
+
error: `CodexLens not available: ${readyStatus.error}. CodexLens will be auto-installed on first use.`,
|
|
355
|
+
};
|
|
356
|
+
}
|
|
357
|
+
|
|
358
|
+
// Build args with --no-embeddings for FTS-only index (faster)
|
|
359
|
+
const args = ['init', path, '--no-embeddings'];
|
|
360
|
+
if (languages && languages.length > 0) {
|
|
361
|
+
args.push('--languages', languages.join(','));
|
|
362
|
+
}
|
|
363
|
+
|
|
364
|
+
// Track progress updates
|
|
365
|
+
const progressUpdates: ProgressInfo[] = [];
|
|
366
|
+
let lastProgress: ProgressInfo | null = null;
|
|
367
|
+
|
|
368
|
+
const result = await executeCodexLens(args, {
|
|
369
|
+
cwd: path,
|
|
370
|
+
timeout: 1800000, // 30 minutes for large codebases
|
|
371
|
+
onProgress: (progress: ProgressInfo) => {
|
|
372
|
+
progressUpdates.push(progress);
|
|
373
|
+
lastProgress = progress;
|
|
374
|
+
},
|
|
375
|
+
});
|
|
376
|
+
|
|
377
|
+
// Build metadata with progress info
|
|
378
|
+
const metadata: SearchMetadata = {
|
|
379
|
+
action: 'init',
|
|
380
|
+
path,
|
|
381
|
+
};
|
|
382
|
+
|
|
383
|
+
if (lastProgress !== null) {
|
|
384
|
+
const p = lastProgress as ProgressInfo;
|
|
385
|
+
metadata.progress = {
|
|
386
|
+
stage: p.stage,
|
|
387
|
+
message: p.message,
|
|
388
|
+
percent: p.percent,
|
|
389
|
+
filesProcessed: p.filesProcessed,
|
|
390
|
+
totalFiles: p.totalFiles,
|
|
391
|
+
};
|
|
392
|
+
}
|
|
393
|
+
|
|
394
|
+
if (progressUpdates.length > 0) {
|
|
395
|
+
metadata.progressHistory = progressUpdates.slice(-5); // Keep last 5 progress updates
|
|
396
|
+
}
|
|
397
|
+
|
|
398
|
+
const successMessage = result.success
|
|
399
|
+
? `FTS index created for ${path}. Note: For semantic/vector search, create vector index via "ccw view" dashboard or run "codexlens init ${path}" (without --no-embeddings).`
|
|
400
|
+
: undefined;
|
|
401
|
+
|
|
402
|
+
return {
|
|
403
|
+
success: result.success,
|
|
404
|
+
error: result.error,
|
|
405
|
+
message: successMessage,
|
|
406
|
+
metadata,
|
|
407
|
+
};
|
|
408
|
+
}
|
|
409
|
+
|
|
410
|
+
/**
|
|
411
|
+
* Action: status - Check CodexLens index status
|
|
412
|
+
*/
|
|
413
|
+
async function executeStatusAction(params: Params): Promise<SearchResult> {
|
|
414
|
+
const { path = '.' } = params;
|
|
415
|
+
|
|
416
|
+
const indexStatus = await checkIndexStatus(path);
|
|
417
|
+
|
|
418
|
+
return {
|
|
419
|
+
success: true,
|
|
420
|
+
status: indexStatus,
|
|
421
|
+
message: indexStatus.warning || `Index status: ${indexStatus.indexed ? 'indexed' : 'not indexed'}, embeddings: ${indexStatus.has_embeddings ? 'available' : 'not available'}`,
|
|
422
|
+
};
|
|
423
|
+
}
|
|
424
|
+
|
|
425
|
+
/**
|
|
426
|
+
* Mode: auto - Intent classification and mode selection
|
|
427
|
+
* Routes to: hybrid (NL + index) | exact (index) | ripgrep (no index)
|
|
428
|
+
*/
|
|
429
|
+
async function executeAutoMode(params: Params): Promise<SearchResult> {
|
|
430
|
+
const { query, path = '.' } = params;
|
|
431
|
+
|
|
432
|
+
if (!query) {
|
|
433
|
+
return {
|
|
434
|
+
success: false,
|
|
435
|
+
error: 'Query is required for search action',
|
|
436
|
+
};
|
|
437
|
+
}
|
|
438
|
+
|
|
439
|
+
// Check index status
|
|
440
|
+
const indexStatus = await checkIndexStatus(path);
|
|
441
|
+
|
|
442
|
+
// Classify intent with index and embeddings awareness
|
|
443
|
+
const classification = classifyIntent(
|
|
444
|
+
query,
|
|
445
|
+
indexStatus.indexed,
|
|
446
|
+
indexStatus.has_embeddings // This now considers 50% threshold
|
|
447
|
+
);
|
|
448
|
+
|
|
449
|
+
// Route to appropriate mode based on classification
|
|
450
|
+
let result: SearchResult;
|
|
451
|
+
|
|
452
|
+
switch (classification.mode) {
|
|
453
|
+
case 'hybrid':
|
|
454
|
+
result = await executeHybridMode(params);
|
|
455
|
+
break;
|
|
456
|
+
|
|
457
|
+
case 'exact':
|
|
458
|
+
result = await executeCodexLensExactMode(params);
|
|
459
|
+
break;
|
|
460
|
+
|
|
461
|
+
case 'ripgrep':
|
|
462
|
+
result = await executeRipgrepMode(params);
|
|
463
|
+
break;
|
|
464
|
+
|
|
465
|
+
default:
|
|
466
|
+
// Fallback to ripgrep
|
|
467
|
+
result = await executeRipgrepMode(params);
|
|
468
|
+
break;
|
|
469
|
+
}
|
|
470
|
+
|
|
471
|
+
// Add classification metadata
|
|
472
|
+
if (result.metadata) {
|
|
473
|
+
result.metadata.classified_as = classification.mode;
|
|
474
|
+
result.metadata.confidence = classification.confidence;
|
|
475
|
+
result.metadata.reasoning = classification.reasoning;
|
|
476
|
+
result.metadata.embeddings_coverage_percent = indexStatus.embeddings_coverage_percent;
|
|
477
|
+
result.metadata.index_status = indexStatus.indexed
|
|
478
|
+
? (indexStatus.has_embeddings ? 'indexed' : 'partial')
|
|
479
|
+
: 'not_indexed';
|
|
480
|
+
|
|
481
|
+
// Add warning if needed
|
|
482
|
+
if (indexStatus.warning) {
|
|
483
|
+
result.metadata.warning = indexStatus.warning;
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
|
|
487
|
+
return result;
|
|
488
|
+
}
|
|
489
|
+
|
|
490
|
+
/**
|
|
491
|
+
* Mode: ripgrep - Fast literal string matching using ripgrep
|
|
492
|
+
* No index required, fallback to CodexLens if ripgrep unavailable
|
|
493
|
+
*/
|
|
494
|
+
async function executeRipgrepMode(params: Params): Promise<SearchResult> {
|
|
495
|
+
const { query, paths = [], contextLines = 0, maxResults = 10, includeHidden = false, path = '.' } = params;
|
|
496
|
+
|
|
497
|
+
if (!query) {
|
|
498
|
+
return {
|
|
499
|
+
success: false,
|
|
500
|
+
error: 'Query is required for search',
|
|
501
|
+
};
|
|
502
|
+
}
|
|
503
|
+
|
|
504
|
+
// Check if ripgrep is available
|
|
505
|
+
const hasRipgrep = checkToolAvailability('rg');
|
|
506
|
+
|
|
507
|
+
// If ripgrep not available, fall back to CodexLens exact mode
|
|
508
|
+
if (!hasRipgrep) {
|
|
509
|
+
const readyStatus = await ensureCodexLensReady();
|
|
510
|
+
if (!readyStatus.ready) {
|
|
511
|
+
return {
|
|
512
|
+
success: false,
|
|
513
|
+
error: 'Neither ripgrep nor CodexLens available. Install ripgrep (rg) or CodexLens for search functionality.',
|
|
514
|
+
};
|
|
515
|
+
}
|
|
516
|
+
|
|
517
|
+
// Use CodexLens exact mode as fallback
|
|
518
|
+
const args = ['search', query, '--limit', maxResults.toString(), '--mode', 'exact', '--json'];
|
|
519
|
+
const result = await executeCodexLens(args, { cwd: path });
|
|
520
|
+
|
|
521
|
+
if (!result.success) {
|
|
522
|
+
return {
|
|
523
|
+
success: false,
|
|
524
|
+
error: result.error,
|
|
525
|
+
metadata: {
|
|
526
|
+
mode: 'ripgrep',
|
|
527
|
+
backend: 'codexlens-fallback',
|
|
528
|
+
count: 0,
|
|
529
|
+
query,
|
|
530
|
+
},
|
|
531
|
+
};
|
|
532
|
+
}
|
|
533
|
+
|
|
534
|
+
// Parse results
|
|
535
|
+
let results: SemanticMatch[] = [];
|
|
536
|
+
try {
|
|
537
|
+
const parsed = JSON.parse(stripAnsi(result.output || '{}'));
|
|
538
|
+
const data = parsed.result?.results || parsed.results || parsed;
|
|
539
|
+
results = (Array.isArray(data) ? data : []).map((item: any) => ({
|
|
540
|
+
file: item.path || item.file,
|
|
541
|
+
score: item.score || 0,
|
|
542
|
+
content: item.excerpt || item.content || '',
|
|
543
|
+
symbol: item.symbol || null,
|
|
544
|
+
}));
|
|
545
|
+
} catch {
|
|
546
|
+
// Keep empty results
|
|
547
|
+
}
|
|
548
|
+
|
|
549
|
+
return {
|
|
550
|
+
success: true,
|
|
551
|
+
results,
|
|
552
|
+
metadata: {
|
|
553
|
+
mode: 'ripgrep',
|
|
554
|
+
backend: 'codexlens-fallback',
|
|
555
|
+
count: results.length,
|
|
556
|
+
query,
|
|
557
|
+
note: 'Using CodexLens exact mode (ripgrep not available)',
|
|
558
|
+
},
|
|
559
|
+
};
|
|
560
|
+
}
|
|
561
|
+
|
|
562
|
+
// Use ripgrep
|
|
563
|
+
const { command, args } = buildRipgrepCommand({
|
|
564
|
+
query,
|
|
565
|
+
paths: paths.length > 0 ? paths : [path],
|
|
566
|
+
contextLines,
|
|
567
|
+
maxResults,
|
|
568
|
+
includeHidden,
|
|
569
|
+
});
|
|
570
|
+
|
|
571
|
+
return new Promise((resolve) => {
|
|
572
|
+
const child = spawn(command, args, {
|
|
573
|
+
cwd: path || process.cwd(),
|
|
574
|
+
stdio: ['ignore', 'pipe', 'pipe'],
|
|
575
|
+
});
|
|
576
|
+
|
|
577
|
+
let stdout = '';
|
|
578
|
+
let stderr = '';
|
|
579
|
+
|
|
580
|
+
child.stdout.on('data', (data) => {
|
|
581
|
+
stdout += data.toString();
|
|
582
|
+
});
|
|
583
|
+
|
|
584
|
+
child.stderr.on('data', (data) => {
|
|
585
|
+
stderr += data.toString();
|
|
586
|
+
});
|
|
587
|
+
|
|
588
|
+
child.on('close', (code) => {
|
|
589
|
+
const results: ExactMatch[] = [];
|
|
590
|
+
|
|
591
|
+
if (code === 0 || (code === 1 && stdout.trim())) {
|
|
592
|
+
const lines = stdout.split('\n').filter((line) => line.trim());
|
|
593
|
+
|
|
594
|
+
for (const line of lines) {
|
|
595
|
+
try {
|
|
596
|
+
const item = JSON.parse(line);
|
|
597
|
+
|
|
598
|
+
if (item.type === 'match') {
|
|
599
|
+
const match: ExactMatch = {
|
|
600
|
+
file: item.data.path.text,
|
|
601
|
+
line: item.data.line_number,
|
|
602
|
+
column:
|
|
603
|
+
item.data.submatches && item.data.submatches[0]
|
|
604
|
+
? item.data.submatches[0].start + 1
|
|
605
|
+
: 1,
|
|
606
|
+
content: item.data.lines.text.trim(),
|
|
607
|
+
};
|
|
608
|
+
results.push(match);
|
|
609
|
+
}
|
|
610
|
+
} catch {
|
|
611
|
+
continue;
|
|
612
|
+
}
|
|
613
|
+
}
|
|
614
|
+
|
|
615
|
+
resolve({
|
|
616
|
+
success: true,
|
|
617
|
+
results,
|
|
618
|
+
metadata: {
|
|
619
|
+
mode: 'ripgrep',
|
|
620
|
+
backend: 'ripgrep',
|
|
621
|
+
count: results.length,
|
|
622
|
+
query,
|
|
623
|
+
},
|
|
624
|
+
});
|
|
625
|
+
} else {
|
|
626
|
+
resolve({
|
|
627
|
+
success: false,
|
|
628
|
+
error: `ripgrep execution failed with code ${code}: ${stderr}`,
|
|
629
|
+
results: [],
|
|
630
|
+
});
|
|
631
|
+
}
|
|
632
|
+
});
|
|
633
|
+
|
|
634
|
+
child.on('error', (error) => {
|
|
635
|
+
resolve({
|
|
636
|
+
success: false,
|
|
637
|
+
error: `Failed to spawn ripgrep: ${error.message}`,
|
|
638
|
+
results: [],
|
|
639
|
+
});
|
|
640
|
+
});
|
|
641
|
+
});
|
|
642
|
+
}
|
|
643
|
+
|
|
644
|
+
/**
|
|
645
|
+
* Mode: exact - CodexLens exact/FTS search
|
|
646
|
+
* Requires index
|
|
647
|
+
*/
|
|
648
|
+
async function executeCodexLensExactMode(params: Params): Promise<SearchResult> {
|
|
649
|
+
const { query, path = '.', maxResults = 10, enrich = false } = params;
|
|
650
|
+
|
|
651
|
+
if (!query) {
|
|
652
|
+
return {
|
|
653
|
+
success: false,
|
|
654
|
+
error: 'Query is required for search',
|
|
655
|
+
};
|
|
656
|
+
}
|
|
657
|
+
|
|
658
|
+
// Check CodexLens availability
|
|
659
|
+
const readyStatus = await ensureCodexLensReady();
|
|
660
|
+
if (!readyStatus.ready) {
|
|
661
|
+
return {
|
|
662
|
+
success: false,
|
|
663
|
+
error: `CodexLens not available: ${readyStatus.error}`,
|
|
664
|
+
};
|
|
665
|
+
}
|
|
666
|
+
|
|
667
|
+
// Check index status
|
|
668
|
+
const indexStatus = await checkIndexStatus(path);
|
|
669
|
+
|
|
670
|
+
const args = ['search', query, '--limit', maxResults.toString(), '--mode', 'exact', '--json'];
|
|
671
|
+
if (enrich) {
|
|
672
|
+
args.push('--enrich');
|
|
673
|
+
}
|
|
674
|
+
const result = await executeCodexLens(args, { cwd: path });
|
|
675
|
+
|
|
676
|
+
if (!result.success) {
|
|
677
|
+
return {
|
|
678
|
+
success: false,
|
|
679
|
+
error: result.error,
|
|
680
|
+
metadata: {
|
|
681
|
+
mode: 'exact',
|
|
682
|
+
backend: 'codexlens',
|
|
683
|
+
count: 0,
|
|
684
|
+
query,
|
|
685
|
+
warning: indexStatus.warning,
|
|
686
|
+
},
|
|
687
|
+
};
|
|
688
|
+
}
|
|
689
|
+
|
|
690
|
+
// Parse results
|
|
691
|
+
let results: SemanticMatch[] = [];
|
|
692
|
+
try {
|
|
693
|
+
const parsed = JSON.parse(stripAnsi(result.output || '{}'));
|
|
694
|
+
const data = parsed.result?.results || parsed.results || parsed;
|
|
695
|
+
results = (Array.isArray(data) ? data : []).map((item: any) => ({
|
|
696
|
+
file: item.path || item.file,
|
|
697
|
+
score: item.score || 0,
|
|
698
|
+
content: item.excerpt || item.content || '',
|
|
699
|
+
symbol: item.symbol || null,
|
|
700
|
+
}));
|
|
701
|
+
} catch {
|
|
702
|
+
// Keep empty results
|
|
703
|
+
}
|
|
704
|
+
|
|
705
|
+
return {
|
|
706
|
+
success: true,
|
|
707
|
+
results,
|
|
708
|
+
metadata: {
|
|
709
|
+
mode: 'exact',
|
|
710
|
+
backend: 'codexlens',
|
|
711
|
+
count: results.length,
|
|
712
|
+
query,
|
|
713
|
+
warning: indexStatus.warning,
|
|
714
|
+
},
|
|
715
|
+
};
|
|
716
|
+
}
|
|
717
|
+
|
|
718
|
+
/**
|
|
719
|
+
* Mode: hybrid - Best quality search with RRF fusion
|
|
720
|
+
* Uses CodexLens hybrid mode (exact + fuzzy + vector)
|
|
721
|
+
* Requires index with embeddings
|
|
722
|
+
*/
|
|
723
|
+
async function executeHybridMode(params: Params): Promise<SearchResult> {
|
|
724
|
+
const { query, path = '.', maxResults = 10, enrich = false } = params;
|
|
725
|
+
|
|
726
|
+
if (!query) {
|
|
727
|
+
return {
|
|
728
|
+
success: false,
|
|
729
|
+
error: 'Query is required for search',
|
|
730
|
+
};
|
|
731
|
+
}
|
|
732
|
+
|
|
733
|
+
// Check CodexLens availability
|
|
734
|
+
const readyStatus = await ensureCodexLensReady();
|
|
735
|
+
if (!readyStatus.ready) {
|
|
736
|
+
return {
|
|
737
|
+
success: false,
|
|
738
|
+
error: `CodexLens not available: ${readyStatus.error}`,
|
|
739
|
+
};
|
|
740
|
+
}
|
|
741
|
+
|
|
742
|
+
// Check index status
|
|
743
|
+
const indexStatus = await checkIndexStatus(path);
|
|
744
|
+
|
|
745
|
+
const args = ['search', query, '--limit', maxResults.toString(), '--mode', 'hybrid', '--json'];
|
|
746
|
+
if (enrich) {
|
|
747
|
+
args.push('--enrich');
|
|
748
|
+
}
|
|
749
|
+
const result = await executeCodexLens(args, { cwd: path });
|
|
750
|
+
|
|
751
|
+
if (!result.success) {
|
|
752
|
+
return {
|
|
753
|
+
success: false,
|
|
754
|
+
error: result.error,
|
|
755
|
+
metadata: {
|
|
756
|
+
mode: 'hybrid',
|
|
757
|
+
backend: 'codexlens',
|
|
758
|
+
count: 0,
|
|
759
|
+
query,
|
|
760
|
+
warning: indexStatus.warning,
|
|
761
|
+
},
|
|
762
|
+
};
|
|
763
|
+
}
|
|
764
|
+
|
|
765
|
+
// Parse results
|
|
766
|
+
let results: SemanticMatch[] = [];
|
|
767
|
+
try {
|
|
768
|
+
const parsed = JSON.parse(stripAnsi(result.output || '{}'));
|
|
769
|
+
const data = parsed.result?.results || parsed.results || parsed;
|
|
770
|
+
results = (Array.isArray(data) ? data : []).map((item: any) => ({
|
|
771
|
+
file: item.path || item.file,
|
|
772
|
+
score: item.score || 0,
|
|
773
|
+
content: item.excerpt || item.content || '',
|
|
774
|
+
symbol: item.symbol || null,
|
|
775
|
+
}));
|
|
776
|
+
} catch {
|
|
777
|
+
return {
|
|
778
|
+
success: true,
|
|
779
|
+
results: [],
|
|
780
|
+
output: result.output,
|
|
781
|
+
metadata: {
|
|
782
|
+
mode: 'hybrid',
|
|
783
|
+
backend: 'codexlens',
|
|
784
|
+
count: 0,
|
|
785
|
+
query,
|
|
786
|
+
warning: indexStatus.warning || 'Failed to parse JSON output',
|
|
787
|
+
},
|
|
788
|
+
};
|
|
789
|
+
}
|
|
790
|
+
|
|
791
|
+
return {
|
|
792
|
+
success: true,
|
|
793
|
+
results,
|
|
794
|
+
metadata: {
|
|
795
|
+
mode: 'hybrid',
|
|
796
|
+
backend: 'codexlens',
|
|
797
|
+
count: results.length,
|
|
798
|
+
query,
|
|
799
|
+
note: 'Hybrid mode uses RRF fusion (exact + fuzzy + vector) for best results',
|
|
800
|
+
warning: indexStatus.warning,
|
|
801
|
+
},
|
|
802
|
+
};
|
|
803
|
+
}
|
|
804
|
+
|
|
805
|
+
/**
|
|
806
|
+
* TypeScript implementation of Reciprocal Rank Fusion
|
|
807
|
+
* Reference: codex-lens/src/codexlens/search/ranking.py
|
|
808
|
+
* Formula: score(d) = Σ weight_source / (k + rank_source(d))
|
|
809
|
+
*/
|
|
810
|
+
function applyRRFFusion(
|
|
811
|
+
resultsMap: Map<string, any[]>,
|
|
812
|
+
weights: Record<string, number>,
|
|
813
|
+
limit: number,
|
|
814
|
+
k: number = 60,
|
|
815
|
+
): any[] {
|
|
816
|
+
const pathScores = new Map<string, { score: number; result: any; sources: string[] }>();
|
|
817
|
+
|
|
818
|
+
resultsMap.forEach((results, source) => {
|
|
819
|
+
const weight = weights[source] || 0;
|
|
820
|
+
if (weight === 0 || !results) return;
|
|
821
|
+
|
|
822
|
+
results.forEach((result, rank) => {
|
|
823
|
+
const path = result.file || result.path;
|
|
824
|
+
if (!path) return;
|
|
825
|
+
|
|
826
|
+
const rrfContribution = weight / (k + rank + 1);
|
|
827
|
+
|
|
828
|
+
if (!pathScores.has(path)) {
|
|
829
|
+
pathScores.set(path, { score: 0, result, sources: [] });
|
|
830
|
+
}
|
|
831
|
+
const entry = pathScores.get(path)!;
|
|
832
|
+
entry.score += rrfContribution;
|
|
833
|
+
if (!entry.sources.includes(source)) {
|
|
834
|
+
entry.sources.push(source);
|
|
835
|
+
}
|
|
836
|
+
});
|
|
837
|
+
});
|
|
838
|
+
|
|
839
|
+
// Sort by fusion score descending
|
|
840
|
+
return Array.from(pathScores.values())
|
|
841
|
+
.sort((a, b) => b.score - a.score)
|
|
842
|
+
.slice(0, limit)
|
|
843
|
+
.map(item => ({
|
|
844
|
+
...item.result,
|
|
845
|
+
fusion_score: item.score,
|
|
846
|
+
matched_backends: item.sources,
|
|
847
|
+
}));
|
|
848
|
+
}
|
|
849
|
+
|
|
850
|
+
/**
|
|
851
|
+
* Promise wrapper with timeout support
|
|
852
|
+
* @param promise - The promise to wrap
|
|
853
|
+
* @param ms - Timeout in milliseconds
|
|
854
|
+
* @param modeName - Name of the mode for error message
|
|
855
|
+
* @returns A new promise that rejects on timeout
|
|
856
|
+
*/
|
|
857
|
+
function withTimeout<T>(promise: Promise<T>, ms: number, modeName: string): Promise<T> {
|
|
858
|
+
return new Promise((resolve, reject) => {
|
|
859
|
+
const timer = setTimeout(() => {
|
|
860
|
+
reject(new Error(`'${modeName}' search timed out after ${ms}ms`));
|
|
861
|
+
}, ms);
|
|
862
|
+
|
|
863
|
+
promise
|
|
864
|
+
.then(resolve)
|
|
865
|
+
.catch(reject)
|
|
866
|
+
.finally(() => clearTimeout(timer));
|
|
867
|
+
});
|
|
868
|
+
}
|
|
869
|
+
|
|
870
|
+
/**
|
|
871
|
+
* Mode: priority - Fallback search strategy: hybrid -> exact -> ripgrep
|
|
872
|
+
* Returns results from the first backend that succeeds and provides results.
|
|
873
|
+
* More efficient than parallel mode - stops as soon as valid results are found.
|
|
874
|
+
*/
|
|
875
|
+
async function executePriorityFallbackMode(params: Params): Promise<SearchResult> {
|
|
876
|
+
const { query, path = '.' } = params;
|
|
877
|
+
const fallbackHistory: string[] = [];
|
|
878
|
+
|
|
879
|
+
if (!query) {
|
|
880
|
+
return { success: false, error: 'Query is required for search' };
|
|
881
|
+
}
|
|
882
|
+
|
|
883
|
+
// Check index status first
|
|
884
|
+
const indexStatus = await checkIndexStatus(path);
|
|
885
|
+
|
|
886
|
+
// 1. Try Hybrid search (highest priority) - 90s timeout for large indexes
|
|
887
|
+
if (indexStatus.indexed && indexStatus.has_embeddings) {
|
|
888
|
+
try {
|
|
889
|
+
const hybridResult = await withTimeout(executeHybridMode(params), 90000, 'hybrid');
|
|
890
|
+
if (hybridResult.success && hybridResult.results && (hybridResult.results as any[]).length > 0) {
|
|
891
|
+
fallbackHistory.push('hybrid: success');
|
|
892
|
+
return {
|
|
893
|
+
...hybridResult,
|
|
894
|
+
metadata: {
|
|
895
|
+
...hybridResult.metadata,
|
|
896
|
+
mode: 'priority',
|
|
897
|
+
note: 'Result from hybrid search (semantic + vector).',
|
|
898
|
+
fallback_history: fallbackHistory,
|
|
899
|
+
},
|
|
900
|
+
};
|
|
901
|
+
}
|
|
902
|
+
fallbackHistory.push('hybrid: no results');
|
|
903
|
+
} catch (error) {
|
|
904
|
+
fallbackHistory.push(`hybrid: ${(error as Error).message}`);
|
|
905
|
+
}
|
|
906
|
+
} else {
|
|
907
|
+
fallbackHistory.push(`hybrid: skipped (${!indexStatus.indexed ? 'no index' : 'no embeddings'})`);
|
|
908
|
+
}
|
|
909
|
+
|
|
910
|
+
// 2. Fallback to Exact search - 10s timeout
|
|
911
|
+
if (indexStatus.indexed) {
|
|
912
|
+
try {
|
|
913
|
+
const exactResult = await withTimeout(executeCodexLensExactMode(params), 10000, 'exact');
|
|
914
|
+
if (exactResult.success && exactResult.results && (exactResult.results as any[]).length > 0) {
|
|
915
|
+
fallbackHistory.push('exact: success');
|
|
916
|
+
return {
|
|
917
|
+
...exactResult,
|
|
918
|
+
metadata: {
|
|
919
|
+
...exactResult.metadata,
|
|
920
|
+
mode: 'priority',
|
|
921
|
+
note: 'Result from exact/FTS search (fallback from hybrid).',
|
|
922
|
+
fallback_history: fallbackHistory,
|
|
923
|
+
},
|
|
924
|
+
};
|
|
925
|
+
}
|
|
926
|
+
fallbackHistory.push('exact: no results');
|
|
927
|
+
} catch (error) {
|
|
928
|
+
fallbackHistory.push(`exact: ${(error as Error).message}`);
|
|
929
|
+
}
|
|
930
|
+
} else {
|
|
931
|
+
fallbackHistory.push('exact: skipped (no index)');
|
|
932
|
+
}
|
|
933
|
+
|
|
934
|
+
// 3. Final fallback to Ripgrep - 5s timeout
|
|
935
|
+
try {
|
|
936
|
+
const ripgrepResult = await withTimeout(executeRipgrepMode(params), 5000, 'ripgrep');
|
|
937
|
+
fallbackHistory.push(ripgrepResult.success ? 'ripgrep: success' : 'ripgrep: failed');
|
|
938
|
+
return {
|
|
939
|
+
...ripgrepResult,
|
|
940
|
+
metadata: {
|
|
941
|
+
...ripgrepResult.metadata,
|
|
942
|
+
mode: 'priority',
|
|
943
|
+
note: 'Result from ripgrep search (final fallback).',
|
|
944
|
+
fallback_history: fallbackHistory,
|
|
945
|
+
},
|
|
946
|
+
};
|
|
947
|
+
} catch (error) {
|
|
948
|
+
fallbackHistory.push(`ripgrep: ${(error as Error).message}`);
|
|
949
|
+
}
|
|
950
|
+
|
|
951
|
+
// All modes failed
|
|
952
|
+
return {
|
|
953
|
+
success: false,
|
|
954
|
+
error: 'All search backends in priority mode failed or returned no results.',
|
|
955
|
+
metadata: {
|
|
956
|
+
mode: 'priority',
|
|
957
|
+
query,
|
|
958
|
+
fallback_history: fallbackHistory,
|
|
959
|
+
} as any,
|
|
960
|
+
};
|
|
961
|
+
}
|
|
962
|
+
|
|
963
|
+
// Tool schema for MCP
|
|
964
|
+
export const schema: ToolSchema = {
|
|
965
|
+
name: 'smart_search',
|
|
966
|
+
description: `Intelligent code search with five modes. Use "auto" mode (default) for intelligent routing.
|
|
967
|
+
|
|
968
|
+
**Usage:**
|
|
969
|
+
smart_search(query="authentication logic") # auto mode - routes to best backend
|
|
970
|
+
smart_search(query="MyClass", mode="exact") # exact mode - precise FTS matching
|
|
971
|
+
smart_search(query="auth", mode="ripgrep") # ripgrep mode - fast literal search (no index)
|
|
972
|
+
smart_search(query="how to auth", mode="hybrid") # hybrid mode - semantic search (requires index)
|
|
973
|
+
|
|
974
|
+
**Index Management:**
|
|
975
|
+
smart_search(action="init") # Create FTS index for current directory
|
|
976
|
+
smart_search(action="status") # Check index and embedding status
|
|
977
|
+
|
|
978
|
+
**Graph Enrichment:**
|
|
979
|
+
smart_search(query="func", enrich=true) # Enrich results with code relationships (calls, imports, called_by, imported_by)
|
|
980
|
+
|
|
981
|
+
**Modes:** auto (intelligent routing), hybrid (semantic, needs index), exact (FTS), ripgrep (fast, no index), priority (fallback: hybrid→exact→ripgrep)`,
|
|
982
|
+
inputSchema: {
|
|
983
|
+
type: 'object',
|
|
984
|
+
properties: {
|
|
985
|
+
action: {
|
|
986
|
+
type: 'string',
|
|
987
|
+
enum: ['init', 'search', 'search_files', 'status'],
|
|
988
|
+
description: 'Action to perform: init (create FTS index, no embeddings), search (default), search_files (paths only), status (check index)',
|
|
989
|
+
default: 'search',
|
|
990
|
+
},
|
|
991
|
+
query: {
|
|
992
|
+
type: 'string',
|
|
993
|
+
description: 'Search query (required for search/search_files actions)',
|
|
994
|
+
},
|
|
995
|
+
mode: {
|
|
996
|
+
type: 'string',
|
|
997
|
+
enum: SEARCH_MODES,
|
|
998
|
+
description: 'Search mode: auto (default), hybrid (best quality), exact (CodexLens FTS), ripgrep (fast, no index), priority (fallback: hybrid->exact->ripgrep)',
|
|
999
|
+
default: 'auto',
|
|
1000
|
+
},
|
|
1001
|
+
output_mode: {
|
|
1002
|
+
type: 'string',
|
|
1003
|
+
enum: ['full', 'files_only', 'count'],
|
|
1004
|
+
description: 'Output format: full (default), files_only (paths only), count (per-file counts)',
|
|
1005
|
+
default: 'full',
|
|
1006
|
+
},
|
|
1007
|
+
path: {
|
|
1008
|
+
type: 'string',
|
|
1009
|
+
description: 'Directory path for init/search actions (default: current directory)',
|
|
1010
|
+
},
|
|
1011
|
+
paths: {
|
|
1012
|
+
type: 'array',
|
|
1013
|
+
description: 'Multiple paths to search within (for search action)',
|
|
1014
|
+
items: {
|
|
1015
|
+
type: 'string',
|
|
1016
|
+
},
|
|
1017
|
+
default: [],
|
|
1018
|
+
},
|
|
1019
|
+
contextLines: {
|
|
1020
|
+
type: 'number',
|
|
1021
|
+
description: 'Number of context lines around matches (exact mode only)',
|
|
1022
|
+
default: 0,
|
|
1023
|
+
},
|
|
1024
|
+
maxResults: {
|
|
1025
|
+
type: 'number',
|
|
1026
|
+
description: 'Maximum number of results (default: 10)',
|
|
1027
|
+
default: 10,
|
|
1028
|
+
},
|
|
1029
|
+
limit: {
|
|
1030
|
+
type: 'number',
|
|
1031
|
+
description: 'Alias for maxResults',
|
|
1032
|
+
default: 10,
|
|
1033
|
+
},
|
|
1034
|
+
includeHidden: {
|
|
1035
|
+
type: 'boolean',
|
|
1036
|
+
description: 'Include hidden files/directories',
|
|
1037
|
+
default: false,
|
|
1038
|
+
},
|
|
1039
|
+
languages: {
|
|
1040
|
+
type: 'array',
|
|
1041
|
+
items: { type: 'string' },
|
|
1042
|
+
description: 'Languages to index (for init action). Example: ["javascript", "typescript"]',
|
|
1043
|
+
},
|
|
1044
|
+
enrich: {
|
|
1045
|
+
type: 'boolean',
|
|
1046
|
+
description: 'Enrich search results with code graph relationships (calls, imports, called_by, imported_by).',
|
|
1047
|
+
default: false,
|
|
1048
|
+
},
|
|
1049
|
+
},
|
|
1050
|
+
required: [],
|
|
1051
|
+
},
|
|
1052
|
+
};
|
|
1053
|
+
|
|
1054
|
+
/**
|
|
1055
|
+
* Transform results based on output_mode
|
|
1056
|
+
*/
|
|
1057
|
+
function transformOutput(
|
|
1058
|
+
results: ExactMatch[] | SemanticMatch[] | GraphMatch[] | unknown[],
|
|
1059
|
+
outputMode: 'full' | 'files_only' | 'count'
|
|
1060
|
+
): unknown {
|
|
1061
|
+
if (!Array.isArray(results)) {
|
|
1062
|
+
return results;
|
|
1063
|
+
}
|
|
1064
|
+
|
|
1065
|
+
switch (outputMode) {
|
|
1066
|
+
case 'files_only': {
|
|
1067
|
+
// Extract unique file paths
|
|
1068
|
+
const files = [...new Set(results.map((r: any) => r.file))].filter(Boolean);
|
|
1069
|
+
return { files, count: files.length };
|
|
1070
|
+
}
|
|
1071
|
+
case 'count': {
|
|
1072
|
+
// Count matches per file
|
|
1073
|
+
const counts: Record<string, number> = {};
|
|
1074
|
+
for (const r of results) {
|
|
1075
|
+
const file = (r as any).file;
|
|
1076
|
+
if (file) {
|
|
1077
|
+
counts[file] = (counts[file] || 0) + 1;
|
|
1078
|
+
}
|
|
1079
|
+
}
|
|
1080
|
+
return {
|
|
1081
|
+
files: Object.entries(counts).map(([file, count]) => ({ file, count })),
|
|
1082
|
+
total: results.length,
|
|
1083
|
+
};
|
|
1084
|
+
}
|
|
1085
|
+
case 'full':
|
|
1086
|
+
default:
|
|
1087
|
+
return results;
|
|
1088
|
+
}
|
|
1089
|
+
}
|
|
1090
|
+
|
|
1091
|
+
// Handler function
|
|
1092
|
+
export async function handler(params: Record<string, unknown>): Promise<ToolResult<SearchResult>> {
|
|
1093
|
+
const parsed = ParamsSchema.safeParse(params);
|
|
1094
|
+
if (!parsed.success) {
|
|
1095
|
+
return { success: false, error: `Invalid params: ${parsed.error.message}` };
|
|
1096
|
+
}
|
|
1097
|
+
|
|
1098
|
+
const { action, mode, output_mode } = parsed.data;
|
|
1099
|
+
|
|
1100
|
+
// Sync limit and maxResults - use the larger of the two if both provided
|
|
1101
|
+
// This ensures user-provided values take precedence over defaults
|
|
1102
|
+
const effectiveLimit = Math.max(parsed.data.limit || 10, parsed.data.maxResults || 10);
|
|
1103
|
+
parsed.data.maxResults = effectiveLimit;
|
|
1104
|
+
parsed.data.limit = effectiveLimit;
|
|
1105
|
+
|
|
1106
|
+
try {
|
|
1107
|
+
let result: SearchResult;
|
|
1108
|
+
|
|
1109
|
+
// Handle actions
|
|
1110
|
+
switch (action) {
|
|
1111
|
+
case 'init':
|
|
1112
|
+
result = await executeInitAction(parsed.data);
|
|
1113
|
+
break;
|
|
1114
|
+
|
|
1115
|
+
case 'status':
|
|
1116
|
+
result = await executeStatusAction(parsed.data);
|
|
1117
|
+
break;
|
|
1118
|
+
|
|
1119
|
+
case 'search_files':
|
|
1120
|
+
// For search_files, use search mode but force files_only output
|
|
1121
|
+
parsed.data.output_mode = 'files_only';
|
|
1122
|
+
// Fall through to search
|
|
1123
|
+
|
|
1124
|
+
case 'search':
|
|
1125
|
+
default:
|
|
1126
|
+
// Handle search modes: auto | hybrid | exact | ripgrep | priority
|
|
1127
|
+
switch (mode) {
|
|
1128
|
+
case 'auto':
|
|
1129
|
+
result = await executeAutoMode(parsed.data);
|
|
1130
|
+
break;
|
|
1131
|
+
case 'hybrid':
|
|
1132
|
+
result = await executeHybridMode(parsed.data);
|
|
1133
|
+
break;
|
|
1134
|
+
case 'exact':
|
|
1135
|
+
result = await executeCodexLensExactMode(parsed.data);
|
|
1136
|
+
break;
|
|
1137
|
+
case 'ripgrep':
|
|
1138
|
+
result = await executeRipgrepMode(parsed.data);
|
|
1139
|
+
break;
|
|
1140
|
+
case 'priority':
|
|
1141
|
+
result = await executePriorityFallbackMode(parsed.data);
|
|
1142
|
+
break;
|
|
1143
|
+
default:
|
|
1144
|
+
throw new Error(`Unsupported mode: ${mode}. Use: auto, hybrid, exact, ripgrep, or priority`);
|
|
1145
|
+
}
|
|
1146
|
+
break;
|
|
1147
|
+
}
|
|
1148
|
+
|
|
1149
|
+
// Transform output based on output_mode (for search actions only)
|
|
1150
|
+
if (action === 'search' || action === 'search_files') {
|
|
1151
|
+
if (result.success && result.results && output_mode !== 'full') {
|
|
1152
|
+
result.results = transformOutput(result.results as any[], output_mode);
|
|
1153
|
+
}
|
|
1154
|
+
}
|
|
1155
|
+
|
|
1156
|
+
return result.success ? { success: true, result } : { success: false, error: result.error };
|
|
1157
|
+
} catch (error) {
|
|
1158
|
+
return { success: false, error: (error as Error).message };
|
|
1159
|
+
}
|
|
1160
|
+
}
|
|
1161
|
+
|
|
1162
|
+
/**
|
|
1163
|
+
* Execute init action with external progress callback
|
|
1164
|
+
* Used by MCP server for streaming progress
|
|
1165
|
+
*/
|
|
1166
|
+
export async function executeInitWithProgress(
|
|
1167
|
+
params: Record<string, unknown>,
|
|
1168
|
+
onProgress?: (progress: ProgressInfo) => void
|
|
1169
|
+
): Promise<SearchResult> {
|
|
1170
|
+
const path = (params.path as string) || '.';
|
|
1171
|
+
const languages = params.languages as string[] | undefined;
|
|
1172
|
+
|
|
1173
|
+
// Check CodexLens availability
|
|
1174
|
+
const readyStatus = await ensureCodexLensReady();
|
|
1175
|
+
if (!readyStatus.ready) {
|
|
1176
|
+
return {
|
|
1177
|
+
success: false,
|
|
1178
|
+
error: `CodexLens not available: ${readyStatus.error}. CodexLens will be auto-installed on first use.`,
|
|
1179
|
+
};
|
|
1180
|
+
}
|
|
1181
|
+
|
|
1182
|
+
const args = ['init', path];
|
|
1183
|
+
if (languages && languages.length > 0) {
|
|
1184
|
+
args.push('--languages', languages.join(','));
|
|
1185
|
+
}
|
|
1186
|
+
|
|
1187
|
+
// Track progress updates
|
|
1188
|
+
const progressUpdates: ProgressInfo[] = [];
|
|
1189
|
+
let lastProgress: ProgressInfo | null = null;
|
|
1190
|
+
|
|
1191
|
+
const result = await executeCodexLens(args, {
|
|
1192
|
+
cwd: path,
|
|
1193
|
+
timeout: 1800000, // 30 minutes for large codebases
|
|
1194
|
+
onProgress: (progress: ProgressInfo) => {
|
|
1195
|
+
progressUpdates.push(progress);
|
|
1196
|
+
lastProgress = progress;
|
|
1197
|
+
// Call external progress callback if provided
|
|
1198
|
+
if (onProgress) {
|
|
1199
|
+
onProgress(progress);
|
|
1200
|
+
}
|
|
1201
|
+
},
|
|
1202
|
+
});
|
|
1203
|
+
|
|
1204
|
+
// Build metadata with progress info
|
|
1205
|
+
const metadata: SearchMetadata = {
|
|
1206
|
+
action: 'init',
|
|
1207
|
+
path,
|
|
1208
|
+
};
|
|
1209
|
+
|
|
1210
|
+
if (lastProgress !== null) {
|
|
1211
|
+
const p = lastProgress as ProgressInfo;
|
|
1212
|
+
metadata.progress = {
|
|
1213
|
+
stage: p.stage,
|
|
1214
|
+
message: p.message,
|
|
1215
|
+
percent: p.percent,
|
|
1216
|
+
filesProcessed: p.filesProcessed,
|
|
1217
|
+
totalFiles: p.totalFiles,
|
|
1218
|
+
};
|
|
1219
|
+
}
|
|
1220
|
+
|
|
1221
|
+
if (progressUpdates.length > 0) {
|
|
1222
|
+
metadata.progressHistory = progressUpdates.slice(-5);
|
|
1223
|
+
}
|
|
1224
|
+
|
|
1225
|
+
return {
|
|
1226
|
+
success: result.success,
|
|
1227
|
+
error: result.error,
|
|
1228
|
+
message: result.success
|
|
1229
|
+
? `CodexLens index created successfully for ${path}`
|
|
1230
|
+
: undefined,
|
|
1231
|
+
metadata,
|
|
1232
|
+
};
|
|
1233
|
+
}
|