@zeyue0329/xiaoma-cli 1.0.49 → 1.0.66
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.
- package/.playwright-cli/console-2026-05-13T06-36-26-793Z.log +2 -0
- package/.playwright-cli/page-2026-05-13T06-36-27-725Z.yml +1 -0
- package/CLAUDE.md +79 -251
- package/LICENSE +30 -0
- package/README.md +127 -2
- package/XiaoMa-CLI-2026H2-/350/277/255/344/273/243/350/247/204/345/210/222.pptx +0 -0
- package/demo/xiaoma-bug-circle-resolve/SKILL.md +6 -0
- package/demo/xiaoma-bug-circle-resolve/workflow.md +254 -0
- package/demo/xiaoma-bug-resolve/SKILL.md +6 -0
- package/demo/xiaoma-bug-resolve/workflow.md +269 -0
- package/demo/xiaoma-prd-saas-zh/README.md +57 -0
- package/demo/xiaoma-prd-saas-zh/domain-research.md +128 -0
- package/demo/xiaoma-prd-saas-zh/epics.md +303 -0
- package/demo/xiaoma-prd-saas-zh/market-research-2026-q1.md +183 -0
- package/demo/xiaoma-prd-saas-zh/prd-bad-examples.md +268 -0
- package/demo/xiaoma-prd-saas-zh/prd.md +409 -0
- package/demo/xiaoma-prd-saas-zh/product-brief.md +97 -0
- package/demo/xiaoma-prd-saas-zh/validation-report.md +279 -0
- package/docs/roadshow/01-/351/241/271/347/233/256/346/246/202/350/247/210/344/270/216/346/236/266/346/236/204.md +189 -0
- package/docs/roadshow/02-/346/231/272/350/203/275/344/275/223/347/263/273/347/273/237/350/257/246/350/247/243.md +464 -0
- package/docs/roadshow/03-/346/231/272/350/203/275/344/275/223/344/272/244/344/272/222/346/265/201/347/250/213/345/233/276.md +334 -0
- package/docs/roadshow/04-/345/267/245/344/275/234/346/265/201/346/211/247/350/241/214/350/257/246/350/247/243.md +1038 -0
- package/docs/roadshow/05-/346/212/200/346/234/257/345/256/236/347/216/260/344/270/216/345/210/233/346/226/260/344/272/256/347/202/271.md +205 -0
- package/docs/roadshow/06-/350/267/257/346/274/224/346/200/273/347/273/223/344/270/216/346/274/224/347/244/272/345/273/272/350/256/256.md +167 -0
- package/media/doc1_fig1.png +0 -0
- package/media/doc1_fig2.png +0 -0
- package/media/doc1_fig3.png +0 -0
- package/media/doc1_fig4.png +0 -0
- package/media/doc2_fig1.png +0 -0
- package/media/doc2_fig2.png +0 -0
- package/media/doc2_fig3.png +0 -0
- package/media/doc2_fig4.png +0 -0
- package/media/doc3_fig1.png +0 -0
- package/media/doc3_fig2.png +0 -0
- package/media/doc3_fig3.png +0 -0
- package/media/doc3_fig4.png +0 -0
- package/media/doc4_fig1.png +0 -0
- package/media/doc4_fig2.png +0 -0
- package/media/doc4_fig3.png +0 -0
- package/media/doc5_fig1.png +0 -0
- package/media/doc5_fig2.png +0 -0
- package/media/doc5_fig3.png +0 -0
- package/package.json +50 -60
- package/src/core/module-help.csv +11 -0
- package/src/core/module.yaml +25 -0
- package/src/core/skills/xiaoma-advanced-elicitation/SKILL.md +6 -0
- package/src/core/skills/xiaoma-advanced-elicitation/methods.csv +51 -0
- package/src/core/skills/xiaoma-advanced-elicitation/workflow.md +135 -0
- package/src/core/skills/xiaoma-advanced-elicitation/xiaoma-skill-manifest.yaml +1 -0
- package/src/core/skills/xiaoma-brainstorming/SKILL.md +6 -0
- package/src/core/skills/xiaoma-brainstorming/brain-methods.csv +62 -0
- package/src/core/skills/xiaoma-brainstorming/steps/step-01-session-setup.md +214 -0
- package/src/core/skills/xiaoma-brainstorming/steps/step-01b-continue.md +124 -0
- package/src/core/skills/xiaoma-brainstorming/steps/step-02a-user-selected.md +229 -0
- package/src/core/skills/xiaoma-brainstorming/steps/step-02b-ai-recommended.md +239 -0
- package/src/core/skills/xiaoma-brainstorming/steps/step-02c-random-selection.md +211 -0
- package/src/core/skills/xiaoma-brainstorming/steps/step-02d-progressive-flow.md +266 -0
- package/src/core/skills/xiaoma-brainstorming/steps/step-03-technique-execution.md +401 -0
- package/src/core/skills/xiaoma-brainstorming/steps/step-04-idea-organization.md +305 -0
- package/src/core/skills/xiaoma-brainstorming/template.md +15 -0
- package/src/core/skills/xiaoma-brainstorming/workflow.md +53 -0
- package/src/core/skills/xiaoma-brainstorming/xiaoma-skill-manifest.yaml +1 -0
- package/src/core/skills/xiaoma-distillator/SKILL.md +178 -0
- package/src/core/skills/xiaoma-distillator/agents/distillate-compressor.md +116 -0
- package/src/core/skills/xiaoma-distillator/agents/round-trip-reconstructor.md +68 -0
- package/src/core/skills/xiaoma-distillator/resources/compression-rules.md +51 -0
- package/src/core/skills/xiaoma-distillator/resources/distillate-format-reference.md +227 -0
- package/src/core/skills/xiaoma-distillator/resources/splitting-strategy.md +78 -0
- package/src/core/skills/xiaoma-distillator/scripts/analyze_sources.py +300 -0
- package/src/core/skills/xiaoma-distillator/scripts/tests/test_analyze_sources.py +204 -0
- package/src/core/skills/xiaoma-distillator/xiaoma-skill-manifest.yaml +15 -0
- package/src/core/skills/xiaoma-editorial-review-prose/SKILL.md +6 -0
- package/src/core/skills/xiaoma-editorial-review-prose/workflow.md +81 -0
- package/src/core/skills/xiaoma-editorial-review-prose/xiaoma-skill-manifest.yaml +1 -0
- package/src/core/skills/xiaoma-editorial-review-structure/SKILL.md +6 -0
- package/src/core/skills/xiaoma-editorial-review-structure/workflow.md +174 -0
- package/src/core/skills/xiaoma-editorial-review-structure/xiaoma-skill-manifest.yaml +1 -0
- package/src/core/skills/xiaoma-help/SKILL.md +6 -0
- package/src/core/skills/xiaoma-help/workflow.md +88 -0
- package/src/core/skills/xiaoma-help/xiaoma-skill-manifest.yaml +1 -0
- package/src/core/skills/xiaoma-index-docs/SKILL.md +6 -0
- package/src/core/skills/xiaoma-index-docs/workflow.md +61 -0
- package/src/core/skills/xiaoma-index-docs/xiaoma-skill-manifest.yaml +1 -0
- package/src/core/skills/xiaoma-party-mode/SKILL.md +6 -0
- package/src/core/skills/xiaoma-party-mode/steps/step-01-agent-loading.md +138 -0
- package/src/core/skills/xiaoma-party-mode/steps/step-02-discussion-orchestration.md +187 -0
- package/src/core/skills/xiaoma-party-mode/steps/step-03-graceful-exit.md +167 -0
- package/src/core/skills/xiaoma-party-mode/workflow.md +190 -0
- package/src/core/skills/xiaoma-party-mode/xiaoma-skill-manifest.yaml +1 -0
- package/src/core/skills/xiaoma-review-adversarial-general/SKILL.md +6 -0
- package/src/core/skills/xiaoma-review-adversarial-general/workflow.md +32 -0
- package/src/core/skills/xiaoma-review-adversarial-general/xiaoma-skill-manifest.yaml +1 -0
- package/src/core/skills/xiaoma-review-edge-case-hunter/SKILL.md +6 -0
- package/src/core/skills/xiaoma-review-edge-case-hunter/workflow.md +62 -0
- package/src/core/skills/xiaoma-review-edge-case-hunter/xiaoma-skill-manifest.yaml +1 -0
- package/src/core/skills/xiaoma-shard-doc/SKILL.md +6 -0
- package/src/core/skills/xiaoma-shard-doc/workflow.md +100 -0
- package/src/core/skills/xiaoma-shard-doc/xiaoma-skill-manifest.yaml +1 -0
- package/src/core/tasks/xiaoma-create-prd/SKILL.md +6 -0
- package/src/core/tasks/xiaoma-create-prd/data/domain-complexity.csv +15 -0
- package/src/core/tasks/xiaoma-create-prd/data/prd-purpose.md +354 -0
- package/src/core/tasks/xiaoma-create-prd/data/project-types.csv +11 -0
- package/src/core/tasks/xiaoma-create-prd/data/upstream-input-contract.md +168 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-01-init.md +178 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-01b-continue.md +161 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-02-discovery.md +208 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-02b-vision.md +142 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-02c-executive-summary.md +158 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-03-success.md +214 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-04-journeys.md +201 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-05-domain.md +194 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-06-innovation.md +211 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-07-project-type.md +222 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-08-scoping.md +216 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-09-functional.md +219 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-10-nonfunctional.md +230 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-11-polish.md +221 -0
- package/src/core/tasks/xiaoma-create-prd/steps-c/step-12-complete.md +115 -0
- package/src/core/tasks/xiaoma-create-prd/templates/prd-skeleton-reference.md +428 -0
- package/src/core/tasks/xiaoma-create-prd/templates/prd-template.md +108 -0
- package/src/core/tasks/xiaoma-create-prd/workflow.md +62 -0
- package/src/core/tasks/xiaoma-create-prd/xiaoma-skill-manifest.yaml +1 -0
- package/src/utility/agent-components/activation-rules.txt +6 -0
- package/src/utility/agent-components/activation-steps.txt +14 -0
- package/src/utility/agent-components/agent-command-header.md +1 -0
- package/src/utility/agent-components/agent.customize.template.yaml +41 -0
- package/src/utility/agent-components/handler-action.txt +4 -0
- package/src/utility/agent-components/handler-data.txt +5 -0
- package/src/utility/agent-components/handler-exec.txt +6 -0
- package/src/utility/agent-components/handler-multi.txt +13 -0
- package/src/utility/agent-components/handler-tmpl.txt +5 -0
- package/src/utility/agent-components/menu-handlers.txt +6 -0
- package/src/xmc/agents/analyst.agent.yaml +47 -0
- package/src/xmc/agents/architect.agent.yaml +29 -0
- package/src/xmc/agents/dev.agent.yaml +38 -0
- package/src/xmc/agents/pm.agent.yaml +44 -0
- package/src/xmc/agents/qa.agent.yaml +58 -0
- package/src/xmc/agents/quick-flow-solo-dev.agent.yaml +36 -0
- package/src/xmc/agents/sm.agent.yaml +53 -0
- package/src/xmc/agents/tech-writer/tech-writer-sidecar/documentation-standards.md +224 -0
- package/src/xmc/agents/tech-writer/tech-writer.agent.yaml +46 -0
- package/src/xmc/agents/tech-writer/xiaoma-skill-manifest.yaml +3 -0
- package/src/xmc/agents/ux-designer.agent.yaml +27 -0
- package/src/xmc/agents/xiaoma-skill-manifest.yaml +39 -0
- package/src/xmc/data/project-context-template.md +26 -0
- package/src/xmc/module-help.csv +32 -0
- package/src/xmc/module.yaml +50 -0
- package/src/xmc/teams/default-party.csv +20 -0
- package/src/xmc/teams/team-fullstack.yaml +12 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/SKILL.md +6 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/checklist.md +28 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-01-init-and-validate.md +102 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-02-requirements-analysis.md +146 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-03-architecture-analysis.md +141 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-04-create-prd.md +101 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-05-validate-prd.md +159 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-06-create-epics.md +104 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-07-create-architecture.md +107 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/steps/step-08-finalize.md +124 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/workflow.md +107 -0
- package/src/xmc/workflows/1-analysis/auto-requirements-pipeline/xiaoma-skill-manifest.yaml +3 -0
- package/src/xmc/workflows/1-analysis/research/market-steps/step-01-init.md +182 -0
- package/src/xmc/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +237 -0
- package/src/xmc/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +249 -0
- package/src/xmc/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +259 -0
- package/src/xmc/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +177 -0
- package/src/xmc/workflows/1-analysis/research/market-steps/step-06-research-completion.md +476 -0
- package/src/xmc/workflows/1-analysis/research/research.template.md +29 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/SKILL.md +6 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/domain-steps/step-01-init.md +137 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/domain-steps/step-02-domain-analysis.md +229 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/domain-steps/step-03-competitive-landscape.md +238 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/domain-steps/step-04-regulatory-focus.md +206 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/domain-steps/step-05-technical-trends.md +234 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/domain-steps/step-06-research-synthesis.md +444 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/research.template.md +29 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/workflow.md +49 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-domain-research/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/SKILL.md +6 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/research.template.md +29 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-01-init.md +184 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-02-customer-behavior.md +239 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-03-customer-pain-points.md +251 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-04-customer-decisions.md +261 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-05-competitive-analysis.md +173 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/steps/step-06-research-completion.md +478 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/workflow.md +49 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-market-research/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/SKILL.md +6 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/research.template.md +29 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/technical-steps/step-01-init.md +137 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/technical-steps/step-02-technical-overview.md +239 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/technical-steps/step-03-integration-patterns.md +248 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/technical-steps/step-04-architectural-patterns.md +202 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/technical-steps/step-05-implementation-research.md +233 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/technical-steps/step-06-research-synthesis.md +487 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/workflow.md +50 -0
- package/src/xmc/workflows/1-analysis/research/xiaoma-technical-research/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/SKILL.md +6 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/product-brief.template.md +10 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/steps/step-01-init.md +170 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/steps/step-01b-continue.md +158 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/steps/step-02-vision.md +193 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/steps/step-03-users.md +196 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/steps/step-04-metrics.md +199 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/steps/step-05-scope.md +213 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/steps/step-06-complete.md +159 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/workflow.md +55 -0
- package/src/xmc/workflows/1-analysis/xiaoma-create-product-brief/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/SKILL.md +88 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/agents/artifact-analyzer.md +60 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/agents/opportunity-reviewer.md +44 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/agents/skeptic-reviewer.md +44 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/agents/web-researcher.md +49 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/prompts/contextual-discovery.md +57 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/prompts/draft-and-review.md +86 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/prompts/finalize.md +75 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/prompts/guided-elicitation.md +70 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/resources/brief-template.md +60 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/xiaoma-manifest.json +17 -0
- package/src/xmc/workflows/1-analysis/xiaoma-product-brief-preview/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/data/domain-complexity.csv +15 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/data/prd-purpose.md +197 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/data/project-types.csv +11 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-01-discovery.md +224 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-02-format-detection.md +191 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-02b-parity-check.md +209 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-03-density-validation.md +174 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-04-brief-coverage-validation.md +214 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-05-measurability-validation.md +228 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-06-traceability-validation.md +217 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-07-implementation-leakage-validation.md +205 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-08-domain-compliance-validation.md +243 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-09-project-type-validation.md +263 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-10-smart-validation.md +209 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-11-holistic-quality-validation.md +264 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-12-completeness-validation.md +242 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +232 -0
- package/src/xmc/workflows/2-plan-workflows/create-prd/workflow-validate-prd.md +65 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/SKILL.md +6 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-01-init.md +135 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-01b-continue.md +127 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-02-discovery.md +190 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-03-core-experience.md +217 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-04-emotional-response.md +220 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-05-inspiration.md +235 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-06-design-system.md +253 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-07-defining-experience.md +255 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-08-visual-foundation.md +225 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-09-design-directions.md +225 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-10-user-journeys.md +242 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-11-component-strategy.md +249 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-12-ux-patterns.md +238 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-13-responsive-accessibility.md +265 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/steps/step-14-complete.md +171 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/ux-design-template.md +13 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/workflow.md +36 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-create-ux-design/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-edit-prd/SKILL.md +6 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-edit-prd/steps-e/step-e-01-discovery.md +242 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-edit-prd/steps-e/step-e-01b-legacy-conversion.md +204 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-edit-prd/steps-e/step-e-02-review.md +245 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-edit-prd/steps-e/step-e-03-edit.md +250 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-edit-prd/steps-e/step-e-04-complete.md +165 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-edit-prd/workflow.md +63 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-edit-prd/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/SKILL.md +6 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/data/domain-complexity.csv +15 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/data/prd-purpose.md +197 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/data/prd-quality-rubric.csv +14 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/data/project-types.csv +11 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-01-discovery.md +221 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-02-format-detection.md +188 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-02b-parity-check.md +206 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-03-density-validation.md +171 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-04-brief-coverage-validation.md +211 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-05-measurability-validation.md +225 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-06-traceability-validation.md +214 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-07-implementation-leakage-validation.md +202 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-08-domain-compliance-validation.md +240 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-09-project-type-validation.md +260 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-10-smart-validation.md +206 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-11-holistic-quality-validation.md +261 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-12-completeness-validation.md +239 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/steps-v/step-v-13-report-complete.md +229 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/workflow.md +62 -0
- package/src/xmc/workflows/2-plan-workflows/xiaoma-validate-prd/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/SKILL.md +6 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/steps/step-01-document-discovery.md +179 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/steps/step-02-prd-analysis.md +168 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/steps/step-03-epic-coverage-validation.md +169 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/steps/step-04-ux-alignment.md +129 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/steps/step-05-epic-quality-review.md +241 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/steps/step-06-final-assessment.md +126 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/templates/readiness-report-template.md +4 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/workflow.md +49 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-check-implementation-readiness/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/SKILL.md +6 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/architecture-decision-template.md +12 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/data/domain-complexity.csv +13 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/data/project-types.csv +7 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/steps/step-01-init.md +153 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/steps/step-01b-continue.md +173 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/steps/step-02-context.md +224 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/steps/step-03-starter.md +329 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/steps/step-04-decisions.md +318 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/steps/step-05-patterns.md +359 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/steps/step-06-structure.md +379 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/steps/step-07-validation.md +359 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/steps/step-08-complete.md +76 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/workflow.md +38 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-architecture/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-epics-and-stories/SKILL.md +6 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-epics-and-stories/steps/step-01-validate-prerequisites.md +255 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-epics-and-stories/steps/step-02-design-epics.md +212 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-epics-and-stories/steps/step-03-create-stories.md +255 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-epics-and-stories/steps/step-04-final-validation.md +131 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-epics-and-stories/templates/epics-template.md +61 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-epics-and-stories/workflow.md +53 -0
- package/src/xmc/workflows/3-solutioning/xiaoma-create-epics-and-stories/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/SKILL.md +6 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/checklist.md +22 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-01-init-and-validate.md +173 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-02-create-story.md +102 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-03-validate-story.md +107 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-04-develop-story.md +97 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-05-code-review.md +95 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-06-test-story.md +253 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-07-fix-and-retest.md +237 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-08-complete-story.md +114 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/steps/step-09-finalize.md +69 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/workflow.md +89 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline/xiaoma-skill-manifest.yaml +3 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline-batch/SKILL.md +6 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline-batch/workflow.md +333 -0
- package/src/xmc/workflows/4-implementation/auto-story-pipeline-batch/xiaoma-skill-manifest.yaml +3 -0
- package/src/xmc/workflows/4-implementation/xiaoma-code-review/SKILL.md +6 -0
- package/src/xmc/workflows/4-implementation/xiaoma-code-review/checklist.md +23 -0
- package/src/xmc/workflows/4-implementation/xiaoma-code-review/discover-inputs.md +88 -0
- package/src/xmc/workflows/4-implementation/xiaoma-code-review/steps/step-01-gather-context.md +61 -0
- package/src/xmc/workflows/4-implementation/xiaoma-code-review/steps/step-02-review.md +41 -0
- package/src/xmc/workflows/4-implementation/xiaoma-code-review/steps/step-03-triage.md +50 -0
- package/src/xmc/workflows/4-implementation/xiaoma-code-review/steps/step-04-present.md +38 -0
- package/src/xmc/workflows/4-implementation/xiaoma-code-review/workflow.md +54 -0
- package/src/xmc/workflows/4-implementation/xiaoma-code-review/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/4-implementation/xiaoma-correct-course/SKILL.md +6 -0
- package/src/xmc/workflows/4-implementation/xiaoma-correct-course/checklist.md +288 -0
- package/src/xmc/workflows/4-implementation/xiaoma-correct-course/workflow.md +267 -0
- package/src/xmc/workflows/4-implementation/xiaoma-correct-course/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/4-implementation/xiaoma-create-story/SKILL.md +6 -0
- package/src/xmc/workflows/4-implementation/xiaoma-create-story/checklist.md +357 -0
- package/src/xmc/workflows/4-implementation/xiaoma-create-story/discover-inputs.md +88 -0
- package/src/xmc/workflows/4-implementation/xiaoma-create-story/template.md +49 -0
- package/src/xmc/workflows/4-implementation/xiaoma-create-story/workflow.md +380 -0
- package/src/xmc/workflows/4-implementation/xiaoma-create-story/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/4-implementation/xiaoma-dev-story/SKILL.md +6 -0
- package/src/xmc/workflows/4-implementation/xiaoma-dev-story/checklist.md +80 -0
- package/src/xmc/workflows/4-implementation/xiaoma-dev-story/workflow.md +450 -0
- package/src/xmc/workflows/4-implementation/xiaoma-dev-story/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/4-implementation/xiaoma-retrospective/SKILL.md +6 -0
- package/src/xmc/workflows/4-implementation/xiaoma-retrospective/workflow.md +1479 -0
- package/src/xmc/workflows/4-implementation/xiaoma-retrospective/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/4-implementation/xiaoma-sprint-planning/SKILL.md +6 -0
- package/src/xmc/workflows/4-implementation/xiaoma-sprint-planning/checklist.md +33 -0
- package/src/xmc/workflows/4-implementation/xiaoma-sprint-planning/sprint-status-template.yaml +56 -0
- package/src/xmc/workflows/4-implementation/xiaoma-sprint-planning/workflow.md +263 -0
- package/src/xmc/workflows/4-implementation/xiaoma-sprint-planning/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/4-implementation/xiaoma-sprint-status/SKILL.md +6 -0
- package/src/xmc/workflows/4-implementation/xiaoma-sprint-status/workflow.md +261 -0
- package/src/xmc/workflows/4-implementation/xiaoma-sprint-status/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/5-full-pipeline/auto-full-pipeline/SKILL.md +6 -0
- package/src/xmc/workflows/5-full-pipeline/auto-full-pipeline/checklist.md +37 -0
- package/src/xmc/workflows/5-full-pipeline/auto-full-pipeline/steps/step-01-init-and-validate.md +152 -0
- package/src/xmc/workflows/5-full-pipeline/auto-full-pipeline/steps/step-02-run-requirements-pipeline.md +120 -0
- package/src/xmc/workflows/5-full-pipeline/auto-full-pipeline/steps/step-03-bridge-sprint-planning.md +119 -0
- package/src/xmc/workflows/5-full-pipeline/auto-full-pipeline/steps/step-04-run-story-pipeline.md +114 -0
- package/src/xmc/workflows/5-full-pipeline/auto-full-pipeline/steps/step-05-finalize.md +194 -0
- package/src/xmc/workflows/5-full-pipeline/auto-full-pipeline/workflow.md +108 -0
- package/src/xmc/workflows/5-full-pipeline/auto-full-pipeline/xiaoma-skill-manifest.yaml +3 -0
- package/src/xmc/workflows/5-full-pipeline/auto-prd-to-stories/SKILL.md +6 -0
- package/src/xmc/workflows/5-full-pipeline/auto-prd-to-stories/checklist.md +43 -0
- package/src/xmc/workflows/5-full-pipeline/auto-prd-to-stories/steps/step-01-init-and-validate.md +155 -0
- package/src/xmc/workflows/5-full-pipeline/auto-prd-to-stories/steps/step-02-create-epics.md +156 -0
- package/src/xmc/workflows/5-full-pipeline/auto-prd-to-stories/steps/step-03-bridge-sprint-planning.md +143 -0
- package/src/xmc/workflows/5-full-pipeline/auto-prd-to-stories/steps/step-04-batch-create-stories.md +309 -0
- package/src/xmc/workflows/5-full-pipeline/auto-prd-to-stories/steps/step-05-finalize.md +311 -0
- package/src/xmc/workflows/5-full-pipeline/auto-prd-to-stories/workflow.md +105 -0
- package/src/xmc/workflows/5-full-pipeline/auto-prd-to-stories/xiaoma-skill-manifest.yaml +3 -0
- package/src/xmc/workflows/xiaoma-document-project/SKILL.md +6 -0
- package/src/xmc/workflows/xiaoma-document-project/checklist.md +245 -0
- package/src/xmc/workflows/xiaoma-document-project/documentation-requirements.csv +12 -0
- package/src/xmc/workflows/xiaoma-document-project/instructions.md +128 -0
- package/src/xmc/workflows/xiaoma-document-project/templates/deep-dive-template.md +345 -0
- package/src/xmc/workflows/xiaoma-document-project/templates/index-template.md +169 -0
- package/src/xmc/workflows/xiaoma-document-project/templates/project-overview-template.md +103 -0
- package/src/xmc/workflows/xiaoma-document-project/templates/project-scan-report-schema.json +160 -0
- package/src/xmc/workflows/xiaoma-document-project/templates/source-tree-template.md +135 -0
- package/src/xmc/workflows/xiaoma-document-project/workflow.md +27 -0
- package/src/xmc/workflows/xiaoma-document-project/workflows/deep-dive-instructions.md +299 -0
- package/src/xmc/workflows/xiaoma-document-project/workflows/deep-dive-workflow.md +34 -0
- package/src/xmc/workflows/xiaoma-document-project/workflows/full-scan-instructions.md +1107 -0
- package/src/xmc/workflows/xiaoma-document-project/workflows/full-scan-workflow.md +34 -0
- package/src/xmc/workflows/xiaoma-document-project/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/xiaoma-generate-project-context/SKILL.md +6 -0
- package/src/xmc/workflows/xiaoma-generate-project-context/project-context-template.md +21 -0
- package/src/xmc/workflows/xiaoma-generate-project-context/steps/step-01-discover.md +186 -0
- package/src/xmc/workflows/xiaoma-generate-project-context/steps/step-02-generate.md +321 -0
- package/src/xmc/workflows/xiaoma-generate-project-context/steps/step-03-complete.md +278 -0
- package/src/xmc/workflows/xiaoma-generate-project-context/workflow.md +43 -0
- package/src/xmc/workflows/xiaoma-generate-project-context/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/xiaoma-qa-generate-e2e-tests/SKILL.md +6 -0
- package/src/xmc/workflows/xiaoma-qa-generate-e2e-tests/checklist.md +33 -0
- package/src/xmc/workflows/xiaoma-qa-generate-e2e-tests/workflow.md +136 -0
- package/src/xmc/workflows/xiaoma-qa-generate-e2e-tests/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/SKILL.md +6 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/steps/step-01-mode-detection.md +169 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/steps/step-02-context-gathering.md +114 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/steps/step-03-execute.md +107 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/steps/step-04-self-check.md +107 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/steps/step-05-adversarial-review.md +94 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/steps/step-06-resolve-findings.md +144 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/workflow.md +38 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/SKILL.md +6 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-01-clarify-and-route.md +51 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-02-plan.md +35 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-03-implement.md +33 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-04-review.md +50 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/steps/step-05-present.md +17 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/tech-spec-template.md +90 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/workflow.md +79 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-dev-new-preview/xiaoma-skill-manifest.yaml +1 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-spec/SKILL.md +6 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-spec/steps/step-01-understand.md +185 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-spec/steps/step-02-investigate.md +140 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-spec/steps/step-03-generate.md +123 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-spec/steps/step-04-review.md +195 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-spec/tech-spec-template.md +74 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-spec/workflow.md +73 -0
- package/src/xmc/workflows/xiaoma-quick-flow/xiaoma-quick-spec/xiaoma-skill-manifest.yaml +1 -0
- package/src/xpm/agents/patent-advisor.agent.yaml +30 -0
- package/src/xpm/module.yaml +26 -0
- package/src/xpm/skills/xiaoma-patent-mining/SKILL.md +6 -0
- package/src/xpm/skills/xiaoma-patent-mining/references/disclosure-template.md +84 -0
- package/src/xpm/skills/xiaoma-patent-mining/references/docx-format-spec.md +183 -0
- package/src/xpm/skills/xiaoma-patent-mining/references/mining-principles.md +168 -0
- package/src/xpm/skills/xiaoma-patent-mining/scripts/md2docx.js +777 -0
- package/src/xpm/skills/xiaoma-patent-mining/steps/step-01-project-analysis.md +65 -0
- package/src/xpm/skills/xiaoma-patent-mining/steps/step-02-patent-mining.md +87 -0
- package/src/xpm/skills/xiaoma-patent-mining/steps/step-03-disclosure-writing.md +110 -0
- package/src/xpm/skills/xiaoma-patent-mining/steps/step-04-ai-taste-removal.md +85 -0
- package/src/xpm/skills/xiaoma-patent-mining/steps/step-05-docx-generation.md +111 -0
- package/src/xpm/skills/xiaoma-patent-mining/workflow.md +94 -0
- package/src/xpm/skills/xiaoma-patent-mining/xiaoma-skill-manifest.yaml +1 -0
- package/tools/cli/README.md +60 -0
- package/tools/cli/commands/install.js +87 -0
- package/tools/cli/commands/status.js +65 -0
- package/tools/cli/commands/uninstall.js +167 -0
- package/tools/cli/external-official-modules.yaml +6 -0
- package/tools/cli/installers/install-messages.yaml +9 -0
- package/tools/cli/installers/lib/core/config-collector.js +1285 -0
- package/tools/cli/installers/lib/core/custom-module-cache.js +260 -0
- package/tools/cli/installers/lib/core/dependency-resolver.js +742 -0
- package/tools/cli/installers/lib/core/detector.js +223 -0
- package/tools/cli/installers/lib/core/ide-config-manager.js +157 -0
- package/tools/cli/installers/lib/core/installer.js +3216 -0
- package/tools/cli/installers/lib/core/manifest-generator.js +1374 -0
- package/tools/cli/installers/lib/core/manifest.js +1042 -0
- package/tools/cli/installers/lib/custom/handler.js +358 -0
- package/tools/cli/installers/lib/ide/_base-ide.js +673 -0
- package/tools/cli/installers/lib/ide/_config-driven.js +1058 -0
- package/tools/cli/installers/lib/ide/manager.js +304 -0
- package/tools/cli/installers/lib/ide/platform-codes.js +100 -0
- package/tools/cli/installers/lib/ide/platform-codes.yaml +321 -0
- package/tools/cli/installers/lib/ide/shared/agent-command-generator.js +181 -0
- package/tools/cli/installers/lib/ide/shared/module-injections.js +136 -0
- package/tools/cli/installers/lib/ide/shared/path-utils.js +364 -0
- package/tools/cli/installers/lib/ide/shared/skill-manifest.js +90 -0
- package/tools/cli/installers/lib/ide/shared/task-tool-command-generator.js +368 -0
- package/tools/cli/installers/lib/ide/shared/workflow-command-generator.js +179 -0
- package/tools/cli/installers/lib/ide/shared/xiaoma-artifacts.js +181 -0
- package/tools/cli/installers/lib/ide/templates/agent-command-template.md +14 -0
- package/tools/cli/installers/lib/ide/templates/combined/antigravity.md +8 -0
- package/tools/cli/installers/lib/ide/templates/combined/default-agent.md +15 -0
- package/tools/cli/installers/lib/ide/templates/combined/default-task.md +10 -0
- package/tools/cli/installers/lib/ide/templates/combined/default-tool.md +10 -0
- package/tools/cli/installers/lib/ide/templates/combined/default-workflow.md +6 -0
- package/tools/cli/installers/lib/ide/templates/combined/gemini-agent.toml +14 -0
- package/tools/cli/installers/lib/ide/templates/combined/gemini-task.toml +11 -0
- package/tools/cli/installers/lib/ide/templates/combined/gemini-tool.toml +11 -0
- package/tools/cli/installers/lib/ide/templates/combined/gemini-workflow-yaml.toml +16 -0
- package/tools/cli/installers/lib/ide/templates/combined/gemini-workflow.toml +14 -0
- package/tools/cli/installers/lib/ide/templates/combined/kiro-agent.md +16 -0
- package/tools/cli/installers/lib/ide/templates/combined/kiro-task.md +9 -0
- package/tools/cli/installers/lib/ide/templates/combined/kiro-tool.md +9 -0
- package/tools/cli/installers/lib/ide/templates/combined/kiro-workflow.md +7 -0
- package/tools/cli/installers/lib/ide/templates/combined/opencode-agent.md +15 -0
- package/tools/cli/installers/lib/ide/templates/combined/opencode-task.md +13 -0
- package/tools/cli/installers/lib/ide/templates/combined/opencode-tool.md +13 -0
- package/tools/cli/installers/lib/ide/templates/combined/opencode-workflow-yaml.md +16 -0
- package/tools/cli/installers/lib/ide/templates/combined/opencode-workflow.md +16 -0
- package/tools/cli/installers/lib/ide/templates/combined/rovodev.md +9 -0
- package/tools/cli/installers/lib/ide/templates/combined/trae.md +9 -0
- package/tools/cli/installers/lib/ide/templates/combined/windsurf-workflow.md +10 -0
- package/tools/cli/installers/lib/ide/templates/split/.gitkeep +0 -0
- package/tools/cli/installers/lib/message-loader.js +83 -0
- package/tools/cli/installers/lib/modules/external-manager.js +136 -0
- package/tools/cli/installers/lib/modules/manager.js +1387 -0
- package/tools/cli/lib/activation-builder.js +165 -0
- package/tools/cli/lib/agent/compiler.js +516 -0
- package/tools/cli/lib/agent/installer.js +680 -0
- package/tools/cli/lib/agent/template-engine.js +152 -0
- package/tools/cli/lib/agent-analyzer.js +97 -0
- package/tools/cli/lib/agent-party-generator.js +203 -0
- package/tools/cli/lib/cli-utils.js +182 -0
- package/tools/cli/lib/config.js +213 -0
- package/tools/cli/lib/file-ops.js +204 -0
- package/tools/cli/lib/platform-codes.js +116 -0
- package/tools/cli/lib/project-root.js +75 -0
- package/tools/cli/lib/prompts.js +809 -0
- package/tools/cli/lib/ui.js +1960 -0
- package/tools/cli/lib/xml-handler.js +177 -0
- package/tools/cli/lib/xml-to-markdown.js +82 -0
- package/tools/{yaml-format.js → cli/lib/yaml-format.js} +39 -71
- package/tools/cli/lib/yaml-xml-builder.js +570 -0
- package/tools/cli/xiaoma-cli.js +106 -0
- package/tools/lib/xml-utils.js +13 -0
- package/tools/platform-codes.yaml +157 -0
- package/tools/schema/agent.js +489 -0
- package/tools/validate-svg-changes.sh +356 -0
- package/tools/xiaoma-npx-wrapper.js +18 -24
- package//344/270/223/345/210/251/344/272/244/345/272/225/344/271/246_1_/351/235/242/345/220/221AI/346/231/272/350/203/275/344/275/223/347/232/204/345/244/232/351/200/232/351/201/223/344/276/235/350/265/226_20260318.md +483 -0
- package//344/270/223/345/210/251/344/272/244/345/272/225/344/271/246_2_/345/237/272/344/272/216/351/205/215/347/275/256/351/251/261/345/212/250/347/232/204/350/267/250/345/271/263/345/217/260IDE/346/231/272/350/203/275_20260318.md +592 -0
- package//344/270/223/345/210/251/344/272/244/345/272/225/344/271/246_3_AI/346/231/272/350/203/275/344/275/223/345/243/260/346/230/216/345/274/217/345/256/232/344/271/211/347/232/204/347/274/226/350/257/221/346/265/201/346/260/264_20260318.md +624 -0
- package//344/270/223/345/210/251/344/272/244/345/272/225/344/271/246_4_/345/237/272/344/272/216/345/223/210/345/270/214/346/214/207/347/272/271/347/232/204/346/231/272/350/203/275/344/275/223/351/231/204/345/261/236/350/265/204/346/272/220/351/200/211_20260318.md +628 -0
- package//344/270/223/345/210/251/344/272/244/345/272/225/344/271/246_5_AI/346/231/272/350/203/275/344/275/223/350/247/246/345/217/221/346/214/207/344/273/244/347/232/204/345/244/215/345/220/210/346/240/274/345/274/217/346/240/241_20260318.md +652 -0
- package/.claude/agents/tech-translator.md +0 -124
- package/.claude/settings.local.json +0 -37
- package/.idea/XiaoMa-Cli.iml +0 -9
- package/.idea/inspectionProfiles/Project_Default.xml +0 -6
- package/.idea/misc.xml +0 -6
- package/.idea/modules.xml +0 -8
- package/.idea/prettier.xml +0 -6
- package/.idea/vcs.xml +0 -7
- package/.idea/workspace.xml +0 -117
- package/.xiaoma-core/.coordinator-state.json +0 -19
- package/JAVA-BACKEND-COMMANDS-REFERENCE.md +0 -300
- package/JAVA-BACKEND-ITERATION-GUIDE.md +0 -2116
- package/common/tasks/create-doc.md +0 -103
- package/common/tasks/execute-checklist.md +0 -88
- package/common/utils/bmad-doc-template.md +0 -327
- package/common/utils/workflow-management.md +0 -71
- package/dist/agents/analyst.txt +0 -6308
- package/dist/agents/architect.txt +0 -5046
- package/dist/agents/automation-orchestrator.txt +0 -396
- package/dist/agents/dev.txt +0 -1180
- package/dist/agents/full-requirement-orchestrator.txt +0 -505
- package/dist/agents/pm.txt +0 -3078
- package/dist/agents/po.txt +0 -1358
- package/dist/agents/qa.txt +0 -2002
- package/dist/agents/sm.txt +0 -3044
- package/dist/agents/ux-expert.txt +0 -707
- package/dist/agents/workflow-executor.txt +0 -1029
- package/dist/agents/workflow-helper.txt +0 -93
- package/dist/agents/xiaoma-master.txt +0 -9008
- package/dist/agents/xiaoma-orchestrator.txt +0 -1523
- package/dist/teams/team-all.txt +0 -23101
- package/dist/teams/team-fullstack-with-database.txt +0 -25076
- package/dist/teams/team-fullstack.txt +0 -15820
- package/dist/teams/team-ide-minimal.txt +0 -8285
- package/dist/teams/team-no-ui.txt +0 -14368
- package/docs/GUIDING-PRINCIPLES.md +0 -91
- package/docs/architecture/workflow-coordinator-implementation.md +0 -1188
- package/docs/architecture-sharding-modification.md +0 -623
- package/docs/automated-requirements-analysis-outputs.md +0 -896
- package/docs/core-architecture.md +0 -219
- package/docs/enhanced-ide-development-workflow.md +0 -248
- package/docs/prd/workflow-coordinator-prd.md +0 -1214
- package/docs/user-guide.md +0 -530
- package/docs/versioning-and-releases.md +0 -155
- package/docs/versions.md +0 -48
- package/docs/working-in-the-brownfield.md +0 -597
- package/tools/api-server.js +0 -367
- package/tools/builders/web-builder.js +0 -830
- package/tools/bump-all-versions.js +0 -133
- package/tools/cli.js +0 -157
- package/tools/flattener/aggregate.js +0 -94
- package/tools/flattener/binary.js +0 -83
- package/tools/flattener/discovery.js +0 -79
- package/tools/flattener/files.js +0 -35
- package/tools/flattener/ignoreRules.js +0 -177
- package/tools/flattener/main.js +0 -673
- package/tools/flattener/projectRoot.js +0 -211
- package/tools/flattener/prompts.js +0 -46
- package/tools/flattener/stats.helpers.js +0 -424
- package/tools/flattener/stats.js +0 -80
- package/tools/flattener/test-matrix.js +0 -468
- package/tools/flattener/xml.js +0 -96
- package/tools/installer/README.md +0 -8
- package/tools/installer/bin/xiaoma.js +0 -477
- package/tools/installer/config/ide-agent-config.yaml +0 -58
- package/tools/installer/config/install.config.yaml +0 -164
- package/tools/installer/lib/config-loader.js +0 -286
- package/tools/installer/lib/file-manager.js +0 -446
- package/tools/installer/lib/ide-base-setup.js +0 -238
- package/tools/installer/lib/ide-setup.js +0 -2027
- package/tools/installer/lib/installer.js +0 -2333
- package/tools/installer/lib/memory-profiler.js +0 -235
- package/tools/installer/lib/module-manager.js +0 -116
- package/tools/installer/lib/resource-locator.js +0 -334
- package/tools/installer/package-lock.json +0 -715
- package/tools/installer/package.json +0 -44
- package/tools/lib/dependency-resolver.js +0 -186
- package/tools/lib/yaml-utils.js +0 -34
- package/tools/md-assets/web-agent-startup-instructions.md +0 -39
- package/tools/preview-release-notes.js +0 -74
- package/tools/setup-hooks.sh +0 -37
- package/tools/shared/bannerArt.js +0 -105
- package/tools/sync-installer-version.js +0 -41
- package/tools/sync-version.sh +0 -23
- package/tools/upgraders/v3-to-v4-upgrader.js +0 -753
- package/tools/version-bump.js +0 -100
- package/tools/workflow-coordinator/README.md +0 -38
- package/tools/workflow-coordinator/USAGE.md +0 -548
- package/tools/workflow-coordinator/package-lock.json +0 -4868
- package/tools/workflow-coordinator/package.json +0 -35
- package/tools/workflow-coordinator/src/api/server.js +0 -207
- package/tools/workflow-coordinator/src/controller/workflow-controller.js +0 -263
- package/tools/workflow-coordinator/src/index.js +0 -113
- package/tools/workflow-coordinator/src/parser/workflow-parser.js +0 -144
- package/tools/workflow-coordinator/src/utils/state-manager.js +0 -59
- package/tools/workflow-coordinator/src/utils/validator.js +0 -86
- package/tools/workflow-coordinator/test/integration-test.js +0 -266
- package/tools/workflow-coordinator/test/quick-test.js +0 -127
- package/xiaoma-core/agent-teams/team-all.yaml +0 -15
- package/xiaoma-core/agent-teams/team-fullstack-with-database.yaml +0 -27
- package/xiaoma-core/agent-teams/team-fullstack.yaml +0 -19
- package/xiaoma-core/agent-teams/team-ide-minimal.yaml +0 -11
- package/xiaoma-core/agent-teams/team-no-ui.yaml +0 -14
- package/xiaoma-core/agents/analyst.md +0 -91
- package/xiaoma-core/agents/architect.md +0 -88
- package/xiaoma-core/agents/automated-fix-validator.yaml +0 -579
- package/xiaoma-core/agents/automated-quality-validator.yaml +0 -549
- package/xiaoma-core/agents/automation-orchestrator.md +0 -353
- package/xiaoma-core/agents/dev.md +0 -144
- package/xiaoma-core/agents/enhanced-workflow-orchestrator.yaml +0 -304
- package/xiaoma-core/agents/full-requirement-orchestrator.md +0 -462
- package/xiaoma-core/agents/global-requirements-auditor.yaml +0 -520
- package/xiaoma-core/agents/intelligent-template-adapter.yaml +0 -389
- package/xiaoma-core/agents/issue-dispatcher.yaml +0 -627
- package/xiaoma-core/agents/master-execution-engine.yaml +0 -543
- package/xiaoma-core/agents/pm.md +0 -85
- package/xiaoma-core/agents/po.md +0 -77
- package/xiaoma-core/agents/qa.md +0 -88
- package/xiaoma-core/agents/requirements-coverage-auditor.yaml +0 -373
- package/xiaoma-core/agents/sm.md +0 -125
- package/xiaoma-core/agents/ux-expert.md +0 -67
- package/xiaoma-core/agents/workflow-executor.md +0 -1031
- package/xiaoma-core/agents/workflow-helper.md +0 -481
- package/xiaoma-core/agents/xiaoma-master.md +0 -108
- package/xiaoma-core/agents/xiaoma-orchestrator.md +0 -145
- package/xiaoma-core/checklists/architect-checklist.md +0 -440
- package/xiaoma-core/checklists/change-checklist.md +0 -184
- package/xiaoma-core/checklists/dev-completion-checklist.md +0 -324
- package/xiaoma-core/checklists/pm-checklist.md +0 -372
- package/xiaoma-core/checklists/po-master-checklist.md +0 -434
- package/xiaoma-core/checklists/po-story-validation-checklist.md +0 -219
- package/xiaoma-core/checklists/qa-approval-checklist.md +0 -393
- package/xiaoma-core/checklists/story-dod-checklist.md +0 -96
- package/xiaoma-core/checklists/story-draft-checklist.md +0 -155
- package/xiaoma-core/core-config.yaml +0 -23
- package/xiaoma-core/data/bmad-kb.md +0 -809
- package/xiaoma-core/data/brainstorming-techniques.md +0 -38
- package/xiaoma-core/data/elicitation-methods.md +0 -156
- package/xiaoma-core/data/technical-preferences.md +0 -5
- package/xiaoma-core/data/test-levels-framework.md +0 -148
- package/xiaoma-core/data/test-priorities-matrix.md +0 -174
- package/xiaoma-core/scripts/build-validation/pre-dev-validation.sh +0 -71
- package/xiaoma-core/scripts/build-validation/progressive-validation.sh +0 -88
- package/xiaoma-core/scripts/build-validation/quick-check.sh +0 -69
- package/xiaoma-core/tasks/advanced-elicitation.md +0 -119
- package/xiaoma-core/tasks/analyze-existing-database.md +0 -155
- package/xiaoma-core/tasks/apply-qa-fixes.md +0 -150
- package/xiaoma-core/tasks/automated-story-cycle.md +0 -370
- package/xiaoma-core/tasks/batch-story-generation.md +0 -354
- package/xiaoma-core/tasks/brownfield-create-epic.md +0 -162
- package/xiaoma-core/tasks/brownfield-create-story.md +0 -149
- package/xiaoma-core/tasks/correct-course.md +0 -72
- package/xiaoma-core/tasks/create-brownfield-story.md +0 -314
- package/xiaoma-core/tasks/create-database-design.md +0 -161
- package/xiaoma-core/tasks/create-deep-research-prompt.md +0 -280
- package/xiaoma-core/tasks/create-enhanced-story-with-database.md +0 -250
- package/xiaoma-core/tasks/create-incremental-architecture.md +0 -525
- package/xiaoma-core/tasks/create-next-story.md +0 -114
- package/xiaoma-core/tasks/create-prd-from-rag.md +0 -435
- package/xiaoma-core/tasks/create-story-with-rag.md +0 -559
- package/xiaoma-core/tasks/develop-story-with-rag.md +0 -536
- package/xiaoma-core/tasks/document-project.md +0 -345
- package/xiaoma-core/tasks/facilitate-brainstorming-session.md +0 -138
- package/xiaoma-core/tasks/generate-ai-frontend-prompt.md +0 -53
- package/xiaoma-core/tasks/generate-database-ddl.md +0 -240
- package/xiaoma-core/tasks/generate-database-entities.md +0 -501
- package/xiaoma-core/tasks/generate-rag-questions.md +0 -312
- package/xiaoma-core/tasks/index-docs.md +0 -175
- package/xiaoma-core/tasks/kb-mode-interaction.md +0 -77
- package/xiaoma-core/tasks/nfr-assess.md +0 -345
- package/xiaoma-core/tasks/project-integration-testing.md +0 -477
- package/xiaoma-core/tasks/qa-gate.md +0 -163
- package/xiaoma-core/tasks/requirement-analysis-with-rag.md +0 -1318
- package/xiaoma-core/tasks/requirements-coverage-audit.md +0 -198
- package/xiaoma-core/tasks/review-story.md +0 -316
- package/xiaoma-core/tasks/risk-profile.md +0 -355
- package/xiaoma-core/tasks/serial-development-orchestration.md +0 -426
- package/xiaoma-core/tasks/shard-doc.md +0 -187
- package/xiaoma-core/tasks/test-design.md +0 -176
- package/xiaoma-core/tasks/trace-requirements.md +0 -266
- package/xiaoma-core/tasks/validate-next-story.md +0 -136
- package/xiaoma-core/templates/api-design-tmpl.yaml +0 -704
- package/xiaoma-core/templates/architecture-tmpl.yaml +0 -650
- package/xiaoma-core/templates/brainstorming-output-tmpl.yaml +0 -156
- package/xiaoma-core/templates/brownfield-architecture-tmpl.yaml +0 -476
- package/xiaoma-core/templates/brownfield-prd-tmpl.yaml +0 -280
- package/xiaoma-core/templates/competitor-analysis-tmpl.yaml +0 -336
- package/xiaoma-core/templates/database-design-tmpl.yaml +0 -266
- package/xiaoma-core/templates/enhanced-story-with-database-tmpl.yaml +0 -428
- package/xiaoma-core/templates/front-end-architecture-tmpl.yaml +0 -272
- package/xiaoma-core/templates/front-end-spec-tmpl.yaml +0 -354
- package/xiaoma-core/templates/fullstack-architecture-tmpl.yaml +0 -925
- package/xiaoma-core/templates/global-qa-monitoring-tmpl.yaml +0 -443
- package/xiaoma-core/templates/incremental-architecture-tmpl.yaml +0 -601
- package/xiaoma-core/templates/market-research-tmpl.yaml +0 -252
- package/xiaoma-core/templates/maven-lombok-template.xml +0 -111
- package/xiaoma-core/templates/prd-from-rag-tmpl.yaml +0 -410
- package/xiaoma-core/templates/prd-tmpl.yaml +0 -202
- package/xiaoma-core/templates/project-brief-tmpl.yaml +0 -221
- package/xiaoma-core/templates/qa-gate-tmpl.yaml +0 -102
- package/xiaoma-core/templates/rag-knowledge-tmpl.yaml +0 -569
- package/xiaoma-core/templates/rag-questions-tmpl.yaml +0 -949
- package/xiaoma-core/templates/requirements-coverage-audit.yaml +0 -330
- package/xiaoma-core/templates/start-enhanced-workflow.yaml +0 -347
- package/xiaoma-core/templates/story-tmpl.yaml +0 -137
- package/xiaoma-core/templates/story-with-rag-tmpl.yaml +0 -360
- package/xiaoma-core/workflows/automated-requirements-analysis.yaml +0 -2149
- package/xiaoma-core/workflows/automated-requirements-development.yaml +0 -739
- package/xiaoma-core/workflows/automated-story-development.yaml +0 -1264
- package/xiaoma-core/workflows/brownfield-fullstack.yaml +0 -298
- package/xiaoma-core/workflows/brownfield-service.yaml +0 -188
- package/xiaoma-core/workflows/brownfield-ui.yaml +0 -198
- package/xiaoma-core/workflows/enhanced-fullstack-with-database.yaml +0 -427
- package/xiaoma-core/workflows/enhanced-fullstack-with-qa-loop.yaml +0 -766
- package/xiaoma-core/workflows/full-requirement-automation.yaml +0 -1305
- package/xiaoma-core/workflows/greenfield-fullstack.yaml +0 -241
- package/xiaoma-core/workflows/greenfield-service.yaml +0 -207
- package/xiaoma-core/workflows/greenfield-ui.yaml +0 -236
|
@@ -1,211 +0,0 @@
|
|
|
1
|
-
const fs = require("fs-extra");
|
|
2
|
-
const path = require("node:path");
|
|
3
|
-
|
|
4
|
-
// Deno/Node compatibility: explicitly import process
|
|
5
|
-
const process = require("node:process");
|
|
6
|
-
const { execFile } = require("node:child_process");
|
|
7
|
-
const { promisify } = require("node:util");
|
|
8
|
-
const execFileAsync = promisify(execFile);
|
|
9
|
-
|
|
10
|
-
// Simple memoization across calls (keyed by realpath of startDir)
|
|
11
|
-
const _cache = new Map();
|
|
12
|
-
|
|
13
|
-
async function _tryRun(cmd, args, cwd, timeoutMs = 500) {
|
|
14
|
-
try {
|
|
15
|
-
const { stdout } = await execFileAsync(cmd, args, {
|
|
16
|
-
cwd,
|
|
17
|
-
timeout: timeoutMs,
|
|
18
|
-
windowsHide: true,
|
|
19
|
-
maxBuffer: 1024 * 1024,
|
|
20
|
-
});
|
|
21
|
-
const out = String(stdout || "").trim();
|
|
22
|
-
return out || null;
|
|
23
|
-
} catch {
|
|
24
|
-
return null;
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
async function _detectVcsTopLevel(startDir) {
|
|
29
|
-
// Run common VCS root queries in parallel; ignore failures
|
|
30
|
-
const gitP = _tryRun("git", ["rev-parse", "--show-toplevel"], startDir);
|
|
31
|
-
const hgP = _tryRun("hg", ["root"], startDir);
|
|
32
|
-
const svnP = (async () => {
|
|
33
|
-
const show = await _tryRun(
|
|
34
|
-
"svn",
|
|
35
|
-
["info", "--show-item", "wc-root"],
|
|
36
|
-
startDir,
|
|
37
|
-
);
|
|
38
|
-
if (show) return show;
|
|
39
|
-
const info = await _tryRun("svn", ["info"], startDir);
|
|
40
|
-
if (info) {
|
|
41
|
-
const line = info
|
|
42
|
-
.split(/\r?\n/)
|
|
43
|
-
.find((l) => l.toLowerCase().startsWith("working copy root path:"));
|
|
44
|
-
if (line) return line.split(":").slice(1).join(":").trim();
|
|
45
|
-
}
|
|
46
|
-
return null;
|
|
47
|
-
})();
|
|
48
|
-
const [git, hg, svn] = await Promise.all([gitP, hgP, svnP]);
|
|
49
|
-
return git || hg || svn || null;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* Attempt to find the project root by walking up from startDir.
|
|
54
|
-
* Uses a robust, prioritized set of ecosystem markers (VCS > workspaces/monorepo > lock/build > language config).
|
|
55
|
-
* Also recognizes package.json with "workspaces" as a workspace root.
|
|
56
|
-
* You can augment markers via env PROJECT_ROOT_MARKERS as a comma-separated list of file/dir names.
|
|
57
|
-
* @param {string} startDir
|
|
58
|
-
* @returns {Promise<string|null>} project root directory or null if not found
|
|
59
|
-
*/
|
|
60
|
-
async function findProjectRoot(startDir) {
|
|
61
|
-
try {
|
|
62
|
-
// Resolve symlinks for robustness (e.g., when invoked from a symlinked path)
|
|
63
|
-
let dir = path.resolve(startDir);
|
|
64
|
-
try {
|
|
65
|
-
dir = await fs.realpath(dir);
|
|
66
|
-
} catch {
|
|
67
|
-
// ignore if realpath fails; continue with resolved path
|
|
68
|
-
}
|
|
69
|
-
const startKey = dir; // preserve starting point for caching
|
|
70
|
-
if (_cache.has(startKey)) return _cache.get(startKey);
|
|
71
|
-
const fsRoot = path.parse(dir).root;
|
|
72
|
-
|
|
73
|
-
// Helper to safely check for existence
|
|
74
|
-
const exists = (p) => fs.pathExists(p);
|
|
75
|
-
|
|
76
|
-
// Build checks: an array of { makePath: (dir) => string, weight }
|
|
77
|
-
const checks = [];
|
|
78
|
-
|
|
79
|
-
const add = (rel, weight) => {
|
|
80
|
-
const makePath = (d) =>
|
|
81
|
-
Array.isArray(rel) ? path.join(d, ...rel) : path.join(d, rel);
|
|
82
|
-
checks.push({ makePath, weight });
|
|
83
|
-
};
|
|
84
|
-
|
|
85
|
-
// Highest priority: explicit sentinel markers
|
|
86
|
-
add(".project-root", 110);
|
|
87
|
-
add(".workspace-root", 110);
|
|
88
|
-
add(".repo-root", 110);
|
|
89
|
-
|
|
90
|
-
// Highest priority: VCS roots
|
|
91
|
-
add(".git", 100);
|
|
92
|
-
add(".hg", 95);
|
|
93
|
-
add(".svn", 95);
|
|
94
|
-
|
|
95
|
-
// Monorepo/workspace indicators
|
|
96
|
-
add("pnpm-workspace.yaml", 90);
|
|
97
|
-
add("lerna.json", 90);
|
|
98
|
-
add("turbo.json", 90);
|
|
99
|
-
add("nx.json", 90);
|
|
100
|
-
add("rush.json", 90);
|
|
101
|
-
add("go.work", 90);
|
|
102
|
-
add("WORKSPACE", 90);
|
|
103
|
-
add("WORKSPACE.bazel", 90);
|
|
104
|
-
add("MODULE.bazel", 90);
|
|
105
|
-
add("pants.toml", 90);
|
|
106
|
-
|
|
107
|
-
// Lockfiles and package-manager/top-level locks
|
|
108
|
-
add("yarn.lock", 85);
|
|
109
|
-
add("pnpm-lock.yaml", 85);
|
|
110
|
-
add("package-lock.json", 85);
|
|
111
|
-
add("bun.lockb", 85);
|
|
112
|
-
add("Cargo.lock", 85);
|
|
113
|
-
add("composer.lock", 85);
|
|
114
|
-
add("poetry.lock", 85);
|
|
115
|
-
add("Pipfile.lock", 85);
|
|
116
|
-
add("Gemfile.lock", 85);
|
|
117
|
-
|
|
118
|
-
// Build-system root indicators
|
|
119
|
-
add("settings.gradle", 80);
|
|
120
|
-
add("settings.gradle.kts", 80);
|
|
121
|
-
add("gradlew", 80);
|
|
122
|
-
add("pom.xml", 80);
|
|
123
|
-
add("build.sbt", 80);
|
|
124
|
-
add(["project", "build.properties"], 80);
|
|
125
|
-
|
|
126
|
-
// Language/project config markers
|
|
127
|
-
add("deno.json", 75);
|
|
128
|
-
add("deno.jsonc", 75);
|
|
129
|
-
add("pyproject.toml", 75);
|
|
130
|
-
add("Pipfile", 75);
|
|
131
|
-
add("requirements.txt", 75);
|
|
132
|
-
add("go.mod", 75);
|
|
133
|
-
add("Cargo.toml", 75);
|
|
134
|
-
add("composer.json", 75);
|
|
135
|
-
add("mix.exs", 75);
|
|
136
|
-
add("Gemfile", 75);
|
|
137
|
-
add("CMakeLists.txt", 75);
|
|
138
|
-
add("stack.yaml", 75);
|
|
139
|
-
add("cabal.project", 75);
|
|
140
|
-
add("rebar.config", 75);
|
|
141
|
-
add("pubspec.yaml", 75);
|
|
142
|
-
add("flake.nix", 75);
|
|
143
|
-
add("shell.nix", 75);
|
|
144
|
-
add("default.nix", 75);
|
|
145
|
-
add(".tool-versions", 75);
|
|
146
|
-
add("package.json", 74); // generic Node project (lower than lockfiles/workspaces)
|
|
147
|
-
|
|
148
|
-
// Changesets
|
|
149
|
-
add([".changeset", "config.json"], 70);
|
|
150
|
-
add(".changeset", 70);
|
|
151
|
-
|
|
152
|
-
// Custom markers via env (comma-separated names)
|
|
153
|
-
if (process.env.PROJECT_ROOT_MARKERS) {
|
|
154
|
-
for (const name of process.env.PROJECT_ROOT_MARKERS.split(",")
|
|
155
|
-
.map((s) => s.trim())
|
|
156
|
-
.filter(Boolean)) {
|
|
157
|
-
add(name, 72);
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
/** Check for package.json with "workspaces" */
|
|
162
|
-
const hasWorkspacePackageJson = async (d) => {
|
|
163
|
-
const pkgPath = path.join(d, "package.json");
|
|
164
|
-
if (!(await exists(pkgPath))) return false;
|
|
165
|
-
try {
|
|
166
|
-
const raw = await fs.readFile(pkgPath, "utf8");
|
|
167
|
-
const pkg = JSON.parse(raw);
|
|
168
|
-
return Boolean(pkg && pkg.workspaces);
|
|
169
|
-
} catch {
|
|
170
|
-
return false;
|
|
171
|
-
}
|
|
172
|
-
};
|
|
173
|
-
|
|
174
|
-
let best = null; // { dir, weight }
|
|
175
|
-
|
|
176
|
-
// Try to detect VCS toplevel once up-front; treat as authoritative slightly above .git marker
|
|
177
|
-
const vcsTop = await _detectVcsTopLevel(dir);
|
|
178
|
-
if (vcsTop) {
|
|
179
|
-
best = { dir: vcsTop, weight: 101 };
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
while (true) {
|
|
183
|
-
// Special check: package.json with "workspaces"
|
|
184
|
-
if ((await hasWorkspacePackageJson(dir)) && (!best || 90 >= best.weight))
|
|
185
|
-
best = { dir, weight: 90 };
|
|
186
|
-
|
|
187
|
-
// Evaluate all other checks in parallel
|
|
188
|
-
const results = await Promise.all(
|
|
189
|
-
checks.map(async (c) => ({ c, ok: await exists(c.makePath(dir)) })),
|
|
190
|
-
);
|
|
191
|
-
|
|
192
|
-
for (const { c, ok } of results) {
|
|
193
|
-
if (!ok) continue;
|
|
194
|
-
if (!best || c.weight >= best.weight) {
|
|
195
|
-
best = { dir, weight: c.weight };
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
if (dir === fsRoot) break;
|
|
200
|
-
dir = path.dirname(dir);
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
const out = best ? best.dir : null;
|
|
204
|
-
_cache.set(startKey, out);
|
|
205
|
-
return out;
|
|
206
|
-
} catch {
|
|
207
|
-
return null;
|
|
208
|
-
}
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
module.exports = { findProjectRoot };
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
const os = require("node:os");
|
|
2
|
-
const path = require("node:path");
|
|
3
|
-
const readline = require("node:readline");
|
|
4
|
-
const process = require("node:process");
|
|
5
|
-
|
|
6
|
-
function expandHome(p) {
|
|
7
|
-
if (!p) return p;
|
|
8
|
-
if (p.startsWith("~")) return path.join(os.homedir(), p.slice(1));
|
|
9
|
-
return p;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
function createRl() {
|
|
13
|
-
return readline.createInterface({
|
|
14
|
-
input: process.stdin,
|
|
15
|
-
output: process.stdout,
|
|
16
|
-
});
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
function promptQuestion(question) {
|
|
20
|
-
return new Promise((resolve) => {
|
|
21
|
-
const rl = createRl();
|
|
22
|
-
rl.question(question, (answer) => {
|
|
23
|
-
rl.close();
|
|
24
|
-
resolve(answer);
|
|
25
|
-
});
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
async function promptYesNo(question, defaultYes = true) {
|
|
30
|
-
const suffix = defaultYes ? " [Y/n] " : " [y/N] ";
|
|
31
|
-
const ans = (await promptQuestion(`${question}${suffix}`))
|
|
32
|
-
.trim()
|
|
33
|
-
.toLowerCase();
|
|
34
|
-
if (!ans) return defaultYes;
|
|
35
|
-
if (["y", "yes"].includes(ans)) return true;
|
|
36
|
-
if (["n", "no"].includes(ans)) return false;
|
|
37
|
-
return promptYesNo(question, defaultYes);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
async function promptPath(question, defaultValue) {
|
|
41
|
-
const prompt = `${question}${defaultValue ? ` (default: ${defaultValue})` : ""}: `;
|
|
42
|
-
const ans = (await promptQuestion(prompt)).trim();
|
|
43
|
-
return expandHome(ans || defaultValue);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
module.exports = { promptYesNo, promptPath, promptQuestion, expandHome };
|
|
@@ -1,424 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
const fs = require("node:fs/promises");
|
|
4
|
-
const path = require("node:path");
|
|
5
|
-
const zlib = require("node:zlib");
|
|
6
|
-
const { Buffer } = require("node:buffer");
|
|
7
|
-
const crypto = require("node:crypto");
|
|
8
|
-
const cp = require("node:child_process");
|
|
9
|
-
|
|
10
|
-
const KB = 1024;
|
|
11
|
-
const MB = 1024 * KB;
|
|
12
|
-
|
|
13
|
-
const formatSize = (bytes) => {
|
|
14
|
-
if (bytes < 1024) return `${bytes} B`;
|
|
15
|
-
if (bytes < 1024 * 1024) return `${(bytes / 1024).toFixed(1)} KB`;
|
|
16
|
-
if (bytes < 1024 * 1024 * 1024)
|
|
17
|
-
return `${(bytes / (1024 * 1024)).toFixed(1)} MB`;
|
|
18
|
-
return `${(bytes / (1024 * 1024 * 1024)).toFixed(2)} GB`;
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
const percentile = (sorted, p) => {
|
|
22
|
-
if (sorted.length === 0) return 0;
|
|
23
|
-
const idx = Math.min(
|
|
24
|
-
sorted.length - 1,
|
|
25
|
-
Math.max(0, Math.ceil((p / 100) * sorted.length) - 1),
|
|
26
|
-
);
|
|
27
|
-
return sorted[idx];
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
async function processWithLimit(items, fn, concurrency = 64) {
|
|
31
|
-
for (let i = 0; i < items.length; i += concurrency) {
|
|
32
|
-
await Promise.all(items.slice(i, i + concurrency).map(fn));
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
async function enrichAllFiles(textFiles, binaryFiles) {
|
|
37
|
-
/** @type {Array<{ path: string; absolutePath: string; size: number; lines?: number; isBinary: boolean; ext: string; dir: string; depth: number; hidden: boolean; mtimeMs: number; isSymlink: boolean; }>} */
|
|
38
|
-
const allFiles = [];
|
|
39
|
-
|
|
40
|
-
async function enrich(file, isBinary) {
|
|
41
|
-
const ext = (path.extname(file.path) || "").toLowerCase();
|
|
42
|
-
const dir = path.dirname(file.path) || ".";
|
|
43
|
-
const depth = file.path.split(path.sep).filter(Boolean).length;
|
|
44
|
-
const hidden = file.path.split(path.sep).some((seg) => seg.startsWith("."));
|
|
45
|
-
let mtimeMs = 0;
|
|
46
|
-
let isSymlink = false;
|
|
47
|
-
try {
|
|
48
|
-
const lst = await fs.lstat(file.absolutePath);
|
|
49
|
-
mtimeMs = lst.mtimeMs;
|
|
50
|
-
isSymlink = lst.isSymbolicLink();
|
|
51
|
-
} catch {
|
|
52
|
-
/* ignore lstat errors during enrichment */
|
|
53
|
-
}
|
|
54
|
-
allFiles.push({
|
|
55
|
-
path: file.path,
|
|
56
|
-
absolutePath: file.absolutePath,
|
|
57
|
-
size: file.size || 0,
|
|
58
|
-
lines: file.lines,
|
|
59
|
-
isBinary,
|
|
60
|
-
ext,
|
|
61
|
-
dir,
|
|
62
|
-
depth,
|
|
63
|
-
hidden,
|
|
64
|
-
mtimeMs,
|
|
65
|
-
isSymlink,
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
await processWithLimit(textFiles, (f) => enrich(f, false));
|
|
70
|
-
await processWithLimit(binaryFiles, (f) => enrich(f, true));
|
|
71
|
-
return allFiles;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
function buildHistogram(allFiles) {
|
|
75
|
-
const buckets = [
|
|
76
|
-
[1 * KB, "0–1KB"],
|
|
77
|
-
[10 * KB, "1–10KB"],
|
|
78
|
-
[100 * KB, "10–100KB"],
|
|
79
|
-
[1 * MB, "100KB–1MB"],
|
|
80
|
-
[10 * MB, "1–10MB"],
|
|
81
|
-
[100 * MB, "10–100MB"],
|
|
82
|
-
[Infinity, ">=100MB"],
|
|
83
|
-
];
|
|
84
|
-
const histogram = buckets.map(([_, label]) => ({
|
|
85
|
-
label,
|
|
86
|
-
count: 0,
|
|
87
|
-
bytes: 0,
|
|
88
|
-
}));
|
|
89
|
-
for (const f of allFiles) {
|
|
90
|
-
for (const [i, bucket] of buckets.entries()) {
|
|
91
|
-
if (f.size < bucket[0]) {
|
|
92
|
-
histogram[i].count++;
|
|
93
|
-
histogram[i].bytes += f.size;
|
|
94
|
-
break;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
return histogram;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
function aggregateByExtension(allFiles) {
|
|
102
|
-
const byExtension = new Map();
|
|
103
|
-
for (const f of allFiles) {
|
|
104
|
-
const key = f.ext || "<none>";
|
|
105
|
-
const v = byExtension.get(key) || { ext: key, count: 0, bytes: 0 };
|
|
106
|
-
v.count++;
|
|
107
|
-
v.bytes += f.size;
|
|
108
|
-
byExtension.set(key, v);
|
|
109
|
-
}
|
|
110
|
-
return [...byExtension.values()].sort((a, b) => b.bytes - a.bytes);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
function aggregateByDirectory(allFiles) {
|
|
114
|
-
const byDirectory = new Map();
|
|
115
|
-
function addDirBytes(dir, bytes) {
|
|
116
|
-
const v = byDirectory.get(dir) || { dir, count: 0, bytes: 0 };
|
|
117
|
-
v.count++;
|
|
118
|
-
v.bytes += bytes;
|
|
119
|
-
byDirectory.set(dir, v);
|
|
120
|
-
}
|
|
121
|
-
for (const f of allFiles) {
|
|
122
|
-
const parts = f.dir === "." ? [] : f.dir.split(path.sep);
|
|
123
|
-
let acc = "";
|
|
124
|
-
for (let i = 0; i < parts.length; i++) {
|
|
125
|
-
acc = i === 0 ? parts[0] : acc + path.sep + parts[i];
|
|
126
|
-
addDirBytes(acc, f.size);
|
|
127
|
-
}
|
|
128
|
-
if (parts.length === 0) addDirBytes(".", f.size);
|
|
129
|
-
}
|
|
130
|
-
return [...byDirectory.values()].sort((a, b) => b.bytes - a.bytes);
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
function computeDepthAndLongest(allFiles) {
|
|
134
|
-
const depthDistribution = new Map();
|
|
135
|
-
for (const f of allFiles) {
|
|
136
|
-
depthDistribution.set(f.depth, (depthDistribution.get(f.depth) || 0) + 1);
|
|
137
|
-
}
|
|
138
|
-
const longestPaths = [...allFiles]
|
|
139
|
-
.sort((a, b) => b.path.length - a.path.length)
|
|
140
|
-
.slice(0, 25)
|
|
141
|
-
.map((f) => ({ path: f.path, length: f.path.length, size: f.size }));
|
|
142
|
-
const depthDist = [...depthDistribution.entries()]
|
|
143
|
-
.sort((a, b) => a[0] - b[0])
|
|
144
|
-
.map(([depth, count]) => ({ depth, count }));
|
|
145
|
-
return { depthDist, longestPaths };
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
function computeTemporal(allFiles, nowMs) {
|
|
149
|
-
let oldest = null,
|
|
150
|
-
newest = null;
|
|
151
|
-
const ageBuckets = [
|
|
152
|
-
{ label: "> 1 year", minDays: 365, maxDays: Infinity, count: 0, bytes: 0 },
|
|
153
|
-
{ label: "6–12 months", minDays: 180, maxDays: 365, count: 0, bytes: 0 },
|
|
154
|
-
{ label: "1–6 months", minDays: 30, maxDays: 180, count: 0, bytes: 0 },
|
|
155
|
-
{ label: "7–30 days", minDays: 7, maxDays: 30, count: 0, bytes: 0 },
|
|
156
|
-
{ label: "1–7 days", minDays: 1, maxDays: 7, count: 0, bytes: 0 },
|
|
157
|
-
{ label: "< 1 day", minDays: 0, maxDays: 1, count: 0, bytes: 0 },
|
|
158
|
-
];
|
|
159
|
-
for (const f of allFiles) {
|
|
160
|
-
const ageDays = Math.max(
|
|
161
|
-
0,
|
|
162
|
-
(nowMs - (f.mtimeMs || nowMs)) / (24 * 60 * 60 * 1000),
|
|
163
|
-
);
|
|
164
|
-
for (const b of ageBuckets) {
|
|
165
|
-
if (ageDays >= b.minDays && ageDays < b.maxDays) {
|
|
166
|
-
b.count++;
|
|
167
|
-
b.bytes += f.size;
|
|
168
|
-
break;
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
if (!oldest || f.mtimeMs < oldest.mtimeMs) oldest = f;
|
|
172
|
-
if (!newest || f.mtimeMs > newest.mtimeMs) newest = f;
|
|
173
|
-
}
|
|
174
|
-
return {
|
|
175
|
-
oldest: oldest
|
|
176
|
-
? {
|
|
177
|
-
path: oldest.path,
|
|
178
|
-
mtime: oldest.mtimeMs ? new Date(oldest.mtimeMs).toISOString() : null,
|
|
179
|
-
}
|
|
180
|
-
: null,
|
|
181
|
-
newest: newest
|
|
182
|
-
? {
|
|
183
|
-
path: newest.path,
|
|
184
|
-
mtime: newest.mtimeMs ? new Date(newest.mtimeMs).toISOString() : null,
|
|
185
|
-
}
|
|
186
|
-
: null,
|
|
187
|
-
ageBuckets,
|
|
188
|
-
};
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
function computeQuality(allFiles, textFiles) {
|
|
192
|
-
const zeroByteFiles = allFiles.filter((f) => f.size === 0).length;
|
|
193
|
-
const emptyTextFiles = textFiles.filter(
|
|
194
|
-
(f) => (f.size || 0) === 0 || (f.lines || 0) === 0,
|
|
195
|
-
).length;
|
|
196
|
-
const hiddenFiles = allFiles.filter((f) => f.hidden).length;
|
|
197
|
-
const symlinks = allFiles.filter((f) => f.isSymlink).length;
|
|
198
|
-
const largeThreshold = 50 * MB;
|
|
199
|
-
const suspiciousThreshold = 100 * MB;
|
|
200
|
-
const largeFilesCount = allFiles.filter(
|
|
201
|
-
(f) => f.size >= largeThreshold,
|
|
202
|
-
).length;
|
|
203
|
-
const suspiciousLargeFilesCount = allFiles.filter(
|
|
204
|
-
(f) => f.size >= suspiciousThreshold,
|
|
205
|
-
).length;
|
|
206
|
-
return {
|
|
207
|
-
zeroByteFiles,
|
|
208
|
-
emptyTextFiles,
|
|
209
|
-
hiddenFiles,
|
|
210
|
-
symlinks,
|
|
211
|
-
largeFilesCount,
|
|
212
|
-
suspiciousLargeFilesCount,
|
|
213
|
-
largeThreshold,
|
|
214
|
-
};
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
function computeDuplicates(allFiles, textFiles) {
|
|
218
|
-
const duplicatesBySize = new Map();
|
|
219
|
-
for (const f of allFiles) {
|
|
220
|
-
const key = String(f.size);
|
|
221
|
-
const arr = duplicatesBySize.get(key) || [];
|
|
222
|
-
arr.push(f);
|
|
223
|
-
duplicatesBySize.set(key, arr);
|
|
224
|
-
}
|
|
225
|
-
const duplicateCandidates = [];
|
|
226
|
-
for (const [sizeKey, arr] of duplicatesBySize.entries()) {
|
|
227
|
-
if (arr.length < 2) continue;
|
|
228
|
-
const textGroup = arr.filter((f) => !f.isBinary);
|
|
229
|
-
const otherGroup = arr.filter((f) => f.isBinary);
|
|
230
|
-
const contentHashGroups = new Map();
|
|
231
|
-
for (const tf of textGroup) {
|
|
232
|
-
try {
|
|
233
|
-
const src = textFiles.find((x) => x.absolutePath === tf.absolutePath);
|
|
234
|
-
const content = src ? src.content : "";
|
|
235
|
-
const h = crypto.createHash("sha1").update(content).digest("hex");
|
|
236
|
-
const g = contentHashGroups.get(h) || [];
|
|
237
|
-
g.push(tf);
|
|
238
|
-
contentHashGroups.set(h, g);
|
|
239
|
-
} catch {
|
|
240
|
-
/* ignore hashing errors for duplicate detection */
|
|
241
|
-
}
|
|
242
|
-
}
|
|
243
|
-
for (const [_h, g] of contentHashGroups.entries()) {
|
|
244
|
-
if (g.length > 1)
|
|
245
|
-
duplicateCandidates.push({
|
|
246
|
-
reason: "same-size+text-hash",
|
|
247
|
-
size: Number(sizeKey),
|
|
248
|
-
count: g.length,
|
|
249
|
-
files: g.map((f) => f.path),
|
|
250
|
-
});
|
|
251
|
-
}
|
|
252
|
-
if (otherGroup.length > 1) {
|
|
253
|
-
duplicateCandidates.push({
|
|
254
|
-
reason: "same-size",
|
|
255
|
-
size: Number(sizeKey),
|
|
256
|
-
count: otherGroup.length,
|
|
257
|
-
files: otherGroup.map((f) => f.path),
|
|
258
|
-
});
|
|
259
|
-
}
|
|
260
|
-
}
|
|
261
|
-
return duplicateCandidates;
|
|
262
|
-
}
|
|
263
|
-
|
|
264
|
-
function estimateCompressibility(textFiles) {
|
|
265
|
-
let compSampleBytes = 0;
|
|
266
|
-
let compCompressedBytes = 0;
|
|
267
|
-
for (const tf of textFiles) {
|
|
268
|
-
try {
|
|
269
|
-
const sampleLen = Math.min(256 * 1024, tf.size || 0);
|
|
270
|
-
if (sampleLen <= 0) continue;
|
|
271
|
-
const sample = tf.content.slice(0, sampleLen);
|
|
272
|
-
const gz = zlib.gzipSync(Buffer.from(sample, "utf8"));
|
|
273
|
-
compSampleBytes += sampleLen;
|
|
274
|
-
compCompressedBytes += gz.length;
|
|
275
|
-
} catch {
|
|
276
|
-
/* ignore compression errors during sampling */
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
return compSampleBytes > 0 ? compCompressedBytes / compSampleBytes : null;
|
|
280
|
-
}
|
|
281
|
-
|
|
282
|
-
function computeGitInfo(allFiles, rootDir, largeThreshold) {
|
|
283
|
-
const info = {
|
|
284
|
-
isRepo: false,
|
|
285
|
-
trackedCount: 0,
|
|
286
|
-
trackedBytes: 0,
|
|
287
|
-
untrackedCount: 0,
|
|
288
|
-
untrackedBytes: 0,
|
|
289
|
-
lfsCandidates: [],
|
|
290
|
-
};
|
|
291
|
-
try {
|
|
292
|
-
if (!rootDir) return info;
|
|
293
|
-
const top = cp
|
|
294
|
-
.execFileSync("git", ["rev-parse", "--show-toplevel"], {
|
|
295
|
-
cwd: rootDir,
|
|
296
|
-
stdio: ["ignore", "pipe", "ignore"],
|
|
297
|
-
})
|
|
298
|
-
.toString()
|
|
299
|
-
.trim();
|
|
300
|
-
if (!top) return info;
|
|
301
|
-
info.isRepo = true;
|
|
302
|
-
const out = cp.execFileSync("git", ["ls-files", "-z"], {
|
|
303
|
-
cwd: rootDir,
|
|
304
|
-
stdio: ["ignore", "pipe", "ignore"],
|
|
305
|
-
});
|
|
306
|
-
const tracked = new Set(out.toString().split("\0").filter(Boolean));
|
|
307
|
-
let trackedBytes = 0,
|
|
308
|
-
trackedCount = 0,
|
|
309
|
-
untrackedBytes = 0,
|
|
310
|
-
untrackedCount = 0;
|
|
311
|
-
const lfsCandidates = [];
|
|
312
|
-
for (const f of allFiles) {
|
|
313
|
-
const isTracked = tracked.has(f.path);
|
|
314
|
-
if (isTracked) {
|
|
315
|
-
trackedCount++;
|
|
316
|
-
trackedBytes += f.size;
|
|
317
|
-
if (f.size >= largeThreshold)
|
|
318
|
-
lfsCandidates.push({ path: f.path, size: f.size });
|
|
319
|
-
} else {
|
|
320
|
-
untrackedCount++;
|
|
321
|
-
untrackedBytes += f.size;
|
|
322
|
-
}
|
|
323
|
-
}
|
|
324
|
-
info.trackedCount = trackedCount;
|
|
325
|
-
info.trackedBytes = trackedBytes;
|
|
326
|
-
info.untrackedCount = untrackedCount;
|
|
327
|
-
info.untrackedBytes = untrackedBytes;
|
|
328
|
-
info.lfsCandidates = lfsCandidates
|
|
329
|
-
.sort((a, b) => b.size - a.size)
|
|
330
|
-
.slice(0, 50);
|
|
331
|
-
} catch {
|
|
332
|
-
/* git not available or not a repo, ignore */
|
|
333
|
-
}
|
|
334
|
-
return info;
|
|
335
|
-
}
|
|
336
|
-
|
|
337
|
-
function computeLargestFiles(allFiles, totalBytes) {
|
|
338
|
-
const toPct = (num, den) => (den === 0 ? 0 : (num / den) * 100);
|
|
339
|
-
return [...allFiles]
|
|
340
|
-
.sort((a, b) => b.size - a.size)
|
|
341
|
-
.slice(0, 50)
|
|
342
|
-
.map((f) => ({
|
|
343
|
-
path: f.path,
|
|
344
|
-
size: f.size,
|
|
345
|
-
sizeFormatted: formatSize(f.size),
|
|
346
|
-
percentOfTotal: toPct(f.size, totalBytes),
|
|
347
|
-
ext: f.ext || "",
|
|
348
|
-
isBinary: f.isBinary,
|
|
349
|
-
mtime: f.mtimeMs ? new Date(f.mtimeMs).toISOString() : null,
|
|
350
|
-
}));
|
|
351
|
-
}
|
|
352
|
-
|
|
353
|
-
function mdTable(rows, headers) {
|
|
354
|
-
const header = `| ${headers.join(" | ")} |`;
|
|
355
|
-
const sep = `| ${headers.map(() => "---").join(" | ")} |`;
|
|
356
|
-
const body = rows.map((r) => `| ${r.join(" | ")} |`).join("\n");
|
|
357
|
-
return `${header}\n${sep}\n${body}`;
|
|
358
|
-
}
|
|
359
|
-
|
|
360
|
-
function buildMarkdownReport(
|
|
361
|
-
largestFiles,
|
|
362
|
-
byExtensionArr,
|
|
363
|
-
byDirectoryArr,
|
|
364
|
-
totalBytes,
|
|
365
|
-
) {
|
|
366
|
-
const toPct = (num, den) => (den === 0 ? 0 : (num / den) * 100);
|
|
367
|
-
const md = [];
|
|
368
|
-
md.push(
|
|
369
|
-
"\n### Top Largest Files (Top 50)\n",
|
|
370
|
-
mdTable(
|
|
371
|
-
largestFiles.map((f) => [
|
|
372
|
-
f.path,
|
|
373
|
-
f.sizeFormatted,
|
|
374
|
-
`${f.percentOfTotal.toFixed(2)}%`,
|
|
375
|
-
f.ext || "",
|
|
376
|
-
f.isBinary ? "binary" : "text",
|
|
377
|
-
]),
|
|
378
|
-
["Path", "Size", "% of total", "Ext", "Type"],
|
|
379
|
-
),
|
|
380
|
-
"\n\n### Top Extensions by Bytes (Top 20)\n",
|
|
381
|
-
);
|
|
382
|
-
const topExtRows = byExtensionArr
|
|
383
|
-
.slice(0, 20)
|
|
384
|
-
.map((e) => [
|
|
385
|
-
e.ext,
|
|
386
|
-
String(e.count),
|
|
387
|
-
formatSize(e.bytes),
|
|
388
|
-
`${toPct(e.bytes, totalBytes).toFixed(2)}%`,
|
|
389
|
-
]);
|
|
390
|
-
md.push(
|
|
391
|
-
mdTable(topExtRows, ["Ext", "Count", "Bytes", "% of total"]),
|
|
392
|
-
"\n\n### Top Directories by Bytes (Top 20)\n",
|
|
393
|
-
);
|
|
394
|
-
const topDirRows = byDirectoryArr
|
|
395
|
-
.slice(0, 20)
|
|
396
|
-
.map((d) => [
|
|
397
|
-
d.dir,
|
|
398
|
-
String(d.count),
|
|
399
|
-
formatSize(d.bytes),
|
|
400
|
-
`${toPct(d.bytes, totalBytes).toFixed(2)}%`,
|
|
401
|
-
]);
|
|
402
|
-
md.push(mdTable(topDirRows, ["Directory", "Files", "Bytes", "% of total"]));
|
|
403
|
-
return md.join("\n");
|
|
404
|
-
}
|
|
405
|
-
|
|
406
|
-
module.exports = {
|
|
407
|
-
KB,
|
|
408
|
-
MB,
|
|
409
|
-
formatSize,
|
|
410
|
-
percentile,
|
|
411
|
-
processWithLimit,
|
|
412
|
-
enrichAllFiles,
|
|
413
|
-
buildHistogram,
|
|
414
|
-
aggregateByExtension,
|
|
415
|
-
aggregateByDirectory,
|
|
416
|
-
computeDepthAndLongest,
|
|
417
|
-
computeTemporal,
|
|
418
|
-
computeQuality,
|
|
419
|
-
computeDuplicates,
|
|
420
|
-
estimateCompressibility,
|
|
421
|
-
computeGitInfo,
|
|
422
|
-
computeLargestFiles,
|
|
423
|
-
buildMarkdownReport,
|
|
424
|
-
};
|