context-probe 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.
Files changed (600) hide show
  1. package/LICENSE +183 -0
  2. package/README.ja.md +323 -0
  3. package/README.md +323 -0
  4. package/dist/src/analyzers/architecture-contract-declarations-dart.d.ts +2 -0
  5. package/dist/src/analyzers/architecture-contract-declarations-dart.js +129 -0
  6. package/dist/src/analyzers/architecture-contract-declarations-ecma-core.d.ts +2 -0
  7. package/dist/src/analyzers/architecture-contract-declarations-ecma-core.js +89 -0
  8. package/dist/src/analyzers/architecture-contract-declarations-ecma-shared.d.ts +10 -0
  9. package/dist/src/analyzers/architecture-contract-declarations-ecma-shared.js +56 -0
  10. package/dist/src/analyzers/architecture-contract-declarations-ecma.d.ts +1 -0
  11. package/dist/src/analyzers/architecture-contract-declarations-ecma.js +1 -0
  12. package/dist/src/analyzers/architecture-contract-declarations-shared.d.ts +8 -0
  13. package/dist/src/analyzers/architecture-contract-declarations-shared.js +21 -0
  14. package/dist/src/analyzers/architecture-contract-declarations.d.ts +2 -0
  15. package/dist/src/analyzers/architecture-contract-declarations.js +2 -0
  16. package/dist/src/analyzers/architecture-contract-score-baseline-analysis.d.ts +8 -0
  17. package/dist/src/analyzers/architecture-contract-score-baseline-analysis.js +70 -0
  18. package/dist/src/analyzers/architecture-contract-score-baseline-core.d.ts +8 -0
  19. package/dist/src/analyzers/architecture-contract-score-baseline-core.js +4 -0
  20. package/dist/src/analyzers/architecture-contract-score-baseline-entry.d.ts +19 -0
  21. package/dist/src/analyzers/architecture-contract-score-baseline-entry.js +89 -0
  22. package/dist/src/analyzers/architecture-contract-score-baseline-scope.d.ts +8 -0
  23. package/dist/src/analyzers/architecture-contract-score-baseline-scope.js +18 -0
  24. package/dist/src/analyzers/architecture-contract-score-baseline.d.ts +1 -0
  25. package/dist/src/analyzers/architecture-contract-score-baseline.js +1 -0
  26. package/dist/src/analyzers/architecture-contract-score-current.d.ts +3 -0
  27. package/dist/src/analyzers/architecture-contract-score-current.js +39 -0
  28. package/dist/src/analyzers/architecture-contract-score-shared.d.ts +18 -0
  29. package/dist/src/analyzers/architecture-contract-score-shared.js +9 -0
  30. package/dist/src/analyzers/architecture-contract-scoring.d.ts +15 -0
  31. package/dist/src/analyzers/architecture-contract-scoring.js +70 -0
  32. package/dist/src/analyzers/architecture-contract-stats-core.d.ts +9 -0
  33. package/dist/src/analyzers/architecture-contract-stats-core.js +20 -0
  34. package/dist/src/analyzers/architecture-contract-stats-file.d.ts +23 -0
  35. package/dist/src/analyzers/architecture-contract-stats-file.js +77 -0
  36. package/dist/src/analyzers/architecture-contract-stats.d.ts +2 -0
  37. package/dist/src/analyzers/architecture-contract-stats.js +1 -0
  38. package/dist/src/analyzers/architecture-contract-types.d.ts +24 -0
  39. package/dist/src/analyzers/architecture-contract-types.js +1 -0
  40. package/dist/src/analyzers/architecture-contracts.d.ts +2 -0
  41. package/dist/src/analyzers/architecture-contracts.js +1 -0
  42. package/dist/src/analyzers/architecture-cti-ingest.d.ts +19 -0
  43. package/dist/src/analyzers/architecture-cti-ingest.js +64 -0
  44. package/dist/src/analyzers/architecture-delivery-normalization-core.d.ts +6 -0
  45. package/dist/src/analyzers/architecture-delivery-normalization-core.js +83 -0
  46. package/dist/src/analyzers/architecture-delivery-normalization-shared.d.ts +16 -0
  47. package/dist/src/analyzers/architecture-delivery-normalization-shared.js +1 -0
  48. package/dist/src/analyzers/architecture-delivery-normalization-spec.d.ts +13 -0
  49. package/dist/src/analyzers/architecture-delivery-normalization-spec.js +52 -0
  50. package/dist/src/analyzers/architecture-delivery-normalization.d.ts +6 -0
  51. package/dist/src/analyzers/architecture-delivery-normalization.js +4 -0
  52. package/dist/src/analyzers/architecture-evolution-efficiency.d.ts +8 -0
  53. package/dist/src/analyzers/architecture-evolution-efficiency.js +76 -0
  54. package/dist/src/analyzers/architecture-evolution-locality.d.ts +7 -0
  55. package/dist/src/analyzers/architecture-evolution-locality.js +129 -0
  56. package/dist/src/analyzers/architecture-evolution-shared.d.ts +33 -0
  57. package/dist/src/analyzers/architecture-evolution-shared.js +29 -0
  58. package/dist/src/analyzers/architecture-evolution.d.ts +3 -0
  59. package/dist/src/analyzers/architecture-evolution.js +2 -0
  60. package/dist/src/analyzers/architecture-observation-ingest-delivery.d.ts +9 -0
  61. package/dist/src/analyzers/architecture-observation-ingest-delivery.js +62 -0
  62. package/dist/src/analyzers/architecture-observation-ingest-shared.d.ts +13 -0
  63. package/dist/src/analyzers/architecture-observation-ingest-shared.js +12 -0
  64. package/dist/src/analyzers/architecture-observation-ingest-telemetry.d.ts +10 -0
  65. package/dist/src/analyzers/architecture-observation-ingest-telemetry.js +71 -0
  66. package/dist/src/analyzers/architecture-observation-ingest.d.ts +5 -0
  67. package/dist/src/analyzers/architecture-observation-ingest.js +2 -0
  68. package/dist/src/analyzers/architecture-observation-normalization-shared.d.ts +10 -0
  69. package/dist/src/analyzers/architecture-observation-normalization-shared.js +19 -0
  70. package/dist/src/analyzers/architecture-operations-common-ops.d.ts +16 -0
  71. package/dist/src/analyzers/architecture-operations-common-ops.js +76 -0
  72. package/dist/src/analyzers/architecture-operations.d.ts +27 -0
  73. package/dist/src/analyzers/architecture-operations.js +56 -0
  74. package/dist/src/analyzers/architecture-pattern-runtime-fallback.d.ts +8 -0
  75. package/dist/src/analyzers/architecture-pattern-runtime-fallback.js +79 -0
  76. package/dist/src/analyzers/architecture-pattern-runtime-family.d.ts +7 -0
  77. package/dist/src/analyzers/architecture-pattern-runtime-family.js +56 -0
  78. package/dist/src/analyzers/architecture-pattern-runtime-normalization-blocks.d.ts +12 -0
  79. package/dist/src/analyzers/architecture-pattern-runtime-normalization-blocks.js +41 -0
  80. package/dist/src/analyzers/architecture-pattern-runtime-normalization-math.d.ts +10 -0
  81. package/dist/src/analyzers/architecture-pattern-runtime-normalization-math.js +19 -0
  82. package/dist/src/analyzers/architecture-pattern-runtime-normalization.d.ts +21 -0
  83. package/dist/src/analyzers/architecture-pattern-runtime-normalization.js +103 -0
  84. package/dist/src/analyzers/architecture-pattern-runtime-resolution-shared.d.ts +16 -0
  85. package/dist/src/analyzers/architecture-pattern-runtime-resolution-shared.js +65 -0
  86. package/dist/src/analyzers/architecture-pattern-runtime-resolution.d.ts +15 -0
  87. package/dist/src/analyzers/architecture-pattern-runtime-resolution.js +99 -0
  88. package/dist/src/analyzers/architecture-pattern-runtime-shared.d.ts +2 -0
  89. package/dist/src/analyzers/architecture-pattern-runtime-shared.js +1 -0
  90. package/dist/src/analyzers/architecture-pattern-runtime-types.d.ts +29 -0
  91. package/dist/src/analyzers/architecture-pattern-runtime-types.js +1 -0
  92. package/dist/src/analyzers/architecture-pattern-runtime.d.ts +7 -0
  93. package/dist/src/analyzers/architecture-pattern-runtime.js +20 -0
  94. package/dist/src/analyzers/architecture-purity-signals.d.ts +6 -0
  95. package/dist/src/analyzers/architecture-purity-signals.js +21 -0
  96. package/dist/src/analyzers/architecture-purity.d.ts +2 -0
  97. package/dist/src/analyzers/architecture-purity.js +1 -0
  98. package/dist/src/analyzers/architecture-scenarios.d.ts +22 -0
  99. package/dist/src/analyzers/architecture-scenarios.js +95 -0
  100. package/dist/src/analyzers/architecture-source-loader-command.d.ts +8 -0
  101. package/dist/src/analyzers/architecture-source-loader-command.js +73 -0
  102. package/dist/src/analyzers/architecture-source-loader-core.d.ts +22 -0
  103. package/dist/src/analyzers/architecture-source-loader-core.js +41 -0
  104. package/dist/src/analyzers/architecture-source-loader-file.d.ts +8 -0
  105. package/dist/src/analyzers/architecture-source-loader-file.js +28 -0
  106. package/dist/src/analyzers/architecture-source-loader-shared.d.ts +24 -0
  107. package/dist/src/analyzers/architecture-source-loader-shared.js +4 -0
  108. package/dist/src/analyzers/architecture-source-loader.d.ts +2 -0
  109. package/dist/src/analyzers/architecture-source-loader.js +1 -0
  110. package/dist/src/analyzers/architecture-telemetry-normalization-band.d.ts +10 -0
  111. package/dist/src/analyzers/architecture-telemetry-normalization-band.js +78 -0
  112. package/dist/src/analyzers/architecture-telemetry-normalization-core.d.ts +6 -0
  113. package/dist/src/analyzers/architecture-telemetry-normalization-core.js +30 -0
  114. package/dist/src/analyzers/architecture-telemetry-normalization-shared.d.ts +16 -0
  115. package/dist/src/analyzers/architecture-telemetry-normalization-shared.js +1 -0
  116. package/dist/src/analyzers/architecture-telemetry-normalization-spec.d.ts +10 -0
  117. package/dist/src/analyzers/architecture-telemetry-normalization-spec.js +20 -0
  118. package/dist/src/analyzers/architecture-telemetry-normalization.d.ts +6 -0
  119. package/dist/src/analyzers/architecture-telemetry-normalization.js +4 -0
  120. package/dist/src/analyzers/architecture-topology-core.d.ts +7 -0
  121. package/dist/src/analyzers/architecture-topology-core.js +4 -0
  122. package/dist/src/analyzers/architecture-topology-shared.d.ts +2 -0
  123. package/dist/src/analyzers/architecture-topology-shared.js +9 -0
  124. package/dist/src/analyzers/architecture-topology-signals.d.ts +21 -0
  125. package/dist/src/analyzers/architecture-topology-signals.js +98 -0
  126. package/dist/src/analyzers/architecture-topology.d.ts +2 -0
  127. package/dist/src/analyzers/architecture-topology.js +1 -0
  128. package/dist/src/analyzers/architecture.d.ts +16 -0
  129. package/dist/src/analyzers/architecture.js +44 -0
  130. package/dist/src/analyzers/code-contracts.d.ts +4 -0
  131. package/dist/src/analyzers/code-contracts.js +74 -0
  132. package/dist/src/analyzers/code-dart.d.ts +3 -0
  133. package/dist/src/analyzers/code-dart.js +57 -0
  134. package/dist/src/analyzers/code-ecma.d.ts +2 -0
  135. package/dist/src/analyzers/code-ecma.js +53 -0
  136. package/dist/src/analyzers/code-shared.d.ts +19 -0
  137. package/dist/src/analyzers/code-shared.js +64 -0
  138. package/dist/src/analyzers/code.d.ts +3 -0
  139. package/dist/src/analyzers/code.js +34 -0
  140. package/dist/src/analyzers/contract-files.d.ts +13 -0
  141. package/dist/src/analyzers/contract-files.js +80 -0
  142. package/dist/src/analyzers/cti-complexity-components.d.ts +12 -0
  143. package/dist/src/analyzers/cti-complexity-components.js +83 -0
  144. package/dist/src/analyzers/cti-complexity-recorder.d.ts +31 -0
  145. package/dist/src/analyzers/cti-complexity-recorder.js +58 -0
  146. package/dist/src/analyzers/cti-complexity.d.ts +7 -0
  147. package/dist/src/analyzers/cti-complexity.js +15 -0
  148. package/dist/src/analyzers/cti-helpers.d.ts +7 -0
  149. package/dist/src/analyzers/cti-helpers.js +40 -0
  150. package/dist/src/analyzers/cti.d.ts +2 -0
  151. package/dist/src/analyzers/cti.js +1 -0
  152. package/dist/src/cli.d.ts +2 -0
  153. package/dist/src/cli.js +95 -0
  154. package/dist/src/command-architecture-inputs-loaders-config.d.ts +24 -0
  155. package/dist/src/command-architecture-inputs-loaders-config.js +17 -0
  156. package/dist/src/command-architecture-inputs-loaders-data.d.ts +22 -0
  157. package/dist/src/command-architecture-inputs-loaders-data.js +105 -0
  158. package/dist/src/command-architecture-inputs-loaders.d.ts +42 -0
  159. package/dist/src/command-architecture-inputs-loaders.js +12 -0
  160. package/dist/src/command-architecture-inputs-provenance.d.ts +2 -0
  161. package/dist/src/command-architecture-inputs-provenance.js +29 -0
  162. package/dist/src/command-architecture-inputs-resolved.d.ts +44 -0
  163. package/dist/src/command-architecture-inputs-resolved.js +72 -0
  164. package/dist/src/command-architecture-inputs-sources.d.ts +2 -0
  165. package/dist/src/command-architecture-inputs-sources.js +1 -0
  166. package/dist/src/command-architecture-inputs.d.ts +4 -0
  167. package/dist/src/command-architecture-inputs.js +63 -0
  168. package/dist/src/command-architecture.d.ts +2 -0
  169. package/dist/src/command-architecture.js +35 -0
  170. package/dist/src/command-domain.d.ts +2 -0
  171. package/dist/src/command-domain.js +124 -0
  172. package/dist/src/command-extraction-helpers.d.ts +13 -0
  173. package/dist/src/command-extraction-helpers.js +33 -0
  174. package/dist/src/command-helpers.d.ts +4 -0
  175. package/dist/src/command-helpers.js +3 -0
  176. package/dist/src/command-history.d.ts +2 -0
  177. package/dist/src/command-history.js +61 -0
  178. package/dist/src/command-input-loaders-architecture-compat-delivery-complexity.d.ts +3 -0
  179. package/dist/src/command-input-loaders-architecture-compat-delivery-complexity.js +132 -0
  180. package/dist/src/command-input-loaders-architecture-compat-pattern-runtime.d.ts +2 -0
  181. package/dist/src/command-input-loaders-architecture-compat-pattern-runtime.js +54 -0
  182. package/dist/src/command-input-loaders-architecture-compat-scenario.d.ts +3 -0
  183. package/dist/src/command-input-loaders-architecture-compat-scenario.js +94 -0
  184. package/dist/src/command-input-loaders-architecture-compat-shared.d.ts +17 -0
  185. package/dist/src/command-input-loaders-architecture-compat-shared.js +109 -0
  186. package/dist/src/command-input-loaders-architecture-compat-telemetry.d.ts +3 -0
  187. package/dist/src/command-input-loaders-architecture-compat-telemetry.js +137 -0
  188. package/dist/src/command-input-loaders-architecture-compat-topology-boundary.d.ts +3 -0
  189. package/dist/src/command-input-loaders-architecture-compat-topology-boundary.js +178 -0
  190. package/dist/src/command-input-loaders-architecture-compat.d.ts +4 -0
  191. package/dist/src/command-input-loaders-architecture-compat.js +4 -0
  192. package/dist/src/command-input-loaders-architecture-config.d.ts +34 -0
  193. package/dist/src/command-input-loaders-architecture-config.js +25 -0
  194. package/dist/src/command-input-loaders-architecture-data.d.ts +17 -0
  195. package/dist/src/command-input-loaders-architecture-data.js +47 -0
  196. package/dist/src/command-input-loaders-architecture.d.ts +2 -0
  197. package/dist/src/command-input-loaders-architecture.js +2 -0
  198. package/dist/src/command-input-loaders-core.d.ts +20 -0
  199. package/dist/src/command-input-loaders-core.js +58 -0
  200. package/dist/src/command-input-loaders.d.ts +2 -0
  201. package/dist/src/command-input-loaders.js +2 -0
  202. package/dist/src/command-path-helpers.d.ts +6 -0
  203. package/dist/src/command-path-helpers.js +15 -0
  204. package/dist/src/command-score-driven.d.ts +19 -0
  205. package/dist/src/command-score-driven.js +96 -0
  206. package/dist/src/command-score.d.ts +3 -0
  207. package/dist/src/command-score.js +78 -0
  208. package/dist/src/command-shadow-rollout-batch.d.ts +5 -0
  209. package/dist/src/command-shadow-rollout-batch.js +85 -0
  210. package/dist/src/command-shadow-rollout-gate.d.ts +5 -0
  211. package/dist/src/command-shadow-rollout-gate.js +33 -0
  212. package/dist/src/command-shadow-rollout-observe.d.ts +5 -0
  213. package/dist/src/command-shadow-rollout-observe.js +43 -0
  214. package/dist/src/command-shadow-rollout-shared.d.ts +4 -0
  215. package/dist/src/command-shadow-rollout-shared.js +23 -0
  216. package/dist/src/command-shadow-rollout.d.ts +2 -0
  217. package/dist/src/command-shadow-rollout.js +16 -0
  218. package/dist/src/command-types.d.ts +4 -0
  219. package/dist/src/command-types.js +1 -0
  220. package/dist/src/commands.d.ts +6 -0
  221. package/dist/src/commands.js +66 -0
  222. package/dist/src/core/aggregate-fitness-core.d.ts +24 -0
  223. package/dist/src/core/aggregate-fitness-core.js +40 -0
  224. package/dist/src/core/aggregate-fitness-evidence.d.ts +2 -0
  225. package/dist/src/core/aggregate-fitness-evidence.js +24 -0
  226. package/dist/src/core/aggregate-fitness-mapping.d.ts +17 -0
  227. package/dist/src/core/aggregate-fitness-mapping.js +57 -0
  228. package/dist/src/core/aggregate-fitness-scoring.d.ts +24 -0
  229. package/dist/src/core/aggregate-fitness-scoring.js +71 -0
  230. package/dist/src/core/aggregate-fitness-shared.d.ts +21 -0
  231. package/dist/src/core/aggregate-fitness-shared.js +127 -0
  232. package/dist/src/core/aggregate-fitness.d.ts +2 -0
  233. package/dist/src/core/aggregate-fitness.js +1 -0
  234. package/dist/src/core/architecture-purity-core.d.ts +3 -0
  235. package/dist/src/core/architecture-purity-core.js +94 -0
  236. package/dist/src/core/architecture-purity-types.d.ts +18 -0
  237. package/dist/src/core/architecture-purity-types.js +1 -0
  238. package/dist/src/core/architecture-scenario-quality.d.ts +5 -0
  239. package/dist/src/core/architecture-scenario-quality.js +52 -0
  240. package/dist/src/core/architecture-scoring-evidence-architecture.d.ts +10 -0
  241. package/dist/src/core/architecture-scoring-evidence-architecture.js +50 -0
  242. package/dist/src/core/architecture-scoring-evidence-findings.d.ts +2 -0
  243. package/dist/src/core/architecture-scoring-evidence-findings.js +2 -0
  244. package/dist/src/core/architecture-scoring-evidence-inputs-ingest.d.ts +5 -0
  245. package/dist/src/core/architecture-scoring-evidence-inputs-ingest.js +68 -0
  246. package/dist/src/core/architecture-scoring-evidence-inputs-shared.d.ts +20 -0
  247. package/dist/src/core/architecture-scoring-evidence-inputs-shared.js +24 -0
  248. package/dist/src/core/architecture-scoring-evidence-inputs-source.d.ts +7 -0
  249. package/dist/src/core/architecture-scoring-evidence-inputs-source.js +16 -0
  250. package/dist/src/core/architecture-scoring-evidence-inputs.d.ts +2 -0
  251. package/dist/src/core/architecture-scoring-evidence-inputs.js +2 -0
  252. package/dist/src/core/architecture-scoring-evidence-observability.d.ts +12 -0
  253. package/dist/src/core/architecture-scoring-evidence-observability.js +75 -0
  254. package/dist/src/core/architecture-scoring-evidence.d.ts +30 -0
  255. package/dist/src/core/architecture-scoring-evidence.js +76 -0
  256. package/dist/src/core/architecture-scoring-evolution-inputs.d.ts +10 -0
  257. package/dist/src/core/architecture-scoring-evolution-inputs.js +56 -0
  258. package/dist/src/core/architecture-scoring-inputs-complexity.d.ts +7 -0
  259. package/dist/src/core/architecture-scoring-inputs-complexity.js +24 -0
  260. package/dist/src/core/architecture-scoring-inputs-observability.d.ts +11 -0
  261. package/dist/src/core/architecture-scoring-inputs-observability.js +84 -0
  262. package/dist/src/core/architecture-scoring-inputs-static.d.ts +13 -0
  263. package/dist/src/core/architecture-scoring-inputs-static.js +48 -0
  264. package/dist/src/core/architecture-scoring-inputs.d.ts +9 -0
  265. package/dist/src/core/architecture-scoring-inputs.js +16 -0
  266. package/dist/src/core/architecture-scoring-metric-shared.d.ts +11 -0
  267. package/dist/src/core/architecture-scoring-metric-shared.js +3 -0
  268. package/dist/src/core/architecture-scoring-metrics-composite.d.ts +3 -0
  269. package/dist/src/core/architecture-scoring-metrics-composite.js +56 -0
  270. package/dist/src/core/architecture-scoring-metrics-core.d.ts +3 -0
  271. package/dist/src/core/architecture-scoring-metrics-core.js +81 -0
  272. package/dist/src/core/architecture-scoring-metrics-evolution.d.ts +3 -0
  273. package/dist/src/core/architecture-scoring-metrics-evolution.js +74 -0
  274. package/dist/src/core/architecture-scoring-metrics-runtime.d.ts +3 -0
  275. package/dist/src/core/architecture-scoring-metrics-runtime.js +68 -0
  276. package/dist/src/core/architecture-scoring-metrics.d.ts +4 -0
  277. package/dist/src/core/architecture-scoring-metrics.js +14 -0
  278. package/dist/src/core/architecture-scoring-types.d.ts +94 -0
  279. package/dist/src/core/architecture-scoring-types.js +1 -0
  280. package/dist/src/core/architecture-scoring.d.ts +9 -0
  281. package/dist/src/core/architecture-scoring.js +82 -0
  282. package/dist/src/core/artifacts.d.ts +3 -0
  283. package/dist/src/core/artifacts.js +58 -0
  284. package/dist/src/core/boundary-fitness-attraction.d.ts +4 -0
  285. package/dist/src/core/boundary-fitness-attraction.js +11 -0
  286. package/dist/src/core/boundary-fitness-contexts.d.ts +7 -0
  287. package/dist/src/core/boundary-fitness-contexts.js +80 -0
  288. package/dist/src/core/boundary-fitness-core.d.ts +28 -0
  289. package/dist/src/core/boundary-fitness-core.js +132 -0
  290. package/dist/src/core/boundary-fitness-evidence.d.ts +17 -0
  291. package/dist/src/core/boundary-fitness-evidence.js +27 -0
  292. package/dist/src/core/boundary-fitness-separation.d.ts +13 -0
  293. package/dist/src/core/boundary-fitness-separation.js +14 -0
  294. package/dist/src/core/boundary-fitness-shared.d.ts +3 -0
  295. package/dist/src/core/boundary-fitness-shared.js +17 -0
  296. package/dist/src/core/boundary-fitness-signals.d.ts +21 -0
  297. package/dist/src/core/boundary-fitness-signals.js +104 -0
  298. package/dist/src/core/boundary-fitness.d.ts +3 -0
  299. package/dist/src/core/boundary-fitness.js +2 -0
  300. package/dist/src/core/command-analytics.d.ts +32 -0
  301. package/dist/src/core/command-analytics.js +80 -0
  302. package/dist/src/core/contracts/analysis.d.ts +105 -0
  303. package/dist/src/core/contracts/analysis.js +1 -0
  304. package/dist/src/core/contracts/architecture-complexity.d.ts +20 -0
  305. package/dist/src/core/contracts/architecture-complexity.js +1 -0
  306. package/dist/src/core/contracts/architecture-constraints.d.ts +62 -0
  307. package/dist/src/core/contracts/architecture-constraints.js +1 -0
  308. package/dist/src/core/contracts/architecture-contract-baseline.d.ts +33 -0
  309. package/dist/src/core/contracts/architecture-contract-baseline.js +1 -0
  310. package/dist/src/core/contracts/architecture-delivery.d.ts +42 -0
  311. package/dist/src/core/contracts/architecture-delivery.js +1 -0
  312. package/dist/src/core/contracts/architecture-normalization.d.ts +6 -0
  313. package/dist/src/core/contracts/architecture-normalization.js +1 -0
  314. package/dist/src/core/contracts/architecture-pattern-runtime.d.ts +69 -0
  315. package/dist/src/core/contracts/architecture-pattern-runtime.js +1 -0
  316. package/dist/src/core/contracts/architecture-scenarios.d.ts +62 -0
  317. package/dist/src/core/contracts/architecture-scenarios.js +1 -0
  318. package/dist/src/core/contracts/architecture-telemetry.d.ts +47 -0
  319. package/dist/src/core/contracts/architecture-telemetry.js +1 -0
  320. package/dist/src/core/contracts/architecture-topology.d.ts +35 -0
  321. package/dist/src/core/contracts/architecture-topology.js +1 -0
  322. package/dist/src/core/contracts/architecture.d.ts +9 -0
  323. package/dist/src/core/contracts/architecture.js +9 -0
  324. package/dist/src/core/contracts/common.d.ts +87 -0
  325. package/dist/src/core/contracts/common.js +1 -0
  326. package/dist/src/core/contracts/domain-design-score.d.ts +14 -0
  327. package/dist/src/core/contracts/domain-design-score.js +1 -0
  328. package/dist/src/core/contracts/domain-design-shadow-rollout-batch.d.ts +58 -0
  329. package/dist/src/core/contracts/domain-design-shadow-rollout-batch.js +1 -0
  330. package/dist/src/core/contracts/domain-design-shadow-rollout-gate.d.ts +46 -0
  331. package/dist/src/core/contracts/domain-design-shadow-rollout-gate.js +1 -0
  332. package/dist/src/core/contracts/domain-design-shadow-rollout-observation.d.ts +17 -0
  333. package/dist/src/core/contracts/domain-design-shadow-rollout-observation.js +1 -0
  334. package/dist/src/core/contracts/domain-design-shadow-rollout-registry.d.ts +15 -0
  335. package/dist/src/core/contracts/domain-design-shadow-rollout-registry.js +1 -0
  336. package/dist/src/core/contracts/domain-design.d.ts +5 -0
  337. package/dist/src/core/contracts/domain-design.js +5 -0
  338. package/dist/src/core/contracts/domain-model.d.ts +35 -0
  339. package/dist/src/core/contracts/domain-model.js +1 -0
  340. package/dist/src/core/contracts/governance-extraction.d.ts +65 -0
  341. package/dist/src/core/contracts/governance-extraction.js +1 -0
  342. package/dist/src/core/contracts/governance-policy.d.ts +23 -0
  343. package/dist/src/core/contracts/governance-policy.js +1 -0
  344. package/dist/src/core/contracts/governance-review.d.ts +31 -0
  345. package/dist/src/core/contracts/governance-review.js +1 -0
  346. package/dist/src/core/contracts/governance-runtime.d.ts +12 -0
  347. package/dist/src/core/contracts/governance-runtime.js +1 -0
  348. package/dist/src/core/contracts/governance-scoring.d.ts +41 -0
  349. package/dist/src/core/contracts/governance-scoring.js +1 -0
  350. package/dist/src/core/contracts/governance.d.ts +5 -0
  351. package/dist/src/core/contracts/governance.js +5 -0
  352. package/dist/src/core/contracts.d.ts +6 -0
  353. package/dist/src/core/contracts.js +6 -0
  354. package/dist/src/core/document-extractor-glossary.d.ts +3 -0
  355. package/dist/src/core/document-extractor-glossary.js +90 -0
  356. package/dist/src/core/document-extractor-identity.d.ts +18 -0
  357. package/dist/src/core/document-extractor-identity.js +37 -0
  358. package/dist/src/core/document-extractor-shared.d.ts +3 -0
  359. package/dist/src/core/document-extractor-shared.js +2 -0
  360. package/dist/src/core/document-extractor-statements-classification-cli.d.ts +3 -0
  361. package/dist/src/core/document-extractor-statements-classification-cli.js +50 -0
  362. package/dist/src/core/document-extractor-statements-classification-core.d.ts +17 -0
  363. package/dist/src/core/document-extractor-statements-classification-core.js +91 -0
  364. package/dist/src/core/document-extractor-statements-classification-heuristic.d.ts +3 -0
  365. package/dist/src/core/document-extractor-statements-classification-heuristic.js +32 -0
  366. package/dist/src/core/document-extractor-statements-classification.d.ts +2 -0
  367. package/dist/src/core/document-extractor-statements-classification.js +2 -0
  368. package/dist/src/core/document-extractor-statements-segments.d.ts +3 -0
  369. package/dist/src/core/document-extractor-statements-segments.js +38 -0
  370. package/dist/src/core/document-extractor-statements.d.ts +1 -0
  371. package/dist/src/core/document-extractor-statements.js +1 -0
  372. package/dist/src/core/document-extractor-text-normalization.d.ts +5 -0
  373. package/dist/src/core/document-extractor-text-normalization.js +29 -0
  374. package/dist/src/core/document-extractor-text-review.d.ts +3 -0
  375. package/dist/src/core/document-extractor-text-review.js +15 -0
  376. package/dist/src/core/document-extractor-text-signals.d.ts +11 -0
  377. package/dist/src/core/document-extractor-text-signals.js +115 -0
  378. package/dist/src/core/document-extractor-text.d.ts +3 -0
  379. package/dist/src/core/document-extractor-text.js +3 -0
  380. package/dist/src/core/document-extractor-types.d.ts +30 -0
  381. package/dist/src/core/document-extractor-types.js +1 -0
  382. package/dist/src/core/document-extractors-review.d.ts +4 -0
  383. package/dist/src/core/document-extractors-review.js +10 -0
  384. package/dist/src/core/document-extractors-runner.d.ts +15 -0
  385. package/dist/src/core/document-extractors-runner.js +31 -0
  386. package/dist/src/core/document-extractors.d.ts +24 -0
  387. package/dist/src/core/document-extractors.js +130 -0
  388. package/dist/src/core/domain-design-matching.d.ts +2 -0
  389. package/dist/src/core/domain-design-matching.js +85 -0
  390. package/dist/src/core/domain-design-scoring-context.d.ts +25 -0
  391. package/dist/src/core/domain-design-scoring-context.js +66 -0
  392. package/dist/src/core/domain-design-scoring-core-docs.d.ts +5 -0
  393. package/dist/src/core/domain-design-scoring-core-docs.js +8 -0
  394. package/dist/src/core/domain-design-scoring-core.d.ts +24 -0
  395. package/dist/src/core/domain-design-scoring-core.js +137 -0
  396. package/dist/src/core/domain-design-scoring-docs-afs.d.ts +2 -0
  397. package/dist/src/core/domain-design-scoring-docs-afs.js +40 -0
  398. package/dist/src/core/domain-design-scoring-docs-bfs.d.ts +2 -0
  399. package/dist/src/core/domain-design-scoring-docs-bfs.js +46 -0
  400. package/dist/src/core/domain-design-scoring-docs-core.d.ts +12 -0
  401. package/dist/src/core/domain-design-scoring-docs-core.js +47 -0
  402. package/dist/src/core/domain-design-scoring-docs-drf.d.ts +2 -0
  403. package/dist/src/core/domain-design-scoring-docs-drf.js +55 -0
  404. package/dist/src/core/domain-design-scoring-docs-shared.d.ts +25 -0
  405. package/dist/src/core/domain-design-scoring-docs-shared.js +1 -0
  406. package/dist/src/core/domain-design-scoring-docs-uli.d.ts +2 -0
  407. package/dist/src/core/domain-design-scoring-docs-uli.js +39 -0
  408. package/dist/src/core/domain-design-scoring-docs.d.ts +1 -0
  409. package/dist/src/core/domain-design-scoring-docs.js +1 -0
  410. package/dist/src/core/domain-design-scoring-locality.d.ts +27 -0
  411. package/dist/src/core/domain-design-scoring-locality.js +87 -0
  412. package/dist/src/core/domain-design-scoring-mccs.d.ts +18 -0
  413. package/dist/src/core/domain-design-scoring-mccs.js +29 -0
  414. package/dist/src/core/domain-design-scoring-pilot.d.ts +13 -0
  415. package/dist/src/core/domain-design-scoring-pilot.js +57 -0
  416. package/dist/src/core/domain-design-scoring-response-shared.d.ts +20 -0
  417. package/dist/src/core/domain-design-scoring-response-shared.js +30 -0
  418. package/dist/src/core/domain-design-scoring-response.d.ts +18 -0
  419. package/dist/src/core/domain-design-scoring-response.js +27 -0
  420. package/dist/src/core/domain-design-scoring-support-drf.d.ts +17 -0
  421. package/dist/src/core/domain-design-scoring-support-drf.js +118 -0
  422. package/dist/src/core/domain-design-scoring-support-persistence.d.ts +6 -0
  423. package/dist/src/core/domain-design-scoring-support-persistence.js +8 -0
  424. package/dist/src/core/domain-design-scoring-support-uli.d.ts +12 -0
  425. package/dist/src/core/domain-design-scoring-support-uli.js +31 -0
  426. package/dist/src/core/domain-design-scoring-support.d.ts +3 -0
  427. package/dist/src/core/domain-design-scoring-support.js +3 -0
  428. package/dist/src/core/domain-design-scoring.d.ts +1 -0
  429. package/dist/src/core/domain-design-scoring.js +1 -0
  430. package/dist/src/core/formula-parser-tokenize.d.ts +14 -0
  431. package/dist/src/core/formula-parser-tokenize.js +58 -0
  432. package/dist/src/core/formula-parser.d.ts +1 -0
  433. package/dist/src/core/formula-parser.js +91 -0
  434. package/dist/src/core/formula.d.ts +1 -0
  435. package/dist/src/core/formula.js +1 -0
  436. package/dist/src/core/history-locality.d.ts +5 -0
  437. package/dist/src/core/history-locality.js +48 -0
  438. package/dist/src/core/history-normalization.d.ts +13 -0
  439. package/dist/src/core/history-normalization.js +105 -0
  440. package/dist/src/core/history-persistence-analysis.d.ts +6 -0
  441. package/dist/src/core/history-persistence-analysis.js +26 -0
  442. package/dist/src/core/history-persistence-clusters.d.ts +6 -0
  443. package/dist/src/core/history-persistence-clusters.js +9 -0
  444. package/dist/src/core/history-persistence-comparison.d.ts +6 -0
  445. package/dist/src/core/history-persistence-comparison.js +66 -0
  446. package/dist/src/core/history-persistence-components.d.ts +8 -0
  447. package/dist/src/core/history-persistence-components.js +99 -0
  448. package/dist/src/core/history-persistence-stability.d.ts +8 -0
  449. package/dist/src/core/history-persistence-stability.js +79 -0
  450. package/dist/src/core/history-persistence.d.ts +2 -0
  451. package/dist/src/core/history-persistence.js +2 -0
  452. package/dist/src/core/history-shared.d.ts +27 -0
  453. package/dist/src/core/history-shared.js +145 -0
  454. package/dist/src/core/history.d.ts +3 -0
  455. package/dist/src/core/history.js +3 -0
  456. package/dist/src/core/io.d.ts +9 -0
  457. package/dist/src/core/io.js +86 -0
  458. package/dist/src/core/measurement-metadata.d.ts +13 -0
  459. package/dist/src/core/measurement-metadata.js +142 -0
  460. package/dist/src/core/model.d.ts +3 -0
  461. package/dist/src/core/model.js +33 -0
  462. package/dist/src/core/policy-defaults-architecture.d.ts +2 -0
  463. package/dist/src/core/policy-defaults-architecture.js +75 -0
  464. package/dist/src/core/policy-defaults-domain.d.ts +2 -0
  465. package/dist/src/core/policy-defaults-domain.js +51 -0
  466. package/dist/src/core/policy-defaults-profiles.d.ts +2 -0
  467. package/dist/src/core/policy-defaults-profiles.js +24 -0
  468. package/dist/src/core/policy-defaults.d.ts +2 -0
  469. package/dist/src/core/policy-defaults.js +4 -0
  470. package/dist/src/core/policy-formulas.d.ts +5 -0
  471. package/dist/src/core/policy-formulas.js +5 -0
  472. package/dist/src/core/policy.d.ts +4 -0
  473. package/dist/src/core/policy.js +20 -0
  474. package/dist/src/core/progress.d.ts +8 -0
  475. package/dist/src/core/progress.js +40 -0
  476. package/dist/src/core/providers-normalization.d.ts +7 -0
  477. package/dist/src/core/providers-normalization.js +27 -0
  478. package/dist/src/core/providers-prompt.d.ts +4 -0
  479. package/dist/src/core/providers-prompt.js +63 -0
  480. package/dist/src/core/providers-runner.d.ts +3 -0
  481. package/dist/src/core/providers-runner.js +32 -0
  482. package/dist/src/core/providers-types.d.ts +10 -0
  483. package/dist/src/core/providers-types.js +1 -0
  484. package/dist/src/core/providers.d.ts +4 -0
  485. package/dist/src/core/providers.js +30 -0
  486. package/dist/src/core/report-actionability.d.ts +4 -0
  487. package/dist/src/core/report-actionability.js +57 -0
  488. package/dist/src/core/report-architecture.d.ts +2 -0
  489. package/dist/src/core/report-architecture.js +80 -0
  490. package/dist/src/core/report-domain.d.ts +2 -0
  491. package/dist/src/core/report-domain.js +50 -0
  492. package/dist/src/core/report-gate.d.ts +3 -0
  493. package/dist/src/core/report-gate.js +54 -0
  494. package/dist/src/core/report-shared-format.d.ts +2 -0
  495. package/dist/src/core/report-shared-format.js +6 -0
  496. package/dist/src/core/report-shared-guidance.d.ts +2 -0
  497. package/dist/src/core/report-shared-guidance.js +98 -0
  498. package/dist/src/core/report-shared-predicates.d.ts +17 -0
  499. package/dist/src/core/report-shared-predicates.js +9 -0
  500. package/dist/src/core/report-shared.d.ts +4 -0
  501. package/dist/src/core/report-shared.js +3 -0
  502. package/dist/src/core/report.d.ts +3 -0
  503. package/dist/src/core/report.js +10 -0
  504. package/dist/src/core/response.d.ts +8 -0
  505. package/dist/src/core/response.js +67 -0
  506. package/dist/src/core/review-items.d.ts +2 -0
  507. package/dist/src/core/review-items.js +116 -0
  508. package/dist/src/core/review-resolutions.d.ts +3 -0
  509. package/dist/src/core/review-resolutions.js +43 -0
  510. package/dist/src/core/review.d.ts +2 -0
  511. package/dist/src/core/review.js +2 -0
  512. package/dist/src/core/scaffold-aggregation.d.ts +13 -0
  513. package/dist/src/core/scaffold-aggregation.js +18 -0
  514. package/dist/src/core/scaffold-architecture-balances.d.ts +3 -0
  515. package/dist/src/core/scaffold-architecture-balances.js +25 -0
  516. package/dist/src/core/scaffold-architecture-drafts-builders.d.ts +19 -0
  517. package/dist/src/core/scaffold-architecture-drafts-builders.js +114 -0
  518. package/dist/src/core/scaffold-architecture-drafts-profiles.d.ts +11 -0
  519. package/dist/src/core/scaffold-architecture-drafts-profiles.js +183 -0
  520. package/dist/src/core/scaffold-architecture-drafts.d.ts +12 -0
  521. package/dist/src/core/scaffold-architecture-drafts.js +4 -0
  522. package/dist/src/core/scaffold-architecture-layer-candidates.d.ts +3 -0
  523. package/dist/src/core/scaffold-architecture-layer-candidates.js +32 -0
  524. package/dist/src/core/scaffold-architecture-layers.d.ts +3 -0
  525. package/dist/src/core/scaffold-architecture-layers.js +15 -0
  526. package/dist/src/core/scaffold-architecture-orchestration.d.ts +5 -0
  527. package/dist/src/core/scaffold-architecture-orchestration.js +36 -0
  528. package/dist/src/core/scaffold-architecture-ordering.d.ts +4 -0
  529. package/dist/src/core/scaffold-architecture-ordering.js +55 -0
  530. package/dist/src/core/scaffold-architecture.d.ts +1 -0
  531. package/dist/src/core/scaffold-architecture.js +1 -0
  532. package/dist/src/core/scaffold-domain-aggregates-candidates.d.ts +4 -0
  533. package/dist/src/core/scaffold-domain-aggregates-candidates.js +8 -0
  534. package/dist/src/core/scaffold-domain-aggregates-core.d.ts +1 -0
  535. package/dist/src/core/scaffold-domain-aggregates-core.js +1 -0
  536. package/dist/src/core/scaffold-domain-aggregates-dedupe.d.ts +2 -0
  537. package/dist/src/core/scaffold-domain-aggregates-dedupe.js +18 -0
  538. package/dist/src/core/scaffold-domain-aggregates-explicit.d.ts +4 -0
  539. package/dist/src/core/scaffold-domain-aggregates-explicit.js +43 -0
  540. package/dist/src/core/scaffold-domain-aggregates-inferred.d.ts +4 -0
  541. package/dist/src/core/scaffold-domain-aggregates-inferred.js +117 -0
  542. package/dist/src/core/scaffold-domain-aggregates-shared.d.ts +23 -0
  543. package/dist/src/core/scaffold-domain-aggregates-shared.js +91 -0
  544. package/dist/src/core/scaffold-domain-aggregates.d.ts +1 -0
  545. package/dist/src/core/scaffold-domain-aggregates.js +1 -0
  546. package/dist/src/core/scaffold-domain-context-candidates.d.ts +5 -0
  547. package/dist/src/core/scaffold-domain-context-candidates.js +65 -0
  548. package/dist/src/core/scaffold-domain-context-naming.d.ts +8 -0
  549. package/dist/src/core/scaffold-domain-context-naming.js +117 -0
  550. package/dist/src/core/scaffold-domain-contexts.d.ts +11 -0
  551. package/dist/src/core/scaffold-domain-contexts.js +75 -0
  552. package/dist/src/core/scaffold-domain-docs.d.ts +17 -0
  553. package/dist/src/core/scaffold-domain-docs.js +18 -0
  554. package/dist/src/core/scaffold-domain.d.ts +7 -0
  555. package/dist/src/core/scaffold-domain.js +62 -0
  556. package/dist/src/core/scaffold-naming.d.ts +4 -0
  557. package/dist/src/core/scaffold-naming.js +32 -0
  558. package/dist/src/core/scaffold-options.d.ts +2 -0
  559. package/dist/src/core/scaffold-options.js +10 -0
  560. package/dist/src/core/scaffold-shared.d.ts +5 -0
  561. package/dist/src/core/scaffold-shared.js +4 -0
  562. package/dist/src/core/scaffold-source-group-classification.d.ts +3 -0
  563. package/dist/src/core/scaffold-source-group-classification.js +91 -0
  564. package/dist/src/core/scaffold-source-group-constants.d.ts +3 -0
  565. package/dist/src/core/scaffold-source-group-constants.js +52 -0
  566. package/dist/src/core/scaffold-source-group-merge.d.ts +5 -0
  567. package/dist/src/core/scaffold-source-group-merge.js +56 -0
  568. package/dist/src/core/scaffold-source-group-naming.d.ts +4 -0
  569. package/dist/src/core/scaffold-source-group-naming.js +66 -0
  570. package/dist/src/core/scaffold-source-groups.d.ts +5 -0
  571. package/dist/src/core/scaffold-source-groups.js +123 -0
  572. package/dist/src/core/scaffold-types.d.ts +30 -0
  573. package/dist/src/core/scaffold-types.js +1 -0
  574. package/dist/src/core/scaffold.d.ts +2 -0
  575. package/dist/src/core/scaffold.js +2 -0
  576. package/dist/src/core/scoring-shared.d.ts +12 -0
  577. package/dist/src/core/scoring-shared.js +39 -0
  578. package/dist/src/core/scoring.d.ts +2 -0
  579. package/dist/src/core/scoring.js +2 -0
  580. package/dist/src/core/shadow-rollout-gate-reasons.d.ts +8 -0
  581. package/dist/src/core/shadow-rollout-gate-reasons.js +22 -0
  582. package/dist/src/core/shadow-rollout-gate-summary.d.ts +2 -0
  583. package/dist/src/core/shadow-rollout-gate-summary.js +36 -0
  584. package/dist/src/core/shadow-rollout-gate.d.ts +2 -0
  585. package/dist/src/core/shadow-rollout-gate.js +50 -0
  586. package/dist/src/core/shadow-rollout-registry.d.ts +5 -0
  587. package/dist/src/core/shadow-rollout-registry.js +31 -0
  588. package/dist/src/core/shadow-rollout-summary.d.ts +4 -0
  589. package/dist/src/core/shadow-rollout-summary.js +39 -0
  590. package/dist/src/core/shadow-rollout.d.ts +3 -0
  591. package/dist/src/core/shadow-rollout.js +3 -0
  592. package/dist/src/core/shared-utils.d.ts +4 -0
  593. package/dist/src/core/shared-utils.js +15 -0
  594. package/dist/src/core/trace.d.ts +14 -0
  595. package/dist/src/core/trace.js +118 -0
  596. package/dist/src/index.d.ts +7 -0
  597. package/dist/src/index.js +7 -0
  598. package/dist/src/packs/index.d.ts +2 -0
  599. package/dist/src/packs/index.js +36 -0
  600. package/package.json +68 -0
