moai-adk 0.15.0__py3-none-any.whl → 0.25.4__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 moai-adk might be problematic. Click here for more details.
- moai_adk/__init__.py +1 -2
- moai_adk/__main__.py +85 -2
- moai_adk/cli/__init__.py +0 -1
- moai_adk/cli/commands/__init__.py +0 -1
- moai_adk/cli/commands/analyze.py +127 -0
- moai_adk/cli/commands/backup.py +5 -3
- moai_adk/cli/commands/doctor.py +35 -11
- moai_adk/cli/commands/improve_user_experience.py +348 -0
- moai_adk/cli/commands/init.py +150 -23
- moai_adk/cli/commands/language.py +269 -0
- moai_adk/cli/commands/migrate.py +158 -0
- moai_adk/cli/commands/status.py +13 -12
- moai_adk/cli/commands/update.py +364 -60
- moai_adk/cli/commands/validate_links.py +118 -0
- moai_adk/cli/main.py +3 -2
- moai_adk/cli/prompts/init_prompts.py +79 -82
- moai_adk/core/__init__.py +0 -1
- moai_adk/core/analysis/__init__.py +9 -0
- moai_adk/core/analysis/session_analyzer.py +439 -0
- moai_adk/core/claude_integration.py +421 -0
- moai_adk/core/command_helpers.py +270 -0
- moai_adk/core/config/__init__.py +6 -0
- moai_adk/core/config/auto_spec_config.py +346 -0
- moai_adk/core/config/migration.py +133 -12
- moai_adk/core/context_manager.py +279 -0
- moai_adk/core/diagnostics/slash_commands.py +0 -1
- moai_adk/core/error_recovery_system.py +1289 -0
- moai_adk/core/git/__init__.py +0 -1
- moai_adk/core/git/branch.py +0 -1
- moai_adk/core/git/branch_manager.py +4 -4
- moai_adk/core/git/checkpoint.py +1 -5
- moai_adk/core/git/commit.py +0 -1
- moai_adk/core/git/event_detector.py +3 -5
- moai_adk/core/git/manager.py +0 -1
- moai_adk/core/hooks/post_tool_auto_spec_completion.py +925 -0
- moai_adk/core/integration/__init__.py +22 -0
- moai_adk/core/integration/engine.py +169 -0
- moai_adk/core/integration/integration_tester.py +225 -0
- moai_adk/core/integration/models.py +88 -0
- moai_adk/core/integration/utils.py +211 -0
- moai_adk/core/issue_creator.py +28 -18
- moai_adk/core/language_config.py +202 -0
- moai_adk/core/language_validator.py +556 -0
- moai_adk/core/mcp/setup.py +113 -0
- moai_adk/core/migration/__init__.py +18 -0
- moai_adk/core/migration/backup_manager.py +208 -0
- moai_adk/core/migration/file_migrator.py +218 -0
- moai_adk/core/migration/version_detector.py +143 -0
- moai_adk/core/migration/version_migrator.py +228 -0
- moai_adk/core/performance/__init__.py +6 -0
- moai_adk/core/performance/cache_system.py +318 -0
- moai_adk/core/performance/parallel_processor.py +116 -0
- moai_adk/core/project/__init__.py +0 -1
- moai_adk/core/project/backup_utils.py +2 -7
- moai_adk/core/project/checker.py +3 -3
- moai_adk/core/project/detector.py +20 -40
- moai_adk/core/project/initializer.py +42 -17
- moai_adk/core/project/phase_executor.py +415 -58
- moai_adk/core/project/validator.py +6 -25
- moai_adk/core/quality/__init__.py +1 -1
- moai_adk/core/quality/trust_checker.py +64 -110
- moai_adk/core/quality/validators/__init__.py +1 -1
- moai_adk/core/quality/validators/base_validator.py +1 -1
- moai_adk/core/rollback_manager.py +993 -0
- moai_adk/core/session_manager.py +667 -0
- moai_adk/core/spec/confidence_scoring.py +749 -0
- moai_adk/core/spec/ears_template_engine.py +1182 -0
- moai_adk/core/spec/quality_validator.py +721 -0
- moai_adk/core/spec_status_manager.py +488 -0
- moai_adk/core/template/__init__.py +0 -1
- moai_adk/core/template/backup.py +41 -1
- moai_adk/core/template/config.py +11 -12
- moai_adk/core/template/languages.py +0 -1
- moai_adk/core/template/merger.py +79 -22
- moai_adk/core/template/processor.py +614 -40
- moai_adk/core/template_engine.py +36 -27
- moai_adk/foundation/git/commit_templates.py +565 -0
- moai_adk/foundation/trust/trust_principles.py +725 -0
- moai_adk/foundation/trust/validation_checklist.py +1678 -0
- moai_adk/statusline/__init__.py +38 -0
- moai_adk/statusline/alfred_detector.py +107 -0
- moai_adk/statusline/config.py +364 -0
- moai_adk/statusline/enhanced_output_style_detector.py +364 -0
- moai_adk/statusline/git_collector.py +190 -0
- moai_adk/statusline/main.py +228 -0
- moai_adk/statusline/metrics_tracker.py +78 -0
- moai_adk/statusline/renderer.py +327 -0
- moai_adk/statusline/update_checker.py +135 -0
- moai_adk/statusline/version_reader.py +647 -0
- moai_adk/templates/.git-hooks/pre-commit +66 -0
- moai_adk/templates/.git-hooks/pre-push +116 -4
- moai_adk/templates/.github/workflows/moai-gitflow.yml +1 -7
- moai_adk/templates/.github/workflows/spec-issue-sync.yml +0 -1
- moai_adk/templates/.gitignore +44 -0
- moai_adk/templates/.mcp.json +22 -0
- moai_adk/templates/CLAUDE.md +450 -1071
- moai_adk/utils/__init__.py +0 -1
- moai_adk/utils/banner.py +0 -1
- moai_adk/utils/common.py +308 -0
- moai_adk/utils/link_validator.py +249 -0
- moai_adk/utils/logger.py +4 -9
- moai_adk/utils/safe_file_reader.py +210 -0
- moai_adk/utils/user_experience.py +531 -0
- moai_adk-0.25.4.dist-info/METADATA +2279 -0
- moai_adk-0.25.4.dist-info/RECORD +112 -0
- moai_adk/core/tags/__init__.py +0 -86
- moai_adk/core/tags/ci_validator.py +0 -463
- moai_adk/core/tags/cli.py +0 -283
- moai_adk/core/tags/generator.py +0 -109
- moai_adk/core/tags/inserter.py +0 -99
- moai_adk/core/tags/mapper.py +0 -126
- moai_adk/core/tags/parser.py +0 -76
- moai_adk/core/tags/pre_commit_validator.py +0 -393
- moai_adk/core/tags/reporter.py +0 -956
- moai_adk/core/tags/tags.py +0 -149
- moai_adk/core/tags/validator.py +0 -897
- moai_adk/templates/.claude/agents/alfred/backend-expert.md +0 -319
- moai_adk/templates/.claude/agents/alfred/cc-manager.md +0 -316
- moai_adk/templates/.claude/agents/alfred/debug-helper.md +0 -208
- moai_adk/templates/.claude/agents/alfred/devops-expert.md +0 -464
- moai_adk/templates/.claude/agents/alfred/doc-syncer.md +0 -214
- moai_adk/templates/.claude/agents/alfred/frontend-expert.md +0 -357
- moai_adk/templates/.claude/agents/alfred/git-manager.md +0 -406
- moai_adk/templates/.claude/agents/alfred/implementation-planner.md +0 -423
- moai_adk/templates/.claude/agents/alfred/project-manager.md +0 -312
- moai_adk/templates/.claude/agents/alfred/quality-gate.md +0 -343
- moai_adk/templates/.claude/agents/alfred/skill-factory.md +0 -865
- moai_adk/templates/.claude/agents/alfred/spec-builder.md +0 -392
- moai_adk/templates/.claude/agents/alfred/tag-agent.md +0 -361
- moai_adk/templates/.claude/agents/alfred/tdd-implementer.md +0 -428
- moai_adk/templates/.claude/agents/alfred/trust-checker.md +0 -375
- moai_adk/templates/.claude/agents/alfred/ui-ux-expert.md +0 -571
- moai_adk/templates/.claude/commands/alfred/0-project.md +0 -1525
- moai_adk/templates/.claude/commands/alfred/1-plan.md +0 -802
- moai_adk/templates/.claude/commands/alfred/2-run.md +0 -709
- moai_adk/templates/.claude/commands/alfred/3-sync.md +0 -1009
- moai_adk/templates/.claude/commands/alfred/9-feedback.md +0 -149
- moai_adk/templates/.claude/hooks/alfred/core/project.py +0 -748
- moai_adk/templates/.claude/hooks/alfred/core/timeout.py +0 -136
- moai_adk/templates/.claude/hooks/alfred/core/ttl_cache.py +0 -108
- moai_adk/templates/.claude/hooks/alfred/core/version_cache.py +0 -198
- moai_adk/templates/.claude/hooks/alfred/handlers/__init__.py +0 -29
- moai_adk/templates/.claude/hooks/alfred/post_tool__log_changes.py +0 -94
- moai_adk/templates/.claude/hooks/alfred/pre_tool__auto_checkpoint.py +0 -100
- moai_adk/templates/.claude/hooks/alfred/session_end__cleanup.py +0 -94
- moai_adk/templates/.claude/hooks/alfred/session_start__show_project_info.py +0 -94
- moai_adk/templates/.claude/hooks/alfred/shared/core/__init__.py +0 -170
- moai_adk/templates/.claude/hooks/alfred/shared/core/checkpoint.py +0 -271
- moai_adk/templates/.claude/hooks/alfred/shared/core/context.py +0 -67
- moai_adk/templates/.claude/hooks/alfred/shared/core/project.py +0 -749
- moai_adk/templates/.claude/hooks/alfred/shared/core/tags.py +0 -230
- moai_adk/templates/.claude/hooks/alfred/shared/core/version_cache.py +0 -198
- moai_adk/templates/.claude/hooks/alfred/shared/handlers/__init__.py +0 -21
- moai_adk/templates/.claude/hooks/alfred/shared/handlers/notification.py +0 -154
- moai_adk/templates/.claude/hooks/alfred/shared/handlers/session.py +0 -174
- moai_adk/templates/.claude/hooks/alfred/shared/handlers/tool.py +0 -87
- moai_adk/templates/.claude/hooks/alfred/shared/handlers/user.py +0 -61
- moai_adk/templates/.claude/hooks/alfred/user_prompt__jit_load_docs.py +0 -112
- moai_adk/templates/.claude/hooks/alfred/utils/__init__.py +0 -1
- moai_adk/templates/.claude/hooks/alfred/utils/timeout.py +0 -161
- moai_adk/templates/.claude/settings.json +0 -144
- moai_adk/templates/.claude/skills/moai-alfred-agent-guide/SKILL.md +0 -70
- moai_adk/templates/.claude/skills/moai-alfred-agent-guide/examples.md +0 -62
- moai_adk/templates/.claude/skills/moai-alfred-agent-guide/reference.md +0 -242
- moai_adk/templates/.claude/skills/moai-alfred-config-schema/SKILL.md +0 -56
- moai_adk/templates/.claude/skills/moai-alfred-config-schema/examples.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-config-schema/reference.md +0 -444
- moai_adk/templates/.claude/skills/moai-alfred-context-budget/SKILL.md +0 -62
- moai_adk/templates/.claude/skills/moai-alfred-context-budget/examples.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-context-budget/reference.md +0 -405
- moai_adk/templates/.claude/skills/moai-alfred-dev-guide/SKILL.md +0 -51
- moai_adk/templates/.claude/skills/moai-alfred-dev-guide/examples.md +0 -355
- moai_adk/templates/.claude/skills/moai-alfred-dev-guide/reference.md +0 -239
- moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-expertise-detection/SKILL.md +0 -323
- moai_adk/templates/.claude/skills/moai-alfred-expertise-detection/examples.md +0 -286
- moai_adk/templates/.claude/skills/moai-alfred-expertise-detection/reference.md +0 -126
- moai_adk/templates/.claude/skills/moai-alfred-git-workflow/SKILL.md +0 -122
- moai_adk/templates/.claude/skills/moai-alfred-git-workflow/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-git-workflow/reference.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-gitflow-policy/SKILL.md +0 -74
- moai_adk/templates/.claude/skills/moai-alfred-gitflow-policy/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-alfred-gitflow-policy/reference.md +0 -269
- moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/SKILL.md +0 -237
- moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/examples.md +0 -615
- moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/reference.md +0 -653
- moai_adk/templates/.claude/skills/moai-alfred-issue-labels/SKILL.md +0 -19
- moai_adk/templates/.claude/skills/moai-alfred-issue-labels/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-alfred-issue-labels/reference.md +0 -150
- moai_adk/templates/.claude/skills/moai-alfred-language-detection/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-alfred-language-detection/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-language-detection/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-persona-roles/SKILL.md +0 -198
- moai_adk/templates/.claude/skills/moai-alfred-persona-roles/examples.md +0 -431
- moai_adk/templates/.claude/skills/moai-alfred-persona-roles/reference.md +0 -141
- moai_adk/templates/.claude/skills/moai-alfred-practices/SKILL.md +0 -89
- moai_adk/templates/.claude/skills/moai-alfred-practices/examples.md +0 -122
- moai_adk/templates/.claude/skills/moai-alfred-practices/reference.md +0 -369
- moai_adk/templates/.claude/skills/moai-alfred-proactive-suggestions/SKILL.md +0 -508
- moai_adk/templates/.claude/skills/moai-alfred-proactive-suggestions/examples.md +0 -481
- moai_adk/templates/.claude/skills/moai-alfred-proactive-suggestions/reference.md +0 -100
- moai_adk/templates/.claude/skills/moai-alfred-reporting/SKILL.md +0 -273
- moai_adk/templates/.claude/skills/moai-alfred-rules/SKILL.md +0 -77
- moai_adk/templates/.claude/skills/moai-alfred-rules/examples.md +0 -265
- moai_adk/templates/.claude/skills/moai-alfred-rules/reference.md +0 -539
- moai_adk/templates/.claude/skills/moai-alfred-session-state/SKILL.md +0 -19
- moai_adk/templates/.claude/skills/moai-alfred-session-state/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-alfred-session-state/reference.md +0 -84
- moai_adk/templates/.claude/skills/moai-alfred-spec-authoring/README.md +0 -137
- moai_adk/templates/.claude/skills/moai-alfred-spec-authoring/SKILL.md +0 -219
- moai_adk/templates/.claude/skills/moai-alfred-spec-authoring/examples/validate-spec.sh +0 -161
- moai_adk/templates/.claude/skills/moai-alfred-spec-authoring/examples.md +0 -541
- moai_adk/templates/.claude/skills/moai-alfred-spec-authoring/reference.md +0 -622
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-extended/SKILL.md +0 -115
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-extended/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-extended/reference.md +0 -348
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-todowrite-pattern/SKILL.md +0 -19
- moai_adk/templates/.claude/skills/moai-alfred-todowrite-pattern/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-alfred-todowrite-pattern/reference.md +0 -211
- moai_adk/templates/.claude/skills/moai-alfred-trust-validation/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-alfred-trust-validation/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-trust-validation/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-workflow/SKILL.md +0 -288
- moai_adk/templates/.claude/skills/moai-cc-agents/SKILL.md +0 -269
- moai_adk/templates/.claude/skills/moai-cc-agents/templates/agent-template.md +0 -32
- moai_adk/templates/.claude/skills/moai-cc-claude-md/SKILL.md +0 -298
- moai_adk/templates/.claude/skills/moai-cc-claude-md/templates/CLAUDE-template.md +0 -26
- moai_adk/templates/.claude/skills/moai-cc-commands/SKILL.md +0 -307
- moai_adk/templates/.claude/skills/moai-cc-commands/templates/command-template.md +0 -21
- moai_adk/templates/.claude/skills/moai-cc-hooks/SKILL.md +0 -252
- moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/pre-bash-check.sh +0 -19
- moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/preserve-permissions.sh +0 -19
- moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/validate-bash-command.py +0 -24
- moai_adk/templates/.claude/skills/moai-cc-mcp-plugins/SKILL.md +0 -199
- moai_adk/templates/.claude/skills/moai-cc-mcp-plugins/templates/settings-mcp-template.json +0 -39
- moai_adk/templates/.claude/skills/moai-cc-memory/SKILL.md +0 -316
- moai_adk/templates/.claude/skills/moai-cc-memory/templates/session-summary-template.md +0 -18
- moai_adk/templates/.claude/skills/moai-cc-settings/SKILL.md +0 -263
- moai_adk/templates/.claude/skills/moai-cc-settings/templates/settings-complete-template.json +0 -30
- moai_adk/templates/.claude/skills/moai-cc-skill-descriptions/SKILL.md +0 -19
- moai_adk/templates/.claude/skills/moai-cc-skill-descriptions/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-cc-skill-descriptions/reference.md +0 -218
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/CHECKLIST.md +0 -482
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/EXAMPLES.md +0 -278
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/INTERACTIVE-DISCOVERY.md +0 -524
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/METADATA.md +0 -477
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/PARALLEL-ANALYSIS-REPORT.md +0 -429
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/PYTHON-VERSION-MATRIX.md +0 -391
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/SKILL-FACTORY-WORKFLOW.md +0 -431
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/SKILL-UPDATE-ADVISOR.md +0 -577
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/SKILL.md +0 -271
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/STEP-BY-STEP-GUIDE.md +0 -466
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/STRUCTURE.md +0 -583
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/WEB-RESEARCH.md +0 -526
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/reference.md +0 -465
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/scripts/generate-structure.sh +0 -328
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/scripts/validate-skill.sh +0 -312
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/templates/SKILL_TEMPLATE.md +0 -245
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/templates/examples-template.md +0 -285
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/templates/reference-template.md +0 -278
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/templates/scripts-template.sh +0 -303
- moai_adk/templates/.claude/skills/moai-cc-skills/SKILL.md +0 -291
- moai_adk/templates/.claude/skills/moai-cc-skills/templates/SKILL-template.md +0 -15
- moai_adk/templates/.claude/skills/moai-design-systems/SKILL.md +0 -802
- moai_adk/templates/.claude/skills/moai-design-systems/examples.md +0 -1238
- moai_adk/templates/.claude/skills/moai-design-systems/reference.md +0 -673
- moai_adk/templates/.claude/skills/moai-domain-backend/SKILL.md +0 -290
- moai_adk/templates/.claude/skills/moai-domain-backend/examples.md +0 -1633
- moai_adk/templates/.claude/skills/moai-domain-backend/reference.md +0 -660
- moai_adk/templates/.claude/skills/moai-domain-cli-tool/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-cli-tool/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-cli-tool/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-data-science/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-data-science/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-data-science/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-database/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-database/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-database/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-devops/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-domain-devops/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-devops/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-domain-frontend/SKILL.md +0 -128
- moai_adk/templates/.claude/skills/moai-domain-frontend/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-frontend/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-domain-ml/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-ml/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-ml/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-mobile-app/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-mobile-app/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-mobile-app/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-security/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-security/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-security/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-web-api/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-web-api/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-web-api/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-essentials-debug/SKILL.md +0 -303
- moai_adk/templates/.claude/skills/moai-essentials-debug/examples.md +0 -1064
- moai_adk/templates/.claude/skills/moai-essentials-debug/reference.md +0 -1047
- moai_adk/templates/.claude/skills/moai-essentials-perf/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-essentials-perf/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-essentials-perf/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-essentials-refactor/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-essentials-refactor/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-essentials-refactor/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-essentials-review/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-essentials-review/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-essentials-review/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-foundation-ears/SKILL.md +0 -116
- moai_adk/templates/.claude/skills/moai-foundation-ears/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-ears/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-foundation-git/SKILL.md +0 -122
- moai_adk/templates/.claude/skills/moai-foundation-git/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-git/reference.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-langs/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-foundation-langs/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-langs/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-foundation-specs/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-foundation-specs/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-specs/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-foundation-tags/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-foundation-tags/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-tags/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-foundation-trust/SKILL.md +0 -307
- moai_adk/templates/.claude/skills/moai-foundation-trust/examples.md +0 -0
- moai_adk/templates/.claude/skills/moai-foundation-trust/reference.md +0 -1099
- moai_adk/templates/.claude/skills/moai-lang-c/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-lang-c/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-c/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-cpp/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-lang-cpp/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-cpp/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-csharp/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-lang-csharp/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-csharp/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-dart/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-lang-dart/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-dart/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-go/SKILL.md +0 -127
- moai_adk/templates/.claude/skills/moai-lang-go/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-go/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-java/SKILL.md +0 -126
- moai_adk/templates/.claude/skills/moai-lang-java/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-java/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-javascript/SKILL.md +0 -125
- moai_adk/templates/.claude/skills/moai-lang-javascript/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-javascript/reference.md +0 -32
- moai_adk/templates/.claude/skills/moai-lang-kotlin/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-lang-kotlin/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-kotlin/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-php/SKILL.md +0 -126
- moai_adk/templates/.claude/skills/moai-lang-php/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-php/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-python/SKILL.md +0 -433
- moai_adk/templates/.claude/skills/moai-lang-python/examples.md +0 -624
- moai_adk/templates/.claude/skills/moai-lang-python/reference.md +0 -316
- moai_adk/templates/.claude/skills/moai-lang-r/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-lang-r/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-r/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-ruby/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-lang-ruby/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-ruby/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-rust/SKILL.md +0 -127
- moai_adk/templates/.claude/skills/moai-lang-rust/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-rust/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-scala/SKILL.md +0 -125
- moai_adk/templates/.claude/skills/moai-lang-scala/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-scala/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-shell/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-lang-shell/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-shell/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-sql/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-lang-sql/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-sql/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-swift/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-lang-swift/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-swift/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-typescript/SKILL.md +0 -133
- moai_adk/templates/.claude/skills/moai-lang-typescript/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-typescript/reference.md +0 -34
- moai_adk/templates/.claude/skills/moai-project-documentation.md +0 -622
- moai_adk/templates/.github/workflows/c-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/cpp-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/csharp-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/dart-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/go-tag-validation.yml +0 -130
- moai_adk/templates/.github/workflows/java-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/javascript-tag-validation.yml +0 -135
- moai_adk/templates/.github/workflows/kotlin-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/php-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/python-tag-validation.yml +0 -118
- moai_adk/templates/.github/workflows/release.yml +0 -118
- moai_adk/templates/.github/workflows/ruby-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/rust-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/shell-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/swift-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/tag-report.yml +0 -269
- moai_adk/templates/.github/workflows/tag-validation.yml +0 -186
- moai_adk/templates/.github/workflows/typescript-tag-validation.yml +0 -154
- moai_adk/templates/.moai/config.json +0 -115
- moai_adk/templates/workflows/go-tag-validation.yml +0 -30
- moai_adk/templates/workflows/javascript-tag-validation.yml +0 -41
- moai_adk/templates/workflows/python-tag-validation.yml +0 -42
- moai_adk/templates/workflows/typescript-tag-validation.yml +0 -31
- moai_adk-0.15.0.dist-info/METADATA +0 -3079
- moai_adk-0.15.0.dist-info/RECORD +0 -365
- {moai_adk-0.15.0.dist-info → moai_adk-0.25.4.dist-info}/WHEEL +0 -0
- {moai_adk-0.15.0.dist-info → moai_adk-0.25.4.dist-info}/entry_points.txt +0 -0
- {moai_adk-0.15.0.dist-info → moai_adk-0.25.4.dist-info}/licenses/LICENSE +0 -0
|
@@ -0,0 +1,346 @@
|
|
|
1
|
+
"""Auto-Spec Completion Configuration Reader."""
|
|
2
|
+
|
|
3
|
+
import json
|
|
4
|
+
import logging
|
|
5
|
+
from pathlib import Path
|
|
6
|
+
from typing import Any, Dict, List
|
|
7
|
+
|
|
8
|
+
# Configure logging
|
|
9
|
+
logger = logging.getLogger(__name__)
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
class AutoSpecConfig:
|
|
13
|
+
"""
|
|
14
|
+
Configuration reader for Auto-Spec Completion system.
|
|
15
|
+
|
|
16
|
+
This class reads and validates the auto-spec completion configuration
|
|
17
|
+
from the main MoAI configuration file.
|
|
18
|
+
"""
|
|
19
|
+
|
|
20
|
+
def __init__(self, config_path: str = None):
|
|
21
|
+
"""Initialize the configuration reader."""
|
|
22
|
+
self.config_path = config_path or self._get_default_config_path()
|
|
23
|
+
self.config = {}
|
|
24
|
+
self.load_config()
|
|
25
|
+
|
|
26
|
+
def _get_default_config_path(self) -> str:
|
|
27
|
+
"""Get the default configuration file path."""
|
|
28
|
+
# Try to find config in multiple locations
|
|
29
|
+
possible_paths = [
|
|
30
|
+
Path.cwd() / ".moai" / "config.json",
|
|
31
|
+
Path.cwd() / "config.json",
|
|
32
|
+
Path.home() / ".moai" / "config.json",
|
|
33
|
+
]
|
|
34
|
+
|
|
35
|
+
for path in possible_paths:
|
|
36
|
+
if path.exists():
|
|
37
|
+
return str(path)
|
|
38
|
+
|
|
39
|
+
# Default to current directory
|
|
40
|
+
return str(Path.cwd() / ".moai" / "config.json")
|
|
41
|
+
|
|
42
|
+
def load_config(self) -> None:
|
|
43
|
+
"""Load configuration from file."""
|
|
44
|
+
try:
|
|
45
|
+
with open(self.config_path, "r", encoding="utf-8") as f:
|
|
46
|
+
self.config = json.load(f)
|
|
47
|
+
|
|
48
|
+
# Extract auto-spec completion config
|
|
49
|
+
self.config = self.config.get("auto_spec_completion", {})
|
|
50
|
+
|
|
51
|
+
logger.info(
|
|
52
|
+
f"Loaded auto-spec completion configuration from {self.config_path}"
|
|
53
|
+
)
|
|
54
|
+
|
|
55
|
+
except FileNotFoundError:
|
|
56
|
+
logger.warning(f"Configuration file not found: {self.config_path}")
|
|
57
|
+
self._load_default_config()
|
|
58
|
+
except json.JSONDecodeError as e:
|
|
59
|
+
logger.error(f"Invalid JSON in configuration file: {e}")
|
|
60
|
+
self._load_default_config()
|
|
61
|
+
except Exception as e:
|
|
62
|
+
logger.error(f"Error loading configuration: {e}")
|
|
63
|
+
self._load_default_config()
|
|
64
|
+
|
|
65
|
+
def _load_default_config(self) -> None:
|
|
66
|
+
"""Load default configuration."""
|
|
67
|
+
logger.info("Loading default auto-spec completion configuration")
|
|
68
|
+
self.config = self._get_default_config()
|
|
69
|
+
|
|
70
|
+
def _get_default_config(self) -> Dict[str, Any]:
|
|
71
|
+
"""Get default configuration."""
|
|
72
|
+
return {
|
|
73
|
+
"enabled": True,
|
|
74
|
+
"trigger_tools": ["Write", "Edit", "MultiEdit"],
|
|
75
|
+
"confidence_threshold": 0.7,
|
|
76
|
+
"execution_timeout_ms": 1500,
|
|
77
|
+
"quality_threshold": {
|
|
78
|
+
"ears_compliance": 0.85,
|
|
79
|
+
"min_content_length": 500,
|
|
80
|
+
"max_review_suggestions": 10,
|
|
81
|
+
},
|
|
82
|
+
"excluded_patterns": [
|
|
83
|
+
"test_*.py",
|
|
84
|
+
"*_test.py",
|
|
85
|
+
"*/tests/*",
|
|
86
|
+
"*/__pycache__/*",
|
|
87
|
+
"*/node_modules/*",
|
|
88
|
+
"*/dist/*",
|
|
89
|
+
"*/build/*",
|
|
90
|
+
],
|
|
91
|
+
"domain_templates": {
|
|
92
|
+
"enabled": True,
|
|
93
|
+
"auto_detect": True,
|
|
94
|
+
"supported_domains": ["auth", "api", "data", "ui", "business"],
|
|
95
|
+
"fallback_domain": "general",
|
|
96
|
+
},
|
|
97
|
+
"spec_structure": {
|
|
98
|
+
"include_meta": True,
|
|
99
|
+
"include_traceability": True,
|
|
100
|
+
"include_edit_guide": True,
|
|
101
|
+
"required_sections": [
|
|
102
|
+
"Overview",
|
|
103
|
+
"Environment",
|
|
104
|
+
"Assumptions",
|
|
105
|
+
"Requirements",
|
|
106
|
+
"Specifications",
|
|
107
|
+
"Traceability",
|
|
108
|
+
],
|
|
109
|
+
},
|
|
110
|
+
"validation": {
|
|
111
|
+
"enabled": True,
|
|
112
|
+
"quality_grades": ["A", "B", "C", "D", "F"],
|
|
113
|
+
"passing_grades": ["A", "B", "C"],
|
|
114
|
+
"auto_improve": True,
|
|
115
|
+
"max_iterations": 3,
|
|
116
|
+
},
|
|
117
|
+
"output": {
|
|
118
|
+
"auto_create_files": True,
|
|
119
|
+
"open_in_editor": True,
|
|
120
|
+
"file_format": "markdown",
|
|
121
|
+
"encoding": "utf-8",
|
|
122
|
+
},
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
def is_enabled(self) -> bool:
|
|
126
|
+
"""Check if auto-spec completion is enabled."""
|
|
127
|
+
return self.config.get("enabled", False)
|
|
128
|
+
|
|
129
|
+
def get_trigger_tools(self) -> List[str]:
|
|
130
|
+
"""Get list of tools that trigger auto-spec completion."""
|
|
131
|
+
return self.config.get("trigger_tools", [])
|
|
132
|
+
|
|
133
|
+
def get_confidence_threshold(self) -> float:
|
|
134
|
+
"""Get confidence threshold for triggering auto-spec completion."""
|
|
135
|
+
return self.config.get("confidence_threshold", 0.7)
|
|
136
|
+
|
|
137
|
+
def get_execution_timeout_ms(self) -> int:
|
|
138
|
+
"""Get execution timeout in milliseconds."""
|
|
139
|
+
return self.config.get("execution_timeout_ms", 1500)
|
|
140
|
+
|
|
141
|
+
def get_quality_threshold(self) -> Dict[str, Any]:
|
|
142
|
+
"""Get quality threshold configuration."""
|
|
143
|
+
return self.config.get("quality_threshold", {})
|
|
144
|
+
|
|
145
|
+
def get_excluded_patterns(self) -> List[str]:
|
|
146
|
+
"""Get list of file patterns to exclude from auto-spec completion."""
|
|
147
|
+
return self.config.get("excluded_patterns", [])
|
|
148
|
+
|
|
149
|
+
def get_domain_templates_config(self) -> Dict[str, Any]:
|
|
150
|
+
"""Get domain templates configuration."""
|
|
151
|
+
return self.config.get("domain_templates", {})
|
|
152
|
+
|
|
153
|
+
def get_spec_structure_config(self) -> Dict[str, Any]:
|
|
154
|
+
"""Get spec structure configuration."""
|
|
155
|
+
return self.config.get("spec_structure", {})
|
|
156
|
+
|
|
157
|
+
def get_validation_config(self) -> Dict[str, Any]:
|
|
158
|
+
"""Get validation configuration."""
|
|
159
|
+
return self.config.get("validation", {})
|
|
160
|
+
|
|
161
|
+
def get_output_config(self) -> Dict[str, Any]:
|
|
162
|
+
"""Get output configuration."""
|
|
163
|
+
return self.config.get("output", {})
|
|
164
|
+
|
|
165
|
+
def should_exclude_file(self, file_path: str) -> bool:
|
|
166
|
+
"""Check if a file should be excluded from auto-spec completion."""
|
|
167
|
+
excluded_patterns = self.get_excluded_patterns()
|
|
168
|
+
|
|
169
|
+
if not excluded_patterns:
|
|
170
|
+
return False
|
|
171
|
+
|
|
172
|
+
# Convert file path to normalized string
|
|
173
|
+
normalized_path = str(Path(file_path)).lower()
|
|
174
|
+
|
|
175
|
+
for pattern in excluded_patterns:
|
|
176
|
+
# Convert pattern to lowercase for case-insensitive matching
|
|
177
|
+
pattern_lower = pattern.lower()
|
|
178
|
+
|
|
179
|
+
# Handle directory patterns
|
|
180
|
+
if pattern.startswith("*/") and pattern.endswith("/*"):
|
|
181
|
+
dir_pattern = pattern[2:-2] # Remove */ and /*
|
|
182
|
+
if dir_pattern in normalized_path:
|
|
183
|
+
return True
|
|
184
|
+
# Handle file patterns
|
|
185
|
+
elif "*" in pattern:
|
|
186
|
+
# Simple wildcard matching
|
|
187
|
+
regex_pattern = pattern.replace("*", ".*")
|
|
188
|
+
import re
|
|
189
|
+
|
|
190
|
+
if re.search(regex_pattern, normalized_path):
|
|
191
|
+
return True
|
|
192
|
+
# Exact match
|
|
193
|
+
elif pattern in normalized_path:
|
|
194
|
+
return True
|
|
195
|
+
|
|
196
|
+
return False
|
|
197
|
+
|
|
198
|
+
def get_required_sections(self) -> List[str]:
|
|
199
|
+
"""Get list of required SPEC sections."""
|
|
200
|
+
return self.config.get("spec_structure", {}).get("required_sections", [])
|
|
201
|
+
|
|
202
|
+
def get_supported_domains(self) -> List[str]:
|
|
203
|
+
"""Get list of supported domains."""
|
|
204
|
+
return self.config.get("domain_templates", {}).get("supported_domains", [])
|
|
205
|
+
|
|
206
|
+
def get_fallback_domain(self) -> str:
|
|
207
|
+
"""Get fallback domain for unsupported domains."""
|
|
208
|
+
return self.config.get("domain_templates", {}).get("fallback_domain", "general")
|
|
209
|
+
|
|
210
|
+
def should_include_meta(self) -> bool:
|
|
211
|
+
"""Check if meta information should be included."""
|
|
212
|
+
return self.config.get("spec_structure", {}).get("include_meta", True)
|
|
213
|
+
|
|
214
|
+
def should_include_traceability(self) -> bool:
|
|
215
|
+
"""Check if traceability information should be included."""
|
|
216
|
+
return self.config.get("spec_structure", {}).get("include_traceability", True)
|
|
217
|
+
|
|
218
|
+
def should_include_edit_guide(self) -> bool:
|
|
219
|
+
"""Check if edit guide should be included."""
|
|
220
|
+
return self.config.get("spec_structure", {}).get("include_edit_guide", True)
|
|
221
|
+
|
|
222
|
+
def get_passing_quality_grades(self) -> List[str]:
|
|
223
|
+
"""Get list of passing quality grades."""
|
|
224
|
+
return self.config.get("validation", {}).get("passing_grades", ["A", "B", "C"])
|
|
225
|
+
|
|
226
|
+
def should_auto_improve(self) -> bool:
|
|
227
|
+
"""Check if auto-improvement is enabled."""
|
|
228
|
+
return self.config.get("validation", {}).get("auto_improve", True)
|
|
229
|
+
|
|
230
|
+
def get_max_improvement_iterations(self) -> int:
|
|
231
|
+
"""Get maximum improvement iterations."""
|
|
232
|
+
return self.config.get("validation", {}).get("max_iterations", 3)
|
|
233
|
+
|
|
234
|
+
def should_auto_create_files(self) -> bool:
|
|
235
|
+
"""Check if auto-creation of files is enabled."""
|
|
236
|
+
return self.config.get("output", {}).get("auto_create_files", True)
|
|
237
|
+
|
|
238
|
+
def should_open_in_editor(self) -> bool:
|
|
239
|
+
"""Check if files should be opened in editor."""
|
|
240
|
+
return self.config.get("output", {}).get("open_in_editor", True)
|
|
241
|
+
|
|
242
|
+
def get_file_format(self) -> str:
|
|
243
|
+
"""Get output file format."""
|
|
244
|
+
return self.config.get("output", {}).get("file_format", "markdown")
|
|
245
|
+
|
|
246
|
+
def get_encoding(self) -> str:
|
|
247
|
+
"""Get output encoding."""
|
|
248
|
+
return self.config.get("output", {}).get("encoding", "utf-8")
|
|
249
|
+
|
|
250
|
+
def is_validation_enabled(self) -> bool:
|
|
251
|
+
"""Check if validation is enabled."""
|
|
252
|
+
return self.config.get("validation", {}).get("enabled", True)
|
|
253
|
+
|
|
254
|
+
def is_domain_detection_enabled(self) -> bool:
|
|
255
|
+
"""Check if domain detection is enabled."""
|
|
256
|
+
return self.config.get("domain_templates", {}).get("auto_detect", True)
|
|
257
|
+
|
|
258
|
+
def validate_config(self) -> List[str]:
|
|
259
|
+
"""Validate configuration and return list of errors."""
|
|
260
|
+
errors = []
|
|
261
|
+
|
|
262
|
+
# Check required fields
|
|
263
|
+
if not isinstance(self.config.get("enabled"), bool):
|
|
264
|
+
errors.append("enabled must be a boolean")
|
|
265
|
+
|
|
266
|
+
if not isinstance(self.config.get("confidence_threshold"), (int, float)):
|
|
267
|
+
errors.append("confidence_threshold must be a number")
|
|
268
|
+
elif not 0 <= self.config.get("confidence_threshold") <= 1:
|
|
269
|
+
errors.append("confidence_threshold must be between 0 and 1")
|
|
270
|
+
|
|
271
|
+
if not isinstance(self.config.get("execution_timeout_ms"), int):
|
|
272
|
+
errors.append("execution_timeout_ms must be an integer")
|
|
273
|
+
elif self.config.get("execution_timeout_ms") <= 0:
|
|
274
|
+
errors.append("execution_timeout_ms must be positive")
|
|
275
|
+
|
|
276
|
+
# Check trigger tools
|
|
277
|
+
trigger_tools = self.config.get("trigger_tools", [])
|
|
278
|
+
if not isinstance(trigger_tools, list):
|
|
279
|
+
errors.append("trigger_tools must be a list")
|
|
280
|
+
else:
|
|
281
|
+
for tool in trigger_tools:
|
|
282
|
+
if not isinstance(tool, str):
|
|
283
|
+
errors.append("All trigger_tools must be strings")
|
|
284
|
+
|
|
285
|
+
# Check excluded patterns
|
|
286
|
+
excluded_patterns = self.config.get("excluded_patterns", [])
|
|
287
|
+
if not isinstance(excluded_patterns, list):
|
|
288
|
+
errors.append("excluded_patterns must be a list")
|
|
289
|
+
else:
|
|
290
|
+
for pattern in excluded_patterns:
|
|
291
|
+
if not isinstance(pattern, str):
|
|
292
|
+
errors.append("All excluded_patterns must be strings")
|
|
293
|
+
|
|
294
|
+
# Check quality threshold
|
|
295
|
+
quality_threshold = self.config.get("quality_threshold", {})
|
|
296
|
+
if not isinstance(quality_threshold, dict):
|
|
297
|
+
errors.append("quality_threshold must be a dictionary")
|
|
298
|
+
else:
|
|
299
|
+
if "ears_compliance" in quality_threshold:
|
|
300
|
+
if not isinstance(quality_threshold["ears_compliance"], (int, float)):
|
|
301
|
+
errors.append("quality_threshold.ears_compliance must be a number")
|
|
302
|
+
elif not 0 <= quality_threshold["ears_compliance"] <= 1:
|
|
303
|
+
errors.append(
|
|
304
|
+
"quality_threshold.ears_compliance must be between 0 and 1"
|
|
305
|
+
)
|
|
306
|
+
|
|
307
|
+
return errors
|
|
308
|
+
|
|
309
|
+
def to_dict(self) -> Dict[str, Any]:
|
|
310
|
+
"""Convert configuration to dictionary."""
|
|
311
|
+
return self.config.copy()
|
|
312
|
+
|
|
313
|
+
def update_config(self, updates: Dict[str, Any]) -> None:
|
|
314
|
+
"""Update configuration with new values."""
|
|
315
|
+
self.config.update(updates)
|
|
316
|
+
logger.info(f"Updated auto-spec completion configuration: {updates}")
|
|
317
|
+
|
|
318
|
+
def save_config(self) -> None:
|
|
319
|
+
"""Save configuration to file."""
|
|
320
|
+
try:
|
|
321
|
+
# Load the full config file
|
|
322
|
+
with open(self.config_path, "r", encoding="utf-8") as f:
|
|
323
|
+
full_config = json.load(f)
|
|
324
|
+
|
|
325
|
+
# Update the auto-spec completion config
|
|
326
|
+
full_config["auto_spec_completion"] = self.config
|
|
327
|
+
|
|
328
|
+
# Save back to file
|
|
329
|
+
with open(self.config_path, "w", encoding="utf-8") as f:
|
|
330
|
+
json.dump(full_config, f, indent=2, ensure_ascii=False)
|
|
331
|
+
|
|
332
|
+
logger.info(
|
|
333
|
+
f"Saved auto-spec completion configuration to {self.config_path}"
|
|
334
|
+
)
|
|
335
|
+
|
|
336
|
+
except Exception as e:
|
|
337
|
+
logger.error(f"Error saving configuration: {e}")
|
|
338
|
+
raise
|
|
339
|
+
|
|
340
|
+
def __str__(self) -> str:
|
|
341
|
+
"""String representation of configuration."""
|
|
342
|
+
return json.dumps(self.config, indent=2, ensure_ascii=False)
|
|
343
|
+
|
|
344
|
+
def __repr__(self) -> str:
|
|
345
|
+
"""String representation for debugging."""
|
|
346
|
+
return f"AutoSpecConfig(enabled={self.is_enabled()}, config_path='{self.config_path}')"
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
# @CODE:LANG-FIX-001:MIGRATION | SPEC: .moai/specs/SPEC-LANG-FIX-001/spec.md
|
|
2
1
|
"""Configuration migration utilities for legacy flat config structure.
|
|
3
2
|
|
|
4
3
|
Supports migration from legacy flat config.json structure to new nested language structure.
|
|
@@ -36,13 +35,12 @@ def migrate_config_to_nested_structure(config: dict[str, Any]) -> dict[str, Any]
|
|
|
36
35
|
conversation_language = config.pop("conversation_language", "en")
|
|
37
36
|
config.pop("locale", None) # Remove legacy locale field
|
|
38
37
|
|
|
39
|
-
#
|
|
38
|
+
# Import enhanced language configuration
|
|
39
|
+
from ..language_config import LANGUAGE_CONFIG
|
|
40
|
+
|
|
41
|
+
# Extract language names from enhanced config
|
|
40
42
|
language_names = {
|
|
41
|
-
|
|
42
|
-
"ko": "한국어",
|
|
43
|
-
"ja": "日本語",
|
|
44
|
-
"zh": "中文",
|
|
45
|
-
"es": "Español",
|
|
43
|
+
code: info["native_name"] for code, info in LANGUAGE_CONFIG.items()
|
|
46
44
|
}
|
|
47
45
|
|
|
48
46
|
language_name = language_names.get(conversation_language, "English")
|
|
@@ -103,11 +101,134 @@ def get_conversation_language_name(config: dict[str, Any]) -> str:
|
|
|
103
101
|
|
|
104
102
|
# If we have the language code, try to map it
|
|
105
103
|
language_code = get_conversation_language(config)
|
|
104
|
+
|
|
105
|
+
# Import enhanced language configuration
|
|
106
|
+
from ..language_config import LANGUAGE_CONFIG
|
|
107
|
+
|
|
108
|
+
# Extract language names from enhanced config
|
|
106
109
|
language_names = {
|
|
107
|
-
|
|
108
|
-
"ko": "한국어",
|
|
109
|
-
"ja": "日本語",
|
|
110
|
-
"zh": "中文",
|
|
111
|
-
"es": "Español",
|
|
110
|
+
code: info["native_name"] for code, info in LANGUAGE_CONFIG.items()
|
|
112
111
|
}
|
|
113
112
|
return language_names.get(language_code, "English")
|
|
113
|
+
|
|
114
|
+
|
|
115
|
+
def migrate_config_schema_v0_17_0(config: dict[str, Any]) -> dict[str, Any]:
|
|
116
|
+
"""Migrate config schema for v0.16.0 → v0.17.0 (report generation feature).
|
|
117
|
+
|
|
118
|
+
Adds new sections:
|
|
119
|
+
- report_generation: Control automatic report generation
|
|
120
|
+
- Enhanced github: auto_delete_branches, spec_git_workflow settings
|
|
121
|
+
|
|
122
|
+
This function is backward-compatible and safe for existing configs.
|
|
123
|
+
|
|
124
|
+
Args:
|
|
125
|
+
config: Configuration dictionary (may be v0.16.0 or earlier).
|
|
126
|
+
|
|
127
|
+
Returns:
|
|
128
|
+
Configuration dictionary with v0.17.0 schema.
|
|
129
|
+
"""
|
|
130
|
+
# 1. Add report_generation section if missing (defaults to enabled=true, auto_create=false)
|
|
131
|
+
if "report_generation" not in config:
|
|
132
|
+
config["report_generation"] = {
|
|
133
|
+
"enabled": True,
|
|
134
|
+
"auto_create": False,
|
|
135
|
+
"warn_user": True,
|
|
136
|
+
"user_choice": "Minimal",
|
|
137
|
+
"configured_at": None, # Will be set when user configures
|
|
138
|
+
"allowed_locations": [
|
|
139
|
+
".moai/docs/",
|
|
140
|
+
".moai/reports/",
|
|
141
|
+
".moai/analysis/",
|
|
142
|
+
".moai/specs/SPEC-*/",
|
|
143
|
+
],
|
|
144
|
+
"notes": (
|
|
145
|
+
"Control automatic report generation. 'enabled': turn on/off, "
|
|
146
|
+
"'auto_create': full (true) vs minimal (false) reports. "
|
|
147
|
+
"Helps reduce token usage."
|
|
148
|
+
),
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
# 2. Enhance github section with new fields
|
|
152
|
+
if "github" not in config:
|
|
153
|
+
config["github"] = {}
|
|
154
|
+
|
|
155
|
+
github_config = config["github"]
|
|
156
|
+
|
|
157
|
+
# Add auto_delete_branches settings if missing
|
|
158
|
+
if "auto_delete_branches" not in github_config:
|
|
159
|
+
github_config["auto_delete_branches"] = None
|
|
160
|
+
github_config["auto_delete_branches_checked"] = False
|
|
161
|
+
github_config["auto_delete_branches_rationale"] = "Not configured"
|
|
162
|
+
|
|
163
|
+
# Add spec_git_workflow settings if missing
|
|
164
|
+
if "spec_git_workflow" not in github_config:
|
|
165
|
+
github_config["spec_git_workflow"] = "per_spec"
|
|
166
|
+
github_config["spec_git_workflow_configured"] = False
|
|
167
|
+
github_config["spec_git_workflow_rationale"] = (
|
|
168
|
+
"Ask per SPEC (flexible, user controls each workflow)"
|
|
169
|
+
)
|
|
170
|
+
|
|
171
|
+
# Add notes for new fields if missing
|
|
172
|
+
if "notes_new_fields" not in github_config:
|
|
173
|
+
github_config["notes_new_fields"] = (
|
|
174
|
+
"auto_delete_branches: whether to auto-delete feature branches after merge. "
|
|
175
|
+
"spec_git_workflow: 'feature_branch' (auto), 'develop_direct' (direct), "
|
|
176
|
+
"'per_spec' (ask per SPEC)"
|
|
177
|
+
)
|
|
178
|
+
|
|
179
|
+
return config
|
|
180
|
+
|
|
181
|
+
|
|
182
|
+
def get_report_generation_config(config: dict[str, Any]) -> dict[str, Any]:
|
|
183
|
+
"""Get report generation configuration with safe defaults.
|
|
184
|
+
|
|
185
|
+
Args:
|
|
186
|
+
config: Configuration dictionary.
|
|
187
|
+
|
|
188
|
+
Returns:
|
|
189
|
+
Report generation configuration with defaults.
|
|
190
|
+
"""
|
|
191
|
+
default_config = {
|
|
192
|
+
"enabled": True,
|
|
193
|
+
"auto_create": False,
|
|
194
|
+
"warn_user": True,
|
|
195
|
+
"user_choice": "Minimal",
|
|
196
|
+
"configured_at": None,
|
|
197
|
+
"allowed_locations": [
|
|
198
|
+
".moai/docs/",
|
|
199
|
+
".moai/reports/",
|
|
200
|
+
".moai/analysis/",
|
|
201
|
+
".moai/specs/SPEC-*/",
|
|
202
|
+
],
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
report_gen = config.get("report_generation", {})
|
|
206
|
+
if isinstance(report_gen, dict):
|
|
207
|
+
# Merge with defaults to ensure all keys exist
|
|
208
|
+
return {**default_config, **report_gen}
|
|
209
|
+
|
|
210
|
+
return default_config
|
|
211
|
+
|
|
212
|
+
|
|
213
|
+
def get_spec_git_workflow(config: dict[str, Any]) -> str:
|
|
214
|
+
"""Get SPEC git workflow setting with safe default.
|
|
215
|
+
|
|
216
|
+
Options:
|
|
217
|
+
- 'per_spec': Ask per SPEC (flexible, user controls)
|
|
218
|
+
- 'feature_branch': Auto-create branch for each SPEC
|
|
219
|
+
- 'develop_direct': Direct commits to develop
|
|
220
|
+
|
|
221
|
+
Args:
|
|
222
|
+
config: Configuration dictionary.
|
|
223
|
+
|
|
224
|
+
Returns:
|
|
225
|
+
Workflow setting string.
|
|
226
|
+
"""
|
|
227
|
+
github_config = config.get("github", {})
|
|
228
|
+
if isinstance(github_config, dict):
|
|
229
|
+
workflow = github_config.get("spec_git_workflow")
|
|
230
|
+
if workflow in ["per_spec", "feature_branch", "develop_direct"]:
|
|
231
|
+
return workflow
|
|
232
|
+
|
|
233
|
+
# Default: per_spec (ask user)
|
|
234
|
+
return "per_spec"
|