claude-mpm 4.16.0__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.
- claude_mpm/VERSION +1 -1
- claude_mpm/agents/BASE_ENGINEER.md +286 -0
- claude_mpm/agents/BASE_PM.md +272 -23
- claude_mpm/agents/OUTPUT_STYLE.md +3 -48
- claude_mpm/agents/PM_INSTRUCTIONS.md +1821 -32
- claude_mpm/agents/WORKFLOW.md +75 -2
- claude_mpm/agents/agent_loader.py +4 -4
- claude_mpm/agents/base_agent.json +6 -3
- claude_mpm/agents/frontmatter_validator.py +1 -1
- claude_mpm/agents/templates/api_qa.json +5 -2
- claude_mpm/agents/templates/circuit_breakers.md +108 -2
- claude_mpm/agents/templates/documentation.json +33 -6
- claude_mpm/agents/templates/engineer.json +5 -1
- claude_mpm/agents/templates/javascript_engineer_agent.json +380 -0
- claude_mpm/agents/templates/php-engineer.json +10 -4
- claude_mpm/agents/templates/pm_red_flags.md +89 -19
- claude_mpm/agents/templates/project_organizer.json +7 -3
- claude_mpm/agents/templates/python_engineer.json +8 -3
- claude_mpm/agents/templates/qa.json +2 -1
- claude_mpm/agents/templates/react_engineer.json +1 -0
- claude_mpm/agents/templates/research.json +82 -12
- claude_mpm/agents/templates/rust_engineer.json +12 -7
- claude_mpm/agents/templates/security.json +4 -4
- claude_mpm/agents/templates/svelte-engineer.json +225 -0
- claude_mpm/agents/templates/tauri_engineer.json +274 -0
- claude_mpm/agents/templates/ticketing.json +10 -6
- claude_mpm/agents/templates/version_control.json +4 -2
- claude_mpm/agents/templates/web_qa.json +2 -1
- claude_mpm/cli/README.md +253 -0
- claude_mpm/cli/__init__.py +11 -1
- claude_mpm/cli/commands/__init__.py +2 -0
- claude_mpm/cli/commands/aggregate.py +1 -1
- claude_mpm/cli/commands/analyze.py +3 -3
- claude_mpm/cli/commands/cleanup.py +1 -1
- claude_mpm/cli/commands/configure_agent_display.py +4 -4
- claude_mpm/cli/commands/debug.py +12 -12
- claude_mpm/cli/commands/hook_errors.py +277 -0
- claude_mpm/cli/commands/mcp_install_commands.py +1 -1
- claude_mpm/cli/commands/mcp_install_commands.py.backup +284 -0
- claude_mpm/cli/commands/mpm_init/README.md +365 -0
- claude_mpm/cli/commands/mpm_init/__init__.py +73 -0
- claude_mpm/cli/commands/mpm_init/core.py +573 -0
- claude_mpm/cli/commands/mpm_init/display.py +341 -0
- claude_mpm/cli/commands/mpm_init/git_activity.py +427 -0
- claude_mpm/cli/commands/mpm_init/modes.py +397 -0
- claude_mpm/cli/commands/mpm_init/prompts.py +442 -0
- claude_mpm/cli/commands/mpm_init_cli.py +396 -0
- claude_mpm/cli/commands/mpm_init_handler.py +67 -1
- claude_mpm/cli/commands/run.py +124 -128
- claude_mpm/cli/commands/skills.py +922 -0
- claude_mpm/cli/executor.py +58 -0
- claude_mpm/cli/interactive/agent_wizard.py +5 -5
- claude_mpm/cli/parsers/base_parser.py +35 -0
- claude_mpm/cli/parsers/mpm_init_parser.py +42 -0
- claude_mpm/cli/parsers/skills_parser.py +275 -0
- claude_mpm/cli/startup.py +168 -8
- claude_mpm/cli/startup_display.py +480 -0
- claude_mpm/cli/utils.py +1 -1
- claude_mpm/cli_module/commands.py +1 -1
- claude_mpm/cli_module/refactoring_guide.md +253 -0
- claude_mpm/commands/mpm-auto-configure.md +52 -0
- claude_mpm/commands/mpm-help.md +6 -0
- claude_mpm/commands/mpm-init.md +130 -8
- claude_mpm/commands/mpm-resume.md +372 -0
- claude_mpm/commands/mpm-tickets.md +56 -7
- claude_mpm/commands/mpm-version.md +113 -0
- claude_mpm/commands/mpm.md +2 -0
- claude_mpm/config/agent_capabilities.yaml +658 -0
- claude_mpm/config/agent_config.py +2 -2
- claude_mpm/config/async_logging_config.yaml +145 -0
- claude_mpm/constants.py +24 -0
- claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +34 -0
- claude_mpm/core/api_validator.py +1 -1
- claude_mpm/core/claude_runner.py +14 -1
- claude_mpm/core/config.py +50 -0
- claude_mpm/core/constants.py +1 -1
- claude_mpm/core/factories.py +1 -1
- claude_mpm/core/framework/processors/metadata_processor.py +1 -1
- claude_mpm/core/hook_error_memory.py +381 -0
- claude_mpm/core/hook_manager.py +41 -2
- claude_mpm/core/interactive_session.py +48 -3
- claude_mpm/core/interfaces.py +56 -1
- claude_mpm/core/logger.py +3 -1
- claude_mpm/core/oneshot_session.py +39 -0
- claude_mpm/core/optimized_agent_loader.py +3 -3
- claude_mpm/d2/.gitignore +22 -0
- claude_mpm/d2/ARCHITECTURE_COMPARISON.md +273 -0
- claude_mpm/d2/FLASK_INTEGRATION.md +156 -0
- claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +452 -0
- claude_mpm/d2/QUICKSTART.md +186 -0
- claude_mpm/d2/README.md +232 -0
- claude_mpm/d2/STORE_FIX_SUMMARY.md +167 -0
- claude_mpm/d2/SVELTE5_STORES_GUIDE.md +180 -0
- claude_mpm/d2/TESTING.md +288 -0
- claude_mpm/d2/index.html +118 -0
- claude_mpm/d2/package.json +19 -0
- claude_mpm/d2/src/App.svelte +110 -0
- claude_mpm/d2/src/components/Header.svelte +153 -0
- claude_mpm/d2/src/components/MainContent.svelte +74 -0
- claude_mpm/d2/src/components/Sidebar.svelte +85 -0
- claude_mpm/d2/src/components/tabs/EventsTab.svelte +326 -0
- claude_mpm/d2/src/lib/socketio.js +144 -0
- claude_mpm/d2/src/main.js +7 -0
- claude_mpm/d2/src/stores/events.js +114 -0
- claude_mpm/d2/src/stores/socket.js +108 -0
- claude_mpm/d2/src/stores/theme.js +65 -0
- claude_mpm/d2/svelte.config.js +12 -0
- claude_mpm/d2/vite.config.js +15 -0
- claude_mpm/dashboard/.claude-mpm/memories/README.md +36 -0
- claude_mpm/dashboard/BUILD_NUMBER +1 -0
- claude_mpm/dashboard/README.md +121 -0
- claude_mpm/dashboard/VERSION +1 -0
- claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +273 -0
- claude_mpm/dashboard/react/components/ErrorBoundary.tsx +75 -0
- claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +141 -0
- claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +36 -0
- claude_mpm/dashboard/react/components/shared/FilterBar.tsx +89 -0
- claude_mpm/dashboard/react/contexts/DashboardContext.tsx +215 -0
- claude_mpm/dashboard/react/entries/events.tsx +165 -0
- claude_mpm/dashboard/react/hooks/useEvents.ts +191 -0
- claude_mpm/dashboard/react/hooks/useSocket.ts +225 -0
- claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +170 -0
- claude_mpm/dashboard/static/built/components/activity-tree.js.map +1 -0
- claude_mpm/dashboard/static/built/components/agent-hierarchy.js +101 -101
- claude_mpm/dashboard/static/built/components/agent-inference.js.map +1 -0
- claude_mpm/dashboard/static/built/components/build-tracker.js +59 -59
- claude_mpm/dashboard/static/built/components/code-simple.js +107 -107
- claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +29 -29
- claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +24 -24
- claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +27 -27
- claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +25 -25
- claude_mpm/dashboard/static/built/components/code-tree.js.map +1 -0
- claude_mpm/dashboard/static/built/components/code-viewer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/connection-debug.js +101 -101
- claude_mpm/dashboard/static/built/components/diff-viewer.js +113 -113
- claude_mpm/dashboard/static/built/components/event-processor.js.map +1 -0
- claude_mpm/dashboard/static/built/components/event-viewer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/export-manager.js.map +1 -0
- claude_mpm/dashboard/static/built/components/file-change-tracker.js +57 -57
- claude_mpm/dashboard/static/built/components/file-change-viewer.js +74 -74
- claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +1 -0
- claude_mpm/dashboard/static/built/components/file-viewer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +1 -0
- claude_mpm/dashboard/static/built/components/hud-manager.js.map +1 -0
- claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/module-viewer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/session-manager.js.map +1 -0
- claude_mpm/dashboard/static/built/components/socket-manager.js.map +1 -0
- claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +1 -0
- claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +1 -0
- claude_mpm/dashboard/static/built/components/working-directory.js.map +1 -0
- claude_mpm/dashboard/static/built/connection-manager.js +76 -76
- claude_mpm/dashboard/static/built/dashboard.js.map +1 -0
- claude_mpm/dashboard/static/built/extension-error-handler.js +22 -22
- claude_mpm/dashboard/static/built/react/events.js.map +1 -0
- claude_mpm/dashboard/static/built/shared/dom-helpers.js +9 -9
- claude_mpm/dashboard/static/built/shared/event-bus.js +5 -5
- claude_mpm/dashboard/static/built/shared/logger.js +16 -16
- claude_mpm/dashboard/static/built/shared/tooltip-service.js +6 -6
- claude_mpm/dashboard/static/built/socket-client.js.map +1 -0
- claude_mpm/dashboard/static/css/activity.css +69 -69
- claude_mpm/dashboard/static/css/connection-status.css +10 -10
- claude_mpm/dashboard/static/css/dashboard.css +15 -15
- claude_mpm/dashboard/static/index.html +22 -22
- claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +170 -0
- claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
- claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
- claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
- claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
- claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
- claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
- claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
- claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
- claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
- claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
- claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
- claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
- claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
- claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
- claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
- claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
- claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
- claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
- claude_mpm/dashboard/static/js/connection-manager.js +76 -76
- claude_mpm/dashboard/static/js/dashboard.js +76 -58
- claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
- claude_mpm/dashboard/static/js/shared/dom-helpers.js +9 -9
- claude_mpm/dashboard/static/js/shared/event-bus.js +5 -5
- claude_mpm/dashboard/static/js/shared/logger.js +16 -16
- claude_mpm/dashboard/static/js/shared/tooltip-service.js +6 -6
- claude_mpm/dashboard/static/js/socket-client.js +138 -121
- claude_mpm/dashboard/static/navigation-test-results.md +118 -0
- claude_mpm/dashboard/static/production/main.html +21 -21
- claude_mpm/dashboard/static/test-archive/dashboard.html +22 -22
- claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +36 -0
- claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +39 -0
- claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +38 -0
- claude_mpm/dashboard/templates/code_simple.html +23 -23
- claude_mpm/dashboard/templates/index.html +18 -18
- claude_mpm/hooks/README.md +143 -0
- claude_mpm/hooks/__init__.py +8 -0
- claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
- claude_mpm/hooks/claude_hooks/hook_handler.py +24 -7
- claude_mpm/hooks/claude_hooks/installer.py +45 -0
- claude_mpm/hooks/claude_hooks/response_tracking.py +35 -1
- claude_mpm/hooks/session_resume_hook.py +121 -0
- claude_mpm/hooks/templates/README.md +180 -0
- claude_mpm/hooks/templates/pre_tool_use_simple.py +78 -0
- claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
- claude_mpm/hooks/templates/settings.json.example +147 -0
- claude_mpm/models/resume_log.py +340 -0
- claude_mpm/schemas/agent_schema.json +596 -0
- claude_mpm/schemas/frontmatter_schema.json +165 -0
- claude_mpm/scripts/claude-hook-handler.sh +3 -3
- claude_mpm/scripts/start_activity_logging.py +3 -1
- claude_mpm/services/agents/auto_config_manager.py +1 -1
- claude_mpm/services/agents/deployment/agent_configuration_manager.py +1 -1
- claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
- claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
- claude_mpm/services/agents/deployment/agent_record_service.py +1 -1
- claude_mpm/services/agents/deployment/agent_validator.py +17 -1
- claude_mpm/services/agents/deployment/async_agent_deployment.py +1 -1
- claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
- claude_mpm/services/agents/deployment/local_template_deployment.py +1 -1
- claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
- claude_mpm/services/agents/loading/framework_agent_loader.py +8 -8
- claude_mpm/services/agents/local_template_manager.py +4 -2
- claude_mpm/services/agents/recommender.py +47 -0
- claude_mpm/services/cli/resume_service.py +617 -0
- claude_mpm/services/cli/session_manager.py +87 -0
- claude_mpm/services/cli/session_pause_manager.py +504 -0
- claude_mpm/services/cli/session_resume_helper.py +372 -0
- claude_mpm/services/cli/unified_dashboard_manager.py +1 -1
- claude_mpm/services/core/base.py +26 -11
- claude_mpm/services/core/interfaces.py +56 -1
- claude_mpm/services/core/models/agent_config.py +3 -0
- claude_mpm/services/core/models/process.py +4 -0
- claude_mpm/services/core/path_resolver.py +1 -1
- claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
- claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
- claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
- claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
- claude_mpm/services/diagnostics/doctor_reporter.py +6 -4
- claude_mpm/services/diagnostics/models.py +21 -0
- claude_mpm/services/event_bus/README.md +244 -0
- claude_mpm/services/event_bus/direct_relay.py +3 -3
- claude_mpm/services/event_bus/event_bus.py +36 -3
- claude_mpm/services/event_bus/relay.py +23 -7
- claude_mpm/services/events/README.md +303 -0
- claude_mpm/services/events/consumers/logging.py +1 -2
- claude_mpm/services/framework_claude_md_generator/README.md +119 -0
- claude_mpm/services/infrastructure/monitoring/resources.py +1 -1
- claude_mpm/services/infrastructure/resume_log_generator.py +439 -0
- claude_mpm/services/local_ops/__init__.py +2 -0
- claude_mpm/services/local_ops/process_manager.py +1 -1
- claude_mpm/services/local_ops/resource_monitor.py +2 -2
- claude_mpm/services/mcp_config_manager.py +7 -131
- claude_mpm/services/mcp_gateway/README.md +185 -0
- claude_mpm/services/mcp_gateway/auto_configure.py +31 -25
- claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
- claude_mpm/services/mcp_gateway/core/process_pool.py +19 -10
- claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
- claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
- claude_mpm/services/mcp_gateway/tools/external_mcp_services.py +26 -21
- claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
- claude_mpm/services/memory/failure_tracker.py +19 -4
- claude_mpm/services/memory/optimizer.py +1 -1
- claude_mpm/services/model/model_router.py +8 -9
- claude_mpm/services/monitor/daemon.py +1 -1
- claude_mpm/services/monitor/server.py +2 -2
- claude_mpm/services/native_agent_converter.py +356 -0
- claude_mpm/services/port_manager.py +1 -1
- claude_mpm/services/project/documentation_manager.py +2 -1
- claude_mpm/services/project/toolchain_analyzer.py +3 -1
- claude_mpm/services/runner_configuration_service.py +1 -0
- claude_mpm/services/self_upgrade_service.py +165 -7
- claude_mpm/services/session_manager.py +205 -1
- claude_mpm/services/skills_config.py +547 -0
- claude_mpm/services/skills_deployer.py +955 -0
- claude_mpm/services/socketio/handlers/connection.py +1 -1
- claude_mpm/services/socketio/handlers/connection.py.backup +217 -0
- claude_mpm/services/socketio/handlers/git.py +2 -2
- claude_mpm/services/socketio/handlers/hook.py.backup +154 -0
- claude_mpm/services/static/.gitkeep +2 -0
- claude_mpm/services/system_instructions_service.py +1 -3
- claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
- claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
- claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
- claude_mpm/services/unified/deployment_strategies/local.py +1 -1
- claude_mpm/services/version_control/VERSION +1 -0
- claude_mpm/services/version_control/conflict_resolution.py +6 -4
- claude_mpm/services/version_service.py +104 -1
- claude_mpm/services/visualization/mermaid_generator.py +2 -3
- claude_mpm/skills/__init__.py +21 -0
- claude_mpm/skills/agent_skills_injector.py +324 -0
- claude_mpm/skills/bundled/.gitkeep +2 -0
- claude_mpm/skills/bundled/LICENSE_ATTRIBUTIONS.md +79 -0
- claude_mpm/skills/bundled/api-documentation.md +393 -0
- claude_mpm/skills/bundled/async-testing.md +571 -0
- claude_mpm/skills/bundled/code-review.md +143 -0
- claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +79 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +178 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +577 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +467 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +537 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +730 -0
- claude_mpm/skills/bundled/collaboration/git-worktrees.md +317 -0
- claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +112 -0
- claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +146 -0
- claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +412 -0
- claude_mpm/skills/bundled/collaboration/stacked-prs.md +251 -0
- claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +81 -0
- claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +362 -0
- claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +312 -0
- claude_mpm/skills/bundled/database-migration.md +199 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +152 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +63 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +668 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +587 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +438 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +391 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +119 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +148 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +483 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +452 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +449 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +411 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +14 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +58 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +68 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +69 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +131 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +325 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +490 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +425 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +499 -0
- claude_mpm/skills/bundled/docker-containerization.md +194 -0
- claude_mpm/skills/bundled/express-local-dev.md +1429 -0
- claude_mpm/skills/bundled/fastapi-local-dev.md +1199 -0
- claude_mpm/skills/bundled/git-workflow.md +414 -0
- claude_mpm/skills/bundled/imagemagick.md +204 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +611 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/README.md +596 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +260 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +315 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +436 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +433 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +452 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +404 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +420 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
- claude_mpm/skills/bundled/json-data-handling.md +223 -0
- claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +202 -0
- claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +86 -0
- claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +54 -0
- claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +322 -0
- claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
- claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +202 -0
- claude_mpm/skills/bundled/main/internal-comms/SKILL.md +43 -0
- claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +47 -0
- claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +65 -0
- claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +30 -0
- claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +16 -0
- claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +202 -0
- claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +160 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +412 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +602 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +915 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +916 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +752 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +1237 -0
- claude_mpm/skills/bundled/main/mcp-builder/scripts/connections.py +157 -0
- claude_mpm/skills/bundled/main/mcp-builder/scripts/evaluation.py +425 -0
- claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +22 -0
- claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +2 -0
- claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +202 -0
- claude_mpm/skills/bundled/main/skill-creator/SKILL.md +189 -0
- claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +500 -0
- claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +464 -0
- claude_mpm/skills/bundled/main/skill-creator/references/examples.md +619 -0
- claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +437 -0
- claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +231 -0
- claude_mpm/skills/bundled/main/skill-creator/scripts/init_skill.py +303 -0
- claude_mpm/skills/bundled/main/skill-creator/scripts/package_skill.py +113 -0
- claude_mpm/skills/bundled/main/skill-creator/scripts/quick_validate.py +72 -0
- claude_mpm/skills/bundled/nextjs-local-dev.md +807 -0
- claude_mpm/skills/bundled/pdf.md +141 -0
- claude_mpm/skills/bundled/performance-profiling.md +573 -0
- claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +170 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +602 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +821 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +742 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +726 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +764 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +831 -0
- claude_mpm/skills/bundled/react/flexlayout-react.md +742 -0
- claude_mpm/skills/bundled/refactoring-patterns.md +180 -0
- claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +226 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +901 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +901 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +775 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +937 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +770 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +961 -0
- claude_mpm/skills/bundled/security-scanning.md +327 -0
- claude_mpm/skills/bundled/systematic-debugging.md +473 -0
- claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +495 -0
- claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +599 -0
- claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +535 -0
- claude_mpm/skills/bundled/tauri/tauri-error-handling.md +613 -0
- claude_mpm/skills/bundled/tauri/tauri-event-system.md +648 -0
- claude_mpm/skills/bundled/tauri/tauri-file-system.md +673 -0
- claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +767 -0
- claude_mpm/skills/bundled/tauri/tauri-performance.md +669 -0
- claude_mpm/skills/bundled/tauri/tauri-state-management.md +573 -0
- claude_mpm/skills/bundled/tauri/tauri-testing.md +384 -0
- claude_mpm/skills/bundled/tauri/tauri-window-management.md +628 -0
- claude_mpm/skills/bundled/test-driven-development.md +378 -0
- claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +119 -0
- claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +158 -0
- claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +253 -0
- claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +145 -0
- claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +543 -0
- claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +741 -0
- claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +470 -0
- claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +458 -0
- claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +639 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +458 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +411 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +317 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +270 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +436 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +140 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +572 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +411 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +569 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +695 -0
- claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +202 -0
- claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +184 -0
- claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +459 -0
- claude_mpm/skills/bundled/testing/webapp-testing/examples/console_logging.py +35 -0
- claude_mpm/skills/bundled/testing/webapp-testing/examples/element_discovery.py +44 -0
- claude_mpm/skills/bundled/testing/webapp-testing/examples/static_html_automation.py +34 -0
- claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +479 -0
- claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +687 -0
- claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +129 -0
- claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +758 -0
- claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +868 -0
- claude_mpm/skills/bundled/vite-local-dev.md +1061 -0
- claude_mpm/skills/bundled/web-performance-optimization.md +2305 -0
- claude_mpm/skills/bundled/xlsx.md +157 -0
- claude_mpm/skills/registry.py +97 -9
- claude_mpm/skills/skills_registry.py +347 -0
- claude_mpm/skills/skills_service.py +739 -0
- claude_mpm/templates/questions/EXAMPLES.md +501 -0
- claude_mpm/templates/questions/__init__.py +43 -0
- claude_mpm/templates/questions/base.py +193 -0
- claude_mpm/templates/questions/pr_strategy.py +314 -0
- claude_mpm/templates/questions/project_init.py +388 -0
- claude_mpm/templates/questions/ticket_mgmt.py +397 -0
- claude_mpm/tools/README_SOCKETIO_DEBUG.md +224 -0
- claude_mpm/tools/__main__.py +8 -8
- claude_mpm/tools/code_tree_analyzer/README.md +64 -0
- claude_mpm/tools/code_tree_analyzer/__init__.py +45 -0
- claude_mpm/tools/code_tree_analyzer/analysis.py +299 -0
- claude_mpm/tools/code_tree_analyzer/cache.py +131 -0
- claude_mpm/tools/code_tree_analyzer/core.py +380 -0
- claude_mpm/tools/code_tree_analyzer/discovery.py +403 -0
- claude_mpm/tools/code_tree_analyzer/events.py +168 -0
- claude_mpm/tools/code_tree_analyzer/gitignore.py +308 -0
- claude_mpm/tools/code_tree_analyzer/models.py +39 -0
- claude_mpm/tools/code_tree_analyzer/multilang_analyzer.py +224 -0
- claude_mpm/tools/code_tree_analyzer/python_analyzer.py +284 -0
- claude_mpm/utils/agent_dependency_loader.py +5 -5
- claude_mpm/utils/dependency_cache.py +3 -1
- claude_mpm/utils/gitignore.py +241 -0
- claude_mpm/utils/log_cleanup.py +3 -3
- claude_mpm/utils/robust_installer.py +3 -5
- claude_mpm/utils/structured_questions.py +619 -0
- claude_mpm-4.25.10.dist-info/METADATA +789 -0
- {claude_mpm-4.16.0.dist-info → claude_mpm-4.25.10.dist-info}/RECORD +485 -240
- claude_mpm/agents/INSTRUCTIONS_OLD_DEPRECATED.md +0 -602
- claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
- claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
- claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
- claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
- claude_mpm/cli/commands/mpm_init.py +0 -2008
- claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
- claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
- claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
- claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
- claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
- claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
- claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
- claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
- claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
- claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
- claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
- claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
- claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
- claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
- claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
- claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
- claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
- claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
- claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
- claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
- claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
- claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
- claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
- claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
- claude_mpm/dashboard/static/dist/dashboard.js +0 -2
- claude_mpm/dashboard/static/dist/react/events.js +0 -30
- claude_mpm/dashboard/static/dist/socket-client.js +0 -2
- claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
- claude_mpm/tools/code_tree_analyzer.py +0 -1825
- claude_mpm-4.16.0.dist-info/METADATA +0 -453
- {claude_mpm-4.16.0.dist-info → claude_mpm-4.25.10.dist-info}/WHEEL +0 -0
- {claude_mpm-4.16.0.dist-info → claude_mpm-4.25.10.dist-info}/entry_points.txt +0 -0
- {claude_mpm-4.16.0.dist-info → claude_mpm-4.25.10.dist-info}/licenses/LICENSE +0 -0
- {claude_mpm-4.16.0.dist-info → claude_mpm-4.25.10.dist-info}/top_level.txt +0 -0
|
@@ -118,7 +118,7 @@ class EventViewer {
|
|
|
118
118
|
this.filteredEvents = this.events.filter(event => {
|
|
119
119
|
// NO AUTOMATIC FILTERING - All events are shown by default for complete visibility
|
|
120
120
|
// Users can apply their own filters using the search and type filter controls
|
|
121
|
-
|
|
121
|
+
|
|
122
122
|
// User-controlled search filter
|
|
123
123
|
if (this.searchFilter) {
|
|
124
124
|
const searchableText = [
|
|
@@ -236,7 +236,7 @@ class EventViewer {
|
|
|
236
236
|
console.warn('[EventViewer] Container not found, skipping render');
|
|
237
237
|
return;
|
|
238
238
|
}
|
|
239
|
-
|
|
239
|
+
|
|
240
240
|
// SAFETY: Basic check to ensure we're rendering to the correct container
|
|
241
241
|
if (eventsList.id !== 'events-list') {
|
|
242
242
|
console.error('[EventViewer] CRITICAL: Attempting to render to wrong container:', eventsList.id);
|
|
@@ -520,7 +520,7 @@ class EventViewer {
|
|
|
520
520
|
*/
|
|
521
521
|
formatCodeEvent(event) {
|
|
522
522
|
const data = event.data || {};
|
|
523
|
-
|
|
523
|
+
|
|
524
524
|
// Handle different code event subtypes
|
|
525
525
|
if (event.subtype === 'progress') {
|
|
526
526
|
const message = data.message || 'Processing...';
|
|
@@ -550,7 +550,7 @@ class EventViewer {
|
|
|
550
550
|
} else if (event.subtype === 'error') {
|
|
551
551
|
return `<strong>Error:</strong> ${data.error || 'Unknown error'} in ${data.file || 'file'}`;
|
|
552
552
|
}
|
|
553
|
-
|
|
553
|
+
|
|
554
554
|
// Generic fallback for code events
|
|
555
555
|
const json = JSON.stringify(data);
|
|
556
556
|
return `<strong>Code:</strong> ${json.length > 100 ? json.substring(0, 100) + '...' : json}`;
|
|
@@ -587,20 +587,20 @@ class EventViewer {
|
|
|
587
587
|
'qa_agent': 'QA',
|
|
588
588
|
'unknown': 'Unknown'
|
|
589
589
|
};
|
|
590
|
-
|
|
590
|
+
|
|
591
591
|
// Try to find a match in the map (case-insensitive)
|
|
592
592
|
const lowerType = (agentType || 'unknown').toLowerCase();
|
|
593
593
|
if (agentTypeMap[lowerType]) {
|
|
594
594
|
return agentTypeMap[lowerType];
|
|
595
595
|
}
|
|
596
|
-
|
|
596
|
+
|
|
597
597
|
// If not in map, try to extract the agent name from patterns like "Research Agent" or "research_agent"
|
|
598
598
|
const match = agentType.match(/^(\w+)(?:_agent|Agent)?$/i);
|
|
599
599
|
if (match && match[1]) {
|
|
600
600
|
// Capitalize first letter
|
|
601
601
|
return match[1].charAt(0).toUpperCase() + match[1].slice(1).toLowerCase();
|
|
602
602
|
}
|
|
603
|
-
|
|
603
|
+
|
|
604
604
|
// Fallback: just capitalize first letter of whatever we have
|
|
605
605
|
return agentType.charAt(0).toUpperCase() + agentType.slice(1);
|
|
606
606
|
}
|
|
@@ -614,7 +614,7 @@ class EventViewer {
|
|
|
614
614
|
formatSingleRowEventContent(event) {
|
|
615
615
|
const eventType = this.formatEventType(event);
|
|
616
616
|
const data = event.data || {};
|
|
617
|
-
|
|
617
|
+
|
|
618
618
|
// Include source if it's not the default 'system' source
|
|
619
619
|
const sourcePrefix = event.source && event.source !== 'system' ? `[${event.source}] ` : '';
|
|
620
620
|
|
|
@@ -626,12 +626,12 @@ class EventViewer {
|
|
|
626
626
|
// Hook events: show tool name and operation details
|
|
627
627
|
const toolName = event.tool_name || data.tool_name || 'Unknown';
|
|
628
628
|
const hookType = event.subtype || 'Unknown';
|
|
629
|
-
|
|
629
|
+
|
|
630
630
|
// Format specific hook types
|
|
631
631
|
if (hookType === 'pre_tool' || hookType === 'post_tool') {
|
|
632
632
|
const operation = data.operation_type || '';
|
|
633
|
-
const status = hookType === 'post_tool' && data.success !== undefined
|
|
634
|
-
? (data.success ? '✓' : '✗')
|
|
633
|
+
const status = hookType === 'post_tool' && data.success !== undefined
|
|
634
|
+
? (data.success ? '✓' : '✗')
|
|
635
635
|
: '';
|
|
636
636
|
dataDetails = `${toolName}${operation ? ` (${operation})` : ''}${status ? ` ${status}` : ''}`;
|
|
637
637
|
} else if (hookType === 'user_prompt') {
|
|
@@ -770,7 +770,7 @@ class EventViewer {
|
|
|
770
770
|
if (hookNames[hookType]) {
|
|
771
771
|
return hookNames[hookType];
|
|
772
772
|
}
|
|
773
|
-
|
|
773
|
+
|
|
774
774
|
// Convert to string and handle null/undefined
|
|
775
775
|
const typeStr = String(hookType || 'unknown');
|
|
776
776
|
return typeStr.replace(/_/g, ' ');
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* File Change Tracker Module
|
|
3
|
-
*
|
|
3
|
+
*
|
|
4
4
|
* Tracks all file operations (Edit, Write, Read, MultiEdit) from event history
|
|
5
5
|
* and builds a tree structure grouped by working directory.
|
|
6
6
|
* Supports session-based filtering and stores complete edit history with timestamps.
|
|
7
|
-
*
|
|
7
|
+
*
|
|
8
8
|
* Architecture:
|
|
9
9
|
* - Maintains a hierarchical structure of file changes
|
|
10
10
|
* - Tracks file lifecycle (create, edit, delete)
|
|
@@ -17,11 +17,11 @@ class FileChangeTracker {
|
|
|
17
17
|
this.fileChanges = new Map(); // Map<filePath, FileChangeData>
|
|
18
18
|
this.sessionData = new Map(); // Map<sessionId, Set<filePath>>
|
|
19
19
|
this.workingDirectories = new Map(); // Map<workingDir, Set<filePath>>
|
|
20
|
-
|
|
20
|
+
|
|
21
21
|
// Current state
|
|
22
22
|
this.currentSessionId = null;
|
|
23
23
|
this.events = [];
|
|
24
|
-
|
|
24
|
+
|
|
25
25
|
// File operation types we track
|
|
26
26
|
this.FILE_OPERATIONS = {
|
|
27
27
|
READ: 'Read',
|
|
@@ -31,12 +31,12 @@ class FileChangeTracker {
|
|
|
31
31
|
DELETE: 'Delete',
|
|
32
32
|
CREATE: 'Create'
|
|
33
33
|
};
|
|
34
|
-
|
|
34
|
+
|
|
35
35
|
// Initialize
|
|
36
36
|
this.initialized = false;
|
|
37
37
|
console.log('FileChangeTracker initialized');
|
|
38
38
|
}
|
|
39
|
-
|
|
39
|
+
|
|
40
40
|
/**
|
|
41
41
|
* Initialize the tracker
|
|
42
42
|
*/
|
|
@@ -45,7 +45,7 @@ class FileChangeTracker {
|
|
|
45
45
|
this.initialized = true;
|
|
46
46
|
console.log('FileChangeTracker ready');
|
|
47
47
|
}
|
|
48
|
-
|
|
48
|
+
|
|
49
49
|
/**
|
|
50
50
|
* Process an event and extract file operations
|
|
51
51
|
* @param {Object} event - Event data
|
|
@@ -53,14 +53,14 @@ class FileChangeTracker {
|
|
|
53
53
|
processEvent(event) {
|
|
54
54
|
// Check if this is a file-related tool event
|
|
55
55
|
if (!this.isFileOperation(event)) return;
|
|
56
|
-
|
|
56
|
+
|
|
57
57
|
const fileOp = this.extractFileOperation(event);
|
|
58
58
|
if (!fileOp) return;
|
|
59
|
-
|
|
59
|
+
|
|
60
60
|
// Add to our tracking structures
|
|
61
61
|
this.addFileOperation(fileOp);
|
|
62
62
|
}
|
|
63
|
-
|
|
63
|
+
|
|
64
64
|
/**
|
|
65
65
|
* Check if an event is a file operation
|
|
66
66
|
* @param {Object} event - Event to check
|
|
@@ -72,16 +72,16 @@ class FileChangeTracker {
|
|
|
72
72
|
const toolName = event.tool_name || (event.data && event.data.tool_name);
|
|
73
73
|
return Object.values(this.FILE_OPERATIONS).includes(toolName);
|
|
74
74
|
}
|
|
75
|
-
|
|
75
|
+
|
|
76
76
|
// Check for hook events with file operations
|
|
77
77
|
if (event.type === 'hook' && event.data) {
|
|
78
78
|
const toolName = event.data.tool_name;
|
|
79
79
|
return Object.values(this.FILE_OPERATIONS).includes(toolName);
|
|
80
80
|
}
|
|
81
|
-
|
|
81
|
+
|
|
82
82
|
return false;
|
|
83
83
|
}
|
|
84
|
-
|
|
84
|
+
|
|
85
85
|
/**
|
|
86
86
|
* Extract file operation details from an event
|
|
87
87
|
* @param {Object} event - Event to process
|
|
@@ -91,30 +91,30 @@ class FileChangeTracker {
|
|
|
91
91
|
const toolName = event.tool_name || (event.data && event.data.tool_name);
|
|
92
92
|
const params = event.tool_parameters || (event.data && event.data.tool_parameters) || {};
|
|
93
93
|
const result = event.tool_result || (event.data && event.data.tool_result);
|
|
94
|
-
|
|
94
|
+
|
|
95
95
|
// Extract file path based on tool type
|
|
96
96
|
let filePath = null;
|
|
97
97
|
let operation = toolName;
|
|
98
98
|
let content = null;
|
|
99
99
|
let oldContent = null;
|
|
100
|
-
|
|
100
|
+
|
|
101
101
|
switch (toolName) {
|
|
102
102
|
case this.FILE_OPERATIONS.READ:
|
|
103
103
|
filePath = params.file_path;
|
|
104
104
|
content = result && result.content;
|
|
105
105
|
break;
|
|
106
|
-
|
|
106
|
+
|
|
107
107
|
case this.FILE_OPERATIONS.WRITE:
|
|
108
108
|
filePath = params.file_path;
|
|
109
109
|
content = params.content;
|
|
110
110
|
break;
|
|
111
|
-
|
|
111
|
+
|
|
112
112
|
case this.FILE_OPERATIONS.EDIT:
|
|
113
113
|
filePath = params.file_path;
|
|
114
114
|
oldContent = params.old_string;
|
|
115
115
|
content = params.new_string;
|
|
116
116
|
break;
|
|
117
|
-
|
|
117
|
+
|
|
118
118
|
case this.FILE_OPERATIONS.MULTI_EDIT:
|
|
119
119
|
filePath = params.file_path;
|
|
120
120
|
// For MultiEdit, we track each edit
|
|
@@ -133,13 +133,13 @@ class FileChangeTracker {
|
|
|
133
133
|
isMultiEdit: true,
|
|
134
134
|
success: event.subtype === 'post_tool' && result && result.success !== false
|
|
135
135
|
};
|
|
136
|
-
|
|
136
|
+
|
|
137
137
|
default:
|
|
138
138
|
return null;
|
|
139
139
|
}
|
|
140
|
-
|
|
140
|
+
|
|
141
141
|
if (!filePath) return null;
|
|
142
|
-
|
|
142
|
+
|
|
143
143
|
return {
|
|
144
144
|
filePath,
|
|
145
145
|
operation,
|
|
@@ -154,7 +154,7 @@ class FileChangeTracker {
|
|
|
154
154
|
success: event.subtype === 'post_tool' && result && result.success !== false
|
|
155
155
|
};
|
|
156
156
|
}
|
|
157
|
-
|
|
157
|
+
|
|
158
158
|
/**
|
|
159
159
|
* Extract working directory from event
|
|
160
160
|
* @param {Object} event - Event data
|
|
@@ -165,31 +165,31 @@ class FileChangeTracker {
|
|
|
165
165
|
if (event.data && event.data.working_directory) {
|
|
166
166
|
return event.data.working_directory;
|
|
167
167
|
}
|
|
168
|
-
|
|
168
|
+
|
|
169
169
|
// Try to extract from context
|
|
170
170
|
if (event.context && event.context.working_directory) {
|
|
171
171
|
return event.context.working_directory;
|
|
172
172
|
}
|
|
173
|
-
|
|
173
|
+
|
|
174
174
|
// Try to extract from file path (get parent directory)
|
|
175
|
-
const filePath = event.tool_parameters?.file_path ||
|
|
175
|
+
const filePath = event.tool_parameters?.file_path ||
|
|
176
176
|
(event.data && event.data.tool_parameters?.file_path);
|
|
177
177
|
if (filePath) {
|
|
178
178
|
const parts = filePath.split('/');
|
|
179
179
|
parts.pop(); // Remove filename
|
|
180
180
|
return parts.join('/') || '/';
|
|
181
181
|
}
|
|
182
|
-
|
|
182
|
+
|
|
183
183
|
return 'unknown';
|
|
184
184
|
}
|
|
185
|
-
|
|
185
|
+
|
|
186
186
|
/**
|
|
187
187
|
* Add a file operation to our tracking structures
|
|
188
188
|
* @param {Object} fileOp - File operation data
|
|
189
189
|
*/
|
|
190
190
|
addFileOperation(fileOp) {
|
|
191
191
|
const { filePath, sessionId, workingDirectory } = fileOp;
|
|
192
|
-
|
|
192
|
+
|
|
193
193
|
// Initialize file change data if needed
|
|
194
194
|
if (!this.fileChanges.has(filePath)) {
|
|
195
195
|
this.fileChanges.set(filePath, {
|
|
@@ -207,26 +207,26 @@ class FileChangeTracker {
|
|
|
207
207
|
totalWrites: 0
|
|
208
208
|
});
|
|
209
209
|
}
|
|
210
|
-
|
|
210
|
+
|
|
211
211
|
const fileData = this.fileChanges.get(filePath);
|
|
212
|
-
|
|
212
|
+
|
|
213
213
|
// Update session tracking
|
|
214
214
|
fileData.sessions.add(sessionId);
|
|
215
215
|
if (!this.sessionData.has(sessionId)) {
|
|
216
216
|
this.sessionData.set(sessionId, new Set());
|
|
217
217
|
}
|
|
218
218
|
this.sessionData.get(sessionId).add(filePath);
|
|
219
|
-
|
|
219
|
+
|
|
220
220
|
// Update working directory tracking
|
|
221
221
|
if (!this.workingDirectories.has(workingDirectory)) {
|
|
222
222
|
this.workingDirectories.set(workingDirectory, new Set());
|
|
223
223
|
}
|
|
224
224
|
this.workingDirectories.get(workingDirectory).add(filePath);
|
|
225
|
-
|
|
225
|
+
|
|
226
226
|
// Add operation to history
|
|
227
227
|
fileData.operations.push(fileOp);
|
|
228
228
|
fileData.lastModified = fileOp.timestamp;
|
|
229
|
-
|
|
229
|
+
|
|
230
230
|
// Update content tracking
|
|
231
231
|
if (fileOp.isRead && fileOp.content && !fileData.initialContent) {
|
|
232
232
|
fileData.initialContent = fileOp.content;
|
|
@@ -261,7 +261,7 @@ class FileChangeTracker {
|
|
|
261
261
|
fileData.totalEdits += fileOp.edits.length;
|
|
262
262
|
}
|
|
263
263
|
}
|
|
264
|
-
|
|
264
|
+
|
|
265
265
|
/**
|
|
266
266
|
* Get file name from path
|
|
267
267
|
* @param {string} filePath - Full file path
|
|
@@ -271,7 +271,7 @@ class FileChangeTracker {
|
|
|
271
271
|
const parts = filePath.split('/');
|
|
272
272
|
return parts[parts.length - 1] || filePath;
|
|
273
273
|
}
|
|
274
|
-
|
|
274
|
+
|
|
275
275
|
/**
|
|
276
276
|
* Update with new events
|
|
277
277
|
* @param {Array} events - Array of events
|
|
@@ -280,15 +280,15 @@ class FileChangeTracker {
|
|
|
280
280
|
// Clear and rebuild
|
|
281
281
|
this.clear();
|
|
282
282
|
this.events = events;
|
|
283
|
-
|
|
283
|
+
|
|
284
284
|
// Process all events
|
|
285
285
|
for (const event of events) {
|
|
286
286
|
this.processEvent(event);
|
|
287
287
|
}
|
|
288
|
-
|
|
288
|
+
|
|
289
289
|
console.log(`FileChangeTracker updated: ${this.fileChanges.size} files tracked`);
|
|
290
290
|
}
|
|
291
|
-
|
|
291
|
+
|
|
292
292
|
/**
|
|
293
293
|
* Get files for current session
|
|
294
294
|
* @param {string} sessionId - Session ID to filter by
|
|
@@ -298,15 +298,15 @@ class FileChangeTracker {
|
|
|
298
298
|
if (!sessionId) {
|
|
299
299
|
return Array.from(this.fileChanges.values());
|
|
300
300
|
}
|
|
301
|
-
|
|
301
|
+
|
|
302
302
|
const sessionFiles = this.sessionData.get(sessionId);
|
|
303
303
|
if (!sessionFiles) return [];
|
|
304
|
-
|
|
305
|
-
return Array.from(sessionFiles).map(filePath =>
|
|
304
|
+
|
|
305
|
+
return Array.from(sessionFiles).map(filePath =>
|
|
306
306
|
this.fileChanges.get(filePath)
|
|
307
307
|
).filter(Boolean);
|
|
308
308
|
}
|
|
309
|
-
|
|
309
|
+
|
|
310
310
|
/**
|
|
311
311
|
* Get file tree structure grouped by working directory
|
|
312
312
|
* @param {string} sessionId - Optional session filter
|
|
@@ -315,7 +315,7 @@ class FileChangeTracker {
|
|
|
315
315
|
getFileTree(sessionId = null) {
|
|
316
316
|
const files = this.getFilesForSession(sessionId);
|
|
317
317
|
const tree = {};
|
|
318
|
-
|
|
318
|
+
|
|
319
319
|
for (const fileData of files) {
|
|
320
320
|
const wd = fileData.workingDirectory || 'unknown';
|
|
321
321
|
if (!tree[wd]) {
|
|
@@ -329,24 +329,24 @@ class FileChangeTracker {
|
|
|
329
329
|
totalWrites: 0
|
|
330
330
|
};
|
|
331
331
|
}
|
|
332
|
-
|
|
332
|
+
|
|
333
333
|
tree[wd].files.push(fileData);
|
|
334
334
|
tree[wd].totalOperations += fileData.operations.length;
|
|
335
335
|
tree[wd].totalEdits += fileData.totalEdits;
|
|
336
336
|
tree[wd].totalReads += fileData.totalReads;
|
|
337
337
|
tree[wd].totalWrites += fileData.totalWrites;
|
|
338
338
|
}
|
|
339
|
-
|
|
339
|
+
|
|
340
340
|
// Sort files within each directory
|
|
341
341
|
Object.values(tree).forEach(dir => {
|
|
342
|
-
dir.files.sort((a, b) =>
|
|
342
|
+
dir.files.sort((a, b) =>
|
|
343
343
|
new Date(b.lastModified) - new Date(a.lastModified)
|
|
344
344
|
);
|
|
345
345
|
});
|
|
346
|
-
|
|
346
|
+
|
|
347
347
|
return tree;
|
|
348
348
|
}
|
|
349
|
-
|
|
349
|
+
|
|
350
350
|
/**
|
|
351
351
|
* Get directory name from path
|
|
352
352
|
* @param {string} dirPath - Directory path
|
|
@@ -357,7 +357,7 @@ class FileChangeTracker {
|
|
|
357
357
|
const parts = dirPath.split('/');
|
|
358
358
|
return parts[parts.length - 1] || dirPath;
|
|
359
359
|
}
|
|
360
|
-
|
|
360
|
+
|
|
361
361
|
/**
|
|
362
362
|
* Get file change details
|
|
363
363
|
* @param {string} filePath - File path
|
|
@@ -366,7 +366,7 @@ class FileChangeTracker {
|
|
|
366
366
|
getFileDetails(filePath) {
|
|
367
367
|
return this.fileChanges.get(filePath) || null;
|
|
368
368
|
}
|
|
369
|
-
|
|
369
|
+
|
|
370
370
|
/**
|
|
371
371
|
* Get operations for a file
|
|
372
372
|
* @param {string} filePath - File path
|
|
@@ -376,17 +376,17 @@ class FileChangeTracker {
|
|
|
376
376
|
getFileOperations(filePath, sessionId = null) {
|
|
377
377
|
const fileData = this.fileChanges.get(filePath);
|
|
378
378
|
if (!fileData) return [];
|
|
379
|
-
|
|
379
|
+
|
|
380
380
|
let operations = fileData.operations;
|
|
381
381
|
if (sessionId) {
|
|
382
382
|
operations = operations.filter(op => op.sessionId === sessionId);
|
|
383
383
|
}
|
|
384
|
-
|
|
385
|
-
return operations.sort((a, b) =>
|
|
384
|
+
|
|
385
|
+
return operations.sort((a, b) =>
|
|
386
386
|
new Date(a.timestamp) - new Date(b.timestamp)
|
|
387
387
|
);
|
|
388
388
|
}
|
|
389
|
-
|
|
389
|
+
|
|
390
390
|
/**
|
|
391
391
|
* Get diff data for a file
|
|
392
392
|
* @param {string} filePath - File path
|
|
@@ -395,7 +395,7 @@ class FileChangeTracker {
|
|
|
395
395
|
getFileDiff(filePath) {
|
|
396
396
|
const fileData = this.fileChanges.get(filePath);
|
|
397
397
|
if (!fileData) return null;
|
|
398
|
-
|
|
398
|
+
|
|
399
399
|
return {
|
|
400
400
|
filePath,
|
|
401
401
|
fileName: fileData.fileName,
|
|
@@ -407,7 +407,7 @@ class FileChangeTracker {
|
|
|
407
407
|
totalWrites: fileData.totalWrites
|
|
408
408
|
};
|
|
409
409
|
}
|
|
410
|
-
|
|
410
|
+
|
|
411
411
|
/**
|
|
412
412
|
* Clear all tracked data
|
|
413
413
|
*/
|
|
@@ -417,7 +417,7 @@ class FileChangeTracker {
|
|
|
417
417
|
this.workingDirectories.clear();
|
|
418
418
|
this.events = [];
|
|
419
419
|
}
|
|
420
|
-
|
|
420
|
+
|
|
421
421
|
/**
|
|
422
422
|
* Get statistics
|
|
423
423
|
* @returns {Object} Statistics
|