claude-mpm 4.14.6__py3-none-any.whl → 4.21.0__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.
Files changed (353) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_ENGINEER.md +286 -0
  3. claude_mpm/agents/BASE_PM.md +272 -23
  4. claude_mpm/agents/OUTPUT_STYLE.md +48 -3
  5. claude_mpm/agents/PM_INSTRUCTIONS.md +49 -0
  6. claude_mpm/agents/agent_loader.py +17 -5
  7. claude_mpm/agents/frontmatter_validator.py +284 -253
  8. claude_mpm/agents/templates/agentic-coder-optimizer.json +9 -2
  9. claude_mpm/agents/templates/api_qa.json +7 -1
  10. claude_mpm/agents/templates/clerk-ops.json +8 -1
  11. claude_mpm/agents/templates/code_analyzer.json +4 -1
  12. claude_mpm/agents/templates/dart_engineer.json +11 -1
  13. claude_mpm/agents/templates/data_engineer.json +11 -1
  14. claude_mpm/agents/templates/documentation.json +6 -1
  15. claude_mpm/agents/templates/engineer.json +18 -1
  16. claude_mpm/agents/templates/gcp_ops_agent.json +8 -1
  17. claude_mpm/agents/templates/golang_engineer.json +11 -1
  18. claude_mpm/agents/templates/java_engineer.json +12 -2
  19. claude_mpm/agents/templates/local_ops_agent.json +216 -37
  20. claude_mpm/agents/templates/nextjs_engineer.json +11 -1
  21. claude_mpm/agents/templates/ops.json +8 -1
  22. claude_mpm/agents/templates/php-engineer.json +20 -4
  23. claude_mpm/agents/templates/project_organizer.json +10 -3
  24. claude_mpm/agents/templates/prompt-engineer.json +5 -1
  25. claude_mpm/agents/templates/python_engineer.json +19 -4
  26. claude_mpm/agents/templates/qa.json +7 -1
  27. claude_mpm/agents/templates/react_engineer.json +11 -1
  28. claude_mpm/agents/templates/refactoring_engineer.json +8 -1
  29. claude_mpm/agents/templates/research.json +4 -1
  30. claude_mpm/agents/templates/ruby-engineer.json +11 -1
  31. claude_mpm/agents/templates/rust_engineer.json +23 -8
  32. claude_mpm/agents/templates/security.json +6 -1
  33. claude_mpm/agents/templates/svelte-engineer.json +225 -0
  34. claude_mpm/agents/templates/ticketing.json +6 -1
  35. claude_mpm/agents/templates/typescript_engineer.json +11 -1
  36. claude_mpm/agents/templates/vercel_ops_agent.json +8 -1
  37. claude_mpm/agents/templates/version_control.json +8 -1
  38. claude_mpm/agents/templates/web_qa.json +7 -1
  39. claude_mpm/agents/templates/web_ui.json +11 -1
  40. claude_mpm/cli/__init__.py +34 -740
  41. claude_mpm/cli/commands/__init__.py +2 -0
  42. claude_mpm/cli/commands/agent_manager.py +25 -12
  43. claude_mpm/cli/commands/agent_state_manager.py +186 -0
  44. claude_mpm/cli/commands/agents.py +204 -148
  45. claude_mpm/cli/commands/aggregate.py +7 -3
  46. claude_mpm/cli/commands/analyze.py +9 -4
  47. claude_mpm/cli/commands/analyze_code.py +7 -2
  48. claude_mpm/cli/commands/auto_configure.py +7 -9
  49. claude_mpm/cli/commands/config.py +47 -13
  50. claude_mpm/cli/commands/configure.py +294 -1788
  51. claude_mpm/cli/commands/configure_agent_display.py +261 -0
  52. claude_mpm/cli/commands/configure_behavior_manager.py +204 -0
  53. claude_mpm/cli/commands/configure_hook_manager.py +225 -0
  54. claude_mpm/cli/commands/configure_models.py +18 -0
  55. claude_mpm/cli/commands/configure_navigation.py +167 -0
  56. claude_mpm/cli/commands/configure_paths.py +104 -0
  57. claude_mpm/cli/commands/configure_persistence.py +254 -0
  58. claude_mpm/cli/commands/configure_startup_manager.py +646 -0
  59. claude_mpm/cli/commands/configure_template_editor.py +497 -0
  60. claude_mpm/cli/commands/configure_validators.py +73 -0
  61. claude_mpm/cli/commands/local_deploy.py +3 -2
  62. claude_mpm/cli/commands/memory.py +54 -20
  63. claude_mpm/cli/commands/mpm_init/__init__.py +73 -0
  64. claude_mpm/cli/commands/mpm_init/core.py +525 -0
  65. claude_mpm/cli/commands/mpm_init/display.py +341 -0
  66. claude_mpm/cli/commands/mpm_init/git_activity.py +427 -0
  67. claude_mpm/cli/commands/mpm_init/modes.py +397 -0
  68. claude_mpm/cli/commands/mpm_init/prompts.py +442 -0
  69. claude_mpm/cli/commands/mpm_init_cli.py +396 -0
  70. claude_mpm/cli/commands/mpm_init_handler.py +75 -4
  71. claude_mpm/cli/commands/skills.py +488 -0
  72. claude_mpm/cli/executor.py +204 -0
  73. claude_mpm/cli/helpers.py +105 -0
  74. claude_mpm/cli/interactive/__init__.py +3 -0
  75. claude_mpm/cli/interactive/skills_wizard.py +491 -0
  76. claude_mpm/cli/parsers/base_parser.py +7 -0
  77. claude_mpm/cli/parsers/mpm_init_parser.py +42 -0
  78. claude_mpm/cli/parsers/skills_parser.py +137 -0
  79. claude_mpm/cli/shared/output_formatters.py +28 -19
  80. claude_mpm/cli/startup.py +538 -0
  81. claude_mpm/commands/mpm-auto-configure.md +52 -0
  82. claude_mpm/commands/mpm-help.md +3 -0
  83. claude_mpm/commands/mpm-init.md +112 -6
  84. claude_mpm/commands/mpm-version.md +113 -0
  85. claude_mpm/commands/mpm.md +1 -0
  86. claude_mpm/config/agent_config.py +2 -2
  87. claude_mpm/constants.py +12 -0
  88. claude_mpm/core/base_service.py +13 -12
  89. claude_mpm/core/config.py +42 -0
  90. claude_mpm/core/enums.py +452 -0
  91. claude_mpm/core/factories.py +1 -1
  92. claude_mpm/core/instruction_reinforcement_hook.py +2 -1
  93. claude_mpm/core/interactive_session.py +6 -3
  94. claude_mpm/core/interfaces.py +56 -1
  95. claude_mpm/core/logging_config.py +6 -2
  96. claude_mpm/core/oneshot_session.py +8 -4
  97. claude_mpm/core/optimized_agent_loader.py +3 -3
  98. claude_mpm/core/output_style_manager.py +12 -192
  99. claude_mpm/core/service_registry.py +5 -1
  100. claude_mpm/core/types.py +2 -9
  101. claude_mpm/core/typing_utils.py +7 -6
  102. claude_mpm/dashboard/static/js/dashboard.js +0 -14
  103. claude_mpm/dashboard/templates/index.html +3 -41
  104. claude_mpm/hooks/__init__.py +8 -0
  105. claude_mpm/hooks/claude_hooks/response_tracking.py +35 -1
  106. claude_mpm/hooks/instruction_reinforcement.py +7 -2
  107. claude_mpm/hooks/session_resume_hook.py +121 -0
  108. claude_mpm/models/resume_log.py +340 -0
  109. claude_mpm/services/agents/auto_config_manager.py +10 -11
  110. claude_mpm/services/agents/deployment/agent_configuration_manager.py +1 -1
  111. claude_mpm/services/agents/deployment/agent_record_service.py +1 -1
  112. claude_mpm/services/agents/deployment/agent_validator.py +17 -1
  113. claude_mpm/services/agents/deployment/async_agent_deployment.py +1 -1
  114. claude_mpm/services/agents/deployment/interface_adapter.py +3 -2
  115. claude_mpm/services/agents/deployment/local_template_deployment.py +1 -1
  116. claude_mpm/services/agents/deployment/pipeline/steps/agent_processing_step.py +7 -6
  117. claude_mpm/services/agents/deployment/pipeline/steps/base_step.py +7 -16
  118. claude_mpm/services/agents/deployment/pipeline/steps/configuration_step.py +4 -3
  119. claude_mpm/services/agents/deployment/pipeline/steps/target_directory_step.py +5 -3
  120. claude_mpm/services/agents/deployment/pipeline/steps/validation_step.py +6 -5
  121. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +9 -6
  122. claude_mpm/services/agents/deployment/validation/__init__.py +3 -1
  123. claude_mpm/services/agents/deployment/validation/validation_result.py +1 -9
  124. claude_mpm/services/agents/local_template_manager.py +1 -1
  125. claude_mpm/services/agents/memory/agent_memory_manager.py +5 -2
  126. claude_mpm/services/agents/recommender.py +47 -0
  127. claude_mpm/services/agents/registry/modification_tracker.py +5 -2
  128. claude_mpm/services/cli/resume_service.py +617 -0
  129. claude_mpm/services/cli/session_manager.py +87 -0
  130. claude_mpm/services/cli/session_pause_manager.py +504 -0
  131. claude_mpm/services/cli/session_resume_helper.py +372 -0
  132. claude_mpm/services/command_handler_service.py +11 -5
  133. claude_mpm/services/core/interfaces/process.py +6 -6
  134. claude_mpm/services/core/interfaces.py +56 -1
  135. claude_mpm/services/core/models/__init__.py +0 -2
  136. claude_mpm/services/core/models/agent_config.py +15 -28
  137. claude_mpm/services/core/models/health.py +1 -28
  138. claude_mpm/services/core/models/process.py +22 -41
  139. claude_mpm/services/core/path_resolver.py +1 -1
  140. claude_mpm/services/diagnostics/__init__.py +2 -2
  141. claude_mpm/services/diagnostics/checks/agent_check.py +25 -24
  142. claude_mpm/services/diagnostics/checks/claude_code_check.py +24 -23
  143. claude_mpm/services/diagnostics/checks/common_issues_check.py +25 -24
  144. claude_mpm/services/diagnostics/checks/configuration_check.py +24 -23
  145. claude_mpm/services/diagnostics/checks/filesystem_check.py +18 -17
  146. claude_mpm/services/diagnostics/checks/installation_check.py +30 -29
  147. claude_mpm/services/diagnostics/checks/instructions_check.py +20 -19
  148. claude_mpm/services/diagnostics/checks/mcp_check.py +50 -36
  149. claude_mpm/services/diagnostics/checks/mcp_services_check.py +36 -31
  150. claude_mpm/services/diagnostics/checks/monitor_check.py +23 -22
  151. claude_mpm/services/diagnostics/checks/startup_log_check.py +9 -8
  152. claude_mpm/services/diagnostics/diagnostic_runner.py +6 -5
  153. claude_mpm/services/diagnostics/doctor_reporter.py +28 -25
  154. claude_mpm/services/diagnostics/models.py +37 -21
  155. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -1
  156. claude_mpm/services/infrastructure/monitoring/aggregator.py +12 -12
  157. claude_mpm/services/infrastructure/monitoring/base.py +5 -13
  158. claude_mpm/services/infrastructure/monitoring/network.py +7 -6
  159. claude_mpm/services/infrastructure/monitoring/process.py +13 -12
  160. claude_mpm/services/infrastructure/monitoring/resources.py +7 -6
  161. claude_mpm/services/infrastructure/monitoring/service.py +16 -15
  162. claude_mpm/services/infrastructure/resume_log_generator.py +439 -0
  163. claude_mpm/services/local_ops/__init__.py +5 -3
  164. claude_mpm/services/local_ops/crash_detector.py +1 -1
  165. claude_mpm/services/local_ops/health_checks/http_check.py +2 -1
  166. claude_mpm/services/local_ops/health_checks/process_check.py +2 -1
  167. claude_mpm/services/local_ops/health_checks/resource_check.py +2 -1
  168. claude_mpm/services/local_ops/health_manager.py +1 -1
  169. claude_mpm/services/local_ops/process_manager.py +12 -12
  170. claude_mpm/services/local_ops/restart_manager.py +1 -1
  171. claude_mpm/services/local_ops/state_manager.py +6 -5
  172. claude_mpm/services/local_ops/unified_manager.py +2 -2
  173. claude_mpm/services/mcp_config_manager.py +7 -126
  174. claude_mpm/services/mcp_gateway/auto_configure.py +31 -25
  175. claude_mpm/services/mcp_gateway/core/__init__.py +1 -2
  176. claude_mpm/services/mcp_gateway/core/base.py +18 -31
  177. claude_mpm/services/mcp_gateway/core/process_pool.py +19 -10
  178. claude_mpm/services/mcp_gateway/tools/external_mcp_services.py +97 -45
  179. claude_mpm/services/mcp_gateway/tools/health_check_tool.py +30 -28
  180. claude_mpm/services/memory_hook_service.py +4 -1
  181. claude_mpm/services/monitor/daemon_manager.py +3 -2
  182. claude_mpm/services/monitor/handlers/dashboard.py +2 -1
  183. claude_mpm/services/monitor/handlers/hooks.py +2 -1
  184. claude_mpm/services/monitor/management/lifecycle.py +3 -2
  185. claude_mpm/services/monitor/server.py +2 -1
  186. claude_mpm/services/session_management_service.py +3 -2
  187. claude_mpm/services/session_manager.py +205 -1
  188. claude_mpm/services/shared/async_service_base.py +16 -27
  189. claude_mpm/services/shared/lifecycle_service_base.py +1 -14
  190. claude_mpm/services/socketio/handlers/__init__.py +5 -2
  191. claude_mpm/services/socketio/handlers/hook.py +13 -2
  192. claude_mpm/services/socketio/handlers/registry.py +4 -2
  193. claude_mpm/services/socketio/server/main.py +10 -8
  194. claude_mpm/services/subprocess_launcher_service.py +14 -5
  195. claude_mpm/services/unified/analyzer_strategies/code_analyzer.py +8 -7
  196. claude_mpm/services/unified/analyzer_strategies/dependency_analyzer.py +6 -5
  197. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +8 -7
  198. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +7 -6
  199. claude_mpm/services/unified/analyzer_strategies/structure_analyzer.py +5 -4
  200. claude_mpm/services/unified/config_strategies/validation_strategy.py +13 -9
  201. claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +10 -3
  202. claude_mpm/services/unified/deployment_strategies/local.py +6 -5
  203. claude_mpm/services/unified/deployment_strategies/utils.py +6 -5
  204. claude_mpm/services/unified/deployment_strategies/vercel.py +7 -6
  205. claude_mpm/services/unified/interfaces.py +3 -1
  206. claude_mpm/services/unified/unified_analyzer.py +14 -10
  207. claude_mpm/services/unified/unified_config.py +2 -1
  208. claude_mpm/services/unified/unified_deployment.py +9 -4
  209. claude_mpm/services/version_service.py +104 -1
  210. claude_mpm/skills/__init__.py +42 -0
  211. claude_mpm/skills/agent_skills_injector.py +324 -0
  212. claude_mpm/skills/bundled/LICENSE_ATTRIBUTIONS.md +79 -0
  213. claude_mpm/skills/bundled/__init__.py +6 -0
  214. claude_mpm/skills/bundled/api-documentation.md +393 -0
  215. claude_mpm/skills/bundled/async-testing.md +571 -0
  216. claude_mpm/skills/bundled/code-review.md +143 -0
  217. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +79 -0
  218. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +178 -0
  219. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +577 -0
  220. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +467 -0
  221. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +537 -0
  222. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +730 -0
  223. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +112 -0
  224. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +146 -0
  225. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +412 -0
  226. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +81 -0
  227. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +362 -0
  228. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +312 -0
  229. claude_mpm/skills/bundled/database-migration.md +199 -0
  230. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +152 -0
  231. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +668 -0
  232. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +587 -0
  233. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +438 -0
  234. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +391 -0
  235. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +119 -0
  236. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +148 -0
  237. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +483 -0
  238. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +452 -0
  239. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +449 -0
  240. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +411 -0
  241. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +14 -0
  242. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +58 -0
  243. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +68 -0
  244. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +69 -0
  245. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +131 -0
  246. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +325 -0
  247. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +490 -0
  248. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +425 -0
  249. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +499 -0
  250. claude_mpm/skills/bundled/docker-containerization.md +194 -0
  251. claude_mpm/skills/bundled/express-local-dev.md +1429 -0
  252. claude_mpm/skills/bundled/fastapi-local-dev.md +1199 -0
  253. claude_mpm/skills/bundled/git-workflow.md +414 -0
  254. claude_mpm/skills/bundled/imagemagick.md +204 -0
  255. claude_mpm/skills/bundled/json-data-handling.md +223 -0
  256. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +86 -0
  257. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +43 -0
  258. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +47 -0
  259. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +65 -0
  260. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +30 -0
  261. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +16 -0
  262. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +160 -0
  263. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +412 -0
  264. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +602 -0
  265. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +915 -0
  266. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +916 -0
  267. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +752 -0
  268. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +1237 -0
  269. claude_mpm/skills/bundled/main/mcp-builder/scripts/connections.py +157 -0
  270. claude_mpm/skills/bundled/main/mcp-builder/scripts/evaluation.py +425 -0
  271. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +189 -0
  272. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +500 -0
  273. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +464 -0
  274. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +619 -0
  275. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +437 -0
  276. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +231 -0
  277. claude_mpm/skills/bundled/main/skill-creator/scripts/init_skill.py +303 -0
  278. claude_mpm/skills/bundled/main/skill-creator/scripts/package_skill.py +113 -0
  279. claude_mpm/skills/bundled/main/skill-creator/scripts/quick_validate.py +72 -0
  280. claude_mpm/skills/bundled/nextjs-local-dev.md +807 -0
  281. claude_mpm/skills/bundled/pdf.md +141 -0
  282. claude_mpm/skills/bundled/performance-profiling.md +567 -0
  283. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +170 -0
  284. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +602 -0
  285. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +821 -0
  286. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +742 -0
  287. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +726 -0
  288. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +764 -0
  289. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +831 -0
  290. claude_mpm/skills/bundled/refactoring-patterns.md +180 -0
  291. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +226 -0
  292. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +901 -0
  293. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +901 -0
  294. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +775 -0
  295. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +937 -0
  296. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +770 -0
  297. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +961 -0
  298. claude_mpm/skills/bundled/security-scanning.md +327 -0
  299. claude_mpm/skills/bundled/systematic-debugging.md +473 -0
  300. claude_mpm/skills/bundled/test-driven-development.md +378 -0
  301. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +119 -0
  302. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +253 -0
  303. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +145 -0
  304. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +543 -0
  305. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +741 -0
  306. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +470 -0
  307. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +458 -0
  308. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +639 -0
  309. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +140 -0
  310. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +572 -0
  311. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +411 -0
  312. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +569 -0
  313. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +695 -0
  314. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +184 -0
  315. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +459 -0
  316. claude_mpm/skills/bundled/testing/webapp-testing/examples/console_logging.py +35 -0
  317. claude_mpm/skills/bundled/testing/webapp-testing/examples/element_discovery.py +44 -0
  318. claude_mpm/skills/bundled/testing/webapp-testing/examples/static_html_automation.py +34 -0
  319. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +479 -0
  320. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +687 -0
  321. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +129 -0
  322. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +758 -0
  323. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +868 -0
  324. claude_mpm/skills/bundled/vite-local-dev.md +1061 -0
  325. claude_mpm/skills/bundled/web-performance-optimization.md +2305 -0
  326. claude_mpm/skills/bundled/xlsx.md +157 -0
  327. claude_mpm/skills/registry.py +286 -0
  328. claude_mpm/skills/skill_manager.py +310 -0
  329. claude_mpm/skills/skills_registry.py +348 -0
  330. claude_mpm/skills/skills_service.py +739 -0
  331. claude_mpm/tools/code_tree_analyzer.py +177 -141
  332. claude_mpm/tools/code_tree_events.py +4 -2
  333. claude_mpm/utils/agent_dependency_loader.py +2 -2
  334. {claude_mpm-4.14.6.dist-info → claude_mpm-4.21.0.dist-info}/METADATA +211 -33
  335. {claude_mpm-4.14.6.dist-info → claude_mpm-4.21.0.dist-info}/RECORD +339 -199
  336. claude_mpm/agents/INSTRUCTIONS_OLD_DEPRECATED.md +0 -602
  337. claude_mpm/cli/commands/mpm_init.py +0 -1994
  338. claude_mpm/dashboard/static/css/code-tree.css +0 -1639
  339. claude_mpm/dashboard/static/js/components/code-tree/tree-breadcrumb.js +0 -353
  340. claude_mpm/dashboard/static/js/components/code-tree/tree-constants.js +0 -235
  341. claude_mpm/dashboard/static/js/components/code-tree/tree-search.js +0 -409
  342. claude_mpm/dashboard/static/js/components/code-tree/tree-utils.js +0 -435
  343. claude_mpm/dashboard/static/js/components/code-tree.js +0 -5869
  344. claude_mpm/dashboard/static/js/components/code-viewer.js +0 -1386
  345. claude_mpm/hooks/claude_hooks/hook_handler_eventbus.py +0 -425
  346. claude_mpm/hooks/claude_hooks/hook_handler_original.py +0 -1041
  347. claude_mpm/hooks/claude_hooks/hook_handler_refactored.py +0 -347
  348. claude_mpm/services/agents/deployment/agent_lifecycle_manager_refactored.py +0 -575
  349. claude_mpm/services/project/analyzer_refactored.py +0 -450
  350. {claude_mpm-4.14.6.dist-info → claude_mpm-4.21.0.dist-info}/WHEEL +0 -0
  351. {claude_mpm-4.14.6.dist-info → claude_mpm-4.21.0.dist-info}/entry_points.txt +0 -0
  352. {claude_mpm-4.14.6.dist-info → claude_mpm-4.21.0.dist-info}/licenses/LICENSE +0 -0
  353. {claude_mpm-4.14.6.dist-info → claude_mpm-4.21.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,105 @@
1
+ """
2
+ CLI Helper Utilities
3
+ ====================
4
+
5
+ This module provides helper functions for the CLI, including configuration
6
+ checks and user prompts.
7
+
8
+ Part of cli/__init__.py refactoring to reduce file size and improve modularity.
9
+ """
10
+
11
+ import sys
12
+ from pathlib import Path
13
+
14
+
15
+ def has_configuration_file() -> bool:
16
+ """Check if any configuration file exists in standard locations."""
17
+ config_paths = [
18
+ Path.cwd() / ".claude-mpm" / "configuration.yaml",
19
+ Path.cwd() / ".claude-mpm" / "configuration.yml",
20
+ Path.home() / ".claude-mpm" / "configuration.yaml",
21
+ Path.home() / ".claude-mpm" / "configuration.yml",
22
+ ]
23
+ return any(path.exists() for path in config_paths)
24
+
25
+
26
+ def is_interactive_session() -> bool:
27
+ """Check if running in an interactive terminal."""
28
+ return sys.stdin.isatty() and sys.stdout.isatty()
29
+
30
+
31
+ def should_skip_config_check(command: str | None) -> bool:
32
+ """Check if command should skip configuration check."""
33
+ skip_commands = ["configure", "doctor", "info", "mcp", "config"]
34
+ return command in skip_commands if command else False
35
+
36
+
37
+ def prompt_for_configuration() -> bool:
38
+ """Prompt user to run configuration wizard.
39
+
40
+ Returns:
41
+ bool: True if user wants to configure, False otherwise
42
+ """
43
+ from rich.console import Console as RichConsole
44
+ from rich.prompt import Confirm
45
+
46
+ console = RichConsole()
47
+
48
+ console.print()
49
+ console.print("[yellow]⚙️ Configuration Recommended[/yellow]")
50
+ console.print()
51
+ console.print("Claude MPM works best with proper configuration.")
52
+ console.print("The configurator helps you:")
53
+ console.print(" • Enable/disable MCP services (ticketer, browser, vector-search)")
54
+ console.print(" • Configure hook services (monitor, dashboard)")
55
+ console.print(" • Select system agents to use")
56
+ console.print()
57
+
58
+ return Confirm.ask("Would you like to run the configurator now?", default=True)
59
+
60
+
61
+ def handle_missing_configuration():
62
+ """Handle missing configuration file by prompting user to configure.
63
+
64
+ WHY: Centralizes the logic for handling missing configuration files,
65
+ keeping main() cleaner and more focused.
66
+ """
67
+ if is_interactive_session():
68
+ # Interactive: Offer to run configurator
69
+ if prompt_for_configuration():
70
+ from rich.console import Console as RichConsole
71
+
72
+ # Import configure command only when needed
73
+ from .commands.configure import ConfigureCommand
74
+
75
+ console = RichConsole()
76
+ config_cmd = ConfigureCommand()
77
+ try:
78
+ config_cmd.execute({})
79
+ console.print(
80
+ "\n[green]✓[/green] Configuration complete! "
81
+ "Continuing with command...\n"
82
+ )
83
+ except Exception as e:
84
+ console.print(f"\n[yellow]⚠[/yellow] Configuration error: {e}")
85
+ console.print(
86
+ "[yellow]Continuing with default configuration...\n[/yellow]"
87
+ )
88
+ else:
89
+ from rich.console import Console as RichConsole
90
+
91
+ console = RichConsole()
92
+ console.print("\n[dim]Using default configuration.[/dim]")
93
+ console.print(
94
+ "[dim]Run 'claude-mpm configure' anytime to set up your "
95
+ "preferences.\n[/dim]"
96
+ )
97
+ else:
98
+ # Non-interactive: Log message only
99
+ import logging
100
+
101
+ logger = logging.getLogger(__name__)
102
+ logger.info(
103
+ "Configuration file not found, using defaults. "
104
+ "Run 'claude-mpm configure' to customize."
105
+ )
@@ -10,9 +10,12 @@ from .agent_wizard import (
10
10
  run_interactive_agent_manager,
11
11
  run_interactive_agent_wizard,
12
12
  )
13
+ from .skills_wizard import SkillsWizard, discover_and_link_runtime_skills
13
14
 
14
15
  __all__ = [
15
16
  "AgentWizard",
17
+ "SkillsWizard",
18
+ "discover_and_link_runtime_skills",
16
19
  "run_interactive_agent_manager",
17
20
  "run_interactive_agent_wizard",
18
21
  ]
@@ -0,0 +1,491 @@
1
+ """Interactive Skills Selection Wizard for Claude MPM.
2
+
3
+ This module provides a step-by-step interactive wizard for selecting and configuring
4
+ skills for agents with user-friendly prompts and intelligent auto-linking.
5
+ """
6
+
7
+ from typing import Dict, List, Optional, Tuple
8
+
9
+ from claude_mpm.core.logging_config import get_logger
10
+ from claude_mpm.skills.registry import get_registry
11
+ from claude_mpm.skills.skill_manager import get_manager
12
+
13
+ logger = get_logger(__name__)
14
+
15
+
16
+ # Agent-to-skills auto-linking mappings
17
+ ENGINEER_CORE_SKILLS = [
18
+ "test-driven-development",
19
+ "systematic-debugging",
20
+ "code-review",
21
+ "refactoring-patterns",
22
+ "git-workflow",
23
+ ]
24
+
25
+ PYTHON_SKILLS = ENGINEER_CORE_SKILLS + ["async-testing"]
26
+ TYPESCRIPT_SKILLS = ENGINEER_CORE_SKILLS + ["async-testing"]
27
+ GOLANG_SKILLS = ENGINEER_CORE_SKILLS + ["async-testing"]
28
+ REACT_SKILLS = TYPESCRIPT_SKILLS + ["performance-profiling"]
29
+ NEXTJS_SKILLS = REACT_SKILLS
30
+ VUE_SKILLS = TYPESCRIPT_SKILLS + ["performance-profiling"]
31
+
32
+ OPS_SKILLS = [
33
+ "docker-containerization",
34
+ "database-migration",
35
+ "security-scanning",
36
+ "systematic-debugging",
37
+ ]
38
+
39
+ DOCUMENTATION_SKILLS = [
40
+ "api-documentation",
41
+ "code-review",
42
+ ]
43
+
44
+ QA_SKILLS = [
45
+ "test-driven-development",
46
+ "systematic-debugging",
47
+ "async-testing",
48
+ "performance-profiling",
49
+ ]
50
+
51
+ # Mapping of agent types to their recommended skills
52
+ AGENT_SKILL_MAPPING = {
53
+ # Engineer agents
54
+ "engineer": ENGINEER_CORE_SKILLS,
55
+ "python-engineer": PYTHON_SKILLS,
56
+ "typescript-engineer": TYPESCRIPT_SKILLS,
57
+ "golang-engineer": GOLANG_SKILLS,
58
+ "react-engineer": REACT_SKILLS,
59
+ "nextjs-engineer": NEXTJS_SKILLS,
60
+ "vue-engineer": VUE_SKILLS,
61
+ # Ops agents
62
+ "ops": OPS_SKILLS,
63
+ "devops": OPS_SKILLS,
64
+ "local-ops": OPS_SKILLS,
65
+ # Documentation agents
66
+ "docs": DOCUMENTATION_SKILLS,
67
+ "documentation": DOCUMENTATION_SKILLS,
68
+ "technical-writer": DOCUMENTATION_SKILLS,
69
+ # QA agents
70
+ "qa": QA_SKILLS,
71
+ "web-qa": QA_SKILLS,
72
+ "api-qa": QA_SKILLS,
73
+ "tester": QA_SKILLS,
74
+ }
75
+
76
+
77
+ class SkillsWizard:
78
+ """Interactive wizard for skills selection and configuration."""
79
+
80
+ def __init__(self):
81
+ """Initialize the skills wizard."""
82
+ self.registry = get_registry()
83
+ self.manager = get_manager()
84
+ self.logger = logger
85
+
86
+ def run_interactive_selection(
87
+ self, selected_agents: Optional[List[str]] = None
88
+ ) -> Tuple[bool, Dict[str, List[str]]]:
89
+ """Run interactive skills selection wizard.
90
+
91
+ Args:
92
+ selected_agents: List of agent IDs that were selected in agent wizard
93
+
94
+ Returns:
95
+ Tuple of (success, agent_skills_mapping)
96
+ - success: Boolean indicating if selection was successful
97
+ - agent_skills_mapping: Dict mapping agent IDs to lists of skill names
98
+ """
99
+ try:
100
+ print("\n" + "=" * 60)
101
+ print("🎯 Skills Selection Wizard")
102
+ print("=" * 60)
103
+ print("\nI'll help you select skills for your agents.")
104
+ print("Press Ctrl+C anytime to cancel.\n")
105
+
106
+ # Auto-link skills based on selected agents
107
+ agent_skills_mapping = {}
108
+ if selected_agents:
109
+ print("📋 Auto-linking skills based on selected agents...\n")
110
+ agent_skills_mapping = self._auto_link_skills(selected_agents)
111
+ self._display_auto_linked_skills(agent_skills_mapping)
112
+
113
+ # Ask if user wants to customize
114
+ customize = (
115
+ input("\nWould you like to customize skill selections? [y/N]: ")
116
+ .strip()
117
+ .lower()
118
+ )
119
+
120
+ if customize in ["y", "yes"]:
121
+ agent_skills_mapping = self._run_custom_selection(
122
+ selected_agents, agent_skills_mapping
123
+ )
124
+
125
+ # Preview final configuration
126
+ self._preview_final_configuration(agent_skills_mapping)
127
+
128
+ # Confirm
129
+ confirm = (
130
+ input("\nApply this skills configuration? [Y/n]: ").strip().lower()
131
+ )
132
+ if confirm in ["n", "no"]:
133
+ return False, {}
134
+
135
+ # Apply configuration
136
+ self._apply_skills_configuration(agent_skills_mapping)
137
+
138
+ print("\n✅ Skills configuration complete!")
139
+ return True, agent_skills_mapping
140
+
141
+ except KeyboardInterrupt:
142
+ print("\n\n❌ Skills selection cancelled")
143
+ return False, {}
144
+ except Exception as e:
145
+ error_msg = f"Skills selection error: {e}"
146
+ self.logger.error(error_msg, exc_info=True)
147
+ print(f"\n❌ {error_msg}")
148
+ return False, {}
149
+
150
+ def _auto_link_skills(self, agent_ids: List[str]) -> Dict[str, List[str]]:
151
+ """Auto-link skills to agents based on agent types.
152
+
153
+ Args:
154
+ agent_ids: List of agent IDs
155
+
156
+ Returns:
157
+ Dictionary mapping agent IDs to skill names
158
+ """
159
+ mapping = {}
160
+ for agent_id in agent_ids:
161
+ # Try to match against known patterns
162
+ skills = self._get_recommended_skills_for_agent(agent_id)
163
+ if skills:
164
+ mapping[agent_id] = skills
165
+ else:
166
+ # Default to core engineer skills if no match
167
+ mapping[agent_id] = ENGINEER_CORE_SKILLS.copy()
168
+
169
+ return mapping
170
+
171
+ def _get_recommended_skills_for_agent(self, agent_id: str) -> List[str]:
172
+ """Get recommended skills for an agent based on its ID.
173
+
174
+ Args:
175
+ agent_id: Agent identifier
176
+
177
+ Returns:
178
+ List of recommended skill names
179
+ """
180
+ agent_id_lower = agent_id.lower()
181
+
182
+ # Direct match
183
+ if agent_id_lower in AGENT_SKILL_MAPPING:
184
+ return AGENT_SKILL_MAPPING[agent_id_lower].copy()
185
+
186
+ # Fuzzy matching for common patterns
187
+ if "python" in agent_id_lower:
188
+ return PYTHON_SKILLS.copy()
189
+ if any(js in agent_id_lower for js in ["typescript", "ts", "javascript", "js"]):
190
+ return TYPESCRIPT_SKILLS.copy()
191
+ if "react" in agent_id_lower:
192
+ return REACT_SKILLS.copy()
193
+ if "next" in agent_id_lower:
194
+ return NEXTJS_SKILLS.copy()
195
+ if "vue" in agent_id_lower:
196
+ return VUE_SKILLS.copy()
197
+ if "go" in agent_id_lower or "golang" in agent_id_lower:
198
+ return GOLANG_SKILLS.copy()
199
+ if any(ops in agent_id_lower for ops in ["ops", "devops", "deploy"]):
200
+ return OPS_SKILLS.copy()
201
+ if any(qa in agent_id_lower for qa in ["qa", "test", "quality"]):
202
+ return QA_SKILLS.copy()
203
+ if any(doc in agent_id_lower for doc in ["doc", "writer", "technical"]):
204
+ return DOCUMENTATION_SKILLS.copy()
205
+ if "engineer" in agent_id_lower:
206
+ return ENGINEER_CORE_SKILLS.copy()
207
+
208
+ # Default
209
+ return []
210
+
211
+ def _display_auto_linked_skills(self, mapping: Dict[str, List[str]]):
212
+ """Display auto-linked skills configuration.
213
+
214
+ Args:
215
+ mapping: Agent-to-skills mapping
216
+ """
217
+ for agent_id, skills in mapping.items():
218
+ print(f" • {agent_id}:")
219
+ for skill in skills:
220
+ print(f" - {skill}")
221
+ print()
222
+
223
+ def _run_custom_selection(
224
+ self, agent_ids: Optional[List[str]], initial_mapping: Dict[str, List[str]]
225
+ ) -> Dict[str, List[str]]:
226
+ """Run custom skills selection for each agent.
227
+
228
+ Args:
229
+ agent_ids: List of agent IDs
230
+ initial_mapping: Initial auto-linked mapping
231
+
232
+ Returns:
233
+ Updated agent-to-skills mapping
234
+ """
235
+ mapping = initial_mapping.copy()
236
+
237
+ # Get all available bundled skills
238
+ bundled_skills = self.registry.list_skills(source="bundled")
239
+ skill_list = sorted([skill.name for skill in bundled_skills])
240
+
241
+ print("\n" + "=" * 60)
242
+ print("Available Bundled Skills:")
243
+ print("=" * 60)
244
+ for i, skill in enumerate(bundled_skills, 1):
245
+ description = (
246
+ skill.description[:60] + "..."
247
+ if len(skill.description) > 60
248
+ else skill.description
249
+ )
250
+ print(f" [{i:2d}] {skill.name}")
251
+ print(f" {description}")
252
+ print()
253
+
254
+ # If no agents provided, ask which agents to configure
255
+ if not agent_ids:
256
+ agent_ids = self._get_agents_to_configure()
257
+
258
+ # Configure each agent
259
+ for agent_id in agent_ids:
260
+ print(f"\n🔧 Configuring skills for: {agent_id}")
261
+ current_skills = mapping.get(agent_id, [])
262
+
263
+ print(f" Current skills ({len(current_skills)}):")
264
+ for skill in current_skills:
265
+ print(f" - {skill}")
266
+
267
+ modify = (
268
+ input(f"\n Modify skills for {agent_id}? [y/N]: ").strip().lower()
269
+ )
270
+ if modify not in ["y", "yes"]:
271
+ continue
272
+
273
+ # Let user select skills
274
+ print("\n Enter skill numbers (comma-separated), or:")
275
+ print(" 'all' - Select all skills")
276
+ print(" 'none' - Clear all skills")
277
+ print(" 'keep' - Keep current selection")
278
+ selection = input(" Selection: ").strip().lower()
279
+
280
+ if selection == "keep":
281
+ continue
282
+ if selection == "none":
283
+ mapping[agent_id] = []
284
+ elif selection == "all":
285
+ mapping[agent_id] = skill_list.copy()
286
+ else:
287
+ # Parse comma-separated numbers
288
+ try:
289
+ selected_indices = [
290
+ int(idx.strip()) for idx in selection.split(",")
291
+ ]
292
+ selected_skills = [
293
+ skill_list[idx - 1]
294
+ for idx in selected_indices
295
+ if 1 <= idx <= len(skill_list)
296
+ ]
297
+ mapping[agent_id] = selected_skills
298
+ except (ValueError, IndexError) as e:
299
+ print(f" ⚠️ Invalid selection, keeping current: {e}")
300
+
301
+ return mapping
302
+
303
+ def _get_agents_to_configure(self) -> List[str]:
304
+ """Ask user which agents to configure.
305
+
306
+ Returns:
307
+ List of agent IDs
308
+ """
309
+ agent_ids_input = input("\nEnter agent IDs (comma-separated): ").strip()
310
+ return [aid.strip() for aid in agent_ids_input.split(",") if aid.strip()]
311
+
312
+ def _preview_final_configuration(self, mapping: Dict[str, List[str]]):
313
+ """Display final skills configuration preview.
314
+
315
+ Args:
316
+ mapping: Agent-to-skills mapping
317
+ """
318
+ print("\n" + "=" * 60)
319
+ print("📋 Final Skills Configuration:")
320
+ print("=" * 60)
321
+
322
+ if not mapping:
323
+ print(" (No skills configured)")
324
+ return
325
+
326
+ for agent_id, skills in mapping.items():
327
+ print(f"\n {agent_id} ({len(skills)} skills):")
328
+ if skills:
329
+ for skill in skills:
330
+ print(f" ✓ {skill}")
331
+ else:
332
+ print(" (no skills)")
333
+
334
+ def _apply_skills_configuration(self, mapping: Dict[str, List[str]]):
335
+ """Apply skills configuration to skill manager.
336
+
337
+ Args:
338
+ mapping: Agent-to-skills mapping
339
+ """
340
+ for agent_id, skills in mapping.items():
341
+ # Clear existing mappings for this agent
342
+ if agent_id in self.manager.agent_skill_mapping:
343
+ self.manager.agent_skill_mapping[agent_id] = []
344
+
345
+ # Add each skill
346
+ for skill_name in skills:
347
+ self.manager.add_skill_to_agent(agent_id, skill_name)
348
+
349
+ self.logger.info(f"Applied skills configuration for {len(mapping)} agents")
350
+
351
+ def list_available_skills(self):
352
+ """Display all available skills."""
353
+ print("\n" + "=" * 60)
354
+ print("📚 Available Skills")
355
+ print("=" * 60)
356
+
357
+ # Bundled skills
358
+ bundled_skills = self.registry.list_skills(source="bundled")
359
+ if bundled_skills:
360
+ print(f"\n🔹 Bundled Skills ({len(bundled_skills)}):")
361
+ for skill in sorted(bundled_skills, key=lambda s: s.name):
362
+ print(f" • {skill.name}")
363
+ if skill.description:
364
+ desc = (
365
+ skill.description[:80] + "..."
366
+ if len(skill.description) > 80
367
+ else skill.description
368
+ )
369
+ print(f" {desc}")
370
+
371
+ # User skills
372
+ user_skills = self.registry.list_skills(source="user")
373
+ if user_skills:
374
+ print(f"\n👤 User Skills ({len(user_skills)}):")
375
+ for skill in sorted(user_skills, key=lambda s: s.name):
376
+ print(f" • {skill.name}")
377
+ if skill.description:
378
+ desc = (
379
+ skill.description[:80] + "..."
380
+ if len(skill.description) > 80
381
+ else skill.description
382
+ )
383
+ print(f" {desc}")
384
+
385
+ # Project skills
386
+ project_skills = self.registry.list_skills(source="project")
387
+ if project_skills:
388
+ print(f"\n📂 Project Skills ({len(project_skills)}):")
389
+ for skill in sorted(project_skills, key=lambda s: s.name):
390
+ print(f" • {skill.name}")
391
+ if skill.description:
392
+ desc = (
393
+ skill.description[:80] + "..."
394
+ if len(skill.description) > 80
395
+ else skill.description
396
+ )
397
+ print(f" {desc}")
398
+
399
+ print()
400
+
401
+
402
+ def discover_and_link_runtime_skills():
403
+ """Discover user/project skills and auto-link to agents at runtime.
404
+
405
+ This function is called during startup to:
406
+ 1. Reload the skills registry (picks up new skills from .claude/skills/)
407
+ 2. Auto-link discovered skills to agents based on tags/naming conventions
408
+ """
409
+ try:
410
+ registry = get_registry()
411
+ manager = get_manager()
412
+
413
+ # Reload registry to pick up new skills
414
+ registry.reload()
415
+
416
+ # Get discovered skills (user and project)
417
+ discovered_skills = registry.list_skills(source="user") + registry.list_skills(
418
+ source="project"
419
+ )
420
+
421
+ if not discovered_skills:
422
+ logger.debug("No runtime skills discovered")
423
+ return
424
+
425
+ logger.info(f"Discovered {len(discovered_skills)} runtime skills")
426
+
427
+ # Auto-link based on skill content and naming
428
+ for skill in discovered_skills:
429
+ agents = _infer_agents_for_skill(skill)
430
+ for agent_id in agents:
431
+ manager.add_skill_to_agent(agent_id, skill.name)
432
+ logger.debug(f"Auto-linked skill '{skill.name}' to agent '{agent_id}'")
433
+
434
+ except Exception as e:
435
+ logger.error(f"Error during runtime skills discovery: {e}", exc_info=True)
436
+
437
+
438
+ def _infer_agents_for_skill(skill) -> List[str]:
439
+ """Infer which agents should have this skill based on tags/name.
440
+
441
+ Args:
442
+ skill: Skill object to analyze
443
+
444
+ Returns:
445
+ List of agent IDs that should have this skill
446
+ """
447
+ agents = []
448
+ content_lower = skill.content.lower()
449
+ name_lower = skill.name.lower()
450
+
451
+ # Python-related
452
+ if any(
453
+ tag in content_lower or tag in name_lower
454
+ for tag in ["python", "django", "flask", "fastapi"]
455
+ ):
456
+ agents.append("python-engineer")
457
+
458
+ # TypeScript/JavaScript-related
459
+ if any(
460
+ tag in content_lower or tag in name_lower
461
+ for tag in ["typescript", "javascript", "react", "next", "vue", "node"]
462
+ ):
463
+ agents.extend(["typescript-engineer", "react-engineer", "nextjs-engineer"])
464
+
465
+ # Go-related
466
+ if any(tag in content_lower or tag in name_lower for tag in ["golang", "go "]):
467
+ agents.append("golang-engineer")
468
+
469
+ # Ops-related
470
+ if any(
471
+ tag in content_lower or tag in name_lower
472
+ for tag in ["docker", "kubernetes", "deploy", "devops", "ops"]
473
+ ):
474
+ agents.extend(["ops", "devops", "local-ops"])
475
+
476
+ # Testing/QA-related
477
+ if any(
478
+ tag in content_lower or tag in name_lower
479
+ for tag in ["test", "qa", "quality", "assert"]
480
+ ):
481
+ agents.extend(["qa", "web-qa", "api-qa"])
482
+
483
+ # Documentation-related
484
+ if any(
485
+ tag in content_lower or tag in name_lower
486
+ for tag in ["documentation", "docs", "api doc", "openapi"]
487
+ ):
488
+ agents.extend(["docs", "documentation", "technical-writer"])
489
+
490
+ # Remove duplicates
491
+ return list(set(agents))
@@ -403,6 +403,13 @@ def create_parser(
403
403
  except ImportError:
404
404
  pass
405
405
 
406
+ try:
407
+ from .skills_parser import add_skills_subparser
408
+
409
+ add_skills_subparser(subparsers)
410
+ except ImportError:
411
+ pass
412
+
406
413
  try:
407
414
  from .config_parser import add_config_subparser
408
415
 
@@ -265,5 +265,47 @@ def add_mpm_init_subparser(subparsers: Any) -> None:
265
265
  help="Path to project directory (default: current directory)",
266
266
  )
267
267
 
268
+ # Pause subcommand - Create session pause documents
269
+ pause_parser = subcommands.add_parser(
270
+ "pause",
271
+ help="Pause current session and save state",
272
+ description="Create session pause documents for later resume. Captures git context, "
273
+ "conversation state, todos, and working directory state.\n\n"
274
+ "Creates three file formats:\n"
275
+ " - JSON: Machine-readable structured data\n"
276
+ " - YAML: Human-readable configuration style\n"
277
+ " - Markdown: Full documentation format",
278
+ formatter_class=argparse.RawDescriptionHelpFormatter,
279
+ epilog="Examples:\n"
280
+ " claude-mpm mpm-init pause # Basic pause\n"
281
+ " claude-mpm mpm-init pause -m 'End of day' # With message\n"
282
+ " claude-mpm mpm-init pause --no-commit # Skip git commit\n"
283
+ " claude-mpm mpm-init pause --export session.json # Export copy",
284
+ )
285
+ pause_parser.add_argument(
286
+ "--message",
287
+ "-m",
288
+ type=str,
289
+ default=None,
290
+ help="Optional message describing pause reason or context",
291
+ )
292
+ pause_parser.add_argument(
293
+ "--no-commit",
294
+ action="store_true",
295
+ help="Skip git commit of session state",
296
+ )
297
+ pause_parser.add_argument(
298
+ "--export",
299
+ type=str,
300
+ default=None,
301
+ help="Export session state to custom location",
302
+ )
303
+ pause_parser.add_argument(
304
+ "project_path",
305
+ nargs="?",
306
+ default=".",
307
+ help="Path to project directory (default: current directory)",
308
+ )
309
+
268
310
  # Set the command handler
269
311
  mpm_init_parser.set_defaults(command="mpm-init")