@girardelli/architect 5.0.0 → 6.0.0
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/.agent/INDEX.md +197 -0
- package/.agent/agents/AGENT-ORCHESTRATOR.md +408 -0
- package/.agent/agents/QA-TEST-ENGINEER.md +152 -0
- package/.agent/agents/SECURITY-AUDITOR.md +87 -0
- package/.agent/agents/TECH-DEBT-CONTROLLER.md +154 -0
- package/.agent/agents/TYPESCRIPT-BACKEND-DEVELOPER.md +484 -0
- package/.agent/guards/CODE-REVIEW-CHECKLIST.md +94 -0
- package/.agent/guards/PREFLIGHT.md +200 -0
- package/.agent/guards/QUALITY-GATES.md +212 -0
- package/.agent/hooks/post-analysis.sh +64 -0
- package/.agent/hooks/pre-commit.sh +68 -0
- package/.agent/hooks/pre-push.sh +59 -0
- package/.agent/rules/00-general.md +229 -0
- package/.agent/rules/01-architecture.md +182 -0
- package/.agent/rules/02-security.md +388 -0
- package/.agent/skills/ARCHITECT-INTEGRATION.md +103 -0
- package/.agent/skills/CI-PIPELINE.md +113 -0
- package/.agent/skills/PROJECT-PATTERNS.md +62 -0
- package/.agent/templates/ADR.md +95 -0
- package/.agent/templates/BDD.md +57 -0
- package/.agent/templates/C4.md +67 -0
- package/.agent/templates/TDD.md +86 -0
- package/.agent/templates/THREAT-MODEL.md +63 -0
- package/.agent/workflows/fix-bug.md +228 -0
- package/.agent/workflows/new-feature.md +311 -0
- package/.agent/workflows/review.md +95 -0
- package/.github/workflows/ci.yml +43 -0
- package/.github/workflows/publish.yml +40 -0
- package/README.md +6 -2
- package/architect-report--girardelli-architect.json +5332 -0
- package/architect-run.sh +6 -10
- package/debug.js +6 -0
- package/dist/adapters/cli.d.ts +14 -0
- package/dist/adapters/cli.d.ts.map +1 -0
- package/dist/{cli.js → adapters/cli.js} +11 -8
- package/dist/adapters/cli.js.map +1 -0
- package/dist/adapters/html-reporter/scripts.d.ts +6 -0
- package/dist/adapters/html-reporter/scripts.d.ts.map +1 -0
- package/dist/adapters/html-reporter/scripts.js +400 -0
- package/dist/adapters/html-reporter/scripts.js.map +1 -0
- package/dist/adapters/html-reporter/sections/agents.d.ts +3 -0
- package/dist/adapters/html-reporter/sections/agents.d.ts.map +1 -0
- package/dist/adapters/html-reporter/sections/agents.js +259 -0
- package/dist/adapters/html-reporter/sections/agents.js.map +1 -0
- package/dist/adapters/html-reporter/sections/anti-patterns.d.ts +14 -0
- package/dist/adapters/html-reporter/sections/anti-patterns.d.ts.map +1 -0
- package/dist/adapters/html-reporter/sections/anti-patterns.js +64 -0
- package/dist/adapters/html-reporter/sections/anti-patterns.js.map +1 -0
- package/dist/adapters/html-reporter/sections/header.d.ts +4 -0
- package/dist/adapters/html-reporter/sections/header.d.ts.map +1 -0
- package/dist/adapters/html-reporter/sections/header.js +30 -0
- package/dist/adapters/html-reporter/sections/header.js.map +1 -0
- package/dist/adapters/html-reporter/sections/layers.d.ts +10 -0
- package/dist/adapters/html-reporter/sections/layers.d.ts.map +1 -0
- package/dist/adapters/html-reporter/sections/layers.js +143 -0
- package/dist/adapters/html-reporter/sections/layers.js.map +1 -0
- package/dist/adapters/html-reporter/sections/overview.d.ts +3 -0
- package/dist/adapters/html-reporter/sections/overview.d.ts.map +1 -0
- package/dist/adapters/html-reporter/sections/overview.js +58 -0
- package/dist/adapters/html-reporter/sections/overview.js.map +1 -0
- package/dist/adapters/html-reporter/sections/refactoring-plan.d.ts +4 -0
- package/dist/adapters/html-reporter/sections/refactoring-plan.d.ts.map +1 -0
- package/dist/adapters/html-reporter/sections/refactoring-plan.js +151 -0
- package/dist/adapters/html-reporter/sections/refactoring-plan.js.map +1 -0
- package/dist/adapters/html-reporter/sections/score.d.ts +8 -0
- package/dist/adapters/html-reporter/sections/score.d.ts.map +1 -0
- package/dist/adapters/html-reporter/sections/score.js +69 -0
- package/dist/adapters/html-reporter/sections/score.js.map +1 -0
- package/dist/adapters/html-reporter/sections/suggestions.d.ts +8 -0
- package/dist/adapters/html-reporter/sections/suggestions.d.ts.map +1 -0
- package/dist/adapters/html-reporter/sections/suggestions.js +34 -0
- package/dist/adapters/html-reporter/sections/suggestions.js.map +1 -0
- package/dist/adapters/html-reporter/styles.d.ts +2 -0
- package/dist/adapters/html-reporter/styles.d.ts.map +1 -0
- package/dist/adapters/html-reporter/styles.js +526 -0
- package/dist/adapters/html-reporter/styles.js.map +1 -0
- package/dist/adapters/html-reporter/utils.d.ts +27 -0
- package/dist/adapters/html-reporter/utils.d.ts.map +1 -0
- package/dist/adapters/html-reporter/utils.js +82 -0
- package/dist/adapters/html-reporter/utils.js.map +1 -0
- package/dist/adapters/html-reporter/utils_adapters.d.ts +21 -0
- package/dist/adapters/html-reporter/utils_adapters.d.ts.map +1 -0
- package/dist/adapters/html-reporter/utils_adapters.js +32 -0
- package/dist/adapters/html-reporter/utils_adapters.js.map +1 -0
- package/dist/adapters/html-reporter/utils_sections.d.ts +8 -0
- package/dist/adapters/html-reporter/utils_sections.d.ts.map +1 -0
- package/dist/adapters/html-reporter/utils_sections.js +58 -0
- package/dist/adapters/html-reporter/utils_sections.js.map +1 -0
- package/dist/adapters/html-reporter.d.ts +9 -0
- package/dist/adapters/html-reporter.d.ts.map +1 -0
- package/dist/adapters/html-reporter.js +87 -0
- package/dist/adapters/html-reporter.js.map +1 -0
- package/dist/adapters/html-reporter_deps.d.ts +15 -0
- package/dist/adapters/html-reporter_deps.d.ts.map +1 -0
- package/dist/adapters/html-reporter_deps.js +12 -0
- package/dist/adapters/html-reporter_deps.js.map +1 -0
- package/dist/adapters/refactor-reporter.d.ts +20 -0
- package/dist/adapters/refactor-reporter.d.ts.map +1 -0
- package/dist/adapters/refactor-reporter.js +389 -0
- package/dist/adapters/refactor-reporter.js.map +1 -0
- package/dist/adapters/reporter.d.ts +13 -0
- package/dist/adapters/reporter.d.ts.map +1 -0
- package/dist/adapters/reporter.js +135 -0
- package/dist/adapters/reporter.js.map +1 -0
- package/dist/agent-generator/context-enricher.d.ts +4 -47
- package/dist/agent-generator/context-enricher.d.ts.map +1 -1
- package/dist/agent-generator/context-enricher.js +13 -573
- package/dist/agent-generator/context-enricher.js.map +1 -1
- package/dist/agent-generator/detectors/base-detector.d.ts +9 -0
- package/dist/agent-generator/detectors/base-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/base-detector.js +12 -0
- package/dist/agent-generator/detectors/base-detector.js.map +1 -0
- package/dist/agent-generator/detectors/dart-detector.d.ts +6 -0
- package/dist/agent-generator/detectors/dart-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/dart-detector.js +15 -0
- package/dist/agent-generator/detectors/dart-detector.js.map +1 -0
- package/dist/agent-generator/detectors/framework-registry.d.ts +6 -0
- package/dist/agent-generator/detectors/framework-registry.d.ts.map +1 -0
- package/dist/agent-generator/detectors/framework-registry.js +81 -0
- package/dist/agent-generator/detectors/framework-registry.js.map +1 -0
- package/dist/agent-generator/detectors/go-detector.d.ts +6 -0
- package/dist/agent-generator/detectors/go-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/go-detector.js +25 -0
- package/dist/agent-generator/detectors/go-detector.js.map +1 -0
- package/dist/agent-generator/detectors/java-detector.d.ts +6 -0
- package/dist/agent-generator/detectors/java-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/java-detector.js +44 -0
- package/dist/agent-generator/detectors/java-detector.js.map +1 -0
- package/dist/agent-generator/detectors/node-detector.d.ts +6 -0
- package/dist/agent-generator/detectors/node-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/node-detector.js +28 -0
- package/dist/agent-generator/detectors/node-detector.js.map +1 -0
- package/dist/agent-generator/detectors/php-detector.d.ts +6 -0
- package/dist/agent-generator/detectors/php-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/php-detector.js +28 -0
- package/dist/agent-generator/detectors/php-detector.js.map +1 -0
- package/dist/agent-generator/detectors/python-detector.d.ts +8 -0
- package/dist/agent-generator/detectors/python-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/python-detector.js +116 -0
- package/dist/agent-generator/detectors/python-detector.js.map +1 -0
- package/dist/agent-generator/detectors/ruby-detector.d.ts +6 -0
- package/dist/agent-generator/detectors/ruby-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/ruby-detector.js +22 -0
- package/dist/agent-generator/detectors/ruby-detector.js.map +1 -0
- package/dist/agent-generator/detectors/rust-detector.d.ts +6 -0
- package/dist/agent-generator/detectors/rust-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/rust-detector.js +18 -0
- package/dist/agent-generator/detectors/rust-detector.js.map +1 -0
- package/dist/agent-generator/detectors/structure-detector.d.ts +5 -0
- package/dist/agent-generator/detectors/structure-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/structure-detector.js +35 -0
- package/dist/agent-generator/detectors/structure-detector.js.map +1 -0
- package/dist/agent-generator/detectors/toolchain-detector.d.ts +6 -0
- package/dist/agent-generator/detectors/toolchain-detector.d.ts.map +1 -0
- package/dist/agent-generator/detectors/toolchain-detector.js +163 -0
- package/dist/agent-generator/detectors/toolchain-detector.js.map +1 -0
- package/dist/agent-generator/engines/audit-engine.d.ts +7 -0
- package/dist/agent-generator/engines/audit-engine.d.ts.map +1 -0
- package/dist/agent-generator/engines/audit-engine.js +84 -0
- package/dist/agent-generator/engines/audit-engine.js.map +1 -0
- package/dist/agent-generator/engines/context-builder.d.ts +11 -0
- package/dist/agent-generator/engines/context-builder.d.ts.map +1 -0
- package/dist/agent-generator/engines/context-builder.js +86 -0
- package/dist/agent-generator/engines/context-builder.js.map +1 -0
- package/dist/agent-generator/engines/generation-engine.d.ts +9 -0
- package/dist/agent-generator/engines/generation-engine.d.ts.map +1 -0
- package/dist/agent-generator/engines/generation-engine.js +177 -0
- package/dist/agent-generator/engines/generation-engine.js.map +1 -0
- package/dist/agent-generator/engines/suggestion-engine.d.ts +15 -0
- package/dist/agent-generator/engines/suggestion-engine.d.ts.map +1 -0
- package/dist/agent-generator/engines/suggestion-engine.js +176 -0
- package/dist/agent-generator/engines/suggestion-engine.js.map +1 -0
- package/dist/agent-generator/enrichers/analysis-helpers.d.ts +9 -0
- package/dist/agent-generator/enrichers/analysis-helpers.d.ts.map +1 -0
- package/dist/agent-generator/enrichers/analysis-helpers.js +51 -0
- package/dist/agent-generator/enrichers/analysis-helpers.js.map +1 -0
- package/dist/agent-generator/enrichers/description-generator.d.ts +5 -0
- package/dist/agent-generator/enrichers/description-generator.d.ts.map +1 -0
- package/dist/agent-generator/enrichers/description-generator.js +81 -0
- package/dist/agent-generator/enrichers/description-generator.js.map +1 -0
- package/dist/agent-generator/enrichers/endpoint-extractor.d.ts +8 -0
- package/dist/agent-generator/enrichers/endpoint-extractor.d.ts.map +1 -0
- package/dist/agent-generator/enrichers/endpoint-extractor.js +91 -0
- package/dist/agent-generator/enrichers/endpoint-extractor.js.map +1 -0
- package/dist/agent-generator/enrichers/layer-classifier.d.ts +13 -0
- package/dist/agent-generator/enrichers/layer-classifier.d.ts.map +1 -0
- package/dist/agent-generator/enrichers/layer-classifier.js +150 -0
- package/dist/agent-generator/enrichers/layer-classifier.js.map +1 -0
- package/dist/agent-generator/enrichers/module-extractor.d.ts +11 -0
- package/dist/agent-generator/enrichers/module-extractor.d.ts.map +1 -0
- package/dist/agent-generator/enrichers/module-extractor.js +174 -0
- package/dist/agent-generator/enrichers/module-extractor.js.map +1 -0
- package/dist/agent-generator/framework-detector.d.ts +4 -26
- package/dist/agent-generator/framework-detector.d.ts.map +1 -1
- package/dist/agent-generator/framework-detector.js +31 -584
- package/dist/agent-generator/framework-detector.js.map +1 -1
- package/dist/agent-generator/index.d.ts +8 -33
- package/dist/agent-generator/index.d.ts.map +1 -1
- package/dist/agent-generator/index.js +18 -524
- package/dist/agent-generator/index.js.map +1 -1
- package/dist/agent-generator/templates/helpers/base-helpers.d.ts +11 -0
- package/dist/agent-generator/templates/helpers/base-helpers.d.ts.map +1 -0
- package/dist/agent-generator/templates/helpers/base-helpers.js +20 -0
- package/dist/agent-generator/templates/helpers/base-helpers.js.map +1 -0
- package/dist/agent-generator/templates/helpers/cross-ref-helpers.d.ts +3 -0
- package/dist/agent-generator/templates/helpers/cross-ref-helpers.d.ts.map +1 -0
- package/dist/agent-generator/templates/helpers/cross-ref-helpers.js +77 -0
- package/dist/agent-generator/templates/helpers/cross-ref-helpers.js.map +1 -0
- package/dist/agent-generator/templates/helpers/security-helpers.d.ts +3 -0
- package/dist/agent-generator/templates/helpers/security-helpers.d.ts.map +1 -0
- package/dist/agent-generator/templates/helpers/security-helpers.js +182 -0
- package/dist/agent-generator/templates/helpers/security-helpers.js.map +1 -0
- package/dist/agent-generator/templates/helpers/stack-helpers.d.ts +5 -0
- package/dist/agent-generator/templates/helpers/stack-helpers.d.ts.map +1 -0
- package/dist/agent-generator/templates/helpers/stack-helpers.js +69 -0
- package/dist/agent-generator/templates/helpers/stack-helpers.js.map +1 -0
- package/dist/agent-generator/templates/helpers/structure-helpers.d.ts +3 -0
- package/dist/agent-generator/templates/helpers/structure-helpers.d.ts.map +1 -0
- package/dist/agent-generator/templates/helpers/structure-helpers.js +275 -0
- package/dist/agent-generator/templates/helpers/structure-helpers.js.map +1 -0
- package/dist/agent-generator/templates/helpers/summary-helpers.d.ts +7 -0
- package/dist/agent-generator/templates/helpers/summary-helpers.d.ts.map +1 -0
- package/dist/agent-generator/templates/helpers/summary-helpers.js +56 -0
- package/dist/agent-generator/templates/helpers/summary-helpers.js.map +1 -0
- package/dist/agent-generator/templates/template-helpers.d.ts +9 -72
- package/dist/agent-generator/templates/template-helpers.d.ts.map +1 -1
- package/dist/agent-generator/templates/template-helpers.js +9 -723
- package/dist/agent-generator/templates/template-helpers.js.map +1 -1
- package/dist/analyzers/git-history.d.ts +1 -1
- package/dist/analyzers/git-history.d.ts.map +1 -1
- package/dist/analyzers/git-history.js +16 -10
- package/dist/analyzers/git-history.js.map +1 -1
- package/dist/cli.js.map +1 -1
- package/dist/core/agent-generator/context-enricher.d.ts +18 -0
- package/dist/core/agent-generator/context-enricher.d.ts.map +1 -0
- package/dist/core/agent-generator/context-enricher.js +53 -0
- package/dist/core/agent-generator/context-enricher.js.map +1 -0
- package/dist/core/agent-generator/detectors/base-detector.d.ts +9 -0
- package/dist/core/agent-generator/detectors/base-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/base-detector.js +12 -0
- package/dist/core/agent-generator/detectors/base-detector.js.map +1 -0
- package/dist/core/agent-generator/detectors/dart-detector.d.ts +6 -0
- package/dist/core/agent-generator/detectors/dart-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/dart-detector.js +15 -0
- package/dist/core/agent-generator/detectors/dart-detector.js.map +1 -0
- package/dist/core/agent-generator/detectors/framework-registry.d.ts +6 -0
- package/dist/core/agent-generator/detectors/framework-registry.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/framework-registry.js +81 -0
- package/dist/core/agent-generator/detectors/framework-registry.js.map +1 -0
- package/dist/core/agent-generator/detectors/go-detector.d.ts +6 -0
- package/dist/core/agent-generator/detectors/go-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/go-detector.js +25 -0
- package/dist/core/agent-generator/detectors/go-detector.js.map +1 -0
- package/dist/core/agent-generator/detectors/java-detector.d.ts +6 -0
- package/dist/core/agent-generator/detectors/java-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/java-detector.js +44 -0
- package/dist/core/agent-generator/detectors/java-detector.js.map +1 -0
- package/dist/core/agent-generator/detectors/node-detector.d.ts +6 -0
- package/dist/core/agent-generator/detectors/node-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/node-detector.js +28 -0
- package/dist/core/agent-generator/detectors/node-detector.js.map +1 -0
- package/dist/core/agent-generator/detectors/php-detector.d.ts +6 -0
- package/dist/core/agent-generator/detectors/php-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/php-detector.js +28 -0
- package/dist/core/agent-generator/detectors/php-detector.js.map +1 -0
- package/dist/core/agent-generator/detectors/python-detector.d.ts +8 -0
- package/dist/core/agent-generator/detectors/python-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/python-detector.js +116 -0
- package/dist/core/agent-generator/detectors/python-detector.js.map +1 -0
- package/dist/core/agent-generator/detectors/ruby-detector.d.ts +6 -0
- package/dist/core/agent-generator/detectors/ruby-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/ruby-detector.js +22 -0
- package/dist/core/agent-generator/detectors/ruby-detector.js.map +1 -0
- package/dist/core/agent-generator/detectors/rust-detector.d.ts +6 -0
- package/dist/core/agent-generator/detectors/rust-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/rust-detector.js +18 -0
- package/dist/core/agent-generator/detectors/rust-detector.js.map +1 -0
- package/dist/core/agent-generator/detectors/structure-detector.d.ts +5 -0
- package/dist/core/agent-generator/detectors/structure-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/structure-detector.js +35 -0
- package/dist/core/agent-generator/detectors/structure-detector.js.map +1 -0
- package/dist/core/agent-generator/detectors/toolchain-detector.d.ts +6 -0
- package/dist/core/agent-generator/detectors/toolchain-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/detectors/toolchain-detector.js +163 -0
- package/dist/core/agent-generator/detectors/toolchain-detector.js.map +1 -0
- package/dist/core/agent-generator/domain-inferrer.d.ts +52 -0
- package/dist/core/agent-generator/domain-inferrer.d.ts.map +1 -0
- package/dist/core/agent-generator/domain-inferrer.js +585 -0
- package/dist/core/agent-generator/domain-inferrer.js.map +1 -0
- package/dist/core/agent-generator/engines/audit-engine.d.ts +9 -0
- package/dist/core/agent-generator/engines/audit-engine.d.ts.map +1 -0
- package/dist/core/agent-generator/engines/audit-engine.js +84 -0
- package/dist/core/agent-generator/engines/audit-engine.js.map +1 -0
- package/dist/core/agent-generator/engines/context-builder.d.ts +13 -0
- package/dist/core/agent-generator/engines/context-builder.d.ts.map +1 -0
- package/dist/core/agent-generator/engines/context-builder.js +86 -0
- package/dist/core/agent-generator/engines/context-builder.js.map +1 -0
- package/dist/core/agent-generator/engines/generation-engine.d.ts +8 -0
- package/dist/core/agent-generator/engines/generation-engine.d.ts.map +1 -0
- package/dist/core/agent-generator/engines/generation-engine.js +162 -0
- package/dist/core/agent-generator/engines/generation-engine.js.map +1 -0
- package/dist/core/agent-generator/engines/generation-engine_deps.d.ts +22 -0
- package/dist/core/agent-generator/engines/generation-engine_deps.d.ts.map +1 -0
- package/dist/core/agent-generator/engines/generation-engine_deps.js +17 -0
- package/dist/core/agent-generator/engines/generation-engine_deps.js.map +1 -0
- package/dist/core/agent-generator/engines/suggestion-engine.d.ts +14 -0
- package/dist/core/agent-generator/engines/suggestion-engine.d.ts.map +1 -0
- package/dist/core/agent-generator/engines/suggestion-engine.js +173 -0
- package/dist/core/agent-generator/engines/suggestion-engine.js.map +1 -0
- package/dist/core/agent-generator/engines/suggestion-engine_deps.d.ts +9 -0
- package/dist/core/agent-generator/engines/suggestion-engine_deps.d.ts.map +1 -0
- package/dist/core/agent-generator/engines/suggestion-engine_deps.js +5 -0
- package/dist/core/agent-generator/engines/suggestion-engine_deps.js.map +1 -0
- package/dist/core/agent-generator/enrichers/analysis-helpers.d.ts +10 -0
- package/dist/core/agent-generator/enrichers/analysis-helpers.d.ts.map +1 -0
- package/dist/core/agent-generator/enrichers/analysis-helpers.js +51 -0
- package/dist/core/agent-generator/enrichers/analysis-helpers.js.map +1 -0
- package/dist/core/agent-generator/enrichers/description-generator.d.ts +5 -0
- package/dist/core/agent-generator/enrichers/description-generator.d.ts.map +1 -0
- package/dist/core/agent-generator/enrichers/description-generator.js +81 -0
- package/dist/core/agent-generator/enrichers/description-generator.js.map +1 -0
- package/dist/core/agent-generator/enrichers/endpoint-extractor.d.ts +8 -0
- package/dist/core/agent-generator/enrichers/endpoint-extractor.d.ts.map +1 -0
- package/dist/core/agent-generator/enrichers/endpoint-extractor.js +91 -0
- package/dist/core/agent-generator/enrichers/endpoint-extractor.js.map +1 -0
- package/dist/core/agent-generator/enrichers/layer-classifier.d.ts +13 -0
- package/dist/core/agent-generator/enrichers/layer-classifier.d.ts.map +1 -0
- package/dist/core/agent-generator/enrichers/layer-classifier.js +150 -0
- package/dist/core/agent-generator/enrichers/layer-classifier.js.map +1 -0
- package/dist/core/agent-generator/enrichers/module-extractor.d.ts +11 -0
- package/dist/core/agent-generator/enrichers/module-extractor.d.ts.map +1 -0
- package/dist/core/agent-generator/enrichers/module-extractor.js +174 -0
- package/dist/core/agent-generator/enrichers/module-extractor.js.map +1 -0
- package/dist/core/agent-generator/framework-detector.d.ts +18 -0
- package/dist/core/agent-generator/framework-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/framework-detector.js +58 -0
- package/dist/core/agent-generator/framework-detector.js.map +1 -0
- package/dist/core/agent-generator/index.d.ts +26 -0
- package/dist/core/agent-generator/index.d.ts.map +1 -0
- package/dist/core/agent-generator/index.js +39 -0
- package/dist/core/agent-generator/index.js.map +1 -0
- package/dist/core/agent-generator/stack-detector.d.ts +14 -0
- package/dist/core/agent-generator/stack-detector.d.ts.map +1 -0
- package/dist/core/agent-generator/stack-detector.js +124 -0
- package/dist/core/agent-generator/stack-detector.js.map +1 -0
- package/dist/core/agent-generator/templates/core/agents.d.ts +17 -0
- package/dist/core/agent-generator/templates/core/agents.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/agents.js +1256 -0
- package/dist/core/agent-generator/templates/core/agents.js.map +1 -0
- package/dist/core/agent-generator/templates/core/architecture-rules.d.ts +7 -0
- package/dist/core/agent-generator/templates/core/architecture-rules.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/architecture-rules.js +274 -0
- package/dist/core/agent-generator/templates/core/architecture-rules.js.map +1 -0
- package/dist/core/agent-generator/templates/core/general-rules.d.ts +8 -0
- package/dist/core/agent-generator/templates/core/general-rules.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/general-rules.js +301 -0
- package/dist/core/agent-generator/templates/core/general-rules.js.map +1 -0
- package/dist/core/agent-generator/templates/core/hooks-generator.d.ts +21 -0
- package/dist/core/agent-generator/templates/core/hooks-generator.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/hooks-generator.js +233 -0
- package/dist/core/agent-generator/templates/core/hooks-generator.js.map +1 -0
- package/dist/core/agent-generator/templates/core/index-md.d.ts +7 -0
- package/dist/core/agent-generator/templates/core/index-md.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/index-md.js +246 -0
- package/dist/core/agent-generator/templates/core/index-md.js.map +1 -0
- package/dist/core/agent-generator/templates/core/orchestrator.d.ts +8 -0
- package/dist/core/agent-generator/templates/core/orchestrator.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/orchestrator.js +422 -0
- package/dist/core/agent-generator/templates/core/orchestrator.js.map +1 -0
- package/dist/core/agent-generator/templates/core/preflight.d.ts +8 -0
- package/dist/core/agent-generator/templates/core/preflight.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/preflight.js +213 -0
- package/dist/core/agent-generator/templates/core/preflight.js.map +1 -0
- package/dist/core/agent-generator/templates/core/quality-gates.d.ts +11 -0
- package/dist/core/agent-generator/templates/core/quality-gates.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/quality-gates.js +254 -0
- package/dist/core/agent-generator/templates/core/quality-gates.js.map +1 -0
- package/dist/core/agent-generator/templates/core/security-rules.d.ts +7 -0
- package/dist/core/agent-generator/templates/core/security-rules.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/security-rules.js +528 -0
- package/dist/core/agent-generator/templates/core/security-rules.js.map +1 -0
- package/dist/core/agent-generator/templates/core/skills-generator.d.ts +19 -0
- package/dist/core/agent-generator/templates/core/skills-generator.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/skills-generator.js +546 -0
- package/dist/core/agent-generator/templates/core/skills-generator.js.map +1 -0
- package/dist/core/agent-generator/templates/core/workflow-fix-bug.d.ts +7 -0
- package/dist/core/agent-generator/templates/core/workflow-fix-bug.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/workflow-fix-bug.js +237 -0
- package/dist/core/agent-generator/templates/core/workflow-fix-bug.js.map +1 -0
- package/dist/core/agent-generator/templates/core/workflow-new-feature.d.ts +8 -0
- package/dist/core/agent-generator/templates/core/workflow-new-feature.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/workflow-new-feature.js +321 -0
- package/dist/core/agent-generator/templates/core/workflow-new-feature.js.map +1 -0
- package/dist/core/agent-generator/templates/core/workflow-review.d.ts +7 -0
- package/dist/core/agent-generator/templates/core/workflow-review.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/core/workflow-review.js +104 -0
- package/dist/core/agent-generator/templates/core/workflow-review.js.map +1 -0
- package/dist/core/agent-generator/templates/domain/index.d.ts +22 -0
- package/dist/core/agent-generator/templates/domain/index.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/domain/index.js +1176 -0
- package/dist/core/agent-generator/templates/domain/index.js.map +1 -0
- package/dist/core/agent-generator/templates/helpers/base-helpers.d.ts +11 -0
- package/dist/core/agent-generator/templates/helpers/base-helpers.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/helpers/base-helpers.js +20 -0
- package/dist/core/agent-generator/templates/helpers/base-helpers.js.map +1 -0
- package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.d.ts +3 -0
- package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.js +77 -0
- package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.js.map +1 -0
- package/dist/core/agent-generator/templates/helpers/security-helpers.d.ts +3 -0
- package/dist/core/agent-generator/templates/helpers/security-helpers.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/helpers/security-helpers.js +182 -0
- package/dist/core/agent-generator/templates/helpers/security-helpers.js.map +1 -0
- package/dist/core/agent-generator/templates/helpers/stack-helpers.d.ts +5 -0
- package/dist/core/agent-generator/templates/helpers/stack-helpers.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/helpers/stack-helpers.js +69 -0
- package/dist/core/agent-generator/templates/helpers/stack-helpers.js.map +1 -0
- package/dist/core/agent-generator/templates/helpers/structure-helpers.d.ts +3 -0
- package/dist/core/agent-generator/templates/helpers/structure-helpers.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/helpers/structure-helpers.js +275 -0
- package/dist/core/agent-generator/templates/helpers/structure-helpers.js.map +1 -0
- package/dist/core/agent-generator/templates/helpers/summary-helpers.d.ts +7 -0
- package/dist/core/agent-generator/templates/helpers/summary-helpers.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/helpers/summary-helpers.js +56 -0
- package/dist/core/agent-generator/templates/helpers/summary-helpers.js.map +1 -0
- package/dist/core/agent-generator/templates/stack/index.d.ts +8 -0
- package/dist/core/agent-generator/templates/stack/index.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/stack/index.js +695 -0
- package/dist/core/agent-generator/templates/stack/index.js.map +1 -0
- package/dist/core/agent-generator/templates/template-helpers.d.ts +12 -0
- package/dist/core/agent-generator/templates/template-helpers.d.ts.map +1 -0
- package/dist/core/agent-generator/templates/template-helpers.js +12 -0
- package/dist/core/agent-generator/templates/template-helpers.js.map +1 -0
- package/dist/core/agent-generator/types/agent.d.ts +40 -0
- package/dist/core/agent-generator/types/agent.d.ts.map +1 -0
- package/dist/core/agent-generator/types/agent.js +27 -0
- package/dist/core/agent-generator/types/agent.js.map +1 -0
- package/dist/core/agent-generator/types/domain.d.ts +59 -0
- package/dist/core/agent-generator/types/domain.d.ts.map +1 -0
- package/dist/core/agent-generator/types/domain.js +2 -0
- package/dist/core/agent-generator/types/domain.js.map +1 -0
- package/dist/core/agent-generator/types/stack.d.ts +37 -0
- package/dist/core/agent-generator/types/stack.d.ts.map +1 -0
- package/dist/core/agent-generator/types/stack.js +2 -0
- package/dist/core/agent-generator/types/stack.js.map +1 -0
- package/dist/core/agent-generator/types/template.d.ts +30 -0
- package/dist/core/agent-generator/types/template.d.ts.map +1 -0
- package/dist/core/agent-generator/types/template.js +2 -0
- package/dist/core/agent-generator/types/template.js.map +1 -0
- package/dist/core/agent-generator/types.d.ts +197 -0
- package/dist/core/agent-generator/types.d.ts.map +1 -0
- package/dist/core/agent-generator/types.js +27 -0
- package/dist/core/agent-generator/types.js.map +1 -0
- package/dist/core/analyzer.d.ts +39 -0
- package/dist/core/analyzer.d.ts.map +1 -0
- package/dist/core/analyzer.js +383 -0
- package/dist/core/analyzer.js.map +1 -0
- package/dist/core/analyzers/forecast.d.ts +85 -0
- package/dist/core/analyzers/forecast.d.ts.map +1 -0
- package/dist/core/analyzers/forecast.js +337 -0
- package/dist/core/analyzers/forecast.js.map +1 -0
- package/dist/core/analyzers/index.d.ts +10 -0
- package/dist/core/analyzers/index.d.ts.map +1 -0
- package/dist/core/analyzers/index.js +7 -0
- package/dist/core/analyzers/index.js.map +1 -0
- package/dist/core/analyzers/temporal-scorer.d.ts +72 -0
- package/dist/core/analyzers/temporal-scorer.d.ts.map +1 -0
- package/dist/core/analyzers/temporal-scorer.js +140 -0
- package/dist/core/analyzers/temporal-scorer.js.map +1 -0
- package/dist/core/anti-patterns.d.ts +25 -0
- package/dist/core/anti-patterns.d.ts.map +1 -0
- package/dist/core/anti-patterns.js +239 -0
- package/dist/core/anti-patterns.js.map +1 -0
- package/dist/core/architect.d.ts +70 -0
- package/dist/core/architect.d.ts.map +1 -0
- package/dist/core/architect.js +273 -0
- package/dist/core/architect.js.map +1 -0
- package/dist/core/architect_deps.d.ts +14 -0
- package/dist/core/architect_deps.d.ts.map +1 -0
- package/dist/core/architect_deps.js +12 -0
- package/dist/core/architect_deps.js.map +1 -0
- package/dist/core/config.d.ts +12 -0
- package/dist/core/config.d.ts.map +1 -0
- package/dist/core/config.js +110 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/diagram.d.ts +10 -0
- package/dist/core/diagram.d.ts.map +1 -0
- package/dist/core/diagram.js +101 -0
- package/dist/core/diagram.js.map +1 -0
- package/dist/core/project-summarizer.d.ts +17 -0
- package/dist/core/project-summarizer.d.ts.map +1 -0
- package/dist/core/project-summarizer.js +39 -0
- package/dist/core/project-summarizer.js.map +1 -0
- package/dist/core/refactor-engine.d.ts +19 -0
- package/dist/core/refactor-engine.d.ts.map +1 -0
- package/dist/core/refactor-engine.js +86 -0
- package/dist/core/refactor-engine.js.map +1 -0
- package/dist/core/rules/barrel-optimizer.d.ts +14 -0
- package/dist/core/rules/barrel-optimizer.d.ts.map +1 -0
- package/dist/core/rules/barrel-optimizer.js +78 -0
- package/dist/core/rules/barrel-optimizer.js.map +1 -0
- package/dist/core/rules/dead-code-detector.d.ts +22 -0
- package/dist/core/rules/dead-code-detector.d.ts.map +1 -0
- package/dist/core/rules/dead-code-detector.js +118 -0
- package/dist/core/rules/dead-code-detector.js.map +1 -0
- package/dist/core/rules/hub-splitter.d.ts +14 -0
- package/dist/core/rules/hub-splitter.d.ts.map +1 -0
- package/dist/core/rules/hub-splitter.js +119 -0
- package/dist/core/rules/hub-splitter.js.map +1 -0
- package/dist/core/rules/import-organizer.d.ts +14 -0
- package/dist/core/rules/import-organizer.d.ts.map +1 -0
- package/dist/core/rules/import-organizer.js +86 -0
- package/dist/core/rules/import-organizer.js.map +1 -0
- package/dist/core/rules/module-grouper.d.ts +14 -0
- package/dist/core/rules/module-grouper.d.ts.map +1 -0
- package/dist/core/rules/module-grouper.js +118 -0
- package/dist/core/rules/module-grouper.js.map +1 -0
- package/dist/core/scorer.d.ts +27 -0
- package/dist/core/scorer.d.ts.map +1 -0
- package/dist/core/scorer.js +229 -0
- package/dist/core/scorer.js.map +1 -0
- package/dist/core/summarizer/keyword-extractor.d.ts +7 -0
- package/dist/core/summarizer/keyword-extractor.d.ts.map +1 -0
- package/dist/core/summarizer/keyword-extractor.js +37 -0
- package/dist/core/summarizer/keyword-extractor.js.map +1 -0
- package/dist/core/summarizer/module-inferrer.d.ts +12 -0
- package/dist/core/summarizer/module-inferrer.d.ts.map +1 -0
- package/dist/core/summarizer/module-inferrer.js +171 -0
- package/dist/core/summarizer/module-inferrer.js.map +1 -0
- package/dist/core/summarizer/package-reader.d.ts +4 -0
- package/dist/core/summarizer/package-reader.d.ts.map +1 -0
- package/dist/core/summarizer/package-reader.js +30 -0
- package/dist/core/summarizer/package-reader.js.map +1 -0
- package/dist/core/summarizer/purpose-inferrer.d.ts +9 -0
- package/dist/core/summarizer/purpose-inferrer.d.ts.map +1 -0
- package/dist/core/summarizer/purpose-inferrer.js +178 -0
- package/dist/core/summarizer/purpose-inferrer.js.map +1 -0
- package/dist/core/summarizer/readme-reader.d.ts +4 -0
- package/dist/core/summarizer/readme-reader.d.ts.map +1 -0
- package/dist/core/summarizer/readme-reader.js +21 -0
- package/dist/core/summarizer/readme-reader.js.map +1 -0
- package/dist/core/types/core.d.ts +87 -0
- package/dist/core/types/core.d.ts.map +1 -0
- package/dist/core/types/core.js +2 -0
- package/dist/core/types/core.js.map +1 -0
- package/dist/core/types/infrastructure.d.ts +39 -0
- package/dist/core/types/infrastructure.d.ts.map +1 -0
- package/dist/core/types/infrastructure.js +2 -0
- package/dist/core/types/infrastructure.js.map +1 -0
- package/dist/core/types/rules.d.ts +54 -0
- package/dist/core/types/rules.d.ts.map +1 -0
- package/dist/core/types/rules.js +2 -0
- package/dist/core/types/rules.js.map +1 -0
- package/dist/core/types/summarizer.d.ts +13 -0
- package/dist/core/types/summarizer.d.ts.map +1 -0
- package/dist/core/types/summarizer.js +2 -0
- package/dist/core/types/summarizer.js.map +1 -0
- package/dist/core/types.d.ts +187 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +2 -0
- package/dist/core/types.js.map +1 -0
- package/dist/diagram.d.ts +1 -0
- package/dist/diagram.d.ts.map +1 -1
- package/dist/diagram.js +24 -39
- package/dist/diagram.js.map +1 -1
- package/dist/html-reporter/scripts.d.ts +6 -0
- package/dist/html-reporter/scripts.d.ts.map +1 -0
- package/dist/html-reporter/scripts.js +316 -0
- package/dist/html-reporter/scripts.js.map +1 -0
- package/dist/html-reporter/sections/agents.d.ts +3 -0
- package/dist/html-reporter/sections/agents.d.ts.map +1 -0
- package/dist/html-reporter/sections/agents.js +259 -0
- package/dist/html-reporter/sections/agents.js.map +1 -0
- package/dist/html-reporter/sections/anti-patterns.d.ts +14 -0
- package/dist/html-reporter/sections/anti-patterns.d.ts.map +1 -0
- package/dist/html-reporter/sections/anti-patterns.js +64 -0
- package/dist/html-reporter/sections/anti-patterns.js.map +1 -0
- package/dist/html-reporter/sections/header.d.ts +4 -0
- package/dist/html-reporter/sections/header.d.ts.map +1 -0
- package/dist/html-reporter/sections/header.js +30 -0
- package/dist/html-reporter/sections/header.js.map +1 -0
- package/dist/html-reporter/sections/layers.d.ts +10 -0
- package/dist/html-reporter/sections/layers.d.ts.map +1 -0
- package/dist/html-reporter/sections/layers.js +143 -0
- package/dist/html-reporter/sections/layers.js.map +1 -0
- package/dist/html-reporter/sections/overview.d.ts +3 -0
- package/dist/html-reporter/sections/overview.d.ts.map +1 -0
- package/dist/html-reporter/sections/overview.js +58 -0
- package/dist/html-reporter/sections/overview.js.map +1 -0
- package/dist/html-reporter/sections/refactoring-plan.d.ts +4 -0
- package/dist/html-reporter/sections/refactoring-plan.d.ts.map +1 -0
- package/dist/html-reporter/sections/refactoring-plan.js +120 -0
- package/dist/html-reporter/sections/refactoring-plan.js.map +1 -0
- package/dist/html-reporter/sections/score.d.ts +8 -0
- package/dist/html-reporter/sections/score.d.ts.map +1 -0
- package/dist/html-reporter/sections/score.js +69 -0
- package/dist/html-reporter/sections/score.js.map +1 -0
- package/dist/html-reporter/sections/suggestions.d.ts +8 -0
- package/dist/html-reporter/sections/suggestions.d.ts.map +1 -0
- package/dist/html-reporter/sections/suggestions.js +34 -0
- package/dist/html-reporter/sections/suggestions.js.map +1 -0
- package/dist/html-reporter/styles.d.ts +2 -0
- package/dist/html-reporter/styles.d.ts.map +1 -0
- package/dist/html-reporter/styles.js +504 -0
- package/dist/html-reporter/styles.js.map +1 -0
- package/dist/html-reporter/utils.d.ts +27 -0
- package/dist/html-reporter/utils.d.ts.map +1 -0
- package/dist/html-reporter/utils.js +82 -0
- package/dist/html-reporter/utils.js.map +1 -0
- package/dist/html-reporter.d.ts +0 -37
- package/dist/html-reporter.d.ts.map +1 -1
- package/dist/html-reporter.js +29 -1679
- package/dist/html-reporter.js.map +1 -1
- package/dist/index.d.ts +16 -84
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +12 -285
- package/dist/index.js.map +1 -1
- package/dist/infrastructure/git-cache.d.ts +7 -0
- package/dist/infrastructure/git-cache.d.ts.map +1 -0
- package/dist/infrastructure/git-cache.js +41 -0
- package/dist/infrastructure/git-cache.js.map +1 -0
- package/dist/infrastructure/git-history.d.ts +113 -0
- package/dist/infrastructure/git-history.d.ts.map +1 -0
- package/dist/infrastructure/git-history.js +339 -0
- package/dist/infrastructure/git-history.js.map +1 -0
- package/dist/infrastructure/logger.d.ts +21 -0
- package/dist/infrastructure/logger.d.ts.map +1 -0
- package/dist/infrastructure/logger.js +59 -0
- package/dist/infrastructure/logger.js.map +1 -0
- package/dist/infrastructure/scanner.d.ts +32 -0
- package/dist/infrastructure/scanner.d.ts.map +1 -0
- package/dist/infrastructure/scanner.js +330 -0
- package/dist/infrastructure/scanner.js.map +1 -0
- package/dist/logger.d.ts +21 -0
- package/dist/logger.d.ts.map +1 -0
- package/dist/logger.js +59 -0
- package/dist/logger.js.map +1 -0
- package/dist/project-summarizer.d.ts +6 -28
- package/dist/project-summarizer.d.ts.map +1 -1
- package/dist/project-summarizer.js +21 -445
- package/dist/project-summarizer.js.map +1 -1
- package/dist/scanner.d.ts.map +1 -1
- package/dist/scanner.js +15 -13
- package/dist/scanner.js.map +1 -1
- package/dist/summarizer/keyword-extractor.d.ts +6 -0
- package/dist/summarizer/keyword-extractor.d.ts.map +1 -0
- package/dist/summarizer/keyword-extractor.js +37 -0
- package/dist/summarizer/keyword-extractor.js.map +1 -0
- package/dist/summarizer/module-inferrer.d.ts +10 -0
- package/dist/summarizer/module-inferrer.d.ts.map +1 -0
- package/dist/summarizer/module-inferrer.js +171 -0
- package/dist/summarizer/module-inferrer.js.map +1 -0
- package/dist/summarizer/package-reader.d.ts +4 -0
- package/dist/summarizer/package-reader.d.ts.map +1 -0
- package/dist/summarizer/package-reader.js +30 -0
- package/dist/summarizer/package-reader.js.map +1 -0
- package/dist/summarizer/purpose-inferrer.d.ts +8 -0
- package/dist/summarizer/purpose-inferrer.d.ts.map +1 -0
- package/dist/summarizer/purpose-inferrer.js +178 -0
- package/dist/summarizer/purpose-inferrer.js.map +1 -0
- package/dist/summarizer/readme-reader.d.ts +4 -0
- package/dist/summarizer/readme-reader.d.ts.map +1 -0
- package/dist/summarizer/readme-reader.js +21 -0
- package/dist/summarizer/readme-reader.js.map +1 -0
- package/fix-scorer.js +18 -0
- package/fix-tests.js +73 -0
- package/package.json +3 -3
- package/scripts/decompose-detectors.ts +183 -0
- package/scripts/decompose-detectors_deps.ts +16 -0
- package/scripts/decompose-enrichers.ts +191 -0
- package/scripts/decompose-enrichers_deps.ts +10 -0
- package/scripts/decompose-helpers.ts +92 -0
- package/scripts/decompose-summarizer.ts +127 -0
- package/setup-refactor.sh +21 -0
- package/src/{cli.ts → adapters/cli.ts} +14 -10
- package/src/adapters/html-reporter/scripts.ts +402 -0
- package/src/adapters/html-reporter/sections/agents.ts +267 -0
- package/src/adapters/html-reporter/sections/anti-patterns.ts +81 -0
- package/src/adapters/html-reporter/sections/header.ts +35 -0
- package/src/adapters/html-reporter/sections/layers.ts +165 -0
- package/src/adapters/html-reporter/sections/overview.ts +64 -0
- package/src/adapters/html-reporter/sections/refactoring-plan.ts +166 -0
- package/src/adapters/html-reporter/sections/score.ts +79 -0
- package/src/adapters/html-reporter/sections/suggestions.ts +39 -0
- package/src/adapters/html-reporter/styles.ts +525 -0
- package/src/adapters/html-reporter/utils_adapters.ts +39 -0
- package/src/adapters/html-reporter/utils_sections.ts +55 -0
- package/src/adapters/html-reporter.ts +89 -0
- package/src/adapters/html-reporter_deps.ts +14 -0
- package/src/{refactor-reporter.ts → adapters/refactor-reporter.ts} +1 -1
- package/src/{reporter.ts → adapters/reporter.ts} +1 -1
- package/src/core/agent-generator/context-enricher.ts +67 -0
- package/src/core/agent-generator/detectors/base-detector.ts +18 -0
- package/src/core/agent-generator/detectors/dart-detector.ts +17 -0
- package/src/core/agent-generator/detectors/framework-registry.ts +82 -0
- package/src/core/agent-generator/detectors/go-detector.ts +26 -0
- package/src/core/agent-generator/detectors/java-detector.ts +46 -0
- package/src/core/agent-generator/detectors/node-detector.ts +28 -0
- package/src/core/agent-generator/detectors/php-detector.ts +28 -0
- package/src/core/agent-generator/detectors/python-detector.ts +125 -0
- package/src/core/agent-generator/detectors/ruby-detector.ts +24 -0
- package/src/core/agent-generator/detectors/rust-detector.ts +19 -0
- package/src/core/agent-generator/detectors/structure-detector.ts +38 -0
- package/src/core/agent-generator/detectors/toolchain-detector.ts +180 -0
- package/src/{agent-generator → core/agent-generator}/domain-inferrer.ts +2 -7
- package/src/core/agent-generator/engines/audit-engine.ts +98 -0
- package/src/core/agent-generator/engines/context-builder.ts +96 -0
- package/src/core/agent-generator/engines/generation-engine.ts +184 -0
- package/src/core/agent-generator/engines/generation-engine_deps.ts +21 -0
- package/src/core/agent-generator/engines/suggestion-engine.ts +202 -0
- package/src/core/agent-generator/engines/suggestion-engine_deps.ts +8 -0
- package/src/core/agent-generator/enrichers/analysis-helpers.ts +58 -0
- package/src/core/agent-generator/enrichers/description-generator.ts +91 -0
- package/src/core/agent-generator/enrichers/endpoint-extractor.ts +114 -0
- package/src/core/agent-generator/enrichers/layer-classifier.ts +156 -0
- package/src/core/agent-generator/enrichers/module-extractor.ts +203 -0
- package/src/core/agent-generator/framework-detector.ts +66 -0
- package/src/core/agent-generator/index.ts +55 -0
- package/src/{agent-generator → core/agent-generator}/stack-detector.ts +2 -2
- package/src/{agent-generator → core/agent-generator}/templates/core/agents.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/architecture-rules.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/general-rules.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/hooks-generator.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/index-md.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/orchestrator.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/preflight.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/quality-gates.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/security-rules.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/skills-generator.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/workflow-fix-bug.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/workflow-new-feature.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/core/workflow-review.ts +1 -1
- package/src/{agent-generator → core/agent-generator}/templates/domain/index.ts +1 -1
- package/src/core/agent-generator/templates/helpers/base-helpers.ts +32 -0
- package/src/core/agent-generator/templates/helpers/cross-ref-helpers.ts +79 -0
- package/src/core/agent-generator/templates/helpers/security-helpers.ts +196 -0
- package/src/core/agent-generator/templates/helpers/stack-helpers.ts +78 -0
- package/src/core/agent-generator/templates/helpers/structure-helpers.ts +291 -0
- package/src/core/agent-generator/templates/helpers/summary-helpers.ts +65 -0
- package/src/{agent-generator → core/agent-generator}/templates/stack/index.ts +1 -1
- package/src/core/agent-generator/templates/template-helpers.ts +12 -0
- package/src/core/agent-generator/types/agent.ts +65 -0
- package/src/core/agent-generator/types/domain.ts +63 -0
- package/src/core/agent-generator/types/stack.ts +38 -0
- package/src/core/agent-generator/types/template.ts +31 -0
- package/src/{analyzer.ts → core/analyzer.ts} +2 -1
- package/src/{analyzers → core/analyzers}/forecast.ts +1 -1
- package/src/{analyzers → core/analyzers}/index.ts +2 -2
- package/src/{analyzers → core/analyzers}/temporal-scorer.ts +1 -1
- package/src/{anti-patterns.ts → core/anti-patterns.ts} +12 -2
- package/src/core/architect.ts +356 -0
- package/src/core/architect_deps.ts +13 -0
- package/src/{config.ts → core/config.ts} +1 -1
- package/src/{diagram.ts → core/diagram.ts} +27 -42
- package/src/core/project-summarizer.ts +42 -0
- package/src/{refactor-engine.ts → core/refactor-engine.ts} +2 -7
- package/src/{rules → core/rules}/barrel-optimizer.ts +3 -1
- package/src/{rules → core/rules}/dead-code-detector.ts +3 -1
- package/src/{rules → core/rules}/hub-splitter.ts +14 -2
- package/src/{rules → core/rules}/import-organizer.ts +5 -3
- package/src/{rules → core/rules}/module-grouper.ts +11 -2
- package/src/{scorer.ts → core/scorer.ts} +7 -7
- package/src/core/summarizer/keyword-extractor.ts +53 -0
- package/src/core/summarizer/module-inferrer.ts +194 -0
- package/src/core/summarizer/package-reader.ts +34 -0
- package/src/core/summarizer/purpose-inferrer.ts +197 -0
- package/src/core/summarizer/readme-reader.ts +24 -0
- package/src/core/types/core.ts +93 -0
- package/src/core/types/infrastructure.ts +41 -0
- package/src/core/types/rules.ts +51 -0
- package/src/core/types/summarizer.ts +8 -0
- package/src/index.ts +17 -384
- package/src/{analyzers → infrastructure}/git-history.ts +19 -10
- package/src/infrastructure/logger.ts +68 -0
- package/src/{scanner.ts → infrastructure/scanner.ts} +17 -14
- package/src/scripts/bundle-deps.js +123 -0
- package/src/scripts/fix-imports.mjs +106 -0
- package/src/scripts/refactor-imports.js +74 -0
- package/src/scripts/refactor-utils.js +23 -0
- package/test-shotgun.js +7 -0
- package/tests/agent-generator.test.ts +3 -2
- package/tests/analyzers-integration.test.ts +9 -9
- package/tests/anti-patterns.test.ts +3 -2
- package/tests/context-enricher.test.ts +3 -2
- package/tests/forecast.test.ts +4 -4
- package/tests/framework-detector.test.ts +2 -2
- package/tests/git-history.test.ts +20 -20
- package/tests/monorepo-scan.test.ts +4 -4
- package/tests/scanner.test.ts +2 -2
- package/tests/scorer.test.ts +17 -17
- package/tests/stack-detector.test.ts +2 -2
- package/tests/template-generation.test.ts +31 -30
- package/tests/template-helpers.test.ts +6 -28
- package/tests/temporal-scorer.test.ts +3 -3
- package/src/agent-generator/context-enricher.ts +0 -672
- package/src/agent-generator/framework-detector.ts +0 -669
- package/src/agent-generator/index.ts +0 -634
- package/src/agent-generator/templates/template-helpers.ts +0 -776
- package/src/agent-generator/types.ts +0 -232
- package/src/html-reporter.ts +0 -1830
- package/src/project-summarizer.ts +0 -521
- package/src/types.ts +0 -193
- /package/src/{analyzers → infrastructure}/git-cache.ts +0 -0
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { groupAntiPatterns, groupSuggestions, escapeHtml, renderHeader, renderFooter, renderProjectOverview, renderScoreHero, renderRadarChart, renderStats, renderLayers, renderDependencyGraph, renderAntiPatternBubbles, renderAntiPatterns, renderSuggestions, renderRefactoringPlan, renderAgentSuggestions, getScripts, getStyles, AnalysisReport, AntiPattern, RefactoringPlan, RefactorStep, AgentSuggestion } from './html-reporter_deps.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Generates premium visual HTML reports from AnalysisReport.
|
|
5
|
+
* Features: D3.js force graph, bubble charts, radar chart, animated counters.
|
|
6
|
+
*/
|
|
7
|
+
export class HtmlReportGenerator {
|
|
8
|
+
generateHtml(report: AnalysisReport, plan?: RefactoringPlan, agentSuggestion?: AgentSuggestion): string {
|
|
9
|
+
const grouped = groupAntiPatterns(report.antiPatterns);
|
|
10
|
+
const sugGrouped = groupSuggestions(report.suggestions);
|
|
11
|
+
|
|
12
|
+
return `<!DOCTYPE html>
|
|
13
|
+
<html lang="en">
|
|
14
|
+
<head>
|
|
15
|
+
<meta charset="UTF-8">
|
|
16
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
17
|
+
<title>Architect Report — ${escapeHtml(report.projectInfo.name)}</title>
|
|
18
|
+
${getStyles()}
|
|
19
|
+
<script src="https://cdn.jsdelivr.net/npm/d3@7"><\/script>
|
|
20
|
+
</head>
|
|
21
|
+
<body>
|
|
22
|
+
${renderHeader(report)}
|
|
23
|
+
<div class="report-layout">
|
|
24
|
+
<nav class="sidebar" id="reportSidebar">
|
|
25
|
+
<div class="sidebar-title">Navigation</div>
|
|
26
|
+
<a href="#score" class="sidebar-link active" data-section="score">📊 Score</a>
|
|
27
|
+
${report.projectSummary ? `<a href="#overview" class="sidebar-link" data-section="overview">📋 Overview</a>` : ''}
|
|
28
|
+
<a href="#layers" class="sidebar-link" data-section="layers">📐 Layers & Graph</a>
|
|
29
|
+
<a href="#anti-patterns" class="sidebar-link" data-section="anti-patterns">⚠️ Anti-Patterns (${report.antiPatterns.length})</a>
|
|
30
|
+
<a href="#suggestions" class="sidebar-link" data-section="suggestions">💡 Suggestions (${report.suggestions.length})</a>
|
|
31
|
+
${plan ? `<a href="#refactoring" class="sidebar-link" data-section="refactoring">🔧 Refactoring (${plan.steps.length})</a>` : ''}
|
|
32
|
+
${agentSuggestion ? `<a href="#agents" class="sidebar-link" data-section="agents">🤖 Agents</a>` : ''}
|
|
33
|
+
</nav>
|
|
34
|
+
<button class="sidebar-toggle" onclick="document.getElementById('reportSidebar').classList.toggle('sidebar-open')">☰</button>
|
|
35
|
+
|
|
36
|
+
<div class="container">
|
|
37
|
+
<div id="score">
|
|
38
|
+
${renderScoreHero(report)}
|
|
39
|
+
${renderRadarChart(report)}
|
|
40
|
+
${renderStats(report)}
|
|
41
|
+
</div>
|
|
42
|
+
|
|
43
|
+
${renderProjectOverview(report)}
|
|
44
|
+
|
|
45
|
+
<details class="section-accordion" id="layers" open>
|
|
46
|
+
<summary class="section-accordion-header">📐 Layer Analysis & Dependencies</summary>
|
|
47
|
+
<div class="section-accordion-body">
|
|
48
|
+
${renderLayers(report)}
|
|
49
|
+
${renderDependencyGraph(report)}
|
|
50
|
+
</div>
|
|
51
|
+
</details>
|
|
52
|
+
|
|
53
|
+
<details class="section-accordion" id="anti-patterns" open>
|
|
54
|
+
<summary class="section-accordion-header">⚠️ Anti-Patterns (${report.antiPatterns.length})</summary>
|
|
55
|
+
<div class="section-accordion-body">
|
|
56
|
+
${renderAntiPatternBubbles(report, grouped)}
|
|
57
|
+
${renderAntiPatterns(report, grouped)}
|
|
58
|
+
</div>
|
|
59
|
+
</details>
|
|
60
|
+
|
|
61
|
+
<details class="section-accordion" id="suggestions">
|
|
62
|
+
<summary class="section-accordion-header">💡 Suggestions (${report.suggestions.length})</summary>
|
|
63
|
+
<div class="section-accordion-body">
|
|
64
|
+
${renderSuggestions(sugGrouped)}
|
|
65
|
+
</div>
|
|
66
|
+
</details>
|
|
67
|
+
|
|
68
|
+
${plan ? `<details class="section-accordion" id="refactoring" open>
|
|
69
|
+
<summary class="section-accordion-header">🔧 Refactoring Plan (${plan.steps.length} steps, ${plan.totalOperations} operations)</summary>
|
|
70
|
+
<div class="section-accordion-body">
|
|
71
|
+
${renderRefactoringPlan(plan)}
|
|
72
|
+
</div>
|
|
73
|
+
</details>` : ''}
|
|
74
|
+
|
|
75
|
+
${agentSuggestion ? `<details class="section-accordion" id="agents" open>
|
|
76
|
+
<summary class="section-accordion-header">🤖 Agent System</summary>
|
|
77
|
+
<div class="section-accordion-body">
|
|
78
|
+
${renderAgentSuggestions(agentSuggestion)}
|
|
79
|
+
</div>
|
|
80
|
+
</details>` : ''}
|
|
81
|
+
</div>
|
|
82
|
+
</div>
|
|
83
|
+
${renderFooter()}
|
|
84
|
+
${getScripts(report)}
|
|
85
|
+
</body>
|
|
86
|
+
</html>`;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export { groupAntiPatterns, groupSuggestions, escapeHtml } from './html-reporter/utils_adapters.js';
|
|
2
|
+
export { renderHeader, renderFooter } from './html-reporter/sections/header.js';
|
|
3
|
+
export { renderProjectOverview } from './html-reporter/sections/overview.js';
|
|
4
|
+
export { renderScoreHero, renderRadarChart, renderStats } from './html-reporter/sections/score.js';
|
|
5
|
+
export { renderLayers, renderDependencyGraph } from './html-reporter/sections/layers.js';
|
|
6
|
+
export { renderAntiPatternBubbles, renderAntiPatterns } from './html-reporter/sections/anti-patterns.js';
|
|
7
|
+
export { renderSuggestions } from './html-reporter/sections/suggestions.js';
|
|
8
|
+
export { renderRefactoringPlan } from './html-reporter/sections/refactoring-plan.js';
|
|
9
|
+
export { renderAgentSuggestions } from './html-reporter/sections/agents.js';
|
|
10
|
+
export { getScripts } from './html-reporter/scripts.js';
|
|
11
|
+
export { getStyles } from './html-reporter/styles.js';
|
|
12
|
+
export { AnalysisReport, AntiPattern } from '../core/types/core.js';
|
|
13
|
+
export { RefactoringPlan, RefactorStep } from '../core/types/rules.js';
|
|
14
|
+
export { AgentSuggestion } from '../core/agent-generator/index.js';
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { AnalysisReport } from '../types/core.js';
|
|
2
|
+
import { RefactoringPlan } from '../types/rules.js';
|
|
3
|
+
import { StackInfo } from './types/stack.js';
|
|
4
|
+
import { EnrichedTemplateContext } from './types/template.js';
|
|
5
|
+
import { AgentGeneratorConfig, DEFAULT_AGENT_CONFIG } from './types/agent.js';
|
|
6
|
+
import { DomainInferrer } from './domain-inferrer.js';
|
|
7
|
+
import { FrameworkDetector } from './framework-detector.js';
|
|
8
|
+
|
|
9
|
+
// Engines
|
|
10
|
+
import { ModuleExtractor } from './enrichers/module-extractor.js';
|
|
11
|
+
import { EndpointExtractor } from './enrichers/endpoint-extractor.js';
|
|
12
|
+
import { AnalysisHelpers } from './enrichers/analysis-helpers.js';
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* ContextEnricher — Builds an EnrichedTemplateContext from AnalysisReport.
|
|
16
|
+
* Refactored via Strategy/Facade into separate Extractor engines.
|
|
17
|
+
*/
|
|
18
|
+
export class ContextEnricher {
|
|
19
|
+
private domainInferrer = new DomainInferrer();
|
|
20
|
+
private frameworkDetector = new FrameworkDetector();
|
|
21
|
+
|
|
22
|
+
private moduleExtractor = new ModuleExtractor();
|
|
23
|
+
private endpointExtractor = new EndpointExtractor();
|
|
24
|
+
private analysisHelpers = new AnalysisHelpers();
|
|
25
|
+
|
|
26
|
+
enrich(
|
|
27
|
+
report: AnalysisReport,
|
|
28
|
+
plan: RefactoringPlan,
|
|
29
|
+
stack: StackInfo,
|
|
30
|
+
projectPath: string,
|
|
31
|
+
config: AgentGeneratorConfig = DEFAULT_AGENT_CONFIG,
|
|
32
|
+
): EnrichedTemplateContext {
|
|
33
|
+
const modules = this.moduleExtractor.extractModules(report, projectPath);
|
|
34
|
+
const endpoints = this.endpointExtractor.extractEndpoints(report, modules);
|
|
35
|
+
const untestedModules = this.analysisHelpers.findUntestedModules(modules);
|
|
36
|
+
const criticalPaths = this.analysisHelpers.findCriticalPaths(report);
|
|
37
|
+
const projectDepth = this.analysisHelpers.classifyProjectDepth(report);
|
|
38
|
+
const domain = this.domainInferrer.infer(report, projectPath);
|
|
39
|
+
|
|
40
|
+
const fwResult = this.frameworkDetector.detect(projectPath, report);
|
|
41
|
+
|
|
42
|
+
const webFrameworks = (report.projectInfo?.frameworks || [])
|
|
43
|
+
.filter(f => !['Jest', 'Vitest', 'Mocha', 'ESLint', 'Prettier', 'Biome',
|
|
44
|
+
'pytest', 'Ruff', 'mypy', 'Black', 'Flake8', 'RSpec',
|
|
45
|
+
'@jest/globals', '@types/jest', 'ts-jest'].includes(f));
|
|
46
|
+
const stackLabel = [...new Set([...stack.languages, ...webFrameworks])].join(' + ');
|
|
47
|
+
|
|
48
|
+
return {
|
|
49
|
+
report,
|
|
50
|
+
plan,
|
|
51
|
+
stack,
|
|
52
|
+
projectName: report.projectInfo.name || 'Project',
|
|
53
|
+
stackLabel,
|
|
54
|
+
config,
|
|
55
|
+
domain,
|
|
56
|
+
modules,
|
|
57
|
+
endpoints,
|
|
58
|
+
untestedModules,
|
|
59
|
+
criticalPaths,
|
|
60
|
+
projectDepth,
|
|
61
|
+
detectedFrameworks: fwResult.frameworks,
|
|
62
|
+
primaryFramework: fwResult.primaryFramework,
|
|
63
|
+
toolchain: fwResult.toolchain,
|
|
64
|
+
projectStructure: fwResult.projectStructure,
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { FrameworkInfo } from '../types/stack.js';
|
|
2
|
+
import { readFileSync } from 'fs';
|
|
3
|
+
|
|
4
|
+
export interface FrameworkDetectorStrategy {
|
|
5
|
+
detect(projectPath: string, out: FrameworkInfo[]): void;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export abstract class BaseDetector implements FrameworkDetectorStrategy {
|
|
9
|
+
abstract detect(projectPath: string, out: FrameworkInfo[]): void;
|
|
10
|
+
|
|
11
|
+
protected safeReadFile(path: string): string {
|
|
12
|
+
try {
|
|
13
|
+
return readFileSync(path, 'utf-8');
|
|
14
|
+
} catch {
|
|
15
|
+
return '';
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { join } from 'path';
|
|
2
|
+
import { existsSync } from 'fs';
|
|
3
|
+
import { FrameworkInfo } from '../types/stack.js';
|
|
4
|
+
import { BaseDetector } from './base-detector.js';
|
|
5
|
+
import { FRAMEWORK_MAP } from './framework-registry.js';
|
|
6
|
+
|
|
7
|
+
export class DartDetector extends BaseDetector {
|
|
8
|
+
public detect(projectPath: string, out: FrameworkInfo[]): void {
|
|
9
|
+
const pubspecPath = join(projectPath, 'pubspec.yaml');
|
|
10
|
+
if (!existsSync(pubspecPath)) return;
|
|
11
|
+
|
|
12
|
+
const content = this.safeReadFile(pubspecPath);
|
|
13
|
+
if (content.includes('flutter:')) {
|
|
14
|
+
out.push({ name: 'Flutter', version: null, category: 'web', confidence: 0.95 });
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { FrameworkInfo } from '../types/stack.js';
|
|
2
|
+
|
|
3
|
+
export const FRAMEWORK_MAP: Record<string, { name: string; category: FrameworkInfo['category'] }> = {
|
|
4
|
+
// Python Web
|
|
5
|
+
'fastapi': { name: 'FastAPI', category: 'web' },
|
|
6
|
+
'django': { name: 'Django', category: 'web' },
|
|
7
|
+
'flask': { name: 'Flask', category: 'web' },
|
|
8
|
+
'starlette': { name: 'Starlette', category: 'web' },
|
|
9
|
+
'tornado': { name: 'Tornado', category: 'web' },
|
|
10
|
+
'sanic': { name: 'Sanic', category: 'web' },
|
|
11
|
+
'aiohttp': { name: 'aiohttp', category: 'web' },
|
|
12
|
+
'litestar': { name: 'Litestar', category: 'web' },
|
|
13
|
+
// Python ORM
|
|
14
|
+
'sqlalchemy': { name: 'SQLAlchemy', category: 'orm' },
|
|
15
|
+
'tortoise-orm': { name: 'Tortoise ORM', category: 'orm' },
|
|
16
|
+
'peewee': { name: 'Peewee', category: 'orm' },
|
|
17
|
+
'sqlmodel': { name: 'SQLModel', category: 'orm' },
|
|
18
|
+
'prisma': { name: 'Prisma', category: 'orm' },
|
|
19
|
+
'django-rest-framework': { name: 'DRF', category: 'web' },
|
|
20
|
+
'djangorestframework': { name: 'DRF', category: 'web' },
|
|
21
|
+
// Python Test
|
|
22
|
+
'pytest': { name: 'pytest', category: 'test' },
|
|
23
|
+
'unittest': { name: 'unittest', category: 'test' },
|
|
24
|
+
'hypothesis': { name: 'Hypothesis', category: 'test' },
|
|
25
|
+
// Python Lint
|
|
26
|
+
'ruff': { name: 'Ruff', category: 'lint' },
|
|
27
|
+
'flake8': { name: 'Flake8', category: 'lint' },
|
|
28
|
+
'pylint': { name: 'Pylint', category: 'lint' },
|
|
29
|
+
'black': { name: 'Black', category: 'lint' },
|
|
30
|
+
'mypy': { name: 'mypy', category: 'lint' },
|
|
31
|
+
// Node.js Web
|
|
32
|
+
'@nestjs/core': { name: 'NestJS', category: 'web' },
|
|
33
|
+
'express': { name: 'Express', category: 'web' },
|
|
34
|
+
'fastify': { name: 'Fastify', category: 'web' },
|
|
35
|
+
'koa': { name: 'Koa', category: 'web' },
|
|
36
|
+
'hapi': { name: 'Hapi', category: 'web' },
|
|
37
|
+
'@hapi/hapi': { name: 'Hapi', category: 'web' },
|
|
38
|
+
'next': { name: 'Next.js', category: 'web' },
|
|
39
|
+
'nuxt': { name: 'Nuxt', category: 'web' },
|
|
40
|
+
// Node.js ORM
|
|
41
|
+
'typeorm': { name: 'TypeORM', category: 'orm' },
|
|
42
|
+
'@prisma/client': { name: 'Prisma', category: 'orm' },
|
|
43
|
+
'sequelize': { name: 'Sequelize', category: 'orm' },
|
|
44
|
+
'mongoose': { name: 'Mongoose', category: 'orm' },
|
|
45
|
+
'knex': { name: 'Knex', category: 'orm' },
|
|
46
|
+
'drizzle-orm': { name: 'Drizzle', category: 'orm' },
|
|
47
|
+
// Node.js Test
|
|
48
|
+
'jest': { name: 'Jest', category: 'test' },
|
|
49
|
+
'vitest': { name: 'Vitest', category: 'test' },
|
|
50
|
+
'mocha': { name: 'Mocha', category: 'test' },
|
|
51
|
+
// Node.js Lint
|
|
52
|
+
'eslint': { name: 'ESLint', category: 'lint' },
|
|
53
|
+
'biome': { name: 'Biome', category: 'lint' },
|
|
54
|
+
'@biomejs/biome': { name: 'Biome', category: 'lint' },
|
|
55
|
+
'prettier': { name: 'Prettier', category: 'lint' },
|
|
56
|
+
// Java/Kotlin
|
|
57
|
+
'spring-boot-starter-web': { name: 'Spring Boot', category: 'web' },
|
|
58
|
+
'spring-boot-starter': { name: 'Spring Boot', category: 'web' },
|
|
59
|
+
'quarkus': { name: 'Quarkus', category: 'web' },
|
|
60
|
+
'micronaut': { name: 'Micronaut', category: 'web' },
|
|
61
|
+
'ktor': { name: 'Ktor', category: 'web' },
|
|
62
|
+
// PHP
|
|
63
|
+
'laravel/framework': { name: 'Laravel', category: 'web' },
|
|
64
|
+
'symfony/framework-bundle': { name: 'Symfony', category: 'web' },
|
|
65
|
+
'slim/slim': { name: 'Slim', category: 'web' },
|
|
66
|
+
// Ruby
|
|
67
|
+
'rails': { name: 'Ruby on Rails', category: 'web' },
|
|
68
|
+
// Go — detected from imports
|
|
69
|
+
'gin-gonic/gin': { name: 'Gin', category: 'web' },
|
|
70
|
+
'labstack/echo': { name: 'Echo', category: 'web' },
|
|
71
|
+
'gofiber/fiber': { name: 'Fiber', category: 'web' },
|
|
72
|
+
'gorilla/mux': { name: 'Gorilla Mux', category: 'web' },
|
|
73
|
+
'go-chi/chi': { name: 'Chi', category: 'web' },
|
|
74
|
+
// Dart/Flutter
|
|
75
|
+
'flutter': { name: 'Flutter', category: 'web' },
|
|
76
|
+
'shelf': { name: 'Shelf', category: 'web' },
|
|
77
|
+
'dart_frog': { name: 'Dart Frog', category: 'web' },
|
|
78
|
+
// Rust
|
|
79
|
+
'actix-web': { name: 'Actix Web', category: 'web' },
|
|
80
|
+
'rocket': { name: 'Rocket', category: 'web' },
|
|
81
|
+
'axum': { name: 'Axum', category: 'web' },
|
|
82
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { join } from 'path';
|
|
2
|
+
import { existsSync } from 'fs';
|
|
3
|
+
import { FrameworkInfo } from '../types/stack.js';
|
|
4
|
+
import { BaseDetector } from './base-detector.js';
|
|
5
|
+
import { FRAMEWORK_MAP } from './framework-registry.js';
|
|
6
|
+
|
|
7
|
+
export class GoDetector extends BaseDetector {
|
|
8
|
+
public detect(projectPath: string, out: FrameworkInfo[]): void {
|
|
9
|
+
const goModPath = join(projectPath, 'go.mod');
|
|
10
|
+
if (!existsSync(goModPath)) return;
|
|
11
|
+
|
|
12
|
+
const content = this.safeReadFile(goModPath);
|
|
13
|
+
const lines = content.split('\n');
|
|
14
|
+
for (const line of lines) {
|
|
15
|
+
const match = line.match(/^\s*(github\.com\/[^\s]+)/);
|
|
16
|
+
if (match) {
|
|
17
|
+
const modPath = match[1].toLowerCase();
|
|
18
|
+
for (const [key, fwInfo] of Object.entries(FRAMEWORK_MAP)) {
|
|
19
|
+
if (modPath.includes(key.toLowerCase())) {
|
|
20
|
+
out.push({ name: fwInfo.name, version: null, category: fwInfo.category, confidence: 0.9 });
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { join } from 'path';
|
|
2
|
+
import { existsSync } from 'fs';
|
|
3
|
+
import { FrameworkInfo } from '../types/stack.js';
|
|
4
|
+
import { BaseDetector } from './base-detector.js';
|
|
5
|
+
import { FRAMEWORK_MAP } from './framework-registry.js';
|
|
6
|
+
|
|
7
|
+
export class JavaDetector extends BaseDetector {
|
|
8
|
+
public detect(projectPath: string, out: FrameworkInfo[]): void {
|
|
9
|
+
// pom.xml
|
|
10
|
+
const pomPath = join(projectPath, 'pom.xml');
|
|
11
|
+
if (existsSync(pomPath)) {
|
|
12
|
+
const content = this.safeReadFile(pomPath);
|
|
13
|
+
const deps = content.match(/<artifactId>([^<]+)<\/artifactId>/gi) || [];
|
|
14
|
+
for (const dep of deps) {
|
|
15
|
+
const match = dep.match(/<artifactId>([^<]+)<\/artifactId>/i);
|
|
16
|
+
if (match) {
|
|
17
|
+
const artifact = match[1].toLowerCase();
|
|
18
|
+
const fwInfo = FRAMEWORK_MAP[artifact];
|
|
19
|
+
if (fwInfo) {
|
|
20
|
+
out.push({ name: fwInfo.name, version: null, category: fwInfo.category, confidence: 0.85 });
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// build.gradle / build.gradle.kts
|
|
27
|
+
for (const gradleFile of ['build.gradle', 'build.gradle.kts']) {
|
|
28
|
+
const gradlePath = join(projectPath, gradleFile);
|
|
29
|
+
if (existsSync(gradlePath)) {
|
|
30
|
+
const content = this.safeReadFile(gradlePath);
|
|
31
|
+
if (content.includes('spring-boot')) {
|
|
32
|
+
out.push({ name: 'Spring Boot', version: null, category: 'web', confidence: 0.9 });
|
|
33
|
+
}
|
|
34
|
+
if (content.includes('quarkus')) {
|
|
35
|
+
out.push({ name: 'Quarkus', version: null, category: 'web', confidence: 0.9 });
|
|
36
|
+
}
|
|
37
|
+
if (content.includes('micronaut')) {
|
|
38
|
+
out.push({ name: 'Micronaut', version: null, category: 'web', confidence: 0.9 });
|
|
39
|
+
}
|
|
40
|
+
if (content.includes('ktor')) {
|
|
41
|
+
out.push({ name: 'Ktor', version: null, category: 'web', confidence: 0.9 });
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { join } from 'path';
|
|
2
|
+
import { existsSync } from 'fs';
|
|
3
|
+
import { FrameworkInfo } from '../types/stack.js';
|
|
4
|
+
import { BaseDetector } from './base-detector.js';
|
|
5
|
+
import { FRAMEWORK_MAP } from './framework-registry.js';
|
|
6
|
+
|
|
7
|
+
export class NodeDetector extends BaseDetector {
|
|
8
|
+
public detect(projectPath: string, out: FrameworkInfo[]): void {
|
|
9
|
+
const pkgPath = join(projectPath, 'package.json');
|
|
10
|
+
if (!existsSync(pkgPath)) return;
|
|
11
|
+
|
|
12
|
+
const content = this.safeReadFile(pkgPath);
|
|
13
|
+
try {
|
|
14
|
+
const pkg = JSON.parse(content);
|
|
15
|
+
const allDeps = { ...pkg.dependencies, ...pkg.devDependencies };
|
|
16
|
+
for (const [name, version] of Object.entries(allDeps)) {
|
|
17
|
+
const fwInfo = FRAMEWORK_MAP[name];
|
|
18
|
+
if (fwInfo) {
|
|
19
|
+
const vStr = typeof version === 'string' ? version : '';
|
|
20
|
+
const vMatch = vStr.match(/([0-9][0-9.]*)/);
|
|
21
|
+
out.push({ name: fwInfo.name, version: vMatch?.[1] || null, category: fwInfo.category, confidence: 0.95 });
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
} catch {
|
|
25
|
+
// Invalid JSON
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { join } from 'path';
|
|
2
|
+
import { existsSync } from 'fs';
|
|
3
|
+
import { FrameworkInfo } from '../types/stack.js';
|
|
4
|
+
import { BaseDetector } from './base-detector.js';
|
|
5
|
+
import { FRAMEWORK_MAP } from './framework-registry.js';
|
|
6
|
+
|
|
7
|
+
export class PhpDetector extends BaseDetector {
|
|
8
|
+
public detect(projectPath: string, out: FrameworkInfo[]): void {
|
|
9
|
+
const composerPath = join(projectPath, 'composer.json');
|
|
10
|
+
if (!existsSync(composerPath)) return;
|
|
11
|
+
|
|
12
|
+
const content = this.safeReadFile(composerPath);
|
|
13
|
+
try {
|
|
14
|
+
const pkg = JSON.parse(content);
|
|
15
|
+
const allDeps = { ...pkg.require, ...pkg['require-dev'] };
|
|
16
|
+
for (const [name, version] of Object.entries(allDeps)) {
|
|
17
|
+
const fwInfo = FRAMEWORK_MAP[name];
|
|
18
|
+
if (fwInfo) {
|
|
19
|
+
const vStr = typeof version === 'string' ? version : '';
|
|
20
|
+
const vMatch = vStr.match(/([0-9][0-9.]*)/);
|
|
21
|
+
out.push({ name: fwInfo.name, version: vMatch?.[1] || null, category: fwInfo.category, confidence: 0.9 });
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
} catch {
|
|
25
|
+
// Invalid JSON
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { join } from 'path';
|
|
2
|
+
import { existsSync } from 'fs';
|
|
3
|
+
import { FrameworkInfo } from '../types/stack.js';
|
|
4
|
+
import { BaseDetector } from './base-detector.js';
|
|
5
|
+
import { FRAMEWORK_MAP } from './framework-registry.js';
|
|
6
|
+
|
|
7
|
+
export class PythonDetector extends BaseDetector {
|
|
8
|
+
public detect(projectPath: string, out: FrameworkInfo[]): void {
|
|
9
|
+
// requirements.txt
|
|
10
|
+
const reqFiles = ['requirements.txt', 'requirements/base.txt', 'requirements/prod.txt'];
|
|
11
|
+
for (const reqFile of reqFiles) {
|
|
12
|
+
const path = join(projectPath, reqFile);
|
|
13
|
+
if (existsSync(path)) {
|
|
14
|
+
const content = this.safeReadFile(path);
|
|
15
|
+
this.parsePythonRequirements(content, out);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
// pyproject.toml
|
|
20
|
+
const pyproject = join(projectPath, 'pyproject.toml');
|
|
21
|
+
if (existsSync(pyproject)) {
|
|
22
|
+
const content = this.safeReadFile(pyproject);
|
|
23
|
+
this.parsePyprojectToml(content, out);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// setup.py / setup.cfg
|
|
27
|
+
const setupPy = join(projectPath, 'setup.py');
|
|
28
|
+
if (existsSync(setupPy)) {
|
|
29
|
+
const content = this.safeReadFile(setupPy);
|
|
30
|
+
this.parsePythonRequirements(content, out);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
// Pipfile
|
|
34
|
+
const pipfile = join(projectPath, 'Pipfile');
|
|
35
|
+
if (existsSync(pipfile)) {
|
|
36
|
+
const content = this.safeReadFile(pipfile);
|
|
37
|
+
this.parsePythonRequirements(content, out);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
private parsePythonRequirements(content: string, out: FrameworkInfo[]): void {
|
|
43
|
+
const lines = content.toLowerCase().split('\n');
|
|
44
|
+
for (const line of lines) {
|
|
45
|
+
const cleaned = line.replace(/#.*$/, '').trim();
|
|
46
|
+
if (!cleaned) continue;
|
|
47
|
+
|
|
48
|
+
// Match: package==1.0.0, package>=1.0, package~=1.0, package[extras]
|
|
49
|
+
const match = cleaned.match(/^([a-z0-9_-]+)(?:\[.*?\])?\s*(?:[=<>~!]+\s*([0-9][0-9.]*\S*))?/);
|
|
50
|
+
if (match) {
|
|
51
|
+
const pkg = match[1].replace(/-/g, '-');
|
|
52
|
+
const version = match[2] || null;
|
|
53
|
+
const fwInfo = FRAMEWORK_MAP[pkg];
|
|
54
|
+
if (fwInfo) {
|
|
55
|
+
out.push({ name: fwInfo.name, version, category: fwInfo.category, confidence: 0.95 });
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
private parsePyprojectToml(content: string, out: FrameworkInfo[]): void {
|
|
61
|
+
// Strategy 1: [project.dependencies] section (legacy format)
|
|
62
|
+
const depSection = content.match(/\[(?:project\.)?dependencies\]([\s\S]*?)(?:\n\[|$)/);
|
|
63
|
+
if (depSection) {
|
|
64
|
+
this.parsePythonRequirements(depSection[1], out);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
// Strategy 2: [project] section with inline `dependencies = [...]` (PEP 621 format)
|
|
68
|
+
// This is the standard pyproject.toml format used by most modern Python projects
|
|
69
|
+
const projectSection = content.match(/\[project\]\s*\n([\s\S]*?)(?:\n\[(?!project\.)|$)/);
|
|
70
|
+
if (projectSection) {
|
|
71
|
+
// Extract the dependencies array: dependencies = [ "pkg>=1.0", ... ]
|
|
72
|
+
const depsArrayMatch = projectSection[1].match(/dependencies\s*=\s*\[([\s\S]*?)\]/);
|
|
73
|
+
if (depsArrayMatch) {
|
|
74
|
+
// Extract quoted strings from the array
|
|
75
|
+
const deps = depsArrayMatch[1].match(/"([^"]+)"/g);
|
|
76
|
+
if (deps) {
|
|
77
|
+
const depsAsLines = deps.map(d => d.replace(/"/g, '')).join('\n');
|
|
78
|
+
this.parsePythonRequirements(depsAsLines, out);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
// Strategy 3: [project.optional-dependencies] sections (dev, test, etc.)
|
|
84
|
+
const optionalDeps = content.match(/\[project\.optional-dependencies\]\s*\n([\s\S]*?)(?:\n\[(?!project\.)|$)/);
|
|
85
|
+
if (optionalDeps) {
|
|
86
|
+
// Parse each group: dev = ["pkg>=1.0", ...], test = [...]
|
|
87
|
+
const groupMatches = optionalDeps[1].matchAll(/\w+\s*=\s*\[([\s\S]*?)\]/g);
|
|
88
|
+
for (const groupMatch of groupMatches) {
|
|
89
|
+
const deps = groupMatch[1].match(/"([^"]+)"/g);
|
|
90
|
+
if (deps) {
|
|
91
|
+
const depsAsLines = deps.map(d => d.replace(/"/g, '')).join('\n');
|
|
92
|
+
this.parsePythonRequirements(depsAsLines, out);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
// Strategy 4: tool.poetry.dependencies
|
|
98
|
+
const poetrySection = content.match(/\[tool\.poetry\.dependencies\]([\s\S]*?)(?:\n\[|$)/);
|
|
99
|
+
if (poetrySection) {
|
|
100
|
+
const lines = poetrySection[1].split('\n');
|
|
101
|
+
for (const line of lines) {
|
|
102
|
+
const match = line.match(/^([a-z0-9_-]+)\s*=\s*"?([^"]*)"?/i);
|
|
103
|
+
if (match) {
|
|
104
|
+
const pkg = match[1].toLowerCase();
|
|
105
|
+
const fwInfo = FRAMEWORK_MAP[pkg];
|
|
106
|
+
if (fwInfo) {
|
|
107
|
+
const versionMatch = match[2].match(/([0-9][0-9.]*)/);
|
|
108
|
+
out.push({ name: fwInfo.name, version: versionMatch?.[1] || null, category: fwInfo.category, confidence: 0.95 });
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
// Deduplicate by framework name (keep highest confidence)
|
|
115
|
+
const seen = new Map<string, number>();
|
|
116
|
+
for (let i = out.length - 1; i >= 0; i--) {
|
|
117
|
+
const key = out[i].name;
|
|
118
|
+
if (seen.has(key)) {
|
|
119
|
+
out.splice(i, 1);
|
|
120
|
+
} else {
|
|
121
|
+
seen.set(key, i);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { join } from 'path';
|
|
2
|
+
import { existsSync } from 'fs';
|
|
3
|
+
import { FrameworkInfo } from '../types/stack.js';
|
|
4
|
+
import { BaseDetector } from './base-detector.js';
|
|
5
|
+
import { FRAMEWORK_MAP } from './framework-registry.js';
|
|
6
|
+
|
|
7
|
+
export class RubyDetector extends BaseDetector {
|
|
8
|
+
public detect(projectPath: string, out: FrameworkInfo[]): void {
|
|
9
|
+
const gemfilePath = join(projectPath, 'Gemfile');
|
|
10
|
+
if (!existsSync(gemfilePath)) return;
|
|
11
|
+
|
|
12
|
+
const content = this.safeReadFile(gemfilePath);
|
|
13
|
+
if (content.includes("'rails'") || content.includes('"rails"')) {
|
|
14
|
+
const vMatch = content.match(/['"]rails['"],\s*['"]~?>\s*([0-9.]+)['"]/);
|
|
15
|
+
out.push({ name: 'Ruby on Rails', version: vMatch?.[1] || null, category: 'web', confidence: 0.95 });
|
|
16
|
+
}
|
|
17
|
+
if (content.includes("'sinatra'") || content.includes('"sinatra"')) {
|
|
18
|
+
out.push({ name: 'Sinatra', category: 'web', version: null, confidence: 0.9 });
|
|
19
|
+
}
|
|
20
|
+
if (content.includes("'rspec'") || content.includes('"rspec"')) {
|
|
21
|
+
out.push({ name: 'RSpec', category: 'test', version: null, confidence: 0.9 });
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { join } from 'path';
|
|
2
|
+
import { existsSync } from 'fs';
|
|
3
|
+
import { FrameworkInfo } from '../types/stack.js';
|
|
4
|
+
import { BaseDetector } from './base-detector.js';
|
|
5
|
+
import { FRAMEWORK_MAP } from './framework-registry.js';
|
|
6
|
+
|
|
7
|
+
export class RustDetector extends BaseDetector {
|
|
8
|
+
public detect(projectPath: string, out: FrameworkInfo[]): void {
|
|
9
|
+
const cargoPath = join(projectPath, 'Cargo.toml');
|
|
10
|
+
if (!existsSync(cargoPath)) return;
|
|
11
|
+
|
|
12
|
+
const content = this.safeReadFile(cargoPath);
|
|
13
|
+
for (const [key, fwInfo] of Object.entries(FRAMEWORK_MAP)) {
|
|
14
|
+
if (content.includes(`"${key}"`) || content.includes(`'${key}'`) || content.includes(`${key} =`)) {
|
|
15
|
+
out.push({ name: fwInfo.name, version: null, category: fwInfo.category, confidence: 0.85 });
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { AnalysisReport } from '../../types/core.js';
|
|
2
|
+
|
|
3
|
+
export class StructureDetector {
|
|
4
|
+
public detectProjectStructure(report: AnalysisReport): 'clean-architecture' | 'mvc' | 'modular' | 'flat' | 'monorepo' | 'unknown' {
|
|
5
|
+
const paths = report.dependencyGraph.nodes.map(n => n.toLowerCase());
|
|
6
|
+
|
|
7
|
+
// Clean Architecture / DDD
|
|
8
|
+
const hasDomain = paths.some(p => p.includes('/domain/'));
|
|
9
|
+
const hasApplication = paths.some(p => p.includes('/application/'));
|
|
10
|
+
const hasInfrastructure = paths.some(p => p.includes('/infrastructure/'));
|
|
11
|
+
const hasPresentation = paths.some(p => p.includes('/presentation/'));
|
|
12
|
+
if ((hasDomain && hasInfrastructure) || (hasDomain && hasApplication && hasPresentation)) {
|
|
13
|
+
return 'clean-architecture';
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
// MVC
|
|
17
|
+
const hasModels = paths.some(p => p.includes('/models/'));
|
|
18
|
+
const hasViews = paths.some(p => p.includes('/views/'));
|
|
19
|
+
const hasControllers = paths.some(p => p.includes('/controllers/'));
|
|
20
|
+
if (hasModels && hasViews && hasControllers) return 'mvc';
|
|
21
|
+
|
|
22
|
+
// Modular (NestJS, feature-based)
|
|
23
|
+
const hasModules = paths.some(p => p.includes('/modules/'));
|
|
24
|
+
const hasFeatures = paths.some(p => p.includes('/features/'));
|
|
25
|
+
if (hasModules || hasFeatures) return 'modular';
|
|
26
|
+
|
|
27
|
+
// Monorepo
|
|
28
|
+
const hasPackages = paths.some(p => p.includes('/packages/'));
|
|
29
|
+
const hasApps = paths.some(p => p.includes('/apps/'));
|
|
30
|
+
if (hasPackages || hasApps) return 'monorepo';
|
|
31
|
+
|
|
32
|
+
// Flat
|
|
33
|
+
const maxDepth = Math.max(...paths.map(p => p.split('/').length));
|
|
34
|
+
if (maxDepth <= 3) return 'flat';
|
|
35
|
+
|
|
36
|
+
return 'unknown';
|
|
37
|
+
}
|
|
38
|
+
}
|