@@ -0,0 +1,127 @@
1
+ import { normalizeDomainDesignLabel, scoreTextAgainstLabel } from "./domain-design-matching.js";
2
+ import { average, clamp01Finite as clamp01, unique } from "./shared-utils.js";
3
+ const STRONG_CONSISTENCY_SIGNALS = [
4
+ /一致/u,
5
+ /整合/u,
6
+ /同時/u,
7
+ /両方/u,
8
+ /またが/u,
9
+ /跨/u,
10
+ /同じ.*(?:更新|確定)/u,
11
+ /\bconsistent\b/i,
12
+ /\bsame transaction\b/i,
13
+ ];
14
+ const OBLIGATION_SIGNALS = [/なければならない/u, /べき/u, /\bmust\b/i];
15
+ export { average, clamp01, unique };
16
+ export function localizationScore(contexts) {
17
+ if (contexts.length === 0) {
18
+ return 0.35;
19
+ }
20
+ return 1 / contexts.length;
21
+ }
22
+ function isStrongConsistencyInvariant(statement) {
23
+ return STRONG_CONSISTENCY_SIGNALS.some((pattern) => pattern.test(statement));
24
+ }
25
+ export function impliesStrongConsistencyWrite(statement) {
26
+ return isStrongConsistencyInvariant(statement) || OBLIGATION_SIGNALS.some((pattern) => pattern.test(statement));
27
+ }
28
+ export function collectAggregateTargets(aggregateDefinitions, contexts, invariant, mappedTerms = []) {
29
+ if (aggregateDefinitions.length === 0) {
30
+ return { targets: [], unknowns: [], hasAnchorEvidence: false };
31
+ }
32
+ const unknowns = [];
33
+ const eligibleAggregates = contexts.length === 0
34
+ ? aggregateDefinitions
35
+ : aggregateDefinitions.filter((aggregate) => contexts.includes(aggregate.context));
36
+ const relatedTerms = invariant.relatedTerms ?? [];
37
+ const statementBackedTermLabels = unique(mappedTerms
38
+ .filter((term) => term.contexts.length > 0 &&
39
+ (contexts.length === 0 || term.contexts.some((context) => contexts.includes(context))))
40
+ .filter((term) => term.labels.some((label) => scoreTextAgainstLabel(invariant.statement, label) > 0) ||
41
+ relatedTerms.some((relatedTerm) => term.labels.some((label) => scoreTextAgainstLabel(relatedTerm, label) > 0)))
42
+ .flatMap((term) => term.labels));
43
+ const scoredCandidates = eligibleAggregates
44
+ .map((aggregate) => {
45
+ const labels = unique([aggregate.name, ...(aggregate.aliases ?? [])]);
46
+ const directScore = Math.max(0, ...labels.map((label) => scoreTextAgainstLabel(invariant.statement, label)));
47
+ const relatedScore = Math.max(0, ...relatedTerms.flatMap((term) => labels.map((label) => scoreTextAgainstLabel(term, label))));
48
+ const glossaryScore = Math.max(0, ...statementBackedTermLabels.flatMap((term) => labels.map((label) => scoreTextAgainstLabel(term, label))));
49
+ return {
50
+ aggregate,
51
+ bestDirectLabels: directScore > 0
52
+ ? labels.filter((label) => scoreTextAgainstLabel(invariant.statement, label) === directScore)
53
+ : [],
54
+ bestRelatedLabels: relatedScore > 0
55
+ ? labels.filter((label) => relatedTerms.some((term) => scoreTextAgainstLabel(term, label) === relatedScore))
56
+ : [],
57
+ directScore,
58
+ relatedScore,
59
+ score: directScore * 3 + relatedScore * 2 + glossaryScore,
60
+ };
61
+ })
62
+ .filter((candidate) => candidate.score > 0)
63
+ .sort((left, right) => right.score - left.score);
64
+ if (scoredCandidates.length > 0) {
65
+ const strongMatches = scoredCandidates.filter((candidate) => candidate.directScore >= 2 || candidate.relatedScore >= 2);
66
+ if (strongMatches.length > 0) {
67
+ const distinctStrongLabels = unique(strongMatches.flatMap((candidate) => (candidate.directScore >= 2 ? candidate.bestDirectLabels : candidate.bestRelatedLabels).map((label) => normalizeDomainDesignLabel(label))));
68
+ if (strongMatches.length === 1 || distinctStrongLabels.length > 1) {
69
+ return {
70
+ targets: strongMatches.map((candidate) => `${candidate.aggregate.context}::${candidate.aggregate.name}`),
71
+ unknowns,
72
+ hasAnchorEvidence: true,
73
+ };
74
+ }
75
+ if (contexts.length === 1) {
76
+ unknowns.push(`Invariant "${invariant.invariantId}" could not be mapped to a specific aggregate within ${contexts[0]}.`);
77
+ }
78
+ return {
79
+ targets: [],
80
+ unknowns,
81
+ hasAnchorEvidence: true,
82
+ };
83
+ }
84
+ const best = scoredCandidates[0];
85
+ const runnerUp = scoredCandidates[1];
86
+ const topCandidates = best ? scoredCandidates.filter((candidate) => candidate.score === best.score) : [];
87
+ if (topCandidates.length > 1 && best) {
88
+ const distinctDirectLabels = unique(topCandidates.flatMap((candidate) => candidate.bestDirectLabels.map((label) => normalizeDomainDesignLabel(label))));
89
+ if (distinctDirectLabels.length > 1) {
90
+ return {
91
+ targets: topCandidates.map((candidate) => `${candidate.aggregate.context}::${candidate.aggregate.name}`),
92
+ unknowns,
93
+ hasAnchorEvidence: true,
94
+ };
95
+ }
96
+ if (contexts.length === 1) {
97
+ unknowns.push(`Invariant "${invariant.invariantId}" could not be mapped to a specific aggregate within ${contexts[0]}.`);
98
+ }
99
+ return { targets: [], unknowns, hasAnchorEvidence: true };
100
+ }
101
+ if (best && (!runnerUp || best.score > runnerUp.score)) {
102
+ return {
103
+ targets: [`${best.aggregate.context}::${best.aggregate.name}`],
104
+ unknowns,
105
+ hasAnchorEvidence: true,
106
+ };
107
+ }
108
+ if (contexts.length === 1) {
109
+ unknowns.push(`Invariant "${invariant.invariantId}" could not be mapped to a specific aggregate within ${contexts[0]}.`);
110
+ }
111
+ return { targets: [], unknowns, hasAnchorEvidence: true };
112
+ }
113
+ if (contexts.length === 1) {
114
+ const sameContextAggregates = aggregateDefinitions.filter((aggregate) => aggregate.context === contexts[0]);
115
+ if (sameContextAggregates.length === 1) {
116
+ return {
117
+ targets: [`${sameContextAggregates[0]?.context}::${sameContextAggregates[0]?.name}`],
118
+ unknowns,
119
+ hasAnchorEvidence: false,
120
+ };
121
+ }
122
+ if (sameContextAggregates.length > 1) {
123
+ unknowns.push(`Invariant "${invariant.invariantId}" could not be mapped to a specific aggregate within ${contexts[0]}.`);
124
+ }
125
+ }
126
+ return { targets: [], unknowns, hasAnchorEvidence: false };
127
+ }
@@ -0,0 +1,2 @@
1
+ export type { AggregateFitnessResult } from "./aggregate-fitness-core.js";
2
+ export { computeAggregateFitness } from "./aggregate-fitness-core.js";
@@ -0,0 +1 @@
1
+ export { computeAggregateFitness } from "./aggregate-fitness-core.js";
@@ -0,0 +1,3 @@
1
+ import type { ArchitectureConstraints, CodebaseAnalysis } from "../core/contracts.js";
2
+ import type { BoundaryPurityScore } from "./architecture-purity-types.js";
3
+ export declare function scoreBoundaryPurity(codebase: CodebaseAnalysis, constraints: ArchitectureConstraints): BoundaryPurityScore;
@@ -0,0 +1,94 @@
1
+ import { average, clamp01, isAllowedFrameworkLayer, isFrameworkish, isInternalish, } from "../analyzers/architecture-purity-signals.js";
2
+ import { getScorableDependencies } from "../analyzers/code.js";
3
+ import { classifyArchitectureLayer } from "../analyzers/contract-files.js";
4
+ function classifyLayer(filePath, constraints) {
5
+ return classifyArchitectureLayer(filePath, constraints);
6
+ }
7
+ export function scoreBoundaryPurity(codebase, constraints) {
8
+ const unknowns = [];
9
+ const findings = [];
10
+ const classifiedFiles = codebase.scorableSourceFiles
11
+ .map((filePath) => ({
12
+ path: filePath,
13
+ layer: classifyLayer(filePath, constraints),
14
+ }))
15
+ .filter((entry) => Boolean(entry.layer));
16
+ const classifiedEdges = getScorableDependencies(codebase)
17
+ .filter((dependency) => dependency.targetKind === "file")
18
+ .map((dependency) => ({
19
+ dependency,
20
+ sourceLayer: classifyLayer(dependency.source, constraints),
21
+ targetLayer: classifyLayer(dependency.target, constraints),
22
+ }))
23
+ .filter((entry) => Boolean(entry.sourceLayer && entry.targetLayer));
24
+ const maxRank = constraints.layers.reduce((current, layer) => Math.max(current, layer.rank), 0);
25
+ const adapterCandidates = classifiedEdges.filter(({ dependency, targetLayer }) => isFrameworkish(dependency.target, targetLayer.name));
26
+ const adapterLeaks = adapterCandidates.filter(({ sourceLayer, targetLayer }) => sourceLayer.rank < targetLayer.rank);
27
+ const ALR = adapterCandidates.length === 0 ? 0 : adapterLeaks.length / adapterCandidates.length;
28
+ if (adapterCandidates.length === 0) {
29
+ unknowns.push("There are too few adapter/framework-like dependencies, so ALR evidence is limited.");
30
+ }
31
+ findings.push(...adapterLeaks.map(({ dependency, sourceLayer, targetLayer }) => ({
32
+ kind: "adapter_leak",
33
+ path: dependency.source,
34
+ source: dependency.source,
35
+ target: dependency.target,
36
+ sourceLayer: sourceLayer.name,
37
+ targetLayer: targetLayer.name,
38
+ confidence: 0.92,
39
+ note: `${sourceLayer.name} depends directly on a framework/adapter-like target in ${targetLayer.name}.`,
40
+ })));
41
+ const frameworkishFiles = classifiedFiles.filter(({ path, layer }) => isFrameworkish(path, layer.name));
42
+ const frameworkContaminations = frameworkishFiles.filter(({ layer }) => !isAllowedFrameworkLayer(layer, maxRank));
43
+ const FCC = frameworkishFiles.length === 0 ? 0.6 : 1 - frameworkContaminations.length / Math.max(1, frameworkishFiles.length);
44
+ if (frameworkishFiles.length === 0) {
45
+ unknowns.push("There are too few framework/adapter-like files, so FCC is conservative.");
46
+ }
47
+ findings.push(...frameworkContaminations.map(({ path, layer }) => ({
48
+ kind: "framework_contamination",
49
+ path,
50
+ sourceLayer: layer.name,
51
+ confidence: 0.86,
52
+ note: `${layer.name} contains framework/adapter-like implementation details.`,
53
+ })));
54
+ const internalTargetMap = new Map();
55
+ for (const { dependency, sourceLayer, targetLayer } of classifiedEdges) {
56
+ if (!isInternalish(dependency.target, targetLayer.name)) {
57
+ continue;
58
+ }
59
+ const entry = internalTargetMap.get(dependency.target) ?? {
60
+ targetLayer: targetLayer.name,
61
+ sourceLayers: new Set(),
62
+ };
63
+ entry.sourceLayers.add(sourceLayer.name);
64
+ internalTargetMap.set(dependency.target, entry);
65
+ }
66
+ const internalTargets = Array.from(internalTargetMap.entries());
67
+ const sharedInternalTargets = internalTargets.filter(([, entry]) => entry.sourceLayers.size > 1);
68
+ const SICR = internalTargets.length === 0 ? 0 : sharedInternalTargets.length / Math.max(1, internalTargets.length);
69
+ if (internalTargets.length === 0) {
70
+ unknowns.push("There are too few internal components to judge sharing, so SICR evidence is limited.");
71
+ }
72
+ findings.push(...sharedInternalTargets.map(([path, entry]) => ({
73
+ kind: "shared_internal_component",
74
+ path,
75
+ target: path,
76
+ targetLayer: entry.targetLayer,
77
+ confidence: 0.88,
78
+ note: `${path} is shared by multiple layers (${Array.from(entry.sourceLayers).join(", ")}).`,
79
+ })));
80
+ const confidence = clamp01(average([
81
+ classifiedEdges.length > 0 ? 0.85 : 0.5,
82
+ adapterCandidates.length > 0 ? 0.82 : 0.6,
83
+ frameworkishFiles.length > 0 ? 0.8 : 0.58,
84
+ internalTargets.length > 0 ? 0.8 : 0.58,
85
+ ], 0.6));
86
+ return {
87
+ ALR,
88
+ FCC,
89
+ SICR,
90
+ confidence,
91
+ unknowns: Array.from(new Set(unknowns)),
92
+ findings,
93
+ };
94
+ }
@@ -0,0 +1,18 @@
1
+ export interface PurityFinding {
2
+ kind: "adapter_leak" | "framework_contamination" | "shared_internal_component";
3
+ path: string;
4
+ source?: string;
5
+ target?: string;
6
+ sourceLayer?: string;
7
+ targetLayer?: string;
8
+ confidence: number;
9
+ note: string;
10
+ }
11
+ export interface BoundaryPurityScore {
12
+ ALR: number;
13
+ FCC: number;
14
+ SICR: number;
15
+ confidence: number;
16
+ unknowns: string[];
17
+ findings: PurityFinding[];
18
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,5 @@
1
+ import type { ArchitectureScenarioCatalog, ArchitectureScenarioQualitySummary, ScenarioObservationSet } from "./contracts.js";
2
+ export declare function summarizeArchitectureScenarioQuality(input: {
3
+ catalog?: ArchitectureScenarioCatalog;
4
+ observations?: ScenarioObservationSet;
5
+ }): ArchitectureScenarioQualitySummary | undefined;
@@ -0,0 +1,52 @@
1
+ function normalizeScenarioIntent(name, metric) {
2
+ return `${name ?? ""}::${metric ?? ""}`.trim().toLowerCase();
3
+ }
4
+ export function summarizeArchitectureScenarioQuality(input) {
5
+ const catalog = input.catalog;
6
+ if (!catalog || catalog.scenarios.length === 0) {
7
+ return undefined;
8
+ }
9
+ const observationIds = new Set((input.observations?.observations ?? []).map((entry) => entry.scenarioId));
10
+ const missingObservationScenarioIds = [];
11
+ const missingTopPriorityObservationIds = [];
12
+ const duplicateScenarioIds = new Set();
13
+ const findings = [];
14
+ const intentToScenarioIds = new Map();
15
+ for (const scenario of catalog.scenarios) {
16
+ const intentKey = normalizeScenarioIntent(scenario.name, scenario.responseMeasure?.metric);
17
+ if (intentKey) {
18
+ const current = intentToScenarioIds.get(intentKey) ?? [];
19
+ current.push(scenario.scenarioId);
20
+ intentToScenarioIds.set(intentKey, current);
21
+ }
22
+ if (!observationIds.has(scenario.scenarioId)) {
23
+ missingObservationScenarioIds.push(scenario.scenarioId);
24
+ if (scenario.priority >= 4) {
25
+ missingTopPriorityObservationIds.push(scenario.scenarioId);
26
+ }
27
+ }
28
+ }
29
+ for (const [intentKey, scenarioIds] of intentToScenarioIds.entries()) {
30
+ if (scenarioIds.length <= 1) {
31
+ continue;
32
+ }
33
+ scenarioIds.forEach((scenarioId) => {
34
+ duplicateScenarioIds.add(scenarioId);
35
+ });
36
+ findings.push(`Scenario intent ${intentKey || "unnamed"} is duplicated across ${scenarioIds.join(", ")} and should be tightened.`);
37
+ }
38
+ if (missingTopPriorityObservationIds.length > 0) {
39
+ findings.push(`Top-priority scenarios are missing observations: ${missingTopPriorityObservationIds.join(", ")}.`);
40
+ }
41
+ else if (missingObservationScenarioIds.length > 0) {
42
+ findings.push(`Scenario observations are still missing for ${missingObservationScenarioIds.join(", ")}.`);
43
+ }
44
+ return {
45
+ totalScenarios: catalog.scenarios.length,
46
+ observedScenarios: catalog.scenarios.length - missingObservationScenarioIds.length,
47
+ missingObservationScenarioIds,
48
+ missingTopPriorityObservationIds,
49
+ duplicateScenarioIds: Array.from(duplicateScenarioIds),
50
+ findings,
51
+ };
52
+ }
@@ -0,0 +1,10 @@
1
+ import type { ArchitectureScoringContext } from "./architecture-scoring-types.js";
2
+ import { toEvidence } from "./response.js";
3
+ type EvidenceEntry = ReturnType<typeof toEvidence>;
4
+ export declare function buildDirectionEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
5
+ export declare function buildPurityEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
6
+ export declare function buildProtocolEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
7
+ export declare function buildScenarioEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
8
+ export declare function buildTopologyEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
9
+ export declare function buildOperationsEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
10
+ export {};
@@ -0,0 +1,50 @@
1
+ import { toEvidence } from "./response.js";
2
+ export function buildDirectionEvidence(context) {
3
+ return context.violations.map((violation) => toEvidence(`${violation.sourceLayer} -> ${violation.targetLayer} direction violation`, {
4
+ source: violation.source,
5
+ target: violation.target,
6
+ }, undefined, 0.95));
7
+ }
8
+ export function buildPurityEvidence(context) {
9
+ return context.purityScore.findings.map((finding) => toEvidence(finding.note, {
10
+ kind: finding.kind,
11
+ path: finding.path,
12
+ ...(finding.source ? { source: finding.source } : {}),
13
+ ...(finding.target ? { target: finding.target } : {}),
14
+ ...(finding.sourceLayer ? { sourceLayer: finding.sourceLayer } : {}),
15
+ ...(finding.targetLayer ? { targetLayer: finding.targetLayer } : {}),
16
+ }, undefined, finding.confidence));
17
+ }
18
+ export function buildProtocolEvidence(context) {
19
+ return context.protocolScore.findings.map((finding) => toEvidence(finding.note, {
20
+ kind: finding.kind,
21
+ path: finding.path,
22
+ ...(finding.symbol ? { symbol: finding.symbol } : {}),
23
+ }, undefined, finding.confidence));
24
+ }
25
+ export function buildScenarioEvidence(context) {
26
+ return context.scenarioScore.findings.map((finding) => toEvidence(finding.note, {
27
+ scenarioId: finding.scenarioId,
28
+ ...(finding.observed !== undefined ? { observed: finding.observed } : {}),
29
+ ...(finding.normalized !== undefined ? { normalized: finding.normalized } : {}),
30
+ source: finding.source,
31
+ }, undefined, finding.confidence));
32
+ }
33
+ export function buildTopologyEvidence(context) {
34
+ return context.topologyScore.findings.map((finding) => toEvidence(finding.note, {
35
+ kind: finding.kind,
36
+ ...(finding.nodeId ? { nodeId: finding.nodeId } : {}),
37
+ ...(finding.source ? { source: finding.source } : {}),
38
+ ...(finding.target ? { target: finding.target } : {}),
39
+ }, undefined, finding.confidence));
40
+ }
41
+ export function buildOperationsEvidence(context) {
42
+ return context.operationsScore.findings.map((finding) => toEvidence(finding.note, {
43
+ kind: finding.kind,
44
+ ...(finding.bandId ? { bandId: finding.bandId } : {}),
45
+ ...(finding.component ? { component: finding.component } : {}),
46
+ ...(finding.patternFamily ? { patternFamily: finding.patternFamily } : {}),
47
+ ...(finding.signal ? { signal: finding.signal } : {}),
48
+ ...(finding.source ? { source: finding.source } : {}),
49
+ }, undefined, finding.confidence));
50
+ }
@@ -0,0 +1,2 @@
1
+ export { buildDirectionEvidence, buildOperationsEvidence, buildProtocolEvidence, buildPurityEvidence, buildScenarioEvidence, buildTopologyEvidence, } from "./architecture-scoring-evidence-architecture.js";
2
+ export { buildComplexityEvidence, buildComplexityExportEvidence, buildDeliveryExportEvidence, buildDeliveryNormalizationEvidence, buildEvolutionEvidence, buildPatternRuntimeNormalizationEvidence, buildTelemetryExportEvidence, buildTelemetryNormalizationEvidence, } from "./architecture-scoring-evidence-observability.js";
@@ -0,0 +1,2 @@
1
+ export { buildDirectionEvidence, buildOperationsEvidence, buildProtocolEvidence, buildPurityEvidence, buildScenarioEvidence, buildTopologyEvidence, } from "./architecture-scoring-evidence-architecture.js";
2
+ export { buildComplexityEvidence, buildComplexityExportEvidence, buildDeliveryExportEvidence, buildDeliveryNormalizationEvidence, buildEvolutionEvidence, buildPatternRuntimeNormalizationEvidence, buildTelemetryExportEvidence, buildTelemetryNormalizationEvidence, } from "./architecture-scoring-evidence-observability.js";
@@ -0,0 +1,5 @@
1
+ import type { EvidenceEntry } from "./architecture-scoring-evidence-inputs-shared.js";
2
+ import type { ArchitectureScoringContext, ComputeArchitectureScoresOptions } from "./architecture-scoring-types.js";
3
+ export declare function buildContractBaselineInputEvidence(options: ComputeArchitectureScoresOptions): EvidenceEntry[];
4
+ export declare function buildDeliveryInputEvidence(options: ComputeArchitectureScoresOptions, context: ArchitectureScoringContext): EvidenceEntry[];
5
+ export declare function buildTelemetryInputEvidence(options: ComputeArchitectureScoresOptions, context: ArchitectureScoringContext): EvidenceEntry[];
@@ -0,0 +1,68 @@
1
+ import { buildSourceInputEvidence } from "./architecture-scoring-evidence-inputs-shared.js";
2
+ import { toEvidence } from "./response.js";
3
+ export function buildContractBaselineInputEvidence(options) {
4
+ if (!options.contractBaseline && !options.contractBaselineSource) {
5
+ return [];
6
+ }
7
+ return [
8
+ toEvidence(`Using a contract baseline for IPS delta comparison${options.contractBaselineSource ? ` (${options.contractBaselineSource.sourceType} source)` : ""}.`, {
9
+ source: "contract_baseline",
10
+ ...(options.contractBaselineSource?.resolvedPath
11
+ ? { sourcePath: options.contractBaselineSource.resolvedPath }
12
+ : {}),
13
+ ...(options.contractBaselineSource?.command ? { command: options.contractBaselineSource.command } : {}),
14
+ }, undefined, options.contractBaselineSource?.confidence ?? 0.82),
15
+ ];
16
+ }
17
+ export function buildDeliveryInputEvidence(options, context) {
18
+ if (options.deliveryObservations) {
19
+ return [
20
+ toEvidence("Using the normalized scores from delivery observations as-is.", { source: "normalized_input" }, undefined, 0.84),
21
+ ];
22
+ }
23
+ if (options.deliveryRawObservations) {
24
+ return [
25
+ toEvidence("Using raw delivery observations after scoring them through the normalization profile.", { source: "raw_normalized" }, undefined, 0.82),
26
+ ];
27
+ }
28
+ if (options.deliveryExport) {
29
+ return [
30
+ toEvidence("Ingested the delivery export as the delivery input for EES.", { source: "delivery_export" }, undefined, 0.8),
31
+ ];
32
+ }
33
+ if (options.deliverySource) {
34
+ return buildSourceInputEvidence(options.deliverySource, "delivery_source", "delivery source", 0.78);
35
+ }
36
+ if (context.deliveryNormalizationResult) {
37
+ return [
38
+ toEvidence("Using raw delivery observations after scoring them through the normalization profile.", { source: "raw_normalized" }, undefined, 0.82),
39
+ ];
40
+ }
41
+ return [];
42
+ }
43
+ export function buildTelemetryInputEvidence(options, context) {
44
+ if (options.telemetryObservations) {
45
+ return [
46
+ toEvidence("Using the normalized scores from telemetry observations as-is.", { source: "normalized_input" }, undefined, 0.84),
47
+ ];
48
+ }
49
+ if (options.telemetryRawObservations) {
50
+ return [
51
+ toEvidence("Using raw telemetry observations after scoring them through the normalization profile.", { source: "raw_normalized" }, undefined, 0.82),
52
+ ];
53
+ }
54
+ if (options.telemetryExport) {
55
+ return [
56
+ toEvidence("Ingested the telemetry export as the CommonOps input for OAS.", { source: "telemetry_export" }, undefined, 0.8),
57
+ ];
58
+ }
59
+ if (options.telemetrySource) {
60
+ return buildSourceInputEvidence(options.telemetrySource, "telemetry_source", "telemetry source", 0.78);
61
+ }
62
+ if (context.telemetryNormalizationResult) {
63
+ return [
64
+ toEvidence("Using raw telemetry observations after scoring them through the normalization profile.", { source: "raw_normalized" }, undefined, 0.82),
65
+ ];
66
+ }
67
+ return [];
68
+ }
@@ -0,0 +1,20 @@
1
+ import { toEvidence } from "./response.js";
2
+ export type EvidenceEntry = ReturnType<typeof toEvidence>;
3
+ export interface SourceConfigFinding {
4
+ note: string;
5
+ kind: string;
6
+ sourceType: string;
7
+ sourcePath?: string;
8
+ command?: string;
9
+ cwd?: string;
10
+ confidence: number;
11
+ }
12
+ export interface ResolvedSourceLike {
13
+ sourceType: string;
14
+ resolvedPath?: string;
15
+ command?: string;
16
+ confidence?: number;
17
+ findings?: SourceConfigFinding[];
18
+ }
19
+ export declare function buildSourceConfigEvidence(source: ResolvedSourceLike | undefined, evidenceSource: string): EvidenceEntry[];
20
+ export declare function buildSourceInputEvidence(source: ResolvedSourceLike | undefined, evidenceSource: string, label: string, confidence?: number): EvidenceEntry[];
@@ -0,0 +1,24 @@
1
+ import { toEvidence } from "./response.js";
2
+ export function buildSourceConfigEvidence(source, evidenceSource) {
3
+ return (source?.findings ?? []).map((finding) => toEvidence(finding.note, {
4
+ kind: finding.kind,
5
+ sourceType: finding.sourceType,
6
+ ...(finding.sourcePath ? { sourcePath: finding.sourcePath } : {}),
7
+ ...(finding.command ? { command: finding.command } : {}),
8
+ ...(finding.cwd ? { cwd: finding.cwd } : {}),
9
+ source: evidenceSource,
10
+ }, undefined, finding.confidence));
11
+ }
12
+ export function buildSourceInputEvidence(source, evidenceSource, label, confidence = 0.78) {
13
+ if (!source) {
14
+ return [];
15
+ }
16
+ return [
17
+ toEvidence(`Ingested a canonical export from ${label} (${source.sourceType}).`, {
18
+ source: evidenceSource,
19
+ sourceType: source.sourceType,
20
+ ...(source.resolvedPath ? { sourcePath: source.resolvedPath } : {}),
21
+ ...(source.command ? { command: source.command } : {}),
22
+ }, undefined, confidence),
23
+ ];
24
+ }
@@ -0,0 +1,7 @@
1
+ import type { EvidenceEntry } from "./architecture-scoring-evidence-inputs-shared.js";
2
+ import type { ComputeArchitectureScoresOptions } from "./architecture-scoring-types.js";
3
+ export declare function buildContractBaselineSourceEvidence(options: ComputeArchitectureScoresOptions): EvidenceEntry[];
4
+ export declare function buildScenarioSourceEvidence(options: ComputeArchitectureScoresOptions): EvidenceEntry[];
5
+ export declare function buildTelemetrySourceEvidence(options: ComputeArchitectureScoresOptions): EvidenceEntry[];
6
+ export declare function buildDeliverySourceEvidence(options: ComputeArchitectureScoresOptions): EvidenceEntry[];
7
+ export declare function buildComplexitySourceEvidence(options: ComputeArchitectureScoresOptions): EvidenceEntry[];
@@ -0,0 +1,16 @@
1
+ import { buildSourceConfigEvidence } from "./architecture-scoring-evidence-inputs-shared.js";
2
+ export function buildContractBaselineSourceEvidence(options) {
3
+ return buildSourceConfigEvidence(options.contractBaselineSource, "contract_baseline_source");
4
+ }
5
+ export function buildScenarioSourceEvidence(options) {
6
+ return buildSourceConfigEvidence(options.scenarioObservationSource, "scenario_observation_source");
7
+ }
8
+ export function buildTelemetrySourceEvidence(options) {
9
+ return buildSourceConfigEvidence(options.telemetrySource, "telemetry_source");
10
+ }
11
+ export function buildDeliverySourceEvidence(options) {
12
+ return buildSourceConfigEvidence(options.deliverySource, "delivery_source");
13
+ }
14
+ export function buildComplexitySourceEvidence(options) {
15
+ return buildSourceConfigEvidence(options.complexitySource, "complexity_source");
16
+ }
@@ -0,0 +1,2 @@
1
+ export { buildContractBaselineInputEvidence, buildDeliveryInputEvidence, buildTelemetryInputEvidence, } from "./architecture-scoring-evidence-inputs-ingest.js";
2
+ export { buildComplexitySourceEvidence, buildContractBaselineSourceEvidence, buildDeliverySourceEvidence, buildScenarioSourceEvidence, buildTelemetrySourceEvidence, } from "./architecture-scoring-evidence-inputs-source.js";
@@ -0,0 +1,2 @@
1
+ export { buildContractBaselineInputEvidence, buildDeliveryInputEvidence, buildTelemetryInputEvidence, } from "./architecture-scoring-evidence-inputs-ingest.js";
2
+ export { buildComplexitySourceEvidence, buildContractBaselineSourceEvidence, buildDeliverySourceEvidence, buildScenarioSourceEvidence, buildTelemetrySourceEvidence, } from "./architecture-scoring-evidence-inputs-source.js";
@@ -0,0 +1,12 @@
1
+ import type { ArchitectureScoringContext } from "./architecture-scoring-types.js";
2
+ import { toEvidence } from "./response.js";
3
+ type EvidenceEntry = ReturnType<typeof toEvidence>;
4
+ export declare function buildTelemetryNormalizationEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
5
+ export declare function buildPatternRuntimeNormalizationEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
6
+ export declare function buildTelemetryExportEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
7
+ export declare function buildDeliveryNormalizationEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
8
+ export declare function buildDeliveryExportEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
9
+ export declare function buildComplexityExportEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
10
+ export declare function buildComplexityEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
11
+ export declare function buildEvolutionEvidence(context: ArchitectureScoringContext): EvidenceEntry[];
12
+ export {};
@@ -0,0 +1,75 @@
1
+ import { toEvidence } from "./response.js";
2
+ export function buildTelemetryNormalizationEvidence(context) {
3
+ return (context.telemetryNormalizationResult?.findings ?? []).map((finding) => toEvidence(finding.note, {
4
+ kind: finding.kind,
5
+ bandId: finding.bandId,
6
+ component: finding.component,
7
+ ...(finding.observed !== undefined ? { observed: finding.observed } : {}),
8
+ ...(finding.normalized !== undefined ? { normalized: finding.normalized } : {}),
9
+ }, undefined, finding.confidence));
10
+ }
11
+ export function buildPatternRuntimeNormalizationEvidence(context) {
12
+ return (context.patternRuntimeNormalizationResult?.findings ?? []).map((finding) => toEvidence(finding.note, {
13
+ kind: finding.kind,
14
+ block: finding.block,
15
+ rawSignal: finding.rawSignal,
16
+ scoreSignal: finding.scoreSignal,
17
+ ...(finding.observed !== undefined ? { observed: finding.observed } : {}),
18
+ ...(finding.normalized !== undefined ? { normalized: finding.normalized } : {}),
19
+ source: "pattern_runtime_raw_normalized",
20
+ }, undefined, finding.confidence));
21
+ }
22
+ export function buildTelemetryExportEvidence(context) {
23
+ return (context.telemetryExportIngestResult?.findings ?? []).map((finding) => toEvidence(finding.note, {
24
+ kind: finding.kind,
25
+ ...(finding.bandId ? { bandId: finding.bandId } : {}),
26
+ ...(finding.component ? { component: finding.component } : {}),
27
+ ...(finding.observed !== undefined ? { observed: finding.observed } : {}),
28
+ ...(finding.sourceSystem ? { sourceSystem: finding.sourceSystem } : {}),
29
+ ...(finding.window ? { window: finding.window } : {}),
30
+ source: "telemetry_export",
31
+ }, undefined, finding.confidence));
32
+ }
33
+ export function buildDeliveryNormalizationEvidence(context) {
34
+ return (context.deliveryNormalizationResult?.findings ?? []).map((finding) => toEvidence(finding.note, {
35
+ kind: finding.kind,
36
+ component: finding.component,
37
+ scoreComponent: finding.scoreComponent,
38
+ ...(finding.observed !== undefined ? { observed: finding.observed } : {}),
39
+ ...(finding.normalized !== undefined ? { normalized: finding.normalized } : {}),
40
+ source: "raw_normalized",
41
+ }, undefined, finding.confidence));
42
+ }
43
+ export function buildDeliveryExportEvidence(context) {
44
+ return (context.deliveryExportIngestResult?.findings ?? []).map((finding) => toEvidence(finding.note, {
45
+ kind: finding.kind,
46
+ ...(finding.component ? { component: finding.component } : {}),
47
+ ...(finding.observed !== undefined ? { observed: finding.observed } : {}),
48
+ ...(finding.sourceSystem ? { sourceSystem: finding.sourceSystem } : {}),
49
+ source: "delivery_export",
50
+ }, undefined, finding.confidence));
51
+ }
52
+ export function buildComplexityExportEvidence(context) {
53
+ return (context.complexityExportIngestResult?.findings ?? []).map((finding) => toEvidence(finding.note, {
54
+ kind: finding.kind,
55
+ component: finding.component,
56
+ ...(finding.observed !== undefined ? { observed: finding.observed } : {}),
57
+ ...(finding.sourceSystem ? { sourceSystem: finding.sourceSystem } : {}),
58
+ source: "complexity_export",
59
+ }, undefined, finding.confidence));
60
+ }
61
+ export function buildComplexityEvidence(context) {
62
+ return context.complexityScore.findings.map((finding) => toEvidence(finding.note, {
63
+ component: finding.component,
64
+ observed: finding.observed,
65
+ normalized: finding.normalized,
66
+ source: finding.source,
67
+ }, undefined, finding.confidence));
68
+ }
69
+ export function buildEvolutionEvidence(context) {
70
+ return context.evolutionLocalityScore.findings.concat(context.evolutionEfficiencyScore.findings).map((finding) => toEvidence(finding.note, {
71
+ kind: finding.kind,
72
+ ...(finding.commitHash ? { commitHash: finding.commitHash } : {}),
73
+ ...(finding.component ? { component: finding.component } : {}),
74
+ }, undefined, finding.confidence));
75
+ }