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,116 @@
1
+ import { classifyReviewItemKind, sortReviewItems } from "./measurement-metadata.js";
2
+ function isGlossaryTerm(entity) {
3
+ return "termId" in entity;
4
+ }
5
+ function getEntityId(entity) {
6
+ if ("termId" in entity) {
7
+ return entity.termId;
8
+ }
9
+ if ("ruleId" in entity) {
10
+ return entity.ruleId;
11
+ }
12
+ return entity.invariantId;
13
+ }
14
+ function getEntitySummary(entity) {
15
+ if (isGlossaryTerm(entity)) {
16
+ return entity.canonicalTerm;
17
+ }
18
+ return entity.statement;
19
+ }
20
+ function getReviewItemsFromEntities(entities, evidenceRefs) {
21
+ const reviewItems = [];
22
+ entities.forEach((entity, index) => {
23
+ const targetEntityId = getEntityId(entity);
24
+ const summary = getEntitySummary(entity);
25
+ if (entity.confidence < 0.75) {
26
+ reviewItems.push({
27
+ reviewItemId: `RV-LOW-${index + 1}`,
28
+ reason: "low_confidence",
29
+ kind: "low_confidence",
30
+ summary: `${summary} has low confidence`,
31
+ confidence: entity.confidence,
32
+ evidenceRefs,
33
+ targetEntityId,
34
+ });
35
+ }
36
+ entity.unknowns.forEach((unknown, unknownIndex) => {
37
+ reviewItems.push({
38
+ reviewItemId: `RV-UNK-${index + 1}-${unknownIndex + 1}`,
39
+ reason: "unknown",
40
+ kind: classifyReviewItemKind(unknown, "unknown"),
41
+ summary: unknown,
42
+ confidence: entity.confidence,
43
+ evidenceRefs,
44
+ targetEntityId,
45
+ });
46
+ });
47
+ if (isGlossaryTerm(entity) && entity.collision) {
48
+ reviewItems.push({
49
+ reviewItemId: `RV-COLL-${index + 1}`,
50
+ reason: "collision",
51
+ kind: "collision",
52
+ summary: `${entity.canonicalTerm} may have a collision`,
53
+ confidence: entity.confidence,
54
+ evidenceRefs,
55
+ targetEntityId,
56
+ });
57
+ }
58
+ });
59
+ return reviewItems;
60
+ }
61
+ export function listReviewItems(response) {
62
+ const reviewItems = [];
63
+ const evidenceRefs = response.evidence.map((entry) => entry.evidenceId);
64
+ response.unknowns.forEach((unknown, index) => {
65
+ reviewItems.push({
66
+ reviewItemId: `RV-RSP-${index + 1}`,
67
+ reason: "unknown",
68
+ kind: classifyReviewItemKind(unknown, "unknown"),
69
+ summary: unknown,
70
+ confidence: response.confidence,
71
+ evidenceRefs,
72
+ });
73
+ });
74
+ if (typeof response.result !== "object" || response.result === null) {
75
+ return reviewItems;
76
+ }
77
+ const result = response.result;
78
+ if (Array.isArray(result.terms)) {
79
+ reviewItems.push(...getReviewItemsFromEntities(result.terms, evidenceRefs));
80
+ }
81
+ if (Array.isArray(result.rules)) {
82
+ reviewItems.push(...getReviewItemsFromEntities(result.rules, evidenceRefs));
83
+ }
84
+ if (Array.isArray(result.invariants)) {
85
+ reviewItems.push(...getReviewItemsFromEntities(result.invariants, evidenceRefs));
86
+ }
87
+ if (Array.isArray(result.metrics)) {
88
+ for (const [index, metric] of result.metrics.entries()) {
89
+ if (metric.confidence < 0.75) {
90
+ reviewItems.push({
91
+ reviewItemId: `RV-METRIC-${index + 1}`,
92
+ reason: "low_confidence",
93
+ kind: "low_confidence",
94
+ summary: `${metric.metricId} has low confidence`,
95
+ confidence: metric.confidence,
96
+ evidenceRefs,
97
+ });
98
+ }
99
+ }
100
+ }
101
+ if (Array.isArray(result.localityWatchlist)) {
102
+ for (const [index, item] of result.localityWatchlist.entries()) {
103
+ reviewItems.push({
104
+ reviewItemId: `RV-HOTSPOT-${index + 1}`,
105
+ reason: "history_hotspot",
106
+ kind: "history_hotspot",
107
+ summary: `Recurring cross-boundary hotspot ${item.boundaries.join(" <-> ")} appears in ${item.count} commits${item.sampleCommitHashes && item.sampleCommitHashes.length > 0
108
+ ? ` (${item.sampleCommitHashes.join(", ")})`
109
+ : ""}.`,
110
+ confidence: response.confidence,
111
+ evidenceRefs,
112
+ });
113
+ }
114
+ }
115
+ return sortReviewItems(reviewItems);
116
+ }
@@ -0,0 +1,3 @@
1
+ import type { ReviewItem, ReviewResolution, ReviewResolutionLog } from "./contracts.js";
2
+ export declare function resolveReviewItems(reviewItems: ReviewItem[], resolutions: ReviewResolution[]): ReviewResolutionLog;
3
+ export declare function applyReviewOverrides<T extends object>(items: T[], log: ReviewResolutionLog | undefined, idKey: keyof T): T[];
@@ -0,0 +1,43 @@
1
+ export function resolveReviewItems(reviewItems, resolutions) {
2
+ const resolvedItems = reviewItems.map((reviewItem) => ({
3
+ ...reviewItem,
4
+ resolution: resolutions.find((resolution) => resolution.reviewItemId === reviewItem.reviewItemId) ?? null,
5
+ }));
6
+ const overrides = resolvedItems.flatMap((reviewItem) => {
7
+ const patch = reviewItem.resolution?.decision?.patch;
8
+ if (!reviewItem.targetEntityId || !patch || Object.keys(patch).length === 0) {
9
+ return [];
10
+ }
11
+ return [
12
+ {
13
+ targetEntityId: reviewItem.targetEntityId,
14
+ patch,
15
+ reason: reviewItem.reason,
16
+ },
17
+ ];
18
+ });
19
+ return {
20
+ reviewItems: resolvedItems,
21
+ overrides,
22
+ };
23
+ }
24
+ export function applyReviewOverrides(items, log, idKey) {
25
+ if (!log) {
26
+ return items;
27
+ }
28
+ const overrideMap = new Map(log.overrides.map((override) => [override.targetEntityId, override.patch]));
29
+ return items.map((item) => {
30
+ const id = item[idKey];
31
+ if (typeof id !== "string") {
32
+ return item;
33
+ }
34
+ const patch = overrideMap.get(id);
35
+ if (!patch) {
36
+ return item;
37
+ }
38
+ return {
39
+ ...item,
40
+ ...patch,
41
+ };
42
+ });
43
+ }
@@ -0,0 +1,2 @@
1
+ export { listReviewItems } from "./review-items.js";
2
+ export { applyReviewOverrides, resolveReviewItems } from "./review-resolutions.js";
@@ -0,0 +1,2 @@
1
+ export { listReviewItems } from "./review-items.js";
2
+ export { applyReviewOverrides, resolveReviewItems } from "./review-resolutions.js";
@@ -0,0 +1,13 @@
1
+ import type { ArchitectureLayerCandidate, DomainContextCandidate, Evidence } from "./contracts.js";
2
+ export declare function mergeEvidence(candidates: Array<{
3
+ evidence: Evidence[];
4
+ }>): Evidence[];
5
+ export declare function mergeUnknowns(candidates: Array<{
6
+ unknowns: string[];
7
+ }>, extras?: string[]): string[];
8
+ export declare function averageConfidence(contextCandidates: Array<{
9
+ candidate: DomainContextCandidate;
10
+ }>, aggregateCandidates: Array<{
11
+ confidence: number;
12
+ }>, extraSignals: number[]): number;
13
+ export declare function averageLayerConfidence(layers: ArchitectureLayerCandidate[]): number;
@@ -0,0 +1,18 @@
1
+ import { unique } from "./scaffold-naming.js";
2
+ export function mergeEvidence(candidates) {
3
+ return candidates.flatMap((candidate) => candidate.evidence).slice(0, 12);
4
+ }
5
+ export function mergeUnknowns(candidates, extras = []) {
6
+ return unique([...extras, ...candidates.flatMap((candidate) => candidate.unknowns)]);
7
+ }
8
+ export function averageConfidence(contextCandidates, aggregateCandidates, extraSignals) {
9
+ const signals = [
10
+ ...contextCandidates.map((entry) => entry.candidate.confidence),
11
+ ...aggregateCandidates.map((candidate) => candidate.confidence),
12
+ ...extraSignals,
13
+ ];
14
+ return signals.reduce((sum, signal) => sum + signal, 0) / Math.max(1, signals.length);
15
+ }
16
+ export function averageLayerConfidence(layers) {
17
+ return layers.reduce((sum, layer) => sum + layer.confidence, 0) / Math.max(1, layers.length);
18
+ }
@@ -0,0 +1,3 @@
1
+ import type { CodebaseAnalysis } from "./contracts.js";
2
+ import type { SourceGroup } from "./scaffold-shared.js";
3
+ export declare function buildArchitectureLayerBalances(codebase: CodebaseAnalysis, groups: SourceGroup[]): Map<string, number>;
@@ -0,0 +1,25 @@
1
+ export function buildArchitectureLayerBalances(codebase, groups) {
2
+ const fileToGroup = new Map();
3
+ for (const group of groups) {
4
+ for (const filePath of group.files) {
5
+ fileToGroup.set(filePath, group.key);
6
+ }
7
+ }
8
+ const balances = new Map();
9
+ for (const group of groups) {
10
+ balances.set(group.key, 0);
11
+ }
12
+ for (const dependency of codebase.dependencies) {
13
+ if (dependency.targetKind !== "file") {
14
+ continue;
15
+ }
16
+ const sourceGroup = fileToGroup.get(dependency.source);
17
+ const targetGroup = fileToGroup.get(dependency.target);
18
+ if (!sourceGroup || !targetGroup || sourceGroup === targetGroup) {
19
+ continue;
20
+ }
21
+ balances.set(sourceGroup, (balances.get(sourceGroup) ?? 0) + 1);
22
+ balances.set(targetGroup, (balances.get(targetGroup) ?? 0) - 1);
23
+ }
24
+ return balances;
25
+ }
@@ -0,0 +1,19 @@
1
+ import type { ArchitectureBoundaryMap, ArchitectureConstraints, ArchitectureScenarioCatalog, ArchitectureScenarioObservationTemplate, ArchitectureTopologyModel, CodebaseAnalysis } from "./contracts.js";
2
+ export declare function buildArchitectureScaffoldDrafts(codebase: CodebaseAnalysis, constraints: ArchitectureConstraints): {
3
+ scenarioObservationsTemplate: {
4
+ value: ArchitectureScenarioObservationTemplate;
5
+ yaml: string;
6
+ };
7
+ scenarioCatalog: {
8
+ value: ArchitectureScenarioCatalog;
9
+ yaml: string;
10
+ };
11
+ topologyModel: {
12
+ value: ArchitectureTopologyModel;
13
+ yaml: string;
14
+ };
15
+ boundaryMap: {
16
+ value: ArchitectureBoundaryMap;
17
+ yaml: string;
18
+ };
19
+ };
@@ -0,0 +1,114 @@
1
+ import YAML from "yaml";
2
+ import { matchGlobs } from "./io.js";
3
+ import { buildScenarioProfile, inferTopologyNodeKind, normalizeNodeId, } from "./scaffold-architecture-drafts-profiles.js";
4
+ function buildScenarioCatalog(constraints) {
5
+ return {
6
+ version: constraints.version,
7
+ scenarios: constraints.layers.map((layer, index) => {
8
+ const profile = buildScenarioProfile(layer);
9
+ return {
10
+ scenarioId: `SC-${String(index + 1).padStart(3, "0")}`,
11
+ name: profile.name,
12
+ qualityAttribute: profile.qualityAttribute,
13
+ stimulus: profile.stimulus,
14
+ environment: "Docs-first repository with scaffolded architecture constraints.",
15
+ response: profile.response,
16
+ responseMeasure: {
17
+ metric: profile.metric,
18
+ unit: "ratio",
19
+ },
20
+ direction: "higher_is_better",
21
+ priority: index + 1,
22
+ target: 0.8,
23
+ worstAcceptable: 0.5,
24
+ };
25
+ }),
26
+ };
27
+ }
28
+ function buildScenarioObservationsTemplate(catalog) {
29
+ return {
30
+ version: catalog.version,
31
+ scenarios: catalog.scenarios.map((scenario) => ({
32
+ scenarioId: scenario.scenarioId,
33
+ ...(scenario.name ? { name: scenario.name } : {}),
34
+ ...(scenario.qualityAttribute ? { qualityAttribute: scenario.qualityAttribute } : {}),
35
+ priority: scenario.priority,
36
+ measurementStatus: "needs_measurement",
37
+ note: `Populate an observed value for ${scenario.qualityAttribute ?? scenario.name ?? scenario.scenarioId} from benchmark or incident review before scoring.`,
38
+ })),
39
+ };
40
+ }
41
+ function classifyLayer(path, constraints) {
42
+ return constraints.layers.find((layer) => matchGlobs(path, layer.globs));
43
+ }
44
+ function buildTopologyModel(codebase, constraints) {
45
+ const nodes = constraints.layers.map((layer) => ({
46
+ nodeId: normalizeNodeId(layer.name),
47
+ kind: inferTopologyNodeKind(layer),
48
+ isolationBoundary: layer.name,
49
+ }));
50
+ const edges = new Map();
51
+ for (const dependency of codebase.dependencies) {
52
+ if (dependency.targetKind !== "file") {
53
+ continue;
54
+ }
55
+ const sourceLayer = classifyLayer(dependency.source, constraints);
56
+ const targetLayer = classifyLayer(dependency.target, constraints);
57
+ if (!sourceLayer || !targetLayer || sourceLayer.name === targetLayer.name) {
58
+ continue;
59
+ }
60
+ const edgeKey = `${sourceLayer.name} -> ${targetLayer.name}`;
61
+ if (!edges.has(edgeKey)) {
62
+ edges.set(edgeKey, {
63
+ source: normalizeNodeId(sourceLayer.name),
64
+ target: normalizeNodeId(targetLayer.name),
65
+ kind: "sync_call",
66
+ });
67
+ }
68
+ }
69
+ const fallbackEdges = edges.size > 0
70
+ ? Array.from(edges.values())
71
+ : nodes.slice(1).map((node, index) => ({
72
+ source: nodes[index]?.nodeId ?? node.nodeId,
73
+ target: node.nodeId,
74
+ kind: "sync_call",
75
+ }));
76
+ return {
77
+ version: constraints.version,
78
+ nodes,
79
+ edges: fallbackEdges,
80
+ };
81
+ }
82
+ function buildBoundaryMap(constraints) {
83
+ return {
84
+ version: constraints.version,
85
+ boundaries: constraints.layers.map((layer) => ({
86
+ name: layer.name,
87
+ pathGlobs: layer.globs,
88
+ })),
89
+ };
90
+ }
91
+ export function buildArchitectureScaffoldDrafts(codebase, constraints) {
92
+ const scenarioCatalog = buildScenarioCatalog(constraints);
93
+ const scenarioObservationsTemplate = buildScenarioObservationsTemplate(scenarioCatalog);
94
+ const topologyModel = buildTopologyModel(codebase, constraints);
95
+ const boundaryMap = buildBoundaryMap(constraints);
96
+ return {
97
+ scenarioObservationsTemplate: {
98
+ value: scenarioObservationsTemplate,
99
+ yaml: YAML.stringify(scenarioObservationsTemplate),
100
+ },
101
+ scenarioCatalog: {
102
+ value: scenarioCatalog,
103
+ yaml: YAML.stringify(scenarioCatalog),
104
+ },
105
+ topologyModel: {
106
+ value: topologyModel,
107
+ yaml: YAML.stringify(topologyModel),
108
+ },
109
+ boundaryMap: {
110
+ value: boundaryMap,
111
+ yaml: YAML.stringify(boundaryMap),
112
+ },
113
+ };
114
+ }
@@ -0,0 +1,11 @@
1
+ import type { LayerDefinition } from "./contracts.js";
2
+ export interface ScenarioDraftProfile {
3
+ name: string;
4
+ qualityAttribute: string;
5
+ metric: string;
6
+ stimulus: string;
7
+ response: string;
8
+ }
9
+ export declare function normalizeNodeId(name: string): string;
10
+ export declare function buildScenarioProfile(layer: LayerDefinition): ScenarioDraftProfile;
11
+ export declare function inferTopologyNodeKind(layer: LayerDefinition): "service" | "datastore" | "queue" | "cache" | "gateway" | "worker" | "unknown";
@@ -0,0 +1,183 @@
1
+ export function normalizeNodeId(name) {
2
+ return name
3
+ .trim()
4
+ .replace(/([a-z0-9])([A-Z])/g, "$1_$2")
5
+ .replace(/[^a-zA-Z0-9]+/g, "_")
6
+ .replace(/_+/g, "_")
7
+ .replace(/^_+|_+$/g, "")
8
+ .toLowerCase();
9
+ }
10
+ function humanizeLayerName(name) {
11
+ const stripped = name.replace(/\d+$/u, "");
12
+ const words = stripped
13
+ .trim()
14
+ .replace(/([a-z0-9])([A-Z])/g, "$1 $2")
15
+ .replace(/[^a-zA-Z0-9]+/g, " ")
16
+ .split(/\s+/u)
17
+ .filter((segment) => segment.length > 0);
18
+ if (words.length === 0) {
19
+ return name;
20
+ }
21
+ const lowercaseWords = new Set(["and", "or", "of", "the", "to", "for", "in", "on", "with"]);
22
+ return words
23
+ .map((word, index) => {
24
+ const normalized = word.toLowerCase();
25
+ if (index > 0 && lowercaseWords.has(normalized)) {
26
+ return normalized;
27
+ }
28
+ if (/^[A-Z0-9]{2,}$/u.test(word)) {
29
+ return word;
30
+ }
31
+ return `${word.charAt(0).toUpperCase()}${word.slice(1).toLowerCase()}`;
32
+ })
33
+ .join(" ");
34
+ }
35
+ function includesAny(normalizedName, markers) {
36
+ return markers.some((marker) => normalizedName.includes(marker));
37
+ }
38
+ export function buildScenarioProfile(layer) {
39
+ const normalized = normalizeNodeId(layer.name);
40
+ const displayName = humanizeLayerName(layer.name);
41
+ const stimulus = `A change request primarily affects the ${displayName} layer.`;
42
+ if (includesAny(normalized, ["domain", "core", "kernel", "model", "foundation"])) {
43
+ return {
44
+ name: "Domain cohesion",
45
+ qualityAttribute: "Domain cohesion",
46
+ metric: "cohesion",
47
+ stimulus,
48
+ response: `The change preserves ${displayName} cohesion and avoids unnecessary cross-layer spread.`,
49
+ };
50
+ }
51
+ if (includesAny(normalized, ["contract", "contracts", "schema", "schemas", "dto", "dtos", "api"])) {
52
+ return {
53
+ name: "Contract stability",
54
+ qualityAttribute: "Contract stability",
55
+ metric: "stability",
56
+ stimulus,
57
+ response: `The change preserves ${displayName} contract boundaries and avoids interface churn.`,
58
+ };
59
+ }
60
+ if (includesAny(normalized, ["ingest", "extract", "import", "load", "parser", "parse", "sync", "crawl"])) {
61
+ return {
62
+ name: "Ingestion coverage",
63
+ qualityAttribute: "Ingestion coverage",
64
+ metric: "coverage",
65
+ stimulus,
66
+ response: `The change keeps ${displayName} ingestion work localized and avoids spreading parsing concerns.`,
67
+ };
68
+ }
69
+ if (includesAny(normalized, ["runtime", "infra", "infrastructure", "platform", "persistence"])) {
70
+ return {
71
+ name: "Runtime containment",
72
+ qualityAttribute: "Runtime containment",
73
+ metric: "containment",
74
+ stimulus,
75
+ response: `The change stays contained within ${displayName} and avoids pulling runtime concerns inward.`,
76
+ };
77
+ }
78
+ if (includesAny(normalized, ["workspace", "project", "bootstrap", "config", "env", "setup"])) {
79
+ return {
80
+ name: "Workspace bootstrap readiness",
81
+ qualityAttribute: "Workspace bootstrap readiness",
82
+ metric: "readiness",
83
+ stimulus,
84
+ response: `The change preserves ${displayName} readiness and keeps setup concerns isolated.`,
85
+ };
86
+ }
87
+ if (includesAny(normalized, ["evaluation", "quality", "benchmark", "review", "telemetry", "metric", "score", "eval"])) {
88
+ return {
89
+ name: "Evaluation fidelity",
90
+ qualityAttribute: "Evaluation fidelity",
91
+ metric: "fidelity",
92
+ stimulus,
93
+ response: `The change preserves ${displayName} fidelity and keeps measurement logic explicit.`,
94
+ };
95
+ }
96
+ if (includesAny(normalized, ["test", "tests", "verify", "validation"])) {
97
+ return {
98
+ name: "Validation coverage",
99
+ qualityAttribute: "Validation coverage",
100
+ metric: "coverage",
101
+ stimulus,
102
+ response: `The change preserves ${displayName} coverage and keeps validation concerns isolated.`,
103
+ };
104
+ }
105
+ if (includesAny(normalized, ["shared", "common", "util", "utils", "types"])) {
106
+ return {
107
+ name: "Shared surface stability",
108
+ qualityAttribute: "Shared surface stability",
109
+ metric: "stability",
110
+ stimulus,
111
+ response: `The change preserves ${displayName} surface stability and avoids leaking shared abstractions.`,
112
+ };
113
+ }
114
+ if (includesAny(normalized, ["data", "store", "storage", "db", "database", "cache", "queue"])) {
115
+ return {
116
+ name: "Data locality",
117
+ qualityAttribute: "Data locality",
118
+ metric: "locality",
119
+ stimulus,
120
+ response: `The change keeps ${displayName} data work localized and avoids data-path spillover.`,
121
+ };
122
+ }
123
+ if (includesAny(normalized, ["tool", "tools", "tooling", "script", "scripts"])) {
124
+ return {
125
+ name: "Tooling fit",
126
+ qualityAttribute: "Tooling fit",
127
+ metric: "fit",
128
+ stimulus,
129
+ response: `The change keeps ${displayName} tooling aligned with operational needs.`,
130
+ };
131
+ }
132
+ if (includesAny(normalized, ["application", "app", "usecase", "usecases", "service", "services", "orchestration"])) {
133
+ return {
134
+ name: "Application flow locality",
135
+ qualityAttribute: "Application flow locality",
136
+ metric: "locality",
137
+ stimulus,
138
+ response: `The change keeps ${displayName} flow localized and avoids unnecessary cross-layer spread.`,
139
+ };
140
+ }
141
+ if (includesAny(normalized, [
142
+ "adapter",
143
+ "adapters",
144
+ "delivery",
145
+ "presentation",
146
+ "interface",
147
+ "interfaces",
148
+ "ui",
149
+ "server",
150
+ "mcp",
151
+ ])) {
152
+ return {
153
+ name: "Boundary adaptation",
154
+ qualityAttribute: "Boundary adaptation",
155
+ metric: "adaptation",
156
+ stimulus,
157
+ response: `The change keeps ${displayName} boundary work explicit and avoids hidden coupling.`,
158
+ };
159
+ }
160
+ return {
161
+ name: `${displayName} locality`,
162
+ qualityAttribute: "Architecture locality",
163
+ metric: "locality",
164
+ stimulus,
165
+ response: `The change remains localized to the ${displayName} layer and avoids unnecessary cross-layer spread.`,
166
+ };
167
+ }
168
+ export function inferTopologyNodeKind(layer) {
169
+ const normalized = normalizeNodeId(layer.name);
170
+ if (/(data|store|storage|db|database|persistence|cache|queue)/u.test(normalized)) {
171
+ return "datastore";
172
+ }
173
+ if (/(worker|job|script|test|eval|quality)/u.test(normalized)) {
174
+ return "worker";
175
+ }
176
+ if (/(api|ui|presentation|delivery|adapter|adapters|extract|extractors|server|mcp)/u.test(normalized)) {
177
+ return "gateway";
178
+ }
179
+ if (/(contract|domain|core|kernel|foundation|model|usecase|usecases|service|services|application|runtime|project|workspace|bootstrap|infra|infrastructure|platform)/u.test(normalized)) {
180
+ return "service";
181
+ }
182
+ return "unknown";
183
+ }
@@ -0,0 +1,12 @@
1
+ import type { ArchitectureBoundaryMap, ArchitectureConstraints, ArchitectureScenarioCatalog, ArchitectureScenarioObservationTemplate, ArchitectureTopologyModel, CodebaseAnalysis } from "./contracts.js";
2
+ export interface ArchitectureScaffoldDraft<T> {
3
+ value: T;
4
+ yaml: string;
5
+ }
6
+ export interface ArchitectureScaffoldDrafts {
7
+ scenarioObservationsTemplate: ArchitectureScaffoldDraft<ArchitectureScenarioObservationTemplate>;
8
+ scenarioCatalog: ArchitectureScaffoldDraft<ArchitectureScenarioCatalog>;
9
+ topologyModel: ArchitectureScaffoldDraft<ArchitectureTopologyModel>;
10
+ boundaryMap: ArchitectureScaffoldDraft<ArchitectureBoundaryMap>;
11
+ }
12
+ export declare function buildArchitectureScaffoldDrafts(codebase: CodebaseAnalysis, constraints: ArchitectureConstraints): ArchitectureScaffoldDrafts;
@@ -0,0 +1,4 @@
1
+ import { buildArchitectureScaffoldDrafts as buildArchitectureScaffoldDraftsImpl } from "./scaffold-architecture-drafts-builders.js";
2
+ export function buildArchitectureScaffoldDrafts(codebase, constraints) {
3
+ return buildArchitectureScaffoldDraftsImpl(codebase, constraints);
4
+ }
@@ -0,0 +1,3 @@
1
+ import type { ArchitectureLayerCandidate } from "./contracts.js";
2
+ import { type SourceGroup } from "./scaffold-shared.js";
3
+ export declare function buildLayerCandidate(group: SourceGroup, balance: number): ArchitectureLayerCandidate;
@@ -0,0 +1,32 @@
1
+ import { clampConfidence, toEvidence } from "./response.js";
2
+ import { inferGroupDisplayName, LAYER_PRIORITY_HINTS, normalizeName } from "./scaffold-shared.js";
3
+ export function buildLayerCandidate(group, balance) {
4
+ const name = inferGroupDisplayName(group);
5
+ const globs = group.pathGlobs;
6
+ const hintKey = normalizeName(group.segment ?? name).replace(/\s+/gu, "_");
7
+ const confidence = clampConfidence(0.58 + (LAYER_PRIORITY_HINTS.has(hintKey) ? 0.18 : 0) + (group.files.length >= 2 ? 0.08 : 0));
8
+ const groupScope = group.heuristicSplit && (group.origins?.length ?? 0) > 1
9
+ ? `${group.origins?.length ?? 0} source buckets`
10
+ : group.basePath || ".";
11
+ return {
12
+ definition: {
13
+ name,
14
+ rank: 0,
15
+ globs,
16
+ },
17
+ confidence,
18
+ evidence: [
19
+ toEvidence(`${name} was inferred from ${group.files.length} source file(s) under ${groupScope}.`, {
20
+ group: group.basePath || ".",
21
+ ...(group.origins && group.origins.length > 0 ? { origins: group.origins } : {}),
22
+ outgoingMinusIncomingDependencies: balance,
23
+ globs,
24
+ }, undefined, confidence),
25
+ ],
26
+ unknowns: group.heuristicSplit
27
+ ? ["This layer was split from a broad infrastructure bucket by heuristic and should be reviewed."]
28
+ : group.segment
29
+ ? []
30
+ : ["Root-level source files were grouped into a single layer by heuristic."],
31
+ };
32
+ }
@@ -0,0 +1,3 @@
1
+ import type { ArchitectureConstraints, ArchitectureLayerCandidate } from "./contracts.js";
2
+ import type { SourceGroup } from "./scaffold-shared.js";
3
+ export declare function buildArchitectureScaffoldLayers(orderedGroups: SourceGroup[], constraints: ArchitectureConstraints, balances: Map<string, number>): ArchitectureLayerCandidate[];
@@ -0,0 +1,15 @@
1
+ import { buildLayerCandidate } from "./scaffold-architecture-layer-candidates.js";
2
+ export function buildArchitectureScaffoldLayers(orderedGroups, constraints, balances) {
3
+ return orderedGroups.map((group, index) => {
4
+ const candidate = buildLayerCandidate(group, balances.get(group.key) ?? 0);
5
+ return {
6
+ ...candidate,
7
+ definition: {
8
+ ...candidate.definition,
9
+ name: constraints.layers[index]?.name ?? candidate.definition.name,
10
+ rank: index,
11
+ globs: constraints.layers[index]?.globs ?? candidate.definition.globs,
12
+ },
13
+ };
14
+ });
15
+ }
@@ -0,0 +1,5 @@
1
+ import type { ArchitectureConstraintsScaffoldResult } from "./contracts.js";
2
+ import { type ScaffoldComputation } from "./scaffold-shared.js";
3
+ export declare function scaffoldArchitectureConstraints(options: {
4
+ repoRoot: string;
5
+ }): Promise<ScaffoldComputation<ArchitectureConstraintsScaffoldResult>>;