@crownpeak/dqm-react-component-dev-mcp 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (444) hide show
  1. package/README.md +138 -0
  2. package/data/.env.example +22 -0
  3. package/data/.gitattributes +47 -0
  4. package/data/.glfrc.json +7 -0
  5. package/data/.husky/pre-commit +5 -0
  6. package/data/.nvmrc +1 -0
  7. package/data/CHANGELOG.md +75 -0
  8. package/data/CODE_OF_CONDUCT.md +129 -0
  9. package/data/CONTRIBUTING.md +203 -0
  10. package/data/DOCS-STRUCTURE.md +307 -0
  11. package/data/I18N.md +292 -0
  12. package/data/LICENSE +22 -0
  13. package/data/README.md +315 -0
  14. package/data/SECURITY.md +125 -0
  15. package/data/WIKI-DEPLOYMENT.md +348 -0
  16. package/data/docs/AI-FEATURES.md +610 -0
  17. package/data/docs/API-REFERENCE.md +1022 -0
  18. package/data/docs/AUTHENTICATION.md +301 -0
  19. package/data/docs/BACKEND-API.md +468 -0
  20. package/data/docs/DEVELOPMENT.md +375 -0
  21. package/data/docs/EXAMPLES.md +622 -0
  22. package/data/docs/MCP-SERVER.md +307 -0
  23. package/data/docs/MIGRATION-GUIDE.md +367 -0
  24. package/data/docs/NPM-PUBLISH.md +193 -0
  25. package/data/docs/QUICKSTART.md +206 -0
  26. package/data/docs/REDIS-SETUP.md +162 -0
  27. package/data/docs/SERVER.md +228 -0
  28. package/data/docs/TROUBLESHOOTING.md +657 -0
  29. package/data/docs/WIDGET-GUIDE.md +638 -0
  30. package/data/docs/WIKI-HOME.md +58 -0
  31. package/data/docs/WIKI-SIDEBAR.md +39 -0
  32. package/data/package.json +171 -0
  33. package/data/playwright.config.ts +64 -0
  34. package/data/probe/.cargo/config.toml +10 -0
  35. package/data/probe/.claude/commands/performance-review.md +15 -0
  36. package/data/probe/.clinerules +288 -0
  37. package/data/probe/.dockerignore +57 -0
  38. package/data/probe/.githooks/post-commit +11 -0
  39. package/data/probe/.githooks/pre-commit +99 -0
  40. package/data/probe/.githooks/pre-commit-vow +9 -0
  41. package/data/probe/.prompts/engineer.md +41 -0
  42. package/data/probe/.roomodes +28 -0
  43. package/data/probe/.windsurfrules +0 -0
  44. package/data/probe/BASH_TOOL_SUMMARY.md +148 -0
  45. package/data/probe/BENCHMARKING.md +256 -0
  46. package/data/probe/CLAUDE.md +226 -0
  47. package/data/probe/CODE_OF_CONDUCT.md +128 -0
  48. package/data/probe/CONTRIBUTING.md +193 -0
  49. package/data/probe/Cargo.toml +120 -0
  50. package/data/probe/Cross.toml +10 -0
  51. package/data/probe/DOCKER-README.md +224 -0
  52. package/data/probe/Dockerfile +32 -0
  53. package/data/probe/ENHANCED_DEBUG_TELEMETRY.md +188 -0
  54. package/data/probe/LICENSE +201 -0
  55. package/data/probe/Makefile +210 -0
  56. package/data/probe/README.md +824 -0
  57. package/data/probe/SECURITY.md +67 -0
  58. package/data/probe/WINDOWS-GUIDE.md +294 -0
  59. package/data/probe/benches/parsing_benchmarks.rs +370 -0
  60. package/data/probe/benches/search_benchmarks.rs +599 -0
  61. package/data/probe/benches/simd_benchmarks.rs +372 -0
  62. package/data/probe/benches/timing_benchmarks.rs +287 -0
  63. package/data/probe/build-windows.bat +229 -0
  64. package/data/probe/codex-config/config.toml +6 -0
  65. package/data/probe/docs/PERFORMANCE_OPTIMIZATION.md +161 -0
  66. package/data/probe/examples/cache_demo.rs +46 -0
  67. package/data/probe/examples/chat/.dockerignore +37 -0
  68. package/data/probe/examples/chat/ChatSessionManager.js +295 -0
  69. package/data/probe/examples/chat/Dockerfile +98 -0
  70. package/data/probe/examples/chat/LICENSE +201 -0
  71. package/data/probe/examples/chat/LOCAL_IMAGE_SUPPORT.md +195 -0
  72. package/data/probe/examples/chat/MCP_INTEGRATION.md +400 -0
  73. package/data/probe/examples/chat/README.md +338 -0
  74. package/data/probe/examples/chat/TRACING.md +226 -0
  75. package/data/probe/examples/chat/appTracer.js +968 -0
  76. package/data/probe/examples/chat/auth.js +76 -0
  77. package/data/probe/examples/chat/bin/probe-chat.js +13 -0
  78. package/data/probe/examples/chat/build.js +104 -0
  79. package/data/probe/examples/chat/cancelRequest.js +84 -0
  80. package/data/probe/examples/chat/demo-agentic-image-flow.js +88 -0
  81. package/data/probe/examples/chat/demo-local-images.js +128 -0
  82. package/data/probe/examples/chat/fileSpanExporter.js +181 -0
  83. package/data/probe/examples/chat/implement/README.md +228 -0
  84. package/data/probe/examples/chat/implement/backends/AiderBackend.js +750 -0
  85. package/data/probe/examples/chat/implement/backends/BaseBackend.js +276 -0
  86. package/data/probe/examples/chat/implement/backends/ClaudeCodeBackend.js +767 -0
  87. package/data/probe/examples/chat/implement/backends/MockBackend.js +237 -0
  88. package/data/probe/examples/chat/implement/backends/registry.js +85 -0
  89. package/data/probe/examples/chat/implement/core/BackendManager.js +567 -0
  90. package/data/probe/examples/chat/implement/core/ImplementTool.js +354 -0
  91. package/data/probe/examples/chat/implement/core/config.js +428 -0
  92. package/data/probe/examples/chat/implement/core/timeouts.js +58 -0
  93. package/data/probe/examples/chat/implement/core/utils.js +496 -0
  94. package/data/probe/examples/chat/implement/types/BackendTypes.js +126 -0
  95. package/data/probe/examples/chat/index.js +669 -0
  96. package/data/probe/examples/chat/mcpServer.js +341 -0
  97. package/data/probe/examples/chat/npm/LICENSE +15 -0
  98. package/data/probe/examples/chat/npm/README.md +168 -0
  99. package/data/probe/examples/chat/npm/bin/probe-chat.js +156 -0
  100. package/data/probe/examples/chat/npm/index.js +259 -0
  101. package/data/probe/examples/chat/npm/package.json +54 -0
  102. package/data/probe/examples/chat/package.json +102 -0
  103. package/data/probe/examples/chat/probeChat.js +456 -0
  104. package/data/probe/examples/chat/probeTool.js +491 -0
  105. package/data/probe/examples/chat/storage/JsonChatStorage.js +476 -0
  106. package/data/probe/examples/chat/telemetry.js +281 -0
  107. package/data/probe/examples/chat/test/integration/chatFlows.test.js +320 -0
  108. package/data/probe/examples/chat/test/integration/toolCalling.test.js +471 -0
  109. package/data/probe/examples/chat/test/mocks/mockLLMProvider.js +269 -0
  110. package/data/probe/examples/chat/test/test-backends.js +90 -0
  111. package/data/probe/examples/chat/test/testUtils.js +530 -0
  112. package/data/probe/examples/chat/test/unit/backendTimeout.test.js +161 -0
  113. package/data/probe/examples/chat/test/unit/packageFiles.test.js +120 -0
  114. package/data/probe/examples/chat/test/verify-tests.js +118 -0
  115. package/data/probe/examples/chat/test-agentic-image-loading.js +294 -0
  116. package/data/probe/examples/chat/test-ai-sdk-telemetry.js +204 -0
  117. package/data/probe/examples/chat/test-chat-tracing.js +38 -0
  118. package/data/probe/examples/chat/test-direct-function.js +49 -0
  119. package/data/probe/examples/chat/test-file-size-validation.js +103 -0
  120. package/data/probe/examples/chat/test-full-mcp-integration.js +258 -0
  121. package/data/probe/examples/chat/test-github-context.txt +12 -0
  122. package/data/probe/examples/chat/test-hierarchy.js +203 -0
  123. package/data/probe/examples/chat/test-image-spans.js +37 -0
  124. package/data/probe/examples/chat/test-local-image-reading.js +176 -0
  125. package/data/probe/examples/chat/test-mcp-integration.js +136 -0
  126. package/data/probe/examples/chat/test-mcp-probe-server.js +161 -0
  127. package/data/probe/examples/chat/test-mcp-with-ai.js +279 -0
  128. package/data/probe/examples/chat/test-multiple-allowed-dirs.js +111 -0
  129. package/data/probe/examples/chat/test-probe-mcp-server.js +110 -0
  130. package/data/probe/examples/chat/test-security-validation.js +145 -0
  131. package/data/probe/examples/chat/test-simple-tracing.js +32 -0
  132. package/data/probe/examples/chat/test-trace-verification.js +235 -0
  133. package/data/probe/examples/chat/test-tracing.js +114 -0
  134. package/data/probe/examples/chat/tokenCounter.js +419 -0
  135. package/data/probe/examples/chat/tokenUsageDisplay.js +134 -0
  136. package/data/probe/examples/chat/webServer.js +1103 -0
  137. package/data/probe/examples/reranker/Cargo.toml +33 -0
  138. package/data/probe/examples/reranker/DEBUG_OUTPUT_ANALYSIS.md +71 -0
  139. package/data/probe/examples/reranker/MODELS.md +66 -0
  140. package/data/probe/examples/reranker/MODEL_COMPARISON.md +60 -0
  141. package/data/probe/examples/reranker/MULTI_MODEL_ANALYSIS.md +176 -0
  142. package/data/probe/examples/reranker/PERFORMANCE_SUMMARY.md +156 -0
  143. package/data/probe/examples/reranker/README.md +347 -0
  144. package/data/probe/examples/reranker/RUST_BERT_COMPARISON.md +82 -0
  145. package/data/probe/examples/reranker/TOKENIZATION_GUIDE.md +120 -0
  146. package/data/probe/examples/reranker/check_rust_tokenizer.py +108 -0
  147. package/data/probe/examples/reranker/convert_to_torchscript.py +109 -0
  148. package/data/probe/examples/reranker/debug_scoring.py +189 -0
  149. package/data/probe/examples/reranker/debug_tokenization.py +154 -0
  150. package/data/probe/examples/reranker/download_models.sh +73 -0
  151. package/data/probe/examples/reranker/requirements.txt +13 -0
  152. package/data/probe/examples/reranker/run_comprehensive_benchmark.sh +83 -0
  153. package/data/probe/examples/reranker/rust_bert_test/Cargo.toml +12 -0
  154. package/data/probe/examples/reranker/rust_bert_test/README.md +54 -0
  155. package/data/probe/examples/reranker/simple_test.py +50 -0
  156. package/data/probe/examples/reranker/test_all_models.sh +63 -0
  157. package/data/probe/examples/reranker/test_bert_results.sh +44 -0
  158. package/data/probe/examples/reranker/test_cross_encoder.py +334 -0
  159. package/data/probe/examples/reranker/test_cross_encoder.sh +80 -0
  160. package/data/probe/examples/reranker/test_exact_comparison.py +151 -0
  161. package/data/probe/examples/reranker/test_parallel_performance.sh +56 -0
  162. package/data/probe/examples/reranker/test_scores.py +132 -0
  163. package/data/probe/install.ps1 +508 -0
  164. package/data/probe/install.sh +460 -0
  165. package/data/probe/npm/CLONE_METHOD_EXAMPLES.md +596 -0
  166. package/data/probe/npm/CONTEXT_COMPACTION.md +303 -0
  167. package/data/probe/npm/DELEGATE_TOOL_README.md +166 -0
  168. package/data/probe/npm/MAID_INTEGRATION.md +313 -0
  169. package/data/probe/npm/MCP_INTEGRATION_SUMMARY.md +241 -0
  170. package/data/probe/npm/README.md +824 -0
  171. package/data/probe/npm/bin/.gitignore +7 -0
  172. package/data/probe/npm/bin/.gitkeep +0 -0
  173. package/data/probe/npm/bin/README.md +12 -0
  174. package/data/probe/npm/bin/probe +167 -0
  175. package/data/probe/npm/docs/CLAUDE_CODE_INTEGRATION.md +414 -0
  176. package/data/probe/npm/docs/CODEX_INTEGRATION.md +502 -0
  177. package/data/probe/npm/docs/EDIT_CREATE_TOOLS.md +233 -0
  178. package/data/probe/npm/docs/RETRY_AND_FALLBACK.md +674 -0
  179. package/data/probe/npm/example-usage.js +335 -0
  180. package/data/probe/npm/examples/multi-engine-demo.js +117 -0
  181. package/data/probe/npm/examples/probe-agent-cli.js +113 -0
  182. package/data/probe/npm/examples/test-agent-edit.js +114 -0
  183. package/data/probe/npm/examples/test-edit-create.js +120 -0
  184. package/data/probe/npm/examples/test-edit-direct.js +114 -0
  185. package/data/probe/npm/index.d.ts +744 -0
  186. package/data/probe/npm/jest.config.js +52 -0
  187. package/data/probe/npm/package.json +117 -0
  188. package/data/probe/npm/scripts/build-agent.cjs +75 -0
  189. package/data/probe/npm/scripts/build-cjs.js +124 -0
  190. package/data/probe/npm/scripts/build-mcp.cjs +36 -0
  191. package/data/probe/npm/scripts/postinstall.js +216 -0
  192. package/data/probe/npm/test-codex-e2e.js +78 -0
  193. package/data/probe/npm/test-download-lock.js +109 -0
  194. package/data/probe/npm/test-grep-security.js +94 -0
  195. package/data/probe/npm/test-grep-simplified.js +63 -0
  196. package/data/probe/npm/test-grep.js +51 -0
  197. package/data/probe/npm/tests/README.md +96 -0
  198. package/data/probe/npm/tests/agent-compact-history.test.js +174 -0
  199. package/data/probe/npm/tests/allow-tests-default.test.js +151 -0
  200. package/data/probe/npm/tests/contextCompactor.test.js +498 -0
  201. package/data/probe/npm/tests/delegate-config.test.js +353 -0
  202. package/data/probe/npm/tests/delegate-integration.test.js +348 -0
  203. package/data/probe/npm/tests/extractor-integration.test.js +162 -0
  204. package/data/probe/npm/tests/extractor.test.js +317 -0
  205. package/data/probe/npm/tests/fixtures/sampleDiagrams.js +267 -0
  206. package/data/probe/npm/tests/integration/claude-code-auto-fallback.spec.js +148 -0
  207. package/data/probe/npm/tests/integration/claude-code-multi-step.spec.js +127 -0
  208. package/data/probe/npm/tests/integration/claude-code-tool-events.spec.js +163 -0
  209. package/data/probe/npm/tests/integration/codex-auto-fallback.spec.js +191 -0
  210. package/data/probe/npm/tests/integration/codex-tool-events.spec.js +147 -0
  211. package/data/probe/npm/tests/integration/examplesChatMcp.test.js +402 -0
  212. package/data/probe/npm/tests/integration/mcpDotenvSupport.test.js +174 -0
  213. package/data/probe/npm/tests/integration/mcpErrorHandling.test.js +566 -0
  214. package/data/probe/npm/tests/integration/mcpRobustness.test.js +564 -0
  215. package/data/probe/npm/tests/integration/mcpStdoutPurity.test.js +355 -0
  216. package/data/probe/npm/tests/integration/probeAgentMcp.test.js +398 -0
  217. package/data/probe/npm/tests/integration/retryFallback.test.js +368 -0
  218. package/data/probe/npm/tests/integration/schema-in-initial-message.test.js +318 -0
  219. package/data/probe/npm/tests/integration/schema-validation-loop-prevention.test.js +244 -0
  220. package/data/probe/npm/tests/integration/schemaRetryLogic.test.js +94 -0
  221. package/data/probe/npm/tests/integration/validationFlow.test.js +329 -0
  222. package/data/probe/npm/tests/manual/test-codex-basic.js +110 -0
  223. package/data/probe/npm/tests/mcp/mcpClientManager.test.js +614 -0
  224. package/data/probe/npm/tests/mcp/mcpConfig.test.js +359 -0
  225. package/data/probe/npm/tests/mcp/mcpXmlBridge.test.js +436 -0
  226. package/data/probe/npm/tests/mcp/mockMcpServer.js +510 -0
  227. package/data/probe/npm/tests/mcp-strict-syntax.test.js +319 -0
  228. package/data/probe/npm/tests/mermaidQuoteEscaping.test.js +214 -0
  229. package/data/probe/npm/tests/nestedQuoteFix.test.js +40 -0
  230. package/data/probe/npm/tests/setup.js +46 -0
  231. package/data/probe/npm/tests/unit/allowed-tools.test.js +513 -0
  232. package/data/probe/npm/tests/unit/attempt-completion-closing-tag-in-content.test.js +188 -0
  233. package/data/probe/npm/tests/unit/attemptCompletionJsonFix.test.js +238 -0
  234. package/data/probe/npm/tests/unit/attemptCompletionJsonIssue.test.js +128 -0
  235. package/data/probe/npm/tests/unit/backtickAutoFix.test.js +35 -0
  236. package/data/probe/npm/tests/unit/bash-probe-agent-integration.test.js +389 -0
  237. package/data/probe/npm/tests/unit/bash-simple-commands.test.js +324 -0
  238. package/data/probe/npm/tests/unit/bash-tool-comprehensive.test.js +371 -0
  239. package/data/probe/npm/tests/unit/bash-tool-integration.test.js +310 -0
  240. package/data/probe/npm/tests/unit/bash-tool.test.js +341 -0
  241. package/data/probe/npm/tests/unit/completion-prompt.test.js +379 -0
  242. package/data/probe/npm/tests/unit/cwd-path-options.test.js +287 -0
  243. package/data/probe/npm/tests/unit/delegate-limits.test.js +422 -0
  244. package/data/probe/npm/tests/unit/direct-content-attempt-completion.test.js +235 -0
  245. package/data/probe/npm/tests/unit/edit-create-tools.test.js +609 -0
  246. package/data/probe/npm/tests/unit/enhancedMermaidValidation.test.js +577 -0
  247. package/data/probe/npm/tests/unit/extract-content.test.js +83 -0
  248. package/data/probe/npm/tests/unit/extract-multiple-targets.test.js +89 -0
  249. package/data/probe/npm/tests/unit/fallbackManager.test.js +442 -0
  250. package/data/probe/npm/tests/unit/githubCompatibilityValidation.test.js +258 -0
  251. package/data/probe/npm/tests/unit/imageConfig.test.js +149 -0
  252. package/data/probe/npm/tests/unit/imagePathResolution.test.js +345 -0
  253. package/data/probe/npm/tests/unit/json-fixing-agent.test.js +238 -0
  254. package/data/probe/npm/tests/unit/json-validation-enhanced-errors.test.js +199 -0
  255. package/data/probe/npm/tests/unit/jsonValidationInfiniteLoopFix.test.js +228 -0
  256. package/data/probe/npm/tests/unit/maidIntegration.test.js +139 -0
  257. package/data/probe/npm/tests/unit/maxIterationsWarning.test.js +195 -0
  258. package/data/probe/npm/tests/unit/mermaidEdgeLabelFix.test.js +161 -0
  259. package/data/probe/npm/tests/unit/mermaidHtmlEntities.test.js +76 -0
  260. package/data/probe/npm/tests/unit/mermaidInfiniteLoopFix.test.js +64 -0
  261. package/data/probe/npm/tests/unit/mermaidValidation.test.js +723 -0
  262. package/data/probe/npm/tests/unit/mermaidValidationVisorExample.test.js +309 -0
  263. package/data/probe/npm/tests/unit/probe-agent-clone-realistic.test.js +643 -0
  264. package/data/probe/npm/tests/unit/probe-agent-clone.test.js +476 -0
  265. package/data/probe/npm/tests/unit/probe-agent-delegate.test.js +400 -0
  266. package/data/probe/npm/tests/unit/probe-agent-model-option.test.js +118 -0
  267. package/data/probe/npm/tests/unit/probeTool-security.test.js +283 -0
  268. package/data/probe/npm/tests/unit/readImageTool.test.js +418 -0
  269. package/data/probe/npm/tests/unit/retryManager.test.js +317 -0
  270. package/data/probe/npm/tests/unit/schema-aware-reminders.test.js +288 -0
  271. package/data/probe/npm/tests/unit/schemaDefinitionDetection.test.js +115 -0
  272. package/data/probe/npm/tests/unit/schemaUtils.test.js +1268 -0
  273. package/data/probe/npm/tests/unit/simpleTelemetry.test.js +282 -0
  274. package/data/probe/npm/tests/unit/simplified-attempt-completion.test.js +274 -0
  275. package/data/probe/npm/tests/unit/single-quote-json-bug.test.js +231 -0
  276. package/data/probe/npm/tests/unit/subgraphAutoFix.test.js +110 -0
  277. package/data/probe/npm/tests/unit/system-prompt.test.js +32 -0
  278. package/data/probe/npm/tests/unit/types-probe-agent-options.test.js +42 -0
  279. package/data/probe/npm/tests/unit/xmlParsing.test.js +720 -0
  280. package/data/probe/npm/tsconfig.json +21 -0
  281. package/data/probe/result1.txt +19 -0
  282. package/data/probe/result2.txt +26 -0
  283. package/data/probe/scripts/benchmark.sh +270 -0
  284. package/data/probe/scripts/cache_memory_analysis.rs +844 -0
  285. package/data/probe/scripts/claude-hook-wrapper.sh +56 -0
  286. package/data/probe/site/.env.example +10 -0
  287. package/data/probe/site/DEPLOYMENT.md +86 -0
  288. package/data/probe/site/README.md +183 -0
  289. package/data/probe/site/adding-languages.md +135 -0
  290. package/data/probe/site/ai-chat.md +427 -0
  291. package/data/probe/site/ai-integration.md +1488 -0
  292. package/data/probe/site/blog/agentic-flow-custom-xml-protocol.md +407 -0
  293. package/data/probe/site/blog/index.md +118 -0
  294. package/data/probe/site/blog/v0.6.0-release.md +426 -0
  295. package/data/probe/site/blog.md +8 -0
  296. package/data/probe/site/changelog.md +200 -0
  297. package/data/probe/site/cli-mode.md +437 -0
  298. package/data/probe/site/code-extraction.md +436 -0
  299. package/data/probe/site/contributing/README.md +9 -0
  300. package/data/probe/site/contributing/documentation-cross-references.md +215 -0
  301. package/data/probe/site/contributing/documentation-maintenance.md +275 -0
  302. package/data/probe/site/contributing/documentation-structure.md +75 -0
  303. package/data/probe/site/documentation-cross-references.md +215 -0
  304. package/data/probe/site/documentation-guide.md +132 -0
  305. package/data/probe/site/documentation-maintenance.md +275 -0
  306. package/data/probe/site/features.md +147 -0
  307. package/data/probe/site/how-it-works.md +118 -0
  308. package/data/probe/site/index.md +175 -0
  309. package/data/probe/site/index.md.bak +133 -0
  310. package/data/probe/site/installation.md +235 -0
  311. package/data/probe/site/integrations/docker.md +248 -0
  312. package/data/probe/site/integrations/github-actions.md +413 -0
  313. package/data/probe/site/language-support-overview.md +168 -0
  314. package/data/probe/site/mcp-integration.md +587 -0
  315. package/data/probe/site/mcp-server.md +304 -0
  316. package/data/probe/site/navigation-structure.md +76 -0
  317. package/data/probe/site/nodejs-sdk.md +798 -0
  318. package/data/probe/site/output-formats.md +625 -0
  319. package/data/probe/site/package.json +21 -0
  320. package/data/probe/site/public/_headers +28 -0
  321. package/data/probe/site/public/_redirects +11 -0
  322. package/data/probe/site/quick-start.md +289 -0
  323. package/data/probe/site/search-functionality.md +291 -0
  324. package/data/probe/site/search-reference.md +291 -0
  325. package/data/probe/site/supported-languages.md +215 -0
  326. package/data/probe/site/use-cases/README.md +8 -0
  327. package/data/probe/site/use-cases/advanced-cli.md +253 -0
  328. package/data/probe/site/use-cases/ai-code-editors.md +239 -0
  329. package/data/probe/site/use-cases/building-ai-tools.md +529 -0
  330. package/data/probe/site/use-cases/cli-ai-workflows.md +285 -0
  331. package/data/probe/site/use-cases/deploying-probe-web-interface.md +255 -0
  332. package/data/probe/site/use-cases/integrating-probe-into-ai-code-editors.md +161 -0
  333. package/data/probe/site/use-cases/nodejs-sdk.md +596 -0
  334. package/data/probe/site/use-cases/team-chat.md +350 -0
  335. package/data/probe/site/web-interface.md +434 -0
  336. package/data/probe/site/wrangler.toml +9 -0
  337. package/data/probe/test-api-key.sh +1 -0
  338. package/data/probe/test-probe-implementation/hello.js +7 -0
  339. package/data/probe/test_cases/demonstrate_early_termination_issues.sh +176 -0
  340. package/data/probe/test_cases/early_termination_issues.rs +533 -0
  341. package/data/probe/test_data/test_nested_struct.go +26 -0
  342. package/data/probe/tests/README.md +286 -0
  343. package/data/probe/tests/README_search_determinism_tests.md +116 -0
  344. package/data/probe/tests/adjacent_comment_test.rs +152 -0
  345. package/data/probe/tests/apostrophe_handling_tests.rs +132 -0
  346. package/data/probe/tests/block_filtering_with_ast_tests.rs +669 -0
  347. package/data/probe/tests/block_merging_tests.rs +396 -0
  348. package/data/probe/tests/c_outline_format_tests.rs +2179 -0
  349. package/data/probe/tests/cache_invalidation_issues.rs.disabled +682 -0
  350. package/data/probe/tests/cache_order_tests.rs +147 -0
  351. package/data/probe/tests/cache_query_scoping_tests.rs +221 -0
  352. package/data/probe/tests/cli_tests.rs +680 -0
  353. package/data/probe/tests/comment_context_integration_test.rs +240 -0
  354. package/data/probe/tests/common.rs +33 -0
  355. package/data/probe/tests/complex_block_merging_tests.rs +599 -0
  356. package/data/probe/tests/complex_query_block_filtering_tests.rs +422 -0
  357. package/data/probe/tests/control_flow_closing_braces_test.rs +91 -0
  358. package/data/probe/tests/cpp_outline_format_tests.rs +1507 -0
  359. package/data/probe/tests/csharp_outline_format_tests.rs +941 -0
  360. package/data/probe/tests/elastic_query_integration_tests.rs +922 -0
  361. package/data/probe/tests/extract_command_tests.rs +1848 -0
  362. package/data/probe/tests/extract_deduplication_tests.rs +146 -0
  363. package/data/probe/tests/extract_input_file_tests.rs +84 -0
  364. package/data/probe/tests/extract_prompt_tests.rs +102 -0
  365. package/data/probe/tests/filename_search_tests.rs +96 -0
  366. package/data/probe/tests/fixtures/user/AssemblyInfo.cs +3 -0
  367. package/data/probe/tests/github_extract_tests.rs +234 -0
  368. package/data/probe/tests/go_comment_test.rs +253 -0
  369. package/data/probe/tests/go_outline_format_tests.rs +2587 -0
  370. package/data/probe/tests/go_path_resolver_tests.rs +96 -0
  371. package/data/probe/tests/html_outline_format_tests.rs +637 -0
  372. package/data/probe/tests/integration_tests.rs +837 -0
  373. package/data/probe/tests/ip_whitelist_test.rs +148 -0
  374. package/data/probe/tests/java_outline_format_tests.rs +1611 -0
  375. package/data/probe/tests/javascript_extract_tests.rs +315 -0
  376. package/data/probe/tests/javascript_outline_format_tests.rs +1464 -0
  377. package/data/probe/tests/json_format_tests.rs +436 -0
  378. package/data/probe/tests/json_schema_validation_tests.rs +450 -0
  379. package/data/probe/tests/lib_usage.rs +60 -0
  380. package/data/probe/tests/line_comment_context_extension_test.rs +459 -0
  381. package/data/probe/tests/line_map_cache_tests.rs +114 -0
  382. package/data/probe/tests/markdown_integration_tests.rs +190 -0
  383. package/data/probe/tests/mocks/test_ip_whitelist.go +11 -0
  384. package/data/probe/tests/mocks/test_object.js +27 -0
  385. package/data/probe/tests/mocks/test_struct.go +50 -0
  386. package/data/probe/tests/multi_keyword_pattern_tests.rs +464 -0
  387. package/data/probe/tests/multi_language_syntax_integration_tests.rs +218 -0
  388. package/data/probe/tests/multiple_capture_groups_tests.rs +169 -0
  389. package/data/probe/tests/negative_compound_word_tests.rs +246 -0
  390. package/data/probe/tests/nested_symbol_extraction_tests.rs +99 -0
  391. package/data/probe/tests/outline_cross_file_interference_test.rs +335 -0
  392. package/data/probe/tests/outline_keyword_preservation_test.rs +67 -0
  393. package/data/probe/tests/output_format_edge_cases_tests.rs +693 -0
  394. package/data/probe/tests/parallel_extraction_tests.rs +178 -0
  395. package/data/probe/tests/parallel_search_tests.rs +355 -0
  396. package/data/probe/tests/path_resolver_tests.rs +698 -0
  397. package/data/probe/tests/php_outline_format_extended_tests.rs +928 -0
  398. package/data/probe/tests/php_outline_format_tests.rs +768 -0
  399. package/data/probe/tests/property_tests.proptest-regressions +9 -0
  400. package/data/probe/tests/property_tests.rs +118 -0
  401. package/data/probe/tests/python_outline_format_tests.rs +1538 -0
  402. package/data/probe/tests/query_command_json_tests.rs +438 -0
  403. package/data/probe/tests/query_command_tests.rs +232 -0
  404. package/data/probe/tests/query_command_xml_tests.rs +569 -0
  405. package/data/probe/tests/quoted_term_with_negative_keyword_tests.rs +216 -0
  406. package/data/probe/tests/required_terms_filename_tests.rs +116 -0
  407. package/data/probe/tests/ruby_outline_format_tests.rs +1011 -0
  408. package/data/probe/tests/rust_line_comment_context_test.rs +151 -0
  409. package/data/probe/tests/rust_outline_format_enhanced_tests.rs +725 -0
  410. package/data/probe/tests/rust_outline_format_tests.rs +843 -0
  411. package/data/probe/tests/schemas/xml_output_schema.xsd +38 -0
  412. package/data/probe/tests/search_determinism_tests.rs +451 -0
  413. package/data/probe/tests/search_hints_tests.rs +253 -0
  414. package/data/probe/tests/special_character_escaping_tests.rs +417 -0
  415. package/data/probe/tests/stemming_compound_word_filtering_tests.rs +535 -0
  416. package/data/probe/tests/strict_elastic_syntax_tests.rs +404 -0
  417. package/data/probe/tests/swift_outline_format_tests.rs +3319 -0
  418. package/data/probe/tests/symbols_tests.rs +166 -0
  419. package/data/probe/tests/test_file.rs +45 -0
  420. package/data/probe/tests/test_tokenize.rs +28 -0
  421. package/data/probe/tests/timeout_tests.rs +82 -0
  422. package/data/probe/tests/tokenization_tests.rs +195 -0
  423. package/data/probe/tests/tokenized_block_filtering_tests.rs +174 -0
  424. package/data/probe/tests/typescript_extract_tests.rs +214 -0
  425. package/data/probe/tests/typescript_outline_format_tests.rs +2188 -0
  426. package/data/probe/tests/xml_format_tests.rs +568 -0
  427. package/data/probe/tests/xml_schema_validation_tests.rs +497 -0
  428. package/data/scripts/postinstall.mjs +9 -0
  429. package/data/scripts/set-version.js +0 -0
  430. package/data/scripts/wiki-build.sh +111 -0
  431. package/data/scripts/wiki-deploy.sh +73 -0
  432. package/data/serve.json +12 -0
  433. package/data/test/demo-dynamic.html +134 -0
  434. package/data/test/demo-esm.html +105 -0
  435. package/data/test/demo-iife.html +78 -0
  436. package/data/tsconfig.json +7 -0
  437. package/data/vite.server.ts +483 -0
  438. package/data/vitest.config.ts +40 -0
  439. package/data/wiki/Home.md +58 -0
  440. package/data/wiki/_Sidebar.md +39 -0
  441. package/docs-mcp.config.json +20 -0
  442. package/package.json +56 -0
  443. package/src/config.js +111 -0
  444. package/src/index.js +395 -0
