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
|
@@ -1,1009 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: alfred:3-sync
|
|
3
|
-
description: "Synchronize documentation and finalize PR"
|
|
4
|
-
argument-hint: 'Mode target path - Mode: auto (default)|force|status|project, target
|
|
5
|
-
path: Synchronization target path'
|
|
6
|
-
allowed-tools:
|
|
7
|
-
- Read
|
|
8
|
-
- Write
|
|
9
|
-
- Edit
|
|
10
|
-
- MultiEdit
|
|
11
|
-
- Bash(git:*)
|
|
12
|
-
- Bash(gh:*)
|
|
13
|
-
- Bash(python3:*)
|
|
14
|
-
- Task
|
|
15
|
-
- Grep
|
|
16
|
-
- Glob
|
|
17
|
-
- TodoWrite
|
|
18
|
-
---
|
|
19
|
-
|
|
20
|
-
# 📚 MoAI-ADK Step 3: Document Synchronization (+Optional PR Ready)
|
|
21
|
-
> **Note**: Interactive prompts use `AskUserQuestion tool (documented in moai-alfred-interactive-questions skill)` for TUI selection menus. The skill is loaded on-demand when user interaction is required.
|
|
22
|
-
>
|
|
23
|
-
> **Batched Design**: All AskUserQuestion calls follow batched design principles (1-4 questions per call) to minimize user interaction turns. See CLAUDE.md section "Alfred Command Completion Pattern" for details.
|
|
24
|
-
|
|
25
|
-
<!-- @CODE:ALF-WORKFLOW-003:CMD-SYNC -->
|
|
26
|
-
|
|
27
|
-
**4-Step Workflow Integration**: This command implements Step 4 of Alfred's workflow (Report & Commit with conditional report generation). See CLAUDE.md for full workflow details.
|
|
28
|
-
|
|
29
|
-
## 🚀 START HERE
|
|
30
|
-
|
|
31
|
-
**CRITICAL**: Load the TUI Survey Skill FIRST before any user interaction:
|
|
32
|
-
|
|
33
|
-
```
|
|
34
|
-
AskUserQuestion tool (documented in moai-alfred-interactive-questions skill)
|
|
35
|
-
```
|
|
36
|
-
|
|
37
|
-
This Skill MUST be loaded at the very beginning to enable TUI menu rendering for AskUserQuestion calls throughout this workflow.
|
|
38
|
-
|
|
39
|
-
## 🎯 Command Purpose
|
|
40
|
-
|
|
41
|
-
Synchronize code changes to Living Documents and verify @TAG system to ensure complete traceability.
|
|
42
|
-
|
|
43
|
-
**Document sync to**: $ARGUMENTS
|
|
44
|
-
|
|
45
|
-
> **Standard two-step workflow** (see `CLAUDE.md` - "Alfred Command Execution Pattern" for details)
|
|
46
|
-
|
|
47
|
-
## 📋 Execution flow
|
|
48
|
-
|
|
49
|
-
**Phase 0: Skill Loading** (IMMEDIATE)
|
|
50
|
-
- Load `AskUserQuestion tool (documented in moai-alfred-interactive-questions skill)` at the very start
|
|
51
|
-
- This enables TUI menu rendering for all user interactions
|
|
52
|
-
|
|
53
|
-
**Phase 1: Analysis & Planning**
|
|
54
|
-
1. **Project status analysis**: Git changes and TAG system verification
|
|
55
|
-
2. **Determine the scope of synchronization**: Full/partial/selective synchronization strategy
|
|
56
|
-
3. **User Confirmation**: Review and approve synchronization plan via AskUserQuestion (TUI menu)
|
|
57
|
-
|
|
58
|
-
**Phase 2: Conditional Execution** (based on user choice)
|
|
59
|
-
4. **Document Synchronization**: Living Document updates and TAG integrity guaranteed (IF user selects "Proceed")
|
|
60
|
-
5. **Git operations**: Commit and PR state transitions via git-manager (IF user selects "Proceed")
|
|
61
|
-
- OR abort workflow (IF user selects "Abort")
|
|
62
|
-
- OR revise plan (IF user selects "Modify")
|
|
63
|
-
|
|
64
|
-
## 🧠 Associated Skills & Agents
|
|
65
|
-
|
|
66
|
-
| Agent | Core Skill | Purpose |
|
|
67
|
-
| ------------ | ------------------------------ | ------------------------------ |
|
|
68
|
-
| tag-agent | `moai-alfred-tag-scanning` | Verify TAG system integrity |
|
|
69
|
-
| quality-gate | `moai-alfred-trust-validation` | Check code quality before sync |
|
|
70
|
-
| doc-syncer | `moai-alfred-tag-scanning` | Synchronize Living Documents |
|
|
71
|
-
| git-manager | `moai-alfred-git-workflow` | Handle Git operations |
|
|
72
|
-
|
|
73
|
-
**Note**: TUI Survey Skill is loaded once at Phase 0 and reused throughout all user interactions.
|
|
74
|
-
|
|
75
|
-
## 🔗 Associated Agent
|
|
76
|
-
|
|
77
|
-
- **Phase 1**: quality-gate (🛡️ Quality Assurance Engineer) - Quality verification before synchronization (conditional)
|
|
78
|
-
- **Primary**: doc-syncer (📖 Technical Writer) - Dedicated to document synchronization
|
|
79
|
-
- **Secondary**: git-manager (🚀 Release Engineer) - Dedicated to Git commits/PR
|
|
80
|
-
|
|
81
|
-
## 💡 Example of use
|
|
82
|
-
|
|
83
|
-
Users can run the command as follows:
|
|
84
|
-
- `/alfred:3-sync` - Auto-sync (PR Ready only)
|
|
85
|
-
- `/alfred:3-sync --auto-merge` - PR auto-merge + branch cleanup
|
|
86
|
-
- `/alfred:3-sync force` - Force full synchronization
|
|
87
|
-
- `/alfred:3-sync status` - Check synchronization status
|
|
88
|
-
- `/alfred:3-sync project` - Integrated project synchronization
|
|
89
|
-
|
|
90
|
-
### 🚀 Fully automated GitFlow (--auto-merge)
|
|
91
|
-
|
|
92
|
-
**Automatically performs the following actions when used in Team mode**:
|
|
93
|
-
1. Document synchronization complete
|
|
94
|
-
2. Switch to PR Ready
|
|
95
|
-
3. Check CI/CD status
|
|
96
|
-
4. PR automatic merge (squash)
|
|
97
|
-
5. Develop checkout and synchronization
|
|
98
|
-
6. Organizing local feature branches
|
|
99
|
-
7. **Ready for next task** ✅
|
|
100
|
-
|
|
101
|
-
**Recommended use time**: When you want to complete the merge in one go after completing TDD implementation.
|
|
102
|
-
|
|
103
|
-
**Personal mode**: Automate local main/develop merges and branch cleanups
|
|
104
|
-
|
|
105
|
-
## 🔍 STEP 1: Analyze synchronization scope and establish plan
|
|
106
|
-
|
|
107
|
-
STEP 1 consists of **two independent phases** to provide flexible workflow based on project complexity:
|
|
108
|
-
|
|
109
|
-
### 📋 STEP 1 Workflow Overview
|
|
110
|
-
|
|
111
|
-
```
|
|
112
|
-
┌─────────────────────────────────────────────────────────────┐
|
|
113
|
-
│ STEP 1: Synchronization Analysis & Planning │
|
|
114
|
-
├─────────────────────────────────────────────────────────────┤
|
|
115
|
-
│ │
|
|
116
|
-
│ Phase A (OPTIONAL) │
|
|
117
|
-
│ ┌─────────────────────────────────────────┐ │
|
|
118
|
-
│ │ 🔍 Explore Agent │ │
|
|
119
|
-
│ │ • Navigate complex TAG chains │ │
|
|
120
|
-
│ │ • Scan entire TAG system │ │
|
|
121
|
-
│ │ • Identify orphan TAGs │ │
|
|
122
|
-
│ └─────────────────────────────────────────┘ │
|
|
123
|
-
│ ↓ │
|
|
124
|
-
│ (exploration results) │
|
|
125
|
-
│ ↓ │
|
|
126
|
-
│ Phase B (REQUIRED) │
|
|
127
|
-
│ ┌─────────────────────────────────────────┐ │
|
|
128
|
-
│ │ ⚙️ tag-agent + doc-syncer Agents │ │
|
|
129
|
-
│ │ • Verify TAG integrity (full project) │ │
|
|
130
|
-
│ │ • Analyze Git changes │ │
|
|
131
|
-
│ │ • Create synchronization plan │ │
|
|
132
|
-
│ │ • Request user approval │ │
|
|
133
|
-
│ └─────────────────────────────────────────┘ │
|
|
134
|
-
│ ↓ │
|
|
135
|
-
│ (user approval via AskUserQuestion) │
|
|
136
|
-
│ ↓ │
|
|
137
|
-
│ PROCEED TO STEP 2 │
|
|
138
|
-
└─────────────────────────────────────────────────────────────┘
|
|
139
|
-
```
|
|
140
|
-
|
|
141
|
-
**Key Points**:
|
|
142
|
-
- **Phase A is optional** - Skip for simple single-SPEC changes
|
|
143
|
-
- **Phase B is required** - Always runs to verify TAGs and plan sync
|
|
144
|
-
- **Results flow forward** - Exploration results (if any) are passed to tag-agent
|
|
145
|
-
- **⚠️ Important**: tag-agent verifies ENTIRE PROJECT, not just changed files
|
|
146
|
-
|
|
147
|
-
---
|
|
148
|
-
|
|
149
|
-
### 🔍 Phase A: TAG Chain Navigation (OPTIONAL)
|
|
150
|
-
|
|
151
|
-
**Use the Explore agent for complex or extensive TAG chains.**
|
|
152
|
-
|
|
153
|
-
#### When to use Phase A:
|
|
154
|
-
|
|
155
|
-
- ✅ Large projects (100+ files)
|
|
156
|
-
- ✅ Need comprehensive TAG chain integrity verification
|
|
157
|
-
- ✅ Changes span multiple SPECs or modules
|
|
158
|
-
- ❌ Simple changes to a single SPEC (skip to Phase B)
|
|
159
|
-
|
|
160
|
-
#### How to invoke Explore agent:
|
|
161
|
-
|
|
162
|
-
```
|
|
163
|
-
Invoking the Task tool (Explore agent):
|
|
164
|
-
- subagent_type: "Explore"
|
|
165
|
-
- description: "Scan entire TAG system"
|
|
166
|
-
- prompt: "프로젝트 전체에서 @TAG 시스템을 스캔해주세요:
|
|
167
|
-
- @SPEC TAG 위치 (.moai/specs/)
|
|
168
|
-
- @TEST TAG 위치 (tests/)
|
|
169
|
-
- @CODE TAG 위치 (src/)
|
|
170
|
-
- @DOC TAG 위치 (docs/)
|
|
171
|
-
- 고아 TAG 및 끊긴 참조 감지
|
|
172
|
-
상세도 수준: very thorough"
|
|
173
|
-
```
|
|
174
|
-
|
|
175
|
-
**Note**: For simple changes, skip Phase A and proceed directly to Phase B.
|
|
176
|
-
|
|
177
|
-
---
|
|
178
|
-
|
|
179
|
-
### ⚙️ Phase B: TAG Verification & Sync Planning (REQUIRED)
|
|
180
|
-
|
|
181
|
-
**Call tag-agent and doc-syncer to verify TAG integrity and plan synchronization.**
|
|
182
|
-
|
|
183
|
-
This phase is **always required** and runs **two agents sequentially**:
|
|
184
|
-
|
|
185
|
-
#### How to invoke agents:
|
|
186
|
-
|
|
187
|
-
```
|
|
188
|
-
1. Tag-agent call (TAG verification - FULL PROJECT SCOPE):
|
|
189
|
-
- subagent_type: "tag-agent"
|
|
190
|
-
- description: "Verify TAG system across entire project"
|
|
191
|
-
- prompt: "전체 프로젝트에서 포괄적인 @TAG 시스템 검증을 수행해주세요.
|
|
192
|
-
|
|
193
|
-
**필수 범위**: 변경된 파일만이 아니라 모든 소스 파일을 스캔합니다.
|
|
194
|
-
|
|
195
|
-
**검증 항목**:
|
|
196
|
-
1. .moai/specs/ 디렉토리의 @SPEC TAG
|
|
197
|
-
2. tests/ 디렉토리의 @TEST TAG
|
|
198
|
-
3. src/ 디렉토리의 @CODE TAG
|
|
199
|
-
4. docs/ 디렉토리의 @DOC TAG
|
|
200
|
-
|
|
201
|
-
**고아 감지** (필수):
|
|
202
|
-
- 매칭되는 @SPEC이 없는 @CODE TAG 감지
|
|
203
|
-
- 매칭되는 @CODE가 없는 @SPEC TAG 감지
|
|
204
|
-
- 매칭되는 @SPEC이 없는 @TEST TAG 감지
|
|
205
|
-
- 매칭되는 @SPEC/@CODE가 없는 @DOC TAG 감지
|
|
206
|
-
|
|
207
|
-
**출력 형식**: 고아 TAG의 전체 목록을 위치와 함께 제공합니다.
|
|
208
|
-
|
|
209
|
-
(선택사항) 탐색 결과: $EXPLORE_RESULTS"
|
|
210
|
-
|
|
211
|
-
2. doc-syncer call (synchronization plan):
|
|
212
|
-
- subagent_type: "doc-syncer"
|
|
213
|
-
- description: "Establish a document synchronization plan"
|
|
214
|
-
- prompt: """당신은 doc-syncer 에이전트입니다.
|
|
215
|
-
|
|
216
|
-
언어 설정:
|
|
217
|
-
- 대화_언어: {{CONVERSATION_LANGUAGE}}
|
|
218
|
-
- 언어명: {{CONVERSATION_LANGUAGE_NAME}}
|
|
219
|
-
|
|
220
|
-
중요 지시사항:
|
|
221
|
-
문서 업데이트는 대화_언어를 반드시 존중해야 합니다:
|
|
222
|
-
- 사용자 대면 문서 (README, 가이드): {{CONVERSATION_LANGUAGE}}
|
|
223
|
-
- SPEC 문서 (spec.md, plan.md, acceptance.md): {{CONVERSATION_LANGUAGE}}
|
|
224
|
-
- 코드 주석: {{CONVERSATION_LANGUAGE}} (기술 키워드 제외)
|
|
225
|
-
- 기술 문서 및 YAML 프론트매터: 영어
|
|
226
|
-
|
|
227
|
-
스킬 호출:
|
|
228
|
-
필요 시 명시적 Skill() 호출 사용:
|
|
229
|
-
- Skill("moai-foundation-tags") - TAG 체인 검증
|
|
230
|
-
- Skill("moai-foundation-trust") - 품질 게이트 검사
|
|
231
|
-
- Skill("moai-alfred-tag-scanning") - TAG 인벤토리 업데이트
|
|
232
|
-
|
|
233
|
-
작업:
|
|
234
|
-
Git 변경사항을 분석하고 문서 동기화 계획을 수립해주세요.
|
|
235
|
-
모든 문서 업데이트가 대화_언어 설정과 일치하는지 확인합니다.
|
|
236
|
-
|
|
237
|
-
$ARGUMENTS
|
|
238
|
-
(선택사항) TAG 검증 결과: $TAG_VALIDATION_RESULTS"""
|
|
239
|
-
```
|
|
240
|
-
|
|
241
|
-
**Note**:
|
|
242
|
-
- **Sequential execution**: Run tag-agent first, then doc-syncer
|
|
243
|
-
- **Results flow**: TAG validation results from tag-agent are passed to doc-syncer via `$TAG_VALIDATION_RESULTS`
|
|
244
|
-
- **Phase A results**: If Phase A was executed, exploration results are passed to tag-agent via `$EXPLORE_RESULTS`
|
|
245
|
-
|
|
246
|
-
---
|
|
247
|
-
|
|
248
|
-
### Synchronization analysis in progress
|
|
249
|
-
|
|
250
|
-
1. **Check project status**
|
|
251
|
-
- Git status and changed file list
|
|
252
|
-
- Code-document consistency check
|
|
253
|
-
- @TAG system verification (using tag-agent or Explore)
|
|
254
|
-
- (Optional) Extensive TAG scan based on Explore results
|
|
255
|
-
|
|
256
|
-
2. **Determine the scope of synchronization**
|
|
257
|
-
- Living Document area requiring update
|
|
258
|
-
- TAG index need to be updated
|
|
259
|
-
- PR status transition possibility (team mode)
|
|
260
|
-
|
|
261
|
-
3. **Establish a synchronization strategy**
|
|
262
|
-
- Synchronization approach for each mode
|
|
263
|
-
- Estimated work time and priorities
|
|
264
|
-
- Identify potential risks
|
|
265
|
-
|
|
266
|
-
### Phase 1 Details: Quality pre-verification (conditional automatic execution)
|
|
267
|
-
|
|
268
|
-
Quickly check code quality before synchronization.
|
|
269
|
-
|
|
270
|
-
**Differences from Phase 3 (2-build)**:
|
|
271
|
-
- **Phase 3**: In-depth verification after completion of TDD implementation (test coverage, code quality, security)
|
|
272
|
-
- **Phase 1**: Quick scan before synchronization (file corruption, critical issues only)
|
|
273
|
-
|
|
274
|
-
**Purpose**: Prevent documentation of code with quality issues
|
|
275
|
-
|
|
276
|
-
**Execution conditions (automatic judgment)**:
|
|
277
|
-
- Check the number of code change lines with Git diff
|
|
278
|
-
- Changed lines > 50 lines: Automatically run
|
|
279
|
-
- Changed lines ≤ 50 lines: Skip
|
|
280
|
-
- Change only document: Skip
|
|
281
|
-
|
|
282
|
-
**Verification items**:
|
|
283
|
-
- **Verify only changed files**: File targets verified by Git diff
|
|
284
|
-
- **TRUST principle verification**: Run trust-checker script
|
|
285
|
-
- **Code style**: Run linter (changed files only)
|
|
286
|
-
- **TAG chain**: Verify changed TAG integrity
|
|
287
|
-
|
|
288
|
-
**How it works**:
|
|
289
|
-
Alfred automatically calls the quality-gate agent when there are a lot of code changes to perform quick quality verification before document synchronization.
|
|
290
|
-
|
|
291
|
-
**Handling verification results**:
|
|
292
|
-
|
|
293
|
-
✅ **PASS (0 Critical)**: Synchronization in progress
|
|
294
|
-
|
|
295
|
-
⚠️ **WARNING (0 Critical, Warning included)**: Synchronization proceeds after displaying warning.
|
|
296
|
-
|
|
297
|
-
❌ **CRITICAL (1 or more Critical)**: Synchronization stopped, correction recommended
|
|
298
|
-
- Critical issue found: Synchronization stopped, correction recommended
|
|
299
|
-
- User selection: “Retry after modification” or “Force proceed”
|
|
300
|
-
|
|
301
|
-
**Skip verification option**:
|
|
302
|
-
To skip pre-verification, use the `/alfred:3-sync --skip-pre-check` option.
|
|
303
|
-
|
|
304
|
-
---
|
|
305
|
-
|
|
306
|
-
### User verification steps
|
|
307
|
-
|
|
308
|
-
After reviewing your sync plan, `AskUserQuestion tool (documented in moai-alfred-interactive-questions skill)` presents the following options for user decision:
|
|
309
|
-
- **"Proceed"** or **"Start"**: Start synchronization as planned
|
|
310
|
-
- **"Modify [Contents]"**: Request modifications to your sync plan
|
|
311
|
-
- **"Abort"**: Abort the sync operation
|
|
312
|
-
|
|
313
|
-
---
|
|
314
|
-
|
|
315
|
-
## 🚀 STEP 2: Execute document synchronization (after user approval)
|
|
316
|
-
|
|
317
|
-
After user approval (collected via `AskUserQuestion tool (documented in moai-alfred-interactive-questions skill)`), the doc-syncer agent performs **Living Document synchronization and @TAG updates**, and optionally executes PR Ready transitions only in team mode.
|
|
318
|
-
|
|
319
|
-
---
|
|
320
|
-
|
|
321
|
-
### 2.0.5 Domain-Based Sync Routing (Automatic - During Sync)
|
|
322
|
-
|
|
323
|
-
**Purpose**: Route documentation sync to domain-specific experts based on changed files
|
|
324
|
-
|
|
325
|
-
**When to run**: During doc-syncer execution, after analyzing git changes
|
|
326
|
-
|
|
327
|
-
**Detection Logic**:
|
|
328
|
-
|
|
329
|
-
Alfred analyzes changed files to determine which domains were modified:
|
|
330
|
-
|
|
331
|
-
```bash
|
|
332
|
-
# Get list of changed files
|
|
333
|
-
git diff --name-only HEAD~1 HEAD
|
|
334
|
-
|
|
335
|
-
# Domain detection by file patterns
|
|
336
|
-
```
|
|
337
|
-
|
|
338
|
-
**File Pattern → Domain Mapping**:
|
|
339
|
-
|
|
340
|
-
| File Patterns | Domain | Sync Focus |
|
|
341
|
-
|---------------|--------|-----------|
|
|
342
|
-
| `src/components/*`, `src/pages/*`, `*.tsx`, `*.jsx`, `*.vue` | Frontend | Component documentation, Storybook, UI architecture |
|
|
343
|
-
| `src/api/*`, `src/models/*`, `src/routes/*`, `src/services/*` | Backend | API documentation (OpenAPI), schema docs, error handling |
|
|
344
|
-
| `Dockerfile`, `docker-compose.yml`, `.github/workflows/*`, `terraform/*`, `k8s/*` | DevOps | Deployment docs, CI/CD status, infrastructure diagrams |
|
|
345
|
-
| `src/database/*`, `migrations/*`, `*.sql`, `schema/*` | Database | Schema documentation, migration logs, query optimization |
|
|
346
|
-
| `notebooks/*`, `src/pipelines/*`, `*.ipynb`, `src/models/ml/*` | Data Science | Pipeline documentation, model cards, data validation |
|
|
347
|
-
| `src/mobile/*`, `ios/*`, `android/*`, `*.swift`, `*.kt` | Mobile | Platform-specific docs, app lifecycle, native modules |
|
|
348
|
-
|
|
349
|
-
**Automatic Invocation Pattern**:
|
|
350
|
-
|
|
351
|
-
```python
|
|
352
|
-
# Pseudo-code for domain detection from git changes
|
|
353
|
-
changed_files = git_diff("HEAD~1", "HEAD")
|
|
354
|
-
|
|
355
|
-
detected_domains = []
|
|
356
|
-
if any(".tsx" in f or ".jsx" in f or "src/components/" in f for f in changed_files):
|
|
357
|
-
detected_domains.append("frontend")
|
|
358
|
-
if any("src/api/" in f or "src/models/" in f or "src/routes/" in f for f in changed_files):
|
|
359
|
-
detected_domains.append("backend")
|
|
360
|
-
if any("Dockerfile" in f or ".github/workflows/" in f or "docker-compose" in f for f in changed_files):
|
|
361
|
-
detected_domains.append("devops")
|
|
362
|
-
# ... repeat for all domains
|
|
363
|
-
|
|
364
|
-
# Invoke domain-specific sync for each detected domain
|
|
365
|
-
for domain in detected_domains:
|
|
366
|
-
Task(
|
|
367
|
-
subagent_type="Explore",
|
|
368
|
-
prompt=f"Generate domain-specific sync report for {domain} changes"
|
|
369
|
-
)
|
|
370
|
-
```
|
|
371
|
-
|
|
372
|
-
**Example Invocation** (Frontend + Backend detected):
|
|
373
|
-
|
|
374
|
-
```python
|
|
375
|
-
# Frontend sync
|
|
376
|
-
Task(
|
|
377
|
-
subagent_type="Explore",
|
|
378
|
-
prompt="""You are frontend-expert providing sync documentation.
|
|
379
|
-
|
|
380
|
-
Changed Files: [src/components/Dashboard.tsx, src/pages/Home.vue]
|
|
381
|
-
|
|
382
|
-
Provide frontend-specific documentation:
|
|
383
|
-
1. Component documentation updates
|
|
384
|
-
2. Storybook story generation
|
|
385
|
-
3. UI architecture diagram updates
|
|
386
|
-
4. Accessibility compliance notes
|
|
387
|
-
|
|
388
|
-
Output format: Markdown document for .moai/reports/sync-frontend.md"""
|
|
389
|
-
)
|
|
390
|
-
|
|
391
|
-
# Backend sync
|
|
392
|
-
Task(
|
|
393
|
-
subagent_type="Explore",
|
|
394
|
-
prompt="""You are backend-expert providing sync documentation.
|
|
395
|
-
|
|
396
|
-
Changed Files: [src/api/auth.py, src/models/user.py, src/routes/users.py]
|
|
397
|
-
|
|
398
|
-
Provide backend-specific documentation:
|
|
399
|
-
1. OpenAPI spec generation
|
|
400
|
-
2. Schema documentation updates
|
|
401
|
-
3. Error handling documentation
|
|
402
|
-
4. API endpoint examples
|
|
403
|
-
|
|
404
|
-
Output format: Markdown document for .moai/reports/sync-backend.md"""
|
|
405
|
-
)
|
|
406
|
-
```
|
|
407
|
-
|
|
408
|
-
**Output Storage Structure**:
|
|
409
|
-
|
|
410
|
-
```
|
|
411
|
-
.moai/reports/
|
|
412
|
-
├── sync-report-2025-10-23.md # Combined sync report
|
|
413
|
-
├── sync-frontend-2025-10-23.md # Frontend-specific sync
|
|
414
|
-
├── sync-backend-2025-10-23.md # Backend-specific sync
|
|
415
|
-
└── sync-devops-2025-10-23.md # DevOps-specific sync
|
|
416
|
-
```
|
|
417
|
-
|
|
418
|
-
**Combined Sync Report Format**:
|
|
419
|
-
|
|
420
|
-
```markdown
|
|
421
|
-
## 📚 Documentation Sync Report - 2025-10-23
|
|
422
|
-
|
|
423
|
-
### Changed Files Summary
|
|
424
|
-
- Frontend: 3 files (components, pages)
|
|
425
|
-
- Backend: 5 files (api, models, routes)
|
|
426
|
-
- DevOps: 1 file (Dockerfile)
|
|
427
|
-
|
|
428
|
-
### Domain-Specific Sync Results
|
|
429
|
-
|
|
430
|
-
#### 🎨 Frontend Sync
|
|
431
|
-
- ✅ Component documentation: Dashboard.tsx documented
|
|
432
|
-
- ✅ Storybook stories: 2 stories generated
|
|
433
|
-
- ✅ UI architecture: Component hierarchy diagram updated
|
|
434
|
-
- 📄 Details: [sync-frontend-2025-10-23.md](./sync-frontend-2025-10-23.md)
|
|
435
|
-
|
|
436
|
-
#### ⚙️ Backend Sync
|
|
437
|
-
- ✅ OpenAPI spec: /api/auth endpoints documented
|
|
438
|
-
- ✅ Schema documentation: User model fields updated
|
|
439
|
-
- ✅ Error handling: 401/403 response examples added
|
|
440
|
-
- 📄 Details: [sync-backend-2025-10-23.md](./sync-backend-2025-10-23.md)
|
|
441
|
-
|
|
442
|
-
#### 🚀 DevOps Sync
|
|
443
|
-
- ✅ Dockerfile: Multi-stage build documented
|
|
444
|
-
- ✅ Deployment: Railway configuration updated
|
|
445
|
-
- 📄 Details: [sync-devops-2025-10-23.md](./sync-devops-2025-10-23.md)
|
|
446
|
-
|
|
447
|
-
### @TAG Verification
|
|
448
|
-
- ✅ All changed files have @TAG references
|
|
449
|
-
- ✅ SPEC → CODE → TEST → DOC chain intact
|
|
450
|
-
|
|
451
|
-
### Next Steps
|
|
452
|
-
- Review domain-specific sync reports
|
|
453
|
-
- Update README.md with new features
|
|
454
|
-
- Create PR for documentation changes
|
|
455
|
-
```
|
|
456
|
-
|
|
457
|
-
**Integration with doc-syncer**:
|
|
458
|
-
|
|
459
|
-
```python
|
|
460
|
-
# doc-syncer orchestrates domain-specific sync
|
|
461
|
-
Task(
|
|
462
|
-
subagent_type="doc-syncer",
|
|
463
|
-
prompt="""You are doc-syncer agent.
|
|
464
|
-
|
|
465
|
-
DOMAIN SYNC RESULTS:
|
|
466
|
-
{domain_sync_results}
|
|
467
|
-
|
|
468
|
-
Consolidate all domain-specific sync reports into master sync report.
|
|
469
|
-
Ensure @TAG chain integrity across all domains.
|
|
470
|
-
Update .moai/reports/sync-report-{date}.md
|
|
471
|
-
|
|
472
|
-
$ARGUMENTS"""
|
|
473
|
-
)
|
|
474
|
-
```
|
|
475
|
-
|
|
476
|
-
**Graceful Degradation**:
|
|
477
|
-
- If no domain detected → Standard sync (no domain-specific reports)
|
|
478
|
-
- If domain expert unavailable → Use generic sync templates
|
|
479
|
-
- Multi-domain changes → Generate separate reports, combine into master
|
|
480
|
-
|
|
481
|
-
---
|
|
482
|
-
|
|
483
|
-
### Phase 2 Details: SPEC Completion Processing (Automatic)
|
|
484
|
-
|
|
485
|
-
The doc-syncer agent automatically determines whether TDD implementation is complete and updates SPEC metadata.
|
|
486
|
-
|
|
487
|
-
**Automatic update conditions**:
|
|
488
|
-
- SPEC with status `draft`
|
|
489
|
-
- RED → GREEN → REFACTOR commit exists
|
|
490
|
-
- @TEST and @CODE TAG exist
|
|
491
|
-
|
|
492
|
-
**Update details**:
|
|
493
|
-
- `status: draft` → `status: completed`
|
|
494
|
-
- `version: 0.0.x` → `version: 0.1.0`
|
|
495
|
-
- Automatic addition of HISTORY section
|
|
496
|
-
|
|
497
|
-
**If conditions are not met**: Phase 2 detailed work is automatically skipped
|
|
498
|
-
|
|
499
|
-
---
|
|
500
|
-
|
|
501
|
-
### Phase 2-1: SPEC Document Synchronization (CRITICAL)
|
|
502
|
-
|
|
503
|
-
**IMPORTANT**: Any code or file changes MUST be reflected in SPEC documents to maintain specification alignment.
|
|
504
|
-
|
|
505
|
-
#### When to synchronize SPEC documents:
|
|
506
|
-
|
|
507
|
-
1. **After code modifications**:
|
|
508
|
-
- Functional changes to implemented features
|
|
509
|
-
- Bug fixes that alter expected behavior
|
|
510
|
-
- Performance optimizations with observable changes
|
|
511
|
-
- API/function signature changes
|
|
512
|
-
- New dependencies or external integrations
|
|
513
|
-
|
|
514
|
-
2. **After requirement clarifications**:
|
|
515
|
-
- Acceptance criteria refinements
|
|
516
|
-
- Edge case discoveries during implementation
|
|
517
|
-
- User feedback incorporation
|
|
518
|
-
- Security/compliance adjustments
|
|
519
|
-
|
|
520
|
-
3. **After structural changes**:
|
|
521
|
-
- File organization or module restructuring
|
|
522
|
-
- New configuration options
|
|
523
|
-
- Breaking API changes
|
|
524
|
-
- Database schema modifications
|
|
525
|
-
|
|
526
|
-
#### SPEC documents requiring update:
|
|
527
|
-
|
|
528
|
-
All files in `.moai/specs/SPEC-{ID}/` must be synchronized:
|
|
529
|
-
|
|
530
|
-
- **spec.md**: Update EARS requirements if implementation differs from specification
|
|
531
|
-
- **plan.md**: Revise implementation strategy if approach changed
|
|
532
|
-
- **acceptance.md**: Update acceptance criteria if new test cases or edge cases discovered
|
|
533
|
-
|
|
534
|
-
#### Synchronization rules:
|
|
535
|
-
|
|
536
|
-
**Code ↔ SPEC Comparison**:
|
|
537
|
-
```
|
|
538
|
-
1. Review Git diff for changed files
|
|
539
|
-
2. Identify functional impacts:
|
|
540
|
-
├─ Signature changes (parameters, return values)
|
|
541
|
-
├─ Behavior changes (logic flow, edge cases)
|
|
542
|
-
├─ Performance characteristics (latency, throughput changes)
|
|
543
|
-
└─ External dependencies (new APIs, services)
|
|
544
|
-
3. Map changes to SPEC requirements:
|
|
545
|
-
├─ Verify each changed function matches EARS statement
|
|
546
|
-
├─ Check if acceptance criteria still valid
|
|
547
|
-
└─ Identify any spec-to-code divergence
|
|
548
|
-
4. Update SPEC documents:
|
|
549
|
-
├─ Correct EARS statements to match actual implementation
|
|
550
|
-
├─ Add discovered edge cases to acceptance criteria
|
|
551
|
-
├─ Update plan.md with implementation changes
|
|
552
|
-
└─ Maintain TAG references (@SPEC, @CODE, @TEST consistency)
|
|
553
|
-
```
|
|
554
|
-
|
|
555
|
-
#### Example: When synchronization is needed
|
|
556
|
-
|
|
557
|
-
**Scenario 1: Bug Fix Changes Behavior**
|
|
558
|
-
```
|
|
559
|
-
Git change: Fixed database connection retry logic
|
|
560
|
-
- Was: Max 3 retries with 1-second delay
|
|
561
|
-
- Now: Max 5 retries with exponential backoff
|
|
562
|
-
|
|
563
|
-
SPEC update required:
|
|
564
|
-
- spec.md: Update EARS statement for retry behavior
|
|
565
|
-
- acceptance.md: Add test case for exponential backoff
|
|
566
|
-
- Update @CODE TAG location if function moved
|
|
567
|
-
```
|
|
568
|
-
|
|
569
|
-
**Scenario 2: API Signature Changes**
|
|
570
|
-
```
|
|
571
|
-
Git change: Refactored authentication function signature
|
|
572
|
-
- Was: validate_token(token: str) -> bool
|
|
573
|
-
- Now: validate_token(token: str, ttl: int = 3600) -> dict
|
|
574
|
-
|
|
575
|
-
SPEC update required:
|
|
576
|
-
- spec.md: Update function requirements for new TTL parameter
|
|
577
|
-
- acceptance.md: Add test cases for TTL validation
|
|
578
|
-
- plan.md: Document reason for signature change
|
|
579
|
-
```
|
|
580
|
-
|
|
581
|
-
**Scenario 3: New Edge Cases Discovered**
|
|
582
|
-
```
|
|
583
|
-
Git change: Added null-check validation during testing
|
|
584
|
-
- Discovered: Special handling needed for empty strings
|
|
585
|
-
|
|
586
|
-
SPEC update required:
|
|
587
|
-
- spec.md: Add EARS statement for empty string edge case
|
|
588
|
-
- acceptance.md: Add test case for empty string handling
|
|
589
|
-
- Link with @TEST TAG from test file
|
|
590
|
-
```
|
|
591
|
-
|
|
592
|
-
#### SPEC-Code Divergence Detection:
|
|
593
|
-
|
|
594
|
-
**Anti-pattern: Code without matching SPEC**
|
|
595
|
-
```
|
|
596
|
-
❌ WRONG: Code changes exist but SPEC documents unchanged
|
|
597
|
-
- Function behavior diverges from specification
|
|
598
|
-
- Acceptance criteria becomes inaccurate
|
|
599
|
-
- @TAG chain breaks (CODE exists without matching SPEC reference)
|
|
600
|
-
|
|
601
|
-
✅ CORRECT: Code changes synchronized to SPEC
|
|
602
|
-
- SPEC documents updated to match implementation
|
|
603
|
-
- All EARS statements verified against actual code
|
|
604
|
-
- @TAG chain maintained: SPEC ↔ CODE ↔ TEST ↔ DOC
|
|
605
|
-
```
|
|
606
|
-
|
|
607
|
-
#### SPEC Synchronization Checklist (doc-syncer responsibility):
|
|
608
|
-
|
|
609
|
-
Before marking sync as complete:
|
|
610
|
-
- [ ] All changed code files reviewed against SPEC
|
|
611
|
-
- [ ] EARS statements match implementation behavior
|
|
612
|
-
- [ ] Acceptance criteria valid for current code
|
|
613
|
-
- [ ] Edge cases discovered during implementation added to SPEC
|
|
614
|
-
- [ ] @CODE/@TEST TAGs point to correct locations
|
|
615
|
-
- [ ] @SPEC TAG references updated if files reorganized
|
|
616
|
-
- [ ] HISTORY section updated if version changed
|
|
617
|
-
- [ ] No spec-code divergence remains
|
|
618
|
-
|
|
619
|
-
---
|
|
620
|
-
|
|
621
|
-
## function
|
|
622
|
-
|
|
623
|
-
- **Automatic Document Synchronization**: The doc-syncer agent performs Living Document synchronization and @TAG updates. Optionally implements the PR Ready transition only in team mode.
|
|
624
|
-
- **SPEC-Code Alignment**: doc-syncer verifies that SPEC documents match implemented code and updates them when changes are detected.
|
|
625
|
-
|
|
626
|
-
## Synchronization output
|
|
627
|
-
|
|
628
|
-
- `.moai/reports/sync-report.md` creation/update
|
|
629
|
-
- TAG chain verification: Direct code scan (`rg '@TAG' -n src/ tests/`)
|
|
630
|
-
|
|
631
|
-
## Execution method by mode
|
|
632
|
-
|
|
633
|
-
## 📋 STEP 1 Implementation Guide: Analyzing the scope of synchronization and establishing a plan
|
|
634
|
-
|
|
635
|
-
### 1. Project status analysis
|
|
636
|
-
|
|
637
|
-
Alfred calls the doc-syncer agent to analyze synchronization targets and scopes.
|
|
638
|
-
|
|
639
|
-
#### Analysis Checklist
|
|
640
|
-
|
|
641
|
-
- [ ] **Git status**: Changed files, branch status, commit history
|
|
642
|
-
- [ ] **Document consistency**: Need for code-to-document synchronization
|
|
643
|
-
- [ ] **TAG system**: @TAG scheme verification and broken links
|
|
644
|
-
- [ ] **Sync scope**: Full vs partial vs specific path synchronization
|
|
645
|
-
|
|
646
|
-
### 2. Determine synchronization strategy
|
|
647
|
-
|
|
648
|
-
#### Mode-specific synchronization approach
|
|
649
|
-
|
|
650
|
-
| mode | Synchronization range | PR processing | Key Features |
|
|
651
|
-
| ------------ | ------------------------------- | ---------------------- | ---------------------- |
|
|
652
|
-
| **Personal** | Local document synchronization | checkpoint only | Focus on personal work |
|
|
653
|
-
| **Team** | Full Sync + TAG | PR Ready conversion | Collaboration support |
|
|
654
|
-
| **Auto** | Intelligent automatic selection | Decisions by situation | Optimal strategy |
|
|
655
|
-
| **Force** | Force full sync | Full regeneration | For error recovery |
|
|
656
|
-
|
|
657
|
-
#### Expected scope of work
|
|
658
|
-
|
|
659
|
-
- **Living Document**: API documentation, README, architecture document
|
|
660
|
-
- **TAG index**: Update `.moai/indexes/tags.db`
|
|
661
|
-
- **Sync report**: `.moai/reports/sync-report.md`
|
|
662
|
-
- **PR status**: Draft → Ready for Review transition
|
|
663
|
-
|
|
664
|
-
### 3. Generate synchronization plan report
|
|
665
|
-
|
|
666
|
-
Present your plan in the following format:
|
|
667
|
-
|
|
668
|
-
```
|
|
669
|
-
## Document Synchronization Plan Report: [TARGET]
|
|
670
|
-
|
|
671
|
-
### 📊 Health Analysis Results
|
|
672
|
-
- **Changed Files**: [Number and Type]
|
|
673
|
-
- **Synchronization Required**: [High/Medium/Low]
|
|
674
|
-
- **TAG System Status**: [Healthy/Problem Detected]
|
|
675
|
-
|
|
676
|
-
### 🎯 Sync Strategy
|
|
677
|
-
- **Selected Mode**: [auto/force/status/project]
|
|
678
|
-
- **Sync Scope**: [Full/Partial/Selective]
|
|
679
|
-
- **PR Handling**: [Maintain/Switch Ready/Create New PR]
|
|
680
|
-
|
|
681
|
-
### ⚠️ Notes
|
|
682
|
-
- **Potential conflicts**: [Possible document conflicts]
|
|
683
|
-
- **TAG issues**: [Broken links, duplicate TAGs]
|
|
684
|
-
- **Performance impact**: [Estimated time for large synchronization]
|
|
685
|
-
|
|
686
|
-
### ✅ Expected deliverables
|
|
687
|
-
- **sync-report.md**: [Summary of sync results]
|
|
688
|
-
- **tags.db**: [Updated TAG index]
|
|
689
|
-
- **Living Documents**: [Updated document list]
|
|
690
|
-
- **PR Status**: [PR transition in team mode]
|
|
691
|
-
|
|
692
|
-
---
|
|
693
|
-
**Approval Request**: Do you want to proceed with synchronization using the above plan?
|
|
694
|
-
(select “Proceed”, “Modify [Content]”, or “Abort”)
|
|
695
|
-
```
|
|
696
|
-
|
|
697
|
-
---
|
|
698
|
-
|
|
699
|
-
## 🚀 STEP 2 Implementation Guide: Document Synchronization (After Approval)
|
|
700
|
-
|
|
701
|
-
Only when the user selects **"Proceed"** or **"Start"** will Alfred call the doc-syncer agent to perform Living Document synchronization and TAG updates.
|
|
702
|
-
|
|
703
|
-
### Sync step-by-step guide
|
|
704
|
-
|
|
705
|
-
1. **Living Document Synchronization**: Code → Document automatically reflected
|
|
706
|
-
2. **TAG System Verification**: @TAG System Integrity Verification
|
|
707
|
-
3. **Index Update**: Traceability Matrix Update
|
|
708
|
-
4. **Create Report**: Create a summary of synchronization results
|
|
709
|
-
|
|
710
|
-
### Agent collaboration structure
|
|
711
|
-
|
|
712
|
-
- **Step 1**: The `doc-syncer` agent is dedicated to Living Document synchronization and @TAG management.
|
|
713
|
-
- **Step 2**: The `git-manager` agent is dedicated to all Git commits, PR state transitions, and synchronization.
|
|
714
|
-
- **Single Responsibility Principle**: doc-syncer only performs document tasks, and git-manager only performs Git tasks.
|
|
715
|
-
- **Sequential execution**: Executes in the order doc-syncer → git-manager to maintain clear dependencies.
|
|
716
|
-
- **No inter-agent calls**: Each agent does not directly call other agents, and executes commands. Runs sequentially in levels only.
|
|
717
|
-
|
|
718
|
-
## 🚀 Optimized parallel/sequential hybrid workflow
|
|
719
|
-
|
|
720
|
-
### Phase 1: Quick status check (parallel execution)
|
|
721
|
-
|
|
722
|
-
Do the following **simultaneously**:
|
|
723
|
-
|
|
724
|
-
```
|
|
725
|
-
Task 1 (haiku): Check Git status
|
|
726
|
-
├── Collect list of changed files
|
|
727
|
-
├── Check branch status
|
|
728
|
-
└── Determine need for synchronization
|
|
729
|
-
|
|
730
|
-
Task 2 (sonnet): Analyze document structure
|
|
731
|
-
├── Detect project type
|
|
732
|
-
├── Collect TAG list
|
|
733
|
-
└── Determine synchronization scope
|
|
734
|
-
```
|
|
735
|
-
|
|
736
|
-
### Phase 2: Document synchronization (sequential execution)
|
|
737
|
-
|
|
738
|
-
The `doc-syncer` agent (sonnet) handles intensive processing:
|
|
739
|
-
|
|
740
|
-
- Living Document synchronization
|
|
741
|
-
- @TAG system verification and update
|
|
742
|
-
- Document-code consistency check
|
|
743
|
-
- TAG traceability matrix update
|
|
744
|
-
|
|
745
|
-
### Phase 3: Git task processing (sequential execution)
|
|
746
|
-
|
|
747
|
-
Final processing by the `git-manager` agent (haiku):
|
|
748
|
-
|
|
749
|
-
- Commit document changes
|
|
750
|
-
- Apply synchronization strategy for each mode
|
|
751
|
-
- Switch PR Ready in Team mode
|
|
752
|
-
- Automatically assign reviewers (using gh CLI)
|
|
753
|
-
|
|
754
|
-
### Phase 4: PR merge and branch cleanup (optional)
|
|
755
|
-
|
|
756
|
-
Additional processing by `git-manager` when using the `--auto-merge` flag:
|
|
757
|
-
|
|
758
|
-
**Team mode (GitFlow)**:
|
|
759
|
-
1. Check PR status (CI/CD pass check)
|
|
760
|
-
2. PR automatic merge (to develop branch)
|
|
761
|
-
3. Delete remote feature branch
|
|
762
|
-
4. Local develop checkout and synchronization
|
|
763
|
-
5. Organizing local feature branches
|
|
764
|
-
6. Notification that the next task is ready
|
|
765
|
-
|
|
766
|
-
**Personal Mode**:
|
|
767
|
-
1. Local main/develop merge
|
|
768
|
-
2. Delete feature branch
|
|
769
|
-
3. Check out the base branch
|
|
770
|
-
4. Notification that the next task is ready
|
|
771
|
-
|
|
772
|
-
**Performance improvements**: Minimize latency by parallelizing the initial verification step
|
|
773
|
-
|
|
774
|
-
### Argument handling
|
|
775
|
-
|
|
776
|
-
- **$1 (mode)**: `$1` → `auto` (default)|`force`|`status`|`project`
|
|
777
|
-
- **$2 (path)**: `$2` → Sync target path (optional)
|
|
778
|
-
- **flags**:
|
|
779
|
-
- `--auto-merge`: Enable PR automatic merge and branch cleanup (Team mode)
|
|
780
|
-
- `--skip-pre-check`: Skip pre-quality check
|
|
781
|
-
- `--skip-quality-check`: Skip final quality check
|
|
782
|
-
|
|
783
|
-
**Command usage example**:
|
|
784
|
-
- `/alfred:3-sync` - Basic automatic synchronization (optimized by mode)
|
|
785
|
-
- `/alfred:3-sync --auto-merge` - PR automatic merge + branch cleanup (Team mode recommended)
|
|
786
|
-
- `/alfred:3-sync force` - Force full synchronization
|
|
787
|
-
- `/alfred:3-sync status` - Check synchronization status
|
|
788
|
-
- `/alfred:3-sync project` - Integrated project synchronization
|
|
789
|
-
- `/alfred:3-sync auto src/auth/` - Specific path Synchronization
|
|
790
|
-
- `/alfred:3-sync --auto-merge --skip-pre-check` - Fast merge
|
|
791
|
-
|
|
792
|
-
### Agent role separation
|
|
793
|
-
|
|
794
|
-
#### doc-syncer dedicated area
|
|
795
|
-
|
|
796
|
-
- Living Document synchronization (code ↔ document)
|
|
797
|
-
- @TAG system verification and update
|
|
798
|
-
- Automatic creation/update of API document
|
|
799
|
-
- README and architecture document synchronization
|
|
800
|
-
- Verification of document-code consistency
|
|
801
|
-
|
|
802
|
-
#### git-manager dedicated area
|
|
803
|
-
|
|
804
|
-
- All Git commit operations (add, commit, push)
|
|
805
|
-
- Apply synchronization strategy for each mode
|
|
806
|
-
- PR status transition (Draft → Ready)
|
|
807
|
-
- **PR auto merge** (when --auto-merge flag)
|
|
808
|
-
- Check CI/CD status
|
|
809
|
-
- Conflict verification
|
|
810
|
-
- Execute Squash merge
|
|
811
|
-
- Remote branch deletion
|
|
812
|
-
- **Branch cleanup and conversion**
|
|
813
|
-
- Local develop checkout
|
|
814
|
-
- Remote synchronization (git pull)
|
|
815
|
-
- Local feature branch deletion
|
|
816
|
-
- Automatic assignment and labeling of reviewers
|
|
817
|
-
- GitHub CLI integration and remote synchronization
|
|
818
|
-
|
|
819
|
-
### 🧪 Personal Mode
|
|
820
|
-
|
|
821
|
-
- The git-manager agent automatically creates checkpoints before and after synchronization
|
|
822
|
-
- The README, in-depth documentation, and PR body are organized manually according to the checklist.
|
|
823
|
-
|
|
824
|
-
### 🏢 Team Mode
|
|
825
|
-
|
|
826
|
-
- Full synchronization of Living Document + @TAG verification/correction
|
|
827
|
-
- Optionally perform PR Ready conversion and labeling only when gh CLI is set
|
|
828
|
-
- Fully automated when using **--auto-merge flag**:
|
|
829
|
-
1. Document synchronization complete.
|
|
830
|
-
2. git push origin feature/SPEC-{ID}
|
|
831
|
-
3. gh pr ready {PR_NUMBER}
|
|
832
|
-
4. Check CI/CD status (gh pr checks)
|
|
833
|
-
5. gh pr merge --squash --delete-branch
|
|
834
|
-
6. git checkout develop && git pull origin develop
|
|
835
|
-
7. Notification that the next task is ready
|
|
836
|
-
|
|
837
|
-
**Important**: All Git operations (commit, sync, PR management) are handled by the git-manager agent, so this command does not run Git operations directly.
|
|
838
|
-
|
|
839
|
-
**Branch Policy**:
|
|
840
|
-
- Base branch: `develop` (GitFlow standard)
|
|
841
|
-
- After merge: automatically checkout `develop`
|
|
842
|
-
- Next `/alfred:1-plan` automatically starts in `develop`
|
|
843
|
-
|
|
844
|
-
## Synchronization Details (Summary)
|
|
845
|
-
|
|
846
|
-
1. Project analysis and TAG verification → Check broken/duplicate/orphaned TAG
|
|
847
|
-
2. Code ↔ Document synchronization → API/README/architecture document update, SPEC ↔ Code TODO synchronization
|
|
848
|
-
3. TAG chain verification → `rg '@TAG' -n src/ tests/` (scan code directly)
|
|
849
|
-
|
|
850
|
-
## Next steps
|
|
851
|
-
|
|
852
|
-
**Recommendation**: For better performance and context management, start a new chat session with the `/clear` or `/new` command before proceeding to the next step.
|
|
853
|
-
|
|
854
|
-
- The entire MoAI-ADK workflow is completed after document synchronization is completed
|
|
855
|
-
- All Git operations are dedicated to the git-manager agent to ensure consistency
|
|
856
|
-
- Only command-level orchestration is used without direct calls between agents
|
|
857
|
-
|
|
858
|
-
## Report results
|
|
859
|
-
|
|
860
|
-
Report synchronization results in a structured format:
|
|
861
|
-
|
|
862
|
-
### Successful synchronization (summary example)
|
|
863
|
-
|
|
864
|
-
✅ Document synchronization complete — Update N, Create M, TAG Modify K, Verification passed
|
|
865
|
-
|
|
866
|
-
### Partial synchronization (problem detected)
|
|
867
|
-
|
|
868
|
-
```
|
|
869
|
-
⚠️ Partial sync completed (issue found)
|
|
870
|
-
|
|
871
|
-
❌ Problems that need solving:
|
|
872
|
-
├── Broken links: X (specific list)
|
|
873
|
-
├── Duplicate TAG: X
|
|
874
|
-
└── Orphan TAG: X
|
|
875
|
-
|
|
876
|
-
🛠️ Auto-correction recommendations:
|
|
877
|
-
1. Broken link recovery
|
|
878
|
-
2. Merge duplicate TAGs
|
|
879
|
-
3. Orphan TAG cleanup
|
|
880
|
-
```
|
|
881
|
-
|
|
882
|
-
## Final Step
|
|
883
|
-
|
|
884
|
-
After document synchronization completes, Alfred automatically invokes AskUserQuestion to ask the user what to do next:
|
|
885
|
-
|
|
886
|
-
```python
|
|
887
|
-
AskUserQuestion(
|
|
888
|
-
questions=[
|
|
889
|
-
{
|
|
890
|
-
"question": "문서 동기화가 완료되었습니다. 다음으로 뭘 하시겠습니까?",
|
|
891
|
-
"header": "다음 단계",
|
|
892
|
-
"multiSelect": false,
|
|
893
|
-
"options": [
|
|
894
|
-
{
|
|
895
|
-
"label": "📋 다음 스펙 작성",
|
|
896
|
-
"description": "/alfred:1-plan으로 새로운 기능 SPEC 작성"
|
|
897
|
-
},
|
|
898
|
-
{
|
|
899
|
-
"label": "📤 PR 병합",
|
|
900
|
-
"description": "GitHub에서 PR 검토 및 병합 진행"
|
|
901
|
-
},
|
|
902
|
-
{
|
|
903
|
-
"label": "🔄 새 세션 시작",
|
|
904
|
-
"description": "성능 최적화를 위해 /clear 실행"
|
|
905
|
-
}
|
|
906
|
-
]
|
|
907
|
-
}
|
|
908
|
-
]
|
|
909
|
-
)
|
|
910
|
-
```
|
|
911
|
-
|
|
912
|
-
**User Responses**:
|
|
913
|
-
- **📋 다음 스펙 작성**: Proceed to `/alfred:1-plan` for creating next SPEC
|
|
914
|
-
- **📤 PR 병합**: Manual PR review and merge on GitHub
|
|
915
|
-
- **🔄 새 세션 시작**: Execute `/clear` to start fresh session (recommended for performance)
|
|
916
|
-
|
|
917
|
-
---
|
|
918
|
-
|
|
919
|
-
## Next steps guidance
|
|
920
|
-
|
|
921
|
-
### Development cycle complete
|
|
922
|
-
|
|
923
|
-
**Default mode (PR Ready only)**:
|
|
924
|
-
```
|
|
925
|
-
🔄 MoAI-ADK 3-step workflow completion:
|
|
926
|
-
✅ /alfred:1-plan → Create EARS specification (feature/SPEC-{ID} branch)
|
|
927
|
-
✅ /alfred:2-run → TDD implementation
|
|
928
|
-
✅ /alfred:3-sync → Document synchronization + PR Ready
|
|
929
|
-
|
|
930
|
-
⏳ Next steps: PR review and manual merge required
|
|
931
|
-
> gh pr view (check PR)
|
|
932
|
-
> gh pr merge --squash (merge after review)
|
|
933
|
-
```
|
|
934
|
-
|
|
935
|
-
**Auto Merge Mode (Recommended)**:
|
|
936
|
-
```
|
|
937
|
-
🔄 Fully automated GitFlow workflow:
|
|
938
|
-
✅ /alfred:1-plan → EARS specification creation (from develop)
|
|
939
|
-
✅ /alfred:2-run → TDD implementation
|
|
940
|
-
✅ /alfred:3-sync --auto-merge → Document synchronization + PR Merge + branch cleanup
|
|
941
|
-
|
|
942
|
-
🎉 Automatic switch to develop branch done!
|
|
943
|
-
📍 You are here: develop (ready for next work)
|
|
944
|
-
> /alfred:1-plan "Describe next feature" # Create new branch in develop
|
|
945
|
-
```
|
|
946
|
-
|
|
947
|
-
### Integrated project mode
|
|
948
|
-
|
|
949
|
-
**When to use**:
|
|
950
|
-
- When the implementation of multiple SPECs has been completed and the entire project documentation needs to be updated
|
|
951
|
-
- When periodic synchronization of the entire document in Personal mode is required.
|
|
952
|
-
|
|
953
|
-
**Differences from Personal/Team mode**:
|
|
954
|
-
- **Personal/Team mode**: Synchronize only specific SPEC-related documents
|
|
955
|
-
- **Project mode**: Synchronize README, architecture documentation, and entire API documentation
|
|
956
|
-
|
|
957
|
-
**Output**:
|
|
958
|
-
- README.md (updated complete feature list)
|
|
959
|
-
- docs/architecture.md (updated system design)
|
|
960
|
-
- docs/api/ (unified API documentation)
|
|
961
|
-
- .moai/indexes/ (rebuilt full TAG index)
|
|
962
|
-
|
|
963
|
-
```
|
|
964
|
-
🏢 Integrated branch sync complete!
|
|
965
|
-
|
|
966
|
-
📋 Entire project synchronization:
|
|
967
|
-
├── README.md (full feature list)
|
|
968
|
-
├── docs/architecture.md (system design)
|
|
969
|
-
├── docs/api/ (unified API documentation)
|
|
970
|
-
└── .moai/indexes/ (full TAG index)
|
|
971
|
-
|
|
972
|
-
🎯 PR conversion support completed
|
|
973
|
-
```
|
|
974
|
-
|
|
975
|
-
## Constraints and Assumptions
|
|
976
|
-
|
|
977
|
-
**Environment Dependency:**
|
|
978
|
-
|
|
979
|
-
- Git repository required
|
|
980
|
-
- gh CLI (required for GitHub integration)
|
|
981
|
-
- Python3 (TAG verification script)
|
|
982
|
-
|
|
983
|
-
**Prerequisites:**
|
|
984
|
-
|
|
985
|
-
- MoAI-ADK project structure (.moai/, .claude/)
|
|
986
|
-
- TDD implementation completion status
|
|
987
|
-
- Compliance with TRUST 5 principles
|
|
988
|
-
|
|
989
|
-
**Limitations:**
|
|
990
|
-
|
|
991
|
-
- TAG verification is based on file existence
|
|
992
|
-
- PR automatic conversion only works in gh CLI environment
|
|
993
|
-
- Coverage figures need to be measured separately
|
|
994
|
-
|
|
995
|
-
---
|
|
996
|
-
|
|
997
|
-
## 🧠 Context Management
|
|
998
|
-
|
|
999
|
-
> For more information: Skill("moai-alfred-dev-guide") - see section "Context Engineering"
|
|
1000
|
-
|
|
1001
|
-
### Core strategy of this command
|
|
1002
|
-
|
|
1003
|
-
**Load first**: `.moai/reports/sync-report-latest.md` (old sync state)
|
|
1004
|
-
|
|
1005
|
-
**Recommendation**: Document synchronization is complete. Now that the entire MoAI-ADK cycle (1-spec → 2-build → 3-sync) has been completed, start a new conversation session with the `/clear` or `/new` command before developing the next feature.
|
|
1006
|
-
|
|
1007
|
-
---
|
|
1008
|
-
|
|
1009
|
-
**Aims to improve code-document consistency and ensure @TAG traceability by linking with the doc-syncer subagent.**
|