@girardelli/architect 6.0.0 → 8.1.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/dist/{adapters → src/adapters}/cli.d.ts +1 -2
- package/dist/{adapters → src/adapters}/cli.js +182 -207
- package/dist/src/adapters/cli.js.map +1 -0
- package/dist/src/adapters/github-action.d.ts +9 -0
- package/dist/src/adapters/github-action.js +94 -0
- package/dist/src/adapters/github-action.js.map +1 -0
- package/dist/{html-reporter → src/adapters/html-reporter}/scripts.d.ts +1 -2
- package/dist/{adapters → src/adapters}/html-reporter/scripts.js.map +1 -1
- package/dist/src/adapters/html-reporter/sections/agents.d.ts +2 -0
- package/dist/{html-reporter → src/adapters/html-reporter}/sections/agents.js +8 -7
- package/dist/src/adapters/html-reporter/sections/agents.js.map +1 -0
- package/dist/{html-reporter → src/adapters/html-reporter}/sections/anti-patterns.d.ts +1 -2
- package/dist/src/adapters/html-reporter/sections/anti-patterns.js.map +1 -0
- package/dist/{html-reporter → src/adapters/html-reporter}/sections/header.d.ts +1 -2
- package/dist/{adapters → src/adapters}/html-reporter/sections/header.js +1 -1
- package/dist/src/adapters/html-reporter/sections/header.js.map +1 -0
- package/dist/{html-reporter → src/adapters/html-reporter}/sections/layers.d.ts +1 -2
- package/dist/src/adapters/html-reporter/sections/layers.js.map +1 -0
- package/dist/src/adapters/html-reporter/sections/overview.d.ts +2 -0
- package/dist/src/adapters/html-reporter/sections/overview.js.map +1 -0
- package/dist/{html-reporter → src/adapters/html-reporter}/sections/refactoring-plan.d.ts +1 -2
- package/dist/src/adapters/html-reporter/sections/refactoring-plan.js.map +1 -0
- package/dist/{html-reporter → src/adapters/html-reporter}/sections/score.d.ts +1 -2
- package/dist/{adapters → src/adapters}/html-reporter/sections/score.js +1 -0
- package/dist/src/adapters/html-reporter/sections/score.js.map +1 -0
- package/dist/{adapters → src/adapters}/html-reporter/sections/suggestions.d.ts +0 -1
- package/dist/src/adapters/html-reporter/sections/suggestions.js.map +1 -0
- package/dist/{adapters → src/adapters}/html-reporter/styles.d.ts +0 -1
- package/dist/{adapters → src/adapters}/html-reporter/styles.js.map +1 -1
- package/dist/{adapters → src/adapters}/html-reporter/utils_adapters.d.ts +1 -2
- package/dist/src/adapters/html-reporter/utils_adapters.js.map +1 -0
- package/dist/{adapters → src/adapters}/html-reporter/utils_sections.d.ts +0 -1
- package/dist/src/adapters/html-reporter/utils_sections.js.map +1 -0
- package/dist/{html-reporter.d.ts → src/adapters/html-reporter.d.ts} +3 -3
- package/dist/{html-reporter.js → src/adapters/html-reporter.js} +11 -11
- package/dist/src/adapters/html-reporter.js.map +1 -0
- package/dist/src/adapters/progress-logger.d.ts +55 -0
- package/dist/src/adapters/progress-logger.js +200 -0
- package/dist/src/adapters/progress-logger.js.map +1 -0
- package/dist/{refactor-reporter.d.ts → src/adapters/refactor-reporter.d.ts} +1 -2
- package/dist/{refactor-reporter.js → src/adapters/refactor-reporter.js} +1 -1
- package/dist/src/adapters/refactor-reporter.js.map +1 -0
- package/dist/{reporter.d.ts → src/adapters/reporter.d.ts} +1 -2
- package/dist/src/adapters/reporter.js.map +1 -0
- package/dist/src/core/GenesisTerminal.d.ts +8 -0
- package/dist/src/core/GenesisTerminal.js +105 -0
- package/dist/src/core/GenesisTerminal.js.map +1 -0
- package/dist/{core → src/core}/architect.d.ts +3 -2
- package/dist/{core → src/core}/architect.js +20 -5
- package/dist/src/core/architect.js.map +1 -0
- package/dist/tests/architect-adapter-enrichment.test.d.ts +1 -0
- package/dist/tests/architect-adapter-enrichment.test.js +11 -0
- package/dist/tests/architect-adapter-enrichment.test.js.map +1 -0
- package/dist/tests/github-action.test.d.ts +1 -0
- package/dist/tests/github-action.test.js +92 -0
- package/dist/tests/github-action.test.js.map +1 -0
- package/package.json +15 -65
- package/src/adapters/cli.ts +216 -245
- package/src/adapters/github-action.ts +109 -0
- package/src/adapters/html-reporter/scripts.ts +1 -1
- package/src/adapters/html-reporter/sections/agents.ts +9 -9
- package/src/adapters/html-reporter/sections/anti-patterns.ts +1 -1
- package/src/adapters/html-reporter/sections/header.ts +2 -2
- package/src/adapters/html-reporter/sections/layers.ts +1 -1
- package/src/adapters/html-reporter/sections/overview.ts +1 -1
- package/src/adapters/html-reporter/sections/refactoring-plan.ts +1 -1
- package/src/adapters/html-reporter/sections/score.ts +2 -1
- package/src/adapters/html-reporter/utils_adapters.ts +1 -1
- package/src/adapters/html-reporter.ts +14 -1
- package/src/adapters/progress-logger.ts +236 -0
- package/src/adapters/refactor-reporter.ts +2 -2
- package/src/adapters/reporter.ts +1 -1
- package/src/core/GenesisTerminal.ts +127 -0
- package/src/core/architect.ts +25 -5
- package/tests/github-action.test.ts +109 -0
- package/tsconfig.json +12 -19
- package/.agent/INDEX.md +0 -197
- package/.agent/agents/AGENT-ORCHESTRATOR.md +0 -408
- package/.agent/agents/QA-TEST-ENGINEER.md +0 -152
- package/.agent/agents/SECURITY-AUDITOR.md +0 -87
- package/.agent/agents/TECH-DEBT-CONTROLLER.md +0 -154
- package/.agent/agents/TYPESCRIPT-BACKEND-DEVELOPER.md +0 -484
- package/.agent/guards/CODE-REVIEW-CHECKLIST.md +0 -94
- package/.agent/guards/PREFLIGHT.md +0 -200
- package/.agent/guards/QUALITY-GATES.md +0 -212
- package/.agent/hooks/post-analysis.sh +0 -64
- package/.agent/hooks/pre-commit.sh +0 -68
- package/.agent/hooks/pre-push.sh +0 -59
- package/.agent/rules/00-general.md +0 -229
- package/.agent/rules/01-architecture.md +0 -182
- package/.agent/rules/02-security.md +0 -388
- package/.agent/skills/ARCHITECT-INTEGRATION.md +0 -103
- package/.agent/skills/CI-PIPELINE.md +0 -113
- package/.agent/skills/PROJECT-PATTERNS.md +0 -62
- package/.agent/templates/ADR.md +0 -95
- package/.agent/templates/BDD.md +0 -57
- package/.agent/templates/C4.md +0 -67
- package/.agent/templates/TDD.md +0 -86
- package/.agent/templates/THREAT-MODEL.md +0 -63
- package/.agent/workflows/fix-bug.md +0 -228
- package/.agent/workflows/new-feature.md +0 -311
- package/.agent/workflows/review.md +0 -95
- package/.github/workflows/ci.yml +0 -43
- package/.github/workflows/publish.yml +0 -40
- package/CONTRIBUTING.md +0 -140
- package/LICENSE +0 -21
- package/PROJECT_STRUCTURE.txt +0 -168
- package/README.md +0 -261
- package/architect-report--girardelli-architect.json +0 -5332
- package/architect-run.sh +0 -427
- package/assets/banner-v3.html +0 -561
- package/debug.js +0 -6
- package/dist/adapters/cli.d.ts.map +0 -1
- package/dist/adapters/cli.js.map +0 -1
- package/dist/adapters/html-reporter/scripts.d.ts +0 -6
- package/dist/adapters/html-reporter/scripts.d.ts.map +0 -1
- package/dist/adapters/html-reporter/sections/agents.d.ts +0 -3
- package/dist/adapters/html-reporter/sections/agents.d.ts.map +0 -1
- package/dist/adapters/html-reporter/sections/agents.js +0 -259
- package/dist/adapters/html-reporter/sections/agents.js.map +0 -1
- package/dist/adapters/html-reporter/sections/anti-patterns.d.ts +0 -14
- package/dist/adapters/html-reporter/sections/anti-patterns.d.ts.map +0 -1
- package/dist/adapters/html-reporter/sections/anti-patterns.js.map +0 -1
- package/dist/adapters/html-reporter/sections/header.d.ts +0 -4
- package/dist/adapters/html-reporter/sections/header.d.ts.map +0 -1
- package/dist/adapters/html-reporter/sections/header.js.map +0 -1
- package/dist/adapters/html-reporter/sections/layers.d.ts +0 -10
- package/dist/adapters/html-reporter/sections/layers.d.ts.map +0 -1
- package/dist/adapters/html-reporter/sections/layers.js.map +0 -1
- package/dist/adapters/html-reporter/sections/overview.d.ts +0 -3
- package/dist/adapters/html-reporter/sections/overview.d.ts.map +0 -1
- package/dist/adapters/html-reporter/sections/overview.js.map +0 -1
- package/dist/adapters/html-reporter/sections/refactoring-plan.d.ts +0 -4
- package/dist/adapters/html-reporter/sections/refactoring-plan.d.ts.map +0 -1
- package/dist/adapters/html-reporter/sections/refactoring-plan.js.map +0 -1
- package/dist/adapters/html-reporter/sections/score.d.ts +0 -8
- package/dist/adapters/html-reporter/sections/score.d.ts.map +0 -1
- package/dist/adapters/html-reporter/sections/score.js.map +0 -1
- package/dist/adapters/html-reporter/sections/suggestions.d.ts.map +0 -1
- package/dist/adapters/html-reporter/sections/suggestions.js.map +0 -1
- package/dist/adapters/html-reporter/styles.d.ts.map +0 -1
- package/dist/adapters/html-reporter/utils.d.ts +0 -27
- package/dist/adapters/html-reporter/utils.d.ts.map +0 -1
- package/dist/adapters/html-reporter/utils.js +0 -82
- package/dist/adapters/html-reporter/utils.js.map +0 -1
- package/dist/adapters/html-reporter/utils_adapters.d.ts.map +0 -1
- package/dist/adapters/html-reporter/utils_adapters.js.map +0 -1
- package/dist/adapters/html-reporter/utils_sections.d.ts.map +0 -1
- package/dist/adapters/html-reporter/utils_sections.js.map +0 -1
- package/dist/adapters/html-reporter.d.ts +0 -9
- package/dist/adapters/html-reporter.d.ts.map +0 -1
- package/dist/adapters/html-reporter.js +0 -87
- package/dist/adapters/html-reporter.js.map +0 -1
- package/dist/adapters/html-reporter_deps.d.ts +0 -15
- package/dist/adapters/html-reporter_deps.d.ts.map +0 -1
- package/dist/adapters/html-reporter_deps.js +0 -12
- package/dist/adapters/html-reporter_deps.js.map +0 -1
- package/dist/adapters/refactor-reporter.d.ts +0 -20
- package/dist/adapters/refactor-reporter.d.ts.map +0 -1
- package/dist/adapters/refactor-reporter.js +0 -389
- package/dist/adapters/refactor-reporter.js.map +0 -1
- package/dist/adapters/reporter.d.ts +0 -13
- package/dist/adapters/reporter.d.ts.map +0 -1
- package/dist/adapters/reporter.js.map +0 -1
- package/dist/agent-generator/context-enricher.d.ts +0 -15
- package/dist/agent-generator/context-enricher.d.ts.map +0 -1
- package/dist/agent-generator/context-enricher.js +0 -53
- package/dist/agent-generator/context-enricher.js.map +0 -1
- package/dist/agent-generator/detectors/base-detector.d.ts +0 -9
- package/dist/agent-generator/detectors/base-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/base-detector.js +0 -12
- package/dist/agent-generator/detectors/base-detector.js.map +0 -1
- package/dist/agent-generator/detectors/dart-detector.d.ts +0 -6
- package/dist/agent-generator/detectors/dart-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/dart-detector.js +0 -15
- package/dist/agent-generator/detectors/dart-detector.js.map +0 -1
- package/dist/agent-generator/detectors/framework-registry.d.ts +0 -6
- package/dist/agent-generator/detectors/framework-registry.d.ts.map +0 -1
- package/dist/agent-generator/detectors/framework-registry.js +0 -81
- package/dist/agent-generator/detectors/framework-registry.js.map +0 -1
- package/dist/agent-generator/detectors/go-detector.d.ts +0 -6
- package/dist/agent-generator/detectors/go-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/go-detector.js +0 -25
- package/dist/agent-generator/detectors/go-detector.js.map +0 -1
- package/dist/agent-generator/detectors/java-detector.d.ts +0 -6
- package/dist/agent-generator/detectors/java-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/java-detector.js +0 -44
- package/dist/agent-generator/detectors/java-detector.js.map +0 -1
- package/dist/agent-generator/detectors/node-detector.d.ts +0 -6
- package/dist/agent-generator/detectors/node-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/node-detector.js +0 -28
- package/dist/agent-generator/detectors/node-detector.js.map +0 -1
- package/dist/agent-generator/detectors/php-detector.d.ts +0 -6
- package/dist/agent-generator/detectors/php-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/php-detector.js +0 -28
- package/dist/agent-generator/detectors/php-detector.js.map +0 -1
- package/dist/agent-generator/detectors/python-detector.d.ts +0 -8
- package/dist/agent-generator/detectors/python-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/python-detector.js +0 -116
- package/dist/agent-generator/detectors/python-detector.js.map +0 -1
- package/dist/agent-generator/detectors/ruby-detector.d.ts +0 -6
- package/dist/agent-generator/detectors/ruby-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/ruby-detector.js +0 -22
- package/dist/agent-generator/detectors/ruby-detector.js.map +0 -1
- package/dist/agent-generator/detectors/rust-detector.d.ts +0 -6
- package/dist/agent-generator/detectors/rust-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/rust-detector.js +0 -18
- package/dist/agent-generator/detectors/rust-detector.js.map +0 -1
- package/dist/agent-generator/detectors/structure-detector.d.ts +0 -5
- package/dist/agent-generator/detectors/structure-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/structure-detector.js +0 -35
- package/dist/agent-generator/detectors/structure-detector.js.map +0 -1
- package/dist/agent-generator/detectors/toolchain-detector.d.ts +0 -6
- package/dist/agent-generator/detectors/toolchain-detector.d.ts.map +0 -1
- package/dist/agent-generator/detectors/toolchain-detector.js +0 -163
- package/dist/agent-generator/detectors/toolchain-detector.js.map +0 -1
- package/dist/agent-generator/domain-inferrer.d.ts +0 -52
- package/dist/agent-generator/domain-inferrer.d.ts.map +0 -1
- package/dist/agent-generator/domain-inferrer.js +0 -585
- package/dist/agent-generator/domain-inferrer.js.map +0 -1
- package/dist/agent-generator/engines/audit-engine.d.ts +0 -7
- package/dist/agent-generator/engines/audit-engine.d.ts.map +0 -1
- package/dist/agent-generator/engines/audit-engine.js +0 -84
- package/dist/agent-generator/engines/audit-engine.js.map +0 -1
- package/dist/agent-generator/engines/context-builder.d.ts +0 -11
- package/dist/agent-generator/engines/context-builder.d.ts.map +0 -1
- package/dist/agent-generator/engines/context-builder.js +0 -86
- package/dist/agent-generator/engines/context-builder.js.map +0 -1
- package/dist/agent-generator/engines/generation-engine.d.ts +0 -9
- package/dist/agent-generator/engines/generation-engine.d.ts.map +0 -1
- package/dist/agent-generator/engines/generation-engine.js +0 -177
- package/dist/agent-generator/engines/generation-engine.js.map +0 -1
- package/dist/agent-generator/engines/suggestion-engine.d.ts +0 -15
- package/dist/agent-generator/engines/suggestion-engine.d.ts.map +0 -1
- package/dist/agent-generator/engines/suggestion-engine.js +0 -176
- package/dist/agent-generator/engines/suggestion-engine.js.map +0 -1
- package/dist/agent-generator/enrichers/analysis-helpers.d.ts +0 -9
- package/dist/agent-generator/enrichers/analysis-helpers.d.ts.map +0 -1
- package/dist/agent-generator/enrichers/analysis-helpers.js +0 -51
- package/dist/agent-generator/enrichers/analysis-helpers.js.map +0 -1
- package/dist/agent-generator/enrichers/description-generator.d.ts +0 -5
- package/dist/agent-generator/enrichers/description-generator.d.ts.map +0 -1
- package/dist/agent-generator/enrichers/description-generator.js +0 -81
- package/dist/agent-generator/enrichers/description-generator.js.map +0 -1
- package/dist/agent-generator/enrichers/endpoint-extractor.d.ts +0 -8
- package/dist/agent-generator/enrichers/endpoint-extractor.d.ts.map +0 -1
- package/dist/agent-generator/enrichers/endpoint-extractor.js +0 -91
- package/dist/agent-generator/enrichers/endpoint-extractor.js.map +0 -1
- package/dist/agent-generator/enrichers/layer-classifier.d.ts +0 -13
- package/dist/agent-generator/enrichers/layer-classifier.d.ts.map +0 -1
- package/dist/agent-generator/enrichers/layer-classifier.js +0 -150
- package/dist/agent-generator/enrichers/layer-classifier.js.map +0 -1
- package/dist/agent-generator/enrichers/module-extractor.d.ts +0 -11
- package/dist/agent-generator/enrichers/module-extractor.d.ts.map +0 -1
- package/dist/agent-generator/enrichers/module-extractor.js +0 -174
- package/dist/agent-generator/enrichers/module-extractor.js.map +0 -1
- package/dist/agent-generator/framework-detector.d.ts +0 -18
- package/dist/agent-generator/framework-detector.d.ts.map +0 -1
- package/dist/agent-generator/framework-detector.js +0 -58
- package/dist/agent-generator/framework-detector.js.map +0 -1
- package/dist/agent-generator/index.d.ts +0 -22
- package/dist/agent-generator/index.d.ts.map +0 -1
- package/dist/agent-generator/index.js +0 -39
- package/dist/agent-generator/index.js.map +0 -1
- package/dist/agent-generator/stack-detector.d.ts +0 -14
- package/dist/agent-generator/stack-detector.d.ts.map +0 -1
- package/dist/agent-generator/stack-detector.js +0 -124
- package/dist/agent-generator/stack-detector.js.map +0 -1
- package/dist/agent-generator/templates/core/agents.d.ts +0 -17
- package/dist/agent-generator/templates/core/agents.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/agents.js +0 -1256
- package/dist/agent-generator/templates/core/agents.js.map +0 -1
- package/dist/agent-generator/templates/core/architecture-rules.d.ts +0 -7
- package/dist/agent-generator/templates/core/architecture-rules.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/architecture-rules.js +0 -274
- package/dist/agent-generator/templates/core/architecture-rules.js.map +0 -1
- package/dist/agent-generator/templates/core/general-rules.d.ts +0 -8
- package/dist/agent-generator/templates/core/general-rules.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/general-rules.js +0 -301
- package/dist/agent-generator/templates/core/general-rules.js.map +0 -1
- package/dist/agent-generator/templates/core/hooks-generator.d.ts +0 -21
- package/dist/agent-generator/templates/core/hooks-generator.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/hooks-generator.js +0 -233
- package/dist/agent-generator/templates/core/hooks-generator.js.map +0 -1
- package/dist/agent-generator/templates/core/index-md.d.ts +0 -7
- package/dist/agent-generator/templates/core/index-md.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/index-md.js +0 -246
- package/dist/agent-generator/templates/core/index-md.js.map +0 -1
- package/dist/agent-generator/templates/core/orchestrator.d.ts +0 -8
- package/dist/agent-generator/templates/core/orchestrator.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/orchestrator.js +0 -422
- package/dist/agent-generator/templates/core/orchestrator.js.map +0 -1
- package/dist/agent-generator/templates/core/preflight.d.ts +0 -8
- package/dist/agent-generator/templates/core/preflight.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/preflight.js +0 -213
- package/dist/agent-generator/templates/core/preflight.js.map +0 -1
- package/dist/agent-generator/templates/core/quality-gates.d.ts +0 -11
- package/dist/agent-generator/templates/core/quality-gates.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/quality-gates.js +0 -254
- package/dist/agent-generator/templates/core/quality-gates.js.map +0 -1
- package/dist/agent-generator/templates/core/security-rules.d.ts +0 -7
- package/dist/agent-generator/templates/core/security-rules.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/security-rules.js +0 -528
- package/dist/agent-generator/templates/core/security-rules.js.map +0 -1
- package/dist/agent-generator/templates/core/skills-generator.d.ts +0 -19
- package/dist/agent-generator/templates/core/skills-generator.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/skills-generator.js +0 -546
- package/dist/agent-generator/templates/core/skills-generator.js.map +0 -1
- package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts +0 -7
- package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/workflow-fix-bug.js +0 -237
- package/dist/agent-generator/templates/core/workflow-fix-bug.js.map +0 -1
- package/dist/agent-generator/templates/core/workflow-new-feature.d.ts +0 -8
- package/dist/agent-generator/templates/core/workflow-new-feature.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/workflow-new-feature.js +0 -321
- package/dist/agent-generator/templates/core/workflow-new-feature.js.map +0 -1
- package/dist/agent-generator/templates/core/workflow-review.d.ts +0 -7
- package/dist/agent-generator/templates/core/workflow-review.d.ts.map +0 -1
- package/dist/agent-generator/templates/core/workflow-review.js +0 -104
- package/dist/agent-generator/templates/core/workflow-review.js.map +0 -1
- package/dist/agent-generator/templates/domain/index.d.ts +0 -22
- package/dist/agent-generator/templates/domain/index.d.ts.map +0 -1
- package/dist/agent-generator/templates/domain/index.js +0 -1176
- package/dist/agent-generator/templates/domain/index.js.map +0 -1
- package/dist/agent-generator/templates/helpers/base-helpers.d.ts +0 -11
- package/dist/agent-generator/templates/helpers/base-helpers.d.ts.map +0 -1
- package/dist/agent-generator/templates/helpers/base-helpers.js +0 -20
- package/dist/agent-generator/templates/helpers/base-helpers.js.map +0 -1
- package/dist/agent-generator/templates/helpers/cross-ref-helpers.d.ts +0 -3
- package/dist/agent-generator/templates/helpers/cross-ref-helpers.d.ts.map +0 -1
- package/dist/agent-generator/templates/helpers/cross-ref-helpers.js +0 -77
- package/dist/agent-generator/templates/helpers/cross-ref-helpers.js.map +0 -1
- package/dist/agent-generator/templates/helpers/security-helpers.d.ts +0 -3
- package/dist/agent-generator/templates/helpers/security-helpers.d.ts.map +0 -1
- package/dist/agent-generator/templates/helpers/security-helpers.js +0 -182
- package/dist/agent-generator/templates/helpers/security-helpers.js.map +0 -1
- package/dist/agent-generator/templates/helpers/stack-helpers.d.ts +0 -5
- package/dist/agent-generator/templates/helpers/stack-helpers.d.ts.map +0 -1
- package/dist/agent-generator/templates/helpers/stack-helpers.js +0 -69
- package/dist/agent-generator/templates/helpers/stack-helpers.js.map +0 -1
- package/dist/agent-generator/templates/helpers/structure-helpers.d.ts +0 -3
- package/dist/agent-generator/templates/helpers/structure-helpers.d.ts.map +0 -1
- package/dist/agent-generator/templates/helpers/structure-helpers.js +0 -275
- package/dist/agent-generator/templates/helpers/structure-helpers.js.map +0 -1
- package/dist/agent-generator/templates/helpers/summary-helpers.d.ts +0 -7
- package/dist/agent-generator/templates/helpers/summary-helpers.d.ts.map +0 -1
- package/dist/agent-generator/templates/helpers/summary-helpers.js +0 -56
- package/dist/agent-generator/templates/helpers/summary-helpers.js.map +0 -1
- package/dist/agent-generator/templates/stack/index.d.ts +0 -8
- package/dist/agent-generator/templates/stack/index.d.ts.map +0 -1
- package/dist/agent-generator/templates/stack/index.js +0 -695
- package/dist/agent-generator/templates/stack/index.js.map +0 -1
- package/dist/agent-generator/templates/template-helpers.d.ts +0 -12
- package/dist/agent-generator/templates/template-helpers.d.ts.map +0 -1
- package/dist/agent-generator/templates/template-helpers.js +0 -12
- package/dist/agent-generator/templates/template-helpers.js.map +0 -1
- package/dist/agent-generator/types.d.ts +0 -196
- package/dist/agent-generator/types.d.ts.map +0 -1
- package/dist/agent-generator/types.js +0 -27
- package/dist/agent-generator/types.js.map +0 -1
- package/dist/analyzer.d.ts +0 -38
- package/dist/analyzer.d.ts.map +0 -1
- package/dist/analyzer.js +0 -383
- package/dist/analyzer.js.map +0 -1
- package/dist/analyzers/forecast.d.ts +0 -85
- package/dist/analyzers/forecast.d.ts.map +0 -1
- package/dist/analyzers/forecast.js +0 -337
- package/dist/analyzers/forecast.js.map +0 -1
- package/dist/analyzers/git-cache.d.ts +0 -7
- package/dist/analyzers/git-cache.d.ts.map +0 -1
- package/dist/analyzers/git-cache.js +0 -41
- package/dist/analyzers/git-cache.js.map +0 -1
- package/dist/analyzers/git-history.d.ts +0 -113
- package/dist/analyzers/git-history.d.ts.map +0 -1
- package/dist/analyzers/git-history.js +0 -339
- package/dist/analyzers/git-history.js.map +0 -1
- package/dist/analyzers/index.d.ts +0 -10
- package/dist/analyzers/index.d.ts.map +0 -1
- package/dist/analyzers/index.js +0 -7
- package/dist/analyzers/index.js.map +0 -1
- package/dist/analyzers/temporal-scorer.d.ts +0 -72
- package/dist/analyzers/temporal-scorer.d.ts.map +0 -1
- package/dist/analyzers/temporal-scorer.js +0 -140
- package/dist/analyzers/temporal-scorer.js.map +0 -1
- package/dist/anti-patterns.d.ts +0 -24
- package/dist/anti-patterns.d.ts.map +0 -1
- package/dist/anti-patterns.js +0 -230
- package/dist/anti-patterns.js.map +0 -1
- package/dist/cli.d.ts +0 -14
- package/dist/cli.d.ts.map +0 -1
- package/dist/cli.js.map +0 -1
- package/dist/config.d.ts +0 -12
- package/dist/config.d.ts.map +0 -1
- package/dist/config.js +0 -110
- package/dist/config.js.map +0 -1
- package/dist/core/agent-generator/context-enricher.d.ts +0 -18
- package/dist/core/agent-generator/context-enricher.d.ts.map +0 -1
- package/dist/core/agent-generator/context-enricher.js +0 -53
- package/dist/core/agent-generator/context-enricher.js.map +0 -1
- package/dist/core/agent-generator/detectors/base-detector.d.ts +0 -9
- package/dist/core/agent-generator/detectors/base-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/base-detector.js +0 -12
- package/dist/core/agent-generator/detectors/base-detector.js.map +0 -1
- package/dist/core/agent-generator/detectors/dart-detector.d.ts +0 -6
- package/dist/core/agent-generator/detectors/dart-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/dart-detector.js +0 -15
- package/dist/core/agent-generator/detectors/dart-detector.js.map +0 -1
- package/dist/core/agent-generator/detectors/framework-registry.d.ts +0 -6
- package/dist/core/agent-generator/detectors/framework-registry.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/framework-registry.js +0 -81
- package/dist/core/agent-generator/detectors/framework-registry.js.map +0 -1
- package/dist/core/agent-generator/detectors/go-detector.d.ts +0 -6
- package/dist/core/agent-generator/detectors/go-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/go-detector.js +0 -25
- package/dist/core/agent-generator/detectors/go-detector.js.map +0 -1
- package/dist/core/agent-generator/detectors/java-detector.d.ts +0 -6
- package/dist/core/agent-generator/detectors/java-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/java-detector.js +0 -44
- package/dist/core/agent-generator/detectors/java-detector.js.map +0 -1
- package/dist/core/agent-generator/detectors/node-detector.d.ts +0 -6
- package/dist/core/agent-generator/detectors/node-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/node-detector.js +0 -28
- package/dist/core/agent-generator/detectors/node-detector.js.map +0 -1
- package/dist/core/agent-generator/detectors/php-detector.d.ts +0 -6
- package/dist/core/agent-generator/detectors/php-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/php-detector.js +0 -28
- package/dist/core/agent-generator/detectors/php-detector.js.map +0 -1
- package/dist/core/agent-generator/detectors/python-detector.d.ts +0 -8
- package/dist/core/agent-generator/detectors/python-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/python-detector.js +0 -116
- package/dist/core/agent-generator/detectors/python-detector.js.map +0 -1
- package/dist/core/agent-generator/detectors/ruby-detector.d.ts +0 -6
- package/dist/core/agent-generator/detectors/ruby-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/ruby-detector.js +0 -22
- package/dist/core/agent-generator/detectors/ruby-detector.js.map +0 -1
- package/dist/core/agent-generator/detectors/rust-detector.d.ts +0 -6
- package/dist/core/agent-generator/detectors/rust-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/rust-detector.js +0 -18
- package/dist/core/agent-generator/detectors/rust-detector.js.map +0 -1
- package/dist/core/agent-generator/detectors/structure-detector.d.ts +0 -5
- package/dist/core/agent-generator/detectors/structure-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/structure-detector.js +0 -35
- package/dist/core/agent-generator/detectors/structure-detector.js.map +0 -1
- package/dist/core/agent-generator/detectors/toolchain-detector.d.ts +0 -6
- package/dist/core/agent-generator/detectors/toolchain-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/detectors/toolchain-detector.js +0 -163
- package/dist/core/agent-generator/detectors/toolchain-detector.js.map +0 -1
- package/dist/core/agent-generator/domain-inferrer.d.ts +0 -52
- package/dist/core/agent-generator/domain-inferrer.d.ts.map +0 -1
- package/dist/core/agent-generator/domain-inferrer.js +0 -585
- package/dist/core/agent-generator/domain-inferrer.js.map +0 -1
- package/dist/core/agent-generator/engines/audit-engine.d.ts +0 -9
- package/dist/core/agent-generator/engines/audit-engine.d.ts.map +0 -1
- package/dist/core/agent-generator/engines/audit-engine.js +0 -84
- package/dist/core/agent-generator/engines/audit-engine.js.map +0 -1
- package/dist/core/agent-generator/engines/context-builder.d.ts +0 -13
- package/dist/core/agent-generator/engines/context-builder.d.ts.map +0 -1
- package/dist/core/agent-generator/engines/context-builder.js +0 -86
- package/dist/core/agent-generator/engines/context-builder.js.map +0 -1
- package/dist/core/agent-generator/engines/generation-engine.d.ts +0 -8
- package/dist/core/agent-generator/engines/generation-engine.d.ts.map +0 -1
- package/dist/core/agent-generator/engines/generation-engine.js +0 -162
- package/dist/core/agent-generator/engines/generation-engine.js.map +0 -1
- package/dist/core/agent-generator/engines/generation-engine_deps.d.ts +0 -22
- package/dist/core/agent-generator/engines/generation-engine_deps.d.ts.map +0 -1
- package/dist/core/agent-generator/engines/generation-engine_deps.js +0 -17
- package/dist/core/agent-generator/engines/generation-engine_deps.js.map +0 -1
- package/dist/core/agent-generator/engines/suggestion-engine.d.ts +0 -14
- package/dist/core/agent-generator/engines/suggestion-engine.d.ts.map +0 -1
- package/dist/core/agent-generator/engines/suggestion-engine.js +0 -173
- package/dist/core/agent-generator/engines/suggestion-engine.js.map +0 -1
- package/dist/core/agent-generator/engines/suggestion-engine_deps.d.ts +0 -9
- package/dist/core/agent-generator/engines/suggestion-engine_deps.d.ts.map +0 -1
- package/dist/core/agent-generator/engines/suggestion-engine_deps.js +0 -5
- package/dist/core/agent-generator/engines/suggestion-engine_deps.js.map +0 -1
- package/dist/core/agent-generator/enrichers/analysis-helpers.d.ts +0 -10
- package/dist/core/agent-generator/enrichers/analysis-helpers.d.ts.map +0 -1
- package/dist/core/agent-generator/enrichers/analysis-helpers.js +0 -51
- package/dist/core/agent-generator/enrichers/analysis-helpers.js.map +0 -1
- package/dist/core/agent-generator/enrichers/description-generator.d.ts +0 -5
- package/dist/core/agent-generator/enrichers/description-generator.d.ts.map +0 -1
- package/dist/core/agent-generator/enrichers/description-generator.js +0 -81
- package/dist/core/agent-generator/enrichers/description-generator.js.map +0 -1
- package/dist/core/agent-generator/enrichers/endpoint-extractor.d.ts +0 -8
- package/dist/core/agent-generator/enrichers/endpoint-extractor.d.ts.map +0 -1
- package/dist/core/agent-generator/enrichers/endpoint-extractor.js +0 -91
- package/dist/core/agent-generator/enrichers/endpoint-extractor.js.map +0 -1
- package/dist/core/agent-generator/enrichers/layer-classifier.d.ts +0 -13
- package/dist/core/agent-generator/enrichers/layer-classifier.d.ts.map +0 -1
- package/dist/core/agent-generator/enrichers/layer-classifier.js +0 -150
- package/dist/core/agent-generator/enrichers/layer-classifier.js.map +0 -1
- package/dist/core/agent-generator/enrichers/module-extractor.d.ts +0 -11
- package/dist/core/agent-generator/enrichers/module-extractor.d.ts.map +0 -1
- package/dist/core/agent-generator/enrichers/module-extractor.js +0 -174
- package/dist/core/agent-generator/enrichers/module-extractor.js.map +0 -1
- package/dist/core/agent-generator/framework-detector.d.ts +0 -18
- package/dist/core/agent-generator/framework-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/framework-detector.js +0 -58
- package/dist/core/agent-generator/framework-detector.js.map +0 -1
- package/dist/core/agent-generator/index.d.ts +0 -26
- package/dist/core/agent-generator/index.d.ts.map +0 -1
- package/dist/core/agent-generator/index.js +0 -39
- package/dist/core/agent-generator/index.js.map +0 -1
- package/dist/core/agent-generator/stack-detector.d.ts +0 -14
- package/dist/core/agent-generator/stack-detector.d.ts.map +0 -1
- package/dist/core/agent-generator/stack-detector.js +0 -124
- package/dist/core/agent-generator/stack-detector.js.map +0 -1
- package/dist/core/agent-generator/templates/core/agents.d.ts +0 -17
- package/dist/core/agent-generator/templates/core/agents.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/agents.js +0 -1256
- package/dist/core/agent-generator/templates/core/agents.js.map +0 -1
- package/dist/core/agent-generator/templates/core/architecture-rules.d.ts +0 -7
- package/dist/core/agent-generator/templates/core/architecture-rules.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/architecture-rules.js +0 -274
- package/dist/core/agent-generator/templates/core/architecture-rules.js.map +0 -1
- package/dist/core/agent-generator/templates/core/general-rules.d.ts +0 -8
- package/dist/core/agent-generator/templates/core/general-rules.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/general-rules.js +0 -301
- package/dist/core/agent-generator/templates/core/general-rules.js.map +0 -1
- package/dist/core/agent-generator/templates/core/hooks-generator.d.ts +0 -21
- package/dist/core/agent-generator/templates/core/hooks-generator.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/hooks-generator.js +0 -233
- package/dist/core/agent-generator/templates/core/hooks-generator.js.map +0 -1
- package/dist/core/agent-generator/templates/core/index-md.d.ts +0 -7
- package/dist/core/agent-generator/templates/core/index-md.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/index-md.js +0 -246
- package/dist/core/agent-generator/templates/core/index-md.js.map +0 -1
- package/dist/core/agent-generator/templates/core/orchestrator.d.ts +0 -8
- package/dist/core/agent-generator/templates/core/orchestrator.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/orchestrator.js +0 -422
- package/dist/core/agent-generator/templates/core/orchestrator.js.map +0 -1
- package/dist/core/agent-generator/templates/core/preflight.d.ts +0 -8
- package/dist/core/agent-generator/templates/core/preflight.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/preflight.js +0 -213
- package/dist/core/agent-generator/templates/core/preflight.js.map +0 -1
- package/dist/core/agent-generator/templates/core/quality-gates.d.ts +0 -11
- package/dist/core/agent-generator/templates/core/quality-gates.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/quality-gates.js +0 -254
- package/dist/core/agent-generator/templates/core/quality-gates.js.map +0 -1
- package/dist/core/agent-generator/templates/core/security-rules.d.ts +0 -7
- package/dist/core/agent-generator/templates/core/security-rules.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/security-rules.js +0 -528
- package/dist/core/agent-generator/templates/core/security-rules.js.map +0 -1
- package/dist/core/agent-generator/templates/core/skills-generator.d.ts +0 -19
- package/dist/core/agent-generator/templates/core/skills-generator.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/skills-generator.js +0 -546
- package/dist/core/agent-generator/templates/core/skills-generator.js.map +0 -1
- package/dist/core/agent-generator/templates/core/workflow-fix-bug.d.ts +0 -7
- package/dist/core/agent-generator/templates/core/workflow-fix-bug.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/workflow-fix-bug.js +0 -237
- package/dist/core/agent-generator/templates/core/workflow-fix-bug.js.map +0 -1
- package/dist/core/agent-generator/templates/core/workflow-new-feature.d.ts +0 -8
- package/dist/core/agent-generator/templates/core/workflow-new-feature.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/workflow-new-feature.js +0 -321
- package/dist/core/agent-generator/templates/core/workflow-new-feature.js.map +0 -1
- package/dist/core/agent-generator/templates/core/workflow-review.d.ts +0 -7
- package/dist/core/agent-generator/templates/core/workflow-review.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/core/workflow-review.js +0 -104
- package/dist/core/agent-generator/templates/core/workflow-review.js.map +0 -1
- package/dist/core/agent-generator/templates/domain/index.d.ts +0 -22
- package/dist/core/agent-generator/templates/domain/index.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/domain/index.js +0 -1176
- package/dist/core/agent-generator/templates/domain/index.js.map +0 -1
- package/dist/core/agent-generator/templates/helpers/base-helpers.d.ts +0 -11
- package/dist/core/agent-generator/templates/helpers/base-helpers.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/helpers/base-helpers.js +0 -20
- package/dist/core/agent-generator/templates/helpers/base-helpers.js.map +0 -1
- package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.d.ts +0 -3
- package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.js +0 -77
- package/dist/core/agent-generator/templates/helpers/cross-ref-helpers.js.map +0 -1
- package/dist/core/agent-generator/templates/helpers/security-helpers.d.ts +0 -3
- package/dist/core/agent-generator/templates/helpers/security-helpers.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/helpers/security-helpers.js +0 -182
- package/dist/core/agent-generator/templates/helpers/security-helpers.js.map +0 -1
- package/dist/core/agent-generator/templates/helpers/stack-helpers.d.ts +0 -5
- package/dist/core/agent-generator/templates/helpers/stack-helpers.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/helpers/stack-helpers.js +0 -69
- package/dist/core/agent-generator/templates/helpers/stack-helpers.js.map +0 -1
- package/dist/core/agent-generator/templates/helpers/structure-helpers.d.ts +0 -3
- package/dist/core/agent-generator/templates/helpers/structure-helpers.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/helpers/structure-helpers.js +0 -275
- package/dist/core/agent-generator/templates/helpers/structure-helpers.js.map +0 -1
- package/dist/core/agent-generator/templates/helpers/summary-helpers.d.ts +0 -7
- package/dist/core/agent-generator/templates/helpers/summary-helpers.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/helpers/summary-helpers.js +0 -56
- package/dist/core/agent-generator/templates/helpers/summary-helpers.js.map +0 -1
- package/dist/core/agent-generator/templates/stack/index.d.ts +0 -8
- package/dist/core/agent-generator/templates/stack/index.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/stack/index.js +0 -695
- package/dist/core/agent-generator/templates/stack/index.js.map +0 -1
- package/dist/core/agent-generator/templates/template-helpers.d.ts +0 -12
- package/dist/core/agent-generator/templates/template-helpers.d.ts.map +0 -1
- package/dist/core/agent-generator/templates/template-helpers.js +0 -12
- package/dist/core/agent-generator/templates/template-helpers.js.map +0 -1
- package/dist/core/agent-generator/types/agent.d.ts +0 -40
- package/dist/core/agent-generator/types/agent.d.ts.map +0 -1
- package/dist/core/agent-generator/types/agent.js +0 -27
- package/dist/core/agent-generator/types/agent.js.map +0 -1
- package/dist/core/agent-generator/types/domain.d.ts +0 -59
- package/dist/core/agent-generator/types/domain.d.ts.map +0 -1
- package/dist/core/agent-generator/types/domain.js +0 -2
- package/dist/core/agent-generator/types/domain.js.map +0 -1
- package/dist/core/agent-generator/types/stack.d.ts +0 -37
- package/dist/core/agent-generator/types/stack.d.ts.map +0 -1
- package/dist/core/agent-generator/types/stack.js +0 -2
- package/dist/core/agent-generator/types/stack.js.map +0 -1
- package/dist/core/agent-generator/types/template.d.ts +0 -30
- package/dist/core/agent-generator/types/template.d.ts.map +0 -1
- package/dist/core/agent-generator/types/template.js +0 -2
- package/dist/core/agent-generator/types/template.js.map +0 -1
- package/dist/core/agent-generator/types.d.ts +0 -197
- package/dist/core/agent-generator/types.d.ts.map +0 -1
- package/dist/core/agent-generator/types.js +0 -27
- package/dist/core/agent-generator/types.js.map +0 -1
- package/dist/core/analyzer.d.ts +0 -39
- package/dist/core/analyzer.d.ts.map +0 -1
- package/dist/core/analyzer.js +0 -383
- package/dist/core/analyzer.js.map +0 -1
- package/dist/core/analyzers/forecast.d.ts +0 -85
- package/dist/core/analyzers/forecast.d.ts.map +0 -1
- package/dist/core/analyzers/forecast.js +0 -337
- package/dist/core/analyzers/forecast.js.map +0 -1
- package/dist/core/analyzers/index.d.ts +0 -10
- package/dist/core/analyzers/index.d.ts.map +0 -1
- package/dist/core/analyzers/index.js +0 -7
- package/dist/core/analyzers/index.js.map +0 -1
- package/dist/core/analyzers/temporal-scorer.d.ts +0 -72
- package/dist/core/analyzers/temporal-scorer.d.ts.map +0 -1
- package/dist/core/analyzers/temporal-scorer.js +0 -140
- package/dist/core/analyzers/temporal-scorer.js.map +0 -1
- package/dist/core/anti-patterns.d.ts +0 -25
- package/dist/core/anti-patterns.d.ts.map +0 -1
- package/dist/core/anti-patterns.js +0 -239
- package/dist/core/anti-patterns.js.map +0 -1
- package/dist/core/architect.d.ts.map +0 -1
- package/dist/core/architect.js.map +0 -1
- package/dist/core/architect_deps.d.ts +0 -14
- package/dist/core/architect_deps.d.ts.map +0 -1
- package/dist/core/architect_deps.js +0 -12
- package/dist/core/architect_deps.js.map +0 -1
- package/dist/core/config.d.ts +0 -12
- package/dist/core/config.d.ts.map +0 -1
- package/dist/core/config.js +0 -110
- package/dist/core/config.js.map +0 -1
- package/dist/core/diagram.d.ts +0 -10
- package/dist/core/diagram.d.ts.map +0 -1
- package/dist/core/diagram.js +0 -101
- package/dist/core/diagram.js.map +0 -1
- package/dist/core/project-summarizer.d.ts +0 -17
- package/dist/core/project-summarizer.d.ts.map +0 -1
- package/dist/core/project-summarizer.js +0 -39
- package/dist/core/project-summarizer.js.map +0 -1
- package/dist/core/refactor-engine.d.ts +0 -19
- package/dist/core/refactor-engine.d.ts.map +0 -1
- package/dist/core/refactor-engine.js +0 -86
- package/dist/core/refactor-engine.js.map +0 -1
- package/dist/core/rules/barrel-optimizer.d.ts +0 -14
- package/dist/core/rules/barrel-optimizer.d.ts.map +0 -1
- package/dist/core/rules/barrel-optimizer.js +0 -78
- package/dist/core/rules/barrel-optimizer.js.map +0 -1
- package/dist/core/rules/dead-code-detector.d.ts +0 -22
- package/dist/core/rules/dead-code-detector.d.ts.map +0 -1
- package/dist/core/rules/dead-code-detector.js +0 -118
- package/dist/core/rules/dead-code-detector.js.map +0 -1
- package/dist/core/rules/hub-splitter.d.ts +0 -14
- package/dist/core/rules/hub-splitter.d.ts.map +0 -1
- package/dist/core/rules/hub-splitter.js +0 -119
- package/dist/core/rules/hub-splitter.js.map +0 -1
- package/dist/core/rules/import-organizer.d.ts +0 -14
- package/dist/core/rules/import-organizer.d.ts.map +0 -1
- package/dist/core/rules/import-organizer.js +0 -86
- package/dist/core/rules/import-organizer.js.map +0 -1
- package/dist/core/rules/module-grouper.d.ts +0 -14
- package/dist/core/rules/module-grouper.d.ts.map +0 -1
- package/dist/core/rules/module-grouper.js +0 -118
- package/dist/core/rules/module-grouper.js.map +0 -1
- package/dist/core/scorer.d.ts +0 -27
- package/dist/core/scorer.d.ts.map +0 -1
- package/dist/core/scorer.js +0 -229
- package/dist/core/scorer.js.map +0 -1
- package/dist/core/summarizer/keyword-extractor.d.ts +0 -7
- package/dist/core/summarizer/keyword-extractor.d.ts.map +0 -1
- package/dist/core/summarizer/keyword-extractor.js +0 -37
- package/dist/core/summarizer/keyword-extractor.js.map +0 -1
- package/dist/core/summarizer/module-inferrer.d.ts +0 -12
- package/dist/core/summarizer/module-inferrer.d.ts.map +0 -1
- package/dist/core/summarizer/module-inferrer.js +0 -171
- package/dist/core/summarizer/module-inferrer.js.map +0 -1
- package/dist/core/summarizer/package-reader.d.ts +0 -4
- package/dist/core/summarizer/package-reader.d.ts.map +0 -1
- package/dist/core/summarizer/package-reader.js +0 -30
- package/dist/core/summarizer/package-reader.js.map +0 -1
- package/dist/core/summarizer/purpose-inferrer.d.ts +0 -9
- package/dist/core/summarizer/purpose-inferrer.d.ts.map +0 -1
- package/dist/core/summarizer/purpose-inferrer.js +0 -178
- package/dist/core/summarizer/purpose-inferrer.js.map +0 -1
- package/dist/core/summarizer/readme-reader.d.ts +0 -4
- package/dist/core/summarizer/readme-reader.d.ts.map +0 -1
- package/dist/core/summarizer/readme-reader.js +0 -21
- package/dist/core/summarizer/readme-reader.js.map +0 -1
- package/dist/core/types/core.d.ts +0 -87
- package/dist/core/types/core.d.ts.map +0 -1
- package/dist/core/types/core.js +0 -2
- package/dist/core/types/core.js.map +0 -1
- package/dist/core/types/infrastructure.d.ts +0 -39
- package/dist/core/types/infrastructure.d.ts.map +0 -1
- package/dist/core/types/infrastructure.js +0 -2
- package/dist/core/types/infrastructure.js.map +0 -1
- package/dist/core/types/rules.d.ts +0 -54
- package/dist/core/types/rules.d.ts.map +0 -1
- package/dist/core/types/rules.js +0 -2
- package/dist/core/types/rules.js.map +0 -1
- package/dist/core/types/summarizer.d.ts +0 -13
- package/dist/core/types/summarizer.d.ts.map +0 -1
- package/dist/core/types/summarizer.js +0 -2
- package/dist/core/types/summarizer.js.map +0 -1
- package/dist/core/types.d.ts +0 -187
- package/dist/core/types.d.ts.map +0 -1
- package/dist/core/types.js +0 -2
- package/dist/core/types.js.map +0 -1
- package/dist/diagram.d.ts +0 -10
- package/dist/diagram.d.ts.map +0 -1
- package/dist/diagram.js +0 -101
- package/dist/diagram.js.map +0 -1
- package/dist/html-reporter/scripts.d.ts.map +0 -1
- package/dist/html-reporter/scripts.js +0 -316
- package/dist/html-reporter/scripts.js.map +0 -1
- package/dist/html-reporter/sections/agents.d.ts +0 -3
- package/dist/html-reporter/sections/agents.d.ts.map +0 -1
- package/dist/html-reporter/sections/agents.js.map +0 -1
- package/dist/html-reporter/sections/anti-patterns.d.ts.map +0 -1
- package/dist/html-reporter/sections/anti-patterns.js +0 -64
- package/dist/html-reporter/sections/anti-patterns.js.map +0 -1
- package/dist/html-reporter/sections/header.d.ts.map +0 -1
- package/dist/html-reporter/sections/header.js +0 -30
- package/dist/html-reporter/sections/header.js.map +0 -1
- package/dist/html-reporter/sections/layers.d.ts.map +0 -1
- package/dist/html-reporter/sections/layers.js +0 -143
- package/dist/html-reporter/sections/layers.js.map +0 -1
- package/dist/html-reporter/sections/overview.d.ts +0 -3
- package/dist/html-reporter/sections/overview.d.ts.map +0 -1
- package/dist/html-reporter/sections/overview.js +0 -58
- package/dist/html-reporter/sections/overview.js.map +0 -1
- package/dist/html-reporter/sections/refactoring-plan.d.ts.map +0 -1
- package/dist/html-reporter/sections/refactoring-plan.js +0 -120
- package/dist/html-reporter/sections/refactoring-plan.js.map +0 -1
- package/dist/html-reporter/sections/score.d.ts.map +0 -1
- package/dist/html-reporter/sections/score.js +0 -69
- package/dist/html-reporter/sections/score.js.map +0 -1
- package/dist/html-reporter/sections/suggestions.d.ts +0 -8
- package/dist/html-reporter/sections/suggestions.d.ts.map +0 -1
- package/dist/html-reporter/sections/suggestions.js +0 -34
- package/dist/html-reporter/sections/suggestions.js.map +0 -1
- package/dist/html-reporter/styles.d.ts +0 -2
- package/dist/html-reporter/styles.d.ts.map +0 -1
- package/dist/html-reporter/styles.js +0 -504
- package/dist/html-reporter/styles.js.map +0 -1
- package/dist/html-reporter/utils.d.ts +0 -27
- package/dist/html-reporter/utils.d.ts.map +0 -1
- package/dist/html-reporter/utils.js +0 -82
- package/dist/html-reporter/utils.js.map +0 -1
- package/dist/html-reporter.d.ts.map +0 -1
- package/dist/html-reporter.js.map +0 -1
- package/dist/index.d.ts +0 -17
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -14
- package/dist/index.js.map +0 -1
- package/dist/infrastructure/git-cache.d.ts +0 -7
- package/dist/infrastructure/git-cache.d.ts.map +0 -1
- package/dist/infrastructure/git-cache.js +0 -41
- package/dist/infrastructure/git-cache.js.map +0 -1
- package/dist/infrastructure/git-history.d.ts +0 -113
- package/dist/infrastructure/git-history.d.ts.map +0 -1
- package/dist/infrastructure/git-history.js +0 -339
- package/dist/infrastructure/git-history.js.map +0 -1
- package/dist/infrastructure/logger.d.ts +0 -21
- package/dist/infrastructure/logger.d.ts.map +0 -1
- package/dist/infrastructure/logger.js +0 -59
- package/dist/infrastructure/logger.js.map +0 -1
- package/dist/infrastructure/scanner.d.ts +0 -32
- package/dist/infrastructure/scanner.d.ts.map +0 -1
- package/dist/infrastructure/scanner.js +0 -330
- package/dist/infrastructure/scanner.js.map +0 -1
- package/dist/logger.d.ts +0 -21
- package/dist/logger.d.ts.map +0 -1
- package/dist/logger.js +0 -59
- package/dist/logger.js.map +0 -1
- package/dist/project-summarizer.d.ts +0 -16
- package/dist/project-summarizer.d.ts.map +0 -1
- package/dist/project-summarizer.js +0 -39
- package/dist/project-summarizer.js.map +0 -1
- package/dist/refactor-engine.d.ts +0 -18
- package/dist/refactor-engine.d.ts.map +0 -1
- package/dist/refactor-engine.js +0 -86
- package/dist/refactor-engine.js.map +0 -1
- package/dist/refactor-reporter.d.ts.map +0 -1
- package/dist/refactor-reporter.js.map +0 -1
- package/dist/reporter.d.ts.map +0 -1
- package/dist/reporter.js +0 -135
- package/dist/reporter.js.map +0 -1
- package/dist/rules/barrel-optimizer.d.ts +0 -13
- package/dist/rules/barrel-optimizer.d.ts.map +0 -1
- package/dist/rules/barrel-optimizer.js +0 -77
- package/dist/rules/barrel-optimizer.js.map +0 -1
- package/dist/rules/dead-code-detector.d.ts +0 -21
- package/dist/rules/dead-code-detector.d.ts.map +0 -1
- package/dist/rules/dead-code-detector.js +0 -117
- package/dist/rules/dead-code-detector.js.map +0 -1
- package/dist/rules/hub-splitter.d.ts +0 -13
- package/dist/rules/hub-splitter.d.ts.map +0 -1
- package/dist/rules/hub-splitter.js +0 -110
- package/dist/rules/hub-splitter.js.map +0 -1
- package/dist/rules/import-organizer.d.ts +0 -13
- package/dist/rules/import-organizer.d.ts.map +0 -1
- package/dist/rules/import-organizer.js +0 -85
- package/dist/rules/import-organizer.js.map +0 -1
- package/dist/rules/module-grouper.d.ts +0 -13
- package/dist/rules/module-grouper.d.ts.map +0 -1
- package/dist/rules/module-grouper.js +0 -110
- package/dist/rules/module-grouper.js.map +0 -1
- package/dist/scanner.d.ts +0 -31
- package/dist/scanner.d.ts.map +0 -1
- package/dist/scanner.js +0 -330
- package/dist/scanner.js.map +0 -1
- package/dist/scorer.d.ts +0 -27
- package/dist/scorer.d.ts.map +0 -1
- package/dist/scorer.js +0 -229
- package/dist/scorer.js.map +0 -1
- package/dist/summarizer/keyword-extractor.d.ts +0 -6
- package/dist/summarizer/keyword-extractor.d.ts.map +0 -1
- package/dist/summarizer/keyword-extractor.js +0 -37
- package/dist/summarizer/keyword-extractor.js.map +0 -1
- package/dist/summarizer/module-inferrer.d.ts +0 -10
- package/dist/summarizer/module-inferrer.d.ts.map +0 -1
- package/dist/summarizer/module-inferrer.js +0 -171
- package/dist/summarizer/module-inferrer.js.map +0 -1
- package/dist/summarizer/package-reader.d.ts +0 -4
- package/dist/summarizer/package-reader.d.ts.map +0 -1
- package/dist/summarizer/package-reader.js +0 -30
- package/dist/summarizer/package-reader.js.map +0 -1
- package/dist/summarizer/purpose-inferrer.d.ts +0 -8
- package/dist/summarizer/purpose-inferrer.d.ts.map +0 -1
- package/dist/summarizer/purpose-inferrer.js +0 -178
- package/dist/summarizer/purpose-inferrer.js.map +0 -1
- package/dist/summarizer/readme-reader.d.ts +0 -4
- package/dist/summarizer/readme-reader.d.ts.map +0 -1
- package/dist/summarizer/readme-reader.js +0 -21
- package/dist/summarizer/readme-reader.js.map +0 -1
- package/dist/types.d.ts +0 -186
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -2
- package/dist/types.js.map +0 -1
- package/examples/sample-report.md +0 -207
- package/fix-scorer.js +0 -18
- package/fix-tests.js +0 -73
- package/jest.config.js +0 -18
- package/scripts/decompose-detectors.ts +0 -183
- package/scripts/decompose-detectors_deps.ts +0 -16
- package/scripts/decompose-enrichers.ts +0 -191
- package/scripts/decompose-enrichers_deps.ts +0 -10
- package/scripts/decompose-helpers.ts +0 -92
- package/scripts/decompose-summarizer.ts +0 -127
- package/setup-refactor.sh +0 -21
- package/src/adapters/html-reporter_deps.ts +0 -14
- package/src/core/agent-generator/context-enricher.ts +0 -67
- package/src/core/agent-generator/detectors/base-detector.ts +0 -18
- package/src/core/agent-generator/detectors/dart-detector.ts +0 -17
- package/src/core/agent-generator/detectors/framework-registry.ts +0 -82
- package/src/core/agent-generator/detectors/go-detector.ts +0 -26
- package/src/core/agent-generator/detectors/java-detector.ts +0 -46
- package/src/core/agent-generator/detectors/node-detector.ts +0 -28
- package/src/core/agent-generator/detectors/php-detector.ts +0 -28
- package/src/core/agent-generator/detectors/python-detector.ts +0 -125
- package/src/core/agent-generator/detectors/ruby-detector.ts +0 -24
- package/src/core/agent-generator/detectors/rust-detector.ts +0 -19
- package/src/core/agent-generator/detectors/structure-detector.ts +0 -38
- package/src/core/agent-generator/detectors/toolchain-detector.ts +0 -180
- package/src/core/agent-generator/domain-inferrer.ts +0 -630
- package/src/core/agent-generator/engines/audit-engine.ts +0 -98
- package/src/core/agent-generator/engines/context-builder.ts +0 -96
- package/src/core/agent-generator/engines/generation-engine.ts +0 -184
- package/src/core/agent-generator/engines/generation-engine_deps.ts +0 -21
- package/src/core/agent-generator/engines/suggestion-engine.ts +0 -202
- package/src/core/agent-generator/engines/suggestion-engine_deps.ts +0 -8
- package/src/core/agent-generator/enrichers/analysis-helpers.ts +0 -58
- package/src/core/agent-generator/enrichers/description-generator.ts +0 -91
- package/src/core/agent-generator/enrichers/endpoint-extractor.ts +0 -114
- package/src/core/agent-generator/enrichers/layer-classifier.ts +0 -156
- package/src/core/agent-generator/enrichers/module-extractor.ts +0 -203
- package/src/core/agent-generator/framework-detector.ts +0 -66
- package/src/core/agent-generator/index.ts +0 -55
- package/src/core/agent-generator/stack-detector.ts +0 -115
- package/src/core/agent-generator/templates/core/agents.ts +0 -1296
- package/src/core/agent-generator/templates/core/architecture-rules.ts +0 -287
- package/src/core/agent-generator/templates/core/general-rules.ts +0 -306
- package/src/core/agent-generator/templates/core/hooks-generator.ts +0 -242
- package/src/core/agent-generator/templates/core/index-md.ts +0 -260
- package/src/core/agent-generator/templates/core/orchestrator.ts +0 -459
- package/src/core/agent-generator/templates/core/preflight.ts +0 -215
- package/src/core/agent-generator/templates/core/quality-gates.ts +0 -256
- package/src/core/agent-generator/templates/core/security-rules.ts +0 -543
- package/src/core/agent-generator/templates/core/skills-generator.ts +0 -585
- package/src/core/agent-generator/templates/core/workflow-fix-bug.ts +0 -239
- package/src/core/agent-generator/templates/core/workflow-new-feature.ts +0 -323
- package/src/core/agent-generator/templates/core/workflow-review.ts +0 -106
- package/src/core/agent-generator/templates/domain/index.ts +0 -1201
- package/src/core/agent-generator/templates/helpers/base-helpers.ts +0 -32
- package/src/core/agent-generator/templates/helpers/cross-ref-helpers.ts +0 -79
- package/src/core/agent-generator/templates/helpers/security-helpers.ts +0 -196
- package/src/core/agent-generator/templates/helpers/stack-helpers.ts +0 -78
- package/src/core/agent-generator/templates/helpers/structure-helpers.ts +0 -291
- package/src/core/agent-generator/templates/helpers/summary-helpers.ts +0 -65
- package/src/core/agent-generator/templates/stack/index.ts +0 -705
- package/src/core/agent-generator/templates/template-helpers.ts +0 -12
- package/src/core/agent-generator/types/agent.ts +0 -65
- package/src/core/agent-generator/types/domain.ts +0 -63
- package/src/core/agent-generator/types/stack.ts +0 -38
- package/src/core/agent-generator/types/template.ts +0 -31
- package/src/core/analyzer.ts +0 -448
- package/src/core/analyzers/forecast.ts +0 -496
- package/src/core/analyzers/index.ts +0 -33
- package/src/core/analyzers/temporal-scorer.ts +0 -227
- package/src/core/anti-patterns.ts +0 -297
- package/src/core/architect_deps.ts +0 -13
- package/src/core/config.ts +0 -123
- package/src/core/diagram.ts +0 -129
- package/src/core/project-summarizer.ts +0 -42
- package/src/core/refactor-engine.ts +0 -112
- package/src/core/rules/barrel-optimizer.ts +0 -99
- package/src/core/rules/dead-code-detector.ts +0 -134
- package/src/core/rules/hub-splitter.ts +0 -135
- package/src/core/rules/import-organizer.ts +0 -100
- package/src/core/rules/module-grouper.ts +0 -133
- package/src/core/scorer.ts +0 -254
- package/src/core/summarizer/keyword-extractor.ts +0 -53
- package/src/core/summarizer/module-inferrer.ts +0 -194
- package/src/core/summarizer/package-reader.ts +0 -34
- package/src/core/summarizer/purpose-inferrer.ts +0 -197
- package/src/core/summarizer/readme-reader.ts +0 -24
- package/src/core/types/core.ts +0 -93
- package/src/core/types/infrastructure.ts +0 -41
- package/src/core/types/rules.ts +0 -51
- package/src/core/types/summarizer.ts +0 -8
- package/src/index.ts +0 -27
- package/src/infrastructure/git-cache.ts +0 -52
- package/src/infrastructure/git-history.ts +0 -497
- package/src/infrastructure/logger.ts +0 -68
- package/src/infrastructure/scanner.ts +0 -347
- package/src/scripts/bundle-deps.js +0 -123
- package/src/scripts/fix-imports.mjs +0 -106
- package/src/scripts/refactor-imports.js +0 -74
- package/src/scripts/refactor-utils.js +0 -23
- package/test-shotgun.js +0 -7
- package/tests/agent-generator.test.ts +0 -428
- package/tests/analyzers-integration.test.ts +0 -174
- package/tests/anti-patterns.test.ts +0 -95
- package/tests/context-enricher.test.ts +0 -972
- package/tests/fixtures/monorepo/package.json +0 -6
- package/tests/fixtures/monorepo/packages/app/package.json +0 -12
- package/tests/fixtures/monorepo/packages/app/src/index.ts +0 -6
- package/tests/fixtures/monorepo/packages/core/package.json +0 -7
- package/tests/fixtures/monorepo/packages/core/src/index.ts +0 -7
- package/tests/forecast.test.ts +0 -509
- package/tests/framework-detector.test.ts +0 -1172
- package/tests/git-history.test.ts +0 -254
- package/tests/monorepo-scan.test.ts +0 -170
- package/tests/scanner.test.ts +0 -54
- package/tests/scorer.test.ts +0 -674
- package/tests/stack-detector.test.ts +0 -241
- package/tests/template-generation.test.ts +0 -707
- package/tests/template-helpers.test.ts +0 -1130
- package/tests/temporal-scorer.test.ts +0 -307
- /package/dist/{adapters → src/adapters}/html-reporter/scripts.js +0 -0
- /package/dist/{adapters → src/adapters}/html-reporter/sections/anti-patterns.js +0 -0
- /package/dist/{adapters → src/adapters}/html-reporter/sections/layers.js +0 -0
- /package/dist/{adapters → src/adapters}/html-reporter/sections/overview.js +0 -0
- /package/dist/{adapters → src/adapters}/html-reporter/sections/refactoring-plan.js +0 -0
- /package/dist/{adapters → src/adapters}/html-reporter/sections/suggestions.js +0 -0
- /package/dist/{adapters → src/adapters}/html-reporter/styles.js +0 -0
- /package/dist/{adapters → src/adapters}/html-reporter/utils_adapters.js +0 -0
- /package/dist/{adapters → src/adapters}/html-reporter/utils_sections.js +0 -0
- /package/dist/{adapters → src/adapters}/reporter.js +0 -0
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { PackageReader } from './summarizer/package-reader.js';
|
|
2
|
-
import { ReadmeReader } from './summarizer/readme-reader.js';
|
|
3
|
-
import { KeywordExtractor } from './summarizer/keyword-extractor.js';
|
|
4
|
-
import { PurposeInferrer } from './summarizer/purpose-inferrer.js';
|
|
5
|
-
import { ModuleInferrer } from './summarizer/module-inferrer.js';
|
|
6
|
-
/**
|
|
7
|
-
* ProjectSummarizer — infers what a project does from its metadata,
|
|
8
|
-
* structure, README, package.json, and file naming conventions.
|
|
9
|
-
*
|
|
10
|
-
* Refactored via Facade pattern in v5.0.0
|
|
11
|
-
*/
|
|
12
|
-
export class ProjectSummarizer {
|
|
13
|
-
constructor() {
|
|
14
|
-
this.packageReader = new PackageReader();
|
|
15
|
-
this.readmeReader = new ReadmeReader();
|
|
16
|
-
this.keywordExtractor = new KeywordExtractor();
|
|
17
|
-
this.purposeInferrer = new PurposeInferrer();
|
|
18
|
-
this.moduleInferrer = new ModuleInferrer();
|
|
19
|
-
}
|
|
20
|
-
summarize(projectPath, report) {
|
|
21
|
-
const packageInfo = this.packageReader.readPackageJson(projectPath);
|
|
22
|
-
const readmeContent = this.readmeReader.readReadme(projectPath);
|
|
23
|
-
const modules = this.moduleInferrer.inferModules(report, projectPath);
|
|
24
|
-
const entryPoints = this.purposeInferrer.findEntryPoints(report, projectPath);
|
|
25
|
-
const keywords = this.keywordExtractor.extractKeywords(packageInfo, readmeContent, modules, report);
|
|
26
|
-
const techStack = this.purposeInferrer.buildTechStack(report, packageInfo);
|
|
27
|
-
const description = this.purposeInferrer.buildDescription(packageInfo, readmeContent, report);
|
|
28
|
-
const purpose = this.purposeInferrer.inferPurpose(keywords, modules, report);
|
|
29
|
-
return {
|
|
30
|
-
description,
|
|
31
|
-
purpose,
|
|
32
|
-
modules,
|
|
33
|
-
techStack,
|
|
34
|
-
entryPoints,
|
|
35
|
-
keywords,
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
//# sourceMappingURL=project-summarizer.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"project-summarizer.js","sourceRoot":"","sources":["../../src/core/project-summarizer.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAEjE;;;;;GAKG;AACH,MAAM,OAAO,iBAAiB;IAA9B;QACU,kBAAa,GAAG,IAAI,aAAa,EAAE,CAAC;QACpC,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAClC,qBAAgB,GAAG,IAAI,gBAAgB,EAAE,CAAC;QAC1C,oBAAe,GAAG,IAAI,eAAe,EAAE,CAAC;QACxC,mBAAc,GAAG,IAAI,cAAc,EAAE,CAAC;IAqBhD,CAAC;IAnBC,SAAS,CAAC,WAAmB,EAAE,MAAsB;QACnD,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;QACpE,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;QAChE,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QACtE,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QAC9E,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,WAAW,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;QACpG,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QAC3E,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,WAAW,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;QAC9F,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;QAE7E,OAAO;YACL,WAAW;YACX,OAAO;YACP,OAAO;YACP,SAAS;YACT,WAAW;YACX,QAAQ;SACT,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { AnalysisReport } from './types/core.js';
|
|
2
|
-
import { RefactoringPlan } from './types/rules.js';
|
|
3
|
-
/**
|
|
4
|
-
* Refactoring Engine v2.0
|
|
5
|
-
* Orchestrates Tier 1 (rule-based) and Tier 2 (AST) refactoring rules.
|
|
6
|
-
*/
|
|
7
|
-
export declare class RefactorEngine {
|
|
8
|
-
private rules;
|
|
9
|
-
constructor();
|
|
10
|
-
/**
|
|
11
|
-
* Analyze a project and generate a refactoring plan.
|
|
12
|
-
*/
|
|
13
|
-
analyze(report: AnalysisReport, projectPath: string): RefactoringPlan;
|
|
14
|
-
/**
|
|
15
|
-
* Estimates the architecture score after applying all refactoring steps.
|
|
16
|
-
*/
|
|
17
|
-
private estimateScoreAfter;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=refactor-engine.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"refactor-engine.d.ts","sourceRoot":"","sources":["../../src/core/refactor-engine.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,eAAe,EAA6C,MAAM,kBAAkB,CAAC;AAS9F;;;GAGG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,KAAK,CAAiB;;IAa9B;;OAEG;IACH,OAAO,CAAC,MAAM,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,GAAG,eAAe;IA8CrE;;OAEG;IACH,OAAO,CAAC,kBAAkB;CA6B3B"}
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
// ── Tier 1 Rules ──
|
|
2
|
-
import { HubSplitterRule } from './rules/hub-splitter.js';
|
|
3
|
-
import { BarrelOptimizerRule } from './rules/barrel-optimizer.js';
|
|
4
|
-
import { ImportOrganizerRule } from './rules/import-organizer.js';
|
|
5
|
-
import { ModuleGrouperRule } from './rules/module-grouper.js';
|
|
6
|
-
import { DeadCodeDetectorRule } from './rules/dead-code-detector.js';
|
|
7
|
-
/**
|
|
8
|
-
* Refactoring Engine v2.0
|
|
9
|
-
* Orchestrates Tier 1 (rule-based) and Tier 2 (AST) refactoring rules.
|
|
10
|
-
*/
|
|
11
|
-
export class RefactorEngine {
|
|
12
|
-
constructor() {
|
|
13
|
-
this.rules = [
|
|
14
|
-
// Tier 1: Rule Engine (pattern matching)
|
|
15
|
-
new HubSplitterRule(),
|
|
16
|
-
new BarrelOptimizerRule(),
|
|
17
|
-
new ImportOrganizerRule(),
|
|
18
|
-
new ModuleGrouperRule(),
|
|
19
|
-
new DeadCodeDetectorRule(),
|
|
20
|
-
];
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* Analyze a project and generate a refactoring plan.
|
|
24
|
-
*/
|
|
25
|
-
analyze(report, projectPath) {
|
|
26
|
-
const allSteps = [];
|
|
27
|
-
let stepId = 1;
|
|
28
|
-
// Run each rule
|
|
29
|
-
for (const rule of this.rules) {
|
|
30
|
-
const steps = rule.analyze(report, projectPath);
|
|
31
|
-
for (const step of steps) {
|
|
32
|
-
step.id = stepId++;
|
|
33
|
-
allSteps.push(step);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
// Sort by priority
|
|
37
|
-
const priorityOrder = {
|
|
38
|
-
CRITICAL: 0,
|
|
39
|
-
HIGH: 1,
|
|
40
|
-
MEDIUM: 2,
|
|
41
|
-
LOW: 3,
|
|
42
|
-
};
|
|
43
|
-
allSteps.sort((a, b) => priorityOrder[a.priority] - priorityOrder[b.priority]);
|
|
44
|
-
// Re-number after sorting
|
|
45
|
-
allSteps.forEach((s, i) => (s.id = i + 1));
|
|
46
|
-
// Calculate total operations
|
|
47
|
-
const totalOperations = allSteps.reduce((sum, s) => sum + s.operations.length, 0);
|
|
48
|
-
// Estimate score after refactoring
|
|
49
|
-
const estimatedScoreAfter = this.estimateScoreAfter(report, allSteps);
|
|
50
|
-
return {
|
|
51
|
-
timestamp: new Date().toISOString(),
|
|
52
|
-
projectPath,
|
|
53
|
-
currentScore: report.score,
|
|
54
|
-
estimatedScoreAfter,
|
|
55
|
-
steps: allSteps,
|
|
56
|
-
totalOperations,
|
|
57
|
-
tier1Steps: allSteps.filter((s) => s.tier === 1).length,
|
|
58
|
-
tier2Steps: allSteps.filter((s) => s.tier === 2).length,
|
|
59
|
-
};
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* Estimates the architecture score after applying all refactoring steps.
|
|
63
|
-
*/
|
|
64
|
-
estimateScoreAfter(report, steps) {
|
|
65
|
-
const breakdown = { ...report.score.breakdown };
|
|
66
|
-
for (const step of steps) {
|
|
67
|
-
for (const impact of step.scoreImpact) {
|
|
68
|
-
if (impact.metric in breakdown) {
|
|
69
|
-
// Use estimated after value, capped at 95
|
|
70
|
-
const key = impact.metric;
|
|
71
|
-
breakdown[key] = Math.min(95, Math.max(breakdown[key], impact.after));
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
// Recalculate overall with same weights
|
|
76
|
-
const overall = Math.round(breakdown.modularity * 0.4 +
|
|
77
|
-
breakdown.coupling * 0.25 +
|
|
78
|
-
breakdown.cohesion * 0.2 +
|
|
79
|
-
breakdown.layering * 0.15);
|
|
80
|
-
return {
|
|
81
|
-
overall: Math.min(100, overall),
|
|
82
|
-
breakdown,
|
|
83
|
-
};
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
//# sourceMappingURL=refactor-engine.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"refactor-engine.js","sourceRoot":"","sources":["../../src/core/refactor-engine.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { AnalysisReport } from '../types/core.js';
|
|
2
|
-
import { RefactorRule, RefactorStep } from '../types/rules.js';
|
|
3
|
-
/**
|
|
4
|
-
* Barrel Optimizer Rule (Tier 1)
|
|
5
|
-
* Analyzes barrel files (__init__.py, index.ts) and suggests optimization.
|
|
6
|
-
* Barrel files that re-export everything create unnecessary coupling.
|
|
7
|
-
*/
|
|
8
|
-
export declare class BarrelOptimizerRule implements RefactorRule {
|
|
9
|
-
name: string;
|
|
10
|
-
tier: 1;
|
|
11
|
-
private static readonly BARREL_FILES;
|
|
12
|
-
analyze(report: AnalysisReport, projectPath: string): RefactorStep[];
|
|
13
|
-
}
|
|
14
|
-
//# sourceMappingURL=barrel-optimizer.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"barrel-optimizer.d.ts","sourceRoot":"","sources":["../../../src/core/rules/barrel-optimizer.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,YAAY,EAAiB,MAAM,mBAAmB,CAAC;AAE9E;;;;GAIG;AACH,qBAAa,mBAAoB,YAAW,YAAY;IACtD,IAAI,SAAsB;IAC1B,IAAI,EAAG,CAAC,CAAU;IAElB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAEjC;IAEH,OAAO,CAAC,MAAM,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,GAAG,YAAY,EAAE;CAiFrE"}
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
import { basename, dirname } from 'path';
|
|
2
|
-
/**
|
|
3
|
-
* Barrel Optimizer Rule (Tier 1)
|
|
4
|
-
* Analyzes barrel files (__init__.py, index.ts) and suggests optimization.
|
|
5
|
-
* Barrel files that re-export everything create unnecessary coupling.
|
|
6
|
-
*/
|
|
7
|
-
export class BarrelOptimizerRule {
|
|
8
|
-
constructor() {
|
|
9
|
-
this.name = 'barrel-optimizer';
|
|
10
|
-
this.tier = 1;
|
|
11
|
-
}
|
|
12
|
-
analyze(report, projectPath) {
|
|
13
|
-
const steps = [];
|
|
14
|
-
// Find barrel files in the dependency graph
|
|
15
|
-
const barrelNodes = report.dependencyGraph.nodes.filter((n) => BarrelOptimizerRule.BARREL_FILES.has(basename(n)));
|
|
16
|
-
for (const barrel of barrelNodes) {
|
|
17
|
-
// Count how many things this barrel re-exports (outgoing edges)
|
|
18
|
-
const outgoing = report.dependencyGraph.edges.filter((e) => e.from === barrel);
|
|
19
|
-
const incoming = report.dependencyGraph.edges.filter((e) => e.to === barrel);
|
|
20
|
-
if (outgoing.length < 3)
|
|
21
|
-
continue;
|
|
22
|
-
// Check for "pass-through" pattern: files import from barrel
|
|
23
|
-
// but barrel just re-exports from siblings
|
|
24
|
-
const siblingDir = dirname(barrel);
|
|
25
|
-
const siblingExports = outgoing.filter((e) => dirname(e.to) === siblingDir);
|
|
26
|
-
const operations = [];
|
|
27
|
-
// Suggest direct imports instead of barrel
|
|
28
|
-
for (const consumer of incoming) {
|
|
29
|
-
const consumedModules = outgoing
|
|
30
|
-
.filter((e) => {
|
|
31
|
-
// Check if consumer actually needs this module
|
|
32
|
-
return report.dependencyGraph.edges.some((edge) => edge.from === consumer.from && edge.to === e.to);
|
|
33
|
-
})
|
|
34
|
-
.map((e) => e.to);
|
|
35
|
-
if (consumedModules.length > 0) {
|
|
36
|
-
operations.push({
|
|
37
|
-
type: 'MODIFY',
|
|
38
|
-
path: consumer.from,
|
|
39
|
-
description: `Replace barrel import from \`${basename(barrel)}\` with direct imports: ${consumedModules.map((m) => basename(m)).join(', ')}`,
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
// Suggest simplifying the barrel
|
|
44
|
-
if (siblingExports.length > 5) {
|
|
45
|
-
operations.push({
|
|
46
|
-
type: 'MODIFY',
|
|
47
|
-
path: barrel,
|
|
48
|
-
description: `Simplify ${basename(barrel)}: only re-export public API (${siblingExports.length} re-exports detected, consider reducing)`,
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
if (operations.length > 0) {
|
|
52
|
-
steps.push({
|
|
53
|
-
id: 0,
|
|
54
|
-
tier: 1,
|
|
55
|
-
rule: this.name,
|
|
56
|
-
priority: outgoing.length >= 8 ? 'HIGH' : 'MEDIUM',
|
|
57
|
-
title: `Optimize barrel: ${barrel}`,
|
|
58
|
-
description: `\`${barrel}\` re-exports ${outgoing.length} modules. ` +
|
|
59
|
-
`This creates a "Shotgun Surgery" risk — any change propagates widely.`,
|
|
60
|
-
rationale: `Barrel files that re-export everything make it hard to tree-shake unused code ` +
|
|
61
|
-
`and create implicit dependencies. Direct imports make dependency relationships explicit ` +
|
|
62
|
-
`and reduce the blast radius of changes.`,
|
|
63
|
-
operations,
|
|
64
|
-
scoreImpact: [
|
|
65
|
-
{ metric: 'coupling', before: report.score.breakdown.coupling, after: Math.min(95, report.score.breakdown.coupling + 10) },
|
|
66
|
-
{ metric: 'layering', before: report.score.breakdown.layering, after: Math.min(95, report.score.breakdown.layering + 5) },
|
|
67
|
-
],
|
|
68
|
-
aiPrompt: `Analyze the barrel file \`${barrel}\` which re-exports ${outgoing.length} modules. This is creating a "Shotgun Surgery" risk.\nPlease optimize it by:\n1. Removing wildcard exports (e.g., \`export *\`) if any.\n2. Only re-exporting the public API interfaces/classes meant for consumers outside this module.\n3. Updating consumers (${incoming.map(i => basename(i.from)).join(', ')}) to import from the specific files directly instead of passing through this barrel file where appropriate.`,
|
|
69
|
-
});
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
return steps;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
BarrelOptimizerRule.BARREL_FILES = new Set([
|
|
76
|
-
'__init__.py', 'index.ts', 'index.js', 'index.tsx', 'index.jsx',
|
|
77
|
-
]);
|
|
78
|
-
//# sourceMappingURL=barrel-optimizer.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"barrel-optimizer.js","sourceRoot":"","sources":["../../../src/core/rules/barrel-optimizer.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { AnalysisReport } from '../types/core.js';
|
|
2
|
-
import { RefactorRule, RefactorStep } from '../types/rules.js';
|
|
3
|
-
/**
|
|
4
|
-
* Dead Code Detector Rule (Tier 1)
|
|
5
|
-
* Finds files with no incoming edges (nobody imports them)
|
|
6
|
-
* and exports that are never used.
|
|
7
|
-
*
|
|
8
|
-
* Handles both path-style (deepguard/report.py) and
|
|
9
|
-
* dot-notation (deepguard.report) references.
|
|
10
|
-
*/
|
|
11
|
-
export declare class DeadCodeDetectorRule implements RefactorRule {
|
|
12
|
-
name: string;
|
|
13
|
-
tier: 1;
|
|
14
|
-
private static readonly ENTRY_POINTS;
|
|
15
|
-
analyze(report: AnalysisReport, projectPath: string): RefactorStep[];
|
|
16
|
-
/**
|
|
17
|
-
* Generate dot-notation variants for a file path.
|
|
18
|
-
* "deepguard/report.py" → ["deepguard.report", ".report"]
|
|
19
|
-
*/
|
|
20
|
-
private getDotVariants;
|
|
21
|
-
}
|
|
22
|
-
//# sourceMappingURL=dead-code-detector.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dead-code-detector.d.ts","sourceRoot":"","sources":["../../../src/core/rules/dead-code-detector.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,YAAY,EAAiB,MAAM,mBAAmB,CAAC;AAE9E;;;;;;;GAOG;AACH,qBAAa,oBAAqB,YAAW,YAAY;IACvD,IAAI,SAAwB;IAC5B,IAAI,EAAG,CAAC,CAAU;IAElB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAIjC;IAEH,OAAO,CAAC,MAAM,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,GAAG,YAAY,EAAE;IA2FpE;;;OAGG;IACH,OAAO,CAAC,cAAc;CAgBvB"}
|
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
import { basename } from 'path';
|
|
2
|
-
/**
|
|
3
|
-
* Dead Code Detector Rule (Tier 1)
|
|
4
|
-
* Finds files with no incoming edges (nobody imports them)
|
|
5
|
-
* and exports that are never used.
|
|
6
|
-
*
|
|
7
|
-
* Handles both path-style (deepguard/report.py) and
|
|
8
|
-
* dot-notation (deepguard.report) references.
|
|
9
|
-
*/
|
|
10
|
-
export class DeadCodeDetectorRule {
|
|
11
|
-
constructor() {
|
|
12
|
-
this.name = 'dead-code-detector';
|
|
13
|
-
this.tier = 1;
|
|
14
|
-
}
|
|
15
|
-
analyze(report, projectPath) {
|
|
16
|
-
const steps = [];
|
|
17
|
-
const edges = report.dependencyGraph.edges;
|
|
18
|
-
// Build a set of ALL referenced targets (both path and dot-notation)
|
|
19
|
-
const allTargets = new Set();
|
|
20
|
-
const allSources = new Set();
|
|
21
|
-
for (const edge of edges) {
|
|
22
|
-
allTargets.add(edge.to);
|
|
23
|
-
allSources.add(edge.from);
|
|
24
|
-
}
|
|
25
|
-
// Only consider actual files (with path separators) as candidates
|
|
26
|
-
const fileNodes = report.dependencyGraph.nodes.filter((n) => n.includes('/') || n.includes('\\'));
|
|
27
|
-
// Build incoming edge count considering dot-notation matches
|
|
28
|
-
const incomingCount = {};
|
|
29
|
-
for (const file of fileNodes) {
|
|
30
|
-
incomingCount[file] = 0;
|
|
31
|
-
// Direct incoming edges
|
|
32
|
-
for (const edge of edges) {
|
|
33
|
-
if (edge.to === file) {
|
|
34
|
-
incomingCount[file]++;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
// Check dot-notation references:
|
|
38
|
-
// deepguard/report.py might be referenced as deepguard.report or .report
|
|
39
|
-
const dotVariants = this.getDotVariants(file);
|
|
40
|
-
for (const variant of dotVariants) {
|
|
41
|
-
if (allTargets.has(variant)) {
|
|
42
|
-
incomingCount[file]++;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
// Find orphan files
|
|
47
|
-
const orphans = [];
|
|
48
|
-
for (const [file, count] of Object.entries(incomingCount)) {
|
|
49
|
-
const fileName = basename(file);
|
|
50
|
-
// Skip entry points and config files
|
|
51
|
-
if (DeadCodeDetectorRule.ENTRY_POINTS.has(fileName))
|
|
52
|
-
continue;
|
|
53
|
-
if (fileName.startsWith('__'))
|
|
54
|
-
continue;
|
|
55
|
-
if (fileName.startsWith('.'))
|
|
56
|
-
continue;
|
|
57
|
-
if (fileName.endsWith('.test.ts') || fileName.endsWith('.spec.ts'))
|
|
58
|
-
continue;
|
|
59
|
-
if (fileName.endsWith('_test.py') || fileName.endsWith('.test.py'))
|
|
60
|
-
continue;
|
|
61
|
-
// Also skip if the file has outgoing edges (it's active code)
|
|
62
|
-
if (allSources.has(file))
|
|
63
|
-
continue;
|
|
64
|
-
if (count === 0) {
|
|
65
|
-
orphans.push(file);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
if (orphans.length > 0) {
|
|
69
|
-
const operations = orphans.map((file) => ({
|
|
70
|
-
type: 'DELETE',
|
|
71
|
-
path: file,
|
|
72
|
-
description: `\`${basename(file)}\` has no incoming dependencies — verify if still needed`,
|
|
73
|
-
}));
|
|
74
|
-
steps.push({
|
|
75
|
-
id: 0,
|
|
76
|
-
tier: 1,
|
|
77
|
-
rule: this.name,
|
|
78
|
-
priority: orphans.length >= 3 ? 'MEDIUM' : 'LOW',
|
|
79
|
-
title: `Review ${orphans.length} potentially unused file(s)`,
|
|
80
|
-
description: `Found ${orphans.length} file(s) with no incoming dependencies: ` +
|
|
81
|
-
`${orphans.map((f) => `\`${basename(f)}\``).join(', ')}. ` +
|
|
82
|
-
`These may be dead code or missing from the module's public API.`,
|
|
83
|
-
rationale: `Files with zero incoming edges are either entry points (already excluded), ` +
|
|
84
|
-
`or potentially dead code. Removing dead code reduces maintenance burden ` +
|
|
85
|
-
`and improves modularity scores.`,
|
|
86
|
-
operations,
|
|
87
|
-
scoreImpact: [
|
|
88
|
-
{ metric: 'modularity', before: report.score.breakdown.modularity, after: Math.min(95, report.score.breakdown.modularity + 5) },
|
|
89
|
-
],
|
|
90
|
-
aiPrompt: `Analyze the following files: ${orphans.map(f => `\`${f}\``).join(', ')}.\nThese files currently have zero incoming dependencies across the architecture, meaning they might be dead code.\nPlease review them:\n1. If they are unused, explicitly delete them to shrink the blast radius.\n2. If they are entry points that the Architect missed, add them to the ignore list or document their usage.\n3. Make sure to remove any vestigial exports or imports pointing to them from the rest of the codebase.`,
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
return steps;
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Generate dot-notation variants for a file path.
|
|
97
|
-
* "deepguard/report.py" → ["deepguard.report", ".report"]
|
|
98
|
-
*/
|
|
99
|
-
getDotVariants(filePath) {
|
|
100
|
-
const variants = [];
|
|
101
|
-
const withoutExt = filePath.replace(/\.[^.]+$/, '');
|
|
102
|
-
const dotPath = withoutExt.replace(/[/\\]/g, '.');
|
|
103
|
-
variants.push(dotPath);
|
|
104
|
-
// Relative dot-notation: .report
|
|
105
|
-
const parts = filePath.split('/');
|
|
106
|
-
if (parts.length >= 2) {
|
|
107
|
-
const lastPart = parts[parts.length - 1].replace(/\.[^.]+$/, '');
|
|
108
|
-
variants.push(`.${lastPart}`);
|
|
109
|
-
}
|
|
110
|
-
return variants;
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
DeadCodeDetectorRule.ENTRY_POINTS = new Set([
|
|
114
|
-
'main.py', 'cli.py', 'app.py', 'manage.py', 'wsgi.py', 'asgi.py',
|
|
115
|
-
'main.ts', 'main.js', 'app.ts', 'app.js', 'server.ts', 'server.js',
|
|
116
|
-
'index.html', 'setup.py', 'setup.cfg', 'pyproject.toml',
|
|
117
|
-
]);
|
|
118
|
-
//# sourceMappingURL=dead-code-detector.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dead-code-detector.js","sourceRoot":"","sources":["../../../src/core/rules/dead-code-detector.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { AnalysisReport } from '../types/core.js';
|
|
2
|
-
import { RefactorRule, RefactorStep } from '../types/rules.js';
|
|
3
|
-
/**
|
|
4
|
-
* Hub Splitter Rule (Tier 1)
|
|
5
|
-
* Detects files with many connections and generates split plans.
|
|
6
|
-
* A "hub" is a file that many other files depend on, creating tight coupling.
|
|
7
|
-
*/
|
|
8
|
-
export declare class HubSplitterRule implements RefactorRule {
|
|
9
|
-
name: string;
|
|
10
|
-
tier: 1;
|
|
11
|
-
analyze(report: AnalysisReport, projectPath: string): RefactorStep[];
|
|
12
|
-
private groupDependents;
|
|
13
|
-
}
|
|
14
|
-
//# sourceMappingURL=hub-splitter.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hub-splitter.d.ts","sourceRoot":"","sources":["../../../src/core/rules/hub-splitter.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,YAAY,EAAiB,MAAM,mBAAmB,CAAC;AAE9E;;;;GAIG;AACH,qBAAa,eAAgB,YAAW,YAAY;IAClD,IAAI,SAAkB;IACtB,IAAI,EAAG,CAAC,CAAU;IAElB,OAAO,CAAC,MAAM,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,GAAG,YAAY,EAAE;IAuGpE,OAAO,CAAC,eAAe;CAkBxB"}
|
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
import { basename, dirname } from 'path';
|
|
2
|
-
/**
|
|
3
|
-
* Hub Splitter Rule (Tier 1)
|
|
4
|
-
* Detects files with many connections and generates split plans.
|
|
5
|
-
* A "hub" is a file that many other files depend on, creating tight coupling.
|
|
6
|
-
*/
|
|
7
|
-
export class HubSplitterRule {
|
|
8
|
-
constructor() {
|
|
9
|
-
this.name = 'hub-splitter';
|
|
10
|
-
this.tier = 1;
|
|
11
|
-
}
|
|
12
|
-
analyze(report, projectPath) {
|
|
13
|
-
const steps = [];
|
|
14
|
-
// Count connections per node
|
|
15
|
-
const connectionCount = {};
|
|
16
|
-
for (const edge of report.dependencyGraph.edges) {
|
|
17
|
-
if (!connectionCount[edge.from])
|
|
18
|
-
connectionCount[edge.from] = { incoming: [], outgoing: [] };
|
|
19
|
-
if (!connectionCount[edge.to])
|
|
20
|
-
connectionCount[edge.to] = { incoming: [], outgoing: [] };
|
|
21
|
-
connectionCount[edge.from].outgoing.push(edge.to);
|
|
22
|
-
connectionCount[edge.to].incoming.push(edge.from);
|
|
23
|
-
}
|
|
24
|
-
// Find hubs (5+ incoming connections, not barrel files)
|
|
25
|
-
const barrelFiles = new Set(['__init__.py', 'index.ts', 'index.js', 'index.tsx', 'mod.rs']);
|
|
26
|
-
for (const [file, connections] of Object.entries(connectionCount)) {
|
|
27
|
-
const fileName = basename(file);
|
|
28
|
-
if (barrelFiles.has(fileName))
|
|
29
|
-
continue;
|
|
30
|
-
// Ignora Tipos base/DTOs - Alto acoplamento em tipos é sinal de maturidade, não gargalo
|
|
31
|
-
const lowerFile = file.toLowerCase();
|
|
32
|
-
if (lowerFile.includes('types') || lowerFile.includes('interface') || lowerFile.includes('/types/')) {
|
|
33
|
-
continue;
|
|
34
|
-
}
|
|
35
|
-
// Tolerância Arquitetural: Eleva de 5 pra 8 dependentes pra engatilhar quebra (Módulos Coesos maduros)
|
|
36
|
-
if (connections.incoming.length < 8)
|
|
37
|
-
continue;
|
|
38
|
-
const operations = [];
|
|
39
|
-
// Determine if this is a dot-notation module or a real file
|
|
40
|
-
const isDotNotation = !file.includes('/') && !file.includes('\\');
|
|
41
|
-
const moduleName = isDotNotation
|
|
42
|
-
? file.split('.').pop() || file
|
|
43
|
-
: fileName.replace(/\.[^.]+$/, '');
|
|
44
|
-
const moduleDir = isDotNotation
|
|
45
|
-
? file.split('.').slice(0, -1).join('/')
|
|
46
|
-
: dirname(file);
|
|
47
|
-
const ext = isDotNotation ? 'py' : (fileName.split('.').pop() || 'py');
|
|
48
|
-
// Analyze what dependents import to suggest groupings
|
|
49
|
-
const dependentGroups = this.groupDependents(connections.incoming);
|
|
50
|
-
// Suggest splitting into domain modules
|
|
51
|
-
if (dependentGroups.length >= 2) {
|
|
52
|
-
for (const group of dependentGroups) {
|
|
53
|
-
const newFileName = `${moduleName}_${group.name}.${ext}`;
|
|
54
|
-
const newPath = moduleDir ? `${moduleDir}/${newFileName}` : newFileName;
|
|
55
|
-
operations.push({
|
|
56
|
-
type: 'CREATE',
|
|
57
|
-
path: newPath,
|
|
58
|
-
description: `Create \`${newFileName}\` with functionality used by: ${group.dependents.join(', ')}`,
|
|
59
|
-
content: ext === 'py'
|
|
60
|
-
? `"""${moduleName}_${group.name} — extracted from ${moduleName}."""\n# Used by: ${group.dependents.join(', ')}\n`
|
|
61
|
-
: `// ${moduleName}_${group.name} — extracted from ${moduleName}\n// Used by: ${group.dependents.join(', ')}\n`,
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
// Update imports in all dependents
|
|
65
|
-
for (const dependent of connections.incoming) {
|
|
66
|
-
operations.push({
|
|
67
|
-
type: 'MODIFY',
|
|
68
|
-
path: dependent,
|
|
69
|
-
description: `Update imports in \`${basename(dependent)}\` to use new split modules`,
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
// Mark original for refactoring
|
|
73
|
-
operations.push({
|
|
74
|
-
type: 'MODIFY',
|
|
75
|
-
path: isDotNotation ? `${moduleDir}/${moduleName}.${ext}` : file,
|
|
76
|
-
description: `Refactor \`${moduleName}.${ext}\` — extract grouped functionality to new modules`,
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
if (operations.length > 0) {
|
|
80
|
-
steps.push({
|
|
81
|
-
id: 0,
|
|
82
|
-
tier: 1,
|
|
83
|
-
rule: this.name,
|
|
84
|
-
priority: connections.incoming.length >= 8 ? 'CRITICAL' : 'HIGH',
|
|
85
|
-
title: `Split hub file: ${moduleName}.${ext}`,
|
|
86
|
-
description: `\`${file}\` has ${connections.incoming.length} incoming connections. ` +
|
|
87
|
-
`Split into ${dependentGroups.length} focused modules to reduce coupling.`,
|
|
88
|
-
rationale: `High fan-in (${connections.incoming.length} files depend on this) creates a bottleneck. ` +
|
|
89
|
-
`Changes to this file ripple to ${connections.incoming.length} other files. ` +
|
|
90
|
-
`Splitting by usage pattern reduces blast radius.`,
|
|
91
|
-
operations,
|
|
92
|
-
scoreImpact: [
|
|
93
|
-
{ metric: 'coupling', before: report.score.breakdown.coupling, after: Math.min(95, report.score.breakdown.coupling + 15) },
|
|
94
|
-
],
|
|
95
|
-
aiPrompt: `Analyze the file \`${file}\`. Based on its incoming connections, it acts as a coupling bottleneck. Please split this file into the following smaller modules:\n` +
|
|
96
|
-
dependentGroups.map(g => `- \`${moduleName}_${g.name}.${ext}\`: Extract functionality specific to these dependents: ${g.dependents.join(', ')}`).join('\n') +
|
|
97
|
-
`\n\nAfter splitting, securely and automatically update all ${connections.incoming.length} dependent files to import from the new specific modules instead of the monolithic \`${moduleName}.${ext}\`. DO NOT remove any functionality, only move it.`,
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
return steps;
|
|
102
|
-
}
|
|
103
|
-
groupDependents(dependents) {
|
|
104
|
-
// Group by top-level directory
|
|
105
|
-
const groups = {};
|
|
106
|
-
for (const dep of dependents) {
|
|
107
|
-
const parts = dep.includes('/') ? dep.split('/') : dep.split('.');
|
|
108
|
-
const groupName = parts.length >= 2 ? parts[parts.length - 2] : 'core';
|
|
109
|
-
if (!groups[groupName])
|
|
110
|
-
groups[groupName] = [];
|
|
111
|
-
groups[groupName].push(basename(dep));
|
|
112
|
-
}
|
|
113
|
-
return Object.entries(groups).map(([name, deps]) => ({
|
|
114
|
-
name,
|
|
115
|
-
dependents: deps,
|
|
116
|
-
}));
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
//# sourceMappingURL=hub-splitter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hub-splitter.js","sourceRoot":"","sources":["../../../src/core/rules/hub-splitter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { AnalysisReport } from '../types/core.js';
|
|
2
|
-
import { RefactorRule, RefactorStep } from '../types/rules.js';
|
|
3
|
-
/**
|
|
4
|
-
* Import Organizer Rule (Tier 1)
|
|
5
|
-
* Detects files that import from too many different modules (cross-boundary).
|
|
6
|
-
* Suggests dependency injection or facade patterns.
|
|
7
|
-
*/
|
|
8
|
-
export declare class ImportOrganizerRule implements RefactorRule {
|
|
9
|
-
name: string;
|
|
10
|
-
tier: 1;
|
|
11
|
-
analyze(report: AnalysisReport, projectPath: string): RefactorStep[];
|
|
12
|
-
private generateFacadeContent;
|
|
13
|
-
}
|
|
14
|
-
//# sourceMappingURL=import-organizer.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"import-organizer.d.ts","sourceRoot":"","sources":["../../../src/core/rules/import-organizer.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,YAAY,EAAiB,MAAM,mBAAmB,CAAC;AAE9E;;;;GAIG;AACH,qBAAa,mBAAoB,YAAW,YAAY;IACtD,IAAI,SAAsB;IAC1B,IAAI,EAAG,CAAC,CAAU;IAElB,OAAO,CAAC,MAAM,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,GAAG,YAAY,EAAE;IAwEpE,OAAO,CAAC,qBAAqB;CAc9B"}
|