@lyse-labs/lyse 0.1.0-alpha.2
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/LICENSE +45 -0
- package/PRIVACY.md +181 -0
- package/README.md +34 -0
- package/SECURITY.md +43 -0
- package/dist/bench/evidence-pack/anti-dummy.d.ts +11 -0
- package/dist/bench/evidence-pack/anti-dummy.js +20 -0
- package/dist/bench/evidence-pack/anti-dummy.js.map +1 -0
- package/dist/bench/evidence-pack/builder.d.ts +14 -0
- package/dist/bench/evidence-pack/builder.js +77 -0
- package/dist/bench/evidence-pack/builder.js.map +1 -0
- package/dist/bench/evidence-pack/histograms.d.ts +2 -0
- package/dist/bench/evidence-pack/histograms.js +131 -0
- package/dist/bench/evidence-pack/histograms.js.map +1 -0
- package/dist/bench/evidence-pack/manifest-detector.d.ts +2 -0
- package/dist/bench/evidence-pack/manifest-detector.js +65 -0
- package/dist/bench/evidence-pack/manifest-detector.js.map +1 -0
- package/dist/bench/evidence-pack/package-json-digest.d.ts +2 -0
- package/dist/bench/evidence-pack/package-json-digest.js +51 -0
- package/dist/bench/evidence-pack/package-json-digest.js.map +1 -0
- package/dist/bench/evidence-pack/sampler.d.ts +2 -0
- package/dist/bench/evidence-pack/sampler.js +140 -0
- package/dist/bench/evidence-pack/sampler.js.map +1 -0
- package/dist/bench/evidence-pack/types.d.ts +127 -0
- package/dist/bench/evidence-pack/types.js +2 -0
- package/dist/bench/evidence-pack/types.js.map +1 -0
- package/dist/bench/evidence-pack/verifier-corpus.d.ts +5 -0
- package/dist/bench/evidence-pack/verifier-corpus.js +13 -0
- package/dist/bench/evidence-pack/verifier-corpus.js.map +1 -0
- package/dist/bench/taxonomy-loader.d.ts +20 -0
- package/dist/bench/taxonomy-loader.js +28 -0
- package/dist/bench/taxonomy-loader.js.map +1 -0
- package/dist/bench/taxonomy.v3.json +20 -0
- package/dist/cli/__tests__/version-migration.test.d.ts +1 -0
- package/dist/cli/__tests__/version-migration.test.js +69 -0
- package/dist/cli/__tests__/version-migration.test.js.map +1 -0
- package/dist/cli/output/__tests__/eslint-style.test.d.ts +1 -0
- package/dist/cli/output/__tests__/eslint-style.test.js +205 -0
- package/dist/cli/output/__tests__/eslint-style.test.js.map +1 -0
- package/dist/cli/output/__tests__/limit.test.d.ts +1 -0
- package/dist/cli/output/__tests__/limit.test.js +65 -0
- package/dist/cli/output/__tests__/limit.test.js.map +1 -0
- package/dist/cli/output/eslint-style.d.ts +18 -0
- package/dist/cli/output/eslint-style.js +42 -0
- package/dist/cli/output/eslint-style.js.map +1 -0
- package/dist/cli/output/limit.d.ts +5 -0
- package/dist/cli/output/limit.js +32 -0
- package/dist/cli/output/limit.js.map +1 -0
- package/dist/cli/output/score-gauge.d.ts +4 -0
- package/dist/cli/output/score-gauge.js +15 -0
- package/dist/cli/output/score-gauge.js.map +1 -0
- package/dist/cli/version-migration.d.ts +18 -0
- package/dist/cli/version-migration.js +49 -0
- package/dist/cli/version-migration.js.map +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.js +856 -0
- package/dist/cli.js.map +1 -0
- package/dist/codemods/diff.d.ts +17 -0
- package/dist/codemods/diff.js +77 -0
- package/dist/codemods/diff.js.map +1 -0
- package/dist/codemods/git-helpers.d.ts +10 -0
- package/dist/codemods/git-helpers.js +75 -0
- package/dist/codemods/git-helpers.js.map +1 -0
- package/dist/codemods/index.d.ts +27 -0
- package/dist/codemods/index.js +40 -0
- package/dist/codemods/index.js.map +1 -0
- package/dist/codemods/naming-component-pascalcase.d.ts +13 -0
- package/dist/codemods/naming-component-pascalcase.js +106 -0
- package/dist/codemods/naming-component-pascalcase.js.map +1 -0
- package/dist/codemods/naming-hook-prefix.d.ts +13 -0
- package/dist/codemods/naming-hook-prefix.js +86 -0
- package/dist/codemods/naming-hook-prefix.js.map +1 -0
- package/dist/codemods/safety.d.ts +50 -0
- package/dist/codemods/safety.js +109 -0
- package/dist/codemods/safety.js.map +1 -0
- package/dist/codemods/safety.test.d.ts +1 -0
- package/dist/codemods/safety.test.js +154 -0
- package/dist/codemods/safety.test.js.map +1 -0
- package/dist/codemods/shadow-native.d.ts +2 -0
- package/dist/codemods/shadow-native.js +103 -0
- package/dist/codemods/shadow-native.js.map +1 -0
- package/dist/codemods/tokens-color.d.ts +2 -0
- package/dist/codemods/tokens-color.js +69 -0
- package/dist/codemods/tokens-color.js.map +1 -0
- package/dist/codemods/tokens-spacing.d.ts +2 -0
- package/dist/codemods/tokens-spacing.js +66 -0
- package/dist/codemods/tokens-spacing.js.map +1 -0
- package/dist/commands/__tests__/email-prompt.test.d.ts +1 -0
- package/dist/commands/__tests__/email-prompt.test.js +126 -0
- package/dist/commands/__tests__/email-prompt.test.js.map +1 -0
- package/dist/commands/__tests__/explain-score.test.d.ts +1 -0
- package/dist/commands/__tests__/explain-score.test.js +88 -0
- package/dist/commands/__tests__/explain-score.test.js.map +1 -0
- package/dist/commands/__tests__/feedback.test.d.ts +1 -0
- package/dist/commands/__tests__/feedback.test.js +186 -0
- package/dist/commands/__tests__/feedback.test.js.map +1 -0
- package/dist/commands/audit-flags.d.ts +49 -0
- package/dist/commands/audit-flags.js +17 -0
- package/dist/commands/audit-flags.js.map +1 -0
- package/dist/commands/audit-pipeline.d.ts +31 -0
- package/dist/commands/audit-pipeline.js +342 -0
- package/dist/commands/audit-pipeline.js.map +1 -0
- package/dist/commands/bench-pack.d.ts +5 -0
- package/dist/commands/bench-pack.js +61 -0
- package/dist/commands/bench-pack.js.map +1 -0
- package/dist/commands/ci-setup.d.ts +9 -0
- package/dist/commands/ci-setup.js +42 -0
- package/dist/commands/ci-setup.js.map +1 -0
- package/dist/commands/email-prompt.d.ts +36 -0
- package/dist/commands/email-prompt.js +160 -0
- package/dist/commands/email-prompt.js.map +1 -0
- package/dist/commands/explain-score.d.ts +35 -0
- package/dist/commands/explain-score.js +137 -0
- package/dist/commands/explain-score.js.map +1 -0
- package/dist/commands/explain.d.ts +6 -0
- package/dist/commands/explain.js +93 -0
- package/dist/commands/explain.js.map +1 -0
- package/dist/commands/feedback.d.ts +31 -0
- package/dist/commands/feedback.js +155 -0
- package/dist/commands/feedback.js.map +1 -0
- package/dist/commands/fix.d.ts +48 -0
- package/dist/commands/fix.js +191 -0
- package/dist/commands/fix.js.map +1 -0
- package/dist/commands/init-detect.d.ts +20 -0
- package/dist/commands/init-detect.js +124 -0
- package/dist/commands/init-detect.js.map +1 -0
- package/dist/commands/init-write-agents-md.d.ts +14 -0
- package/dist/commands/init-write-agents-md.js +71 -0
- package/dist/commands/init-write-agents-md.js.map +1 -0
- package/dist/commands/init-write-lyse-md.d.ts +14 -0
- package/dist/commands/init-write-lyse-md.js +253 -0
- package/dist/commands/init-write-lyse-md.js.map +1 -0
- package/dist/commands/init.d.ts +8 -0
- package/dist/commands/init.js +147 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/mcp-entry.d.ts +33 -0
- package/dist/commands/mcp-entry.js +47 -0
- package/dist/commands/mcp-entry.js.map +1 -0
- package/dist/commands/mcp-setup.d.ts +10 -0
- package/dist/commands/mcp-setup.js +74 -0
- package/dist/commands/mcp-setup.js.map +1 -0
- package/dist/commands/share.d.ts +4 -0
- package/dist/commands/share.js +60 -0
- package/dist/commands/share.js.map +1 -0
- package/dist/commands/telemetry.d.ts +4 -0
- package/dist/commands/telemetry.js +27 -0
- package/dist/commands/telemetry.js.map +1 -0
- package/dist/commands/templates/lyse-workflow.yml.template +30 -0
- package/dist/config/schema.d.ts +158 -0
- package/dist/config/schema.js +136 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/credentials/keychain.d.ts +20 -0
- package/dist/credentials/keychain.js +35 -0
- package/dist/credentials/keychain.js.map +1 -0
- package/dist/credentials/keychain.test.d.ts +1 -0
- package/dist/credentials/keychain.test.js +32 -0
- package/dist/credentials/keychain.test.js.map +1 -0
- package/dist/credentials/paths.d.ts +1 -0
- package/dist/credentials/paths.js +6 -0
- package/dist/credentials/paths.js.map +1 -0
- package/dist/credentials/store.d.ts +17 -0
- package/dist/credentials/store.js +60 -0
- package/dist/credentials/store.js.map +1 -0
- package/dist/credentials/store.test.d.ts +1 -0
- package/dist/credentials/store.test.js +48 -0
- package/dist/credentials/store.test.js.map +1 -0
- package/dist/detection/from-filesystem.d.ts +2 -0
- package/dist/detection/from-filesystem.js +26 -0
- package/dist/detection/from-filesystem.js.map +1 -0
- package/dist/detection/from-git.d.ts +2 -0
- package/dist/detection/from-git.js +53 -0
- package/dist/detection/from-git.js.map +1 -0
- package/dist/detection/from-package-json.d.ts +2 -0
- package/dist/detection/from-package-json.js +194 -0
- package/dist/detection/from-package-json.js.map +1 -0
- package/dist/detection/pre-flight.d.ts +5 -0
- package/dist/detection/pre-flight.js +47 -0
- package/dist/detection/pre-flight.js.map +1 -0
- package/dist/detection/types.d.ts +27 -0
- package/dist/detection/types.js +2 -0
- package/dist/detection/types.js.map +1 -0
- package/dist/entitlement/check.d.ts +7 -0
- package/dist/entitlement/check.js +37 -0
- package/dist/entitlement/check.js.map +1 -0
- package/dist/entitlement/index.d.ts +1 -0
- package/dist/entitlement/index.js +2 -0
- package/dist/entitlement/index.js.map +1 -0
- package/dist/entitlement/keys.d.ts +10 -0
- package/dist/entitlement/keys.js +14 -0
- package/dist/entitlement/keys.js.map +1 -0
- package/dist/history/ndjson-store.d.ts +70 -0
- package/dist/history/ndjson-store.js +102 -0
- package/dist/history/ndjson-store.js.map +1 -0
- package/dist/identity/index.d.ts +1 -0
- package/dist/identity/index.js +2 -0
- package/dist/identity/index.js.map +1 -0
- package/dist/identity/repo-bucket.d.ts +22 -0
- package/dist/identity/repo-bucket.js +78 -0
- package/dist/identity/repo-bucket.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +15 -0
- package/dist/index.js.map +1 -0
- package/dist/llm/layer4-stage.d.ts +18 -0
- package/dist/llm/layer4-stage.js +12 -0
- package/dist/llm/layer4-stage.js.map +1 -0
- package/dist/loaders/components.d.ts +26 -0
- package/dist/loaders/components.js +285 -0
- package/dist/loaders/components.js.map +1 -0
- package/dist/loaders/stories.d.ts +2 -0
- package/dist/loaders/stories.js +231 -0
- package/dist/loaders/stories.js.map +1 -0
- package/dist/loaders/token-graph.d.ts +39 -0
- package/dist/loaders/token-graph.js +146 -0
- package/dist/loaders/token-graph.js.map +1 -0
- package/dist/loaders/tokens.d.ts +2 -0
- package/dist/loaders/tokens.js +521 -0
- package/dist/loaders/tokens.js.map +1 -0
- package/dist/mcp/_find-root.d.ts +12 -0
- package/dist/mcp/_find-root.js +28 -0
- package/dist/mcp/_find-root.js.map +1 -0
- package/dist/mcp/server.d.ts +1 -0
- package/dist/mcp/server.js +42 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/audit-file.d.ts +25 -0
- package/dist/mcp/tools/audit-file.js +147 -0
- package/dist/mcp/tools/audit-file.js.map +1 -0
- package/dist/mcp/tools/suggest-fix.d.ts +13 -0
- package/dist/mcp/tools/suggest-fix.js +100 -0
- package/dist/mcp/tools/suggest-fix.js.map +1 -0
- package/dist/menu/action-menu.d.ts +6 -0
- package/dist/menu/action-menu.js +15 -0
- package/dist/menu/action-menu.js.map +1 -0
- package/dist/menu/prompts.d.ts +7 -0
- package/dist/menu/prompts.js +30 -0
- package/dist/menu/prompts.js.map +1 -0
- package/dist/menu/repl.d.ts +17 -0
- package/dist/menu/repl.js +77 -0
- package/dist/menu/repl.js.map +1 -0
- package/dist/parsers/css-in-js.d.ts +2 -0
- package/dist/parsers/css-in-js.js +69 -0
- package/dist/parsers/css-in-js.js.map +1 -0
- package/dist/parsers/css.d.ts +2 -0
- package/dist/parsers/css.js +32 -0
- package/dist/parsers/css.js.map +1 -0
- package/dist/parsers/scss-transform.d.ts +25 -0
- package/dist/parsers/scss-transform.js +55 -0
- package/dist/parsers/scss-transform.js.map +1 -0
- package/dist/parsers/tailwind-v4.d.ts +8 -0
- package/dist/parsers/tailwind-v4.js +90 -0
- package/dist/parsers/tailwind-v4.js.map +1 -0
- package/dist/parsers/ts-morph-project.d.ts +16 -0
- package/dist/parsers/ts-morph-project.js +77 -0
- package/dist/parsers/ts-morph-project.js.map +1 -0
- package/dist/parsers/ts.d.ts +2 -0
- package/dist/parsers/ts.js +61 -0
- package/dist/parsers/ts.js.map +1 -0
- package/dist/reliability/__tests__/types.test.d.ts +1 -0
- package/dist/reliability/__tests__/types.test.js +14 -0
- package/dist/reliability/__tests__/types.test.js.map +1 -0
- package/dist/reliability/catalogue/__tests__/promotion.test.d.ts +1 -0
- package/dist/reliability/catalogue/__tests__/promotion.test.js +23 -0
- package/dist/reliability/catalogue/__tests__/promotion.test.js.map +1 -0
- package/dist/reliability/catalogue/__tests__/sub-axes.test.d.ts +1 -0
- package/dist/reliability/catalogue/__tests__/sub-axes.test.js +27 -0
- package/dist/reliability/catalogue/__tests__/sub-axes.test.js.map +1 -0
- package/dist/reliability/catalogue/promotion.d.ts +8 -0
- package/dist/reliability/catalogue/promotion.js +25 -0
- package/dist/reliability/catalogue/promotion.js.map +1 -0
- package/dist/reliability/catalogue/sub-axes.d.ts +3 -0
- package/dist/reliability/catalogue/sub-axes.js +18 -0
- package/dist/reliability/catalogue/sub-axes.js.map +1 -0
- package/dist/reliability/confidence/__tests__/manifest-loader.test.d.ts +1 -0
- package/dist/reliability/confidence/__tests__/manifest-loader.test.js +103 -0
- package/dist/reliability/confidence/__tests__/manifest-loader.test.js.map +1 -0
- package/dist/reliability/confidence/bundled-manifest.d.ts +2 -0
- package/dist/reliability/confidence/bundled-manifest.js +8 -0
- package/dist/reliability/confidence/bundled-manifest.js.map +1 -0
- package/dist/reliability/confidence/index.d.ts +3 -0
- package/dist/reliability/confidence/index.js +3 -0
- package/dist/reliability/confidence/index.js.map +1 -0
- package/dist/reliability/confidence/manifest-loader.d.ts +8 -0
- package/dist/reliability/confidence/manifest-loader.js +53 -0
- package/dist/reliability/confidence/manifest-loader.js.map +1 -0
- package/dist/reliability/feedback/__tests__/interactive.test.d.ts +1 -0
- package/dist/reliability/feedback/__tests__/interactive.test.js +85 -0
- package/dist/reliability/feedback/__tests__/interactive.test.js.map +1 -0
- package/dist/reliability/feedback/__tests__/repo-bucket.test.d.ts +1 -0
- package/dist/reliability/feedback/__tests__/repo-bucket.test.js +18 -0
- package/dist/reliability/feedback/__tests__/repo-bucket.test.js.map +1 -0
- package/dist/reliability/feedback/__tests__/sender.test.d.ts +1 -0
- package/dist/reliability/feedback/__tests__/sender.test.js +101 -0
- package/dist/reliability/feedback/__tests__/sender.test.js.map +1 -0
- package/dist/reliability/feedback/interactive.d.ts +20 -0
- package/dist/reliability/feedback/interactive.js +150 -0
- package/dist/reliability/feedback/interactive.js.map +1 -0
- package/dist/reliability/feedback/repo-bucket.d.ts +2 -0
- package/dist/reliability/feedback/repo-bucket.js +9 -0
- package/dist/reliability/feedback/repo-bucket.js.map +1 -0
- package/dist/reliability/feedback/sender.d.ts +16 -0
- package/dist/reliability/feedback/sender.js +28 -0
- package/dist/reliability/feedback/sender.js.map +1 -0
- package/dist/reliability/index.d.ts +1 -0
- package/dist/reliability/index.js +2 -0
- package/dist/reliability/index.js.map +1 -0
- package/dist/reliability/llm-eval/__tests__/budget.test.d.ts +1 -0
- package/dist/reliability/llm-eval/__tests__/budget.test.js +39 -0
- package/dist/reliability/llm-eval/__tests__/budget.test.js.map +1 -0
- package/dist/reliability/llm-eval/budget.d.ts +14 -0
- package/dist/reliability/llm-eval/budget.js +43 -0
- package/dist/reliability/llm-eval/budget.js.map +1 -0
- package/dist/reliability/score/__tests__/formula-v1.test.d.ts +1 -0
- package/dist/reliability/score/__tests__/formula-v1.test.js +29 -0
- package/dist/reliability/score/__tests__/formula-v1.test.js.map +1 -0
- package/dist/reliability/score/formula-v1.d.ts +13 -0
- package/dist/reliability/score/formula-v1.js +19 -0
- package/dist/reliability/score/formula-v1.js.map +1 -0
- package/dist/reliability/score/version-pin.d.ts +1 -0
- package/dist/reliability/score/version-pin.js +2 -0
- package/dist/reliability/score/version-pin.js.map +1 -0
- package/dist/reliability/score/weight.d.ts +1 -0
- package/dist/reliability/score/weight.js +5 -0
- package/dist/reliability/score/weight.js.map +1 -0
- package/dist/reliability/types.d.ts +39 -0
- package/dist/reliability/types.js +2 -0
- package/dist/reliability/types.js.map +1 -0
- package/dist/reporters/coverage-footer.d.ts +2 -0
- package/dist/reporters/coverage-footer.js +7 -0
- package/dist/reporters/coverage-footer.js.map +1 -0
- package/dist/reporters/json.d.ts +5 -0
- package/dist/reporters/json.js +51 -0
- package/dist/reporters/json.js.map +1 -0
- package/dist/reporters/markdown.d.ts +7 -0
- package/dist/reporters/markdown.js +35 -0
- package/dist/reporters/markdown.js.map +1 -0
- package/dist/reporters/sarif.d.ts +5 -0
- package/dist/reporters/sarif.js +109 -0
- package/dist/reporters/sarif.js.map +1 -0
- package/dist/reporters/terminal-format.d.ts +34 -0
- package/dist/reporters/terminal-format.js +97 -0
- package/dist/reporters/terminal-format.js.map +1 -0
- package/dist/reporters/terminal.d.ts +4 -0
- package/dist/reporters/terminal.js +201 -0
- package/dist/reporters/terminal.js.map +1 -0
- package/dist/rule-runner.d.ts +8 -0
- package/dist/rule-runner.js +22 -0
- package/dist/rule-runner.js.map +1 -0
- package/dist/rules/_codemod-adapter.d.ts +16 -0
- package/dist/rules/_codemod-adapter.js +49 -0
- package/dist/rules/_codemod-adapter.js.map +1 -0
- package/dist/rules/_exclude.d.ts +11 -0
- package/dist/rules/_exclude.js +17 -0
- package/dist/rules/_exclude.js.map +1 -0
- package/dist/rules/_function-body-analysis.d.ts +82 -0
- package/dist/rules/_function-body-analysis.js +379 -0
- package/dist/rules/_function-body-analysis.js.map +1 -0
- package/dist/rules/_rule-module.d.ts +31 -0
- package/dist/rules/_rule-module.js +32 -0
- package/dist/rules/_rule-module.js.map +1 -0
- package/dist/rules/_skip-context.d.ts +36 -0
- package/dist/rules/_skip-context.js +128 -0
- package/dist/rules/_skip-context.js.map +1 -0
- package/dist/rules/a11y-essentials.d.ts +1 -0
- package/dist/rules/a11y-essentials.js +140 -0
- package/dist/rules/a11y-essentials.js.map +1 -0
- package/dist/rules/ai-surface-agents-md-quality.d.ts +22 -0
- package/dist/rules/ai-surface-agents-md-quality.js +233 -0
- package/dist/rules/ai-surface-agents-md-quality.js.map +1 -0
- package/dist/rules/ai-surface-component-manifest-json.d.ts +19 -0
- package/dist/rules/ai-surface-component-manifest-json.js +232 -0
- package/dist/rules/ai-surface-component-manifest-json.js.map +1 -0
- package/dist/rules/ai-surface-ds-index-exported.d.ts +19 -0
- package/dist/rules/ai-surface-ds-index-exported.js +239 -0
- package/dist/rules/ai-surface-ds-index-exported.js.map +1 -0
- package/dist/rules/components-shadow-native.d.ts +2 -0
- package/dist/rules/components-shadow-native.js +118 -0
- package/dist/rules/components-shadow-native.js.map +1 -0
- package/dist/rules/manifest.d.ts +5 -0
- package/dist/rules/manifest.js +20 -0
- package/dist/rules/manifest.js.map +1 -0
- package/dist/rules/naming-component-pascalcase.d.ts +7 -0
- package/dist/rules/naming-component-pascalcase.js +197 -0
- package/dist/rules/naming-component-pascalcase.js.map +1 -0
- package/dist/rules/naming-hook-prefix.d.ts +6 -0
- package/dist/rules/naming-hook-prefix.js +185 -0
- package/dist/rules/naming-hook-prefix.js.map +1 -0
- package/dist/rules/pack-loader.d.ts +30 -0
- package/dist/rules/pack-loader.js +60 -0
- package/dist/rules/pack-loader.js.map +1 -0
- package/dist/rules/pack-validator.d.ts +8 -0
- package/dist/rules/pack-validator.js +97 -0
- package/dist/rules/pack-validator.js.map +1 -0
- package/dist/rules/registry.d.ts +3 -0
- package/dist/rules/registry.js +28 -0
- package/dist/rules/registry.js.map +1 -0
- package/dist/rules/storybook-coverage.d.ts +1 -0
- package/dist/rules/storybook-coverage.js +49 -0
- package/dist/rules/storybook-coverage.js.map +1 -0
- package/dist/rules/templates/_regex-utils.d.ts +5 -0
- package/dist/rules/templates/_regex-utils.js +8 -0
- package/dist/rules/templates/_regex-utils.js.map +1 -0
- package/dist/rules/templates/a11y-jsx-template.d.ts +15 -0
- package/dist/rules/templates/a11y-jsx-template.js +69 -0
- package/dist/rules/templates/a11y-jsx-template.js.map +1 -0
- package/dist/rules/templates/css-property-token-compliance.d.ts +18 -0
- package/dist/rules/templates/css-property-token-compliance.js +56 -0
- package/dist/rules/templates/css-property-token-compliance.js.map +1 -0
- package/dist/rules/templates/import-source-restriction.d.ts +18 -0
- package/dist/rules/templates/import-source-restriction.js +60 -0
- package/dist/rules/templates/import-source-restriction.js.map +1 -0
- package/dist/rules/templates/js-call-token-compliance.d.ts +18 -0
- package/dist/rules/templates/js-call-token-compliance.js +61 -0
- package/dist/rules/templates/js-call-token-compliance.js.map +1 -0
- package/dist/rules/templates/js-prop-token-compliance.d.ts +21 -0
- package/dist/rules/templates/js-prop-token-compliance.js +56 -0
- package/dist/rules/templates/js-prop-token-compliance.js.map +1 -0
- package/dist/rules/templates/naming-convention.d.ts +18 -0
- package/dist/rules/templates/naming-convention.js +76 -0
- package/dist/rules/templates/naming-convention.js.map +1 -0
- package/dist/rules/templates/registry.d.ts +5 -0
- package/dist/rules/templates/registry.js +30 -0
- package/dist/rules/templates/registry.js.map +1 -0
- package/dist/rules/templates/storybook-coverage-template.d.ts +15 -0
- package/dist/rules/templates/storybook-coverage-template.js +58 -0
- package/dist/rules/templates/storybook-coverage-template.js.map +1 -0
- package/dist/rules/templates/tailwind-utility-class-compliance.d.ts +15 -0
- package/dist/rules/templates/tailwind-utility-class-compliance.js +70 -0
- package/dist/rules/templates/tailwind-utility-class-compliance.js.map +1 -0
- package/dist/rules/templates/types.d.ts +16 -0
- package/dist/rules/templates/types.js +2 -0
- package/dist/rules/templates/types.js.map +1 -0
- package/dist/rules/tokens-description-coverage.d.ts +15 -0
- package/dist/rules/tokens-description-coverage.js +193 -0
- package/dist/rules/tokens-description-coverage.js.map +1 -0
- package/dist/rules/tokens-dtcg-conformance.d.ts +47 -0
- package/dist/rules/tokens-dtcg-conformance.js +363 -0
- package/dist/rules/tokens-dtcg-conformance.js.map +1 -0
- package/dist/rules/tokens-no-hardcoded-color.d.ts +18 -0
- package/dist/rules/tokens-no-hardcoded-color.js +436 -0
- package/dist/rules/tokens-no-hardcoded-color.js.map +1 -0
- package/dist/rules/tokens-no-hardcoded-spacing.d.ts +8 -0
- package/dist/rules/tokens-no-hardcoded-spacing.js +193 -0
- package/dist/rules/tokens-no-hardcoded-spacing.js.map +1 -0
- package/dist/scorer.d.ts +38 -0
- package/dist/scorer.js +126 -0
- package/dist/scorer.js.map +1 -0
- package/dist/share/clipboard.d.ts +26 -0
- package/dist/share/clipboard.js +76 -0
- package/dist/share/clipboard.js.map +1 -0
- package/dist/suppression/__tests__/inline.test.d.ts +1 -0
- package/dist/suppression/__tests__/inline.test.js +25 -0
- package/dist/suppression/__tests__/inline.test.js.map +1 -0
- package/dist/suppression/__tests__/lyseignore.test.d.ts +1 -0
- package/dist/suppression/__tests__/lyseignore.test.js +32 -0
- package/dist/suppression/__tests__/lyseignore.test.js.map +1 -0
- package/dist/suppression/defaults.d.ts +1 -0
- package/dist/suppression/defaults.js +14 -0
- package/dist/suppression/defaults.js.map +1 -0
- package/dist/suppression/inline.d.ts +7 -0
- package/dist/suppression/inline.js +32 -0
- package/dist/suppression/inline.js.map +1 -0
- package/dist/suppression/lyseignore.d.ts +2 -0
- package/dist/suppression/lyseignore.js +22 -0
- package/dist/suppression/lyseignore.js.map +1 -0
- package/dist/telemetry/consent.d.ts +48 -0
- package/dist/telemetry/consent.js +139 -0
- package/dist/telemetry/consent.js.map +1 -0
- package/dist/telemetry/index.d.ts +2 -0
- package/dist/telemetry/index.js +3 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/telemetry/local-log.d.ts +64 -0
- package/dist/telemetry/local-log.js +123 -0
- package/dist/telemetry/local-log.js.map +1 -0
- package/dist/tokens/dtcg-model.d.ts +53 -0
- package/dist/tokens/dtcg-model.js +18 -0
- package/dist/tokens/dtcg-model.js.map +1 -0
- package/dist/tokens/normalizer.d.ts +17 -0
- package/dist/tokens/normalizer.js +360 -0
- package/dist/tokens/normalizer.js.map +1 -0
- package/dist/types.d.ts +300 -0
- package/dist/types.js +4 -0
- package/dist/types.js.map +1 -0
- package/dist/util/git.d.ts +6 -0
- package/dist/util/git.js +40 -0
- package/dist/util/git.js.map +1 -0
- package/dist/util/git.test.d.ts +5 -0
- package/dist/util/git.test.js +42 -0
- package/dist/util/git.test.js.map +1 -0
- package/dist/util/gitignore.d.ts +9 -0
- package/dist/util/gitignore.js +39 -0
- package/dist/util/gitignore.js.map +1 -0
- package/dist/util/hash-deps.d.ts +6 -0
- package/dist/util/hash-deps.js +24 -0
- package/dist/util/hash-deps.js.map +1 -0
- package/dist/util/spinner.d.ts +41 -0
- package/dist/util/spinner.js +126 -0
- package/dist/util/spinner.js.map +1 -0
- package/dist/util/with-spinner.d.ts +11 -0
- package/dist/util/with-spinner.js +19 -0
- package/dist/util/with-spinner.js.map +1 -0
- package/dist/walker.d.ts +14 -0
- package/dist/walker.js +91 -0
- package/dist/walker.js.map +1 -0
- package/package.json +83 -0
- package/rules-manifest.json +289 -0
- package/schemas/v1/lyse-config.json +82 -0
- package/schemas/v1/lyse-event.json +68 -0
- package/schemas/v1/lyse-license.json +19 -0
- package/schemas/v1/lyse-llm-payload.json +53 -0
- package/schemas/v1/lyse-llm-response.json +45 -0
- package/schemas/v1/lyse-result.json +98 -0
- package/schemas/v1/lyse-rules.json +42 -0
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* commands/fix.ts — Auto-fix orchestrator with 6 safety guards.
|
|
3
|
+
*
|
|
4
|
+
* Guard 1: always creates a separate branch (lyse/auto-fix-DATE, collision-safe)
|
|
5
|
+
* Guard 2: refuses to run on a dirty working tree (--force-on-dirty override)
|
|
6
|
+
* Guard 3: first-run dry-run preview hook (interactive prompt plugged in by Task 18)
|
|
7
|
+
* Guard 4: confidence floor — default "high"; opt-in via --confidence=medium|low
|
|
8
|
+
* Guard 5: per-rule commits with descriptive messages
|
|
9
|
+
* Guard 6: optional test verification (--verify-with-tests; reverts commit on fail)
|
|
10
|
+
*/
|
|
11
|
+
import type { Confidence } from "../types.js";
|
|
12
|
+
export interface FixOptions {
|
|
13
|
+
/** Absolute path to the repository root. */
|
|
14
|
+
cwd: string;
|
|
15
|
+
/** Dry-run mode: compute what would be done but don't write or commit. */
|
|
16
|
+
dryRun?: boolean;
|
|
17
|
+
/** Enable interactive prompts (used by Task 18 wizard). */
|
|
18
|
+
interactive?: boolean;
|
|
19
|
+
/** Minimum confidence floor; defaults to "high". */
|
|
20
|
+
confidence?: Confidence;
|
|
21
|
+
/** Limit fixes to a specific rule ID. */
|
|
22
|
+
rule?: string;
|
|
23
|
+
/** Override Guard 2 and allow running on a dirty working tree. */
|
|
24
|
+
forceOnDirty?: boolean;
|
|
25
|
+
/** Run the test suite after each rule batch and revert on failure (Guard 6). */
|
|
26
|
+
verifyWithTests?: boolean;
|
|
27
|
+
/** Override the branch name (useful for tests). */
|
|
28
|
+
branch?: string;
|
|
29
|
+
/** Skip interactive prompts (used in tests and CI). */
|
|
30
|
+
autoApprove?: boolean;
|
|
31
|
+
}
|
|
32
|
+
export interface RuleResult {
|
|
33
|
+
ruleId: string;
|
|
34
|
+
count: number;
|
|
35
|
+
commitSha: string | null;
|
|
36
|
+
testsPassed?: boolean | undefined;
|
|
37
|
+
/** Warnings for findings that could not be applied (e.g. git apply reject, empty diff). */
|
|
38
|
+
warnings?: string[];
|
|
39
|
+
}
|
|
40
|
+
export interface FixResult {
|
|
41
|
+
branch: string;
|
|
42
|
+
ruleResults: RuleResult[];
|
|
43
|
+
skipped: {
|
|
44
|
+
medium: number;
|
|
45
|
+
low: number;
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
export declare function runFix(opt: FixOptions): Promise<FixResult>;
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* commands/fix.ts — Auto-fix orchestrator with 6 safety guards.
|
|
3
|
+
*
|
|
4
|
+
* Guard 1: always creates a separate branch (lyse/auto-fix-DATE, collision-safe)
|
|
5
|
+
* Guard 2: refuses to run on a dirty working tree (--force-on-dirty override)
|
|
6
|
+
* Guard 3: first-run dry-run preview hook (interactive prompt plugged in by Task 18)
|
|
7
|
+
* Guard 4: confidence floor — default "high"; opt-in via --confidence=medium|low
|
|
8
|
+
* Guard 5: per-rule commits with descriptive messages
|
|
9
|
+
* Guard 6: optional test verification (--verify-with-tests; reverts commit on fail)
|
|
10
|
+
*/
|
|
11
|
+
import { readFile } from "node:fs/promises";
|
|
12
|
+
import { join } from "node:path";
|
|
13
|
+
import { spawn } from "node:child_process";
|
|
14
|
+
import { ensureClean, ensureSafeBranch, createBranch, commitAll, revertCommit, runTests, hasTestScript, } from "../codemods/git-helpers.js";
|
|
15
|
+
import { groupByConfidence, groupByRule, buildClassifyContext } from "../codemods/safety.js";
|
|
16
|
+
import { auditDirectory } from "./audit-pipeline.js";
|
|
17
|
+
import { appendFixEvent as appendFixEventStore } from "../history/ndjson-store.js";
|
|
18
|
+
// ---------------------------------------------------------------------------
|
|
19
|
+
// Rule lookup — map from rule ID to Rule (which carries applyCodemod)
|
|
20
|
+
// ---------------------------------------------------------------------------
|
|
21
|
+
import { ruleMap } from "../rules/registry.js";
|
|
22
|
+
// ---------------------------------------------------------------------------
|
|
23
|
+
// Diff application
|
|
24
|
+
// ---------------------------------------------------------------------------
|
|
25
|
+
/**
|
|
26
|
+
* Apply a unified diff to the working tree using `git apply`.
|
|
27
|
+
* The diff must be a valid unified diff with paths relative to `cwd`.
|
|
28
|
+
*
|
|
29
|
+
* If `diff` is empty, this is a no-op.
|
|
30
|
+
*/
|
|
31
|
+
async function applyDiff(cwd, diff) {
|
|
32
|
+
if (!diff)
|
|
33
|
+
return;
|
|
34
|
+
return new Promise((resolve, reject) => {
|
|
35
|
+
const child = spawn("git", ["apply", "--recount", "-"], { cwd });
|
|
36
|
+
let stderr = "";
|
|
37
|
+
child.stderr.on("data", (chunk) => {
|
|
38
|
+
stderr += chunk.toString();
|
|
39
|
+
});
|
|
40
|
+
child.on("exit", (code) => {
|
|
41
|
+
if (code === 0) {
|
|
42
|
+
resolve();
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
reject(new Error(`git apply failed (exit ${code}): ${stderr.trim()}`));
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
child.on("error", reject);
|
|
49
|
+
child.stdin.write(diff);
|
|
50
|
+
child.stdin.end();
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
// ---------------------------------------------------------------------------
|
|
54
|
+
// Main orchestrator
|
|
55
|
+
// ---------------------------------------------------------------------------
|
|
56
|
+
export async function runFix(opt) {
|
|
57
|
+
// Guard 2: refuse on dirty working tree (unless --force-on-dirty)
|
|
58
|
+
await ensureClean(opt.cwd, opt.forceOnDirty ?? false);
|
|
59
|
+
// Pre-flight: must not be on a detached HEAD
|
|
60
|
+
await ensureSafeBranch(opt.cwd);
|
|
61
|
+
// Run audit to discover findings
|
|
62
|
+
const { result: auditResult, tokens, config } = await auditDirectory(opt.cwd);
|
|
63
|
+
// Build ClassifyContext from audit results (shared with the post-audit menu count)
|
|
64
|
+
const ctx = buildClassifyContext(auditResult.findings, tokens, config, opt.cwd);
|
|
65
|
+
// Filter to fixable findings (those where the rule has applyCodemod)
|
|
66
|
+
const fixable = auditResult.findings.filter((f) => {
|
|
67
|
+
const rule = ruleMap.get(f.ruleId);
|
|
68
|
+
return !!rule?.applyCodemod;
|
|
69
|
+
});
|
|
70
|
+
// Group by confidence level (Guard 4: confidence floor)
|
|
71
|
+
const grouped = groupByConfidence(fixable, ctx);
|
|
72
|
+
// Guard 4: confidence floor — default "high"
|
|
73
|
+
const floor = opt.confidence ?? "high";
|
|
74
|
+
let toApply;
|
|
75
|
+
if (floor === "high") {
|
|
76
|
+
toApply = grouped.high;
|
|
77
|
+
}
|
|
78
|
+
else if (floor === "medium") {
|
|
79
|
+
toApply = [...grouped.high, ...grouped.medium];
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
toApply = [...grouped.high, ...grouped.medium, ...grouped.low];
|
|
83
|
+
}
|
|
84
|
+
// Apply rule filter if requested
|
|
85
|
+
if (opt.rule) {
|
|
86
|
+
toApply = toApply.filter((f) => f.ruleId === opt.rule);
|
|
87
|
+
}
|
|
88
|
+
// Guard 3: first-run dry-run preview
|
|
89
|
+
// If this is the first run AND interactive mode is on AND not autoApprove,
|
|
90
|
+
// Task 18 wizard will inject a prompt here. For now, the hook is present
|
|
91
|
+
// but non-blocking (the logic slot is reserved, not filled until Task 18).
|
|
92
|
+
// Task 18: const firstRun = await isFirstAutoFixStore(opt.cwd);
|
|
93
|
+
// Task 18: if (firstRun && opt.interactive && !opt.autoApprove) { await showPreviewPrompt(...); }
|
|
94
|
+
// Guard 1: create a separate branch
|
|
95
|
+
const branchName = opt.branch ?? `lyse/auto-fix-${new Date().toISOString().slice(0, 10)}`;
|
|
96
|
+
// In dry-run mode we never actually create the branch
|
|
97
|
+
const actualBranch = opt.dryRun ? branchName : await createBranch(opt.cwd, branchName);
|
|
98
|
+
const ruleResults = [];
|
|
99
|
+
const byRule = groupByRule(toApply);
|
|
100
|
+
for (const [ruleId, findings] of byRule.entries()) {
|
|
101
|
+
// Dry-run: just report what would happen, no mutations
|
|
102
|
+
if (opt.dryRun) {
|
|
103
|
+
ruleResults.push({ ruleId, count: findings.length, commitSha: null });
|
|
104
|
+
continue;
|
|
105
|
+
}
|
|
106
|
+
const rule = ruleMap.get(ruleId);
|
|
107
|
+
if (!rule?.applyCodemod) {
|
|
108
|
+
// Guard 5: skip rules without a codemod (should not happen after fixable filter, but be safe)
|
|
109
|
+
ruleResults.push({ ruleId, count: 0, commitSha: null });
|
|
110
|
+
continue;
|
|
111
|
+
}
|
|
112
|
+
let appliedCount = 0;
|
|
113
|
+
const ruleWarnings = [];
|
|
114
|
+
for (const finding of findings) {
|
|
115
|
+
const loc = `${finding.location.file}:${finding.location.line}`;
|
|
116
|
+
// Load the current file content for this finding
|
|
117
|
+
const filePath = join(opt.cwd, finding.location.file);
|
|
118
|
+
let fileContent;
|
|
119
|
+
try {
|
|
120
|
+
fileContent = await readFile(filePath, "utf8");
|
|
121
|
+
}
|
|
122
|
+
catch (err) {
|
|
123
|
+
// File disappeared between audit and fix — skip with warning
|
|
124
|
+
ruleWarnings.push(`Skipped finding at ${loc} — file not readable: ${err.message}`);
|
|
125
|
+
continue;
|
|
126
|
+
}
|
|
127
|
+
const codemodCtx = {
|
|
128
|
+
...ctx,
|
|
129
|
+
fileContent,
|
|
130
|
+
parsedAst: null,
|
|
131
|
+
};
|
|
132
|
+
const result = rule.applyCodemod(finding, codemodCtx);
|
|
133
|
+
// Skip if no diff was produced (confidence too low, no token match, etc.)
|
|
134
|
+
if (!result.diff) {
|
|
135
|
+
ruleWarnings.push(`Skipped finding at ${loc} — codemod produced no diff`);
|
|
136
|
+
continue;
|
|
137
|
+
}
|
|
138
|
+
try {
|
|
139
|
+
await applyDiff(opt.cwd, result.diff);
|
|
140
|
+
appliedCount++;
|
|
141
|
+
}
|
|
142
|
+
catch (err) {
|
|
143
|
+
// If git apply fails, surface as a warning rather than silently swallowing
|
|
144
|
+
ruleWarnings.push(`Skipped finding at ${loc} — git apply failed: ${err.message}`);
|
|
145
|
+
continue;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
// Guard 5: per-rule commit with descriptive message
|
|
149
|
+
if (appliedCount === 0) {
|
|
150
|
+
if (ruleWarnings.length > 0) {
|
|
151
|
+
ruleResults.push({ ruleId, count: 0, commitSha: null, warnings: ruleWarnings });
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
ruleResults.push({ ruleId, count: 0, commitSha: null });
|
|
155
|
+
}
|
|
156
|
+
continue;
|
|
157
|
+
}
|
|
158
|
+
const msg = `Lyse: fix ${appliedCount} ${ruleId} finding${appliedCount !== 1 ? "s" : ""} (high confidence)`;
|
|
159
|
+
const sha = await commitAll(opt.cwd, msg);
|
|
160
|
+
// Guard 6: optional test verification — revert commit on test failure
|
|
161
|
+
let testsPassed;
|
|
162
|
+
if (opt.verifyWithTests && (await hasTestScript(opt.cwd))) {
|
|
163
|
+
const { passed } = await runTests(opt.cwd);
|
|
164
|
+
testsPassed = passed;
|
|
165
|
+
if (!passed) {
|
|
166
|
+
await revertCommit(opt.cwd, sha);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
if (ruleWarnings.length > 0) {
|
|
170
|
+
ruleResults.push({ ruleId, count: appliedCount, commitSha: sha, testsPassed, warnings: ruleWarnings });
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
ruleResults.push({ ruleId, count: appliedCount, commitSha: sha, testsPassed });
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
// Append to history for each rule that had fixes applied
|
|
177
|
+
for (const result of ruleResults) {
|
|
178
|
+
if (result.count > 0 && result.commitSha) {
|
|
179
|
+
await appendFixEventStore(opt.cwd, result.ruleId, "high", result.count, result.commitSha);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
return {
|
|
183
|
+
branch: actualBranch,
|
|
184
|
+
ruleResults,
|
|
185
|
+
skipped: {
|
|
186
|
+
medium: grouped.medium.length,
|
|
187
|
+
low: grouped.low.length,
|
|
188
|
+
},
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
//# sourceMappingURL=fix.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fix.js","sourceRoot":"","sources":["../../src/commands/fix.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export type Framework = "react" | "vue" | "solid" | "svelte" | "unknown";
|
|
2
|
+
export type Styling = "tailwind-v4" | "tailwind-v3" | "css-modules" | "vanilla-extract" | "emotion" | "styled-components" | "unknown";
|
|
3
|
+
export type TestRunner = "vitest" | "jest" | "playwright" | "none";
|
|
4
|
+
export interface StackDetection {
|
|
5
|
+
framework: Framework;
|
|
6
|
+
styling: Styling;
|
|
7
|
+
hasTypeScript: boolean;
|
|
8
|
+
testRunners: TestRunner[];
|
|
9
|
+
}
|
|
10
|
+
interface PackageJsonLike {
|
|
11
|
+
dependencies?: Record<string, string>;
|
|
12
|
+
devDependencies?: Record<string, string>;
|
|
13
|
+
}
|
|
14
|
+
export declare function detectStack(repoRoot: string): StackDetection;
|
|
15
|
+
export declare function readPackageJson(repoRoot: string): PackageJsonLike;
|
|
16
|
+
export declare function mergeDeps(pkg: PackageJsonLike): Record<string, string>;
|
|
17
|
+
export declare function detectFramework(deps: Record<string, string>): Framework;
|
|
18
|
+
export declare function detectStyling(deps: Record<string, string>, repoRoot: string): Styling;
|
|
19
|
+
export declare function detectTestRunners(deps: Record<string, string>): TestRunner[];
|
|
20
|
+
export {};
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { existsSync, readFileSync, readdirSync } from "node:fs";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
export function detectStack(repoRoot) {
|
|
4
|
+
const pkg = readPackageJson(repoRoot);
|
|
5
|
+
const deps = mergeDeps(pkg);
|
|
6
|
+
return {
|
|
7
|
+
framework: detectFramework(deps),
|
|
8
|
+
styling: detectStyling(deps, repoRoot),
|
|
9
|
+
hasTypeScript: existsSync(join(repoRoot, "tsconfig.json")) || "typescript" in deps,
|
|
10
|
+
testRunners: detectTestRunners(deps),
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
export function readPackageJson(repoRoot) {
|
|
14
|
+
try {
|
|
15
|
+
return JSON.parse(readFileSync(join(repoRoot, "package.json"), "utf8"));
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return {};
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
export function mergeDeps(pkg) {
|
|
22
|
+
return { ...pkg.dependencies, ...pkg.devDependencies };
|
|
23
|
+
}
|
|
24
|
+
export function detectFramework(deps) {
|
|
25
|
+
if ("react" in deps)
|
|
26
|
+
return "react";
|
|
27
|
+
if ("vue" in deps)
|
|
28
|
+
return "vue";
|
|
29
|
+
if ("solid-js" in deps)
|
|
30
|
+
return "solid";
|
|
31
|
+
if ("svelte" in deps)
|
|
32
|
+
return "svelte";
|
|
33
|
+
return "unknown";
|
|
34
|
+
}
|
|
35
|
+
export function detectStyling(deps, repoRoot) {
|
|
36
|
+
const tw = deps["tailwindcss"];
|
|
37
|
+
if (tw) {
|
|
38
|
+
if (isTailwindV4(tw) || hasTailwindV4CssEntry(repoRoot))
|
|
39
|
+
return "tailwind-v4";
|
|
40
|
+
return "tailwind-v3";
|
|
41
|
+
}
|
|
42
|
+
if ("@vanilla-extract/css" in deps)
|
|
43
|
+
return "vanilla-extract";
|
|
44
|
+
if ("@emotion/react" in deps || "@emotion/styled" in deps)
|
|
45
|
+
return "emotion";
|
|
46
|
+
if ("styled-components" in deps)
|
|
47
|
+
return "styled-components";
|
|
48
|
+
if (hasCssModuleFile(repoRoot))
|
|
49
|
+
return "css-modules";
|
|
50
|
+
return "unknown";
|
|
51
|
+
}
|
|
52
|
+
function isTailwindV4(versionRange) {
|
|
53
|
+
const m = versionRange.match(/(\d+)/);
|
|
54
|
+
if (!m || !m[1])
|
|
55
|
+
return false;
|
|
56
|
+
return parseInt(m[1], 10) >= 4;
|
|
57
|
+
}
|
|
58
|
+
function hasTailwindV4CssEntry(repoRoot) {
|
|
59
|
+
const candidates = [
|
|
60
|
+
"app.css",
|
|
61
|
+
"globals.css",
|
|
62
|
+
"src/app.css",
|
|
63
|
+
"src/globals.css",
|
|
64
|
+
"src/styles/globals.css",
|
|
65
|
+
"styles/globals.css",
|
|
66
|
+
"app/globals.css",
|
|
67
|
+
];
|
|
68
|
+
for (const c of candidates) {
|
|
69
|
+
const p = join(repoRoot, c);
|
|
70
|
+
if (!existsSync(p))
|
|
71
|
+
continue;
|
|
72
|
+
try {
|
|
73
|
+
const css = readFileSync(p, "utf8");
|
|
74
|
+
if (/@import\s+["']tailwindcss["']/.test(css) || /@theme\b/.test(css))
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
catch {
|
|
78
|
+
// ignore
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
function hasCssModuleFile(repoRoot) {
|
|
84
|
+
const probes = ["src", "app", "components"];
|
|
85
|
+
for (const p of probes) {
|
|
86
|
+
const root = join(repoRoot, p);
|
|
87
|
+
if (!existsSync(root))
|
|
88
|
+
continue;
|
|
89
|
+
if (scanForCssModule(root, 3))
|
|
90
|
+
return true;
|
|
91
|
+
}
|
|
92
|
+
return false;
|
|
93
|
+
}
|
|
94
|
+
function scanForCssModule(dir, depth) {
|
|
95
|
+
if (depth < 0)
|
|
96
|
+
return false;
|
|
97
|
+
let entries = [];
|
|
98
|
+
try {
|
|
99
|
+
entries = readdirSync(dir, { withFileTypes: true });
|
|
100
|
+
}
|
|
101
|
+
catch {
|
|
102
|
+
return false;
|
|
103
|
+
}
|
|
104
|
+
for (const e of entries) {
|
|
105
|
+
if (e.name === "node_modules" || e.name.startsWith("."))
|
|
106
|
+
continue;
|
|
107
|
+
if (e.isFile() && /\.module\.(css|scss|sass)$/.test(e.name))
|
|
108
|
+
return true;
|
|
109
|
+
if (e.isDirectory() && scanForCssModule(join(dir, e.name), depth - 1))
|
|
110
|
+
return true;
|
|
111
|
+
}
|
|
112
|
+
return false;
|
|
113
|
+
}
|
|
114
|
+
export function detectTestRunners(deps) {
|
|
115
|
+
const runners = [];
|
|
116
|
+
if ("vitest" in deps)
|
|
117
|
+
runners.push("vitest");
|
|
118
|
+
if ("jest" in deps || "@jest/core" in deps)
|
|
119
|
+
runners.push("jest");
|
|
120
|
+
if ("@playwright/test" in deps || "playwright" in deps)
|
|
121
|
+
runners.push("playwright");
|
|
122
|
+
return runners.length > 0 ? runners : ["none"];
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=init-detect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init-detect.js","sourceRoot":"","sources":["../../src/commands/init-detect.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export declare const LYSE_BLOCK_BEGIN = "<!-- lyse-managed:begin -->";
|
|
2
|
+
export declare const LYSE_BLOCK_END = "<!-- lyse-managed:end -->";
|
|
3
|
+
export interface WriteAgentsMdResult {
|
|
4
|
+
path: string;
|
|
5
|
+
created: boolean;
|
|
6
|
+
blockReplaced: boolean;
|
|
7
|
+
blockAppended: boolean;
|
|
8
|
+
}
|
|
9
|
+
export declare function buildLyseBlock(): string;
|
|
10
|
+
export declare function replaceOrAppendLyseBlock(existing: string, block: string): {
|
|
11
|
+
content: string;
|
|
12
|
+
replaced: boolean;
|
|
13
|
+
};
|
|
14
|
+
export declare function writeAgentsMd(repoRoot: string): WriteAgentsMdResult;
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { existsSync, readFileSync, writeFileSync } from "node:fs";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
export const LYSE_BLOCK_BEGIN = "<!-- lyse-managed:begin -->";
|
|
4
|
+
export const LYSE_BLOCK_END = "<!-- lyse-managed:end -->";
|
|
5
|
+
const LYSE_HEADING = "## Lyse audit (auto-managed)";
|
|
6
|
+
const MINIMAL_PREAMBLE = "# Agents\n\nThis file is read by AI coding assistants. Edit freely outside the Lyse-managed block.\n\n";
|
|
7
|
+
export function buildLyseBlock() {
|
|
8
|
+
return [
|
|
9
|
+
LYSE_HEADING,
|
|
10
|
+
"",
|
|
11
|
+
LYSE_BLOCK_BEGIN,
|
|
12
|
+
"### Validate design-system conformance",
|
|
13
|
+
"",
|
|
14
|
+
"```bash",
|
|
15
|
+
"pnpm exec lyse audit",
|
|
16
|
+
"```",
|
|
17
|
+
"",
|
|
18
|
+
"Exit codes:",
|
|
19
|
+
"- 0 — pass (Health Score ≥ project threshold)",
|
|
20
|
+
"- 1 — fail (Health Score below threshold or hard errors)",
|
|
21
|
+
"- 2 — config error",
|
|
22
|
+
LYSE_BLOCK_END,
|
|
23
|
+
"",
|
|
24
|
+
].join("\n");
|
|
25
|
+
}
|
|
26
|
+
export function replaceOrAppendLyseBlock(existing, block) {
|
|
27
|
+
const beginIdx = existing.indexOf(LYSE_BLOCK_BEGIN);
|
|
28
|
+
const endIdx = existing.indexOf(LYSE_BLOCK_END);
|
|
29
|
+
if (beginIdx !== -1 && endIdx !== -1 && endIdx > beginIdx) {
|
|
30
|
+
const headingStart = findHeadingStart(existing, beginIdx);
|
|
31
|
+
const blockEndPos = endIdx + LYSE_BLOCK_END.length;
|
|
32
|
+
let after = existing.slice(blockEndPos);
|
|
33
|
+
if (after.startsWith("\n\n"))
|
|
34
|
+
after = after.slice(1);
|
|
35
|
+
else if (!after.startsWith("\n"))
|
|
36
|
+
after = "\n" + after;
|
|
37
|
+
const before = existing.slice(0, headingStart);
|
|
38
|
+
const beforeNormalized = before.endsWith("\n") || before.length === 0 ? before : before + "\n";
|
|
39
|
+
return { content: beforeNormalized + block + after, replaced: true };
|
|
40
|
+
}
|
|
41
|
+
const sep = existing.length === 0 || existing.endsWith("\n\n") ? "" : existing.endsWith("\n") ? "\n" : "\n\n";
|
|
42
|
+
return { content: existing + sep + block, replaced: false };
|
|
43
|
+
}
|
|
44
|
+
function findHeadingStart(content, beginIdx) {
|
|
45
|
+
const headingIdx = content.lastIndexOf(LYSE_HEADING, beginIdx);
|
|
46
|
+
if (headingIdx === -1)
|
|
47
|
+
return beginIdx;
|
|
48
|
+
if (headingIdx === 0)
|
|
49
|
+
return 0;
|
|
50
|
+
let i = headingIdx;
|
|
51
|
+
while (i > 0 && content[i - 1] === "\n")
|
|
52
|
+
i--;
|
|
53
|
+
return i === 0 ? 0 : i + 1;
|
|
54
|
+
}
|
|
55
|
+
export function writeAgentsMd(repoRoot) {
|
|
56
|
+
const path = join(repoRoot, "AGENTS.md");
|
|
57
|
+
const block = buildLyseBlock();
|
|
58
|
+
if (!existsSync(path)) {
|
|
59
|
+
const content = MINIMAL_PREAMBLE + block;
|
|
60
|
+
writeFileSync(path, content);
|
|
61
|
+
return { path, created: true, blockReplaced: false, blockAppended: false };
|
|
62
|
+
}
|
|
63
|
+
const existing = readFileSync(path, "utf8");
|
|
64
|
+
const { content, replaced } = replaceOrAppendLyseBlock(existing, block);
|
|
65
|
+
if (content === existing) {
|
|
66
|
+
return { path, created: false, blockReplaced: false, blockAppended: false };
|
|
67
|
+
}
|
|
68
|
+
writeFileSync(path, content);
|
|
69
|
+
return { path, created: false, blockReplaced: replaced, blockAppended: !replaced };
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=init-write-agents-md.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init-write-agents-md.js","sourceRoot":"","sources":["../../src/commands/init-write-agents-md.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { StackDetection } from "./init-detect.js";
|
|
2
|
+
import type { ComponentInventoryEntry } from "../types.js";
|
|
3
|
+
export interface LyseMdInputs {
|
|
4
|
+
repoRoot: string;
|
|
5
|
+
stack: StackDetection;
|
|
6
|
+
componentsModule: string | null;
|
|
7
|
+
componentInventory: ComponentInventoryEntry[];
|
|
8
|
+
}
|
|
9
|
+
export declare function writeLyseMd(inputs: LyseMdInputs): {
|
|
10
|
+
path: string;
|
|
11
|
+
created: boolean;
|
|
12
|
+
updated: boolean;
|
|
13
|
+
};
|
|
14
|
+
export declare function buildLyseMd(inputs: LyseMdInputs): string;
|