claude-mpm 4.20.3__py3-none-any.whl → 4.25.10__py3-none-any.whl

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.

Potentially problematic release.


This version of claude-mpm might be problematic. Click here for more details.

Files changed (454) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +23 -6
  3. claude_mpm/agents/OUTPUT_STYLE.md +3 -48
  4. claude_mpm/agents/PM_INSTRUCTIONS.md +1783 -34
  5. claude_mpm/agents/WORKFLOW.md +75 -2
  6. claude_mpm/agents/base_agent.json +6 -3
  7. claude_mpm/agents/frontmatter_validator.py +1 -1
  8. claude_mpm/agents/templates/api_qa.json +5 -2
  9. claude_mpm/agents/templates/circuit_breakers.md +108 -2
  10. claude_mpm/agents/templates/documentation.json +33 -6
  11. claude_mpm/agents/templates/javascript_engineer_agent.json +380 -0
  12. claude_mpm/agents/templates/php-engineer.json +10 -4
  13. claude_mpm/agents/templates/pm_red_flags.md +89 -19
  14. claude_mpm/agents/templates/project_organizer.json +7 -3
  15. claude_mpm/agents/templates/qa.json +2 -1
  16. claude_mpm/agents/templates/react_engineer.json +1 -0
  17. claude_mpm/agents/templates/research.json +82 -12
  18. claude_mpm/agents/templates/security.json +4 -4
  19. claude_mpm/agents/templates/tauri_engineer.json +274 -0
  20. claude_mpm/agents/templates/ticketing.json +10 -6
  21. claude_mpm/agents/templates/version_control.json +4 -2
  22. claude_mpm/agents/templates/web_qa.json +2 -1
  23. claude_mpm/cli/README.md +253 -0
  24. claude_mpm/cli/__init__.py +11 -1
  25. claude_mpm/cli/commands/aggregate.py +1 -1
  26. claude_mpm/cli/commands/analyze.py +3 -3
  27. claude_mpm/cli/commands/cleanup.py +1 -1
  28. claude_mpm/cli/commands/configure_agent_display.py +4 -4
  29. claude_mpm/cli/commands/debug.py +12 -12
  30. claude_mpm/cli/commands/hook_errors.py +277 -0
  31. claude_mpm/cli/commands/mcp_install_commands.py +1 -1
  32. claude_mpm/cli/commands/mcp_install_commands.py.backup +284 -0
  33. claude_mpm/cli/commands/mpm_init/README.md +365 -0
  34. claude_mpm/cli/commands/mpm_init/__init__.py +73 -0
  35. claude_mpm/cli/commands/mpm_init/core.py +573 -0
  36. claude_mpm/cli/commands/mpm_init/display.py +341 -0
  37. claude_mpm/cli/commands/mpm_init/git_activity.py +427 -0
  38. claude_mpm/cli/commands/mpm_init/modes.py +397 -0
  39. claude_mpm/cli/commands/mpm_init/prompts.py +442 -0
  40. claude_mpm/cli/commands/mpm_init_cli.py +396 -0
  41. claude_mpm/cli/commands/mpm_init_handler.py +67 -1
  42. claude_mpm/cli/commands/run.py +124 -128
  43. claude_mpm/cli/commands/skills.py +522 -34
  44. claude_mpm/cli/executor.py +56 -0
  45. claude_mpm/cli/interactive/agent_wizard.py +5 -5
  46. claude_mpm/cli/parsers/base_parser.py +28 -0
  47. claude_mpm/cli/parsers/mpm_init_parser.py +42 -0
  48. claude_mpm/cli/parsers/skills_parser.py +138 -0
  49. claude_mpm/cli/startup.py +111 -8
  50. claude_mpm/cli/startup_display.py +480 -0
  51. claude_mpm/cli/utils.py +1 -1
  52. claude_mpm/cli_module/commands.py +1 -1
  53. claude_mpm/cli_module/refactoring_guide.md +253 -0
  54. claude_mpm/commands/mpm-help.md +3 -0
  55. claude_mpm/commands/mpm-init.md +19 -3
  56. claude_mpm/commands/mpm-resume.md +372 -0
  57. claude_mpm/commands/mpm-tickets.md +56 -7
  58. claude_mpm/commands/mpm.md +1 -0
  59. claude_mpm/config/agent_capabilities.yaml +658 -0
  60. claude_mpm/config/async_logging_config.yaml +145 -0
  61. claude_mpm/constants.py +12 -0
  62. claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +34 -0
  63. claude_mpm/core/api_validator.py +1 -1
  64. claude_mpm/core/claude_runner.py +14 -1
  65. claude_mpm/core/config.py +8 -0
  66. claude_mpm/core/constants.py +1 -1
  67. claude_mpm/core/framework/processors/metadata_processor.py +1 -1
  68. claude_mpm/core/hook_error_memory.py +381 -0
  69. claude_mpm/core/hook_manager.py +41 -2
  70. claude_mpm/core/interactive_session.py +48 -3
  71. claude_mpm/core/interfaces.py +56 -1
  72. claude_mpm/core/logger.py +3 -1
  73. claude_mpm/core/oneshot_session.py +39 -0
  74. claude_mpm/d2/.gitignore +22 -0
  75. claude_mpm/d2/ARCHITECTURE_COMPARISON.md +273 -0
  76. claude_mpm/d2/FLASK_INTEGRATION.md +156 -0
  77. claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +452 -0
  78. claude_mpm/d2/QUICKSTART.md +186 -0
  79. claude_mpm/d2/README.md +232 -0
  80. claude_mpm/d2/STORE_FIX_SUMMARY.md +167 -0
  81. claude_mpm/d2/SVELTE5_STORES_GUIDE.md +180 -0
  82. claude_mpm/d2/TESTING.md +288 -0
  83. claude_mpm/d2/index.html +118 -0
  84. claude_mpm/d2/package.json +19 -0
  85. claude_mpm/d2/src/App.svelte +110 -0
  86. claude_mpm/d2/src/components/Header.svelte +153 -0
  87. claude_mpm/d2/src/components/MainContent.svelte +74 -0
  88. claude_mpm/d2/src/components/Sidebar.svelte +85 -0
  89. claude_mpm/d2/src/components/tabs/EventsTab.svelte +326 -0
  90. claude_mpm/d2/src/lib/socketio.js +144 -0
  91. claude_mpm/d2/src/main.js +7 -0
  92. claude_mpm/d2/src/stores/events.js +114 -0
  93. claude_mpm/d2/src/stores/socket.js +108 -0
  94. claude_mpm/d2/src/stores/theme.js +65 -0
  95. claude_mpm/d2/svelte.config.js +12 -0
  96. claude_mpm/d2/vite.config.js +15 -0
  97. claude_mpm/dashboard/.claude-mpm/memories/README.md +36 -0
  98. claude_mpm/dashboard/BUILD_NUMBER +1 -0
  99. claude_mpm/dashboard/README.md +121 -0
  100. claude_mpm/dashboard/VERSION +1 -0
  101. claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +273 -0
  102. claude_mpm/dashboard/react/components/ErrorBoundary.tsx +75 -0
  103. claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +141 -0
  104. claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +36 -0
  105. claude_mpm/dashboard/react/components/shared/FilterBar.tsx +89 -0
  106. claude_mpm/dashboard/react/contexts/DashboardContext.tsx +215 -0
  107. claude_mpm/dashboard/react/entries/events.tsx +165 -0
  108. claude_mpm/dashboard/react/hooks/useEvents.ts +191 -0
  109. claude_mpm/dashboard/react/hooks/useSocket.ts +225 -0
  110. claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +170 -0
  111. claude_mpm/dashboard/static/built/components/activity-tree.js.map +1 -0
  112. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +101 -101
  113. claude_mpm/dashboard/static/built/components/agent-inference.js.map +1 -0
  114. claude_mpm/dashboard/static/built/components/build-tracker.js +59 -59
  115. claude_mpm/dashboard/static/built/components/code-simple.js +107 -107
  116. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +29 -29
  117. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +24 -24
  118. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +27 -27
  119. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +25 -25
  120. claude_mpm/dashboard/static/built/components/code-tree.js.map +1 -0
  121. claude_mpm/dashboard/static/built/components/code-viewer.js.map +1 -0
  122. claude_mpm/dashboard/static/built/components/connection-debug.js +101 -101
  123. claude_mpm/dashboard/static/built/components/diff-viewer.js +113 -113
  124. claude_mpm/dashboard/static/built/components/event-processor.js.map +1 -0
  125. claude_mpm/dashboard/static/built/components/event-viewer.js.map +1 -0
  126. claude_mpm/dashboard/static/built/components/export-manager.js.map +1 -0
  127. claude_mpm/dashboard/static/built/components/file-change-tracker.js +57 -57
  128. claude_mpm/dashboard/static/built/components/file-change-viewer.js +74 -74
  129. claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +1 -0
  130. claude_mpm/dashboard/static/built/components/file-viewer.js.map +1 -0
  131. claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +1 -0
  132. claude_mpm/dashboard/static/built/components/hud-manager.js.map +1 -0
  133. claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +1 -0
  134. claude_mpm/dashboard/static/built/components/module-viewer.js.map +1 -0
  135. claude_mpm/dashboard/static/built/components/session-manager.js.map +1 -0
  136. claude_mpm/dashboard/static/built/components/socket-manager.js.map +1 -0
  137. claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +1 -0
  138. claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +1 -0
  139. claude_mpm/dashboard/static/built/components/working-directory.js.map +1 -0
  140. claude_mpm/dashboard/static/built/connection-manager.js +76 -76
  141. claude_mpm/dashboard/static/built/dashboard.js.map +1 -0
  142. claude_mpm/dashboard/static/built/extension-error-handler.js +22 -22
  143. claude_mpm/dashboard/static/built/react/events.js.map +1 -0
  144. claude_mpm/dashboard/static/built/shared/dom-helpers.js +9 -9
  145. claude_mpm/dashboard/static/built/shared/event-bus.js +5 -5
  146. claude_mpm/dashboard/static/built/shared/logger.js +16 -16
  147. claude_mpm/dashboard/static/built/shared/tooltip-service.js +6 -6
  148. claude_mpm/dashboard/static/built/socket-client.js.map +1 -0
  149. claude_mpm/dashboard/static/css/activity.css +69 -69
  150. claude_mpm/dashboard/static/css/connection-status.css +10 -10
  151. claude_mpm/dashboard/static/css/dashboard.css +15 -15
  152. claude_mpm/dashboard/static/index.html +22 -22
  153. claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +170 -0
  154. claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
  155. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
  156. claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
  157. claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
  158. claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
  159. claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
  160. claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
  161. claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
  162. claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
  163. claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
  164. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
  165. claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
  166. claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
  167. claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
  168. claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
  169. claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
  170. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
  171. claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
  172. claude_mpm/dashboard/static/js/connection-manager.js +76 -76
  173. claude_mpm/dashboard/static/js/dashboard.js +76 -58
  174. claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
  175. claude_mpm/dashboard/static/js/shared/dom-helpers.js +9 -9
  176. claude_mpm/dashboard/static/js/shared/event-bus.js +5 -5
  177. claude_mpm/dashboard/static/js/shared/logger.js +16 -16
  178. claude_mpm/dashboard/static/js/shared/tooltip-service.js +6 -6
  179. claude_mpm/dashboard/static/js/socket-client.js +138 -121
  180. claude_mpm/dashboard/static/navigation-test-results.md +118 -0
  181. claude_mpm/dashboard/static/production/main.html +21 -21
  182. claude_mpm/dashboard/static/test-archive/dashboard.html +22 -22
  183. claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +36 -0
  184. claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +39 -0
  185. claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +38 -0
  186. claude_mpm/dashboard/templates/code_simple.html +23 -23
  187. claude_mpm/dashboard/templates/index.html +18 -18
  188. claude_mpm/hooks/README.md +143 -0
  189. claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
  190. claude_mpm/hooks/claude_hooks/hook_handler.py +24 -7
  191. claude_mpm/hooks/claude_hooks/installer.py +45 -0
  192. claude_mpm/hooks/templates/README.md +180 -0
  193. claude_mpm/hooks/templates/pre_tool_use_simple.py +78 -0
  194. claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
  195. claude_mpm/hooks/templates/settings.json.example +147 -0
  196. claude_mpm/schemas/agent_schema.json +596 -0
  197. claude_mpm/schemas/frontmatter_schema.json +165 -0
  198. claude_mpm/scripts/claude-hook-handler.sh +3 -3
  199. claude_mpm/scripts/start_activity_logging.py +3 -1
  200. claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
  201. claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
  202. claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
  203. claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
  204. claude_mpm/services/agents/loading/framework_agent_loader.py +8 -8
  205. claude_mpm/services/agents/local_template_manager.py +3 -1
  206. claude_mpm/services/cli/session_pause_manager.py +504 -0
  207. claude_mpm/services/cli/session_resume_helper.py +36 -16
  208. claude_mpm/services/cli/unified_dashboard_manager.py +1 -1
  209. claude_mpm/services/core/base.py +26 -11
  210. claude_mpm/services/core/interfaces.py +56 -1
  211. claude_mpm/services/core/models/agent_config.py +3 -0
  212. claude_mpm/services/core/models/process.py +4 -0
  213. claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
  214. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  215. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  216. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  217. claude_mpm/services/diagnostics/doctor_reporter.py +6 -4
  218. claude_mpm/services/diagnostics/models.py +21 -0
  219. claude_mpm/services/event_bus/README.md +244 -0
  220. claude_mpm/services/event_bus/direct_relay.py +3 -3
  221. claude_mpm/services/event_bus/event_bus.py +36 -3
  222. claude_mpm/services/event_bus/relay.py +23 -7
  223. claude_mpm/services/events/README.md +303 -0
  224. claude_mpm/services/events/consumers/logging.py +1 -2
  225. claude_mpm/services/framework_claude_md_generator/README.md +119 -0
  226. claude_mpm/services/infrastructure/monitoring/resources.py +1 -1
  227. claude_mpm/services/local_ops/__init__.py +2 -0
  228. claude_mpm/services/local_ops/process_manager.py +1 -1
  229. claude_mpm/services/local_ops/resource_monitor.py +2 -2
  230. claude_mpm/services/mcp_gateway/README.md +185 -0
  231. claude_mpm/services/mcp_gateway/auto_configure.py +31 -25
  232. claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
  233. claude_mpm/services/mcp_gateway/core/process_pool.py +19 -10
  234. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
  235. claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
  236. claude_mpm/services/mcp_gateway/tools/external_mcp_services.py +26 -21
  237. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
  238. claude_mpm/services/memory/failure_tracker.py +19 -4
  239. claude_mpm/services/memory/optimizer.py +1 -1
  240. claude_mpm/services/model/model_router.py +8 -9
  241. claude_mpm/services/monitor/daemon.py +1 -1
  242. claude_mpm/services/monitor/server.py +2 -2
  243. claude_mpm/services/native_agent_converter.py +356 -0
  244. claude_mpm/services/port_manager.py +1 -1
  245. claude_mpm/services/project/documentation_manager.py +2 -1
  246. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  247. claude_mpm/services/runner_configuration_service.py +1 -0
  248. claude_mpm/services/self_upgrade_service.py +165 -7
  249. claude_mpm/services/skills_config.py +547 -0
  250. claude_mpm/services/skills_deployer.py +955 -0
  251. claude_mpm/services/socketio/handlers/connection.py +1 -1
  252. claude_mpm/services/socketio/handlers/connection.py.backup +217 -0
  253. claude_mpm/services/socketio/handlers/git.py +2 -2
  254. claude_mpm/services/socketio/handlers/hook.py.backup +154 -0
  255. claude_mpm/services/static/.gitkeep +2 -0
  256. claude_mpm/services/system_instructions_service.py +1 -3
  257. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  258. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  259. claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
  260. claude_mpm/services/version_control/VERSION +1 -0
  261. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  262. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  263. claude_mpm/skills/__init__.py +3 -3
  264. claude_mpm/skills/agent_skills_injector.py +42 -49
  265. claude_mpm/skills/bundled/.gitkeep +2 -0
  266. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +4 -0
  267. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +108 -114
  268. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +577 -0
  269. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +467 -0
  270. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +537 -0
  271. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +730 -0
  272. claude_mpm/skills/bundled/collaboration/git-worktrees.md +317 -0
  273. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +46 -41
  274. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +412 -0
  275. claude_mpm/skills/bundled/collaboration/stacked-prs.md +251 -0
  276. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +36 -73
  277. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +362 -0
  278. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +312 -0
  279. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +100 -125
  280. claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +63 -0
  281. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +668 -0
  282. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +587 -0
  283. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +438 -0
  284. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +391 -0
  285. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +28 -72
  286. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +11 -0
  287. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +490 -0
  288. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +425 -0
  289. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +272 -0
  290. claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +611 -0
  291. claude_mpm/skills/bundled/infrastructure/env-manager/README.md +596 -0
  292. claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +260 -0
  293. claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +315 -0
  294. claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +436 -0
  295. claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +433 -0
  296. claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +452 -0
  297. claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +404 -0
  298. claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +420 -0
  299. claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
  300. claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +202 -0
  301. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +13 -1
  302. claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +54 -0
  303. claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +322 -0
  304. claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  305. claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +202 -0
  306. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +11 -0
  307. claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +202 -0
  308. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +109 -277
  309. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +412 -0
  310. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +1237 -0
  311. claude_mpm/skills/bundled/main/mcp-builder/scripts/connections.py +17 -10
  312. claude_mpm/skills/bundled/main/mcp-builder/scripts/evaluation.py +92 -39
  313. claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +22 -0
  314. claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +2 -0
  315. claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +202 -0
  316. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +135 -155
  317. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +500 -0
  318. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +464 -0
  319. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +619 -0
  320. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +437 -0
  321. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +231 -0
  322. claude_mpm/skills/bundled/main/skill-creator/scripts/init_skill.py +13 -12
  323. claude_mpm/skills/bundled/main/skill-creator/scripts/package_skill.py +5 -3
  324. claude_mpm/skills/bundled/main/skill-creator/scripts/quick_validate.py +19 -12
  325. claude_mpm/skills/bundled/performance-profiling.md +6 -0
  326. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +170 -0
  327. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +602 -0
  328. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +821 -0
  329. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +742 -0
  330. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +726 -0
  331. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +764 -0
  332. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +831 -0
  333. claude_mpm/skills/bundled/react/flexlayout-react.md +742 -0
  334. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +226 -0
  335. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +901 -0
  336. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +901 -0
  337. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +775 -0
  338. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +937 -0
  339. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +770 -0
  340. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +961 -0
  341. claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +495 -0
  342. claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +599 -0
  343. claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +535 -0
  344. claude_mpm/skills/bundled/tauri/tauri-error-handling.md +613 -0
  345. claude_mpm/skills/bundled/tauri/tauri-event-system.md +648 -0
  346. claude_mpm/skills/bundled/tauri/tauri-file-system.md +673 -0
  347. claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +767 -0
  348. claude_mpm/skills/bundled/tauri/tauri-performance.md +669 -0
  349. claude_mpm/skills/bundled/tauri/tauri-state-management.md +573 -0
  350. claude_mpm/skills/bundled/tauri/tauri-testing.md +384 -0
  351. claude_mpm/skills/bundled/tauri/tauri-window-management.md +628 -0
  352. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +21 -25
  353. claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +158 -0
  354. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +253 -0
  355. claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +458 -0
  356. claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +411 -0
  357. claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +317 -0
  358. claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +270 -0
  359. claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +436 -0
  360. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +86 -250
  361. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +572 -0
  362. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +411 -0
  363. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +569 -0
  364. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +695 -0
  365. claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +202 -0
  366. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +145 -57
  367. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +459 -0
  368. claude_mpm/skills/bundled/testing/webapp-testing/examples/console_logging.py +6 -6
  369. claude_mpm/skills/bundled/testing/webapp-testing/examples/element_discovery.py +13 -9
  370. claude_mpm/skills/bundled/testing/webapp-testing/examples/static_html_automation.py +8 -8
  371. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +479 -0
  372. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +687 -0
  373. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +37 -15
  374. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +758 -0
  375. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +868 -0
  376. claude_mpm/skills/skills_registry.py +44 -48
  377. claude_mpm/skills/skills_service.py +117 -108
  378. claude_mpm/templates/questions/EXAMPLES.md +501 -0
  379. claude_mpm/templates/questions/__init__.py +43 -0
  380. claude_mpm/templates/questions/base.py +193 -0
  381. claude_mpm/templates/questions/pr_strategy.py +314 -0
  382. claude_mpm/templates/questions/project_init.py +388 -0
  383. claude_mpm/templates/questions/ticket_mgmt.py +397 -0
  384. claude_mpm/tools/README_SOCKETIO_DEBUG.md +224 -0
  385. claude_mpm/tools/__main__.py +8 -8
  386. claude_mpm/tools/code_tree_analyzer/README.md +64 -0
  387. claude_mpm/tools/code_tree_analyzer/__init__.py +45 -0
  388. claude_mpm/tools/code_tree_analyzer/analysis.py +299 -0
  389. claude_mpm/tools/code_tree_analyzer/cache.py +131 -0
  390. claude_mpm/tools/code_tree_analyzer/core.py +380 -0
  391. claude_mpm/tools/code_tree_analyzer/discovery.py +403 -0
  392. claude_mpm/tools/code_tree_analyzer/events.py +168 -0
  393. claude_mpm/tools/code_tree_analyzer/gitignore.py +308 -0
  394. claude_mpm/tools/code_tree_analyzer/models.py +39 -0
  395. claude_mpm/tools/code_tree_analyzer/multilang_analyzer.py +224 -0
  396. claude_mpm/tools/code_tree_analyzer/python_analyzer.py +284 -0
  397. claude_mpm/utils/agent_dependency_loader.py +3 -3
  398. claude_mpm/utils/dependency_cache.py +3 -1
  399. claude_mpm/utils/gitignore.py +241 -0
  400. claude_mpm/utils/log_cleanup.py +3 -3
  401. claude_mpm/utils/robust_installer.py +3 -5
  402. claude_mpm/utils/structured_questions.py +619 -0
  403. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/METADATA +218 -31
  404. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/RECORD +409 -246
  405. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  406. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  407. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  408. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  409. claude_mpm/cli/commands/mpm_init.py +0 -2093
  410. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  411. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  412. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  413. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  414. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  415. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  416. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  417. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  418. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  419. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  420. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  421. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  422. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  423. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  424. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  425. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  426. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  427. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  428. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  429. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  430. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  431. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  432. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  433. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  434. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  435. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  436. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  437. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  438. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  439. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  440. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  441. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  442. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  443. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  444. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  445. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  446. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  447. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  448. claude_mpm/skills/bundled/debugging/verification-before-completion/references/common-failures.md +0 -213
  449. claude_mpm/tools/code_tree_analyzer.py +0 -1825
  450. /claude_mpm/skills/bundled/collaboration/requesting-code-review/{code-reviewer.md → references/code-reviewer-template.md} +0 -0
  451. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/WHEEL +0 -0
  452. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/entry_points.txt +0 -0
  453. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/licenses/LICENSE +0 -0
  454. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,308 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Gitignore Manager