@@ -0,0 +1,372 @@
1
+ use ahash::AHashMap as HashMap;
2
+ use criterion::{black_box, criterion_group, criterion_main, BenchmarkId, Criterion, Throughput};
3
+ use probe_code::ranking::{
4
+ rank_documents, rank_documents_simd, rank_documents_simd_simple, RankingParams,
5
+ };
6
+ use probe_code::simd_ranking::SparseVector;
7
+ use rand::prelude::*;
8
+
9
+ /// Generate synthetic documents for benchmarking
10
+ fn generate_synthetic_docs(num_docs: usize, vocab_size: usize) -> Vec<String> {
11
+ let mut rng = rand::thread_rng();
12
+ let mut documents = Vec::with_capacity(num_docs);
13
+
14
+ // Create a vocabulary of common programming terms
15
+ let vocab: Vec<String> = (0..vocab_size)
16
+ .map(|i| match i % 20 {
17
+ 0..=4 => format!("function_{i}"),
18
+ 5..=9 => format!("class_{i}"),
19
+ 10..=14 => format!("method_{i}"),
20
+ 15..=19 => format!("variable_{i}"),
21
+ _ => format!("token_{i}"),
22
+ })
23
+ .collect();
24
+
25
+ for _ in 0..num_docs {
26
+ let doc_length = rng.gen_range(20..200); // Realistic document lengths
27
+ let mut doc_tokens = Vec::with_capacity(doc_length);
28
+
29
+ for _ in 0..doc_length {
30
+ let token_idx = rng.gen_range(0..vocab_size);
31
+ doc_tokens.push(vocab[token_idx].clone());
32
+ }
33
+
34
+ documents.push(doc_tokens.join(" "));
35
+ }
36
+
37
+ documents
38
+ }
39
+
40
+ /// Generate realistic code-like documents
41
+ fn generate_code_documents(num_docs: usize) -> Vec<String> {
42
+ let mut rng = rand::thread_rng();
43
+ let mut documents = Vec::with_capacity(num_docs);
44
+
45
+ let functions = [
46
+ "process",
47
+ "handle",
48
+ "execute",
49
+ "compute",
50
+ "calculate",
51
+ "transform",
52
+ "validate",
53
+ ];
54
+ let objects = [
55
+ "data",
56
+ "input",
57
+ "output",
58
+ "result",
59
+ "value",
60
+ "parameter",
61
+ "config",
62
+ ];
63
+ let operations = [
64
+ "load", "save", "parse", "format", "convert", "merge", "filter",
65
+ ];
66
+
67
+ for _ in 0..num_docs {
68
+ let mut doc = String::new();
69
+
70
+ // Add some function definitions
71
+ for _ in 0..rng.gen_range(1..5) {
72
+ let func = functions[rng.gen_range(0..functions.len())];
73
+ let obj = objects[rng.gen_range(0..objects.len())];
74
+ let op = operations[rng.gen_range(0..operations.len())];
75
+
76
+ doc.push_str(&format!("function {func}{obj}() {{\n"));
77
+ doc.push_str(&format!(" let {obj} = {op}();\n"));
78
+ doc.push_str(&format!(" return {obj}.{op}();\n"));
79
+ doc.push_str("}\n\n");
80
+ }
81
+
82
+ // Add some variable declarations
83
+ for _ in 0..rng.gen_range(2..8) {
84
+ let obj = objects[rng.gen_range(0..objects.len())];
85
+ let val = rng.gen_range(0..1000);
86
+ doc.push_str(&format!("const {obj} = {val};\n"));
87
+ }
88
+
89
+ documents.push(doc);
90
+ }
91
+
92
+ documents
93
+ }
94
+
95
+ /// Benchmark sparse vector operations
96
+ fn bench_sparse_vector_ops(c: &mut Criterion) {
97
+ let mut group = c.benchmark_group("sparse_vector_ops");
98
+
99
+ // Create test sparse vectors of different sizes
100
+ let sizes = [10, 50, 100, 500];
101
+
102
+ for &size in &sizes {
103
+ let mut tf_map1 = HashMap::new();
104
+ let mut tf_map2 = HashMap::new();
105
+
106
+ // Create overlapping sparse vectors
107
+ for i in 0..size {
108
+ tf_map1.insert(i as u8, (i % 10) + 1);
109
+ if i % 3 == 0 {
110
+ // 33% overlap
111
+ tf_map2.insert(i as u8, (i % 5) + 1);
112
+ }
113
+ }
114
+
115
+ let sparse1 = SparseVector::from_tf_map(&tf_map1);
116
+ let sparse2 = SparseVector::from_tf_map(&tf_map2);
117
+
118
+ group.throughput(Throughput::Elements(size as u64));
119
+ group.bench_with_input(
120
+ BenchmarkId::new("dot_product", size),
121
+ &(&sparse1, &sparse2),
122
+ |b, (v1, v2)| b.iter(|| black_box(v1.dot_product(v2))),
123
+ );
124
+
125
+ group.bench_with_input(
126
+ BenchmarkId::new("intersection", size),
127
+ &(&sparse1, &sparse2),
128
+ |b, (v1, v2)| b.iter(|| black_box(v1.intersect_indices(v2))),
129
+ );
130
+ }
131
+
132
+ group.finish();
133
+ }
134
+
135
+ /// Benchmark traditional vs SIMD ranking on synthetic data
136
+ fn bench_ranking_synthetic(c: &mut Criterion) {
137
+ let mut group = c.benchmark_group("ranking_synthetic");
138
+
139
+ let doc_counts = [100, 500, 1000, 2000];
140
+ let vocab_size = 1000;
141
+
142
+ for &num_docs in &doc_counts {
143
+ let documents = generate_synthetic_docs(num_docs, vocab_size);
144
+ let doc_refs: Vec<&str> = documents.iter().map(|s| s.as_str()).collect();
145
+
146
+ let queries = [
147
+ "function process data",
148
+ "class method handle",
149
+ "variable input output load",
150
+ ];
151
+
152
+ for query in queries {
153
+ let params = RankingParams {
154
+ documents: &doc_refs,
155
+ query,
156
+ pre_tokenized: None,
157
+ };
158
+
159
+ group.throughput(Throughput::Elements(num_docs as u64));
160
+
161
+ let query_id = query.replace(' ', "_");
162
+ group.bench_with_input(
163
+ BenchmarkId::new(format!("traditional_{query_id}"), num_docs),
164
+ &params,
165
+ |b, params| b.iter(|| black_box(rank_documents(params))),
166
+ );
167
+
168
+ group.bench_with_input(
169
+ BenchmarkId::new(format!("simd_{query_id}"), num_docs),
170
+ &params,
171
+ |b, params| b.iter(|| black_box(rank_documents_simd(params))),
172
+ );
173
+
174
+ group.bench_with_input(
175
+ BenchmarkId::new(format!("simd_simple_{query_id}"), num_docs),
176
+ &params,
177
+ |b, params| b.iter(|| black_box(rank_documents_simd_simple(params))),
178
+ );
179
+ }
180
+ }
181
+
182
+ group.finish();
183
+ }
184
+
185
+ /// Benchmark traditional vs SIMD ranking on realistic code documents
186
+ fn bench_ranking_realistic(c: &mut Criterion) {
187
+ let mut group = c.benchmark_group("ranking_realistic");
188
+
189
+ let doc_counts = [50, 200, 500, 1000];
190
+
191
+ for &num_docs in &doc_counts {
192
+ let documents = generate_code_documents(num_docs);
193
+ let doc_refs: Vec<&str> = documents.iter().map(|s| s.as_str()).collect();
194
+
195
+ let queries = [
196
+ "function process data load",
197
+ "class method handle input",
198
+ "variable config parameter validate",
199
+ "execute compute transform merge",
200
+ ];
201
+
202
+ for query in queries {
203
+ let params = RankingParams {
204
+ documents: &doc_refs,
205
+ query,
206
+ pre_tokenized: None,
207
+ };
208
+
209
+ group.throughput(Throughput::Elements(num_docs as u64));
210
+
211
+ let query_id = query.replace(' ', "_");
212
+ group.bench_with_input(
213
+ BenchmarkId::new(format!("traditional_{query_id}"), num_docs),
214
+ &params,
215
+ |b, params| b.iter(|| black_box(rank_documents(params))),
216
+ );
217
+
218
+ group.bench_with_input(
219
+ BenchmarkId::new(format!("simd_{query_id}"), num_docs),
220
+ &params,
221
+ |b, params| b.iter(|| black_box(rank_documents_simd(params))),
222
+ );
223
+
224
+ group.bench_with_input(
225
+ BenchmarkId::new(format!("simd_simple_{query_id}"), num_docs),
226
+ &params,
227
+ |b, params| b.iter(|| black_box(rank_documents_simd_simple(params))),
228
+ );
229
+ }
230
+ }
231
+
232
+ group.finish();
233
+ }
234
+
235
+ /// Benchmark memory usage and allocation patterns
236
+ fn bench_memory_efficiency(c: &mut Criterion) {
237
+ let mut group = c.benchmark_group("memory_efficiency");
238
+
239
+ let num_docs = 1000;
240
+ let documents = generate_code_documents(num_docs);
241
+ let doc_refs: Vec<&str> = documents.iter().map(|s| s.as_str()).collect();
242
+
243
+ let query = "function process data load validate";
244
+ let params = RankingParams {
245
+ documents: &doc_refs,
246
+ query,
247
+ pre_tokenized: None,
248
+ };
249
+
250
+ group.bench_function("traditional_memory", |b| {
251
+ b.iter(|| {
252
+ let _results = black_box(rank_documents(&params));
253
+ // Memory will be automatically freed here
254
+ })
255
+ });
256
+
257
+ group.bench_function("simd_memory", |b| {
258
+ b.iter(|| {
259
+ let _results = black_box(rank_documents_simd(&params));
260
+ // Memory will be automatically freed here
261
+ })
262
+ });
263
+
264
+ group.bench_function("simd_simple_memory", |b| {
265
+ b.iter(|| {
266
+ let _results = black_box(rank_documents_simd_simple(&params));
267
+ // Memory will be automatically freed here
268
+ })
269
+ });
270
+
271
+ group.finish();
272
+ }
273
+
274
+ /// Benchmark with varying query complexities
275
+ fn bench_query_complexity(c: &mut Criterion) {
276
+ let mut group = c.benchmark_group("query_complexity");
277
+
278
+ let num_docs = 500;
279
+ let documents = generate_code_documents(num_docs);
280
+ let doc_refs: Vec<&str> = documents.iter().map(|s| s.as_str()).collect();
281
+
282
+ let queries = [
283
+ ("simple", "function"),
284
+ ("medium", "function process data"),
285
+ ("complex", "function process data load validate transform"),
286
+ ("boolean", "+function +process -deprecated"),
287
+ ("mixed", "function OR method AND (data OR input)"),
288
+ ];
289
+
290
+ for (complexity, query) in queries {
291
+ let params = RankingParams {
292
+ documents: &doc_refs,
293
+ query,
294
+ pre_tokenized: None,
295
+ };
296
+
297
+ group.bench_with_input(
298
+ BenchmarkId::new("traditional", complexity),
299
+ &params,
300
+ |b, params| b.iter(|| black_box(rank_documents(params))),
301
+ );
302
+
303
+ group.bench_with_input(
304
+ BenchmarkId::new("simd", complexity),
305
+ &params,
306
+ |b, params| b.iter(|| black_box(rank_documents_simd(params))),
307
+ );
308
+
309
+ // Simple SIMD works best with non-boolean queries
310
+ if !query.contains(['+', '-', '(', ')']) {
311
+ group.bench_with_input(
312
+ BenchmarkId::new("simd_simple", complexity),
313
+ &params,
314
+ |b, params| b.iter(|| black_box(rank_documents_simd_simple(params))),
315
+ );
316
+ }
317
+ }
318
+
319
+ group.finish();
320
+ }
321
+
322
+ /// Benchmark scalability with increasing document sizes
323
+ fn bench_scalability(c: &mut Criterion) {
324
+ let mut group = c.benchmark_group("scalability");
325
+ group.sample_size(20); // Fewer samples for large datasets
326
+
327
+ let doc_counts = [100, 500, 1000, 2500, 5000];
328
+ let query = "function process data load";
329
+
330
+ for &num_docs in &doc_counts {
331
+ let documents = generate_synthetic_docs(num_docs, 500);
332
+ let doc_refs: Vec<&str> = documents.iter().map(|s| s.as_str()).collect();
333
+
334
+ let params = RankingParams {
335
+ documents: &doc_refs,
336
+ query,
337
+ pre_tokenized: None,
338
+ };
339
+
340
+ group.throughput(Throughput::Elements(num_docs as u64));
341
+
342
+ group.bench_with_input(
343
+ BenchmarkId::new("traditional", num_docs),
344
+ &params,
345
+ |b, params| b.iter(|| black_box(rank_documents(params))),
346
+ );
347
+
348
+ group.bench_with_input(BenchmarkId::new("simd", num_docs), &params, |b, params| {
349
+ b.iter(|| black_box(rank_documents_simd(params)))
350
+ });
351
+
352
+ group.bench_with_input(
353
+ BenchmarkId::new("simd_simple", num_docs),
354
+ &params,
355
+ |b, params| b.iter(|| black_box(rank_documents_simd_simple(params))),
356
+ );
357
+ }
358
+
359
+ group.finish();
360
+ }
361
+
362
+ criterion_group!(
363
+ benches,
364
+ bench_sparse_vector_ops,
365
+ bench_ranking_synthetic,
366
+ bench_ranking_realistic,
367
+ bench_memory_efficiency,
368
+ bench_query_complexity,
369
+ bench_scalability
370
+ );
371
+
372
+ criterion_main!(benches);
@@ -0,0 +1,287 @@
1
+ use criterion::{black_box, criterion_group, criterion_main, BenchmarkId, Criterion};
2
+ use probe_code::search::search_runner::{format_duration, SearchTimings};
3
+ use std::collections::HashMap;
4
+ use std::time::{Duration, Instant};
5
+
6
+ /// Benchmark the timing infrastructure overhead
7
+ fn benchmark_timing_overhead(c: &mut Criterion) {
8
+ let mut group = c.benchmark_group("timing_overhead");
9
+
10
+ // Test timing collection overhead
11
+ group.bench_function("timing_collection", |b| {
12
+ b.iter(|| {
13
+ let start = Instant::now();
14
+
15
+ // Simulate work
16
+ black_box((0..1000).map(|i| i * 2).collect::<Vec<_>>());
17
+
18
+ let duration = start.elapsed();
19
+ black_box(duration)
20
+ })
21
+ });
22
+
23
+ // Test SearchTimings struct creation
24
+ group.bench_function("search_timings_creation", |b| {
25
+ b.iter(|| {
26
+ let timings = SearchTimings {
27
+ query_preprocessing: Some(Duration::from_millis(10)),
28
+ pattern_generation: Some(Duration::from_millis(5)),
29
+ file_searching: Some(Duration::from_millis(100)),
30
+ filename_matching: Some(Duration::from_millis(20)),
31
+ early_filtering: Some(Duration::from_millis(30)),
32
+ early_caching: Some(Duration::from_millis(15)),
33
+ early_ranking: Some(Duration::from_millis(22)),
34
+ result_processing: Some(Duration::from_millis(200)),
35
+ result_processing_file_io: Some(Duration::from_millis(50)),
36
+ result_processing_line_collection: Some(Duration::from_millis(25)),
37
+ result_processing_ast_parsing: Some(Duration::from_millis(75)),
38
+ result_processing_block_extraction: Some(Duration::from_millis(40)),
39
+ result_processing_result_building: Some(Duration::from_millis(60)),
40
+ result_processing_ast_parsing_language_init: Some(Duration::from_millis(5)),
41
+ result_processing_ast_parsing_parser_init: Some(Duration::from_millis(3)),
42
+ result_processing_ast_parsing_tree_parsing: Some(Duration::from_millis(45)),
43
+ result_processing_ast_parsing_line_map_building: Some(Duration::from_millis(8)),
44
+ result_processing_block_extraction_code_structure: Some(Duration::from_millis(15)),
45
+ result_processing_block_extraction_filtering: Some(Duration::from_millis(10)),
46
+ result_processing_block_extraction_result_building: Some(Duration::from_millis(20)),
47
+ result_processing_term_matching: Some(Duration::from_millis(12)),
48
+ result_processing_compound_processing: Some(Duration::from_millis(8)),
49
+ result_processing_line_matching: Some(Duration::from_millis(18)),
50
+ result_processing_result_creation: Some(Duration::from_millis(25)),
51
+ result_processing_synchronization: Some(Duration::from_millis(5)),
52
+ result_processing_uncovered_lines: Some(Duration::from_millis(15)),
53
+ result_ranking: Some(Duration::from_millis(35)),
54
+ limit_application: Some(Duration::from_millis(2)),
55
+ block_merging: Some(Duration::from_millis(8)),
56
+ final_caching: Some(Duration::from_millis(12)),
57
+ total_search_time: Some(Duration::from_millis(500)),
58
+ };
59
+ black_box(timings)
60
+ })
61
+ });
62
+
63
+ group.finish();
64
+ }
65
+
66
+ /// Benchmark duration formatting
67
+ fn benchmark_duration_formatting(c: &mut Criterion) {
68
+ let durations = [
69
+ Duration::from_nanos(500),
70
+ Duration::from_micros(100),
71
+ Duration::from_millis(50),
72
+ Duration::from_millis(999),
73
+ Duration::from_secs(1),
74
+ Duration::from_secs(10),
75
+ Duration::from_secs(60),
76
+ ];
77
+
78
+ let mut group = c.benchmark_group("duration_formatting");
79
+
80
+ for (i, duration) in durations.iter().enumerate() {
81
+ group.bench_with_input(
82
+ BenchmarkId::new("format_duration", i),
83
+ duration,
84
+ |b, duration| b.iter(|| black_box(format_duration(*duration))),
85
+ );
86
+ }
87
+
88
+ group.finish();
89
+ }
90
+
91
+ /// Benchmark timing aggregation
92
+ fn benchmark_timing_aggregation(c: &mut Criterion) {
93
+ let mut group = c.benchmark_group("timing_aggregation");
94
+
95
+ // Create sample timings data
96
+ let create_sample_timings = || {
97
+ vec![
98
+ Duration::from_millis(10),
99
+ Duration::from_millis(25),
100
+ Duration::from_millis(5),
101
+ Duration::from_millis(50),
102
+ Duration::from_millis(100),
103
+ Duration::from_millis(75),
104
+ Duration::from_millis(30),
105
+ Duration::from_millis(15),
106
+ Duration::from_millis(8),
107
+ Duration::from_millis(45),
108
+ ]
109
+ };
110
+
111
+ // Test aggregation operations
112
+ group.bench_function("sum_durations", |b| {
113
+ b.iter(|| {
114
+ let durations = create_sample_timings();
115
+ let total: Duration = durations.iter().sum();
116
+ black_box(total)
117
+ })
118
+ });
119
+
120
+ group.bench_function("average_duration", |b| {
121
+ b.iter(|| {
122
+ let durations = create_sample_timings();
123
+ let total: Duration = durations.iter().sum();
124
+ let avg = total / durations.len() as u32;
125
+ black_box(avg)
126
+ })
127
+ });
128
+
129
+ group.bench_function("min_max_duration", |b| {
130
+ b.iter(|| {
131
+ let durations = create_sample_timings();
132
+ let min = *durations.iter().min().unwrap();
133
+ let max = *durations.iter().max().unwrap();
134
+ black_box((min, max))
135
+ })
136
+ });
137
+
138
+ group.finish();
139
+ }
140
+
141
+ /// Benchmark timing storage and retrieval
142
+ fn benchmark_timing_storage(c: &mut Criterion) {
143
+ let mut group = c.benchmark_group("timing_storage");
144
+
145
+ // Test HashMap storage for timing data
146
+ group.bench_function("hashmap_storage", |b| {
147
+ b.iter(|| {
148
+ let mut timings = HashMap::new();
149
+ timings.insert("query_preprocessing", Duration::from_millis(10));
150
+ timings.insert("pattern_generation", Duration::from_millis(5));
151
+ timings.insert("file_searching", Duration::from_millis(100));
152
+ timings.insert("filename_matching", Duration::from_millis(20));
153
+ timings.insert("early_filtering", Duration::from_millis(30));
154
+ timings.insert("result_processing", Duration::from_millis(200));
155
+ timings.insert("result_ranking", Duration::from_millis(35));
156
+ timings.insert("limit_application", Duration::from_millis(2));
157
+ timings.insert("block_merging", Duration::from_millis(8));
158
+ timings.insert("final_caching", Duration::from_millis(12));
159
+
160
+ // Simulate retrieval
161
+ let total: Duration = timings.values().sum();
162
+ black_box(total)
163
+ })
164
+ });
165
+
166
+ // Test Vec storage for timing data
167
+ group.bench_function("vec_storage", |b| {
168
+ b.iter(|| {
169
+ let timings = vec![
170
+ ("query_preprocessing", Duration::from_millis(10)),
171
+ ("pattern_generation", Duration::from_millis(5)),
172
+ ("file_searching", Duration::from_millis(100)),
173
+ ("filename_matching", Duration::from_millis(20)),
174
+ ("early_filtering", Duration::from_millis(30)),
175
+ ("result_processing", Duration::from_millis(200)),
176
+ ("result_ranking", Duration::from_millis(35)),
177
+ ("limit_application", Duration::from_millis(2)),
178
+ ("block_merging", Duration::from_millis(8)),
179
+ ("final_caching", Duration::from_millis(12)),
180
+ ];
181
+
182
+ // Simulate retrieval
183
+ let total: Duration = timings.iter().map(|(_, d)| *d).sum();
184
+ black_box(total)
185
+ })
186
+ });
187
+
188
+ group.finish();
189
+ }
190
+
191
+ /// Benchmark debug mode timing output
192
+ fn benchmark_debug_output(c: &mut Criterion) {
193
+ let mut group = c.benchmark_group("debug_output");
194
+
195
+ // Create sample timings
196
+ let create_sample_search_timings = || SearchTimings {
197
+ query_preprocessing: Some(Duration::from_millis(10)),
198
+ pattern_generation: Some(Duration::from_millis(5)),
199
+ file_searching: Some(Duration::from_millis(100)),
200
+ filename_matching: Some(Duration::from_millis(20)),
201
+ early_filtering: Some(Duration::from_millis(30)),
202
+ early_caching: Some(Duration::from_millis(15)),
203
+ early_ranking: Some(Duration::from_millis(22)),
204
+ result_processing: Some(Duration::from_millis(200)),
205
+ result_processing_file_io: Some(Duration::from_millis(50)),
206
+ result_processing_line_collection: Some(Duration::from_millis(25)),
207
+ result_processing_ast_parsing: Some(Duration::from_millis(75)),
208
+ result_processing_block_extraction: Some(Duration::from_millis(40)),
209
+ result_processing_result_building: Some(Duration::from_millis(60)),
210
+ result_processing_ast_parsing_language_init: Some(Duration::from_millis(5)),
211
+ result_processing_ast_parsing_parser_init: Some(Duration::from_millis(3)),
212
+ result_processing_ast_parsing_tree_parsing: Some(Duration::from_millis(45)),
213
+ result_processing_ast_parsing_line_map_building: Some(Duration::from_millis(8)),
214
+ result_processing_block_extraction_code_structure: Some(Duration::from_millis(15)),
215
+ result_processing_block_extraction_filtering: Some(Duration::from_millis(10)),
216
+ result_processing_block_extraction_result_building: Some(Duration::from_millis(20)),
217
+ result_processing_term_matching: Some(Duration::from_millis(12)),
218
+ result_processing_compound_processing: Some(Duration::from_millis(8)),
219
+ result_processing_line_matching: Some(Duration::from_millis(18)),
220
+ result_processing_result_creation: Some(Duration::from_millis(25)),
221
+ result_processing_synchronization: Some(Duration::from_millis(5)),
222
+ result_processing_uncovered_lines: Some(Duration::from_millis(15)),
223
+ result_ranking: Some(Duration::from_millis(35)),
224
+ limit_application: Some(Duration::from_millis(2)),
225
+ block_merging: Some(Duration::from_millis(8)),
226
+ final_caching: Some(Duration::from_millis(12)),
227
+ total_search_time: Some(Duration::from_millis(500)),
228
+ };
229
+
230
+ // Note: We can't actually test print_timings in benchmarks since it uses println!
231
+ // Instead, we'll benchmark the logic that would be involved
232
+ group.bench_function("timing_analysis", |b| {
233
+ b.iter(|| {
234
+ let timings = create_sample_search_timings();
235
+
236
+ // Simulate the work that print_timings would do
237
+ let mut total_time = Duration::from_secs(0);
238
+
239
+ if let Some(d) = timings.query_preprocessing {
240
+ total_time += d;
241
+ }
242
+ if let Some(d) = timings.pattern_generation {
243
+ total_time += d;
244
+ }
245
+ if let Some(d) = timings.file_searching {
246
+ total_time += d;
247
+ }
248
+ if let Some(d) = timings.filename_matching {
249
+ total_time += d;
250
+ }
251
+ if let Some(d) = timings.early_filtering {
252
+ total_time += d;
253
+ }
254
+ if let Some(d) = timings.result_processing {
255
+ total_time += d;
256
+ }
257
+ if let Some(d) = timings.result_ranking {
258
+ total_time += d;
259
+ }
260
+ if let Some(d) = timings.limit_application {
261
+ total_time += d;
262
+ }
263
+ if let Some(d) = timings.block_merging {
264
+ total_time += d;
265
+ }
266
+ if let Some(d) = timings.final_caching {
267
+ total_time += d;
268
+ }
269
+
270
+ // Simulate formatting
271
+ let formatted = format_duration(total_time);
272
+ black_box(formatted)
273
+ })
274
+ });
275
+
276
+ group.finish();
277
+ }
278
+
279
+ criterion_group!(
280
+ benches,
281
+ benchmark_timing_overhead,
282
+ benchmark_duration_formatting,
283
+ benchmark_timing_aggregation,
284
+ benchmark_timing_storage,
285
+ benchmark_debug_output
286
+ );
287
+ criterion_main!(benches);