raptor-aios 0.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/CHANGELOG.md +26 -0
- package/LICENSE +21 -0
- package/README.md +315 -0
- package/bin/raptor.js +5 -0
- package/dist/_core/dist/agents/adapters/antigravity.d.ts +9 -0
- package/dist/_core/dist/agents/adapters/antigravity.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/antigravity.js +72 -0
- package/dist/_core/dist/agents/adapters/antigravity.js.map +1 -0
- package/dist/_core/dist/agents/adapters/claude-code.d.ts +9 -0
- package/dist/_core/dist/agents/adapters/claude-code.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/claude-code.js +71 -0
- package/dist/_core/dist/agents/adapters/claude-code.js.map +1 -0
- package/dist/_core/dist/agents/adapters/codex.d.ts +12 -0
- package/dist/_core/dist/agents/adapters/codex.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/codex.js +69 -0
- package/dist/_core/dist/agents/adapters/codex.js.map +1 -0
- package/dist/_core/dist/agents/adapters/copilot.d.ts +12 -0
- package/dist/_core/dist/agents/adapters/copilot.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/copilot.js +71 -0
- package/dist/_core/dist/agents/adapters/copilot.js.map +1 -0
- package/dist/_core/dist/agents/adapters/cursor.d.ts +9 -0
- package/dist/_core/dist/agents/adapters/cursor.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/cursor.js +62 -0
- package/dist/_core/dist/agents/adapters/cursor.js.map +1 -0
- package/dist/_core/dist/agents/adapters/gemini.d.ts +11 -0
- package/dist/_core/dist/agents/adapters/gemini.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/gemini.js +68 -0
- package/dist/_core/dist/agents/adapters/gemini.js.map +1 -0
- package/dist/_core/dist/agents/adapters/human.d.ts +10 -0
- package/dist/_core/dist/agents/adapters/human.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/human.js +48 -0
- package/dist/_core/dist/agents/adapters/human.js.map +1 -0
- package/dist/_core/dist/agents/artifact-watcher.d.ts +86 -0
- package/dist/_core/dist/agents/artifact-watcher.d.ts.map +1 -0
- package/dist/_core/dist/agents/artifact-watcher.js +214 -0
- package/dist/_core/dist/agents/artifact-watcher.js.map +1 -0
- package/dist/_core/dist/agents/backup.d.ts +69 -0
- package/dist/_core/dist/agents/backup.d.ts.map +1 -0
- package/dist/_core/dist/agents/backup.js +107 -0
- package/dist/_core/dist/agents/backup.js.map +1 -0
- package/dist/_core/dist/agents/config.d.ts +36 -0
- package/dist/_core/dist/agents/config.d.ts.map +1 -0
- package/dist/_core/dist/agents/config.js +270 -0
- package/dist/_core/dist/agents/config.js.map +1 -0
- package/dist/_core/dist/agents/context-file.d.ts +35 -0
- package/dist/_core/dist/agents/context-file.d.ts.map +1 -0
- package/dist/_core/dist/agents/context-file.js +106 -0
- package/dist/_core/dist/agents/context-file.js.map +1 -0
- package/dist/_core/dist/agents/handoff.d.ts +57 -0
- package/dist/_core/dist/agents/handoff.d.ts.map +1 -0
- package/dist/_core/dist/agents/handoff.js +71 -0
- package/dist/_core/dist/agents/handoff.js.map +1 -0
- package/dist/_core/dist/agents/index.d.ts +32 -0
- package/dist/_core/dist/agents/index.d.ts.map +1 -0
- package/dist/_core/dist/agents/index.js +37 -0
- package/dist/_core/dist/agents/index.js.map +1 -0
- package/dist/_core/dist/agents/keys.d.ts +50 -0
- package/dist/_core/dist/agents/keys.d.ts.map +1 -0
- package/dist/_core/dist/agents/keys.js +91 -0
- package/dist/_core/dist/agents/keys.js.map +1 -0
- package/dist/_core/dist/agents/materialize.d.ts +37 -0
- package/dist/_core/dist/agents/materialize.d.ts.map +1 -0
- package/dist/_core/dist/agents/materialize.js +157 -0
- package/dist/_core/dist/agents/materialize.js.map +1 -0
- package/dist/_core/dist/agents/prompt-builder.d.ts +35 -0
- package/dist/_core/dist/agents/prompt-builder.d.ts.map +1 -0
- package/dist/_core/dist/agents/prompt-builder.js +261 -0
- package/dist/_core/dist/agents/prompt-builder.js.map +1 -0
- package/dist/_core/dist/agents/prompt-markers.d.ts +69 -0
- package/dist/_core/dist/agents/prompt-markers.d.ts.map +1 -0
- package/dist/_core/dist/agents/prompt-markers.js +111 -0
- package/dist/_core/dist/agents/prompt-markers.js.map +1 -0
- package/dist/_core/dist/agents/registry.d.ts +35 -0
- package/dist/_core/dist/agents/registry.d.ts.map +1 -0
- package/dist/_core/dist/agents/registry.js +102 -0
- package/dist/_core/dist/agents/registry.js.map +1 -0
- package/dist/_core/dist/agents/selector.d.ts +33 -0
- package/dist/_core/dist/agents/selector.d.ts.map +1 -0
- package/dist/_core/dist/agents/selector.js +120 -0
- package/dist/_core/dist/agents/selector.js.map +1 -0
- package/dist/_core/dist/agents/slash-materializer.d.ts +63 -0
- package/dist/_core/dist/agents/slash-materializer.d.ts.map +1 -0
- package/dist/_core/dist/agents/slash-materializer.js +131 -0
- package/dist/_core/dist/agents/slash-materializer.js.map +1 -0
- package/dist/_core/dist/agents/types.d.ts +121 -0
- package/dist/_core/dist/agents/types.d.ts.map +1 -0
- package/dist/_core/dist/agents/types.js +10 -0
- package/dist/_core/dist/agents/types.js.map +1 -0
- package/dist/_core/dist/audit/hash.d.ts +4 -0
- package/dist/_core/dist/audit/hash.d.ts.map +1 -0
- package/dist/_core/dist/audit/hash.js +12 -0
- package/dist/_core/dist/audit/hash.js.map +1 -0
- package/dist/_core/dist/audit/index.d.ts +6 -0
- package/dist/_core/dist/audit/index.d.ts.map +1 -0
- package/dist/_core/dist/audit/index.js +6 -0
- package/dist/_core/dist/audit/index.js.map +1 -0
- package/dist/_core/dist/audit/logger.d.ts +77 -0
- package/dist/_core/dist/audit/logger.d.ts.map +1 -0
- package/dist/_core/dist/audit/logger.js +93 -0
- package/dist/_core/dist/audit/logger.js.map +1 -0
- package/dist/_core/dist/audit/query.d.ts +13 -0
- package/dist/_core/dist/audit/query.d.ts.map +1 -0
- package/dist/_core/dist/audit/query.js +57 -0
- package/dist/_core/dist/audit/query.js.map +1 -0
- package/dist/_core/dist/audit/schema.d.ts +455 -0
- package/dist/_core/dist/audit/schema.d.ts.map +1 -0
- package/dist/_core/dist/audit/schema.js +341 -0
- package/dist/_core/dist/audit/schema.js.map +1 -0
- package/dist/_core/dist/audit/validate.d.ts +21 -0
- package/dist/_core/dist/audit/validate.d.ts.map +1 -0
- package/dist/_core/dist/audit/validate.js +139 -0
- package/dist/_core/dist/audit/validate.js.map +1 -0
- package/dist/_core/dist/constitution/core.d.ts +22 -0
- package/dist/_core/dist/constitution/core.d.ts.map +1 -0
- package/dist/_core/dist/constitution/core.js +102 -0
- package/dist/_core/dist/constitution/core.js.map +1 -0
- package/dist/_core/dist/constitution/index.d.ts +2 -0
- package/dist/_core/dist/constitution/index.d.ts.map +1 -0
- package/dist/_core/dist/constitution/index.js +2 -0
- package/dist/_core/dist/constitution/index.js.map +1 -0
- package/dist/_core/dist/extensions/index.d.ts +12 -0
- package/dist/_core/dist/extensions/index.d.ts.map +1 -0
- package/dist/_core/dist/extensions/index.js +12 -0
- package/dist/_core/dist/extensions/index.js.map +1 -0
- package/dist/_core/dist/extensions/integrate.d.ts +69 -0
- package/dist/_core/dist/extensions/integrate.d.ts.map +1 -0
- package/dist/_core/dist/extensions/integrate.js +181 -0
- package/dist/_core/dist/extensions/integrate.js.map +1 -0
- package/dist/_core/dist/extensions/loader.d.ts +24 -0
- package/dist/_core/dist/extensions/loader.d.ts.map +1 -0
- package/dist/_core/dist/extensions/loader.js +73 -0
- package/dist/_core/dist/extensions/loader.js.map +1 -0
- package/dist/_core/dist/extensions/manifest.d.ts +23 -0
- package/dist/_core/dist/extensions/manifest.d.ts.map +1 -0
- package/dist/_core/dist/extensions/manifest.js +176 -0
- package/dist/_core/dist/extensions/manifest.js.map +1 -0
- package/dist/_core/dist/extensions/registry.d.ts +32 -0
- package/dist/_core/dist/extensions/registry.d.ts.map +1 -0
- package/dist/_core/dist/extensions/registry.js +57 -0
- package/dist/_core/dist/extensions/registry.js.map +1 -0
- package/dist/_core/dist/extensions/resolver.d.ts +55 -0
- package/dist/_core/dist/extensions/resolver.d.ts.map +1 -0
- package/dist/_core/dist/extensions/resolver.js +143 -0
- package/dist/_core/dist/extensions/resolver.js.map +1 -0
- package/dist/_core/dist/extensions/types.d.ts +173 -0
- package/dist/_core/dist/extensions/types.d.ts.map +1 -0
- package/dist/_core/dist/extensions/types.js +83 -0
- package/dist/_core/dist/extensions/types.js.map +1 -0
- package/dist/_core/dist/frontmatter/index.d.ts +10 -0
- package/dist/_core/dist/frontmatter/index.d.ts.map +1 -0
- package/dist/_core/dist/frontmatter/index.js +24 -0
- package/dist/_core/dist/frontmatter/index.js.map +1 -0
- package/dist/_core/dist/gates/agent-gates.d.ts +16 -0
- package/dist/_core/dist/gates/agent-gates.d.ts.map +1 -0
- package/dist/_core/dist/gates/agent-gates.js +205 -0
- package/dist/_core/dist/gates/agent-gates.js.map +1 -0
- package/dist/_core/dist/gates/builtin.d.ts +18 -0
- package/dist/_core/dist/gates/builtin.d.ts.map +1 -0
- package/dist/_core/dist/gates/builtin.js +860 -0
- package/dist/_core/dist/gates/builtin.js.map +1 -0
- package/dist/_core/dist/gates/index.d.ts +7 -0
- package/dist/_core/dist/gates/index.d.ts.map +1 -0
- package/dist/_core/dist/gates/index.js +7 -0
- package/dist/_core/dist/gates/index.js.map +1 -0
- package/dist/_core/dist/gates/m7-gates.d.ts +17 -0
- package/dist/_core/dist/gates/m7-gates.d.ts.map +1 -0
- package/dist/_core/dist/gates/m7-gates.js +309 -0
- package/dist/_core/dist/gates/m7-gates.js.map +1 -0
- package/dist/_core/dist/gates/phase-gates.d.ts +18 -0
- package/dist/_core/dist/gates/phase-gates.d.ts.map +1 -0
- package/dist/_core/dist/gates/phase-gates.js +275 -0
- package/dist/_core/dist/gates/phase-gates.js.map +1 -0
- package/dist/_core/dist/gates/runner.d.ts +4 -0
- package/dist/_core/dist/gates/runner.d.ts.map +1 -0
- package/dist/_core/dist/gates/runner.js +64 -0
- package/dist/_core/dist/gates/runner.js.map +1 -0
- package/dist/_core/dist/gates/types.d.ts +36 -0
- package/dist/_core/dist/gates/types.d.ts.map +1 -0
- package/dist/_core/dist/gates/types.js +2 -0
- package/dist/_core/dist/gates/types.js.map +1 -0
- package/dist/_core/dist/hooks/index.d.ts +4 -0
- package/dist/_core/dist/hooks/index.d.ts.map +1 -0
- package/dist/_core/dist/hooks/index.js +4 -0
- package/dist/_core/dist/hooks/index.js.map +1 -0
- package/dist/_core/dist/hooks/runner.d.ts +28 -0
- package/dist/_core/dist/hooks/runner.d.ts.map +1 -0
- package/dist/_core/dist/hooks/runner.js +294 -0
- package/dist/_core/dist/hooks/runner.js.map +1 -0
- package/dist/_core/dist/hooks/runtime.d.ts +65 -0
- package/dist/_core/dist/hooks/runtime.d.ts.map +1 -0
- package/dist/_core/dist/hooks/runtime.js +212 -0
- package/dist/_core/dist/hooks/runtime.js.map +1 -0
- package/dist/_core/dist/hooks/types.d.ts +36 -0
- package/dist/_core/dist/hooks/types.d.ts.map +1 -0
- package/dist/_core/dist/hooks/types.js +23 -0
- package/dist/_core/dist/hooks/types.js.map +1 -0
- package/dist/_core/dist/index.d.ts +21 -0
- package/dist/_core/dist/index.d.ts.map +1 -0
- package/dist/_core/dist/index.js +20 -0
- package/dist/_core/dist/index.js.map +1 -0
- package/dist/_core/dist/manifest/index.d.ts +119 -0
- package/dist/_core/dist/manifest/index.d.ts.map +1 -0
- package/dist/_core/dist/manifest/index.js +125 -0
- package/dist/_core/dist/manifest/index.js.map +1 -0
- package/dist/_core/dist/markers/index.d.ts +47 -0
- package/dist/_core/dist/markers/index.d.ts.map +1 -0
- package/dist/_core/dist/markers/index.js +97 -0
- package/dist/_core/dist/markers/index.js.map +1 -0
- package/dist/_core/dist/mcp/config.d.ts +19 -0
- package/dist/_core/dist/mcp/config.d.ts.map +1 -0
- package/dist/_core/dist/mcp/config.js +114 -0
- package/dist/_core/dist/mcp/config.js.map +1 -0
- package/dist/_core/dist/mcp/index.d.ts +9 -0
- package/dist/_core/dist/mcp/index.d.ts.map +1 -0
- package/dist/_core/dist/mcp/index.js +8 -0
- package/dist/_core/dist/mcp/index.js.map +1 -0
- package/dist/_core/dist/mcp/materializer.d.ts +40 -0
- package/dist/_core/dist/mcp/materializer.d.ts.map +1 -0
- package/dist/_core/dist/mcp/materializer.js +161 -0
- package/dist/_core/dist/mcp/materializer.js.map +1 -0
- package/dist/_core/dist/mcp/targets.d.ts +37 -0
- package/dist/_core/dist/mcp/targets.d.ts.map +1 -0
- package/dist/_core/dist/mcp/targets.js +56 -0
- package/dist/_core/dist/mcp/targets.js.map +1 -0
- package/dist/_core/dist/mcp/types.d.ts +34 -0
- package/dist/_core/dist/mcp/types.d.ts.map +1 -0
- package/dist/_core/dist/mcp/types.js +8 -0
- package/dist/_core/dist/mcp/types.js.map +1 -0
- package/dist/_core/dist/models/analyze.d.ts +131 -0
- package/dist/_core/dist/models/analyze.d.ts.map +1 -0
- package/dist/_core/dist/models/analyze.js +301 -0
- package/dist/_core/dist/models/analyze.js.map +1 -0
- package/dist/_core/dist/models/checklist.d.ts +113 -0
- package/dist/_core/dist/models/checklist.d.ts.map +1 -0
- package/dist/_core/dist/models/checklist.js +159 -0
- package/dist/_core/dist/models/checklist.js.map +1 -0
- package/dist/_core/dist/models/clarify.d.ts +116 -0
- package/dist/_core/dist/models/clarify.d.ts.map +1 -0
- package/dist/_core/dist/models/clarify.js +166 -0
- package/dist/_core/dist/models/clarify.js.map +1 -0
- package/dist/_core/dist/models/impl-log.d.ts +64 -0
- package/dist/_core/dist/models/impl-log.d.ts.map +1 -0
- package/dist/_core/dist/models/impl-log.js +137 -0
- package/dist/_core/dist/models/impl-log.js.map +1 -0
- package/dist/_core/dist/models/index.d.ts +8 -0
- package/dist/_core/dist/models/index.d.ts.map +1 -0
- package/dist/_core/dist/models/index.js +8 -0
- package/dist/_core/dist/models/index.js.map +1 -0
- package/dist/_core/dist/models/plan.d.ts +24 -0
- package/dist/_core/dist/models/plan.d.ts.map +1 -0
- package/dist/_core/dist/models/plan.js +15 -0
- package/dist/_core/dist/models/plan.js.map +1 -0
- package/dist/_core/dist/models/spec.d.ts +23 -0
- package/dist/_core/dist/models/spec.d.ts.map +1 -0
- package/dist/_core/dist/models/spec.js +22 -0
- package/dist/_core/dist/models/spec.js.map +1 -0
- package/dist/_core/dist/models/tasks.d.ts +33 -0
- package/dist/_core/dist/models/tasks.d.ts.map +1 -0
- package/dist/_core/dist/models/tasks.js +78 -0
- package/dist/_core/dist/models/tasks.js.map +1 -0
- package/dist/_core/dist/presets/gates.d.ts +9 -0
- package/dist/_core/dist/presets/gates.d.ts.map +1 -0
- package/dist/_core/dist/presets/gates.js +173 -0
- package/dist/_core/dist/presets/gates.js.map +1 -0
- package/dist/_core/dist/presets/index.d.ts +10 -0
- package/dist/_core/dist/presets/index.d.ts.map +1 -0
- package/dist/_core/dist/presets/index.js +7 -0
- package/dist/_core/dist/presets/index.js.map +1 -0
- package/dist/_core/dist/presets/loader.d.ts +56 -0
- package/dist/_core/dist/presets/loader.d.ts.map +1 -0
- package/dist/_core/dist/presets/loader.js +216 -0
- package/dist/_core/dist/presets/loader.js.map +1 -0
- package/dist/_core/dist/presets/mobile-opinionated.d.ts +3 -0
- package/dist/_core/dist/presets/mobile-opinionated.d.ts.map +1 -0
- package/dist/_core/dist/presets/mobile-opinionated.js +78 -0
- package/dist/_core/dist/presets/mobile-opinionated.js.map +1 -0
- package/dist/_core/dist/presets/registry.d.ts +5 -0
- package/dist/_core/dist/presets/registry.d.ts.map +1 -0
- package/dist/_core/dist/presets/registry.js +14 -0
- package/dist/_core/dist/presets/registry.js.map +1 -0
- package/dist/_core/dist/presets/renderer.d.ts +5 -0
- package/dist/_core/dist/presets/renderer.d.ts.map +1 -0
- package/dist/_core/dist/presets/renderer.js +37 -0
- package/dist/_core/dist/presets/renderer.js.map +1 -0
- package/dist/_core/dist/presets/stacking.d.ts +29 -0
- package/dist/_core/dist/presets/stacking.d.ts.map +1 -0
- package/dist/_core/dist/presets/stacking.js +91 -0
- package/dist/_core/dist/presets/stacking.js.map +1 -0
- package/dist/_core/dist/presets/types.d.ts +22 -0
- package/dist/_core/dist/presets/types.d.ts.map +1 -0
- package/dist/_core/dist/presets/types.js +2 -0
- package/dist/_core/dist/presets/types.js.map +1 -0
- package/dist/_core/dist/prompts/audit-log.d.ts +73 -0
- package/dist/_core/dist/prompts/audit-log.d.ts.map +1 -0
- package/dist/_core/dist/prompts/audit-log.js +73 -0
- package/dist/_core/dist/prompts/audit-log.js.map +1 -0
- package/dist/_core/dist/prompts/index.d.ts +9 -0
- package/dist/_core/dist/prompts/index.d.ts.map +1 -0
- package/dist/_core/dist/prompts/index.js +7 -0
- package/dist/_core/dist/prompts/index.js.map +1 -0
- package/dist/_core/dist/prompts/renderer.d.ts +73 -0
- package/dist/_core/dist/prompts/renderer.d.ts.map +1 -0
- package/dist/_core/dist/prompts/renderer.js +179 -0
- package/dist/_core/dist/prompts/renderer.js.map +1 -0
- package/dist/_core/dist/prompts/resumption.d.ts +59 -0
- package/dist/_core/dist/prompts/resumption.d.ts.map +1 -0
- package/dist/_core/dist/prompts/resumption.js +149 -0
- package/dist/_core/dist/prompts/resumption.js.map +1 -0
- package/dist/_core/dist/skills/config.d.ts +27 -0
- package/dist/_core/dist/skills/config.d.ts.map +1 -0
- package/dist/_core/dist/skills/config.js +102 -0
- package/dist/_core/dist/skills/config.js.map +1 -0
- package/dist/_core/dist/skills/index.d.ts +9 -0
- package/dist/_core/dist/skills/index.d.ts.map +1 -0
- package/dist/_core/dist/skills/index.js +8 -0
- package/dist/_core/dist/skills/index.js.map +1 -0
- package/dist/_core/dist/skills/materializer.d.ts +45 -0
- package/dist/_core/dist/skills/materializer.d.ts.map +1 -0
- package/dist/_core/dist/skills/materializer.js +97 -0
- package/dist/_core/dist/skills/materializer.js.map +1 -0
- package/dist/_core/dist/skills/registry.d.ts +18 -0
- package/dist/_core/dist/skills/registry.d.ts.map +1 -0
- package/dist/_core/dist/skills/registry.js +36 -0
- package/dist/_core/dist/skills/registry.js.map +1 -0
- package/dist/_core/dist/skills/types.d.ts +39 -0
- package/dist/_core/dist/skills/types.d.ts.map +1 -0
- package/dist/_core/dist/skills/types.js +13 -0
- package/dist/_core/dist/skills/types.js.map +1 -0
- package/dist/_core/dist/state/feature.d.ts +58 -0
- package/dist/_core/dist/state/feature.d.ts.map +1 -0
- package/dist/_core/dist/state/feature.js +81 -0
- package/dist/_core/dist/state/feature.js.map +1 -0
- package/dist/_core/dist/state/index.d.ts +8 -0
- package/dist/_core/dist/state/index.d.ts.map +1 -0
- package/dist/_core/dist/state/index.js +6 -0
- package/dist/_core/dist/state/index.js.map +1 -0
- package/dist/_core/dist/state/init-options.d.ts +60 -0
- package/dist/_core/dist/state/init-options.d.ts.map +1 -0
- package/dist/_core/dist/state/init-options.js +74 -0
- package/dist/_core/dist/state/init-options.js.map +1 -0
- package/dist/_core/dist/template/engine.d.ts +7 -0
- package/dist/_core/dist/template/engine.d.ts.map +1 -0
- package/dist/_core/dist/template/engine.js +86 -0
- package/dist/_core/dist/template/engine.js.map +1 -0
- package/dist/_core/dist/template/helpers.d.ts +5 -0
- package/dist/_core/dist/template/helpers.d.ts.map +1 -0
- package/dist/_core/dist/template/helpers.js +59 -0
- package/dist/_core/dist/template/helpers.js.map +1 -0
- package/dist/_core/dist/template/index.d.ts +6 -0
- package/dist/_core/dist/template/index.d.ts.map +1 -0
- package/dist/_core/dist/template/index.js +6 -0
- package/dist/_core/dist/template/index.js.map +1 -0
- package/dist/_core/dist/template/loader.d.ts +36 -0
- package/dist/_core/dist/template/loader.d.ts.map +1 -0
- package/dist/_core/dist/template/loader.js +62 -0
- package/dist/_core/dist/template/loader.js.map +1 -0
- package/dist/_core/dist/template/parser.d.ts +3 -0
- package/dist/_core/dist/template/parser.d.ts.map +1 -0
- package/dist/_core/dist/template/parser.js +234 -0
- package/dist/_core/dist/template/parser.js.map +1 -0
- package/dist/_core/dist/template/types.d.ts +40 -0
- package/dist/_core/dist/template/types.d.ts.map +1 -0
- package/dist/_core/dist/template/types.js +14 -0
- package/dist/_core/dist/template/types.js.map +1 -0
- package/dist/_core/dist/verify/a11y.d.ts +36 -0
- package/dist/_core/dist/verify/a11y.d.ts.map +1 -0
- package/dist/_core/dist/verify/a11y.js +153 -0
- package/dist/_core/dist/verify/a11y.js.map +1 -0
- package/dist/_core/dist/verify/architecture.d.ts +37 -0
- package/dist/_core/dist/verify/architecture.d.ts.map +1 -0
- package/dist/_core/dist/verify/architecture.js +113 -0
- package/dist/_core/dist/verify/architecture.js.map +1 -0
- package/dist/_core/dist/verify/index.d.ts +10 -0
- package/dist/_core/dist/verify/index.d.ts.map +1 -0
- package/dist/_core/dist/verify/index.js +10 -0
- package/dist/_core/dist/verify/index.js.map +1 -0
- package/dist/_core/dist/verify/os-matrix.d.ts +35 -0
- package/dist/_core/dist/verify/os-matrix.d.ts.map +1 -0
- package/dist/_core/dist/verify/os-matrix.js +104 -0
- package/dist/_core/dist/verify/os-matrix.js.map +1 -0
- package/dist/_core/dist/verify/perf.d.ts +43 -0
- package/dist/_core/dist/verify/perf.d.ts.map +1 -0
- package/dist/_core/dist/verify/perf.js +69 -0
- package/dist/_core/dist/verify/perf.js.map +1 -0
- package/dist/_core/dist/verify/stores.d.ts +38 -0
- package/dist/_core/dist/verify/stores.d.ts.map +1 -0
- package/dist/_core/dist/verify/stores.js +57 -0
- package/dist/_core/dist/verify/stores.js.map +1 -0
- package/dist/_core/dist/version.d.ts +8 -0
- package/dist/_core/dist/version.d.ts.map +1 -0
- package/dist/_core/dist/version.js +11 -0
- package/dist/_core/dist/version.js.map +1 -0
- package/dist/_core/dist/workflows/bundled.d.ts +32 -0
- package/dist/_core/dist/workflows/bundled.d.ts.map +1 -0
- package/dist/_core/dist/workflows/bundled.js +254 -0
- package/dist/_core/dist/workflows/bundled.js.map +1 -0
- package/dist/_core/dist/workflows/engine.d.ts +74 -0
- package/dist/_core/dist/workflows/engine.d.ts.map +1 -0
- package/dist/_core/dist/workflows/engine.js +574 -0
- package/dist/_core/dist/workflows/engine.js.map +1 -0
- package/dist/_core/dist/workflows/expressions.d.ts +48 -0
- package/dist/_core/dist/workflows/expressions.d.ts.map +1 -0
- package/dist/_core/dist/workflows/expressions.js +336 -0
- package/dist/_core/dist/workflows/expressions.js.map +1 -0
- package/dist/_core/dist/workflows/index.d.ts +16 -0
- package/dist/_core/dist/workflows/index.d.ts.map +1 -0
- package/dist/_core/dist/workflows/index.js +15 -0
- package/dist/_core/dist/workflows/index.js.map +1 -0
- package/dist/_core/dist/workflows/parser.d.ts +38 -0
- package/dist/_core/dist/workflows/parser.d.ts.map +1 -0
- package/dist/_core/dist/workflows/parser.js +386 -0
- package/dist/_core/dist/workflows/parser.js.map +1 -0
- package/dist/_core/dist/workflows/sdd-flow.d.ts +85 -0
- package/dist/_core/dist/workflows/sdd-flow.d.ts.map +1 -0
- package/dist/_core/dist/workflows/sdd-flow.js +269 -0
- package/dist/_core/dist/workflows/sdd-flow.js.map +1 -0
- package/dist/_core/dist/workflows/types.d.ts +285 -0
- package/dist/_core/dist/workflows/types.d.ts.map +1 -0
- package/dist/_core/dist/workflows/types.js +13 -0
- package/dist/_core/dist/workflows/types.js.map +1 -0
- package/dist/_core/package.json +6 -0
- package/dist/_core/templates/constitution.md.hbs +46 -0
- package/dist/_core/templates/ghaWorkflow.yml.hbs +58 -0
- package/dist/_core/templates/hotfix.md.hbs +39 -0
- package/dist/_core/templates/plan.md.hbs +212 -0
- package/dist/_core/templates/preCommitHook.sh.hbs +30 -0
- package/dist/_core/templates/prePushHook.sh.hbs +45 -0
- package/dist/_core/templates/raptor.yml.hbs +24 -0
- package/dist/_core/templates/spec.md.hbs +127 -0
- package/dist/_core/templates/tasks.md.hbs +71 -0
- package/dist/commands/add-agent.d.ts +22 -0
- package/dist/commands/add-agent.d.ts.map +1 -0
- package/dist/commands/add-agent.js +121 -0
- package/dist/commands/add-agent.js.map +1 -0
- package/dist/commands/add-extension.d.ts +18 -0
- package/dist/commands/add-extension.d.ts.map +1 -0
- package/dist/commands/add-extension.js +83 -0
- package/dist/commands/add-extension.js.map +1 -0
- package/dist/commands/analyze.d.ts +18 -0
- package/dist/commands/analyze.d.ts.map +1 -0
- package/dist/commands/analyze.js +323 -0
- package/dist/commands/analyze.js.map +1 -0
- package/dist/commands/approve.d.ts +14 -0
- package/dist/commands/approve.d.ts.map +1 -0
- package/dist/commands/approve.js +116 -0
- package/dist/commands/approve.js.map +1 -0
- package/dist/commands/audit/query.d.ts +23 -0
- package/dist/commands/audit/query.d.ts.map +1 -0
- package/dist/commands/audit/query.js +118 -0
- package/dist/commands/audit/query.js.map +1 -0
- package/dist/commands/audit/show.d.ts +17 -0
- package/dist/commands/audit/show.d.ts.map +1 -0
- package/dist/commands/audit/show.js +53 -0
- package/dist/commands/audit/show.js.map +1 -0
- package/dist/commands/checklist.d.ts +17 -0
- package/dist/commands/checklist.d.ts.map +1 -0
- package/dist/commands/checklist.js +255 -0
- package/dist/commands/checklist.js.map +1 -0
- package/dist/commands/clarify.d.ts +17 -0
- package/dist/commands/clarify.d.ts.map +1 -0
- package/dist/commands/clarify.js +254 -0
- package/dist/commands/clarify.js.map +1 -0
- package/dist/commands/doctor.d.ts +8 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +435 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/extension/add.d.ts +15 -0
- package/dist/commands/extension/add.d.ts.map +1 -0
- package/dist/commands/extension/add.js +93 -0
- package/dist/commands/extension/add.js.map +1 -0
- package/dist/commands/extension/info.d.ts +13 -0
- package/dist/commands/extension/info.d.ts.map +1 -0
- package/dist/commands/extension/info.js +75 -0
- package/dist/commands/extension/info.js.map +1 -0
- package/dist/commands/extension/list.d.ts +10 -0
- package/dist/commands/extension/list.d.ts.map +1 -0
- package/dist/commands/extension/list.js +71 -0
- package/dist/commands/extension/list.js.map +1 -0
- package/dist/commands/extension/remove.d.ts +14 -0
- package/dist/commands/extension/remove.d.ts.map +1 -0
- package/dist/commands/extension/remove.js +49 -0
- package/dist/commands/extension/remove.js.map +1 -0
- package/dist/commands/gate/approve.d.ts +15 -0
- package/dist/commands/gate/approve.d.ts.map +1 -0
- package/dist/commands/gate/approve.js +106 -0
- package/dist/commands/gate/approve.js.map +1 -0
- package/dist/commands/gate/list.d.ts +6 -0
- package/dist/commands/gate/list.d.ts.map +1 -0
- package/dist/commands/gate/list.js +38 -0
- package/dist/commands/gate/list.js.map +1 -0
- package/dist/commands/gate/skip.d.ts +14 -0
- package/dist/commands/gate/skip.d.ts.map +1 -0
- package/dist/commands/gate/skip.js +95 -0
- package/dist/commands/gate/skip.js.map +1 -0
- package/dist/commands/hook/list.d.ts +11 -0
- package/dist/commands/hook/list.d.ts.map +1 -0
- package/dist/commands/hook/list.js +152 -0
- package/dist/commands/hook/list.js.map +1 -0
- package/dist/commands/hook/run.d.ts +16 -0
- package/dist/commands/hook/run.d.ts.map +1 -0
- package/dist/commands/hook/run.js +74 -0
- package/dist/commands/hook/run.js.map +1 -0
- package/dist/commands/hotfix.d.ts +21 -0
- package/dist/commands/hotfix.d.ts.map +1 -0
- package/dist/commands/hotfix.js +216 -0
- package/dist/commands/hotfix.js.map +1 -0
- package/dist/commands/implement.d.ts +19 -0
- package/dist/commands/implement.d.ts.map +1 -0
- package/dist/commands/implement.js +282 -0
- package/dist/commands/implement.js.map +1 -0
- package/dist/commands/init.d.ts +43 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +465 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/list-agents.d.ts +12 -0
- package/dist/commands/list-agents.d.ts.map +1 -0
- package/dist/commands/list-agents.js +55 -0
- package/dist/commands/list-agents.js.map +1 -0
- package/dist/commands/mcp/add.d.ts +21 -0
- package/dist/commands/mcp/add.d.ts.map +1 -0
- package/dist/commands/mcp/add.js +119 -0
- package/dist/commands/mcp/add.js.map +1 -0
- package/dist/commands/mcp/list.d.ts +10 -0
- package/dist/commands/mcp/list.d.ts.map +1 -0
- package/dist/commands/mcp/list.js +54 -0
- package/dist/commands/mcp/list.js.map +1 -0
- package/dist/commands/mcp/remove.d.ts +10 -0
- package/dist/commands/mcp/remove.d.ts.map +1 -0
- package/dist/commands/mcp/remove.js +53 -0
- package/dist/commands/mcp/remove.js.map +1 -0
- package/dist/commands/mcp/sync.d.ts +7 -0
- package/dist/commands/mcp/sync.d.ts.map +1 -0
- package/dist/commands/mcp/sync.js +31 -0
- package/dist/commands/mcp/sync.js.map +1 -0
- package/dist/commands/new.d.ts +19 -0
- package/dist/commands/new.d.ts.map +1 -0
- package/dist/commands/new.js +306 -0
- package/dist/commands/new.js.map +1 -0
- package/dist/commands/plan.d.ts +17 -0
- package/dist/commands/plan.d.ts.map +1 -0
- package/dist/commands/plan.js +200 -0
- package/dist/commands/plan.js.map +1 -0
- package/dist/commands/preset/add.d.ts +13 -0
- package/dist/commands/preset/add.d.ts.map +1 -0
- package/dist/commands/preset/add.js +66 -0
- package/dist/commands/preset/add.js.map +1 -0
- package/dist/commands/preset/info.d.ts +13 -0
- package/dist/commands/preset/info.d.ts.map +1 -0
- package/dist/commands/preset/info.js +80 -0
- package/dist/commands/preset/info.js.map +1 -0
- package/dist/commands/preset/list.d.ts +10 -0
- package/dist/commands/preset/list.d.ts.map +1 -0
- package/dist/commands/preset/list.js +63 -0
- package/dist/commands/preset/list.js.map +1 -0
- package/dist/commands/preset/remove.d.ts +14 -0
- package/dist/commands/preset/remove.d.ts.map +1 -0
- package/dist/commands/preset/remove.js +60 -0
- package/dist/commands/preset/remove.js.map +1 -0
- package/dist/commands/repair/constitution.d.ts +11 -0
- package/dist/commands/repair/constitution.d.ts.map +1 -0
- package/dist/commands/repair/constitution.js +117 -0
- package/dist/commands/repair/constitution.js.map +1 -0
- package/dist/commands/resync.d.ts +22 -0
- package/dist/commands/resync.d.ts.map +1 -0
- package/dist/commands/resync.js +103 -0
- package/dist/commands/resync.js.map +1 -0
- package/dist/commands/skill/add.d.ts +19 -0
- package/dist/commands/skill/add.d.ts.map +1 -0
- package/dist/commands/skill/add.js +107 -0
- package/dist/commands/skill/add.js.map +1 -0
- package/dist/commands/skill/list.d.ts +10 -0
- package/dist/commands/skill/list.d.ts.map +1 -0
- package/dist/commands/skill/list.js +56 -0
- package/dist/commands/skill/list.js.map +1 -0
- package/dist/commands/skill/remove.d.ts +10 -0
- package/dist/commands/skill/remove.d.ts.map +1 -0
- package/dist/commands/skill/remove.js +47 -0
- package/dist/commands/skill/remove.js.map +1 -0
- package/dist/commands/skill/sync.d.ts +7 -0
- package/dist/commands/skill/sync.d.ts.map +1 -0
- package/dist/commands/skill/sync.js +30 -0
- package/dist/commands/skill/sync.js.map +1 -0
- package/dist/commands/status.d.ts +17 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +265 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/tasks.d.ts +16 -0
- package/dist/commands/tasks.d.ts.map +1 -0
- package/dist/commands/tasks.js +176 -0
- package/dist/commands/tasks.js.map +1 -0
- package/dist/commands/trace.d.ts +16 -0
- package/dist/commands/trace.d.ts.map +1 -0
- package/dist/commands/trace.js +113 -0
- package/dist/commands/trace.js.map +1 -0
- package/dist/commands/upgrade.d.ts +20 -0
- package/dist/commands/upgrade.d.ts.map +1 -0
- package/dist/commands/upgrade.js +178 -0
- package/dist/commands/upgrade.js.map +1 -0
- package/dist/commands/verify/a11y.d.ts +15 -0
- package/dist/commands/verify/a11y.d.ts.map +1 -0
- package/dist/commands/verify/a11y.js +121 -0
- package/dist/commands/verify/a11y.js.map +1 -0
- package/dist/commands/verify/architecture.d.ts +11 -0
- package/dist/commands/verify/architecture.d.ts.map +1 -0
- package/dist/commands/verify/architecture.js +71 -0
- package/dist/commands/verify/architecture.js.map +1 -0
- package/dist/commands/verify/audit.d.ts +18 -0
- package/dist/commands/verify/audit.d.ts.map +1 -0
- package/dist/commands/verify/audit.js +108 -0
- package/dist/commands/verify/audit.js.map +1 -0
- package/dist/commands/verify/constitution.d.ts +10 -0
- package/dist/commands/verify/constitution.d.ts.map +1 -0
- package/dist/commands/verify/constitution.js +91 -0
- package/dist/commands/verify/constitution.js.map +1 -0
- package/dist/commands/verify/os-matrix.d.ts +14 -0
- package/dist/commands/verify/os-matrix.d.ts.map +1 -0
- package/dist/commands/verify/os-matrix.js +108 -0
- package/dist/commands/verify/os-matrix.js.map +1 -0
- package/dist/commands/verify/perf.d.ts +17 -0
- package/dist/commands/verify/perf.d.ts.map +1 -0
- package/dist/commands/verify/perf.js +106 -0
- package/dist/commands/verify/perf.js.map +1 -0
- package/dist/commands/verify/stores.d.ts +14 -0
- package/dist/commands/verify/stores.d.ts.map +1 -0
- package/dist/commands/verify/stores.js +98 -0
- package/dist/commands/verify/stores.js.map +1 -0
- package/dist/commands/verify.d.ts +14 -0
- package/dist/commands/verify.d.ts.map +1 -0
- package/dist/commands/verify.js +97 -0
- package/dist/commands/verify.js.map +1 -0
- package/dist/commands/workflow/catalog.d.ts +11 -0
- package/dist/commands/workflow/catalog.d.ts.map +1 -0
- package/dist/commands/workflow/catalog.js +164 -0
- package/dist/commands/workflow/catalog.js.map +1 -0
- package/dist/commands/workflow/list.d.ts +7 -0
- package/dist/commands/workflow/list.d.ts.map +1 -0
- package/dist/commands/workflow/list.js +50 -0
- package/dist/commands/workflow/list.js.map +1 -0
- package/dist/commands/workflow/resume.d.ts +13 -0
- package/dist/commands/workflow/resume.d.ts.map +1 -0
- package/dist/commands/workflow/resume.js +126 -0
- package/dist/commands/workflow/resume.js.map +1 -0
- package/dist/commands/workflow/run.d.ts +14 -0
- package/dist/commands/workflow/run.d.ts.map +1 -0
- package/dist/commands/workflow/run.js +139 -0
- package/dist/commands/workflow/run.js.map +1 -0
- package/dist/commands/workflow/status.d.ts +10 -0
- package/dist/commands/workflow/status.d.ts.map +1 -0
- package/dist/commands/workflow/status.js +86 -0
- package/dist/commands/workflow/status.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/shared/agents.d.ts +12 -0
- package/dist/shared/agents.d.ts.map +1 -0
- package/dist/shared/agents.js +31 -0
- package/dist/shared/agents.js.map +1 -0
- package/dist/shared/artifact-io.d.ts +54 -0
- package/dist/shared/artifact-io.d.ts.map +1 -0
- package/dist/shared/artifact-io.js +71 -0
- package/dist/shared/artifact-io.js.map +1 -0
- package/dist/shared/feature-prompt.d.ts +18 -0
- package/dist/shared/feature-prompt.d.ts.map +1 -0
- package/dist/shared/feature-prompt.js +21 -0
- package/dist/shared/feature-prompt.js.map +1 -0
- package/dist/shared/hooks.d.ts +7 -0
- package/dist/shared/hooks.d.ts.map +1 -0
- package/dist/shared/hooks.js +52 -0
- package/dist/shared/hooks.js.map +1 -0
- package/dist/shared/mcp.d.ts +9 -0
- package/dist/shared/mcp.d.ts.map +1 -0
- package/dist/shared/mcp.js +15 -0
- package/dist/shared/mcp.js.map +1 -0
- package/dist/shared/project.d.ts +42 -0
- package/dist/shared/project.d.ts.map +1 -0
- package/dist/shared/project.js +98 -0
- package/dist/shared/project.js.map +1 -0
- package/dist/shared/workflow-resolver.d.ts +19 -0
- package/dist/shared/workflow-resolver.d.ts.map +1 -0
- package/dist/shared/workflow-resolver.js +71 -0
- package/dist/shared/workflow-resolver.js.map +1 -0
- package/dist/workflow/args-builder.d.ts +31 -0
- package/dist/workflow/args-builder.d.ts.map +1 -0
- package/dist/workflow/args-builder.js +110 -0
- package/dist/workflow/args-builder.js.map +1 -0
- package/dist/workflow/executor.d.ts +18 -0
- package/dist/workflow/executor.d.ts.map +1 -0
- package/dist/workflow/executor.js +112 -0
- package/dist/workflow/executor.js.map +1 -0
- package/extensions/git/commands/rpt.git.feature.md +85 -0
- package/extensions/git/extension.yml +47 -0
- package/package.json +58 -0
- package/scripts/bash/check-prerequisites.sh +149 -0
- package/scripts/bash/common.sh +389 -0
- package/scripts/bash/create-new-feature.sh +164 -0
- package/scripts/bash/setup-plan.sh +113 -0
- package/scripts/check-naming.sh +138 -0
- package/scripts/check-prompts.sh +165 -0
- package/scripts/check-tasks.sh +166 -0
- package/scripts/powershell/check-prerequisites.ps1 +117 -0
- package/scripts/powershell/common.ps1 +328 -0
- package/scripts/powershell/create-new-feature.ps1 +138 -0
- package/scripts/powershell/setup-plan.ps1 +96 -0
- package/scripts/prepare-npm.mjs +157 -0
- package/templates/checklist-template.md +103 -0
- package/templates/commands/analyze.md +103 -0
- package/templates/commands/checklist.md +87 -0
- package/templates/commands/clarify.md +85 -0
- package/templates/commands/constitution.md +126 -0
- package/templates/commands/implement.md +117 -0
- package/templates/commands/plan.md +125 -0
- package/templates/commands/specify.md +127 -0
- package/templates/commands/tasks.md +98 -0
- package/templates/commands/taskstoissues.md +81 -0
- package/templates/constitution-template.md +48 -0
- package/templates/plan-template.md +150 -0
- package/templates/spec-template.md +116 -0
- package/templates/tasks-template.md +77 -0
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Accessibility verification — STATIC analysis of UI source.
|
|
3
|
+
*
|
|
4
|
+
* This is the "verification edge" for M3: instead of only trusting the
|
|
5
|
+
* `a11y` declaration in spec.md frontmatter, this actually scans the rendered
|
|
6
|
+
* UI source and flags interactive elements that are not screen-reader
|
|
7
|
+
* operable. Framework focus: React Native (Pressable/Touchable/Button,
|
|
8
|
+
* Image, TextInput), but the heuristics are plain JSX so they generalize.
|
|
9
|
+
*
|
|
10
|
+
* Heuristic, not a full AST: it captures each opening tag's prop block (up to
|
|
11
|
+
* the first `>`) and checks for accessibility props. Good enough for a lint;
|
|
12
|
+
* it never executes code.
|
|
13
|
+
*/
|
|
14
|
+
const INTERACTIVE = [
|
|
15
|
+
"Pressable",
|
|
16
|
+
"TouchableOpacity",
|
|
17
|
+
"TouchableHighlight",
|
|
18
|
+
"TouchableWithoutFeedback",
|
|
19
|
+
"TouchableNativeFeedback",
|
|
20
|
+
];
|
|
21
|
+
function hasA11yLabelOrRole(props) {
|
|
22
|
+
return /\baccessibilityLabel\b|\baccessibilityRole\b|\baccessibilityLabelledBy\b|\baria-label\b/.test(props);
|
|
23
|
+
}
|
|
24
|
+
function isHiddenFromA11y(props) {
|
|
25
|
+
return (/\baccessibilityElementsHidden\b/.test(props) ||
|
|
26
|
+
/importantForAccessibility\s*=\s*["'{]?\s*no/.test(props) ||
|
|
27
|
+
/\baccessible\s*=\s*\{?\s*false\b/.test(props));
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Extract a JSX opening tag's prop block starting right after the tag name.
|
|
31
|
+
* Scans to the `>` that closes the tag at bracket-depth 0, so `=>` arrow
|
|
32
|
+
* functions, JSX expressions and `>` inside `{}`/`()`/`[]`/strings don't end
|
|
33
|
+
* the tag prematurely. Returns null if no closing `>` is found.
|
|
34
|
+
*/
|
|
35
|
+
function extractTagProps(content, from) {
|
|
36
|
+
let curly = 0;
|
|
37
|
+
let paren = 0;
|
|
38
|
+
let brack = 0;
|
|
39
|
+
let str = null;
|
|
40
|
+
for (let i = from; i < content.length; i++) {
|
|
41
|
+
const c = content[i];
|
|
42
|
+
if (str) {
|
|
43
|
+
if (c === str && content[i - 1] !== "\\")
|
|
44
|
+
str = null;
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
if (c === '"' || c === "'" || c === "`") {
|
|
48
|
+
str = c;
|
|
49
|
+
}
|
|
50
|
+
else if (c === "{")
|
|
51
|
+
curly++;
|
|
52
|
+
else if (c === "}")
|
|
53
|
+
curly--;
|
|
54
|
+
else if (c === "(")
|
|
55
|
+
paren++;
|
|
56
|
+
else if (c === ")")
|
|
57
|
+
paren--;
|
|
58
|
+
else if (c === "[")
|
|
59
|
+
brack++;
|
|
60
|
+
else if (c === "]")
|
|
61
|
+
brack--;
|
|
62
|
+
else if (c === ">" && curly === 0 && paren === 0 && brack === 0) {
|
|
63
|
+
return content.slice(from, i);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
return null;
|
|
67
|
+
}
|
|
68
|
+
function lineOf(content, index) {
|
|
69
|
+
let line = 1;
|
|
70
|
+
for (let i = 0; i < index && i < content.length; i++) {
|
|
71
|
+
if (content[i] === "\n")
|
|
72
|
+
line++;
|
|
73
|
+
}
|
|
74
|
+
return line;
|
|
75
|
+
}
|
|
76
|
+
/** Scan a single source file's content for a11y violations. */
|
|
77
|
+
export function scanA11ySource(file, content) {
|
|
78
|
+
const findings = [];
|
|
79
|
+
const emit = (rule, severity, element, index, message) => {
|
|
80
|
+
findings.push({ rule, severity, file, line: lineOf(content, index), element, message });
|
|
81
|
+
};
|
|
82
|
+
const scanTag = (tag, onMatch) => {
|
|
83
|
+
const re = new RegExp(`<${tag}\\b`, "g");
|
|
84
|
+
let m;
|
|
85
|
+
while ((m = re.exec(content)) !== null) {
|
|
86
|
+
const props = extractTagProps(content, re.lastIndex);
|
|
87
|
+
if (props !== null)
|
|
88
|
+
onMatch(props, m.index);
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
// A11Y-INTERACTIVE: touchables without a label/role and not hidden.
|
|
92
|
+
// A11Y-TOUCH-TARGET: inline size below the 44dp minimum (M3 refinement).
|
|
93
|
+
for (const tag of INTERACTIVE) {
|
|
94
|
+
scanTag(tag, (props, idx) => {
|
|
95
|
+
if (isHiddenFromA11y(props))
|
|
96
|
+
return;
|
|
97
|
+
if (!hasA11yLabelOrRole(props)) {
|
|
98
|
+
emit("A11Y-INTERACTIVE", "error", tag, idx, `<${tag}> is interactive but has no accessibilityLabel/accessibilityRole — not screen-reader operable.`);
|
|
99
|
+
}
|
|
100
|
+
const w = props.match(/\bwidth:\s*(\d+)/);
|
|
101
|
+
const h = props.match(/\bheight:\s*(\d+)/);
|
|
102
|
+
if (w && h && (Number(w[1]) < 44 || Number(h[1]) < 44)) {
|
|
103
|
+
emit("A11Y-TOUCH-TARGET", "warning", tag, idx, `<${tag}> inline size ${w[1]}x${h[1]}dp is below the 44dp minimum touch target.`);
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
// A11Y-FONT-SCALING: disabling font scaling breaks Dynamic Type (M3 refinement).
|
|
108
|
+
for (const tag of ["Text", "TextInput"]) {
|
|
109
|
+
scanTag(tag, (props, idx) => {
|
|
110
|
+
if (/\ballowFontScaling\s*=\s*\{?\s*false\b/.test(props)) {
|
|
111
|
+
emit("A11Y-FONT-SCALING", "warning", tag, idx, `<${tag}> sets allowFontScaling={false} — text won't scale with the user's font size.`);
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
// A11Y-BUTTON: <Button> needs a title (its accessible name) or a label.
|
|
116
|
+
scanTag("Button", (props, idx) => {
|
|
117
|
+
if (isHiddenFromA11y(props))
|
|
118
|
+
return;
|
|
119
|
+
if (!hasA11yLabelOrRole(props) && !/\btitle\s*=/.test(props)) {
|
|
120
|
+
emit("A11Y-BUTTON", "error", "Button", idx, "<Button> has no title or accessibilityLabel — no accessible name.");
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
// A11Y-IMAGE: images that carry content need a label (or be explicitly hidden).
|
|
124
|
+
scanTag("Image", (props, idx) => {
|
|
125
|
+
if (isHiddenFromA11y(props))
|
|
126
|
+
return;
|
|
127
|
+
if (!/\bsource\s*=/.test(props))
|
|
128
|
+
return; // decorative/no-source: skip
|
|
129
|
+
if (!hasA11yLabelOrRole(props)) {
|
|
130
|
+
emit("A11Y-IMAGE", "warning", "Image", idx, "<Image> has a source but no accessibilityLabel — screen readers announce nothing (or hide it explicitly).");
|
|
131
|
+
}
|
|
132
|
+
});
|
|
133
|
+
// A11Y-INPUT: text inputs need a label (placeholder is not a label).
|
|
134
|
+
scanTag("TextInput", (props, idx) => {
|
|
135
|
+
if (isHiddenFromA11y(props))
|
|
136
|
+
return;
|
|
137
|
+
if (!hasA11yLabelOrRole(props)) {
|
|
138
|
+
emit("A11Y-INPUT", "warning", "TextInput", idx, "<TextInput> has no accessibilityLabel — a placeholder is not an accessible label.");
|
|
139
|
+
}
|
|
140
|
+
});
|
|
141
|
+
return findings;
|
|
142
|
+
}
|
|
143
|
+
/** Aggregate a scan across multiple files. */
|
|
144
|
+
export function scanA11yFiles(files) {
|
|
145
|
+
const findings = files.flatMap((f) => scanA11ySource(f.path, f.content));
|
|
146
|
+
return {
|
|
147
|
+
filesScanned: files.length,
|
|
148
|
+
findings,
|
|
149
|
+
errors: findings.filter((f) => f.severity === "error").length,
|
|
150
|
+
warnings: findings.filter((f) => f.severity === "warning").length,
|
|
151
|
+
};
|
|
152
|
+
}
|
|
153
|
+
//# sourceMappingURL=a11y.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"a11y.js","sourceRoot":"","sources":["../../src/verify/a11y.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Clean-architecture verification (M8 — radar/experimental) — STATIC analysis
|
|
3
|
+
* of the import graph to enforce mobile layering:
|
|
4
|
+
*
|
|
5
|
+
* - domain purity: files under `domain/` must not import react/react-native/UI.
|
|
6
|
+
* - layer direction: domain ⟶ (nothing); data ⟶ domain only; presentation ⟶
|
|
7
|
+
* domain/data. So `domain/` importing data/presentation/components/screens is
|
|
8
|
+
* a violation; `data/` importing presentation/components/screens is too.
|
|
9
|
+
* - no cross-feature imports: `features/A/**` must not import `features/B/**`.
|
|
10
|
+
*
|
|
11
|
+
* Pure: takes {path, content} and returns findings. Heuristic (path-segment +
|
|
12
|
+
* import-string based), never executes code. Rules only fire when a project
|
|
13
|
+
* actually uses these folder conventions.
|
|
14
|
+
*/
|
|
15
|
+
export interface ArchFinding {
|
|
16
|
+
rule: string;
|
|
17
|
+
severity: "error" | "warning";
|
|
18
|
+
file: string;
|
|
19
|
+
line: number;
|
|
20
|
+
importPath: string;
|
|
21
|
+
message: string;
|
|
22
|
+
}
|
|
23
|
+
/** Extract module specifiers from import/export-from/require statements. */
|
|
24
|
+
export declare function extractImports(content: string): Array<{
|
|
25
|
+
spec: string;
|
|
26
|
+
index: number;
|
|
27
|
+
}>;
|
|
28
|
+
export interface ArchReport {
|
|
29
|
+
filesScanned: number;
|
|
30
|
+
findings: ArchFinding[];
|
|
31
|
+
errors: number;
|
|
32
|
+
}
|
|
33
|
+
export declare function analyzeArchitecture(files: Array<{
|
|
34
|
+
path: string;
|
|
35
|
+
content: string;
|
|
36
|
+
}>): ArchReport;
|
|
37
|
+
//# sourceMappingURL=architecture.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"architecture.d.ts","sourceRoot":"","sources":["../../src/verify/architecture.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,OAAO,GAAG,SAAS,CAAC;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;CACjB;AAoBD,4EAA4E;AAC5E,wBAAgB,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,KAAK,CAAC;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC,CAatF;AAQD,MAAM,WAAW,UAAU;IACzB,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,WAAW,EAAE,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,mBAAmB,CACjC,KAAK,EAAE,KAAK,CAAC;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC,GAC9C,UAAU,CAkEZ"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Clean-architecture verification (M8 — radar/experimental) — STATIC analysis
|
|
3
|
+
* of the import graph to enforce mobile layering:
|
|
4
|
+
*
|
|
5
|
+
* - domain purity: files under `domain/` must not import react/react-native/UI.
|
|
6
|
+
* - layer direction: domain ⟶ (nothing); data ⟶ domain only; presentation ⟶
|
|
7
|
+
* domain/data. So `domain/` importing data/presentation/components/screens is
|
|
8
|
+
* a violation; `data/` importing presentation/components/screens is too.
|
|
9
|
+
* - no cross-feature imports: `features/A/**` must not import `features/B/**`.
|
|
10
|
+
*
|
|
11
|
+
* Pure: takes {path, content} and returns findings. Heuristic (path-segment +
|
|
12
|
+
* import-string based), never executes code. Rules only fire when a project
|
|
13
|
+
* actually uses these folder conventions.
|
|
14
|
+
*/
|
|
15
|
+
const UI_IMPORTS = /^(react|react-native)(\/|$)/;
|
|
16
|
+
const LAYER_KEYWORDS = ["domain", "data", "presentation", "components", "screens"];
|
|
17
|
+
function segments(p) {
|
|
18
|
+
return p.split(/[\\/]/).filter(Boolean);
|
|
19
|
+
}
|
|
20
|
+
function layerOf(path) {
|
|
21
|
+
const segs = segments(path);
|
|
22
|
+
return LAYER_KEYWORDS.find((k) => segs.includes(k));
|
|
23
|
+
}
|
|
24
|
+
function featureOf(path) {
|
|
25
|
+
const m = path.match(/(?:^|[\\/])features[\\/]([^\\/]+)[\\/]/);
|
|
26
|
+
return m ? m[1] : undefined;
|
|
27
|
+
}
|
|
28
|
+
/** Extract module specifiers from import/export-from/require statements. */
|
|
29
|
+
export function extractImports(content) {
|
|
30
|
+
const out = [];
|
|
31
|
+
const patterns = [
|
|
32
|
+
/\bimport\b[^'"`]*?from\s*['"]([^'"]+)['"]/g,
|
|
33
|
+
/\bimport\s*['"]([^'"]+)['"]/g,
|
|
34
|
+
/\bexport\b[^'"`]*?from\s*['"]([^'"]+)['"]/g,
|
|
35
|
+
/\brequire\(\s*['"]([^'"]+)['"]\s*\)/g,
|
|
36
|
+
];
|
|
37
|
+
for (const re of patterns) {
|
|
38
|
+
let m;
|
|
39
|
+
while ((m = re.exec(content)) !== null)
|
|
40
|
+
out.push({ spec: m[1], index: m.index });
|
|
41
|
+
}
|
|
42
|
+
return out;
|
|
43
|
+
}
|
|
44
|
+
function lineOf(content, index) {
|
|
45
|
+
let line = 1;
|
|
46
|
+
for (let i = 0; i < index && i < content.length; i++)
|
|
47
|
+
if (content[i] === "\n")
|
|
48
|
+
line++;
|
|
49
|
+
return line;
|
|
50
|
+
}
|
|
51
|
+
export function analyzeArchitecture(files) {
|
|
52
|
+
const findings = [];
|
|
53
|
+
for (const { path, content } of files) {
|
|
54
|
+
const fileLayer = layerOf(path);
|
|
55
|
+
const fileFeature = featureOf(path);
|
|
56
|
+
for (const { spec, index } of extractImports(content)) {
|
|
57
|
+
const line = lineOf(content, index);
|
|
58
|
+
const importLayer = layerOf(spec);
|
|
59
|
+
const importFeature = featureOf(spec);
|
|
60
|
+
// 1. domain purity
|
|
61
|
+
if (fileLayer === "domain" && UI_IMPORTS.test(spec)) {
|
|
62
|
+
findings.push({
|
|
63
|
+
rule: "ARCH-DOMAIN-PURITY",
|
|
64
|
+
severity: "error",
|
|
65
|
+
file: path,
|
|
66
|
+
line,
|
|
67
|
+
importPath: spec,
|
|
68
|
+
message: `domain/ must stay UI-free but imports "${spec}".`,
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
// 2. layer direction
|
|
72
|
+
const forbiddenForDomain = ["data", "presentation", "components", "screens"];
|
|
73
|
+
const forbiddenForData = ["presentation", "components", "screens"];
|
|
74
|
+
if (fileLayer === "domain" && importLayer && forbiddenForDomain.includes(importLayer)) {
|
|
75
|
+
findings.push({
|
|
76
|
+
rule: "ARCH-LAYER-DIRECTION",
|
|
77
|
+
severity: "error",
|
|
78
|
+
file: path,
|
|
79
|
+
line,
|
|
80
|
+
importPath: spec,
|
|
81
|
+
message: `domain/ must not depend on ${importLayer}/ (inner layer importing outer).`,
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
else if (fileLayer === "data" && importLayer && forbiddenForData.includes(importLayer)) {
|
|
85
|
+
findings.push({
|
|
86
|
+
rule: "ARCH-LAYER-DIRECTION",
|
|
87
|
+
severity: "error",
|
|
88
|
+
file: path,
|
|
89
|
+
line,
|
|
90
|
+
importPath: spec,
|
|
91
|
+
message: `data/ must not depend on ${importLayer}/ (wrong dependency direction).`,
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
// 3. no cross-feature imports
|
|
95
|
+
if (fileFeature && importFeature && fileFeature !== importFeature) {
|
|
96
|
+
findings.push({
|
|
97
|
+
rule: "ARCH-CROSS-FEATURE",
|
|
98
|
+
severity: "error",
|
|
99
|
+
file: path,
|
|
100
|
+
line,
|
|
101
|
+
importPath: spec,
|
|
102
|
+
message: `feature "${fileFeature}" imports feature "${importFeature}" — features must be independent.`,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
return {
|
|
108
|
+
filesScanned: files.length,
|
|
109
|
+
findings,
|
|
110
|
+
errors: findings.filter((f) => f.severity === "error").length,
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=architecture.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"architecture.js","sourceRoot":"","sources":["../../src/verify/architecture.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Verification edge — actually measure the app against its declared
|
|
3
|
+
* mobile budgets/criteria (a11y, perf), complementing the declarative gates.
|
|
4
|
+
*/
|
|
5
|
+
export { type A11ySeverity, type A11yFinding, type A11yReport, scanA11ySource, scanA11yFiles, } from "./a11y.js";
|
|
6
|
+
export { type AmStartTimings, type PerfEvaluation, parseAmStartOutput, evaluatePerf, median, parseHermesEnabled, } from "./perf.js";
|
|
7
|
+
export { type OsMatrixCheck, type OsMatrixEvaluation, androidVersionToApi, androidApiToVersion, parseAndroidMinSdk, parseIosDeploymentTarget, evaluateOsMatrix, } from "./os-matrix.js";
|
|
8
|
+
export { type StoreCheck, type StoresEvaluation, extractAndroidPermission, extractIosUsageKey, parseManifestPermissions, parseInfoPlistKeys, evaluateStores, } from "./stores.js";
|
|
9
|
+
export { type ArchFinding, type ArchReport, extractImports, analyzeArchitecture, } from "./architecture.js";
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/verify/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EACL,KAAK,YAAY,EACjB,KAAK,WAAW,EAChB,KAAK,UAAU,EACf,cAAc,EACd,aAAa,GACd,MAAM,WAAW,CAAC;AACnB,OAAO,EACL,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,kBAAkB,EAClB,YAAY,EACZ,MAAM,EACN,kBAAkB,GACnB,MAAM,WAAW,CAAC;AACnB,OAAO,EACL,KAAK,aAAa,EAClB,KAAK,kBAAkB,EACvB,mBAAmB,EACnB,mBAAmB,EACnB,kBAAkB,EAClB,wBAAwB,EACxB,gBAAgB,GACjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EACL,KAAK,UAAU,EACf,KAAK,gBAAgB,EACrB,wBAAwB,EACxB,kBAAkB,EAClB,wBAAwB,EACxB,kBAAkB,EAClB,cAAc,GACf,MAAM,aAAa,CAAC;AACrB,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,UAAU,EACf,cAAc,EACd,mBAAmB,GACpB,MAAM,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Verification edge — actually measure the app against its declared
|
|
3
|
+
* mobile budgets/criteria (a11y, perf), complementing the declarative gates.
|
|
4
|
+
*/
|
|
5
|
+
export { scanA11ySource, scanA11yFiles, } from "./a11y.js";
|
|
6
|
+
export { parseAmStartOutput, evaluatePerf, median, parseHermesEnabled, } from "./perf.js";
|
|
7
|
+
export { androidVersionToApi, androidApiToVersion, parseAndroidMinSdk, parseIosDeploymentTarget, evaluateOsMatrix, } from "./os-matrix.js";
|
|
8
|
+
export { extractAndroidPermission, extractIosUsageKey, parseManifestPermissions, parseInfoPlistKeys, evaluateStores, } from "./stores.js";
|
|
9
|
+
export { extractImports, analyzeArchitecture, } from "./architecture.js";
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/verify/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAIL,cAAc,EACd,aAAa,GACd,MAAM,WAAW,CAAC;AACnB,OAAO,EAGL,kBAAkB,EAClB,YAAY,EACZ,MAAM,EACN,kBAAkB,GACnB,MAAM,WAAW,CAAC;AACnB,OAAO,EAGL,mBAAmB,EACnB,mBAAmB,EACnB,kBAAkB,EAClB,wBAAwB,EACxB,gBAAgB,GACjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAGL,wBAAwB,EACxB,kBAAkB,EAClB,wBAAwB,EACxB,kBAAkB,EAClB,cAAc,GACf,MAAM,aAAa,CAAC;AACrB,OAAO,EAGL,cAAc,EACd,mBAAmB,GACpB,MAAM,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* OS support matrix verification (M4) — measure the DECLARED os_matrix
|
|
3
|
+
* (plan.md frontmatter) against the REAL native config of a React Native CLI
|
|
4
|
+
* project: Android `minSdkVersion` (android/build.gradle) and the iOS
|
|
5
|
+
* deployment target (xcodeproj `IPHONEOS_DEPLOYMENT_TARGET`, Podfile fallback).
|
|
6
|
+
*
|
|
7
|
+
* Pure functions (take file content) so the logic is testable; the CLI reads
|
|
8
|
+
* the files and may apply `--fix`.
|
|
9
|
+
*/
|
|
10
|
+
/** Resolve a declared Android min ("7.0" or an API number "24") to an API level. */
|
|
11
|
+
export declare function androidVersionToApi(value: string): number | undefined;
|
|
12
|
+
export declare function androidApiToVersion(api: number): string;
|
|
13
|
+
/** Parse `minSdkVersion = N` (or `minSdkVersion N`) from a build.gradle. */
|
|
14
|
+
export declare function parseAndroidMinSdk(gradle: string): number | undefined;
|
|
15
|
+
/** Parse the iOS deployment target from a pbxproj or a Podfile literal. */
|
|
16
|
+
export declare function parseIosDeploymentTarget(content: string): string | undefined;
|
|
17
|
+
export interface OsMatrixCheck {
|
|
18
|
+
platform: "android" | "ios";
|
|
19
|
+
declared: string;
|
|
20
|
+
native: string;
|
|
21
|
+
status: "match" | "mismatch" | "missing";
|
|
22
|
+
detail: string;
|
|
23
|
+
}
|
|
24
|
+
export interface OsMatrixEvaluation {
|
|
25
|
+
checks: OsMatrixCheck[];
|
|
26
|
+
ok: boolean;
|
|
27
|
+
}
|
|
28
|
+
export declare function evaluateOsMatrix(declared: {
|
|
29
|
+
ios_min?: string;
|
|
30
|
+
android_min?: string;
|
|
31
|
+
}, native: {
|
|
32
|
+
androidMinSdk?: number;
|
|
33
|
+
iosTarget?: string;
|
|
34
|
+
}): OsMatrixEvaluation;
|
|
35
|
+
//# sourceMappingURL=os-matrix.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"os-matrix.d.ts","sourceRoot":"","sources":["../../src/verify/os-matrix.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AASH,oFAAoF;AACpF,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAQrE;AAED,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAGvD;AAED,4EAA4E;AAC5E,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAGrE;AAED,2EAA2E;AAC3E,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAM5E;AAOD,MAAM,WAAW,aAAa;IAC5B,QAAQ,EAAE,SAAS,GAAG,KAAK,CAAC;IAC5B,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,OAAO,GAAG,UAAU,GAAG,SAAS,CAAC;IACzC,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,aAAa,EAAE,CAAC;IACxB,EAAE,EAAE,OAAO,CAAC;CACb;AAED,wBAAgB,gBAAgB,CAC9B,QAAQ,EAAE;IAAE,OAAO,CAAC,EAAE,MAAM,CAAC;IAAC,WAAW,CAAC,EAAE,MAAM,CAAA;CAAE,EACpD,MAAM,EAAE;IAAE,aAAa,CAAC,EAAE,MAAM,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,GACrD,kBAAkB,CAqDpB"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* OS support matrix verification (M4) — measure the DECLARED os_matrix
|
|
3
|
+
* (plan.md frontmatter) against the REAL native config of a React Native CLI
|
|
4
|
+
* project: Android `minSdkVersion` (android/build.gradle) and the iOS
|
|
5
|
+
* deployment target (xcodeproj `IPHONEOS_DEPLOYMENT_TARGET`, Podfile fallback).
|
|
6
|
+
*
|
|
7
|
+
* Pure functions (take file content) so the logic is testable; the CLI reads
|
|
8
|
+
* the files and may apply `--fix`.
|
|
9
|
+
*/
|
|
10
|
+
/** Android marketing version → API level. */
|
|
11
|
+
const ANDROID_API_BY_VERSION = {
|
|
12
|
+
"5.0": 21, "5.1": 22, "6.0": 23, "7.0": 24, "7.1": 25, "8.0": 26, "8.1": 27,
|
|
13
|
+
"9": 28, "9.0": 28, "10": 29, "11": 30, "12": 31, "12L": 32, "13": 33,
|
|
14
|
+
"14": 34, "15": 35, "16": 36,
|
|
15
|
+
};
|
|
16
|
+
/** Resolve a declared Android min ("7.0" or an API number "24") to an API level. */
|
|
17
|
+
export function androidVersionToApi(value) {
|
|
18
|
+
const v = value.trim();
|
|
19
|
+
if (ANDROID_API_BY_VERSION[v] !== undefined)
|
|
20
|
+
return ANDROID_API_BY_VERSION[v];
|
|
21
|
+
if (/^\d+$/.test(v)) {
|
|
22
|
+
const n = Number(v);
|
|
23
|
+
if (n >= 21)
|
|
24
|
+
return n; // already an API level
|
|
25
|
+
}
|
|
26
|
+
return undefined;
|
|
27
|
+
}
|
|
28
|
+
export function androidApiToVersion(api) {
|
|
29
|
+
const found = Object.entries(ANDROID_API_BY_VERSION).find(([, a]) => a === api);
|
|
30
|
+
return found ? found[0] : `API ${api}`;
|
|
31
|
+
}
|
|
32
|
+
/** Parse `minSdkVersion = N` (or `minSdkVersion N`) from a build.gradle. */
|
|
33
|
+
export function parseAndroidMinSdk(gradle) {
|
|
34
|
+
const m = gradle.match(/minSdkVersion\s*=?\s*(\d+)/);
|
|
35
|
+
return m ? Number(m[1]) : undefined;
|
|
36
|
+
}
|
|
37
|
+
/** Parse the iOS deployment target from a pbxproj or a Podfile literal. */
|
|
38
|
+
export function parseIosDeploymentTarget(content) {
|
|
39
|
+
const pb = content.match(/IPHONEOS_DEPLOYMENT_TARGET\s*=\s*([0-9.]+)/);
|
|
40
|
+
if (pb)
|
|
41
|
+
return pb[1];
|
|
42
|
+
const pod = content.match(/platform\s+:ios,\s*['"]([0-9.]+)['"]/);
|
|
43
|
+
if (pod)
|
|
44
|
+
return pod[1];
|
|
45
|
+
return undefined;
|
|
46
|
+
}
|
|
47
|
+
function normIos(v) {
|
|
48
|
+
// "15.1" and "15.10" stay distinct; trim trailing ".0" so "15.0" == "15".
|
|
49
|
+
return v.trim().replace(/\.0+$/, "");
|
|
50
|
+
}
|
|
51
|
+
export function evaluateOsMatrix(declared, native) {
|
|
52
|
+
const checks = [];
|
|
53
|
+
// Android
|
|
54
|
+
if (declared.android_min !== undefined) {
|
|
55
|
+
const declApi = androidVersionToApi(String(declared.android_min));
|
|
56
|
+
if (native.androidMinSdk === undefined) {
|
|
57
|
+
checks.push({
|
|
58
|
+
platform: "android",
|
|
59
|
+
declared: `${declared.android_min} (API ${declApi ?? "?"})`,
|
|
60
|
+
native: "(not found)",
|
|
61
|
+
status: "missing",
|
|
62
|
+
detail: "Could not read minSdkVersion from android/build.gradle.",
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
const match = declApi === native.androidMinSdk;
|
|
67
|
+
checks.push({
|
|
68
|
+
platform: "android",
|
|
69
|
+
declared: `${declared.android_min} (API ${declApi ?? "?"})`,
|
|
70
|
+
native: `API ${native.androidMinSdk} (${androidApiToVersion(native.androidMinSdk)})`,
|
|
71
|
+
status: match ? "match" : "mismatch",
|
|
72
|
+
detail: match
|
|
73
|
+
? "Declared android_min matches the native minSdkVersion."
|
|
74
|
+
: `Declared API ${declApi} but native minSdkVersion is ${native.androidMinSdk}.`,
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
// iOS
|
|
79
|
+
if (declared.ios_min !== undefined) {
|
|
80
|
+
if (native.iosTarget === undefined) {
|
|
81
|
+
checks.push({
|
|
82
|
+
platform: "ios",
|
|
83
|
+
declared: declared.ios_min,
|
|
84
|
+
native: "(not found)",
|
|
85
|
+
status: "missing",
|
|
86
|
+
detail: "Could not read IPHONEOS_DEPLOYMENT_TARGET (xcodeproj/Podfile).",
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
const match = normIos(String(declared.ios_min)) === normIos(native.iosTarget);
|
|
91
|
+
checks.push({
|
|
92
|
+
platform: "ios",
|
|
93
|
+
declared: String(declared.ios_min),
|
|
94
|
+
native: native.iosTarget,
|
|
95
|
+
status: match ? "match" : "mismatch",
|
|
96
|
+
detail: match
|
|
97
|
+
? "Declared ios_min matches the native deployment target."
|
|
98
|
+
: `Declared ${declared.ios_min} but native target is ${native.iosTarget}.`,
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
return { checks, ok: checks.every((c) => c.status === "match") };
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=os-matrix.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"os-matrix.js","sourceRoot":"","sources":["../../src/verify/os-matrix.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Performance verification — measure the running app, don't just declare it.
|
|
3
|
+
*
|
|
4
|
+
* This is the "verification edge" for M5: instead of only trusting
|
|
5
|
+
* `perf_budget.ttfi_ms` in plan.md, this measures the real cold-start of the
|
|
6
|
+
* installed app on a device/emulator (Android `am start -W`) and compares it
|
|
7
|
+
* to the declared budget.
|
|
8
|
+
*
|
|
9
|
+
* This module is the PURE part (parsing + evaluation); the adb invocation
|
|
10
|
+
* lives in the CLI so the logic stays testable.
|
|
11
|
+
*/
|
|
12
|
+
export interface AmStartTimings {
|
|
13
|
+
/** Total time to fully drawn / displayed, ms. */
|
|
14
|
+
totalTimeMs?: number;
|
|
15
|
+
/** Wait time reported by the activity manager, ms. */
|
|
16
|
+
waitTimeMs?: number;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Parse the output of `adb shell am start -W <pkg>/<activity>`.
|
|
20
|
+
* Looks for `TotalTime:` and `WaitTime:` lines.
|
|
21
|
+
*/
|
|
22
|
+
export declare function parseAmStartOutput(output: string): AmStartTimings;
|
|
23
|
+
export interface PerfEvaluation {
|
|
24
|
+
measuredMs: number;
|
|
25
|
+
budgetMs: number;
|
|
26
|
+
pass: boolean;
|
|
27
|
+
marginMs: number;
|
|
28
|
+
message: string;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Compare a measured cold-start against the declared TTFI budget.
|
|
32
|
+
* `measuredMs` is the best available signal (prefer TotalTime, else WaitTime).
|
|
33
|
+
*/
|
|
34
|
+
export declare function evaluatePerf(timings: AmStartTimings, budgetMs: number): PerfEvaluation | null;
|
|
35
|
+
/**
|
|
36
|
+
* Whether Hermes is enabled (Android `gradle.properties` `hermesEnabled=true`).
|
|
37
|
+
* Hermes materially affects JS startup/TTFI, so it is part of the M5 picture.
|
|
38
|
+
* Returns undefined when the flag isn't present.
|
|
39
|
+
*/
|
|
40
|
+
export declare function parseHermesEnabled(gradleProperties: string): boolean | undefined;
|
|
41
|
+
/** Median of a list of samples (for multi-run measurement). */
|
|
42
|
+
export declare function median(samples: number[]): number;
|
|
43
|
+
//# sourceMappingURL=perf.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"perf.d.ts","sourceRoot":"","sources":["../../src/verify/perf.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,MAAM,WAAW,cAAc;IAC7B,iDAAiD;IACjD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,sDAAsD;IACtD,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;;GAGG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,cAAc,CAWjE;AAED,MAAM,WAAW,cAAc;IAC7B,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,OAAO,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED;;;GAGG;AACH,wBAAgB,YAAY,CAC1B,OAAO,EAAE,cAAc,EACvB,QAAQ,EAAE,MAAM,GACf,cAAc,GAAG,IAAI,CAcvB;AAED;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,gBAAgB,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS,CAGhF;AAED,+DAA+D;AAC/D,wBAAgB,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,CAOhD"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Performance verification — measure the running app, don't just declare it.
|
|
3
|
+
*
|
|
4
|
+
* This is the "verification edge" for M5: instead of only trusting
|
|
5
|
+
* `perf_budget.ttfi_ms` in plan.md, this measures the real cold-start of the
|
|
6
|
+
* installed app on a device/emulator (Android `am start -W`) and compares it
|
|
7
|
+
* to the declared budget.
|
|
8
|
+
*
|
|
9
|
+
* This module is the PURE part (parsing + evaluation); the adb invocation
|
|
10
|
+
* lives in the CLI so the logic stays testable.
|
|
11
|
+
*/
|
|
12
|
+
/**
|
|
13
|
+
* Parse the output of `adb shell am start -W <pkg>/<activity>`.
|
|
14
|
+
* Looks for `TotalTime:` and `WaitTime:` lines.
|
|
15
|
+
*/
|
|
16
|
+
export function parseAmStartOutput(output) {
|
|
17
|
+
const num = (re) => {
|
|
18
|
+
const m = output.match(re);
|
|
19
|
+
return m ? Number(m[1]) : undefined;
|
|
20
|
+
};
|
|
21
|
+
const result = {};
|
|
22
|
+
const total = num(/TotalTime:\s*(\d+)/);
|
|
23
|
+
const wait = num(/WaitTime:\s*(\d+)/);
|
|
24
|
+
if (total !== undefined)
|
|
25
|
+
result.totalTimeMs = total;
|
|
26
|
+
if (wait !== undefined)
|
|
27
|
+
result.waitTimeMs = wait;
|
|
28
|
+
return result;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Compare a measured cold-start against the declared TTFI budget.
|
|
32
|
+
* `measuredMs` is the best available signal (prefer TotalTime, else WaitTime).
|
|
33
|
+
*/
|
|
34
|
+
export function evaluatePerf(timings, budgetMs) {
|
|
35
|
+
const measuredMs = timings.totalTimeMs ?? timings.waitTimeMs;
|
|
36
|
+
if (measuredMs === undefined)
|
|
37
|
+
return null;
|
|
38
|
+
const pass = measuredMs <= budgetMs;
|
|
39
|
+
const marginMs = budgetMs - measuredMs;
|
|
40
|
+
return {
|
|
41
|
+
measuredMs,
|
|
42
|
+
budgetMs,
|
|
43
|
+
pass,
|
|
44
|
+
marginMs,
|
|
45
|
+
message: pass
|
|
46
|
+
? `cold-start ${measuredMs}ms is within the ${budgetMs}ms TTFI budget (margin ${marginMs}ms).`
|
|
47
|
+
: `cold-start ${measuredMs}ms EXCEEDS the ${budgetMs}ms TTFI budget by ${-marginMs}ms.`,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Whether Hermes is enabled (Android `gradle.properties` `hermesEnabled=true`).
|
|
52
|
+
* Hermes materially affects JS startup/TTFI, so it is part of the M5 picture.
|
|
53
|
+
* Returns undefined when the flag isn't present.
|
|
54
|
+
*/
|
|
55
|
+
export function parseHermesEnabled(gradleProperties) {
|
|
56
|
+
const m = gradleProperties.match(/^\s*hermesEnabled\s*=\s*(true|false)/m);
|
|
57
|
+
return m ? m[1] === "true" : undefined;
|
|
58
|
+
}
|
|
59
|
+
/** Median of a list of samples (for multi-run measurement). */
|
|
60
|
+
export function median(samples) {
|
|
61
|
+
if (samples.length === 0)
|
|
62
|
+
return NaN;
|
|
63
|
+
const sorted = [...samples].sort((a, b) => a - b);
|
|
64
|
+
const mid = Math.floor(sorted.length / 2);
|
|
65
|
+
return sorted.length % 2 === 0
|
|
66
|
+
? Math.round((sorted[mid - 1] + sorted[mid]) / 2)
|
|
67
|
+
: sorted[mid];
|
|
68
|
+
}
|
|
69
|
+
//# sourceMappingURL=perf.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"perf.js","sourceRoot":"","sources":["../../src/verify/perf.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AASH;;;GAGG;AACH,MAAM,UAAU,kBAAkB,CAAC,MAAc;IAC/C,MAAM,GAAG,GAAG,CAAC,EAAU,EAAsB,EAAE;QAC7C,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC3B,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACtC,CAAC,CAAC;IACF,MAAM,MAAM,GAAmB,EAAE,CAAC;IAClC,MAAM,KAAK,GAAG,GAAG,CAAC,oBAAoB,CAAC,CAAC;IACxC,MAAM,IAAI,GAAG,GAAG,CAAC,mBAAmB,CAAC,CAAC;IACtC,IAAI,KAAK,KAAK,SAAS;QAAE,MAAM,CAAC,WAAW,GAAG,KAAK,CAAC;IACpD,IAAI,IAAI,KAAK,SAAS;QAAE,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC;IACjD,OAAO,MAAM,CAAC;AAChB,CAAC;AAUD;;;GAGG;AACH,MAAM,UAAU,YAAY,CAC1B,OAAuB,EACvB,QAAgB;IAEhB,MAAM,UAAU,GAAG,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,UAAU,CAAC;IAC7D,IAAI,UAAU,KAAK,SAAS;QAAE,OAAO,IAAI,CAAC;IAC1C,MAAM,IAAI,GAAG,UAAU,IAAI,QAAQ,CAAC;IACpC,MAAM,QAAQ,GAAG,QAAQ,GAAG,UAAU,CAAC;IACvC,OAAO;QACL,UAAU;QACV,QAAQ;QACR,IAAI;QACJ,QAAQ;QACR,OAAO,EAAE,IAAI;YACX,CAAC,CAAC,cAAc,UAAU,oBAAoB,QAAQ,0BAA0B,QAAQ,MAAM;YAC9F,CAAC,CAAC,cAAc,UAAU,kBAAkB,QAAQ,qBAAqB,CAAC,QAAQ,KAAK;KAC1F,CAAC;AACJ,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,kBAAkB,CAAC,gBAAwB;IACzD,MAAM,CAAC,GAAG,gBAAgB,CAAC,KAAK,CAAC,uCAAuC,CAAC,CAAC;IAC1E,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;AACzC,CAAC;AAED,+DAA+D;AAC/D,MAAM,UAAU,MAAM,CAAC,OAAiB;IACtC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,GAAG,CAAC;IACrC,MAAM,MAAM,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAClD,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAC1C,OAAO,MAAM,CAAC,MAAM,GAAG,CAAC,KAAK,CAAC;QAC5B,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,GAAG,GAAG,CAAC,CAAE,GAAG,MAAM,CAAC,GAAG,CAAE,CAAC,GAAG,CAAC,CAAC;QACnD,CAAC,CAAC,MAAM,CAAC,GAAG,CAAE,CAAC;AACnB,CAAC"}
|