4
+ =================
5
+
6
+ Manages .gitignore pattern matching for file filtering.
7
+
8
+ WHY: Properly respecting .gitignore patterns ensures we don't analyze
9
+ or display files that should be ignored in the repository.
10
+ """
11
+
12
+ from pathlib import Path
13
+ from typing import Any, ClassVar, Dict, List, Optional
14
+
15
+ try:
16
+ import pathspec
17
+
18
+ PATHSPEC_AVAILABLE = True
19
+ except ImportError:
20
+ PATHSPEC_AVAILABLE = False
21
+ pathspec = None
22
+
23
+ from ...core.logging_config import get_logger
24
+
25
+
26
+ class GitignoreManager:
27
+ """Manages .gitignore pattern matching for file filtering."""
28
+
29
+ # Default patterns that should always be ignored
30
+ DEFAULT_PATTERNS: ClassVar[list] = [
31
+ ".git/",
32
+ "__pycache__/",
33
+ "*.pyc",
34
+ "*.pyo",
35
+ ".DS_Store",
36
+ ".pytest_cache/",
37
+ ".mypy_cache/",
38
+ "dist/",
39
+ "build/",
40
+ "*.egg-info/",
41
+ ".coverage",
42
+ ".tox/",
43
+ "htmlcov/",
44
+ ".idea/",
45
+ ".vscode/",
46
+ "*.swp",
47
+ "*.swo",
48
+ "*~",
49
+ "Thumbs.db",
50
+ "node_modules/",
51
+ ".venv/",
52
+ "venv/",
53
+ "env/",
54
+ ".env",
55
+ "*.log",
56
+ ".ipynb_checkpoints/",
57
+ "__MACOSX/",
58
+ ".Spotlight-V100/",
59
+ ".Trashes/",
60
+ "desktop.ini",
61
+ ]
62
+
63
+ # Additional patterns to hide dotfiles (when enabled)
64
+ DOTFILE_PATTERNS: ClassVar[list] = [
65
+ ".*", # All dotfiles
66
+ ".*/", # All dot directories
67
+ ]
68
+
69
+ # Important files/directories to always show
70
+ DOTFILE_EXCEPTIONS: ClassVar[set] = {
71
+ # Removed .gitignore from exceptions - it should be hidden by default
72
+ ".env.example",
73
+ ".env.sample",
74
+ ".gitlab-ci.yml",
75
+ ".travis.yml",
76
+ ".dockerignore",
77
+ ".editorconfig",
78
+ ".eslintrc",
79
+ ".prettierrc",
80
+ # Removed .github from exceptions - it should be hidden by default
81
+ }
82
+
83
+ def __init__(self):
84
+ """Initialize the GitignoreManager."""
85
+ self.logger = get_logger(__name__)
86
+ self._pathspec_cache: Dict[str, Any] = {}
87
+ self._gitignore_cache: Dict[str, List[str]] = {}
88
+ self._use_pathspec = PATHSPEC_AVAILABLE
89
+
90
+ if not self._use_pathspec:
91
+ self.logger.warning(
92
+ "pathspec library not available - using basic pattern matching"
93
+ )
94
+
95
+ def get_ignore_patterns(self, working_dir: Path) -> List[str]:
96
+ """Get all ignore patterns for a directory.
97
+
98
+ Args:
99
+ working_dir: The working directory to search for .gitignore files
100
+
101
+ Returns:
102
+ Combined list of ignore patterns from all sources
103
+ """
104
+ # Always include default patterns
105
+ patterns = self.DEFAULT_PATTERNS.copy()
106
+
107
+ # Don't add dotfile patterns here - handle them separately in should_ignore
108
+ # This prevents exceptions from being overridden by the .* pattern
109
+
110
+ # Find and parse .gitignore files
111
+ gitignore_files = self._find_gitignore_files(working_dir)
112
+ for gitignore_file in gitignore_files:
113
+ patterns.extend(self._parse_gitignore(gitignore_file))
114
+
115
+ return patterns
116
+
117
+ def should_ignore(self, path: Path, working_dir: Path) -> bool:
118
+ """Check if a path should be ignored based on patterns.
119
+
120
+ Args:
121
+ path: The path to check
122
+ working_dir: The working directory (for relative path calculation)
123
+
124
+ Returns:
125
+ True if the path should be ignored
126
+ """
127
+ # Get the filename
128
+ filename = path.name
129
+
130
+ # 1. ALWAYS hide system files regardless of settings
131
+ ALWAYS_HIDE = {".DS_Store", "Thumbs.db", ".pyc", ".pyo", ".pyd"}
132
+ if filename in ALWAYS_HIDE or filename.endswith((".pyc", ".pyo", ".pyd")):
133
+ return True
134
+
135
+ # 2. Check dotfiles - ALWAYS filter them out (except exceptions)
136
+ if filename.startswith("."):
137
+ # Hide all dotfiles except those in the exceptions list
138
+ # This means: return True (ignore) if NOT in exceptions
139
+ return filename not in self.DOTFILE_EXCEPTIONS
140
+
141
+ # Get or create PathSpec for this working directory
142
+ pathspec_obj = self._get_pathspec(working_dir)
143
+
144
+ if pathspec_obj:
145
+ # Use pathspec for accurate matching
146
+ try:
147
+ rel_path = path.relative_to(working_dir)
148
+ rel_path_str = str(rel_path)
149
+
150
+ # For directories, also check with trailing slash
151
+ if path.is_dir():
152
+ return pathspec_obj.match_file(
153
+ rel_path_str
154
+ ) or pathspec_obj.match_file(rel_path_str + "/")
155
+ return pathspec_obj.match_file(rel_path_str)
156
+ except ValueError:
157
+ # Path is outside working directory
158
+ return False
159
+ else:
160
+ # Fallback to basic pattern matching
161
+ return self._basic_should_ignore(path, working_dir)
162
+
163
+ def _get_pathspec(self, working_dir: Path) -> Optional[Any]:
164
+ """Get or create a PathSpec object for the working directory.
165
+
166
+ Args:
167
+ working_dir: The working directory
168
+
169
+ Returns:
170
+ PathSpec object or None if not available
171
+ """
172
+ if not self._use_pathspec:
173
+ return None
174
+
175
+ cache_key = str(working_dir)
176
+ if cache_key not in self._pathspec_cache:
177
+ patterns = self.get_ignore_patterns(working_dir)
178
+ try:
179
+ self._pathspec_cache[cache_key] = pathspec.PathSpec.from_lines(
180
+ "gitwildmatch", patterns
181
+ )
182
+ except Exception as e:
183
+ self.logger.warning(f"Failed to create PathSpec: {e}")
184
+ return None
185
+
186
+ return self._pathspec_cache[cache_key]
187
+
188
+ def _find_gitignore_files(self, working_dir: Path) -> List[Path]:
189
+ """Find all .gitignore files in the directory tree.
190
+
191
+ Args:
192
+ working_dir: The directory to search
193
+
194
+ Returns:
195
+ List of .gitignore file paths
196
+ """
197
+ gitignore_files = []
198
+
199
+ # Check for .gitignore in working directory
200
+ main_gitignore = working_dir / ".gitignore"
201
+ if main_gitignore.exists():
202
+ gitignore_files.append(main_gitignore)
203
+
204
+ # Also check parent directories up to repository root
205
+ current = working_dir
206
+ while current != current.parent:
207
+ parent_gitignore = current.parent / ".gitignore"
208
+ if parent_gitignore.exists():
209
+ gitignore_files.append(parent_gitignore)
210
+
211
+ # Stop if we find a .git directory (repository root)
212
+ if (current / ".git").exists():
213
+ break
214
+
215
+ current = current.parent
216
+
217
+ return gitignore_files
218
+
219
+ def _parse_gitignore(self, gitignore_path: Path) -> List[str]:
220
+ """Parse a .gitignore file and return patterns.
221
+
222
+ Args:
223
+ gitignore_path: Path to .gitignore file
224
+
225
+ Returns:
226
+ List of patterns from the file
227
+ """
228
+ cache_key = str(gitignore_path)
229
+
230
+ # Check cache
231
+ if cache_key in self._gitignore_cache:
232
+ return self._gitignore_cache[cache_key]
233
+
234
+ patterns = []
235
+ try:
236
+ with Path(gitignore_path).open(
237
+ encoding="utf-8",
238
+ ) as f:
239
+ for line in f:
240
+ line = line.strip()
241
+ # Skip empty lines and comments
242
+ if line and not line.startswith("#"):
243
+ patterns.append(line)
244
+
245
+ self._gitignore_cache[cache_key] = patterns
246
+ except Exception as e:
247
+ self.logger.warning(f"Failed to parse {gitignore_path}: {e}")
248
+
249
+ return patterns
250
+
251
+ def _basic_should_ignore(self, path: Path, working_dir: Path) -> bool:
252
+ """Basic pattern matching fallback when pathspec is not available.
253
+
254
+ Args:
255
+ path: The path to check
256
+ working_dir: The working directory
257
+
258
+ Returns:
259
+ True if the path should be ignored
260
+ """
261
+ path_str = str(path)
262
+ path_name = path.name
263
+
264
+ # 1. ALWAYS hide system files regardless of settings
265
+ ALWAYS_HIDE = {".DS_Store", "Thumbs.db", ".pyc", ".pyo", ".pyd"}
266
+ if path_name in ALWAYS_HIDE or path_name.endswith((".pyc", ".pyo", ".pyd")):
267
+ return True
268
+
269
+ # 2. Check dotfiles - ALWAYS filter them out (except exceptions)
270
+ if path_name.startswith("."):
271
+ # Only show if in exceptions list
272
+ return path_name not in self.DOTFILE_EXCEPTIONS
273
+
274
+ patterns = self.get_ignore_patterns(working_dir)
275
+
276
+ for pattern in patterns:
277
+ # Skip dotfile patterns since we already handled them above
278
+ if pattern in [".*", ".*/"]:
279
+ continue
280
+
281
+ # Simple pattern matching
282
+ if pattern.endswith("/"):
283
+ # Directory pattern
284
+ if path.is_dir() and path_name == pattern[:-1]:
285
+ return True
286
+ elif pattern.startswith("*."):
287
+ # Extension pattern
288
+ if path_name.endswith(pattern[1:]):
289
+ return True
290
+ elif "*" in pattern:
291
+ # Wildcard pattern (simplified)
292
+ import fnmatch
293
+
294
+ if fnmatch.fnmatch(path_name, pattern):
295
+ return True
296
+ elif pattern in path_str:
297
+ # Substring match
298
+ return True
299
+ elif path_name == pattern:
300
+ # Exact match
301
+ return True
302
+
303
+ return False
304
+
305
+ def clear_cache(self):
306
+ """Clear all caches."""
307
+ self._pathspec_cache.clear()
308
+ self._gitignore_cache.clear()
@@ -0,0 +1,39 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Code Tree Models
4
+ ================
5
+
6
+ Data structures for representing code nodes in the analysis tree.
7
+
8
+ WHY: Centralizes data models for clean separation between data and logic.
9
+ """
10
+
11
+ from dataclasses import dataclass
12
+ from typing import Any, Dict, List, Optional
13
+
14
+
15
+ @dataclass
16
+ class CodeNode:
17
+ """Represents a node in the code tree."""
18
+
19
+ file_path: str
20
+ node_type: str
21
+ name: str
22
+ line_start: int
23
+ line_end: int
24
+ complexity: int = 0
25
+ has_docstring: bool = False
26
+ decorators: List[str] = None
27
+ parent: Optional[str] = None
28
+ children: List["CodeNode"] = None
29
+ language: str = "python"
30
+ signature: str = ""
31
+ metrics: Dict[str, Any] = None
32
+
33
+ def __post_init__(self):
34
+ if self.decorators is None:
35
+ self.decorators = []
36
+ if self.children is None:
37
+ self.children = []
38
+ if self.metrics is None:
39
+ self.metrics = {}
@@ -0,0 +1,224 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Multi-Language Analyzer
4
+ ========================
5
+
6
+ Analyzes multiple programming languages using tree-sitter.
7
+
8
+ WHY: Tree-sitter provides consistent parsing across multiple languages,
9
+ allowing us to support JavaScript, TypeScript, and other languages.
10
+ """
11
+
12
+ import importlib.util
13
+ from pathlib import Path
14
+ from typing import ClassVar, List, Optional
15
+
16
+ from ...core.logging_config import get_logger
17
+ from ..code_tree_events import CodeNodeEvent, CodeTreeEventEmitter
18
+ from .models import CodeNode
19
+
20
+ # Check for tree-sitter availability
21
+ if importlib.util.find_spec("tree_sitter"):
22
+ import tree_sitter
23
+
24
+ TREE_SITTER_AVAILABLE = True
25
+ else:
26
+ TREE_SITTER_AVAILABLE = False
27
+ tree_sitter = None
28
+
29
+
30
+ class MultiLanguageAnalyzer:
31
+ """Analyzes multiple programming languages using tree-sitter."""
32
+
33
+ LANGUAGE_PARSERS: ClassVar[dict] = {
34
+ "python": "tree_sitter_python",
35
+ "javascript": "tree_sitter_javascript",
36
+ "typescript": "tree_sitter_typescript",
37
+ }
38
+
39
+ def __init__(self, emitter: Optional[CodeTreeEventEmitter] = None):
40
+ self.logger = get_logger(__name__)
41
+ self.emitter = emitter
42
+ self.parsers = {}
43
+ self._init_parsers()
44
+
45
+ def _init_parsers(self):
46
+ """Initialize tree-sitter parsers for supported languages."""
47
+ if not TREE_SITTER_AVAILABLE:
48
+ self.logger.warning(
49
+ "tree-sitter not available - multi-language support disabled"
50
+ )
51
+ return
52
+
53
+ for lang, module_name in self.LANGUAGE_PARSERS.items():
54
+ try:
55
+ # Dynamic import of language module
56
+ module = __import__(module_name)
57
+ parser = tree_sitter.Parser()
58
+ # Different tree-sitter versions have different APIs
59
+ if hasattr(parser, "set_language"):
60
+ parser.set_language(tree_sitter.Language(module.language()))
61
+ else:
62
+ # Newer API
63
+ lang_obj = tree_sitter.Language(module.language())
64
+ parser = tree_sitter.Parser(lang_obj)
65
+ self.parsers[lang] = parser
66
+ except (ImportError, AttributeError) as e:
67
+ # Silently skip unavailable parsers - will fall back to basic file discovery
68
+ self.logger.debug(f"Language parser not available for {lang}: {e}")
69
+
70
+ def analyze_file(self, file_path: Path, language: str) -> List[CodeNode]:
71
+ """Analyze a file using tree-sitter.
72
+
73
+ Args:
74
+ file_path: Path to source file
75
+ language: Programming language
76
+
77
+ Returns:
78
+ List of code nodes found in the file
79
+ """
80
+ if language not in self.parsers:
81
+ # No parser available - return empty list to fall back to basic discovery
82
+ self.logger.debug(
83
+ f"No parser available for language: {language}, using basic file discovery"
84
+ )
85
+ return []
86
+
87
+ nodes = []
88
+
89
+ try:
90
+ with file_path.open("rb") as f:
91
+ source = f.read()
92
+
93
+ parser = self.parsers[language]
94
+ tree = parser.parse(source)
95
+
96
+ # Extract nodes based on language
97
+ if language in {"javascript", "typescript"}:
98
+ nodes = self._extract_js_nodes(tree, file_path, source)
99
+ else:
100
+ nodes = self._extract_generic_nodes(tree, file_path, source, language)
101
+
102
+ except Exception as e:
103
+ self.logger.error(f"Error analyzing {file_path}: {e}")
104
+ if self.emitter:
105
+ self.emitter.emit_error(str(file_path), str(e))
106
+
107
+ return nodes
108
+
109
+ def _extract_js_nodes(self, tree, file_path: Path, source: bytes) -> List[CodeNode]:
110
+ """Extract nodes from JavaScript/TypeScript files."""
111
+ nodes = []
112
+
113
+ def walk_tree(node, parent_name=None):
114
+ if node.type == "class_declaration":
115
+ # Extract class
116
+ name_node = node.child_by_field_name("name")
117
+ if name_node:
118
+ class_node = CodeNode(
119
+ file_path=str(file_path),
120
+ node_type="class",
121
+ name=source[name_node.start_byte : name_node.end_byte].decode(
122
+ "utf-8"
123
+ ),
124
+ line_start=node.start_point[0] + 1,
125
+ line_end=node.end_point[0] + 1,
126
+ parent=parent_name,
127
+ language="javascript",
128
+ )
129
+ nodes.append(class_node)
130
+
131
+ if self.emitter:
132
+ self.emitter.emit_node(
133
+ CodeNodeEvent(
134
+ file_path=str(file_path),
135
+ node_type="class",
136
+ name=class_node.name,
137
+ line_start=class_node.line_start,
138
+ line_end=class_node.line_end,
139
+ parent=parent_name,
140
+ language="javascript",
141
+ )
142
+ )
143
+
144
+ elif node.type in (
145
+ "function_declaration",
146
+ "arrow_function",
147
+ "method_definition",
148
+ ):
149
+ # Extract function
150
+ name_node = node.child_by_field_name("name")
151
+ if name_node:
152
+ func_name = source[
153
+ name_node.start_byte : name_node.end_byte
154
+ ].decode("utf-8")
155
+ func_node = CodeNode(
156
+ file_path=str(file_path),
157
+ node_type=(
158
+ "function" if node.type != "method_definition" else "method"
159
+ ),
160
+ name=func_name,
161
+ line_start=node.start_point[0] + 1,
162
+ line_end=node.end_point[0] + 1,
163
+ parent=parent_name,
164
+ language="javascript",
165
+ )
166
+ nodes.append(func_node)
167
+
168
+ if self.emitter:
169
+ self.emitter.emit_node(
170
+ CodeNodeEvent(
171
+ file_path=str(file_path),
172
+ node_type=func_node.node_type,
173
+ name=func_name,
174
+ line_start=func_node.line_start,
175
+ line_end=func_node.line_end,
176
+ parent=parent_name,
177
+ language="javascript",
178
+ )
179
+ )
180
+
181
+ # Recursively walk children
182
+ for child in node.children:
183
+ walk_tree(child, parent_name)
184
+
185
+ walk_tree(tree.root_node)
186
+ return nodes
187
+
188
+ def _extract_generic_nodes(
189
+ self, tree, file_path: Path, source: bytes, language: str
190
+ ) -> List[CodeNode]:
191
+ """Generic node extraction for other languages."""
192
+ # Simple generic extraction - can be enhanced per language
193
+ nodes = []
194
+
195
+ def walk_tree(node):
196
+ # Look for common patterns
197
+ if "class" in node.type or "struct" in node.type:
198
+ nodes.append(
199
+ CodeNode(
200
+ file_path=str(file_path),
201
+ node_type="class",
202
+ name=f"{node.type}_{node.start_point[0]}",
203
+ line_start=node.start_point[0] + 1,
204
+ line_end=node.end_point[0] + 1,
205
+ language=language,
206
+ )
207
+ )
208
+ elif "function" in node.type or "method" in node.type:
209
+ nodes.append(
210
+ CodeNode(
211
+ file_path=str(file_path),
212
+ node_type="function",
213
+ name=f"{node.type}_{node.start_point[0]}",
214
+ line_start=node.start_point[0] + 1,
215
+ line_end=node.end_point[0] + 1,
216
+ language=language,
217
+ )
218
+ )
219
+
220
+ for child in node.children:
221
+ walk_tree(child)
222
+
223
+ walk_tree(tree.root_node)
224
+ return nodes