@event4u/agent-config 5.10.0 → 6.0.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 (2224) hide show
  1. package/.claude-plugin/marketplace.json +233 -229
  2. package/AGENTS.md +6 -6
  3. package/CHANGELOG.md +466 -0
  4. package/CONTRIBUTING.md +27 -15
  5. package/MIGRATION.md +102 -0
  6. package/README.md +48 -19
  7. package/dist/agent-src/README.md +64 -0
  8. package/dist/agent-src/commands/agent-handoff.md +124 -0
  9. package/dist/agent-src/commands/agent-status.md +140 -0
  10. package/dist/agent-src/commands/agents/audit.md +158 -0
  11. package/dist/agent-src/commands/agents/init.md +192 -0
  12. package/dist/agent-src/commands/agents/optimize.md +187 -0
  13. package/dist/agent-src/commands/agents/user/accept.md +123 -0
  14. package/dist/agent-src/commands/agents/user/init.md +163 -0
  15. package/dist/agent-src/commands/agents/user/review.md +113 -0
  16. package/dist/agent-src/commands/agents/user/show.md +115 -0
  17. package/dist/agent-src/commands/agents/user/update.md +103 -0
  18. package/dist/agent-src/commands/agents/user.md +71 -0
  19. package/dist/agent-src/commands/agents.md +66 -0
  20. package/dist/agent-src/commands/analytics/prune.md +71 -0
  21. package/dist/agent-src/commands/analytics/show.md +100 -0
  22. package/dist/agent-src/commands/analytics.md +77 -0
  23. package/dist/agent-src/commands/analyze-reference-repo.md +204 -0
  24. package/dist/agent-src/commands/bug-fix.md +193 -0
  25. package/dist/agent-src/commands/bug-investigate.md +186 -0
  26. package/dist/agent-src/commands/challenge-me/vision.md +354 -0
  27. package/dist/agent-src/commands/challenge-me/with-docs.md +339 -0
  28. package/dist/agent-src/commands/challenge-me.md +68 -0
  29. package/dist/agent-src/commands/chat-history/import.md +172 -0
  30. package/dist/agent-src/commands/chat-history/learn.md +184 -0
  31. package/dist/agent-src/commands/chat-history/show.md +113 -0
  32. package/dist/agent-src/commands/chat-history.md +60 -0
  33. package/dist/agent-src/commands/check-current-md.md +143 -0
  34. package/dist/agent-src/commands/commit/in-chunks.md +147 -0
  35. package/dist/agent-src/commands/commit.md +195 -0
  36. package/dist/agent-src/commands/condense.md +239 -0
  37. package/dist/agent-src/commands/context/create.md +181 -0
  38. package/dist/agent-src/commands/context/refactor.md +183 -0
  39. package/dist/agent-src/commands/context.md +52 -0
  40. package/dist/agent-src/commands/cost-report.md +131 -0
  41. package/dist/agent-src/commands/council/analysis.md +147 -0
  42. package/dist/agent-src/commands/council/debate.md +134 -0
  43. package/dist/agent-src/commands/council/default.md +289 -0
  44. package/dist/agent-src/commands/council/design.md +107 -0
  45. package/dist/agent-src/commands/council/optimize.md +123 -0
  46. package/dist/agent-src/commands/council/pr.md +130 -0
  47. package/dist/agent-src/commands/council.md +111 -0
  48. package/dist/agent-src/commands/e2e-heal.md +110 -0
  49. package/dist/agent-src/commands/e2e-plan.md +97 -0
  50. package/dist/agent-src/commands/estimate-ticket.md +92 -0
  51. package/dist/agent-src/commands/evals/agent-handoff.json +34 -0
  52. package/dist/agent-src/commands/evals/agent-status.json +34 -0
  53. package/dist/agent-src/commands/evals/agents.json +34 -0
  54. package/dist/agent-src/commands/evals/commit.json +34 -0
  55. package/dist/agent-src/commands/evals/condense.json +34 -0
  56. package/dist/agent-src/commands/evals/council.json +34 -0
  57. package/dist/agent-src/commands/evals/create-pr.json +34 -0
  58. package/dist/agent-src/commands/evals/estimate-ticket.json +34 -0
  59. package/dist/agent-src/commands/evals/feature.json +34 -0
  60. package/dist/agent-src/commands/evals/fix.json +34 -0
  61. package/dist/agent-src/commands/evals/implement-ticket.json +34 -0
  62. package/dist/agent-src/commands/evals/jira-ticket.json +34 -0
  63. package/dist/agent-src/commands/evals/judge.json +34 -0
  64. package/dist/agent-src/commands/evals/memory.json +34 -0
  65. package/dist/agent-src/commands/evals/mode.json +34 -0
  66. package/dist/agent-src/commands/evals/optimize.json +34 -0
  67. package/dist/agent-src/commands/evals/refine-ticket.json +34 -0
  68. package/dist/agent-src/commands/evals/review-changes.json +34 -0
  69. package/dist/agent-src/commands/evals/roadmap.json +34 -0
  70. package/dist/agent-src/commands/evals/work.json +34 -0
  71. package/dist/agent-src/commands/feature/dev.md +124 -0
  72. package/dist/agent-src/commands/feature/explore.md +191 -0
  73. package/dist/agent-src/commands/feature/plan.md +333 -0
  74. package/dist/agent-src/commands/feature/refactor.md +194 -0
  75. package/dist/agent-src/commands/feature/roadmap.md +222 -0
  76. package/dist/agent-src/commands/feature.md +63 -0
  77. package/dist/agent-src/commands/fix/ci.md +59 -0
  78. package/dist/agent-src/commands/fix/portability.md +108 -0
  79. package/dist/agent-src/commands/fix/pr-bot-comments.md +157 -0
  80. package/dist/agent-src/commands/fix/pr-comments.md +69 -0
  81. package/dist/agent-src/commands/fix/pr-developer-comments.md +163 -0
  82. package/dist/agent-src/commands/fix/refs.md +105 -0
  83. package/dist/agent-src/commands/fix/seeder.md +158 -0
  84. package/dist/agent-src/commands/fix.md +88 -0
  85. package/dist/agent-src/commands/ghostwriter/delete.md +124 -0
  86. package/dist/agent-src/commands/ghostwriter/fetch.md +190 -0
  87. package/dist/agent-src/commands/ghostwriter/list.md +108 -0
  88. package/dist/agent-src/commands/ghostwriter/show.md +119 -0
  89. package/dist/agent-src/commands/ghostwriter/write.md +165 -0
  90. package/dist/agent-src/commands/ghostwriter.md +101 -0
  91. package/dist/agent-src/commands/grill-me.md +45 -0
  92. package/dist/agent-src/commands/image/analyse.md +52 -0
  93. package/dist/agent-src/commands/image/create.md +54 -0
  94. package/dist/agent-src/commands/image/verify.md +49 -0
  95. package/dist/agent-src/commands/image.md +70 -0
  96. package/dist/agent-src/commands/implement-ticket.md +169 -0
  97. package/dist/agent-src/commands/jira-ticket.md +84 -0
  98. package/dist/agent-src/commands/judge/on-diff.md +124 -0
  99. package/dist/agent-src/commands/judge/solo.md +96 -0
  100. package/dist/agent-src/commands/judge/steps.md +94 -0
  101. package/dist/agent-src/commands/judge.md +86 -0
  102. package/dist/agent-src/commands/knowledge/cross-repo.md +72 -0
  103. package/dist/agent-src/commands/knowledge/forget.md +97 -0
  104. package/dist/agent-src/commands/knowledge/ingest.md +115 -0
  105. package/dist/agent-src/commands/knowledge/list.md +95 -0
  106. package/dist/agent-src/commands/knowledge.md +70 -0
  107. package/dist/agent-src/commands/memory/add.md +147 -0
  108. package/dist/agent-src/commands/memory/learn-low-impact.md +148 -0
  109. package/dist/agent-src/commands/memory/load.md +176 -0
  110. package/dist/agent-src/commands/memory/mine-session.md +157 -0
  111. package/dist/agent-src/commands/memory/promote.md +195 -0
  112. package/dist/agent-src/commands/memory/propose.md +122 -0
  113. package/dist/agent-src/commands/memory.md +61 -0
  114. package/dist/agent-src/commands/mode.md +133 -0
  115. package/dist/agent-src/commands/module/create.md +144 -0
  116. package/dist/agent-src/commands/module/explore.md +198 -0
  117. package/dist/agent-src/commands/module.md +52 -0
  118. package/dist/agent-src/commands/optimize/agents-dir.md +119 -0
  119. package/dist/agent-src/commands/optimize/augmentignore.md +312 -0
  120. package/dist/agent-src/commands/optimize/rtk.md +161 -0
  121. package/dist/agent-src/commands/optimize/skills.md +132 -0
  122. package/dist/agent-src/commands/optimize-prompt.md +67 -0
  123. package/dist/agent-src/commands/optimize.md +61 -0
  124. package/dist/agent-src/commands/orchestrate.md +129 -0
  125. package/dist/agent-src/commands/override/create.md +108 -0
  126. package/dist/agent-src/commands/override/manage.md +107 -0
  127. package/dist/agent-src/commands/override.md +72 -0
  128. package/dist/agent-src/commands/package-reset.md +163 -0
  129. package/dist/agent-src/commands/package-test.md +239 -0
  130. package/dist/agent-src/commands/post-as/ghostwriter.md +72 -0
  131. package/dist/agent-src/commands/post-as/me.md +130 -0
  132. package/dist/agent-src/commands/post-as.md +63 -0
  133. package/dist/agent-src/commands/pr/create/description-only.md +161 -0
  134. package/dist/agent-src/commands/pr/create.md +254 -0
  135. package/dist/agent-src/commands/prediction-pool.md +235 -0
  136. package/dist/agent-src/commands/prepare-for-review.md +107 -0
  137. package/dist/agent-src/commands/profile/activate.md +82 -0
  138. package/dist/agent-src/commands/profile/deactivate.md +69 -0
  139. package/dist/agent-src/commands/profile/show.md +80 -0
  140. package/dist/agent-src/commands/profile.md +69 -0
  141. package/dist/agent-src/commands/project-analyze.md +321 -0
  142. package/dist/agent-src/commands/project-health.md +106 -0
  143. package/dist/agent-src/commands/quality-fix.md +145 -0
  144. package/dist/agent-src/commands/refine-ticket.md +98 -0
  145. package/dist/agent-src/commands/research/deep.md +155 -0
  146. package/dist/agent-src/commands/research/report.md +140 -0
  147. package/dist/agent-src/commands/research.md +179 -0
  148. package/dist/agent-src/commands/review-changes.md +213 -0
  149. package/dist/agent-src/commands/review-routing.md +125 -0
  150. package/dist/agent-src/commands/roadmap/ai-council.md +189 -0
  151. package/dist/agent-src/commands/roadmap/create.md +214 -0
  152. package/dist/agent-src/commands/roadmap/process-full.md +109 -0
  153. package/dist/agent-src/commands/roadmap/process-phase.md +75 -0
  154. package/dist/agent-src/commands/roadmap/process-step.md +63 -0
  155. package/dist/agent-src/commands/roadmap.md +83 -0
  156. package/dist/agent-src/commands/rule-compliance-audit.md +156 -0
  157. package/dist/agent-src/commands/set-cost-profile.md +118 -0
  158. package/dist/agent-src/commands/skill/preview.md +68 -0
  159. package/dist/agent-src/commands/skill.md +49 -0
  160. package/dist/agent-src/commands/skills/discover.md +77 -0
  161. package/dist/agent-src/commands/skills.md +57 -0
  162. package/dist/agent-src/commands/sync-agent-settings.md +141 -0
  163. package/dist/agent-src/commands/sync-gitignore/fix.md +149 -0
  164. package/dist/agent-src/commands/sync-gitignore.md +140 -0
  165. package/dist/agent-src/commands/tests/create.md +91 -0
  166. package/dist/agent-src/commands/tests/execute.md +85 -0
  167. package/dist/agent-src/commands/tests.md +76 -0
  168. package/dist/agent-src/commands/threat-model.md +126 -0
  169. package/dist/agent-src/commands/update-form-request-messages.md +200 -0
  170. package/dist/agent-src/commands/upstream-contribute.md +182 -0
  171. package/dist/agent-src/commands/video/from-script.md +158 -0
  172. package/dist/agent-src/commands/video/from-song.md +490 -0
  173. package/dist/agent-src/commands/video/scene.md +130 -0
  174. package/dist/agent-src/commands/video/stitch.md +88 -0
  175. package/dist/agent-src/commands/video/storyboard.md +100 -0
  176. package/dist/agent-src/commands/video.md +74 -0
  177. package/dist/agent-src/commands/work.md +175 -0
  178. package/dist/agent-src/contexts/authority/commit-mechanics.md +93 -0
  179. package/dist/agent-src/contexts/communication/rules-auto/source-of-truth-mechanics.md +99 -0
  180. package/dist/agent-src/contexts/contracts/artifact-engagement-flow.md +259 -0
  181. package/dist/agent-src/contexts/contracts/consumer-agents-md-guide.md +127 -0
  182. package/dist/agent-src/contexts/contracts/emergency-triage-block.md +53 -0
  183. package/dist/agent-src/contexts/execution/non-interactive-contract.md +132 -0
  184. package/dist/agent-src/contexts/execution/toolchain-resolver.md +113 -0
  185. package/dist/agent-src/personas/README.md +114 -0
  186. package/dist/agent-src/profiles/agency.yml +36 -0
  187. package/dist/agent-src/profiles/content_creator.yml +34 -0
  188. package/dist/agent-src/profiles/developer.yml +31 -0
  189. package/dist/agent-src/profiles/finance.yml +30 -0
  190. package/dist/agent-src/profiles/founder.yml +33 -0
  191. package/dist/agent-src/profiles/ops.yml +33 -0
  192. package/dist/agent-src/rules/ask-when-uncertain.md +70 -0
  193. package/dist/agent-src/rules/augment-edit-discipline.md +31 -0
  194. package/dist/agent-src/rules/commit-policy.md +59 -0
  195. package/dist/agent-src/rules/direct-answers.md +64 -0
  196. package/dist/agent-src/rules/domain-adoption-policy.md +160 -0
  197. package/dist/agent-src/rules/language-and-tone.md +64 -0
  198. package/dist/agent-src/rules/linked-projects-onboarding-gate.md +38 -0
  199. package/dist/agent-src/rules/media-governance-routing.md +85 -0
  200. package/dist/agent-src/rules/missing-tool-handling.md +22 -0
  201. package/dist/agent-src/rules/model-recommendation.md +25 -0
  202. package/dist/agent-src/rules/no-attribution-footers.md +57 -0
  203. package/dist/agent-src/rules/no-cheap-questions.md +75 -0
  204. package/dist/agent-src/rules/no-pr-progress-comments.md +109 -0
  205. package/dist/agent-src/rules/no-roadmap-references.md +141 -0
  206. package/dist/agent-src/rules/non-destructive-by-default.md +58 -0
  207. package/dist/agent-src/rules/persona-governance.md +93 -0
  208. package/dist/agent-src/rules/preservation-guard.md +97 -0
  209. package/dist/agent-src/rules/provider-lifecycle-discipline.md +78 -0
  210. package/dist/agent-src/rules/roadmap-progress-sync.md +114 -0
  211. package/dist/agent-src/rules/scope-control.md +68 -0
  212. package/dist/agent-src/rules/source-of-truth.md +80 -0
  213. package/dist/agent-src/rules/user-interrupt-priority.md +49 -0
  214. package/dist/agent-src/rules/verify-before-complete.md +78 -0
  215. package/dist/agent-src/scripts/update_roadmap_progress.py +537 -0
  216. package/dist/agent-src/skills/accessibility-auditor/SKILL.md +147 -0
  217. package/dist/agent-src/skills/accessibility-auditor/data/aria-patterns.csv +13 -0
  218. package/dist/agent-src/skills/accessibility-auditor/data/manifest.json +34 -0
  219. package/dist/agent-src/skills/agents-md-thin-root/SKILL.md +143 -0
  220. package/dist/agent-src/skills/api-design/SKILL.md +120 -0
  221. package/dist/agent-src/skills/api-design/data/api-patterns.csv +13 -0
  222. package/dist/agent-src/skills/api-design/data/manifest.json +34 -0
  223. package/dist/agent-src/skills/api-endpoint/SKILL.md +100 -0
  224. package/dist/agent-src/skills/authz-review/SKILL.md +188 -0
  225. package/dist/agent-src/skills/blade-ui/SKILL.md +135 -0
  226. package/dist/agent-src/skills/character-consistency/SKILL.md +192 -0
  227. package/dist/agent-src/skills/check-refs/SKILL.md +96 -0
  228. package/dist/agent-src/skills/code-review/SKILL.md +224 -0
  229. package/dist/agent-src/skills/command-writing/SKILL.md +301 -0
  230. package/dist/agent-src/skills/condense-memory/SKILL.md +123 -0
  231. package/dist/agent-src/skills/context-document/SKILL.md +160 -0
  232. package/dist/agent-src/skills/corpus-grounding/SKILL.md +205 -0
  233. package/dist/agent-src/skills/corpus-grounding/evals/triggers.json +16 -0
  234. package/dist/agent-src/skills/corpus-grounding/scripts/bm25_search.py +212 -0
  235. package/dist/agent-src/skills/corpus-grounding/scripts/decision_engine.py +438 -0
  236. package/dist/agent-src/skills/corpus-grounding/scripts/ground.py +166 -0
  237. package/dist/agent-src/skills/corpus-grounding/scripts/schema_validator.py +160 -0
  238. package/dist/agent-src/skills/dashboard-design/SKILL.md +129 -0
  239. package/dist/agent-src/skills/database/SKILL.md +111 -0
  240. package/dist/agent-src/skills/database/data/manifest.json +35 -0
  241. package/dist/agent-src/skills/database/data/query-tuning.csv +13 -0
  242. package/dist/agent-src/skills/deep-reading-analyst/SKILL.md +188 -0
  243. package/dist/agent-src/skills/design-intelligence/ATTRIBUTION.md +54 -0
  244. package/dist/agent-src/skills/design-intelligence/LICENSE.apache-2.0.txt +202 -0
  245. package/dist/agent-src/skills/design-intelligence/SKILL.md +177 -0
  246. package/dist/agent-src/skills/design-intelligence/data/app-interface.csv +31 -0
  247. package/dist/agent-src/skills/design-intelligence/data/charts.csv +26 -0
  248. package/dist/agent-src/skills/design-intelligence/data/colors.csv +162 -0
  249. package/dist/agent-src/skills/design-intelligence/data/design-languages/academia.txt +120 -0
  250. package/dist/agent-src/skills/design-intelligence/data/design-languages/bauhaus.txt +140 -0
  251. package/dist/agent-src/skills/design-intelligence/data/design-languages/bold-typography.txt +107 -0
  252. package/dist/agent-src/skills/design-intelligence/data/design-languages/claymorphism.txt +76 -0
  253. package/dist/agent-src/skills/design-intelligence/data/design-languages/cyberpunk.txt +157 -0
  254. package/dist/agent-src/skills/design-intelligence/data/design-languages/enterprise.txt +89 -0
  255. package/dist/agent-src/skills/design-intelligence/data/design-languages/flat-design.txt +66 -0
  256. package/dist/agent-src/skills/design-intelligence/data/design-languages/kinetic.txt +98 -0
  257. package/dist/agent-src/skills/design-intelligence/data/design-languages/material-design.txt +133 -0
  258. package/dist/agent-src/skills/design-intelligence/data/design-languages/modern-dark.txt +123 -0
  259. package/dist/agent-src/skills/design-intelligence/data/design-languages/monochrome.txt +216 -0
  260. package/dist/agent-src/skills/design-intelligence/data/design-languages/neo-brutalism.txt +65 -0
  261. package/dist/agent-src/skills/design-intelligence/data/design-languages/neumorphism.txt +75 -0
  262. package/dist/agent-src/skills/design-intelligence/data/design-languages/saas.txt +109 -0
  263. package/dist/agent-src/skills/design-intelligence/data/design-languages/sketch.txt +83 -0
  264. package/dist/agent-src/skills/design-intelligence/data/design-languages/terminal.txt +80 -0
  265. package/dist/agent-src/skills/design-intelligence/data/icons.csv +106 -0
  266. package/dist/agent-src/skills/design-intelligence/data/landing.csv +35 -0
  267. package/dist/agent-src/skills/design-intelligence/data/manifest.json +500 -0
  268. package/dist/agent-src/skills/design-intelligence/data/products.csv +162 -0
  269. package/dist/agent-src/skills/design-intelligence/data/react-performance.csv +45 -0
  270. package/dist/agent-src/skills/design-intelligence/data/stacks/angular.csv +51 -0
  271. package/dist/agent-src/skills/design-intelligence/data/stacks/astro.csv +54 -0
  272. package/dist/agent-src/skills/design-intelligence/data/stacks/flutter.csv +53 -0
  273. package/dist/agent-src/skills/design-intelligence/data/stacks/html-tailwind.csv +56 -0
  274. package/dist/agent-src/skills/design-intelligence/data/stacks/jetpack-compose.csv +53 -0
  275. package/dist/agent-src/skills/design-intelligence/data/stacks/laravel.csv +51 -0
  276. package/dist/agent-src/skills/design-intelligence/data/stacks/nextjs.csv +53 -0
  277. package/dist/agent-src/skills/design-intelligence/data/stacks/nuxt-ui.csv +51 -0
  278. package/dist/agent-src/skills/design-intelligence/data/stacks/nuxtjs.csv +59 -0
  279. package/dist/agent-src/skills/design-intelligence/data/stacks/react-native.csv +52 -0
  280. package/dist/agent-src/skills/design-intelligence/data/stacks/react.csv +54 -0
  281. package/dist/agent-src/skills/design-intelligence/data/stacks/shadcn.csv +61 -0
  282. package/dist/agent-src/skills/design-intelligence/data/stacks/svelte.csv +54 -0
  283. package/dist/agent-src/skills/design-intelligence/data/stacks/swiftui.csv +51 -0
  284. package/dist/agent-src/skills/design-intelligence/data/stacks/threejs.csv +54 -0
  285. package/dist/agent-src/skills/design-intelligence/data/stacks/vue.csv +50 -0
  286. package/dist/agent-src/skills/design-intelligence/data/styles.csv +85 -0
  287. package/dist/agent-src/skills/design-intelligence/data/typography.csv +74 -0
  288. package/dist/agent-src/skills/design-intelligence/data/ui-reasoning.csv +162 -0
  289. package/dist/agent-src/skills/design-intelligence/data/ux-guidelines.csv +100 -0
  290. package/dist/agent-src/skills/design-intelligence/evals/triggers.json +16 -0
  291. package/dist/agent-src/skills/design-intelligence/references/design-languages.md +45 -0
  292. package/dist/agent-src/skills/design-intelligence/references/design-rules-checklist.md +268 -0
  293. package/dist/agent-src/skills/design-review/SKILL.md +233 -0
  294. package/dist/agent-src/skills/design-tokens/SKILL.md +135 -0
  295. package/dist/agent-src/skills/design-tokens/evals/triggers.json +16 -0
  296. package/dist/agent-src/skills/design-tokens/scripts/tokens.py +296 -0
  297. package/dist/agent-src/skills/design-tokens/templates/design-tokens-starter.json +143 -0
  298. package/dist/agent-src/skills/existing-ui-audit/SKILL.md +217 -0
  299. package/dist/agent-src/skills/fe-design/SKILL.md +265 -0
  300. package/dist/agent-src/skills/feature-planning/SKILL.md +271 -0
  301. package/dist/agent-src/skills/flux/SKILL.md +126 -0
  302. package/dist/agent-src/skills/jira-integration/SKILL.md +187 -0
  303. package/dist/agent-src/skills/lint-skills/SKILL.md +95 -0
  304. package/dist/agent-src/skills/livewire/SKILL.md +139 -0
  305. package/dist/agent-src/skills/md-language-check/SKILL.md +130 -0
  306. package/dist/agent-src/skills/merge-conflicts/SKILL.md +195 -0
  307. package/dist/agent-src/skills/motion-choreographer/SKILL.md +197 -0
  308. package/dist/agent-src/skills/persona-writing/SKILL.md +158 -0
  309. package/dist/agent-src/skills/prompt-validator/SKILL.md +167 -0
  310. package/dist/agent-src/skills/prompt-validator/evals/triggers.json +16 -0
  311. package/dist/agent-src/skills/react-shadcn-ui/SKILL.md +235 -0
  312. package/dist/agent-src/skills/react-shadcn-ui/scripts/shadcn_add.py +299 -0
  313. package/dist/agent-src/skills/readme-reviewer/SKILL.md +242 -0
  314. package/dist/agent-src/skills/readme-writing/SKILL.md +240 -0
  315. package/dist/agent-src/skills/readme-writing-package/SKILL.md +350 -0
  316. package/dist/agent-src/skills/roadmap-management/SKILL.md +461 -0
  317. package/dist/agent-src/skills/rule-refactor/SKILL.md +149 -0
  318. package/dist/agent-src/skills/rule-writing/SKILL.md +277 -0
  319. package/dist/agent-src/skills/scene-expander/SKILL.md +158 -0
  320. package/dist/agent-src/skills/scene-expander/scene-blueprint.schema.yaml +114 -0
  321. package/dist/agent-src/skills/script-writing/SKILL.md +231 -0
  322. package/dist/agent-src/skills/sentry-integration/SKILL.md +175 -0
  323. package/dist/agent-src/skills/song-to-script/SKILL.md +303 -0
  324. package/dist/agent-src/skills/sql-writing/SKILL.md +85 -0
  325. package/dist/agent-src/skills/tailwind-engineer/SKILL.md +154 -0
  326. package/dist/agent-src/skills/tailwind-engineer/scripts/tailwind_config_gen.py +463 -0
  327. package/dist/agent-src/skills/technical-specification/SKILL.md +251 -0
  328. package/dist/agent-src/skills/threat-modeling/SKILL.md +207 -0
  329. package/dist/agent-src/skills/threat-modeling/data/manifest.json +83 -0
  330. package/dist/agent-src/skills/threat-modeling/data/reasoning.csv +10 -0
  331. package/dist/agent-src/skills/threat-modeling/data/surfaces.csv +10 -0
  332. package/dist/agent-src/skills/threat-modeling/data/threats.csv +16 -0
  333. package/dist/agent-src/skills/upstream-contribute/SKILL.md +261 -0
  334. package/dist/agent-src/templates/AGENTS.md +34 -0
  335. package/dist/agent-src/templates/agents/agent-project-settings.example.yml +286 -0
  336. package/dist/agent-src/templates/agents/proposal.example.md +155 -0
  337. package/dist/agent-src/templates/command.md +105 -0
  338. package/dist/agent-src/templates/copilot-instructions.md +167 -0
  339. package/dist/agent-src/templates/github-workflows/proposal-drift.yml +118 -0
  340. package/dist/agent-src/templates/hooks/pre-commit-frontmatter +66 -0
  341. package/dist/agent-src/templates/hooks/pre-commit-roadmap-progress +99 -0
  342. package/dist/agent-src/templates/persona.md +99 -0
  343. package/dist/agent-src/templates/rule.md +135 -0
  344. package/dist/agent-src/templates/scripts/work_engine/directives/ui/polish.py +513 -0
  345. package/dist/agent-src/templates/scripts/work_engine/directives/ui/review.py +471 -0
  346. package/dist/agent-src/templates/scripts/work_engine/orchestration.py +193 -0
  347. package/dist/agent-src/templates/scripts/work_engine/stack/runner.py +481 -0
  348. package/dist/agent-src/user-types/README.md +124 -0
  349. package/dist/cli/agent-config.js +51 -3
  350. package/dist/cli/agent-config.js.map +1 -1
  351. package/dist/cli/commands/commands.js +152 -0
  352. package/dist/cli/commands/commands.js.map +1 -0
  353. package/dist/cli/commands/mcpServer.js +54 -0
  354. package/dist/cli/commands/mcpServer.js.map +1 -0
  355. package/dist/cli/commands/packs.js +1 -1
  356. package/dist/cli/commands/packs.js.map +1 -1
  357. package/dist/cli/commands/profiles.js +77 -0
  358. package/dist/cli/commands/profiles.js.map +1 -0
  359. package/dist/cli/commands/profiles.test.js +88 -0
  360. package/dist/cli/commands/profiles.test.js.map +1 -0
  361. package/dist/cli/commands/workspaces.js +1 -1
  362. package/dist/cli/commands/workspaces.js.map +1 -1
  363. package/dist/cli/discovery/loadManifest.js.map +1 -1
  364. package/dist/cli/mcp/content.js +127 -0
  365. package/dist/cli/mcp/content.js.map +1 -0
  366. package/dist/cli/mcp/content.test.js +54 -0
  367. package/dist/cli/mcp/content.test.js.map +1 -0
  368. package/dist/cli/mcp/dispatch.js +167 -0
  369. package/dist/cli/mcp/dispatch.js.map +1 -0
  370. package/dist/cli/mcp/dispatch.test.js +108 -0
  371. package/dist/cli/mcp/dispatch.test.js.map +1 -0
  372. package/dist/cli/mcp/stdio.js +69 -0
  373. package/dist/cli/mcp/stdio.js.map +1 -0
  374. package/dist/cli/paths.js +8 -2
  375. package/dist/cli/paths.js.map +1 -1
  376. package/dist/cli/registry.js +2 -0
  377. package/dist/cli/registry.js.map +1 -1
  378. package/dist/discovery/deprecation-report.md +1 -1
  379. package/dist/discovery/discovery-manifest.json +2885 -2056
  380. package/dist/discovery/discovery-manifest.json.sha256 +1 -1
  381. package/dist/discovery/discovery-manifest.summary.md +8 -6
  382. package/dist/discovery/orphan-report.md +1 -1
  383. package/dist/discovery/packs.json +689 -466
  384. package/dist/discovery/trust-report.md +5 -5
  385. package/dist/discovery/workspaces.json +495 -477
  386. package/dist/install/detect.js +2 -2
  387. package/dist/install/detect.js.map +1 -1
  388. package/dist/install/wizard-plan.js +18 -18
  389. package/dist/install/wizard-plan.js.map +1 -1
  390. package/dist/mcp/registry-manifest.json +4 -4
  391. package/dist/router.json +1 -1
  392. package/dist/server/io/substituteTemplate.js +5 -5
  393. package/dist/server/io/substituteTemplate.js.map +1 -1
  394. package/dist/server/routes/settings.js +2 -2
  395. package/dist/server/routes/settings.js.map +1 -1
  396. package/dist/server/routes/userMd.js +1 -1
  397. package/dist/server/routes/userMd.js.map +1 -1
  398. package/dist/server/routes/wizard.js +27 -13
  399. package/dist/server/routes/wizard.js.map +1 -1
  400. package/dist/server/routes/workspace.js +556 -117
  401. package/dist/server/routes/workspace.js.map +1 -1
  402. package/dist/server/schemas/settings.js +7 -2
  403. package/dist/server/schemas/settings.js.map +1 -1
  404. package/dist/shared/userMd/formAdapter.js +2 -2
  405. package/dist/ui/assets/index-CoQo90sz.js +40 -0
  406. package/dist/ui/assets/index-CoQo90sz.js.map +1 -0
  407. package/dist/ui/index.html +1 -1
  408. package/docs/DISTRIBUTION_CHECKLIST.md +2 -2
  409. package/docs/adrs/cost/0001-hard-stop-hook.md +5 -5
  410. package/docs/adrs/memory/0001-consumer-side-snapshot.md +4 -4
  411. package/docs/adrs/router/0001-three-tier-routing.md +3 -3
  412. package/docs/adrs/schema/0001-json-schema-frontmatter.md +6 -6
  413. package/docs/adrs/smoke/0001-per-tier-smoke-scripts.md +6 -6
  414. package/docs/architecture/augment-projection.md +10 -10
  415. package/docs/architecture/claude-bundle.md +5 -5
  416. package/docs/architecture/current-onboard-baseline.md +4 -4
  417. package/docs/architecture/current-safety-behavior.md +16 -16
  418. package/docs/architecture/multi-tool-projection.md +8 -8
  419. package/docs/architecture/source-projection.md +11 -11
  420. package/docs/architecture.md +11 -11
  421. package/docs/archive/CHANGELOG-pre-2.17.0.md +1 -1
  422. package/docs/archive/CHANGELOG-pre-2.2.0.md +7 -7
  423. package/docs/archive/CHANGELOG-pre-2.20.0.md +1 -1
  424. package/docs/archive/CHANGELOG-pre-2.25.0.md +1 -1
  425. package/docs/archive/CHANGELOG-pre-2.7.0.md +1 -1
  426. package/docs/archive/CHANGELOG-pre-3.0.0.md +1 -1
  427. package/docs/archive/CHANGELOG-pre-3.1.0.md +1 -1
  428. package/docs/archive/CHANGELOG-pre-3.2.0.md +1 -1
  429. package/docs/archive/CHANGELOG-pre-4.5.0.md +1 -1
  430. package/docs/archive/CHANGELOG-pre-5.4.0.md +1 -1
  431. package/docs/archive/CHANGELOG-pre-5.9.0.md +1 -1
  432. package/docs/artefact-census.md +71 -0
  433. package/docs/case-studies/frontend-design-vs-ui-ux-pro-max.md +86 -0
  434. package/docs/catalog.md +463 -454
  435. package/docs/command-flows.md +232 -0
  436. package/docs/contracts/CHANGELOG-conventions.md +2 -2
  437. package/docs/contracts/STABILITY.md +1 -1
  438. package/docs/contracts/adoption-signal-floor.md +2 -2
  439. package/docs/contracts/adr-architectural-consensus-mechanism.md +1 -1
  440. package/docs/contracts/adr-chat-history-split.md +1 -1
  441. package/docs/contracts/adr-gtm-context-spine.md +2 -2
  442. package/docs/contracts/adr-install-user-type-axis.md +3 -3
  443. package/docs/contracts/adr-layout.md +3 -3
  444. package/docs/contracts/adr-mcp-runtime.md +8 -8
  445. package/docs/contracts/adr-prompt-driven-execution.md +1 -1
  446. package/docs/contracts/adr-settings-sync-engine.md +3 -3
  447. package/docs/contracts/adr-user-types-axis.md +2 -2
  448. package/docs/contracts/adr-wing4-context-spine.md +2 -2
  449. package/docs/contracts/agent-user-schema.md +6 -6
  450. package/docs/contracts/agents-md-tech-stack.md +2 -2
  451. package/docs/contracts/ai-council-config.md +4 -4
  452. package/docs/contracts/at-rest-encryption.md +48 -7
  453. package/docs/contracts/audit-log-v1.md +3 -3
  454. package/docs/contracts/benchmark-ab-contract.md +6 -1
  455. package/docs/contracts/benchmark-corpus-spec.md +2 -2
  456. package/docs/contracts/benchmark-report-schema.md +4 -4
  457. package/docs/contracts/branch-protection-policy.md +5 -0
  458. package/docs/contracts/capability-packs.md +217 -0
  459. package/docs/contracts/ci-cost-budget.md +6 -1
  460. package/docs/contracts/ci-green-floor.md +1 -1
  461. package/docs/contracts/command-category-governance.md +79 -0
  462. package/docs/contracts/command-clusters.md +42 -4
  463. package/docs/contracts/config-presets.md +1 -1
  464. package/docs/contracts/cost-dashboard.md +1 -1
  465. package/docs/contracts/cost-profile-defaults.md +2 -2
  466. package/docs/contracts/cost-summary-schema.md +4 -4
  467. package/docs/contracts/creative-pack-boundary.md +58 -0
  468. package/docs/contracts/daily-workspace.md +8 -3
  469. package/docs/contracts/discovery-manifest.md +5 -5
  470. package/docs/contracts/discovery-manifest.schema.json +14 -3
  471. package/docs/contracts/evidence-based-pruning.md +101 -0
  472. package/docs/contracts/explain-modes.md +37 -0
  473. package/docs/contracts/file-ownership-matrix.json +1804 -4620
  474. package/docs/contracts/frontmatter-contract.md +6 -6
  475. package/docs/contracts/ghostwriter-schema.md +1 -1
  476. package/docs/contracts/gui-wizard.md +1 -1
  477. package/docs/contracts/harness-expectations.md +5 -0
  478. package/docs/contracts/hook-architecture-v1.md +1 -1
  479. package/docs/contracts/host-agent-protocol.md +19 -1
  480. package/docs/contracts/install-scopes.md +7 -2
  481. package/docs/contracts/installed-tools-lockfile.md +2 -2
  482. package/docs/contracts/linear-ai-rules-inclusion.md +2 -2
  483. package/docs/contracts/linear-ai-three-layers.md +1 -1
  484. package/docs/contracts/linter-structural-model.md +2 -2
  485. package/docs/contracts/load-context-budget-model.md +1 -1
  486. package/docs/contracts/load-context-schema.md +1 -1
  487. package/docs/contracts/local-analytics.md +9 -1
  488. package/docs/contracts/low-impact-corpus-format.md +1 -1
  489. package/docs/contracts/mcp-cloud-scope.md +6 -6
  490. package/docs/contracts/mcp-phase-1-scope.md +5 -5
  491. package/docs/contracts/measurement-baseline.md +5 -5
  492. package/docs/contracts/migrate-command.md +44 -8
  493. package/docs/contracts/multi-tool-projection-fidelity.md +3 -3
  494. package/docs/contracts/namespace.md +1 -1
  495. package/docs/contracts/orchestration-dsl-v1.md +2 -2
  496. package/docs/contracts/package-self-orientation.md +17 -17
  497. package/docs/contracts/pilot/language-and-tone.md +1 -1
  498. package/docs/contracts/plain-language-surface.md +2 -2
  499. package/docs/contracts/profile-system.md +26 -1
  500. package/docs/contracts/provider-lifecycle.md +3 -3
  501. package/docs/contracts/release-pr-gating.md +5 -0
  502. package/docs/contracts/release-trunk-sync.md +3 -3
  503. package/docs/contracts/review-lens-schema.md +59 -0
  504. package/docs/contracts/role-experience.md +10 -6
  505. package/docs/contracts/router-blending.md +2 -2
  506. package/docs/contracts/rule-classification.md +1 -1
  507. package/docs/contracts/rule-router.md +3 -3
  508. package/docs/contracts/safety-model.md +2 -2
  509. package/docs/contracts/session-profile-overlay.md +40 -3
  510. package/docs/contracts/settings-api.md +3 -3
  511. package/docs/contracts/settings-sync-yaml-subset.md +4 -4
  512. package/docs/contracts/skill-bundled-assets.md +62 -0
  513. package/docs/contracts/skill-discovery.md +1 -1
  514. package/docs/contracts/skill-distribution-channels.md +6 -1
  515. package/docs/contracts/skill-dry-run.md +2 -2
  516. package/docs/contracts/skill-family-map.yml +915 -0
  517. package/docs/contracts/smoke-contracts.md +4 -4
  518. package/docs/contracts/telegraph-telemetry.md +2 -2
  519. package/docs/contracts/trust-and-safety.md +3 -3
  520. package/docs/contracts/universal-skills.md +16 -16
  521. package/docs/contracts/value-dashboard-spec.md +21 -21
  522. package/docs/contracts/value-report-schema.md +8 -8
  523. package/docs/customization.md +8 -8
  524. package/docs/decisions/ADR-006-skill-tools-python-pilot.md +2 -2
  525. package/docs/decisions/ADR-007-agent-discovery-scopes.md +1 -1
  526. package/docs/decisions/ADR-008-installed-tools-manifest.md +1 -1
  527. package/docs/decisions/ADR-009-event4u-namespace.md +3 -3
  528. package/docs/decisions/ADR-013-discovery-frontmatter-contract.md +27 -8
  529. package/docs/decisions/ADR-015-discovery-manifest-contract.md +5 -5
  530. package/docs/decisions/ADR-017-monorepo-physical-layout.md +5 -5
  531. package/docs/decisions/ADR-018-trust-and-safety-layer.md +2 -2
  532. package/docs/decisions/ADR-019-router-json-dist-location.md +2 -2
  533. package/docs/decisions/ADR-020-global-only-consumer-scope.md +27 -2
  534. package/docs/decisions/ADR-022-daily-workspace-decomposition.md +2 -2
  535. package/docs/decisions/ADR-024-workspace-v0-feature-floor.md +1 -1
  536. package/docs/decisions/ADR-028-root-layout.md +1 -1
  537. package/docs/decisions/ADR-030-claude-code-command-projection.md +2 -2
  538. package/docs/decisions/ADR-038-canonical-settings-path.md +20 -0
  539. package/docs/decisions/ADR-041-controlled-command-verbs.md +133 -0
  540. package/docs/decisions/ADR-042-runtime-resolver-decision-gate.md +113 -0
  541. package/docs/decisions/ADR-043-monorepo-collapse-to-src-domains.md +128 -0
  542. package/docs/decisions/ADR-044-command-naming-scheme-hyphenated.md +250 -0
  543. package/docs/decisions/ADR-045-src-source-layout-and-profiles-as-views.md +111 -0
  544. package/docs/decisions/ADR-046-thin-command-principle.md +93 -0
  545. package/docs/decisions/ADR-047-framework-neutral-stack-adaptive-commands.md +94 -0
  546. package/docs/decisions/ADR-048-command-justification-rule.md +106 -0
  547. package/docs/decisions/ADR-049-configuration-trust-boundary.md +114 -0
  548. package/docs/decisions/ADR-050-workspace-vs-package-root-boundary.md +121 -0
  549. package/docs/decisions/ADR-051-uncondensed-source-container-relocation.md +114 -0
  550. package/docs/decisions/ADR-052-packages-removal-and-pack-home-migration.md +86 -0
  551. package/docs/decisions/ADR-053-agents-namespace-dual-role-resolution.md +132 -0
  552. package/docs/decisions/ADR-054-rule-adherence-decay-triggered-restate.md +143 -0
  553. package/docs/decisions/ADR-055-flow-layer-data-model.md +235 -0
  554. package/docs/decisions/ADR-056-unvalidated-video-adapters-disposition.md +124 -0
  555. package/docs/decisions/ADR-057-consolidation-evidence-gate-outcomes.md +135 -0
  556. package/docs/decisions/ADR-058-condensed-output-relocation-to-dist.md +94 -0
  557. package/docs/decisions/ADR-059-render-resume-filesystem-as-state.md +161 -0
  558. package/docs/decisions/ADR-060-comfyui-sandbox-model.md +154 -0
  559. package/docs/decisions/ADR-061-corpus-grounding-layer.md +170 -0
  560. package/docs/decisions/ADR-062-encrypt-at-rest-store-architecture.md +121 -0
  561. package/docs/decisions/ADR-063-append-jsonl-encryption-deferred.md +83 -0
  562. package/docs/decisions/ADR-064-append-jsonl-per-record-encryption.md +113 -0
  563. package/docs/decisions/ADR-065-tier3-inbox-handoff-v0.md +86 -0
  564. package/docs/decisions/ADR-066-skill-body-prerendering.md +93 -0
  565. package/docs/decisions/ADR-067-glama-registry-listing.md +259 -0
  566. package/docs/decisions/ADR-068-host-tier-detection.md +90 -0
  567. package/docs/decisions/ADR-069-prompt-renderer.md +97 -0
  568. package/docs/decisions/ADR-070-tier1-drive-loop.md +94 -0
  569. package/docs/decisions/ADR-071-launch-drive-integration.md +95 -0
  570. package/docs/decisions/ADR-072-codex-gemini-drive-configs.md +90 -0
  571. package/docs/decisions/ADR-073-drive-health-kill-switch.md +81 -0
  572. package/docs/decisions/ADR-074-drive-kill-switch-auto-recovery.md +84 -0
  573. package/docs/decisions/ADR-075-workspace-gui-drive.md +83 -0
  574. package/docs/decisions/ADR-076-workspace-multi-turn.md +92 -0
  575. package/docs/decisions/ADR-077-workspace-followup-gui.md +70 -0
  576. package/docs/decisions/ADR-078-drive-health-panel.md +70 -0
  577. package/docs/decisions/ADR-079-workspace-host-picker.md +81 -0
  578. package/docs/decisions/ADR-080-host-session-expired-410.md +92 -0
  579. package/docs/decisions/ADR-081-drive-health-reset-and-410-affordance.md +71 -0
  580. package/docs/decisions/ADR-082-410-one-click-relaunch.md +58 -0
  581. package/docs/decisions/ADR-083-session-thread-and-arbitrary-continuation.md +85 -0
  582. package/docs/decisions/ADR-084-drive-health-refresh-on-drive.md +52 -0
  583. package/docs/decisions/ADR-085-mcp-stdio-end-user-distribution-shape.md +158 -0
  584. package/docs/decisions/ADR-086-read-only-cross-agent-mcp-discovery-helper.md +171 -0
  585. package/docs/decisions/ADR-087-installer-e2e-test-strategy.md +111 -0
  586. package/docs/decisions/ADR-088-no-external-runtime-federation.md +145 -0
  587. package/docs/decisions/ADR-089-lean-local-plugin-install.md +111 -0
  588. package/docs/decisions/INDEX.md +49 -0
  589. package/docs/deploy/small-team-recipe.md +1 -1
  590. package/docs/deploy/team-deployment-posture.md +1 -1
  591. package/docs/development.md +6 -6
  592. package/docs/distribution/public-install-smoke.md +1 -1
  593. package/docs/distribution/registries.md +5 -5
  594. package/docs/distribution/registry-submissions.md +2 -2
  595. package/docs/end-to-end-walkthroughs.md +10 -10
  596. package/docs/experiences/agency.md +49 -0
  597. package/docs/experiences/content_creator.md +47 -0
  598. package/docs/experiences/developer.md +49 -0
  599. package/docs/experiences/finance.md +48 -0
  600. package/docs/experiences/founder.md +47 -0
  601. package/docs/experiences/ops.md +47 -0
  602. package/docs/featured-commands.md +12 -12
  603. package/docs/featured-skills.md +32 -32
  604. package/docs/flows.md +67 -0
  605. package/docs/getting-started-by-role.md +41 -41
  606. package/docs/getting-started-laravel.md +26 -26
  607. package/docs/getting-started-local-stdio.md +77 -0
  608. package/docs/getting-started.md +2 -2
  609. package/docs/governance.md +96 -0
  610. package/docs/guidelines/agent-infra/asking-and-brevity-examples.md +6 -6
  611. package/docs/guidelines/agent-infra/comparison-matrix.md +179 -0
  612. package/docs/guidelines/agent-infra/corpus-grounding-authoring.md +91 -0
  613. package/docs/guidelines/agent-infra/direct-answers-demos.md +23 -26
  614. package/docs/guidelines/agent-infra/language-and-tone-examples.md +29 -2
  615. package/docs/guidelines/agent-infra/layered-settings.md +3 -3
  616. package/docs/guidelines/agent-infra/linked-projects-onboarding-gate.md +80 -0
  617. package/docs/guidelines/agent-infra/missing-tool-handling.md +66 -0
  618. package/docs/guidelines/agent-infra/model-recommendation.md +72 -0
  619. package/docs/guidelines/agent-infra/roadmap-progress-mechanics.md +1 -1
  620. package/docs/guidelines/agent-infra/self-improvement-pipeline.md +1 -1
  621. package/docs/guidelines/agent-infra/verify-before-complete-demos.md +1 -1
  622. package/docs/guidelines/augment-portability-patterns.md +1 -1
  623. package/docs/guides/local-analytics.md +1 -1
  624. package/docs/guides/local-knowledge.md +3 -3
  625. package/docs/hook-payload-capture.md +5 -5
  626. package/docs/installation.md +3 -3
  627. package/docs/mcp-registries.md +94 -0
  628. package/docs/mcp-server.md +4 -4
  629. package/docs/mcp.md +3 -0
  630. package/docs/parity/ruflo.md +7 -7
  631. package/docs/personas.md +3 -3
  632. package/docs/profiles.md +15 -11
  633. package/docs/quality.md +3 -3
  634. package/docs/setup/mcp-client-config.md +134 -9
  635. package/docs/setup/mcp-server-docker.md +9 -7
  636. package/docs/setup/per-ide/claude-code.md +3 -3
  637. package/docs/setup/per-ide/claude-desktop.md +1 -1
  638. package/docs/setup/per-ide/cursor.md +2 -2
  639. package/docs/setup/per-ide/windsurf.md +1 -1
  640. package/docs/showcase.md +12 -12
  641. package/docs/skill-duplication-findings.md +91 -0
  642. package/docs/skills-catalog.md +228 -224
  643. package/docs/skills-taxonomy.md +90 -0
  644. package/docs/ui-track-mental-model.md +2 -2
  645. package/docs/value.md +50 -50
  646. package/docs/walkthroughs/assets/workspace-role-grid.png +0 -0
  647. package/docs/walkthroughs/assets/workspace-session-started.png +0 -0
  648. package/docs/walkthroughs/assets/workspace-task-picker.png +0 -0
  649. package/docs/walkthroughs/daily-workspace.md +127 -0
  650. package/llms.txt +18 -14
  651. package/package.json +10 -9
  652. package/src/config/agent-settings.template.yml +612 -0
  653. package/src/config/discovery/command-verbs.yml +56 -0
  654. package/src/config/discovery/packs.yml +255 -0
  655. package/src/config/discovery/workspaces.yml +72 -0
  656. package/src/scripts/__pycache__/validate_frontmatter.cpython-312.pyc +0 -0
  657. package/src/scripts/_archive/README.md +59 -0
  658. package/src/scripts/_archive/_bootstrap_tier_frontmatter.py +151 -0
  659. package/src/scripts/_archive/_p43_bodies.py +235 -0
  660. package/src/scripts/_archive/_p43_condense.py +118 -0
  661. package/src/scripts/_archive/_p4_migrate.py +199 -0
  662. package/src/scripts/_cli/cmd_doctor.py +1583 -0
  663. package/src/scripts/_cli/cmd_export.py +157 -0
  664. package/src/scripts/_cli/cmd_migrate.py +524 -0
  665. package/src/scripts/_cli/cmd_refresh.py +179 -0
  666. package/src/scripts/_cli/cmd_settings_migrate.py +147 -0
  667. package/src/scripts/_cli/cmd_update.py +279 -0
  668. package/src/scripts/_cli/cmd_upgrade.py +172 -0
  669. package/src/scripts/_cli/cmd_versions.py +160 -0
  670. package/src/scripts/_dispatch.bash +1129 -0
  671. package/src/scripts/_lib/__pycache__/__init__.cpython-312.pyc +0 -0
  672. package/src/scripts/_lib/__pycache__/agent_src.cpython-312.pyc +0 -0
  673. package/src/scripts/_lib/agent_src.py +491 -0
  674. package/src/scripts/_lib/bench_ab_cache.py +162 -0
  675. package/src/scripts/_lib/changelog_eras.py +330 -0
  676. package/src/scripts/_lib/claude_desktop_bundler.py +238 -0
  677. package/src/scripts/_lib/cli_wrapper.py +64 -0
  678. package/src/scripts/_lib/global_deploy_inventory.py +282 -0
  679. package/src/scripts/_lib/install_regenerator.py +134 -0
  680. package/src/scripts/_lib/installed_lock.py +256 -0
  681. package/src/scripts/_lib/model_tier.py +52 -0
  682. package/src/scripts/_lib/scope_guard.sh +163 -0
  683. package/src/scripts/_lib/value_ladder.py +696 -0
  684. package/src/scripts/_lib/value_report.py +455 -0
  685. package/src/scripts/_phase4_bucket.py +210 -0
  686. package/src/scripts/_pilot_measure.py +53 -0
  687. package/src/scripts/adoption_report.py +195 -0
  688. package/src/scripts/adoption_snapshot.py +219 -0
  689. package/src/scripts/adoption_status.py +166 -0
  690. package/src/scripts/agent-config +57 -0
  691. package/src/scripts/ai-video/adapters/comfyui.sh +392 -0
  692. package/src/scripts/ai-video/adapters/fal.sh +311 -0
  693. package/src/scripts/ai-video/adapters/gemini-veo.sh +246 -0
  694. package/src/scripts/ai-video/adapters/higgsfield.sh +310 -0
  695. package/src/scripts/ai-video/adapters/kling.sh +248 -0
  696. package/src/scripts/ai-video/adapters/musetalk.sh +120 -0
  697. package/src/scripts/ai-video/adapters/openai-images.sh +147 -0
  698. package/src/scripts/ai-video/adapters/replicate.sh +289 -0
  699. package/src/scripts/ai-video/adapters/sora.sh +207 -0
  700. package/src/scripts/ai-video/adapters/syncso.sh +200 -0
  701. package/src/scripts/ai-video/audio-adapters/allin1.sh +115 -0
  702. package/src/scripts/ai-video/audio-adapters/whisperx.sh +128 -0
  703. package/src/scripts/ai-video/lib/adapter-common.sh +231 -0
  704. package/src/scripts/ai-video/lib/adapter-contract.md +329 -0
  705. package/src/scripts/ai-video/lib/audio-adapter-contract.md +210 -0
  706. package/src/scripts/ai-video/lib/comfyui-nodes.allowlist.json +21 -0
  707. package/src/scripts/ai-video/lib/comfyui-templates/ltx-2.json +79 -0
  708. package/src/scripts/ai-video/lib/comfyui-templates/wan22-ti2v-5b.json +78 -0
  709. package/src/scripts/ai-video/lib/embed-provenance.sh +194 -0
  710. package/src/scripts/ai-video/lib/fixtures/allin1/analysis.json +13 -0
  711. package/src/scripts/ai-video/lib/fixtures/comfyui/result.json +1 -0
  712. package/src/scripts/ai-video/lib/fixtures/fal/result.json +1 -0
  713. package/src/scripts/ai-video/lib/fixtures/fal/scene-0001.mp4 +1 -0
  714. package/src/scripts/ai-video/lib/fixtures/gemini-veo/result.json +1 -0
  715. package/src/scripts/ai-video/lib/fixtures/higgsfield/result.json +1 -0
  716. package/src/scripts/ai-video/lib/fixtures/kling/result.json +1 -0
  717. package/src/scripts/ai-video/lib/fixtures/kling/scene-0001.mp4 +1 -0
  718. package/src/scripts/ai-video/lib/fixtures/musetalk/lipsync-0001.mp4 +1 -0
  719. package/src/scripts/ai-video/lib/fixtures/musetalk/result.json +1 -0
  720. package/src/scripts/ai-video/lib/fixtures/openai-images/result.json +1 -0
  721. package/src/scripts/ai-video/lib/fixtures/replicate/result.json +1 -0
  722. package/src/scripts/ai-video/lib/fixtures/replicate/scene-0001.mp4 +1 -0
  723. package/src/scripts/ai-video/lib/fixtures/sora/result.json +1 -0
  724. package/src/scripts/ai-video/lib/fixtures/syncso/lipsync-0001.mp4 +1 -0
  725. package/src/scripts/ai-video/lib/fixtures/syncso/result.json +1 -0
  726. package/src/scripts/ai-video/lib/fixtures/whisperx/transcript.json +26 -0
  727. package/src/scripts/ai-video/lib/ingest-song.sh +89 -0
  728. package/src/scripts/ai-video/lib/load-config.sh +180 -0
  729. package/src/scripts/ai-video/lib/model-capabilities/README.md +82 -0
  730. package/src/scripts/ai-video/lib/model-capabilities/comfyui.json +31 -0
  731. package/src/scripts/ai-video/lib/model-capabilities/fal.json +77 -0
  732. package/src/scripts/ai-video/lib/model-capabilities/musetalk.json +24 -0
  733. package/src/scripts/ai-video/lib/model-capabilities/replicate.json +82 -0
  734. package/src/scripts/ai-video/lib/model-capabilities/syncso.json +23 -0
  735. package/src/scripts/ai-video/lib/resume-scan.sh +212 -0
  736. package/src/scripts/ai-video/lib/telemetry.sh +115 -0
  737. package/src/scripts/ai-video/lib/validate-deps.sh +132 -0
  738. package/src/scripts/ai-video/lib/validate-vocal-map.sh +121 -0
  739. package/src/scripts/ai-video/smoke-trace.sh +179 -0
  740. package/src/scripts/ai-video/stitch.sh +161 -0
  741. package/src/scripts/ai-video/test-pipeline.sh +169 -0
  742. package/src/scripts/ai_council/advisors.py +148 -0
  743. package/src/scripts/ai_council/clients.py +1385 -0
  744. package/src/scripts/ai_council/compile_corpus.py +179 -0
  745. package/src/scripts/ai_council/events_log.py +141 -0
  746. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_2a4_acceptance.py +208 -0
  747. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_budget_v2_audit.py +206 -0
  748. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_context_layer_v1_estimate.py +67 -0
  749. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_context_layer_v1_review.py +292 -0
  750. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_followups_review.py +259 -0
  751. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_nondestructive_inline_audit.py +209 -0
  752. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_phase4_dispatch_latency.py +108 -0
  753. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_phase6_trigger_jaccard.py +92 -0
  754. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_phase_2a_budget_rebalance.py +257 -0
  755. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_phase_2a_post_revert.py +197 -0
  756. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_rebalancing_audit.py +149 -0
  757. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_roundtrip.py +111 -0
  758. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_rule_hardening_v1.py +251 -0
  759. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_silent_taskfiles.py +98 -0
  760. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_open_questions.py +232 -0
  761. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_optimization.py +144 -0
  762. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_v3_gaps.py +252 -0
  763. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_v3_review.py +240 -0
  764. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_tier_retrofit.py +180 -0
  765. package/src/scripts/ai_council/pricing.py +215 -0
  766. package/src/scripts/ai_council/session.py +366 -0
  767. package/src/scripts/annotate_discovery.py +149 -0
  768. package/src/scripts/apply_modules_config.py +290 -0
  769. package/src/scripts/audit_adr_coverage.py +175 -0
  770. package/src/scripts/audit_auto_rules.py +175 -0
  771. package/src/scripts/audit_cloud_compatibility.py +362 -0
  772. package/src/scripts/audit_command_surface.py +669 -0
  773. package/src/scripts/audit_initial_context.py +237 -0
  774. package/src/scripts/audit_likelihood.py +148 -0
  775. package/src/scripts/audit_mcp_tools.py +146 -0
  776. package/src/scripts/audit_overlap.py +145 -0
  777. package/src/scripts/audit_skill_overlap.py +207 -0
  778. package/src/scripts/audit_user_type_axis.py +140 -0
  779. package/src/scripts/backfill_model_tier.py +184 -0
  780. package/src/scripts/bench_ab_cache_dispatch.py +68 -0
  781. package/src/scripts/bench_ab_clone.py +170 -0
  782. package/src/scripts/bench_ab_diff.py +220 -0
  783. package/src/scripts/bench_ab_integrity.py +143 -0
  784. package/src/scripts/bench_ab_run.py +235 -0
  785. package/src/scripts/bench_ab_task_runner.py +369 -0
  786. package/src/scripts/bench_ab_tracka_run.py +202 -0
  787. package/src/scripts/bench_baseline_ready.py +108 -0
  788. package/src/scripts/bench_condense_memory.py +168 -0
  789. package/src/scripts/bench_drift_check.py +151 -0
  790. package/src/scripts/bench_per_tool.py +216 -0
  791. package/src/scripts/bench_rtk_savings.py +320 -0
  792. package/src/scripts/bench_run.py +272 -0
  793. package/src/scripts/bench_runner.py +158 -0
  794. package/src/scripts/build_cloud_bundle.py +458 -0
  795. package/src/scripts/build_discovery_manifest.py +747 -0
  796. package/src/scripts/build_linear_digest.py +260 -0
  797. package/src/scripts/build_mcp_registry_manifest.py +181 -0
  798. package/src/scripts/build_rule_trigger_matrix.py +350 -0
  799. package/src/scripts/capture_showcase_session.py +361 -0
  800. package/src/scripts/check_always_budget.py +532 -0
  801. package/src/scripts/check_artefact_checksums.py +111 -0
  802. package/src/scripts/check_augment_description_cap.py +79 -0
  803. package/src/scripts/check_augmentignore.py +72 -0
  804. package/src/scripts/check_beta_review_markers.py +127 -0
  805. package/src/scripts/check_cluster_patterns.py +206 -0
  806. package/src/scripts/check_command_count_messaging.py +152 -0
  807. package/src/scripts/check_condensation.py +375 -0
  808. package/src/scripts/check_condensed_paths.py +231 -0
  809. package/src/scripts/check_context_paths.py +202 -0
  810. package/src/scripts/check_council_references.py +228 -0
  811. package/src/scripts/check_discovery_determinism.py +70 -0
  812. package/src/scripts/check_gate_paths.py +128 -0
  813. package/src/scripts/check_module_management_neutral.py +147 -0
  814. package/src/scripts/check_no_new_legacy_path.py +100 -0
  815. package/src/scripts/check_no_roadmap_refs.py +155 -0
  816. package/src/scripts/check_one_off_location.py +81 -0
  817. package/src/scripts/check_overlay_cascade_subdirs.py +129 -0
  818. package/src/scripts/check_portability.py +574 -0
  819. package/src/scripts/check_public_catalog_links.py +125 -0
  820. package/src/scripts/check_public_links.py +185 -0
  821. package/src/scripts/check_references.py +557 -0
  822. package/src/scripts/check_release_includes_discovery.py +61 -0
  823. package/src/scripts/check_release_pr_shape.py +123 -0
  824. package/src/scripts/check_release_published.py +145 -0
  825. package/src/scripts/check_reply_consistency.py +169 -0
  826. package/src/scripts/check_roadmap_trackable.py +114 -0
  827. package/src/scripts/check_role_doc_links.py +110 -0
  828. package/src/scripts/check_safety_floor_untouched.py +125 -0
  829. package/src/scripts/check_skill_requires.py +147 -0
  830. package/src/scripts/check_template_pin_drift.py +129 -0
  831. package/src/scripts/check_test_coverage_diff.py +180 -0
  832. package/src/scripts/check_token_optimizer_freshness.py +146 -0
  833. package/src/scripts/check_update_banner.py +86 -0
  834. package/src/scripts/ci_time_ratio.py +168 -0
  835. package/src/scripts/compile_router.py +232 -0
  836. package/src/scripts/condense.py +1919 -0
  837. package/src/scripts/condense_memory.py +178 -0
  838. package/src/scripts/config/packs.py +157 -0
  839. package/src/scripts/config/profile_explain.py +89 -0
  840. package/src/scripts/config/profiles.py +191 -0
  841. package/src/scripts/config/session_profiles.py +542 -0
  842. package/src/scripts/cost_by_conversation.py +78 -0
  843. package/src/scripts/cost_summary.py +97 -0
  844. package/src/scripts/council_cli.py +2557 -0
  845. package/src/scripts/cross_repo_retrieve.py +172 -0
  846. package/src/scripts/discovery_stats.py +70 -0
  847. package/src/scripts/extract_audit_patterns.py +202 -0
  848. package/src/scripts/first_run_gate_hook.py +179 -0
  849. package/src/scripts/gen_discovery_baseline.py +127 -0
  850. package/src/scripts/generate_catalog.py +116 -0
  851. package/src/scripts/generate_command_flows.py +191 -0
  852. package/src/scripts/generate_index.py +303 -0
  853. package/src/scripts/generate_ownership_matrix.py +378 -0
  854. package/src/scripts/generate_pack_manifests.py +340 -0
  855. package/src/scripts/hook_manifest.yaml +243 -0
  856. package/src/scripts/hooks/dispatch_hook.py +461 -0
  857. package/src/scripts/hooks/replay_hook.py +144 -0
  858. package/src/scripts/hooks_doctor.py +223 -0
  859. package/src/scripts/hooks_status.py +157 -0
  860. package/src/scripts/install +425 -0
  861. package/src/scripts/install-hooks.sh +204 -0
  862. package/src/scripts/install.py +5183 -0
  863. package/src/scripts/install.sh +1156 -0
  864. package/src/scripts/inventory_abstraction_budget.py +622 -0
  865. package/src/scripts/inventory_frontmatter.py +164 -0
  866. package/src/scripts/inventory_meta_layers.py +288 -0
  867. package/src/scripts/iron_law_sha.py +107 -0
  868. package/src/scripts/linked_projects_list.py +91 -0
  869. package/src/scripts/lint_agent_skill_names.py +150 -0
  870. package/src/scripts/lint_agents_layout.py +197 -0
  871. package/src/scripts/lint_agents_md.py +210 -0
  872. package/src/scripts/lint_archived_skills.py +159 -0
  873. package/src/scripts/lint_artefact_frontmatter.py +188 -0
  874. package/src/scripts/lint_bench_ab.py +172 -0
  875. package/src/scripts/lint_bench_corpus.py +255 -0
  876. package/src/scripts/lint_command_flow_coverage.py +132 -0
  877. package/src/scripts/lint_command_routing.py +160 -0
  878. package/src/scripts/lint_command_tiers.py +175 -0
  879. package/src/scripts/lint_command_verbs.py +206 -0
  880. package/src/scripts/lint_commit_subjects.py +139 -0
  881. package/src/scripts/lint_context_spine_usage.py +137 -0
  882. package/src/scripts/lint_discovery_manifest.py +176 -0
  883. package/src/scripts/lint_discovery_vocabulary.py +220 -0
  884. package/src/scripts/lint_examples.py +102 -0
  885. package/src/scripts/lint_explain_trace.py +80 -0
  886. package/src/scripts/lint_featured_skills.py +144 -0
  887. package/src/scripts/lint_flows.py +215 -0
  888. package/src/scripts/lint_framework_leakage.py +375 -0
  889. package/src/scripts/lint_framework_leakage_allowlist.json +575 -0
  890. package/src/scripts/lint_frontmatter_boilerplate.py +77 -0
  891. package/src/scripts/lint_ghostwriter_source.py +242 -0
  892. package/src/scripts/lint_handoffs.py +217 -0
  893. package/src/scripts/lint_hook_concern_budget.py +207 -0
  894. package/src/scripts/lint_hook_manifest.py +217 -0
  895. package/src/scripts/lint_load_context.py +196 -0
  896. package/src/scripts/lint_marketplace.py +180 -0
  897. package/src/scripts/lint_marketplace_install_completeness.py +198 -0
  898. package/src/scripts/lint_mcp_registry_manifest.py +69 -0
  899. package/src/scripts/lint_media_policy_linkage.py +140 -0
  900. package/src/scripts/lint_model_tier_coverage.py +73 -0
  901. package/src/scripts/lint_namespace.py +135 -0
  902. package/src/scripts/lint_namespace_collisions.py +103 -0
  903. package/src/scripts/lint_new_skill_gate.py +144 -0
  904. package/src/scripts/lint_no_new_atomic_commands.py +180 -0
  905. package/src/scripts/lint_one_off_age.py +184 -0
  906. package/src/scripts/lint_orchestration_dsl.py +217 -0
  907. package/src/scripts/lint_orchestrator_auto_detect.py +111 -0
  908. package/src/scripts/lint_pack_boundaries.py +147 -0
  909. package/src/scripts/lint_pack_dependencies.py +137 -0
  910. package/src/scripts/lint_pack_first_win.py +121 -0
  911. package/src/scripts/lint_persona_governance.py +164 -0
  912. package/src/scripts/lint_positioning.py +143 -0
  913. package/src/scripts/lint_profile_overlay_set_only.py +179 -0
  914. package/src/scripts/lint_regression.py +251 -0
  915. package/src/scripts/lint_roadmap_ci_steps.py +186 -0
  916. package/src/scripts/lint_roadmap_complexity.py +220 -0
  917. package/src/scripts/lint_role_experiences.py +255 -0
  918. package/src/scripts/lint_rule_interactions.py +170 -0
  919. package/src/scripts/lint_rule_tiers.py +90 -0
  920. package/src/scripts/lint_showcase_sessions.py +148 -0
  921. package/src/scripts/lint_skill_tools.py +168 -0
  922. package/src/scripts/lint_topics_yaml.py +89 -0
  923. package/src/scripts/lint_trust_coherence.py +212 -0
  924. package/src/scripts/lint_value_dashboard.py +218 -0
  925. package/src/scripts/mcp_parity_smoke.py +316 -0
  926. package/src/scripts/mcp_registry_submit.sh +187 -0
  927. package/src/scripts/mcp_server/__init__.py +19 -0
  928. package/src/scripts/mcp_server/consumer_tool_catalog.json +276 -0
  929. package/src/scripts/mcp_server/prompts.py +442 -0
  930. package/src/scripts/mcp_server/resources.py +201 -0
  931. package/src/scripts/mcp_server/tools.py +950 -0
  932. package/src/scripts/measure_augment_budget.py +214 -0
  933. package/src/scripts/measure_density.py +232 -0
  934. package/src/scripts/measure_frugality_savings.py +164 -0
  935. package/src/scripts/measure_markitdown_lift.py +127 -0
  936. package/src/scripts/measure_patterns.py +376 -0
  937. package/src/scripts/measure_projection_bytes.py +159 -0
  938. package/src/scripts/measure_rule_budget.py +347 -0
  939. package/src/scripts/measure_skill_reduction.py +102 -0
  940. package/src/scripts/migrate_command_suggestions.py +151 -0
  941. package/src/scripts/migrate_frontmatter_defaults.py +245 -0
  942. package/src/scripts/mine_session.py +279 -0
  943. package/src/scripts/move_artefact.py +143 -0
  944. package/src/scripts/new_skill.py +148 -0
  945. package/src/scripts/pack_dependency_allowlist.json +70 -0
  946. package/src/scripts/pack_mcp_content.py +293 -0
  947. package/src/scripts/plan_physical_move.py +353 -0
  948. package/src/scripts/print_required_checks.py +196 -0
  949. package/src/scripts/probe_projection_fidelity.py +202 -0
  950. package/src/scripts/profile_staleness_hook.py +69 -0
  951. package/src/scripts/profile_use.py +164 -0
  952. package/src/scripts/project_thin_rules.py +168 -0
  953. package/src/scripts/prototype_lint_contradictions.py +150 -0
  954. package/src/scripts/prove_pack_extractable.py +187 -0
  955. package/src/scripts/recruit_preflight.sh +152 -0
  956. package/src/scripts/refine_ticket_detect.py +646 -0
  957. package/src/scripts/release.py +1091 -0
  958. package/src/scripts/render_benchmark_md.py +312 -0
  959. package/src/scripts/render_value_md.py +347 -0
  960. package/src/scripts/repro/repro_marketplace_install_gap.sh +161 -0
  961. package/src/scripts/roadmap_progress_hook.py +274 -0
  962. package/src/scripts/router_telemetry.py +470 -0
  963. package/src/scripts/run_skill_evals.py +185 -0
  964. package/src/scripts/runtime_registry.py +166 -0
  965. package/src/scripts/schemas/command.schema.json +219 -0
  966. package/src/scripts/schemas/flow.schema.json +59 -0
  967. package/src/scripts/schemas/pack.schema.json +95 -0
  968. package/src/scripts/schemas/rule.schema.json +145 -0
  969. package/src/scripts/score_skill_selection.py +198 -0
  970. package/src/scripts/skill_collision_clusters.py +162 -0
  971. package/src/scripts/skill_discovery.py +254 -0
  972. package/src/scripts/skill_linter.py +3694 -0
  973. package/src/scripts/skill_overlap.py +204 -0
  974. package/src/scripts/skill_preview.py +179 -0
  975. package/src/scripts/skill_tools/audit_persona_coverage.py +147 -0
  976. package/src/scripts/skill_tools/audit_user_type_coverage.py +148 -0
  977. package/src/scripts/skill_tools/run_block_d_eval.py +129 -0
  978. package/src/scripts/skill_tools/score_skill_relevance.py +169 -0
  979. package/src/scripts/skill_tools/suggest_skill_for_task.py +113 -0
  980. package/src/scripts/skill_trigger_eval.py +682 -0
  981. package/src/scripts/skill_usage_collect.py +191 -0
  982. package/src/scripts/skill_usage_report.py +162 -0
  983. package/src/scripts/smoke/kernel.sh +107 -0
  984. package/src/scripts/smoke/router.sh +148 -0
  985. package/src/scripts/smoke/schema.sh +78 -0
  986. package/src/scripts/smoke/skills.sh +112 -0
  987. package/src/scripts/smoke_path_resolution.py +93 -0
  988. package/src/scripts/smoke_quickstart.py +144 -0
  989. package/src/scripts/snapshot_agent_outputs.py +144 -0
  990. package/src/scripts/spotcheck_thin_root.py +134 -0
  991. package/src/scripts/sync_agent_settings.py +180 -0
  992. package/src/scripts/sync_github_metadata.py +147 -0
  993. package/src/scripts/sync_gitignore.py +291 -0
  994. package/src/scripts/telegraph_stats.py +119 -0
  995. package/src/scripts/trigger_coverage.py +129 -0
  996. package/src/scripts/update_counts.py +199 -0
  997. package/src/scripts/update_prices.py +125 -0
  998. package/src/scripts/validate_agent_settings.py +124 -0
  999. package/src/scripts/validate_decision_engine.py +136 -0
  1000. package/src/scripts/validate_discovery_manifest.py +94 -0
  1001. package/src/scripts/validate_frontmatter.py +647 -0
  1002. package/src/scripts/validate_pack_yaml.py +179 -0
  1003. package/src/scripts/verify_physical_move.py +185 -0
  1004. package/src/scripts/wrapper_freshness_hook.py +86 -0
  1005. package/.agent-src/README.md +0 -64
  1006. package/.agent-src/commands/agent-handoff.md +0 -120
  1007. package/.agent-src/commands/agent-status.md +0 -136
  1008. package/.agent-src/commands/agents/audit.md +0 -157
  1009. package/.agent-src/commands/agents/init.md +0 -191
  1010. package/.agent-src/commands/agents/optimize.md +0 -186
  1011. package/.agent-src/commands/agents/user/accept.md +0 -121
  1012. package/.agent-src/commands/agents/user/init.md +0 -161
  1013. package/.agent-src/commands/agents/user/review.md +0 -111
  1014. package/.agent-src/commands/agents/user/show.md +0 -113
  1015. package/.agent-src/commands/agents/user/update.md +0 -102
  1016. package/.agent-src/commands/agents/user.md +0 -70
  1017. package/.agent-src/commands/agents.md +0 -61
  1018. package/.agent-src/commands/analytics/prune.md +0 -70
  1019. package/.agent-src/commands/analytics/show.md +0 -99
  1020. package/.agent-src/commands/analytics.md +0 -56
  1021. package/.agent-src/commands/analyze-reference-repo.md +0 -203
  1022. package/.agent-src/commands/bug-fix.md +0 -192
  1023. package/.agent-src/commands/bug-investigate.md +0 -185
  1024. package/.agent-src/commands/challenge-me/vision.md +0 -353
  1025. package/.agent-src/commands/challenge-me/with-docs.md +0 -338
  1026. package/.agent-src/commands/challenge-me.md +0 -67
  1027. package/.agent-src/commands/chat-history/import.md +0 -171
  1028. package/.agent-src/commands/chat-history/learn.md +0 -183
  1029. package/.agent-src/commands/chat-history/show.md +0 -111
  1030. package/.agent-src/commands/chat-history.md +0 -58
  1031. package/.agent-src/commands/check-current-md.md +0 -142
  1032. package/.agent-src/commands/commit/in-chunks.md +0 -145
  1033. package/.agent-src/commands/commit.md +0 -190
  1034. package/.agent-src/commands/condense.md +0 -235
  1035. package/.agent-src/commands/context/create.md +0 -180
  1036. package/.agent-src/commands/context/refactor.md +0 -182
  1037. package/.agent-src/commands/context.md +0 -50
  1038. package/.agent-src/commands/cost-report.md +0 -130
  1039. package/.agent-src/commands/council/analysis.md +0 -146
  1040. package/.agent-src/commands/council/debate.md +0 -133
  1041. package/.agent-src/commands/council/default.md +0 -288
  1042. package/.agent-src/commands/council/design.md +0 -106
  1043. package/.agent-src/commands/council/optimize.md +0 -122
  1044. package/.agent-src/commands/council/pr.md +0 -129
  1045. package/.agent-src/commands/council.md +0 -106
  1046. package/.agent-src/commands/create-pr/description-only.md +0 -159
  1047. package/.agent-src/commands/create-pr.md +0 -249
  1048. package/.agent-src/commands/e2e-heal.md +0 -109
  1049. package/.agent-src/commands/e2e-plan.md +0 -96
  1050. package/.agent-src/commands/estimate-ticket.md +0 -88
  1051. package/.agent-src/commands/feature/dev.md +0 -123
  1052. package/.agent-src/commands/feature/explore.md +0 -190
  1053. package/.agent-src/commands/feature/plan.md +0 -332
  1054. package/.agent-src/commands/feature/refactor.md +0 -193
  1055. package/.agent-src/commands/feature/roadmap.md +0 -221
  1056. package/.agent-src/commands/feature.md +0 -58
  1057. package/.agent-src/commands/fix/ci.md +0 -58
  1058. package/.agent-src/commands/fix/portability.md +0 -106
  1059. package/.agent-src/commands/fix/pr-bot-comments.md +0 -156
  1060. package/.agent-src/commands/fix/pr-comments.md +0 -68
  1061. package/.agent-src/commands/fix/pr-developer-comments.md +0 -162
  1062. package/.agent-src/commands/fix/refs.md +0 -103
  1063. package/.agent-src/commands/fix/seeder.md +0 -157
  1064. package/.agent-src/commands/fix.md +0 -60
  1065. package/.agent-src/commands/ghostwriter/delete.md +0 -122
  1066. package/.agent-src/commands/ghostwriter/fetch.md +0 -189
  1067. package/.agent-src/commands/ghostwriter/list.md +0 -106
  1068. package/.agent-src/commands/ghostwriter/show.md +0 -117
  1069. package/.agent-src/commands/ghostwriter/write.md +0 -164
  1070. package/.agent-src/commands/ghostwriter.md +0 -100
  1071. package/.agent-src/commands/grill-me.md +0 -44
  1072. package/.agent-src/commands/image/analyse.md +0 -51
  1073. package/.agent-src/commands/image/create.md +0 -53
  1074. package/.agent-src/commands/image/verify.md +0 -48
  1075. package/.agent-src/commands/image.md +0 -69
  1076. package/.agent-src/commands/implement-ticket.md +0 -165
  1077. package/.agent-src/commands/jira-ticket.md +0 -80
  1078. package/.agent-src/commands/judge/on-diff.md +0 -123
  1079. package/.agent-src/commands/judge/solo.md +0 -95
  1080. package/.agent-src/commands/judge/steps.md +0 -93
  1081. package/.agent-src/commands/judge.md +0 -60
  1082. package/.agent-src/commands/knowledge/cross-repo.md +0 -71
  1083. package/.agent-src/commands/knowledge/forget.md +0 -96
  1084. package/.agent-src/commands/knowledge/ingest.md +0 -114
  1085. package/.agent-src/commands/knowledge/list.md +0 -94
  1086. package/.agent-src/commands/knowledge.md +0 -69
  1087. package/.agent-src/commands/memory/add.md +0 -146
  1088. package/.agent-src/commands/memory/learn-low-impact.md +0 -147
  1089. package/.agent-src/commands/memory/load.md +0 -175
  1090. package/.agent-src/commands/memory/mine-session.md +0 -156
  1091. package/.agent-src/commands/memory/promote.md +0 -194
  1092. package/.agent-src/commands/memory/propose.md +0 -121
  1093. package/.agent-src/commands/memory.md +0 -56
  1094. package/.agent-src/commands/mode.md +0 -129
  1095. package/.agent-src/commands/module/create.md +0 -143
  1096. package/.agent-src/commands/module/explore.md +0 -197
  1097. package/.agent-src/commands/module.md +0 -50
  1098. package/.agent-src/commands/optimize/agents-dir.md +0 -118
  1099. package/.agent-src/commands/optimize/augmentignore.md +0 -311
  1100. package/.agent-src/commands/optimize/rtk.md +0 -160
  1101. package/.agent-src/commands/optimize/skills.md +0 -131
  1102. package/.agent-src/commands/optimize-prompt.md +0 -66
  1103. package/.agent-src/commands/optimize.md +0 -56
  1104. package/.agent-src/commands/orchestrate.md +0 -128
  1105. package/.agent-src/commands/override/create.md +0 -107
  1106. package/.agent-src/commands/override/manage.md +0 -106
  1107. package/.agent-src/commands/override.md +0 -50
  1108. package/.agent-src/commands/package-reset.md +0 -162
  1109. package/.agent-src/commands/package-test.md +0 -238
  1110. package/.agent-src/commands/post-as/ghostwriter.md +0 -70
  1111. package/.agent-src/commands/post-as/me.md +0 -128
  1112. package/.agent-src/commands/post-as.md +0 -62
  1113. package/.agent-src/commands/prediction-pool.md +0 -234
  1114. package/.agent-src/commands/prepare-for-review.md +0 -106
  1115. package/.agent-src/commands/profile/activate.md +0 -81
  1116. package/.agent-src/commands/profile/deactivate.md +0 -68
  1117. package/.agent-src/commands/profile/show.md +0 -70
  1118. package/.agent-src/commands/profile.md +0 -68
  1119. package/.agent-src/commands/project-analyze.md +0 -320
  1120. package/.agent-src/commands/project-health.md +0 -105
  1121. package/.agent-src/commands/quality-fix.md +0 -137
  1122. package/.agent-src/commands/refine-ticket.md +0 -94
  1123. package/.agent-src/commands/research/deep.md +0 -154
  1124. package/.agent-src/commands/research/report.md +0 -139
  1125. package/.agent-src/commands/research.md +0 -177
  1126. package/.agent-src/commands/review-changes.md +0 -205
  1127. package/.agent-src/commands/review-routing.md +0 -117
  1128. package/.agent-src/commands/roadmap/ai-council.md +0 -188
  1129. package/.agent-src/commands/roadmap/create.md +0 -213
  1130. package/.agent-src/commands/roadmap/process-full.md +0 -108
  1131. package/.agent-src/commands/roadmap/process-phase.md +0 -74
  1132. package/.agent-src/commands/roadmap/process-step.md +0 -62
  1133. package/.agent-src/commands/roadmap.md +0 -78
  1134. package/.agent-src/commands/rule-compliance-audit.md +0 -148
  1135. package/.agent-src/commands/set-cost-profile.md +0 -117
  1136. package/.agent-src/commands/skill/preview.md +0 -67
  1137. package/.agent-src/commands/skill.md +0 -48
  1138. package/.agent-src/commands/skills/discover.md +0 -76
  1139. package/.agent-src/commands/skills.md +0 -56
  1140. package/.agent-src/commands/sync-agent-settings.md +0 -139
  1141. package/.agent-src/commands/sync-gitignore/fix.md +0 -147
  1142. package/.agent-src/commands/sync-gitignore.md +0 -138
  1143. package/.agent-src/commands/tests/create.md +0 -83
  1144. package/.agent-src/commands/tests/execute.md +0 -67
  1145. package/.agent-src/commands/tests.md +0 -50
  1146. package/.agent-src/commands/threat-model.md +0 -125
  1147. package/.agent-src/commands/update-form-request-messages.md +0 -199
  1148. package/.agent-src/commands/upstream-contribute.md +0 -181
  1149. package/.agent-src/commands/video/from-script.md +0 -127
  1150. package/.agent-src/commands/video/from-song.md +0 -351
  1151. package/.agent-src/commands/video/scene.md +0 -96
  1152. package/.agent-src/commands/video/stitch.md +0 -87
  1153. package/.agent-src/commands/video/storyboard.md +0 -99
  1154. package/.agent-src/commands/video.md +0 -73
  1155. package/.agent-src/commands/work.md +0 -166
  1156. package/.agent-src/contexts/authority/commit-mechanics.md +0 -93
  1157. package/.agent-src/contexts/communication/rules-auto/augment-source-of-truth-mechanics.md +0 -98
  1158. package/.agent-src/contexts/contracts/artifact-engagement-flow.md +0 -259
  1159. package/.agent-src/contexts/contracts/consumer-agents-md-guide.md +0 -127
  1160. package/.agent-src/contexts/contracts/emergency-triage-block.md +0 -53
  1161. package/.agent-src/personas/README.md +0 -114
  1162. package/.agent-src/profiles/agency.yml +0 -27
  1163. package/.agent-src/profiles/content_creator.yml +0 -30
  1164. package/.agent-src/profiles/developer.yml +0 -26
  1165. package/.agent-src/profiles/finance.yml +0 -24
  1166. package/.agent-src/profiles/founder.yml +0 -25
  1167. package/.agent-src/profiles/ops.yml +0 -25
  1168. package/.agent-src/rules/ask-when-uncertain.md +0 -70
  1169. package/.agent-src/rules/augment-edit-discipline.md +0 -31
  1170. package/.agent-src/rules/augment-source-of-truth.md +0 -75
  1171. package/.agent-src/rules/commit-policy.md +0 -59
  1172. package/.agent-src/rules/direct-answers.md +0 -64
  1173. package/.agent-src/rules/domain-adoption-policy.md +0 -160
  1174. package/.agent-src/rules/language-and-tone.md +0 -64
  1175. package/.agent-src/rules/linked-projects-onboarding-gate.md +0 -79
  1176. package/.agent-src/rules/media-governance-routing.md +0 -85
  1177. package/.agent-src/rules/missing-tool-handling.md +0 -76
  1178. package/.agent-src/rules/model-recommendation.md +0 -85
  1179. package/.agent-src/rules/no-attribution-footers.md +0 -57
  1180. package/.agent-src/rules/no-cheap-questions.md +0 -75
  1181. package/.agent-src/rules/no-pr-progress-comments.md +0 -109
  1182. package/.agent-src/rules/no-roadmap-references.md +0 -141
  1183. package/.agent-src/rules/non-destructive-by-default.md +0 -58
  1184. package/.agent-src/rules/persona-governance.md +0 -93
  1185. package/.agent-src/rules/preservation-guard.md +0 -97
  1186. package/.agent-src/rules/provider-lifecycle-discipline.md +0 -78
  1187. package/.agent-src/rules/roadmap-progress-sync.md +0 -99
  1188. package/.agent-src/rules/scope-control.md +0 -68
  1189. package/.agent-src/rules/user-interrupt-priority.md +0 -49
  1190. package/.agent-src/rules/verify-before-complete.md +0 -78
  1191. package/.agent-src/scripts/update_roadmap_progress.py +0 -416
  1192. package/.agent-src/skills/accessibility-auditor/SKILL.md +0 -136
  1193. package/.agent-src/skills/agents-md-thin-root/SKILL.md +0 -143
  1194. package/.agent-src/skills/api-design/SKILL.md +0 -112
  1195. package/.agent-src/skills/api-endpoint/SKILL.md +0 -94
  1196. package/.agent-src/skills/authz-review/SKILL.md +0 -180
  1197. package/.agent-src/skills/blade-ui/SKILL.md +0 -129
  1198. package/.agent-src/skills/character-consistency/SKILL.md +0 -141
  1199. package/.agent-src/skills/check-refs/SKILL.md +0 -96
  1200. package/.agent-src/skills/code-review/SKILL.md +0 -224
  1201. package/.agent-src/skills/command-writing/SKILL.md +0 -282
  1202. package/.agent-src/skills/condense-memory/SKILL.md +0 -123
  1203. package/.agent-src/skills/context-document/SKILL.md +0 -160
  1204. package/.agent-src/skills/dashboard-design/SKILL.md +0 -123
  1205. package/.agent-src/skills/database/SKILL.md +0 -103
  1206. package/.agent-src/skills/deep-reading-analyst/SKILL.md +0 -198
  1207. package/.agent-src/skills/design-review/SKILL.md +0 -233
  1208. package/.agent-src/skills/existing-ui-audit/SKILL.md +0 -209
  1209. package/.agent-src/skills/fe-design/SKILL.md +0 -255
  1210. package/.agent-src/skills/feature-planning/SKILL.md +0 -271
  1211. package/.agent-src/skills/flux/SKILL.md +0 -121
  1212. package/.agent-src/skills/jira-integration/SKILL.md +0 -187
  1213. package/.agent-src/skills/lint-skills/SKILL.md +0 -95
  1214. package/.agent-src/skills/livewire/SKILL.md +0 -134
  1215. package/.agent-src/skills/md-language-check/SKILL.md +0 -130
  1216. package/.agent-src/skills/merge-conflicts/SKILL.md +0 -195
  1217. package/.agent-src/skills/motion-choreographer/SKILL.md +0 -171
  1218. package/.agent-src/skills/persona-writing/SKILL.md +0 -158
  1219. package/.agent-src/skills/react-shadcn-ui/SKILL.md +0 -213
  1220. package/.agent-src/skills/readme-reviewer/SKILL.md +0 -242
  1221. package/.agent-src/skills/readme-writing/SKILL.md +0 -240
  1222. package/.agent-src/skills/readme-writing-package/SKILL.md +0 -350
  1223. package/.agent-src/skills/roadmap-management/SKILL.md +0 -461
  1224. package/.agent-src/skills/rule-refactor/SKILL.md +0 -149
  1225. package/.agent-src/skills/rule-writing/SKILL.md +0 -277
  1226. package/.agent-src/skills/scene-expander/SKILL.md +0 -147
  1227. package/.agent-src/skills/scene-expander/scene-blueprint.schema.yaml +0 -108
  1228. package/.agent-src/skills/script-writing/SKILL.md +0 -231
  1229. package/.agent-src/skills/sentry-integration/SKILL.md +0 -175
  1230. package/.agent-src/skills/song-to-script/SKILL.md +0 -216
  1231. package/.agent-src/skills/sql-writing/SKILL.md +0 -79
  1232. package/.agent-src/skills/tailwind-engineer/SKILL.md +0 -148
  1233. package/.agent-src/skills/technical-specification/SKILL.md +0 -251
  1234. package/.agent-src/skills/threat-modeling/SKILL.md +0 -197
  1235. package/.agent-src/skills/upstream-contribute/SKILL.md +0 -261
  1236. package/.agent-src/templates/AGENTS.md +0 -34
  1237. package/.agent-src/templates/agents/agent-project-settings.example.yml +0 -286
  1238. package/.agent-src/templates/agents/proposal.example.md +0 -155
  1239. package/.agent-src/templates/command.md +0 -105
  1240. package/.agent-src/templates/copilot-instructions.md +0 -167
  1241. package/.agent-src/templates/github-workflows/proposal-drift.yml +0 -118
  1242. package/.agent-src/templates/hooks/pre-commit-frontmatter +0 -66
  1243. package/.agent-src/templates/hooks/pre-commit-roadmap-progress +0 -99
  1244. package/.agent-src/templates/persona.md +0 -99
  1245. package/.agent-src/templates/rule.md +0 -135
  1246. package/.agent-src/templates/scripts/work_engine/directives/ui/polish.py +0 -510
  1247. package/.agent-src/templates/scripts/work_engine/directives/ui/review.py +0 -468
  1248. package/.agent-src/templates/scripts/work_engine/orchestration.py +0 -182
  1249. package/.agent-src/user-types/README.md +0 -124
  1250. package/config/agent-settings.template.yml +0 -578
  1251. package/config/discovery/packs.yml +0 -181
  1252. package/config/discovery/workspaces.yml +0 -72
  1253. package/dist/ui/assets/index-DcAWIwwY.js +0 -40
  1254. package/dist/ui/assets/index-DcAWIwwY.js.map +0 -1
  1255. package/scripts/__pycache__/validate_frontmatter.cpython-312.pyc +0 -0
  1256. package/scripts/_archive/README.md +0 -59
  1257. package/scripts/_archive/_bootstrap_tier_frontmatter.py +0 -151
  1258. package/scripts/_archive/_p43_bodies.py +0 -235
  1259. package/scripts/_archive/_p43_condense.py +0 -118
  1260. package/scripts/_archive/_p4_migrate.py +0 -199
  1261. package/scripts/_cli/cmd_doctor.py +0 -1583
  1262. package/scripts/_cli/cmd_export.py +0 -157
  1263. package/scripts/_cli/cmd_migrate.py +0 -437
  1264. package/scripts/_cli/cmd_refresh.py +0 -173
  1265. package/scripts/_cli/cmd_settings_migrate.py +0 -147
  1266. package/scripts/_cli/cmd_update.py +0 -279
  1267. package/scripts/_cli/cmd_upgrade.py +0 -142
  1268. package/scripts/_cli/cmd_versions.py +0 -160
  1269. package/scripts/_dispatch.bash +0 -1126
  1270. package/scripts/_lib/__pycache__/__init__.cpython-312.pyc +0 -0
  1271. package/scripts/_lib/__pycache__/agent_src.cpython-312.pyc +0 -0
  1272. package/scripts/_lib/agent_src.py +0 -187
  1273. package/scripts/_lib/bench_ab_cache.py +0 -162
  1274. package/scripts/_lib/changelog_eras.py +0 -330
  1275. package/scripts/_lib/claude_desktop_bundler.py +0 -238
  1276. package/scripts/_lib/install_regenerator.py +0 -129
  1277. package/scripts/_lib/installed_lock.py +0 -256
  1278. package/scripts/_lib/scope_guard.sh +0 -162
  1279. package/scripts/_lib/value_ladder.py +0 -696
  1280. package/scripts/_lib/value_report.py +0 -455
  1281. package/scripts/_phase4_bucket.py +0 -210
  1282. package/scripts/_pilot_measure.py +0 -53
  1283. package/scripts/adoption_report.py +0 -195
  1284. package/scripts/adoption_snapshot.py +0 -219
  1285. package/scripts/adoption_status.py +0 -166
  1286. package/scripts/agent-config +0 -57
  1287. package/scripts/ai-video/adapters/gemini-veo.sh +0 -62
  1288. package/scripts/ai-video/adapters/higgsfield.sh +0 -245
  1289. package/scripts/ai-video/adapters/kling.sh +0 -59
  1290. package/scripts/ai-video/adapters/openai-images.sh +0 -143
  1291. package/scripts/ai-video/adapters/sora.sh +0 -60
  1292. package/scripts/ai-video/lib/adapter-common.sh +0 -116
  1293. package/scripts/ai-video/lib/adapter-contract.md +0 -163
  1294. package/scripts/ai-video/lib/fixtures/gemini-veo/result.json +0 -1
  1295. package/scripts/ai-video/lib/fixtures/higgsfield/result.json +0 -1
  1296. package/scripts/ai-video/lib/fixtures/kling/result.json +0 -1
  1297. package/scripts/ai-video/lib/fixtures/openai-images/result.json +0 -1
  1298. package/scripts/ai-video/lib/fixtures/sora/result.json +0 -1
  1299. package/scripts/ai-video/lib/load-config.sh +0 -140
  1300. package/scripts/ai-video/lib/validate-deps.sh +0 -132
  1301. package/scripts/ai-video/stitch.sh +0 -154
  1302. package/scripts/ai-video/test-pipeline.sh +0 -169
  1303. package/scripts/ai_council/advisors.py +0 -148
  1304. package/scripts/ai_council/clients.py +0 -1385
  1305. package/scripts/ai_council/compile_corpus.py +0 -179
  1306. package/scripts/ai_council/events_log.py +0 -141
  1307. package/scripts/ai_council/one_off_archive/2026-05/_one_off_2a4_acceptance.py +0 -208
  1308. package/scripts/ai_council/one_off_archive/2026-05/_one_off_budget_v2_audit.py +0 -206
  1309. package/scripts/ai_council/one_off_archive/2026-05/_one_off_context_layer_v1_estimate.py +0 -67
  1310. package/scripts/ai_council/one_off_archive/2026-05/_one_off_context_layer_v1_review.py +0 -292
  1311. package/scripts/ai_council/one_off_archive/2026-05/_one_off_followups_review.py +0 -259
  1312. package/scripts/ai_council/one_off_archive/2026-05/_one_off_nondestructive_inline_audit.py +0 -209
  1313. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase4_dispatch_latency.py +0 -108
  1314. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase6_trigger_jaccard.py +0 -92
  1315. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase_2a_budget_rebalance.py +0 -257
  1316. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase_2a_post_revert.py +0 -197
  1317. package/scripts/ai_council/one_off_archive/2026-05/_one_off_rebalancing_audit.py +0 -149
  1318. package/scripts/ai_council/one_off_archive/2026-05/_one_off_roundtrip.py +0 -111
  1319. package/scripts/ai_council/one_off_archive/2026-05/_one_off_rule_hardening_v1.py +0 -251
  1320. package/scripts/ai_council/one_off_archive/2026-05/_one_off_silent_taskfiles.py +0 -98
  1321. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_open_questions.py +0 -232
  1322. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_optimization.py +0 -144
  1323. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_v3_gaps.py +0 -252
  1324. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_v3_review.py +0 -240
  1325. package/scripts/ai_council/one_off_archive/2026-05/_one_off_tier_retrofit.py +0 -180
  1326. package/scripts/ai_council/pricing.py +0 -215
  1327. package/scripts/ai_council/session.py +0 -366
  1328. package/scripts/annotate_discovery.py +0 -149
  1329. package/scripts/apply_modules_config.py +0 -290
  1330. package/scripts/audit_adr_coverage.py +0 -175
  1331. package/scripts/audit_auto_rules.py +0 -175
  1332. package/scripts/audit_cloud_compatibility.py +0 -362
  1333. package/scripts/audit_command_surface.py +0 -374
  1334. package/scripts/audit_initial_context.py +0 -234
  1335. package/scripts/audit_likelihood.py +0 -148
  1336. package/scripts/audit_mcp_tools.py +0 -146
  1337. package/scripts/audit_overlap.py +0 -145
  1338. package/scripts/audit_user_type_axis.py +0 -140
  1339. package/scripts/backfill_model_tier.py +0 -182
  1340. package/scripts/bench_ab_cache_dispatch.py +0 -68
  1341. package/scripts/bench_ab_clone.py +0 -170
  1342. package/scripts/bench_ab_diff.py +0 -220
  1343. package/scripts/bench_ab_integrity.py +0 -143
  1344. package/scripts/bench_ab_run.py +0 -235
  1345. package/scripts/bench_ab_task_runner.py +0 -369
  1346. package/scripts/bench_ab_tracka_run.py +0 -202
  1347. package/scripts/bench_baseline_ready.py +0 -108
  1348. package/scripts/bench_condense_memory.py +0 -168
  1349. package/scripts/bench_drift_check.py +0 -151
  1350. package/scripts/bench_per_tool.py +0 -216
  1351. package/scripts/bench_rtk_savings.py +0 -320
  1352. package/scripts/bench_run.py +0 -272
  1353. package/scripts/bench_runner.py +0 -158
  1354. package/scripts/build_cloud_bundle.py +0 -458
  1355. package/scripts/build_discovery_manifest.py +0 -679
  1356. package/scripts/build_linear_digest.py +0 -260
  1357. package/scripts/build_mcp_registry_manifest.py +0 -181
  1358. package/scripts/build_rule_trigger_matrix.py +0 -350
  1359. package/scripts/capture_showcase_session.py +0 -361
  1360. package/scripts/check_always_budget.py +0 -532
  1361. package/scripts/check_artefact_checksums.py +0 -111
  1362. package/scripts/check_augment_description_cap.py +0 -79
  1363. package/scripts/check_augmentignore.py +0 -72
  1364. package/scripts/check_beta_review_markers.py +0 -127
  1365. package/scripts/check_cluster_patterns.py +0 -175
  1366. package/scripts/check_command_count_messaging.py +0 -158
  1367. package/scripts/check_condensation.py +0 -375
  1368. package/scripts/check_condensed_paths.py +0 -221
  1369. package/scripts/check_context_paths.py +0 -202
  1370. package/scripts/check_council_references.py +0 -228
  1371. package/scripts/check_discovery_determinism.py +0 -70
  1372. package/scripts/check_gate_paths.py +0 -117
  1373. package/scripts/check_module_management_neutral.py +0 -149
  1374. package/scripts/check_no_roadmap_refs.py +0 -155
  1375. package/scripts/check_one_off_location.py +0 -81
  1376. package/scripts/check_overlay_cascade_subdirs.py +0 -129
  1377. package/scripts/check_portability.py +0 -574
  1378. package/scripts/check_public_catalog_links.py +0 -125
  1379. package/scripts/check_public_links.py +0 -185
  1380. package/scripts/check_references.py +0 -541
  1381. package/scripts/check_release_includes_discovery.py +0 -61
  1382. package/scripts/check_release_pr_shape.py +0 -119
  1383. package/scripts/check_release_published.py +0 -145
  1384. package/scripts/check_reply_consistency.py +0 -169
  1385. package/scripts/check_roadmap_trackable.py +0 -114
  1386. package/scripts/check_role_doc_links.py +0 -110
  1387. package/scripts/check_safety_floor_untouched.py +0 -125
  1388. package/scripts/check_skill_requires.py +0 -143
  1389. package/scripts/check_template_pin_drift.py +0 -129
  1390. package/scripts/check_test_coverage_diff.py +0 -180
  1391. package/scripts/check_token_optimizer_freshness.py +0 -146
  1392. package/scripts/check_update_banner.py +0 -86
  1393. package/scripts/ci_time_ratio.py +0 -168
  1394. package/scripts/compile_router.py +0 -232
  1395. package/scripts/condense.py +0 -1649
  1396. package/scripts/condense_memory.py +0 -178
  1397. package/scripts/config/profiles.py +0 -188
  1398. package/scripts/config/session_profiles.py +0 -492
  1399. package/scripts/cost_by_conversation.py +0 -78
  1400. package/scripts/cost_summary.py +0 -97
  1401. package/scripts/council_cli.py +0 -2544
  1402. package/scripts/cross_repo_retrieve.py +0 -172
  1403. package/scripts/discovery_stats.py +0 -70
  1404. package/scripts/extract_audit_patterns.py +0 -202
  1405. package/scripts/first_run_gate_hook.py +0 -178
  1406. package/scripts/gen_discovery_baseline.py +0 -127
  1407. package/scripts/generate_catalog.py +0 -116
  1408. package/scripts/generate_index.py +0 -302
  1409. package/scripts/generate_ownership_matrix.py +0 -378
  1410. package/scripts/generate_pack_manifests.py +0 -183
  1411. package/scripts/hook_manifest.yaml +0 -234
  1412. package/scripts/hooks/dispatch_hook.py +0 -461
  1413. package/scripts/hooks/replay_hook.py +0 -144
  1414. package/scripts/hooks_doctor.py +0 -223
  1415. package/scripts/hooks_status.py +0 -157
  1416. package/scripts/install +0 -424
  1417. package/scripts/install-hooks.sh +0 -185
  1418. package/scripts/install.py +0 -5027
  1419. package/scripts/install.sh +0 -1140
  1420. package/scripts/inventory_abstraction_budget.py +0 -621
  1421. package/scripts/inventory_frontmatter.py +0 -164
  1422. package/scripts/inventory_meta_layers.py +0 -288
  1423. package/scripts/iron_law_sha.py +0 -107
  1424. package/scripts/linked_projects_list.py +0 -91
  1425. package/scripts/lint_agents_layout.py +0 -191
  1426. package/scripts/lint_agents_md.py +0 -208
  1427. package/scripts/lint_archived_skills.py +0 -159
  1428. package/scripts/lint_artefact_frontmatter.py +0 -180
  1429. package/scripts/lint_bench_ab.py +0 -172
  1430. package/scripts/lint_bench_corpus.py +0 -255
  1431. package/scripts/lint_command_tiers.py +0 -128
  1432. package/scripts/lint_commit_subjects.py +0 -139
  1433. package/scripts/lint_context_spine_usage.py +0 -137
  1434. package/scripts/lint_discovery_manifest.py +0 -136
  1435. package/scripts/lint_discovery_vocabulary.py +0 -156
  1436. package/scripts/lint_examples.py +0 -102
  1437. package/scripts/lint_explain_trace.py +0 -80
  1438. package/scripts/lint_featured_skills.py +0 -139
  1439. package/scripts/lint_framework_leakage.py +0 -375
  1440. package/scripts/lint_framework_leakage_allowlist.json +0 -575
  1441. package/scripts/lint_frontmatter_boilerplate.py +0 -77
  1442. package/scripts/lint_ghostwriter_source.py +0 -240
  1443. package/scripts/lint_handoffs.py +0 -217
  1444. package/scripts/lint_hook_concern_budget.py +0 -207
  1445. package/scripts/lint_hook_manifest.py +0 -217
  1446. package/scripts/lint_load_context.py +0 -196
  1447. package/scripts/lint_marketplace.py +0 -180
  1448. package/scripts/lint_marketplace_install_completeness.py +0 -188
  1449. package/scripts/lint_mcp_registry_manifest.py +0 -69
  1450. package/scripts/lint_media_policy_linkage.py +0 -140
  1451. package/scripts/lint_model_tier_coverage.py +0 -73
  1452. package/scripts/lint_namespace.py +0 -135
  1453. package/scripts/lint_no_new_atomic_commands.py +0 -180
  1454. package/scripts/lint_one_off_age.py +0 -184
  1455. package/scripts/lint_orchestration_dsl.py +0 -217
  1456. package/scripts/lint_pack_boundaries.py +0 -147
  1457. package/scripts/lint_pack_first_win.py +0 -103
  1458. package/scripts/lint_persona_governance.py +0 -164
  1459. package/scripts/lint_positioning.py +0 -143
  1460. package/scripts/lint_regression.py +0 -232
  1461. package/scripts/lint_roadmap_ci_steps.py +0 -186
  1462. package/scripts/lint_roadmap_complexity.py +0 -220
  1463. package/scripts/lint_role_experiences.py +0 -237
  1464. package/scripts/lint_rule_interactions.py +0 -170
  1465. package/scripts/lint_rule_tiers.py +0 -90
  1466. package/scripts/lint_showcase_sessions.py +0 -148
  1467. package/scripts/lint_skill_tools.py +0 -168
  1468. package/scripts/lint_topics_yaml.py +0 -89
  1469. package/scripts/lint_trust_coherence.py +0 -212
  1470. package/scripts/lint_value_dashboard.py +0 -218
  1471. package/scripts/mcp_parity_smoke.py +0 -164
  1472. package/scripts/mcp_registry_submit.sh +0 -187
  1473. package/scripts/mcp_server/__init__.py +0 -19
  1474. package/scripts/mcp_server/consumer_tool_catalog.json +0 -275
  1475. package/scripts/mcp_server/prompts.py +0 -441
  1476. package/scripts/mcp_server/resources.py +0 -201
  1477. package/scripts/mcp_server/tools.py +0 -838
  1478. package/scripts/measure_augment_budget.py +0 -214
  1479. package/scripts/measure_density.py +0 -232
  1480. package/scripts/measure_frugality_savings.py +0 -164
  1481. package/scripts/measure_markitdown_lift.py +0 -127
  1482. package/scripts/measure_patterns.py +0 -376
  1483. package/scripts/measure_projection_bytes.py +0 -159
  1484. package/scripts/measure_rule_budget.py +0 -347
  1485. package/scripts/measure_skill_reduction.py +0 -102
  1486. package/scripts/migrate_command_suggestions.py +0 -151
  1487. package/scripts/migrate_frontmatter_defaults.py +0 -245
  1488. package/scripts/mine_session.py +0 -279
  1489. package/scripts/move_artefact.py +0 -143
  1490. package/scripts/new_skill.py +0 -148
  1491. package/scripts/pack_mcp_content.py +0 -288
  1492. package/scripts/plan_physical_move.py +0 -353
  1493. package/scripts/print_required_checks.py +0 -196
  1494. package/scripts/probe_projection_fidelity.py +0 -202
  1495. package/scripts/profile_staleness_hook.py +0 -69
  1496. package/scripts/profile_use.py +0 -125
  1497. package/scripts/project_thin_rules.py +0 -168
  1498. package/scripts/prototype_lint_contradictions.py +0 -150
  1499. package/scripts/recruit_preflight.sh +0 -152
  1500. package/scripts/refine_ticket_detect.py +0 -646
  1501. package/scripts/release.py +0 -1049
  1502. package/scripts/render_benchmark_md.py +0 -312
  1503. package/scripts/render_value_md.py +0 -347
  1504. package/scripts/repro/repro_marketplace_install_gap.sh +0 -161
  1505. package/scripts/roadmap_progress_hook.py +0 -274
  1506. package/scripts/router_telemetry.py +0 -470
  1507. package/scripts/run_skill_evals.py +0 -185
  1508. package/scripts/runtime_registry.py +0 -166
  1509. package/scripts/schemas/command.schema.json +0 -178
  1510. package/scripts/schemas/rule.schema.json +0 -145
  1511. package/scripts/score_skill_selection.py +0 -198
  1512. package/scripts/skill_collision_clusters.py +0 -162
  1513. package/scripts/skill_discovery.py +0 -254
  1514. package/scripts/skill_linter.py +0 -3686
  1515. package/scripts/skill_overlap.py +0 -204
  1516. package/scripts/skill_preview.py +0 -179
  1517. package/scripts/skill_tools/audit_persona_coverage.py +0 -147
  1518. package/scripts/skill_tools/audit_user_type_coverage.py +0 -148
  1519. package/scripts/skill_tools/run_block_d_eval.py +0 -129
  1520. package/scripts/skill_tools/score_skill_relevance.py +0 -169
  1521. package/scripts/skill_tools/suggest_skill_for_task.py +0 -113
  1522. package/scripts/skill_trigger_eval.py +0 -682
  1523. package/scripts/skill_usage_collect.py +0 -191
  1524. package/scripts/skill_usage_report.py +0 -162
  1525. package/scripts/smoke/kernel.sh +0 -107
  1526. package/scripts/smoke/router.sh +0 -148
  1527. package/scripts/smoke/schema.sh +0 -71
  1528. package/scripts/smoke/skills.sh +0 -112
  1529. package/scripts/smoke_path_resolution.py +0 -93
  1530. package/scripts/smoke_quickstart.py +0 -144
  1531. package/scripts/snapshot_agent_outputs.py +0 -144
  1532. package/scripts/spotcheck_thin_root.py +0 -134
  1533. package/scripts/sync_agent_settings.py +0 -180
  1534. package/scripts/sync_github_metadata.py +0 -147
  1535. package/scripts/sync_gitignore.py +0 -291
  1536. package/scripts/telegraph_stats.py +0 -119
  1537. package/scripts/trigger_coverage.py +0 -129
  1538. package/scripts/update_counts.py +0 -195
  1539. package/scripts/update_prices.py +0 -125
  1540. package/scripts/validate_agent_settings.py +0 -124
  1541. package/scripts/validate_decision_engine.py +0 -136
  1542. package/scripts/validate_discovery_manifest.py +0 -94
  1543. package/scripts/validate_frontmatter.py +0 -571
  1544. package/scripts/verify_physical_move.py +0 -185
  1545. /package/{.agent-src → dist/agent-src}/contexts/augment-infrastructure.md +0 -0
  1546. /package/{.agent-src → dist/agent-src}/contexts/authority/destructive-mechanics.md +0 -0
  1547. /package/{.agent-src → dist/agent-src}/contexts/authority/kernel-rule-edits.md +0 -0
  1548. /package/{.agent-src → dist/agent-src}/contexts/authority/scope-mechanics.md +0 -0
  1549. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/guidelines-mechanics.md +0 -0
  1550. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/skill-quality-mechanics.md +0 -0
  1551. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/slash-command-routing-policy-mechanics.md +0 -0
  1552. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/think-before-action-mechanics.md +0 -0
  1553. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/token-efficiency-mechanics.md +0 -0
  1554. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/user-interaction-mechanics.md +0 -0
  1555. /package/{.agent-src → dist/agent-src}/contexts/contracts/agents-md-anatomy.md +0 -0
  1556. /package/{.agent-src → dist/agent-src}/contexts/contracts/command-suggestion-flow.md +0 -0
  1557. /package/{.agent-src → dist/agent-src}/contexts/contracts/frugality-charter.md +0 -0
  1558. /package/{.agent-src → dist/agent-src}/contexts/contracts/research-schema.md +0 -0
  1559. /package/{.agent-src → dist/agent-src}/contexts/documentation-hierarchy.md +0 -0
  1560. /package/{.agent-src → dist/agent-src}/contexts/execution/autonomy-detection.md +0 -0
  1561. /package/{.agent-src → dist/agent-src}/contexts/execution/autonomy-examples.md +0 -0
  1562. /package/{.agent-src → dist/agent-src}/contexts/execution/autonomy-mechanics.md +0 -0
  1563. /package/{.agent-src → dist/agent-src}/contexts/execution/cheap-question-mechanics.md +0 -0
  1564. /package/{.agent-src → dist/agent-src}/contexts/execution/interrupt-examples.md +0 -0
  1565. /package/{.agent-src → dist/agent-src}/contexts/execution/roadmap-process-loop.md +0 -0
  1566. /package/{.agent-src → dist/agent-src}/contexts/execution/verification-mechanics.md +0 -0
  1567. /package/{.agent-src → dist/agent-src}/contexts/judges/no-consolidate-rationale.md +0 -0
  1568. /package/{.agent-src → dist/agent-src}/contexts/judges/persona-voice-rubric.md +0 -0
  1569. /package/{.agent-src → dist/agent-src}/contexts/model-recommendations.md +0 -0
  1570. /package/{.agent-src → dist/agent-src}/contexts/override-system.md +0 -0
  1571. /package/{.agent-src → dist/agent-src}/contexts/skills-and-commands.md +0 -0
  1572. /package/{.agent-src → dist/agent-src}/contexts/subagent-configuration.md +0 -0
  1573. /package/{.agent-src → dist/agent-src}/ghostwriter/README.md +0 -0
  1574. /package/{.agent-src → dist/agent-src}/ghostwriter/fictional-fixture-v1.md +0 -0
  1575. /package/{.agent-src → dist/agent-src}/packs/README.md +0 -0
  1576. /package/{.agent-src → dist/agent-src}/packs/agency-delivery.yml +0 -0
  1577. /package/{.agent-src → dist/agent-src}/packs/content-engine.yml +0 -0
  1578. /package/{.agent-src → dist/agent-src}/packs/founder-mvp.yml +0 -0
  1579. /package/{.agent-src → dist/agent-src}/personas/_template-specialist/persona.md +0 -0
  1580. /package/{.agent-src → dist/agent-src}/personas/advisors/contrarian.md +0 -0
  1581. /package/{.agent-src → dist/agent-src}/personas/advisors/executor.md +0 -0
  1582. /package/{.agent-src → dist/agent-src}/personas/advisors/expansionist.md +0 -0
  1583. /package/{.agent-src → dist/agent-src}/personas/advisors/first-principles.md +0 -0
  1584. /package/{.agent-src → dist/agent-src}/personas/advisors/outsider.md +0 -0
  1585. /package/{.agent-src → dist/agent-src}/personas/ai-agent.md +0 -0
  1586. /package/{.agent-src → dist/agent-src}/personas/ai-video-technical-director.md +0 -0
  1587. /package/{.agent-src → dist/agent-src}/personas/backend-architect.md +0 -0
  1588. /package/{.agent-src → dist/agent-src}/personas/cmo.md +0 -0
  1589. /package/{.agent-src → dist/agent-src}/personas/critical-challenger.md +0 -0
  1590. /package/{.agent-src → dist/agent-src}/personas/customer-success-lead.md +0 -0
  1591. /package/{.agent-src → dist/agent-src}/personas/developer.md +0 -0
  1592. /package/{.agent-src → dist/agent-src}/personas/discovery-lead.md +0 -0
  1593. /package/{.agent-src → dist/agent-src}/personas/eloquent-tamer.md +0 -0
  1594. /package/{.agent-src → dist/agent-src}/personas/engineering-manager.md +0 -0
  1595. /package/{.agent-src → dist/agent-src}/personas/finance-partner.md +0 -0
  1596. /package/{.agent-src → dist/agent-src}/personas/frontend-engineer.md +0 -0
  1597. /package/{.agent-src → dist/agent-src}/personas/growth-pm.md +0 -0
  1598. /package/{.agent-src → dist/agent-src}/personas/hollywood-director.md +0 -0
  1599. /package/{.agent-src → dist/agent-src}/personas/people-strategist.md +0 -0
  1600. /package/{.agent-src → dist/agent-src}/personas/product-owner.md +0 -0
  1601. /package/{.agent-src → dist/agent-src}/personas/qa.md +0 -0
  1602. /package/{.agent-src → dist/agent-src}/personas/revops-maintainer.md +0 -0
  1603. /package/{.agent-src → dist/agent-src}/personas/revops.md +0 -0
  1604. /package/{.agent-src → dist/agent-src}/personas/security-engineer.md +0 -0
  1605. /package/{.agent-src → dist/agent-src}/personas/senior-engineer.md +0 -0
  1606. /package/{.agent-src → dist/agent-src}/personas/stakeholder.md +0 -0
  1607. /package/{.agent-src → dist/agent-src}/personas/strategist.md +0 -0
  1608. /package/{.agent-src → dist/agent-src}/personas/tech-writer.md +0 -0
  1609. /package/{.agent-src → dist/agent-src}/presets/README.md +0 -0
  1610. /package/{.agent-src → dist/agent-src}/presets/balanced.yml +0 -0
  1611. /package/{.agent-src → dist/agent-src}/presets/fast.yml +0 -0
  1612. /package/{.agent-src → dist/agent-src}/presets/strict.yml +0 -0
  1613. /package/{.agent-src → dist/agent-src}/profiles/README.md +0 -0
  1614. /package/{.agent-src → dist/agent-src}/rules/agent-authority.md +0 -0
  1615. /package/{.agent-src → dist/agent-src}/rules/analysis-skill-routing.md +0 -0
  1616. /package/{.agent-src → dist/agent-src}/rules/architecture.md +0 -0
  1617. /package/{.agent-src → dist/agent-src}/rules/artifact-drafting-protocol.md +0 -0
  1618. /package/{.agent-src → dist/agent-src}/rules/artifact-engagement-recording.md +0 -0
  1619. /package/{.agent-src → dist/agent-src}/rules/autonomous-execution.md +0 -0
  1620. /package/{.agent-src → dist/agent-src}/rules/cli-output-handling.md +0 -0
  1621. /package/{.agent-src → dist/agent-src}/rules/command-suggestion-policy.md +0 -0
  1622. /package/{.agent-src → dist/agent-src}/rules/commit-conventions.md +0 -0
  1623. /package/{.agent-src → dist/agent-src}/rules/context-hygiene.md +0 -0
  1624. /package/{.agent-src → dist/agent-src}/rules/copilot-routing.md +0 -0
  1625. /package/{.agent-src → dist/agent-src}/rules/devcontainer-routing.md +0 -0
  1626. /package/{.agent-src → dist/agent-src}/rules/docker-commands.md +0 -0
  1627. /package/{.agent-src → dist/agent-src}/rules/domain-safety-disclaimer.md +0 -0
  1628. /package/{.agent-src → dist/agent-src}/rules/domain-safety-pii.md +0 -0
  1629. /package/{.agent-src → dist/agent-src}/rules/domain-safety-retention.md +0 -0
  1630. /package/{.agent-src → dist/agent-src}/rules/downstream-changes.md +0 -0
  1631. /package/{.agent-src → dist/agent-src}/rules/engineering-safety-floor.md +0 -0
  1632. /package/{.agent-src → dist/agent-src}/rules/external-reference-deep-dive.md +0 -0
  1633. /package/{.agent-src → dist/agent-src}/rules/fast-path-marker-visibility.md +0 -0
  1634. /package/{.agent-src → dist/agent-src}/rules/finance-safety-floor.md +0 -0
  1635. /package/{.agent-src → dist/agent-src}/rules/framework-neutrality-in-generic-skills.md +0 -0
  1636. /package/{.agent-src → dist/agent-src}/rules/git-history-discipline.md +0 -0
  1637. /package/{.agent-src → dist/agent-src}/rules/guidelines.md +0 -0
  1638. /package/{.agent-src → dist/agent-src}/rules/improve-before-implement.md +0 -0
  1639. /package/{.agent-src → dist/agent-src}/rules/invite-challenge.md +0 -0
  1640. /package/{.agent-src → dist/agent-src}/rules/laravel-routing.md +0 -0
  1641. /package/{.agent-src → dist/agent-src}/rules/laravel-translations.md +0 -0
  1642. /package/{.agent-src → dist/agent-src}/rules/low-impact-corpus-privacy-floor.md +0 -0
  1643. /package/{.agent-src → dist/agent-src}/rules/markdown-safe-codeblocks.md +0 -0
  1644. /package/{.agent-src → dist/agent-src}/rules/media-sync-ground-truth.md +0 -0
  1645. /package/{.agent-src → dist/agent-src}/rules/minimal-safe-diff.md +0 -0
  1646. /package/{.agent-src → dist/agent-src}/rules/no-decorative-emojis-in-git-surfaces.md +0 -0
  1647. /package/{.agent-src → dist/agent-src}/rules/onboarding-gate.md +0 -0
  1648. /package/{.agent-src → dist/agent-src}/rules/package-ci-checks.md +0 -0
  1649. /package/{.agent-src → dist/agent-src}/rules/php-coding.md +0 -0
  1650. /package/{.agent-src → dist/agent-src}/rules/reviewer-awareness.md +0 -0
  1651. /package/{.agent-src → dist/agent-src}/rules/roadmap-ci-steps-policy.md +0 -0
  1652. /package/{.agent-src → dist/agent-src}/rules/role-mode-adherence.md +0 -0
  1653. /package/{.agent-src → dist/agent-src}/rules/rule-type-governance.md +0 -0
  1654. /package/{.agent-src → dist/agent-src}/rules/runtime-safety.md +0 -0
  1655. /package/{.agent-src → dist/agent-src}/rules/security-sensitive-stop.md +0 -0
  1656. /package/{.agent-src → dist/agent-src}/rules/size-enforcement.md +0 -0
  1657. /package/{.agent-src → dist/agent-src}/rules/skill-improvement-trigger.md +0 -0
  1658. /package/{.agent-src → dist/agent-src}/rules/skill-quality.md +0 -0
  1659. /package/{.agent-src → dist/agent-src}/rules/slash-command-routing-policy.md +0 -0
  1660. /package/{.agent-src → dist/agent-src}/rules/strategy-safety-floor.md +0 -0
  1661. /package/{.agent-src → dist/agent-src}/rules/symfony-routing.md +0 -0
  1662. /package/{.agent-src → dist/agent-src}/rules/telegraph-speak.md +0 -0
  1663. /package/{.agent-src → dist/agent-src}/rules/think-before-action.md +0 -0
  1664. /package/{.agent-src → dist/agent-src}/rules/token-efficiency.md +0 -0
  1665. /package/{.agent-src → dist/agent-src}/rules/token-optimizer-maintenance.md +0 -0
  1666. /package/{.agent-src → dist/agent-src}/rules/tool-safety.md +0 -0
  1667. /package/{.agent-src → dist/agent-src}/rules/ui-audit-gate.md +0 -0
  1668. /package/{.agent-src → dist/agent-src}/rules/upstream-proposal.md +0 -0
  1669. /package/{.agent-src → dist/agent-src}/rules/user-interaction.md +0 -0
  1670. /package/{.agent-src → dist/agent-src}/scripts/scan-seeder-violations.php +0 -0
  1671. /package/{.agent-src → dist/agent-src}/skills/activation-design/SKILL.md +0 -0
  1672. /package/{.agent-src → dist/agent-src}/skills/adr-create/SKILL.md +0 -0
  1673. /package/{.agent-src → dist/agent-src}/skills/adversarial-review/SKILL.md +0 -0
  1674. /package/{.agent-src → dist/agent-src}/skills/agent-docs-writing/SKILL.md +0 -0
  1675. /package/{.agent-src → dist/agent-src}/skills/ai-council/SKILL.md +0 -0
  1676. /package/{.agent-src → dist/agent-src}/skills/analysis-autonomous-mode/SKILL.md +0 -0
  1677. /package/{.agent-src → dist/agent-src}/skills/analysis-skill-router/SKILL.md +0 -0
  1678. /package/{.agent-src → dist/agent-src}/skills/api-testing/SKILL.md +0 -0
  1679. /package/{.agent-src → dist/agent-src}/skills/architecture-review-lens/SKILL.md +0 -0
  1680. /package/{.agent-src → dist/agent-src}/skills/artisan-commands/SKILL.md +0 -0
  1681. /package/{.agent-src → dist/agent-src}/skills/async-python-patterns/SKILL.md +0 -0
  1682. /package/{.agent-src → dist/agent-src}/skills/aws-infrastructure/SKILL.md +0 -0
  1683. /package/{.agent-src → dist/agent-src}/skills/blast-radius-analyzer/SKILL.md +0 -0
  1684. /package/{.agent-src → dist/agent-src}/skills/bug-analyzer/SKILL.md +0 -0
  1685. /package/{.agent-src → dist/agent-src}/skills/build-buy-partner/SKILL.md +0 -0
  1686. /package/{.agent-src → dist/agent-src}/skills/canvas-design/SKILL.md +0 -0
  1687. /package/{.agent-src → dist/agent-src}/skills/canvas-design/evals/triggers.json +0 -0
  1688. /package/{.agent-src → dist/agent-src}/skills/churn-prevention/SKILL.md +0 -0
  1689. /package/{.agent-src → dist/agent-src}/skills/code-refactoring/SKILL.md +0 -0
  1690. /package/{.agent-src → dist/agent-src}/skills/command-routing/SKILL.md +0 -0
  1691. /package/{.agent-src → dist/agent-src}/skills/comp-banding/SKILL.md +0 -0
  1692. /package/{.agent-src → dist/agent-src}/skills/competitive-moat-analysis/SKILL.md +0 -0
  1693. /package/{.agent-src → dist/agent-src}/skills/competitive-positioning/SKILL.md +0 -0
  1694. /package/{.agent-src → dist/agent-src}/skills/composer-packages/SKILL.md +0 -0
  1695. /package/{.agent-src → dist/agent-src}/skills/content-funnel-design/SKILL.md +0 -0
  1696. /package/{.agent-src → dist/agent-src}/skills/context-authoring/SKILL.md +0 -0
  1697. /package/{.agent-src → dist/agent-src}/skills/contracts-cognition/SKILL.md +0 -0
  1698. /package/{.agent-src → dist/agent-src}/skills/conventional-commits-writing/SKILL.md +0 -0
  1699. /package/{.agent-src → dist/agent-src}/skills/copilot-agents-optimization/SKILL.md +0 -0
  1700. /package/{.agent-src → dist/agent-src}/skills/copilot-config/SKILL.md +0 -0
  1701. /package/{.agent-src → dist/agent-src}/skills/customer-research/SKILL.md +0 -0
  1702. /package/{.agent-src → dist/agent-src}/skills/data-flow-mapper/SKILL.md +0 -0
  1703. /package/{.agent-src → dist/agent-src}/skills/data-handling-judgment/SKILL.md +0 -0
  1704. /package/{.agent-src → dist/agent-src}/skills/dcf-modeling/SKILL.md +0 -0
  1705. /package/{.agent-src → dist/agent-src}/skills/deal-qualification-meddic/SKILL.md +0 -0
  1706. /package/{.agent-src → dist/agent-src}/skills/decision-record/SKILL.md +0 -0
  1707. /package/{.agent-src → dist/agent-src}/skills/defense-in-depth/SKILL.md +0 -0
  1708. /package/{.agent-src → dist/agent-src}/skills/dependency-upgrade/SKILL.md +0 -0
  1709. /package/{.agent-src → dist/agent-src}/skills/description-assist/SKILL.md +0 -0
  1710. /package/{.agent-src → dist/agent-src}/skills/devcontainer/SKILL.md +0 -0
  1711. /package/{.agent-src → dist/agent-src}/skills/developer-like-execution/SKILL.md +0 -0
  1712. /package/{.agent-src → dist/agent-src}/skills/discovery-interview/SKILL.md +0 -0
  1713. /package/{.agent-src → dist/agent-src}/skills/doc-coauthoring/SKILL.md +0 -0
  1714. /package/{.agent-src → dist/agent-src}/skills/doc-coauthoring/evals/triggers.json +0 -0
  1715. /package/{.agent-src → dist/agent-src}/skills/docker/SKILL.md +0 -0
  1716. /package/{.agent-src → dist/agent-src}/skills/editorial-calendar/SKILL.md +0 -0
  1717. /package/{.agent-src → dist/agent-src}/skills/eloquent/SKILL.md +0 -0
  1718. /package/{.agent-src → dist/agent-src}/skills/eloquent/evals/triggers.json +0 -0
  1719. /package/{.agent-src → dist/agent-src}/skills/error-handling-patterns/SKILL.md +0 -0
  1720. /package/{.agent-src → dist/agent-src}/skills/estimate-ticket/SKILL.md +0 -0
  1721. /package/{.agent-src → dist/agent-src}/skills/estimate-ticket/evals/output-schema.yml +0 -0
  1722. /package/{.agent-src → dist/agent-src}/skills/estimate-ticket/evals/triggers.json +0 -0
  1723. /package/{.agent-src → dist/agent-src}/skills/expansion-playbook/SKILL.md +0 -0
  1724. /package/{.agent-src → dist/agent-src}/skills/file-editor/SKILL.md +0 -0
  1725. /package/{.agent-src → dist/agent-src}/skills/finishing-a-development-branch/SKILL.md +0 -0
  1726. /package/{.agent-src → dist/agent-src}/skills/forecast-accuracy/SKILL.md +0 -0
  1727. /package/{.agent-src → dist/agent-src}/skills/forecasting/SKILL.md +0 -0
  1728. /package/{.agent-src → dist/agent-src}/skills/form-handler/SKILL.md +0 -0
  1729. /package/{.agent-src → dist/agent-src}/skills/fundraising-narrative/SKILL.md +0 -0
  1730. /package/{.agent-src → dist/agent-src}/skills/funnel-analysis/SKILL.md +0 -0
  1731. /package/{.agent-src → dist/agent-src}/skills/git-workflow/SKILL.md +0 -0
  1732. /package/{.agent-src → dist/agent-src}/skills/github-ci/SKILL.md +0 -0
  1733. /package/{.agent-src → dist/agent-src}/skills/grafana/SKILL.md +0 -0
  1734. /package/{.agent-src → dist/agent-src}/skills/gtm-launch/SKILL.md +0 -0
  1735. /package/{.agent-src → dist/agent-src}/skills/guideline-writing/SKILL.md +0 -0
  1736. /package/{.agent-src → dist/agent-src}/skills/hiring-loop-design/SKILL.md +0 -0
  1737. /package/{.agent-src → dist/agent-src}/skills/image-analyser/SKILL.md +0 -0
  1738. /package/{.agent-src → dist/agent-src}/skills/image-analyser/canon-spec.md +0 -0
  1739. /package/{.agent-src → dist/agent-src}/skills/image-analyser/evals/triggers.json +0 -0
  1740. /package/{.agent-src → dist/agent-src}/skills/image-creator/SKILL.md +0 -0
  1741. /package/{.agent-src → dist/agent-src}/skills/image-creator/evals/triggers.json +0 -0
  1742. /package/{.agent-src → dist/agent-src}/skills/incident-commander/SKILL.md +0 -0
  1743. /package/{.agent-src → dist/agent-src}/skills/jobs-events/SKILL.md +0 -0
  1744. /package/{.agent-src → dist/agent-src}/skills/judge-bug-hunter/SKILL.md +0 -0
  1745. /package/{.agent-src → dist/agent-src}/skills/judge-code-quality/SKILL.md +0 -0
  1746. /package/{.agent-src → dist/agent-src}/skills/judge-security-auditor/SKILL.md +0 -0
  1747. /package/{.agent-src → dist/agent-src}/skills/judge-test-coverage/SKILL.md +0 -0
  1748. /package/{.agent-src → dist/agent-src}/skills/laravel/SKILL.md +0 -0
  1749. /package/{.agent-src → dist/agent-src}/skills/laravel-api-endpoint/SKILL.md +0 -0
  1750. /package/{.agent-src → dist/agent-src}/skills/laravel-dto/SKILL.md +0 -0
  1751. /package/{.agent-src → dist/agent-src}/skills/laravel-horizon/SKILL.md +0 -0
  1752. /package/{.agent-src → dist/agent-src}/skills/laravel-mail/SKILL.md +0 -0
  1753. /package/{.agent-src → dist/agent-src}/skills/laravel-middleware/SKILL.md +0 -0
  1754. /package/{.agent-src → dist/agent-src}/skills/laravel-migration/SKILL.md +0 -0
  1755. /package/{.agent-src → dist/agent-src}/skills/laravel-notifications/SKILL.md +0 -0
  1756. /package/{.agent-src → dist/agent-src}/skills/laravel-pennant/SKILL.md +0 -0
  1757. /package/{.agent-src → dist/agent-src}/skills/laravel-pulse/SKILL.md +0 -0
  1758. /package/{.agent-src → dist/agent-src}/skills/laravel-reverb/SKILL.md +0 -0
  1759. /package/{.agent-src → dist/agent-src}/skills/laravel-scheduling/SKILL.md +0 -0
  1760. /package/{.agent-src → dist/agent-src}/skills/laravel-validation/SKILL.md +0 -0
  1761. /package/{.agent-src → dist/agent-src}/skills/laravel-websocket/SKILL.md +0 -0
  1762. /package/{.agent-src → dist/agent-src}/skills/launch-readiness/SKILL.md +0 -0
  1763. /package/{.agent-src → dist/agent-src}/skills/learning-to-rule-or-skill/SKILL.md +0 -0
  1764. /package/{.agent-src → dist/agent-src}/skills/livewire-architect/SKILL.md +0 -0
  1765. /package/{.agent-src → dist/agent-src}/skills/logging-monitoring/SKILL.md +0 -0
  1766. /package/{.agent-src → dist/agent-src}/skills/market-entry-analysis/SKILL.md +0 -0
  1767. /package/{.agent-src → dist/agent-src}/skills/markitdown/SKILL.md +0 -0
  1768. /package/{.agent-src → dist/agent-src}/skills/mcp/SKILL.md +0 -0
  1769. /package/{.agent-src → dist/agent-src}/skills/mcp-builder/SKILL.md +0 -0
  1770. /package/{.agent-src → dist/agent-src}/skills/memory-consolidation/SKILL.md +0 -0
  1771. /package/{.agent-src → dist/agent-src}/skills/messaging-architecture/SKILL.md +0 -0
  1772. /package/{.agent-src → dist/agent-src}/skills/migration-architect/SKILL.md +0 -0
  1773. /package/{.agent-src → dist/agent-src}/skills/mobile-e2e-strategy/SKILL.md +0 -0
  1774. /package/{.agent-src → dist/agent-src}/skills/module-detect-on-the-fly/SKILL.md +0 -0
  1775. /package/{.agent-src → dist/agent-src}/skills/module-management/SKILL.md +0 -0
  1776. /package/{.agent-src → dist/agent-src}/skills/multi-tenancy/SKILL.md +0 -0
  1777. /package/{.agent-src → dist/agent-src}/skills/nextjs-patterns/SKILL.md +0 -0
  1778. /package/{.agent-src → dist/agent-src}/skills/okr-tree-modeling/SKILL.md +0 -0
  1779. /package/{.agent-src → dist/agent-src}/skills/onboarding-design/SKILL.md +0 -0
  1780. /package/{.agent-src → dist/agent-src}/skills/onboarding-program/SKILL.md +0 -0
  1781. /package/{.agent-src → dist/agent-src}/skills/one-on-one-cadence/SKILL.md +0 -0
  1782. /package/{.agent-src → dist/agent-src}/skills/openapi/SKILL.md +0 -0
  1783. /package/{.agent-src → dist/agent-src}/skills/org-design/SKILL.md +0 -0
  1784. /package/{.agent-src → dist/agent-src}/skills/override-management/SKILL.md +0 -0
  1785. /package/{.agent-src → dist/agent-src}/skills/perf-feedback-craft/SKILL.md +0 -0
  1786. /package/{.agent-src → dist/agent-src}/skills/performance/SKILL.md +0 -0
  1787. /package/{.agent-src → dist/agent-src}/skills/performance-analysis/SKILL.md +0 -0
  1788. /package/{.agent-src → dist/agent-src}/skills/pest-testing/SKILL.md +0 -0
  1789. /package/{.agent-src → dist/agent-src}/skills/php-coder/SKILL.md +0 -0
  1790. /package/{.agent-src → dist/agent-src}/skills/php-coder/evals/triggers.json +0 -0
  1791. /package/{.agent-src → dist/agent-src}/skills/php-debugging/SKILL.md +0 -0
  1792. /package/{.agent-src → dist/agent-src}/skills/php-service/SKILL.md +0 -0
  1793. /package/{.agent-src → dist/agent-src}/skills/pipeline-strategy/SKILL.md +0 -0
  1794. /package/{.agent-src → dist/agent-src}/skills/pixar-storyteller/SKILL.md +0 -0
  1795. /package/{.agent-src → dist/agent-src}/skills/playwright-architect/SKILL.md +0 -0
  1796. /package/{.agent-src → dist/agent-src}/skills/playwright-testing/SKILL.md +0 -0
  1797. /package/{.agent-src → dist/agent-src}/skills/po-discovery/SKILL.md +0 -0
  1798. /package/{.agent-src → dist/agent-src}/skills/positioning-strategy/SKILL.md +0 -0
  1799. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/SKILL.md +0 -0
  1800. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/evals/triggers.json +0 -0
  1801. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/reference/ev-fixtures.md +0 -0
  1802. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/reference/odds-and-bonus.md +0 -0
  1803. /package/{.agent-src → dist/agent-src}/skills/privacy-review/SKILL.md +0 -0
  1804. /package/{.agent-src → dist/agent-src}/skills/project-analysis-core/SKILL.md +0 -0
  1805. /package/{.agent-src → dist/agent-src}/skills/project-analysis-hypothesis-driven/SKILL.md +0 -0
  1806. /package/{.agent-src → dist/agent-src}/skills/project-analysis-laravel/SKILL.md +0 -0
  1807. /package/{.agent-src → dist/agent-src}/skills/project-analysis-nextjs/SKILL.md +0 -0
  1808. /package/{.agent-src → dist/agent-src}/skills/project-analysis-node-express/SKILL.md +0 -0
  1809. /package/{.agent-src → dist/agent-src}/skills/project-analysis-react/SKILL.md +0 -0
  1810. /package/{.agent-src → dist/agent-src}/skills/project-analysis-symfony/SKILL.md +0 -0
  1811. /package/{.agent-src → dist/agent-src}/skills/project-analysis-zend-laminas/SKILL.md +0 -0
  1812. /package/{.agent-src → dist/agent-src}/skills/project-analyzer/SKILL.md +0 -0
  1813. /package/{.agent-src → dist/agent-src}/skills/project-docs/SKILL.md +0 -0
  1814. /package/{.agent-src → dist/agent-src}/skills/prompt-engineering-patterns/SKILL.md +0 -0
  1815. /package/{.agent-src → dist/agent-src}/skills/prompt-optimizer/SKILL.md +0 -0
  1816. /package/{.agent-src → dist/agent-src}/skills/quality-tools/SKILL.md +0 -0
  1817. /package/{.agent-src → dist/agent-src}/skills/react-native-setup/SKILL.md +0 -0
  1818. /package/{.agent-src → dist/agent-src}/skills/receiving-code-review/SKILL.md +0 -0
  1819. /package/{.agent-src → dist/agent-src}/skills/refine-prompt/SKILL.md +0 -0
  1820. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/SKILL.md +0 -0
  1821. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/detection-map.yml +0 -0
  1822. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/evals/output-schema.yml +0 -0
  1823. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/evals/triggers.json +0 -0
  1824. /package/{.agent-src → dist/agent-src}/skills/release-comms/SKILL.md +0 -0
  1825. /package/{.agent-src → dist/agent-src}/skills/repomix-packer/SKILL.md +0 -0
  1826. /package/{.agent-src → dist/agent-src}/skills/requesting-code-review/SKILL.md +0 -0
  1827. /package/{.agent-src → dist/agent-src}/skills/retention-loops/SKILL.md +0 -0
  1828. /package/{.agent-src → dist/agent-src}/skills/review-routing/SKILL.md +0 -0
  1829. /package/{.agent-src → dist/agent-src}/skills/rice-prioritization/SKILL.md +0 -0
  1830. /package/{.agent-src → dist/agent-src}/skills/risk-officer/SKILL.md +0 -0
  1831. /package/{.agent-src → dist/agent-src}/skills/roadmap-writing/SKILL.md +0 -0
  1832. /package/{.agent-src → dist/agent-src}/skills/rtk-output-filtering/SKILL.md +0 -0
  1833. /package/{.agent-src → dist/agent-src}/skills/runway-cognition/SKILL.md +0 -0
  1834. /package/{.agent-src → dist/agent-src}/skills/scenario-modeling/SKILL.md +0 -0
  1835. /package/{.agent-src → dist/agent-src}/skills/secrets-management/SKILL.md +0 -0
  1836. /package/{.agent-src → dist/agent-src}/skills/security/SKILL.md +0 -0
  1837. /package/{.agent-src → dist/agent-src}/skills/security-audit/SKILL.md +0 -0
  1838. /package/{.agent-src → dist/agent-src}/skills/sequential-thinking/SKILL.md +0 -0
  1839. /package/{.agent-src → dist/agent-src}/skills/skill-improvement-pipeline/SKILL.md +0 -0
  1840. /package/{.agent-src → dist/agent-src}/skills/skill-management/SKILL.md +0 -0
  1841. /package/{.agent-src → dist/agent-src}/skills/skill-reviewer/SKILL.md +0 -0
  1842. /package/{.agent-src → dist/agent-src}/skills/skill-writing/SKILL.md +0 -0
  1843. /package/{.agent-src → dist/agent-src}/skills/skill-writing/evals/triggers.json +0 -0
  1844. /package/{.agent-src → dist/agent-src}/skills/stakeholder-tradeoff/SKILL.md +0 -0
  1845. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/SKILL.md +0 -0
  1846. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/README.md +0 -0
  1847. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-and-judge-two-stage.md +0 -0
  1848. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-and-judge.md +0 -0
  1849. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-competitively.md +0 -0
  1850. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-in-parallel.md +0 -0
  1851. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-in-steps.md +0 -0
  1852. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-in-worktrees.md +0 -0
  1853. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/judge-with-debate.md +0 -0
  1854. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/schemas/subagent-status.json +0 -0
  1855. /package/{.agent-src → dist/agent-src}/skills/symfony-workflow/SKILL.md +0 -0
  1856. /package/{.agent-src → dist/agent-src}/skills/systematic-debugging/SKILL.md +0 -0
  1857. /package/{.agent-src → dist/agent-src}/skills/tech-debt-tracker/SKILL.md +0 -0
  1858. /package/{.agent-src → dist/agent-src}/skills/terraform/SKILL.md +0 -0
  1859. /package/{.agent-src → dist/agent-src}/skills/terragrunt/SKILL.md +0 -0
  1860. /package/{.agent-src → dist/agent-src}/skills/test-driven-development/SKILL.md +0 -0
  1861. /package/{.agent-src → dist/agent-src}/skills/test-performance/SKILL.md +0 -0
  1862. /package/{.agent-src → dist/agent-src}/skills/testing-anti-patterns/SKILL.md +0 -0
  1863. /package/{.agent-src → dist/agent-src}/skills/testing-anti-patterns/process-anti-patterns.md +0 -0
  1864. /package/{.agent-src → dist/agent-src}/skills/throughput-vs-morale-tradeoff/SKILL.md +0 -0
  1865. /package/{.agent-src → dist/agent-src}/skills/token-optimizer/SKILL.md +0 -0
  1866. /package/{.agent-src → dist/agent-src}/skills/traefik/SKILL.md +0 -0
  1867. /package/{.agent-src → dist/agent-src}/skills/ui-component-architect/SKILL.md +0 -0
  1868. /package/{.agent-src → dist/agent-src}/skills/unit-economics-modeling/SKILL.md +0 -0
  1869. /package/{.agent-src → dist/agent-src}/skills/universal-project-analysis/SKILL.md +0 -0
  1870. /package/{.agent-src → dist/agent-src}/skills/using-git-worktrees/SKILL.md +0 -0
  1871. /package/{.agent-src → dist/agent-src}/skills/validate-feature-fit/SKILL.md +0 -0
  1872. /package/{.agent-src → dist/agent-src}/skills/verify-completion-evidence/SKILL.md +0 -0
  1873. /package/{.agent-src → dist/agent-src}/skills/video-director/SKILL.md +0 -0
  1874. /package/{.agent-src → dist/agent-src}/skills/vision-articulation/SKILL.md +0 -0
  1875. /package/{.agent-src → dist/agent-src}/skills/voc-extract/SKILL.md +0 -0
  1876. /package/{.agent-src → dist/agent-src}/skills/voice-and-tone-design/SKILL.md +0 -0
  1877. /package/{.agent-src → dist/agent-src}/templates/agent-settings.md +0 -0
  1878. /package/{.agent-src → dist/agent-src}/templates/agents/.gitattributes.fragment +0 -0
  1879. /package/{.agent-src → dist/agent-src}/templates/agents/memory/architecture-decisions.example.yml +0 -0
  1880. /package/{.agent-src → dist/agent-src}/templates/agents/memory/domain-invariants.example.yml +0 -0
  1881. /package/{.agent-src → dist/agent-src}/templates/agents/memory/historical-patterns.example.yml +0 -0
  1882. /package/{.agent-src → dist/agent-src}/templates/agents/memory/incident-learnings.example.yml +0 -0
  1883. /package/{.agent-src → dist/agent-src}/templates/agents/memory/ownership.example.yml +0 -0
  1884. /package/{.agent-src → dist/agent-src}/templates/agents/memory/product-rules.example.yml +0 -0
  1885. /package/{.agent-src → dist/agent-src}/templates/contexts/auth-model.md +0 -0
  1886. /package/{.agent-src → dist/agent-src}/templates/contexts/data-sensitivity.md +0 -0
  1887. /package/{.agent-src → dist/agent-src}/templates/contexts/deployment-order.md +0 -0
  1888. /package/{.agent-src → dist/agent-src}/templates/contexts/observability.md +0 -0
  1889. /package/{.agent-src → dist/agent-src}/templates/contexts/tenant-boundaries.md +0 -0
  1890. /package/{.agent-src → dist/agent-src}/templates/contexts.md +0 -0
  1891. /package/{.agent-src → dist/agent-src}/templates/features.md +0 -0
  1892. /package/{.agent-src → dist/agent-src}/templates/github-workflows/memory-hygiene.yml +0 -0
  1893. /package/{.agent-src → dist/agent-src}/templates/github-workflows/pr-risk-review.yml +0 -0
  1894. /package/{.agent-src → dist/agent-src}/templates/github-workflows/roadmap-progress-check.yml +0 -0
  1895. /package/{.agent-src → dist/agent-src}/templates/overrides/command.md +0 -0
  1896. /package/{.agent-src → dist/agent-src}/templates/overrides/guideline.md +0 -0
  1897. /package/{.agent-src → dist/agent-src}/templates/overrides/rule.md +0 -0
  1898. /package/{.agent-src → dist/agent-src}/templates/overrides/skill.md +0 -0
  1899. /package/{.agent-src → dist/agent-src}/templates/overrides/template.md +0 -0
  1900. /package/{.agent-src → dist/agent-src}/templates/roadmaps.md +0 -0
  1901. /package/{.agent-src → dist/agent-src}/templates/scripts/README.md +0 -0
  1902. /package/{.agent-src → dist/agent-src}/templates/scripts/check_memory.py +0 -0
  1903. /package/{.agent-src → dist/agent-src}/templates/scripts/check_memory_proposal.py +0 -0
  1904. /package/{.agent-src → dist/agent-src}/templates/scripts/historical-bug-patterns.example.yml +0 -0
  1905. /package/{.agent-src → dist/agent-src}/templates/scripts/implement_ticket/__init__.py +0 -0
  1906. /package/{.agent-src → dist/agent-src}/templates/scripts/implement_ticket/__main__.py +0 -0
  1907. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_hash.py +0 -0
  1908. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_lookup.py +0 -0
  1909. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_report.py +0 -0
  1910. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_signal.py +0 -0
  1911. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_status.py +0 -0
  1912. /package/{.agent-src → dist/agent-src}/templates/scripts/ownership-map.example.yml +0 -0
  1913. /package/{.agent-src → dist/agent-src}/templates/scripts/pr-risk-config.example.yml +0 -0
  1914. /package/{.agent-src → dist/agent-src}/templates/scripts/pr_review_routing.py +0 -0
  1915. /package/{.agent-src → dist/agent-src}/templates/scripts/pr_risk_review.py +0 -0
  1916. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/__init__.py +0 -0
  1917. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/aggregator.py +0 -0
  1918. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/boundary.py +0 -0
  1919. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/engagement.py +0 -0
  1920. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/report_renderer.py +0 -0
  1921. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/settings.py +0 -0
  1922. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry_record.py +0 -0
  1923. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry_report.py +0 -0
  1924. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry_status.py +0 -0
  1925. /package/{.agent-src → dist/agent-src}/templates/scripts/tier_usage_report.py +0 -0
  1926. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/__init__.py +0 -0
  1927. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/__main__.py +0 -0
  1928. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/_lib/__init__.py +0 -0
  1929. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/_lib/agent_settings.py +0 -0
  1930. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/_lib/user_global_paths.py +0 -0
  1931. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/cli.py +0 -0
  1932. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/cli_args.py +0 -0
  1933. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/delivery_state.py +0 -0
  1934. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/__init__.py +0 -0
  1935. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/__init__.py +0 -0
  1936. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/analyze.py +0 -0
  1937. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/implement.py +0 -0
  1938. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/memory.py +0 -0
  1939. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/plan.py +0 -0
  1940. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/refine.py +0 -0
  1941. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/report.py +0 -0
  1942. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/test.py +0 -0
  1943. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/verify.py +0 -0
  1944. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/__init__.py +0 -0
  1945. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/contract.py +0 -0
  1946. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/stitch.py +0 -0
  1947. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/ui.py +0 -0
  1948. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/__init__.py +0 -0
  1949. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/_passthrough.py +0 -0
  1950. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/apply.py +0 -0
  1951. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/audit.py +0 -0
  1952. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/design.py +0 -0
  1953. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/__init__.py +0 -0
  1954. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/_skipped.py +0 -0
  1955. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/apply.py +0 -0
  1956. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/refine.py +0 -0
  1957. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/report.py +0 -0
  1958. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/test.py +0 -0
  1959. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/dispatcher.py +0 -0
  1960. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/emitters.py +0 -0
  1961. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/errors.py +0 -0
  1962. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hook_bootstrap.py +0 -0
  1963. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/__init__.py +0 -0
  1964. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/__init__.py +0 -0
  1965. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/_chat_history_base.py +0 -0
  1966. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/chat_history_append.py +0 -0
  1967. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/chat_history_halt_append.py +0 -0
  1968. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/decision_gate.py +0 -0
  1969. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/decision_trace.py +0 -0
  1970. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/directive_set_guard.py +0 -0
  1971. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/halt_surface_audit.py +0 -0
  1972. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/memory_visibility.py +0 -0
  1973. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/state_shape_validation.py +0 -0
  1974. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/trace.py +0 -0
  1975. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/context.py +0 -0
  1976. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/events.py +0 -0
  1977. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/exceptions.py +0 -0
  1978. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/registry.py +0 -0
  1979. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/runner.py +0 -0
  1980. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/settings.py +0 -0
  1981. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/input_builders.py +0 -0
  1982. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/intent/__init__.py +0 -0
  1983. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/intent/classify.py +0 -0
  1984. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/migration/__init__.py +0 -0
  1985. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/migration/v0_to_v1.py +0 -0
  1986. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/persona_policy.py +0 -0
  1987. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/__init__.py +0 -0
  1988. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/diff.py +0 -0
  1989. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/file.py +0 -0
  1990. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/prompt.py +0 -0
  1991. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/__init__.py +0 -0
  1992. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/confidence.py +0 -0
  1993. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/decision_engine.py +0 -0
  1994. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/decision_trace.py +0 -0
  1995. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/memory_visibility.py +0 -0
  1996. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/stack/__init__.py +0 -0
  1997. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/stack/detect.py +0 -0
  1998. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/state.py +0 -0
  1999. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/state_io.py +0 -0
  2000. /package/{.agent-src → dist/agent-src}/templates/skill-archive-note.md +0 -0
  2001. /package/{.agent-src → dist/agent-src}/templates/skill.md +0 -0
  2002. /package/{.agent-src → dist/agent-src}/user-types/_template/user-type.md +0 -0
  2003. /package/{.agent-src → dist/agent-src}/user-types/galabau-field-crew.md +0 -0
  2004. /package/{.agent-src → dist/agent-src}/user-types/metalworking-shop.md +0 -0
  2005. /package/{.agent-src → dist/agent-src}/user-types/truck-driver.md +0 -0
  2006. /package/{config → src/config}/discovery/session-profiles.yml +0 -0
  2007. /package/{config → src/config}/discovery/unassigned-artefacts.yml +0 -0
  2008. /package/{config → src/config}/gitignore-block.txt +0 -0
  2009. /package/{config → src/config}/profiles/balanced.ini +0 -0
  2010. /package/{config → src/config}/profiles/full.ini +0 -0
  2011. /package/{config → src/config}/profiles/minimal.ini +0 -0
  2012. /package/{scripts → src/scripts}/_archive/_backfill_skill_domains.py +0 -0
  2013. /package/{scripts → src/scripts}/_archive/_phase2_shim_helper.py +0 -0
  2014. /package/{scripts → src/scripts}/_archive/_pilot_council_question.py +0 -0
  2015. /package/{scripts → src/scripts}/_cli/__init__.py +0 -0
  2016. /package/{scripts → src/scripts}/_cli/cmd_explain.py +0 -0
  2017. /package/{scripts → src/scripts}/_cli/cmd_prune.py +0 -0
  2018. /package/{scripts → src/scripts}/_cli/cmd_settings_check.py +0 -0
  2019. /package/{scripts → src/scripts}/_cli/cmd_sync.py +0 -0
  2020. /package/{scripts → src/scripts}/_cli/cmd_uninstall.py +0 -0
  2021. /package/{scripts → src/scripts}/_cli/cmd_validate.py +0 -0
  2022. /package/{scripts → src/scripts}/_cli/explain_last/__init__.py +0 -0
  2023. /package/{scripts → src/scripts}/_cli/explain_last/assumptions.py +0 -0
  2024. /package/{scripts → src/scripts}/_cli/explain_last/council.py +0 -0
  2025. /package/{scripts → src/scripts}/_cli/explain_last/halt.py +0 -0
  2026. /package/{scripts → src/scripts}/_cli/explain_last/inputs.py +0 -0
  2027. /package/{scripts → src/scripts}/_cli/explain_last/memory.py +0 -0
  2028. /package/{scripts → src/scripts}/_cli/explain_last/provider.py +0 -0
  2029. /package/{scripts → src/scripts}/_cli/explain_last/render.py +0 -0
  2030. /package/{scripts → src/scripts}/_cli/explain_last/route.py +0 -0
  2031. /package/{scripts → src/scripts}/_cli/explain_last/scrubber.py +0 -0
  2032. /package/{scripts → src/scripts}/_cli/explain_last/sections/__init__.py +0 -0
  2033. /package/{scripts → src/scripts}/_cli/explain_last/sections/assumptions.py +0 -0
  2034. /package/{scripts → src/scripts}/_cli/explain_last/sections/council.py +0 -0
  2035. /package/{scripts → src/scripts}/_cli/explain_last/sections/halt.py +0 -0
  2036. /package/{scripts → src/scripts}/_cli/explain_last/sections/header.py +0 -0
  2037. /package/{scripts → src/scripts}/_cli/explain_last/sections/inputs.py +0 -0
  2038. /package/{scripts → src/scripts}/_cli/explain_last/sections/memory.py +0 -0
  2039. /package/{scripts → src/scripts}/_cli/explain_last/sections/pack.py +0 -0
  2040. /package/{scripts → src/scripts}/_cli/explain_last/sections/provider.py +0 -0
  2041. /package/{scripts → src/scripts}/_cli/explain_last/sections/route.py +0 -0
  2042. /package/{scripts → src/scripts}/_cli/explain_last/state_loader.py +0 -0
  2043. /package/{scripts → src/scripts}/_emit_domain_table.py +0 -0
  2044. /package/{scripts → src/scripts}/_lib/__init__.py +0 -0
  2045. /package/{scripts → src/scripts}/_lib/agent_settings.py +0 -0
  2046. /package/{scripts → src/scripts}/_lib/agents_overlay.py +0 -0
  2047. /package/{scripts → src/scripts}/_lib/bench_ab_scoring.py +0 -0
  2048. /package/{scripts → src/scripts}/_lib/bench_cost.py +0 -0
  2049. /package/{scripts → src/scripts}/_lib/bench_quality.py +0 -0
  2050. /package/{scripts → src/scripts}/_lib/bench_report.py +0 -0
  2051. /package/{scripts → src/scripts}/_lib/bench_telegraph.py +0 -0
  2052. /package/{scripts → src/scripts}/_lib/bench_telegraph_report.py +0 -0
  2053. /package/{scripts → src/scripts}/_lib/fs_atomic.py +0 -0
  2054. /package/{scripts → src/scripts}/_lib/installed_tools.py +0 -0
  2055. /package/{scripts → src/scripts}/_lib/json_pointers.py +0 -0
  2056. /package/{scripts → src/scripts}/_lib/linked_projects.py +0 -0
  2057. /package/{scripts → src/scripts}/_lib/module_detection.py +0 -0
  2058. /package/{scripts → src/scripts}/_lib/pin_resolver.py +0 -0
  2059. /package/{scripts → src/scripts}/_lib/script_output.py +0 -0
  2060. /package/{scripts → src/scripts}/_lib/token_count.py +0 -0
  2061. /package/{scripts → src/scripts}/_lib/update_check.py +0 -0
  2062. /package/{scripts → src/scripts}/_lib/user_global_paths.py +0 -0
  2063. /package/{scripts → src/scripts}/_tmp_scan_framework_leakage.py +0 -0
  2064. /package/{scripts → src/scripts}/adr/regenerate_index.py +0 -0
  2065. /package/{scripts/ai-video/lib/fixtures/kling → src/scripts/ai-video/lib/fixtures/comfyui}/scene-0001.mp4 +0 -0
  2066. /package/{scripts → src/scripts}/ai-video/lib/fixtures/gemini-veo/scene-0001.mp4 +0 -0
  2067. /package/{scripts → src/scripts}/ai-video/lib/fixtures/higgsfield/scene-0001.mp4 +0 -0
  2068. /package/{scripts → src/scripts}/ai-video/lib/fixtures/openai-images/scene-0001.png +0 -0
  2069. /package/{scripts → src/scripts}/ai-video/lib/fixtures/sora/scene-0001.mp4 +0 -0
  2070. /package/{scripts → src/scripts}/ai-video/lib/operator-pick.sh +0 -0
  2071. /package/{scripts → src/scripts}/ai-video/lib/parse-blueprint.sh +0 -0
  2072. /package/{scripts → src/scripts}/ai-video/lib/probe-audio.sh +0 -0
  2073. /package/{scripts → src/scripts}/ai-video/lib/redact.sh +0 -0
  2074. /package/{scripts → src/scripts}/ai_council/__init__.py +0 -0
  2075. /package/{scripts → src/scripts}/ai_council/_default_prices.py +0 -0
  2076. /package/{scripts → src/scripts}/ai_council/airgap.py +0 -0
  2077. /package/{scripts → src/scripts}/ai_council/budget_guard.py +0 -0
  2078. /package/{scripts → src/scripts}/ai_council/bundler.py +0 -0
  2079. /package/{scripts → src/scripts}/ai_council/cli_hints.py +0 -0
  2080. /package/{scripts → src/scripts}/ai_council/confidence_gate.py +0 -0
  2081. /package/{scripts → src/scripts}/ai_council/config.py +0 -0
  2082. /package/{scripts → src/scripts}/ai_council/consensus.py +0 -0
  2083. /package/{scripts → src/scripts}/ai_council/learn_low_impact_preview.py +0 -0
  2084. /package/{scripts → src/scripts}/ai_council/low_impact.py +0 -0
  2085. /package/{scripts → src/scripts}/ai_council/low_impact_corpus.py +0 -0
  2086. /package/{scripts → src/scripts}/ai_council/low_impact_intake.py +0 -0
  2087. /package/{scripts → src/scripts}/ai_council/modes.py +0 -0
  2088. /package/{scripts → src/scripts}/ai_council/necessity.py +0 -0
  2089. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/README.md +0 -0
  2090. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_add_quiet.py +0 -0
  2091. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_inject_quiet_flag.py +0 -0
  2092. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_measure_v2.sh +0 -0
  2093. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_measure_verbosity.sh +0 -0
  2094. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_per_task.sh +0 -0
  2095. /package/{scripts → src/scripts}/ai_council/orchestrator.py +0 -0
  2096. /package/{scripts → src/scripts}/ai_council/probation_gate.py +0 -0
  2097. /package/{scripts → src/scripts}/ai_council/project_context.py +0 -0
  2098. /package/{scripts → src/scripts}/ai_council/prompts.py +0 -0
  2099. /package/{scripts → src/scripts}/ai_council/redact_low_impact_entry.py +0 -0
  2100. /package/{scripts → src/scripts}/ai_council/replay.py +0 -0
  2101. /package/{scripts → src/scripts}/ai_council/shadow_dispatch.py +0 -0
  2102. /package/{scripts → src/scripts}/ai_council/solo_dispatch.py +0 -0
  2103. /package/{scripts → src/scripts}/audit_skill_descriptions.py +0 -0
  2104. /package/{scripts → src/scripts}/bootstrap.sh +0 -0
  2105. /package/{scripts → src/scripts}/chat_history.py +0 -0
  2106. /package/{scripts → src/scripts}/check_bite_sized_granularity.py +0 -0
  2107. /package/{scripts → src/scripts}/check_council_layout.py +0 -0
  2108. /package/{scripts → src/scripts}/check_iron_law_prominence.py +0 -0
  2109. /package/{scripts → src/scripts}/check_kernel_rule_bundle.py +0 -0
  2110. /package/{scripts → src/scripts}/check_md_language.py +0 -0
  2111. /package/{scripts → src/scripts}/check_memory.py +0 -0
  2112. /package/{scripts → src/scripts}/check_memory_proposal.py +0 -0
  2113. /package/{scripts → src/scripts}/check_no_local_settings_committed.py +0 -0
  2114. /package/{scripts → src/scripts}/check_proposal.py +0 -0
  2115. /package/{scripts → src/scripts}/check_release_trunk_sync.py +0 -0
  2116. /package/{scripts → src/scripts}/ci_status.py +0 -0
  2117. /package/{scripts → src/scripts}/ci_summary.py +0 -0
  2118. /package/{scripts → src/scripts}/cleanup_other_scope.sh +0 -0
  2119. /package/{scripts → src/scripts}/command_suggester/__init__.py +0 -0
  2120. /package/{scripts → src/scripts}/command_suggester/cooldown.py +0 -0
  2121. /package/{scripts → src/scripts}/command_suggester/loader.py +0 -0
  2122. /package/{scripts → src/scripts}/command_suggester/match.py +0 -0
  2123. /package/{scripts → src/scripts}/command_suggester/rank.py +0 -0
  2124. /package/{scripts → src/scripts}/command_suggester/render.py +0 -0
  2125. /package/{scripts → src/scripts}/command_suggester/sanitize.py +0 -0
  2126. /package/{scripts → src/scripts}/command_suggester/settings.py +0 -0
  2127. /package/{scripts → src/scripts}/command_suggester/types.py +0 -0
  2128. /package/{scripts → src/scripts}/condense.sh +0 -0
  2129. /package/{scripts → src/scripts}/config/__init__.py +0 -0
  2130. /package/{scripts → src/scripts}/config/presets.py +0 -0
  2131. /package/{scripts → src/scripts}/context_hygiene_hook.py +0 -0
  2132. /package/{scripts → src/scripts}/cost/budget.mjs +0 -0
  2133. /package/{scripts → src/scripts}/cost/preflight.mjs +0 -0
  2134. /package/{scripts → src/scripts}/cost/track.mjs +0 -0
  2135. /package/{scripts → src/scripts}/council_prune.py +0 -0
  2136. /package/{scripts → src/scripts}/count_token_optimizer_usage.sh +0 -0
  2137. /package/{scripts → src/scripts}/expected_perms.json +0 -0
  2138. /package/{scripts → src/scripts}/first-run.sh +0 -0
  2139. /package/{scripts → src/scripts}/ghostwriter_fixture_allowlist.txt +0 -0
  2140. /package/{scripts → src/scripts}/hermetic-install.sh +0 -0
  2141. /package/{scripts → src/scripts}/hooks/__init__.py +0 -0
  2142. /package/{scripts → src/scripts}/hooks/augment-chat-history.sh +0 -0
  2143. /package/{scripts → src/scripts}/hooks/augment-context-hygiene.sh +0 -0
  2144. /package/{scripts → src/scripts}/hooks/augment-dispatcher.sh +0 -0
  2145. /package/{scripts → src/scripts}/hooks/augment-onboarding-gate.sh +0 -0
  2146. /package/{scripts → src/scripts}/hooks/augment-roadmap-progress.sh +0 -0
  2147. /package/{scripts → src/scripts}/hooks/cline-dispatcher.sh +0 -0
  2148. /package/{scripts → src/scripts}/hooks/cowork-dispatcher.sh +0 -0
  2149. /package/{scripts → src/scripts}/hooks/cursor-dispatcher.sh +0 -0
  2150. /package/{scripts → src/scripts}/hooks/dispatch_issues.py +0 -0
  2151. /package/{scripts → src/scripts}/hooks/envelope.py +0 -0
  2152. /package/{scripts → src/scripts}/hooks/gemini-dispatcher.sh +0 -0
  2153. /package/{scripts → src/scripts}/hooks/state_io.py +0 -0
  2154. /package/{scripts → src/scripts}/hooks/windsurf-dispatcher.sh +0 -0
  2155. /package/{scripts → src/scripts}/install_anthropic_key.sh +0 -0
  2156. /package/{scripts → src/scripts}/install_openai_key.sh +0 -0
  2157. /package/{scripts → src/scripts}/lint_global_paths.py +0 -0
  2158. /package/{scripts → src/scripts}/lint_readme_jargon.py +0 -0
  2159. /package/{scripts → src/scripts}/lint_readme_size.py +0 -0
  2160. /package/{scripts → src/scripts}/mcp_render.py +0 -0
  2161. /package/{scripts → src/scripts}/mcp_server/__main__.py +0 -0
  2162. /package/{scripts → src/scripts}/mcp_server/catalog.py +0 -0
  2163. /package/{scripts → src/scripts}/mcp_server/metadata.py +0 -0
  2164. /package/{scripts → src/scripts}/mcp_server/requirements.txt +0 -0
  2165. /package/{scripts → src/scripts}/mcp_server/server.py +0 -0
  2166. /package/{scripts → src/scripts}/mcp_server/telemetry.py +0 -0
  2167. /package/{scripts → src/scripts}/mcp_setup.sh +0 -0
  2168. /package/{scripts → src/scripts}/mcp_telemetry_health.py +0 -0
  2169. /package/{scripts → src/scripts}/mcp_telemetry_query.py +0 -0
  2170. /package/{scripts → src/scripts}/mcp_telemetry_store.py +0 -0
  2171. /package/{scripts → src/scripts}/memory_hash.py +0 -0
  2172. /package/{scripts → src/scripts}/memory_lookup.py +0 -0
  2173. /package/{scripts → src/scripts}/memory_report.py +0 -0
  2174. /package/{scripts → src/scripts}/memory_signal.py +0 -0
  2175. /package/{scripts → src/scripts}/memory_status.py +0 -0
  2176. /package/{scripts → src/scripts}/minimal_safe_diff_hook.py +0 -0
  2177. /package/{scripts → src/scripts}/onboarding_gate_hook.py +0 -0
  2178. /package/{scripts → src/scripts}/prediction-pool/adapters/_schema.md +0 -0
  2179. /package/{scripts → src/scripts}/prediction-pool/adapters/kicktipp.yml +0 -0
  2180. /package/{scripts → src/scripts}/prediction-pool/poisson_sim.py +0 -0
  2181. /package/{scripts → src/scripts}/prediction-pool/pool_winsim.py +0 -0
  2182. /package/{scripts → src/scripts}/prediction-pool/score_ev.py +0 -0
  2183. /package/{scripts → src/scripts}/prepack-check.mjs +0 -0
  2184. /package/{scripts → src/scripts}/probe_skill_registration.py +0 -0
  2185. /package/{scripts → src/scripts}/propose_modules_config.py +0 -0
  2186. /package/{scripts → src/scripts}/readme_linter.py +0 -0
  2187. /package/{scripts → src/scripts}/redact_hook_capture.py +0 -0
  2188. /package/{scripts → src/scripts}/requirements-evals.txt +0 -0
  2189. /package/{scripts → src/scripts}/runtime_dispatcher.py +0 -0
  2190. /package/{scripts → src/scripts}/runtime_handler.py +0 -0
  2191. /package/{scripts → src/scripts}/schemas/agent-settings.schema.json +0 -0
  2192. /package/{scripts → src/scripts}/schemas/persona.schema.json +0 -0
  2193. /package/{scripts → src/scripts}/schemas/skill.schema.json +0 -0
  2194. /package/{scripts → src/scripts}/schemas/user-type-axis.schema.json +0 -0
  2195. /package/{scripts → src/scripts}/schemas/user-type.schema.json +0 -0
  2196. /package/{scripts → src/scripts}/setup_eval_venv.sh +0 -0
  2197. /package/{scripts → src/scripts}/skill_tools/__init__.py +0 -0
  2198. /package/{scripts → src/scripts}/sync_yaml_rt.py +0 -0
  2199. /package/{scripts → src/scripts}/tool_registry.py +0 -0
  2200. /package/{scripts → src/scripts}/tools/__init__.py +0 -0
  2201. /package/{scripts → src/scripts}/tools/adapter_errors.py +0 -0
  2202. /package/{scripts → src/scripts}/tools/base_adapter.py +0 -0
  2203. /package/{scripts → src/scripts}/tools/github_adapter.py +0 -0
  2204. /package/{scripts → src/scripts}/tools/jira_adapter.py +0 -0
  2205. /package/{scripts → src/scripts}/update-github-metadata.sh +0 -0
  2206. /package/{scripts → src/scripts}/validate_safe_paths.py +0 -0
  2207. /package/{scripts → src/scripts}/validate_telegraph_carveouts.py +0 -0
  2208. /package/{scripts → src/scripts}/verify_before_complete_hook.py +0 -0
  2209. /package/{templates → src/templates}/agent-config-wrapper.sh +0 -0
  2210. /package/{templates → src/templates}/agent-user.md +0 -0
  2211. /package/{templates → src/templates}/agent-user.yml +0 -0
  2212. /package/{templates → src/templates}/claude_desktop_config.json.template +0 -0
  2213. /package/{templates → src/templates}/consumer-settings/ONBOARDING.md +0 -0
  2214. /package/{templates → src/templates}/consumer-settings/README.md +0 -0
  2215. /package/{templates → src/templates}/consumer-settings/augment-cli-hooks.json +0 -0
  2216. /package/{templates → src/templates}/consumer-settings/augment-settings.json +0 -0
  2217. /package/{templates → src/templates}/consumer-settings/claude-settings.json +0 -0
  2218. /package/{templates → src/templates}/consumer-settings/copilot-settings.json +0 -0
  2219. /package/{templates → src/templates}/cursor-rule.mdc.j2 +0 -0
  2220. /package/{templates → src/templates}/marketing-copy.yml +0 -0
  2221. /package/{templates → src/templates}/minimal/.agent-settings.yml +0 -0
  2222. /package/{templates → src/templates}/minimal/agents-overrides-readme.md +0 -0
  2223. /package/{templates → src/templates}/minimal/overrides-gitkeep +0 -0
  2224. /package/{templates → src/templates}/windsurf-rule.md.j2 +0 -0
@@ -1,2544 +0,0 @@
1
- #!/usr/bin/env python3
2
- """Council CLI — `./agent-config council:{estimate,run,render}`.
3
-
4
- Wraps `scripts.ai_council.orchestrator` for non-interactive callers.
5
- Subcommands:
6
-
7
- estimate Bundle + estimate per-member cost (no API call, no spend).
8
- run Same + estimate, then call the council. Requires --confirm.
9
- render Re-render a saved responses JSON to the markdown report.
10
-
11
- `./agent-config` is non-interactive by contract — the cost gate is an
12
- explicit `--confirm` flag, never an interactive y/n.
13
- """
14
- from __future__ import annotations
15
-
16
- import argparse
17
- import json
18
- import sys
19
- from dataclasses import asdict
20
- from pathlib import Path
21
- try: # invocation-agnostic import (repo-root-on-path vs scripts-on-path)
22
- from scripts._lib.agent_settings import project_settings_path
23
- except ModuleNotFoundError: # pragma: no cover
24
- from _lib.agent_settings import project_settings_path
25
- from typing import Any
26
-
27
- import yaml
28
-
29
- REPO_ROOT = Path(__file__).resolve().parents[1]
30
- SETTINGS_FILE = project_settings_path(REPO_ROOT)
31
- AI_COUNCIL_FILE = REPO_ROOT / "agents" / "settings" / ".ai-council.yml"
32
-
33
- # Canonical output dirs per ai-council § "Output path convention".
34
- # Enforced at write-time by `_validate_council_output_path` so shell-side
35
- # `>` redirects and forgetful agents can't strand artefacts at agents/ root.
36
- COUNCIL_CANONICAL_DIRS: dict[str, str] = {
37
- "responses": "agents/runtime/council/responses",
38
- "sessions": "agents/runtime/council/sessions",
39
- "questions": "agents/runtime/council/questions",
40
- }
41
-
42
-
43
- def _validate_council_output_path(
44
- path_str: str, *, kind: str, subcommand: str,
45
- ) -> Path:
46
- """Reject non-canonical --output paths at write-time.
47
-
48
- `kind` selects the expected canonical dir (`responses`, `sessions`,
49
- `questions`). Raises `argparse.ArgumentTypeError` on violation so
50
- `main()` surfaces a clean ❌ message and returns 2.
51
- """
52
- expected_rel = COUNCIL_CANONICAL_DIRS[kind]
53
- expected_abs = (REPO_ROOT / expected_rel).resolve()
54
- p = Path(path_str)
55
- target = p if p.is_absolute() else (REPO_ROOT / p)
56
- target_resolved = target.resolve()
57
- try:
58
- target_resolved.relative_to(expected_abs)
59
- except ValueError as exc:
60
- raise argparse.ArgumentTypeError(
61
- f"council:{subcommand} --output must live under "
62
- f"{expected_rel}/ (per ai-council § Output path convention); "
63
- f"got {path_str!r}."
64
- ) from exc
65
- return p
66
-
67
- sys.path.insert(0, str(REPO_ROOT))
68
-
69
- from scripts.ai_council.bundler import ( # noqa: E402
70
- BundleTooLarge, bundle_prompt, bundle_roadmap,
71
- )
72
- from scripts.ai_council.clients import ( # noqa: E402
73
- DEFAULT_MAX_TOKENS, UNLIMITED_TOKENS_FALLBACK,
74
- AnthropicClient, AnthropicCliClient, CliClient, CliClientError,
75
- CouncilResponse, ExternalAIClient, GeminiClient, GeminiCliClient,
76
- ManualClient, OpenAIClient, OpenAICliClient, PerplexityClient,
77
- PerplexityCliClient, XAIClient, XAICliClient,
78
- load_anthropic_key, load_cli_call_counts, load_openai_key,
79
- quota_summary_line, reset_cli_call_counts,
80
- )
81
- from scripts.ai_council.advisors import ( # noqa: E402
82
- AdvisorPlan, build_persona_labels, plan_advisor_swap,
83
- )
84
- from scripts.ai_council.cli_hints import format_install_hints # noqa: E402
85
- from scripts.ai_council.config import ( # noqa: E402
86
- AdvisorConfig, CouncilConfig, CouncilConfigError,
87
- load_council_config, resolve_api_key,
88
- )
89
- from scripts.ai_council.solo_dispatch import ( # noqa: E402
90
- AuthCache, select_solo_member,
91
- )
92
- from scripts.ai_council.modes import ( # noqa: E402
93
- InvalidModeError, resolve_mode,
94
- )
95
- from scripts.ai_council.events_log import append_event # noqa: E402
96
- from scripts.ai_council.necessity import ( # noqa: E402
97
- ClassificationResult, SizeFitVerdict, classify_necessity,
98
- classify_size_fit, downgrade_message, educate_message,
99
- )
100
- from scripts.ai_council.orchestrator import ( # noqa: E402
101
- ConsensusResult,
102
- CostBudget, CouncilQuestion, DebateCapExceeded, DebateCheckpoint,
103
- DebateCostEstimate,
104
- PeerReviewResult, consult, estimate, estimate_debate_cost, render,
105
- run_consensus_scoring, run_debate, run_peer_review,
106
- )
107
- from scripts.ai_council.pricing import ( # noqa: E402
108
- PriceTable, estimate_cost, load_prices,
109
- )
110
- from scripts.ai_council.project_context import detect_project_context # noqa: E402
111
- from scripts.ai_council.replay import ( # noqa: E402
112
- DecisionReplayInputs, render_decision_replay,
113
- )
114
-
115
- SCHEMA_VERSION = 1
116
-
117
- #: Provider names accepted under `mode=api`. Mirrors the routing table
118
- #: in ``_construct_api_member``; both must stay in sync.
119
- _API_PROVIDERS = frozenset({"anthropic", "openai", "gemini", "xai", "perplexity"})
120
-
121
- #: Provider names with a wired ``mode=cli`` subclass. Mirrors the
122
- #: routing table in ``_construct_cli_member``; both must stay in sync.
123
- #: Phase 2 ships ``anthropic``; Phase 3 adds ``openai`` + ``gemini``;
124
- #: Phase 4 adds ``xai`` + ``perplexity`` (community CLIs, no
125
- #: subscription savings — they still consume the API key and remain
126
- #: ``billable=True``).
127
- _CLI_PROVIDERS = frozenset({"anthropic", "openai", "gemini", "xai", "perplexity"})
128
-
129
-
130
- class CouncilDisabledError(RuntimeError):
131
- """Raised when ai_council.enabled is false or no member is enabled."""
132
-
133
-
134
- def load_settings(
135
- path: Path = SETTINGS_FILE,
136
- *,
137
- ai_council_path: Path = AI_COUNCIL_FILE,
138
- ) -> dict[str, Any]:
139
- """Load merged settings via the centralized loader.
140
-
141
- road-to-portable-dev-preferences P3 migration: tolerance contract
142
- (missing file / malformed YAML / no PyYAML) is handled uniformly by
143
- ``load_agent_settings``. ``ai_council.*`` keys are not whitelisted,
144
- so the project file remains authoritative for council config.
145
-
146
- Step-2 council-redesign overlay: when ``agents/settings/.ai-council.yml``
147
- exists it is the single source of truth — the validated config is
148
- synthesized back into ``settings['ai_council']`` and wins over any
149
- legacy block in ``.agent-settings.yml``. The pre-2 path stays alive
150
- so the migration breadcrumb in ``.agent-settings.yml`` can ship
151
- independently.
152
- """
153
- from scripts._lib.agent_settings import load_agent_settings
154
- settings = load_agent_settings(project_path=path)
155
- if ai_council_path.exists():
156
- cfg = load_council_config(ai_council_path)
157
- settings["ai_council"] = _synthesize_ai_council_block(cfg)
158
- return settings
159
-
160
-
161
- def _synthesize_ai_council_block(cfg: CouncilConfig) -> dict[str, Any]:
162
- """Project a validated ``CouncilConfig`` onto the legacy dict shape.
163
-
164
- ``build_members`` and the ``_resolve_*`` helpers read the legacy
165
- ``ai_council.*`` keys — keeping the projection identical means no
166
- downstream caller changes. ``api_key_ref`` is carried through; raw
167
- keys are never resolved here (resolution is lazy, per enabled
168
- member, inside ``_construct_api_member``).
169
- """
170
- members: dict[str, dict[str, Any]] = {}
171
- for name, m in cfg.members.items():
172
- entry: dict[str, Any] = {"enabled": m.enabled, "model": m.model}
173
- if m.api_key_ref is not None:
174
- entry["api_key_ref"] = m.api_key_ref
175
- if m.mode is not None:
176
- entry["mode"] = m.mode
177
- if m.binary is not None:
178
- entry["binary"] = m.binary
179
- if m.model_ladder:
180
- entry["model_ladder"] = list(m.model_ladder)
181
- members[name] = entry
182
- advisors: dict[str, dict[str, Any]] = {}
183
- for name, a in cfg.advisors.items():
184
- entry = {
185
- "enabled": a.enabled,
186
- "member": a.member,
187
- "persona": a.persona,
188
- }
189
- if a.model is not None:
190
- entry["model"] = a.model
191
- advisors[name] = entry
192
- return {
193
- "enabled": cfg.enabled,
194
- "mode": cfg.defaults.mode,
195
- "min_rounds": cfg.defaults.min_rounds,
196
- "deep_min_rounds": cfg.defaults.deep_min_rounds,
197
- "max_output_tokens": cfg.defaults.max_output_tokens,
198
- "session_retention_days": cfg.defaults.session_retention_days,
199
- "debate_max_rounds": cfg.defaults.debate_max_rounds,
200
- "cost_budget": {
201
- "max_input_tokens": cfg.cost_budget.max_input_tokens,
202
- "max_output_tokens": cfg.cost_budget.max_output_tokens,
203
- "max_calls": cfg.cost_budget.max_calls,
204
- "max_total_usd": cfg.cost_budget.max_total_usd,
205
- },
206
- "consensus_scoring": {
207
- "enabled": cfg.consensus_scoring.enabled,
208
- "strong_threshold": cfg.consensus_scoring.strong_threshold,
209
- "minority_threshold": cfg.consensus_scoring.minority_threshold,
210
- "lenses": list(cfg.consensus_scoring.lenses),
211
- },
212
- "cli_call_budget": {
213
- "max_calls_per_day": dict(cfg.cli_call_budget.max_calls_per_day),
214
- "warn_at": cfg.cli_call_budget.warn_at,
215
- },
216
- "necessity_classifier": {
217
- "enabled": cfg.necessity_classifier.enabled,
218
- "mode": cfg.necessity_classifier.mode,
219
- "user_explicit_mode": cfg.necessity_classifier.user_explicit_mode,
220
- },
221
- "model_downgrade": {
222
- "enabled": cfg.model_downgrade.enabled,
223
- "auto_apply": cfg.model_downgrade.auto_apply,
224
- },
225
- "debate": {
226
- "max_cost_usd": cfg.debate.max_cost_usd,
227
- "cost_disclosure": {
228
- "mode": cfg.debate.cost_disclosure.mode,
229
- "threshold_usd": cfg.debate.cost_disclosure.threshold_usd,
230
- "show_per_member": cfg.debate.cost_disclosure.show_per_member,
231
- },
232
- },
233
- "lens_overrides": {
234
- "necessity_classifier_mode": dict(
235
- cfg.lens_overrides.necessity_classifier_mode,
236
- ),
237
- "necessity_classifier_user_explicit_mode": dict(
238
- cfg.lens_overrides.necessity_classifier_user_explicit_mode,
239
- ),
240
- "model_downgrade": {
241
- lens: {"enabled": md.enabled, "auto_apply": md.auto_apply}
242
- for lens, md in cfg.lens_overrides.model_downgrade.items()
243
- },
244
- "cost_disclosure": {
245
- lens: {
246
- "mode": cd.mode,
247
- "threshold_usd": cd.threshold_usd,
248
- "show_per_member": cd.show_per_member,
249
- }
250
- for lens, cd in cfg.lens_overrides.cost_disclosure.items()
251
- },
252
- },
253
- "members": members,
254
- "advisors": advisors,
255
- }
256
-
257
-
258
- def build_members(
259
- settings: dict[str, Any],
260
- *,
261
- invocation_mode: str | None = None,
262
- model_overrides: dict[str, str] | None = None,
263
- siblings_overrides: dict[str, list[str]] | None = None,
264
- skipped: list[dict[str, Any]] | None = None,
265
- ) -> list[ExternalAIClient]:
266
- """Construct enabled council members from settings.
267
-
268
- Honours `ai_council.enabled` (master switch) and per-member
269
- `enabled` flags. Raises `CouncilDisabledError` when the council is
270
- off or no member is wired up.
271
-
272
- `model_overrides` is a per-invocation `{member_name: model_id}`
273
- map that wins over the per-member `model` in settings. Members not
274
- listed fall back to the settings value, then the per-client default.
275
-
276
- `siblings_overrides` is a per-invocation `{member_name: [model, ...]}`
277
- map that fans the named provider out to multiple sibling models in
278
- one run (e.g. claude-sonnet-4-5 + claude-opus-4-1). Each model
279
- becomes its own billable member with independent cost tracking.
280
- Mutually exclusive with `model_overrides` for the same provider;
281
- requires `mode=api`; provider must be enabled in settings.
282
-
283
- `skipped` is an optional caller-owned list. When provided, each
284
- cli-mode member that fails to construct (binary missing) is appended
285
- as `{"member": <name>, "reason": "binary_missing", "detail": <msg>}`
286
- instead of crashing the loop. The skip is also surfaced on stderr
287
- as `[council] SKIP <name>: <detail>` so the run log carries it
288
- even when the caller passes ``None``. Phase 5 Step 2 contract:
289
- a missing CLI binary degrades that member only — never silently
290
- drops, never crashes the whole council unless every configured
291
- member ends up skipped.
292
- """
293
- ai = (settings.get("ai_council") or {}) if isinstance(settings, dict) else {}
294
- if not ai.get("enabled"):
295
- raise CouncilDisabledError(
296
- "ai_council.enabled is false in .agent-settings.yml — "
297
- "flip it on before invoking council:* commands."
298
- )
299
- members_cfg = ai.get("members") or {}
300
- global_mode = ai.get("mode")
301
- cli_budget_cfg = (ai.get("cli_call_budget") or {}) if isinstance(ai, dict) else {}
302
- cli_caps = (cli_budget_cfg.get("max_calls_per_day") or {}) if isinstance(cli_budget_cfg, dict) else {}
303
- cli_warn_at = float(cli_budget_cfg.get("warn_at", 0.8)) if isinstance(cli_budget_cfg, dict) else 0.8
304
- overrides = model_overrides or {}
305
- siblings = siblings_overrides or {}
306
- unknown = set(overrides) - set(members_cfg)
307
- if unknown:
308
- raise CouncilDisabledError(
309
- f"--model targets unknown member(s) {sorted(unknown)!r}; "
310
- f"known members: {sorted(members_cfg)!r}."
311
- )
312
- unknown_sib = set(siblings) - set(members_cfg)
313
- if unknown_sib:
314
- raise CouncilDisabledError(
315
- f"--siblings targets unknown member(s) {sorted(unknown_sib)!r}; "
316
- f"known members: {sorted(members_cfg)!r}."
317
- )
318
- conflict = set(overrides) & set(siblings)
319
- if conflict:
320
- raise CouncilDisabledError(
321
- f"--model and --siblings target the same member(s) {sorted(conflict)!r}; "
322
- f"pick one per provider per invocation."
323
- )
324
- members: list[ExternalAIClient] = []
325
- for name, cfg in members_cfg.items():
326
- cfg = cfg or {}
327
- if not cfg.get("enabled"):
328
- if name in siblings:
329
- raise CouncilDisabledError(
330
- f"--siblings targets member {name!r} but it is not "
331
- f"enabled in .agent-settings.yml (ai_council.members.{name}.enabled)."
332
- )
333
- continue
334
- mode = resolve_mode(
335
- name,
336
- invocation_mode=invocation_mode,
337
- member_settings=cfg,
338
- global_mode=global_mode,
339
- )
340
- if name in siblings:
341
- if mode != "api":
342
- raise CouncilDisabledError(
343
- f"--siblings requires mode=api for member {name!r} (got {mode!r})."
344
- )
345
- api_key_ref = cfg.get("api_key_ref")
346
- for sib_model in siblings[name]:
347
- members.append(
348
- _construct_api_member(name, sib_model, api_key_ref=api_key_ref),
349
- )
350
- continue
351
- model = overrides.get(name) or cfg.get("model")
352
- if mode == "api" and name in _API_PROVIDERS:
353
- members.append(
354
- _construct_api_member(name, model, api_key_ref=cfg.get("api_key_ref")),
355
- )
356
- elif mode == "cli" and name in _CLI_PROVIDERS:
357
- try:
358
- members.append(
359
- _construct_cli_member(
360
- name,
361
- model,
362
- binary=cfg.get("binary"),
363
- max_calls_per_day=cli_caps.get(name),
364
- warn_at=cli_warn_at,
365
- ),
366
- )
367
- except CliClientError as exc:
368
- _, _, display = _CLI_FACTORY[name]
369
- detail = (
370
- f"{exc} Install the {display} CLI or flip "
371
- f"ai_council.members.{name}.mode back to 'api'."
372
- )
373
- entry = {
374
- "member": name,
375
- "reason": "binary_missing",
376
- "detail": detail,
377
- }
378
- if skipped is not None:
379
- skipped.append(entry)
380
- print(f"[council] SKIP {name}: {detail}", file=sys.stderr)
381
- continue
382
- elif mode == "cli":
383
- raise CouncilDisabledError(
384
- f"member {name!r} resolves to mode=cli but no CLI client is "
385
- f"wired (known: {sorted(_CLI_PROVIDERS)!r})."
386
- )
387
- elif mode == "manual":
388
- members.append(ManualClient(name=name, model=model or "manual"))
389
- elif mode == "playwright":
390
- raise CouncilDisabledError(
391
- f"member {name!r} resolves to mode=playwright (Phase 2c, not wired)."
392
- )
393
- else:
394
- raise CouncilDisabledError(
395
- f"member {name!r} has no transport — mode={mode}, "
396
- f"name not in {sorted(_API_PROVIDERS)!r}."
397
- )
398
- if not members:
399
- if skipped:
400
- names = ", ".join(s["member"] for s in skipped)
401
- raise CouncilDisabledError(
402
- f"no council member could be constructed — every enabled "
403
- f"member was skipped ({names}). See [council] SKIP entries "
404
- f"on stderr for the per-member reason."
405
- )
406
- raise CouncilDisabledError(
407
- "no council member has `enabled: true` — enable at least one in "
408
- ".agent-settings.yml under ai_council.members.*."
409
- )
410
- return members
411
-
412
-
413
- def _build_advisor_plans(
414
- ai_cfg: dict[str, Any],
415
- repo_root: Path,
416
- ) -> dict[str, AdvisorPlan]:
417
- """Reconstruct AdvisorConfig from the projected dict, then plan swaps.
418
-
419
- The legacy ``ai_council.advisors`` dict shape is the projection
420
- written by ``_synthesize_ai_council_block``. Disabled advisors are
421
- silently skipped by ``plan_advisor_swap``; one-per-provider is
422
- enforced there. Returns empty when no advisor block is present.
423
- """
424
- raw = ai_cfg.get("advisors") if isinstance(ai_cfg, dict) else None
425
- if not raw:
426
- return {}
427
- advisors: dict[str, AdvisorConfig] = {}
428
- for name, entry in raw.items():
429
- if not isinstance(entry, dict):
430
- continue
431
- advisors[name] = AdvisorConfig(
432
- name=name,
433
- enabled=bool(entry.get("enabled", False)),
434
- member=str(entry.get("member", "")),
435
- persona=str(entry.get("persona", "")),
436
- model=entry.get("model"),
437
- )
438
- return plan_advisor_swap(advisors, repo_root)
439
-
440
-
441
- def _advisor_model_overrides(
442
- plans: dict[str, AdvisorPlan],
443
- explicit: dict[str, str] | None,
444
- ) -> dict[str, str]:
445
- """Merge advisor model_overrides under explicit ``--model`` flags.
446
-
447
- Explicit CLI ``--model`` overrides win over advisor-bound model
448
- overrides — the user's flag is always authoritative.
449
- """
450
- merged: dict[str, str] = {}
451
- for member, plan in plans.items():
452
- if plan.model_override:
453
- merged[member] = plan.model_override
454
- if explicit:
455
- merged.update(explicit)
456
- return merged
457
-
458
-
459
- def _format_advisor_summary(
460
- plans: dict[str, AdvisorPlan],
461
- members: list[ExternalAIClient],
462
- ) -> str:
463
- """Render the ``advisor: <persona> on <member> via <model>`` lines."""
464
- if not plans:
465
- return ""
466
- member_models = {m.name: m.model for m in members}
467
- rows: list[str] = []
468
- for member, plan in plans.items():
469
- model = member_models.get(member, plan.model_override or "?")
470
- rows.append(
471
- f" advisor: {plan.display_name} on {member} via {model}"
472
- )
473
- return "\n".join(rows)
474
-
475
-
476
- def _construct_api_member(
477
- name: str,
478
- model: str | None,
479
- *,
480
- api_key_ref: str | None = None,
481
- ) -> ExternalAIClient:
482
- """Build an api-mode client for a known provider name.
483
-
484
- ``api_key_ref`` carries the validated ``file:<path>`` / ``env:<VAR>``
485
- reference from ``agents/settings/.ai-council.yml`` and is resolved lazily here
486
- so the council does not require keys for disabled providers. When
487
- ``api_key_ref`` is ``None`` (no new config yet, or legacy code path),
488
- fall back to the per-provider loaders so the pre-step-2
489
- ``.agent-settings.yml`` flow keeps working during migration. Tests
490
- monkeypatch the legacy loaders — that path stays intact.
491
- """
492
- if name == "anthropic":
493
- api_key = (
494
- resolve_api_key(api_key_ref, scope="ai_council.members.anthropic")
495
- if api_key_ref else load_anthropic_key()
496
- )
497
- return AnthropicClient(model=model or "claude-sonnet-4-5", api_key=api_key)
498
- if name == "openai":
499
- api_key = (
500
- resolve_api_key(api_key_ref, scope="ai_council.members.openai")
501
- if api_key_ref else load_openai_key()
502
- )
503
- return OpenAIClient(model=model or "gpt-4o", api_key=api_key)
504
- if name == "gemini":
505
- if not api_key_ref:
506
- raise CouncilDisabledError(
507
- "member 'gemini' requires api_key_ref in agents/settings/.ai-council.yml "
508
- "(e.g. `env:GEMINI_API_KEY`) — no legacy fallback."
509
- )
510
- api_key = resolve_api_key(api_key_ref, scope="ai_council.members.gemini")
511
- return GeminiClient(model=model or "gemini-2.5-pro", api_key=api_key)
512
- if name == "xai":
513
- if not api_key_ref:
514
- raise CouncilDisabledError(
515
- "member 'xai' requires api_key_ref in agents/settings/.ai-council.yml "
516
- "(e.g. `env:XAI_API_KEY`) — no legacy fallback."
517
- )
518
- api_key = resolve_api_key(api_key_ref, scope="ai_council.members.xai")
519
- return XAIClient(model=model or "grok-4", api_key=api_key)
520
- if name == "perplexity":
521
- if not api_key_ref:
522
- raise CouncilDisabledError(
523
- "member 'perplexity' requires api_key_ref in agents/settings/.ai-council.yml "
524
- "(e.g. `env:PERPLEXITY_API_KEY`) — no legacy fallback."
525
- )
526
- api_key = resolve_api_key(api_key_ref, scope="ai_council.members.perplexity")
527
- return PerplexityClient(model=model or "sonar-pro", api_key=api_key)
528
- raise CouncilDisabledError(
529
- f"member {name!r} has no api transport "
530
- f"(known: {sorted(_API_PROVIDERS)!r})."
531
- )
532
-
533
-
534
- #: Provider → (class-attribute-name, default_model, human_display) for
535
- #: cli-mode routing. The class ref is looked up via ``getattr`` on this
536
- #: module at call time so ``monkeypatch.setattr(council_cli, "AnthropicCliClient", X)``
537
- #: keeps working from tests. The display string is used by
538
- #: ``build_members`` to render the "Install the <X> CLI" hint in
539
- #: skip-with-reason logs without re-importing every subclass at the
540
- #: call site.
541
- _CLI_FACTORY: dict[str, tuple[str, str, str]] = {
542
- "anthropic": ("AnthropicCliClient", "claude-sonnet-4-5", "Claude"),
543
- "openai": ("OpenAICliClient", "gpt-5", "Codex"),
544
- "gemini": ("GeminiCliClient", "gemini-2.5-pro", "Gemini"),
545
- "xai": ("XAICliClient", "grok-4", "Grok (community)"),
546
- "perplexity": ("PerplexityCliClient", "sonar-pro", "Perplexity (community)"),
547
- }
548
-
549
-
550
- def _construct_cli_member(
551
- name: str,
552
- model: str | None,
553
- *,
554
- binary: str | None = None,
555
- max_calls_per_day: int | None = None,
556
- warn_at: float = 0.8,
557
- ) -> ExternalAIClient:
558
- """Build a cli-mode client for a known provider name.
559
-
560
- ``binary`` overrides the provider default (e.g. ``/opt/claude``);
561
- ``None`` falls through to ``shutil.which(default_binary)``. The
562
- daily quota is plumbed through to the subclass; ``None`` disables
563
- the local counter (only stderr-based quota detection remains).
564
- ``warn_at`` (step-8 P1) is the fractional threshold flipping the
565
- pre-run quota summary to its ``⚠️`` shape; default 0.8 mirrors
566
- ``CliCallBudgetConfig``.
567
- Lets the subclass' ``CliClientError`` propagate so ``build_members``
568
- can convert it into a structured per-member skip entry without
569
- crashing the whole council (the original "fail loudly for the
570
- entire council" contract is preserved when no other member
571
- survives — the empty-members guard at the end of ``build_members``
572
- fires with the skip log attached).
573
- """
574
- if name in _CLI_FACTORY:
575
- attr, default_model, _display = _CLI_FACTORY[name]
576
- cls = globals()[attr]
577
- return cls(
578
- model=model or default_model,
579
- binary=binary,
580
- max_calls_per_day=max_calls_per_day,
581
- warn_at=warn_at,
582
- )
583
- raise CouncilDisabledError(
584
- f"member {name!r} has no cli transport "
585
- f"(known: {sorted(_CLI_PROVIDERS)!r})."
586
- )
587
-
588
-
589
- def build_question(
590
- *,
591
- input_path: Path,
592
- input_mode: str,
593
- max_tokens: int,
594
- prompt_mode_override: str | None = None,
595
- ) -> tuple[CouncilQuestion, str]:
596
- """Bundle the input file. Returns (question, artefact_label).
597
-
598
- `prompt_mode_override` swaps the per-mode neutrality addendum looked
599
- up by `system_prompt_for(question.mode, ...)`. The bundle shape is
600
- unchanged — the bundler still uses `input_mode` to format the
601
- artefact. Routed by the `/council pr|design|optimize|analysis`
602
- wrappers via the `--prompt-mode` CLI flag.
603
- """
604
- if input_mode == "prompt":
605
- text = input_path.read_text(encoding="utf-8")
606
- ctx = bundle_prompt(text)
607
- artefact = str(input_path)
608
- elif input_mode == "roadmap":
609
- ctx = bundle_roadmap(input_path)
610
- artefact = str(input_path)
611
- else:
612
- raise ValueError(
613
- f"unsupported input mode: {input_mode!r} (use prompt | roadmap)"
614
- )
615
- mode = prompt_mode_override or ctx.mode
616
- return CouncilQuestion(mode=mode, user_prompt=ctx.text,
617
- max_tokens=max_tokens), artefact
618
-
619
-
620
- def format_estimate_table(
621
- members: list[ExternalAIClient],
622
- estimates: list[Any],
623
- *,
624
- consensus_delta_usd: float = 0.0,
625
- consensus_extra_calls: int = 0,
626
- peer_review_delta_usd: float = 0.0,
627
- peer_review_extra_calls: int = 0,
628
- ) -> str:
629
- rows = [
630
- f" {m.name}/{m.model}: "
631
- f"~{e.input_tokens} in + {e.output_tokens} out = ${e.total_usd:.4f}"
632
- for m, e in zip(members, estimates)
633
- ]
634
- total = sum(e.total_usd for e in estimates)
635
- if consensus_extra_calls > 0:
636
- rows.append(
637
- f" +consensus scoring: +{consensus_extra_calls} calls "
638
- f"(~+${consensus_delta_usd:.4f})"
639
- )
640
- total += consensus_delta_usd
641
- if peer_review_extra_calls > 0:
642
- rows.append(
643
- f" +peer-review: +{peer_review_extra_calls} calls "
644
- f"(~+${peer_review_delta_usd:.4f})"
645
- )
646
- total += peer_review_delta_usd
647
- rows.append(f" TOTAL: ${total:.4f}")
648
- return "\n".join(rows)
649
-
650
-
651
- def _consensus_cost_delta(
652
- ai_cfg: dict[str, Any],
653
- prompt_mode: str,
654
- estimates: list[Any],
655
- n_billable: int,
656
- ) -> tuple[int, float]:
657
- """Return ``(extra_calls, extra_usd)`` for the consensus round.
658
-
659
- Active when ``ai_council.consensus_scoring.enabled`` is true AND the
660
- invocation's lens is in ``consensus_scoring.lenses``. Each member
661
- contributes two extra calls (extraction + scoring); the worst-case
662
- cost uses the base per-member estimate as a ceiling.
663
- """
664
- cs = ai_cfg.get("consensus_scoring") or {}
665
- if not cs.get("enabled"):
666
- return 0, 0.0
667
- lenses = cs.get("lenses") or ["analysis"]
668
- if prompt_mode not in lenses:
669
- return 0, 0.0
670
- extra_calls = 2 * n_billable
671
- extra_usd = 2.0 * sum(e.total_usd for e in estimates)
672
- return extra_calls, extra_usd
673
-
674
-
675
- def _maybe_run_consensus(
676
- ai_cfg: dict[str, Any],
677
- question: CouncilQuestion,
678
- members: list[ExternalAIClient],
679
- responses: list[CouncilResponse],
680
- budget: CostBudget,
681
- table: PriceTable,
682
- project: Any,
683
- args: argparse.Namespace,
684
- ) -> ConsensusResult | None:
685
- """Run the consensus scoring round when enabled for this lens."""
686
- cs = ai_cfg.get("consensus_scoring") or {}
687
- if not cs.get("enabled"):
688
- return None
689
- lenses = cs.get("lenses") or ["analysis"]
690
- if question.mode not in lenses:
691
- return None
692
- return run_consensus_scoring(
693
- members, responses,
694
- budget=budget, table=table, project=project,
695
- original_ask=args.original_ask,
696
- max_tokens=question.max_tokens,
697
- strong_threshold=float(cs.get("strong_threshold", 0.7)),
698
- minority_threshold=float(cs.get("minority_threshold", 0.4)),
699
- )
700
-
701
-
702
- def _serialise_consensus(consensus: ConsensusResult) -> dict[str, Any]:
703
- """Project ConsensusResult onto a JSON-safe dict for session payloads."""
704
- return {
705
- "findings": [
706
- {"id": f.id, "source": f.source, "text": f.text}
707
- for f in consensus.findings
708
- ],
709
- "scores": [
710
- {
711
- "finding_id": s.finding_id, "scorer": s.scorer,
712
- "score": s.score, "agree": s.agree, "reason": s.reason,
713
- }
714
- for s in consensus.scores
715
- ],
716
- "metadata": {
717
- fid: {
718
- "mean_score": m.mean_score,
719
- "agreement_rate": m.agreement_rate,
720
- "consensus_strength": m.consensus_strength,
721
- "dissent_count": m.dissent_count,
722
- "scorers": list(m.scorers),
723
- "concur_count": m.concur_count,
724
- "dissent_reasons": [list(pair) for pair in m.dissent_reasons],
725
- "evidence_quality": m.evidence_quality,
726
- }
727
- for fid, m in consensus.metadata.items()
728
- },
729
- "extraction_responses": _serialise_responses(consensus.extraction_responses),
730
- "scoring_responses": _serialise_responses(consensus.scoring_responses),
731
- }
732
-
733
-
734
- def _decision_replay_settings(
735
- ai_cfg: dict[str, Any], lens: str,
736
- ) -> tuple[bool, bool]:
737
- """Resolve (enabled, include_member_arguments) for ``lens``.
738
-
739
- Per-lens override under ``lenses.<lens>.decision_replay`` beats the
740
- global ``decision_replay`` block. Defaults: enabled=True,
741
- include_member_arguments=True (Phase 9 ships ON by default — the
742
- artefact is the audit trail GPT review of PR #148 called out as
743
- missing).
744
- """
745
- global_block = ai_cfg.get("decision_replay") or {}
746
- enabled = global_block.get("enabled", True)
747
- include_args = global_block.get("include_member_arguments", True)
748
- lenses = ai_cfg.get("lenses") or {}
749
- lens_block = (lenses.get(lens) or {}).get("decision_replay")
750
- if isinstance(lens_block, dict):
751
- if "enabled" in lens_block:
752
- enabled = lens_block["enabled"]
753
- if "include_member_arguments" in lens_block:
754
- include_args = lens_block["include_member_arguments"]
755
- return bool(enabled), bool(include_args)
756
-
757
-
758
- def _maybe_write_decision_replay(
759
- *,
760
- ai_cfg: dict[str, Any],
761
- lens: str,
762
- out_path: Path,
763
- consensus: ConsensusResult | None,
764
- deliberation: list[CouncilResponse],
765
- original_ask: str,
766
- ) -> Path | None:
767
- """Write ``decision-replay.md`` alongside ``out_path`` when enabled.
768
-
769
- No-op when ``decision_replay.enabled`` resolves to ``False`` for the
770
- lens or when ``consensus`` is ``None`` (nothing to replay). Returns
771
- the artefact path on success, ``None`` otherwise.
772
- """
773
- enabled, include_args = _decision_replay_settings(ai_cfg, lens)
774
- if not enabled or consensus is None:
775
- return None
776
- replay = render_decision_replay(
777
- DecisionReplayInputs(
778
- findings=list(consensus.findings),
779
- scores=list(consensus.scores),
780
- metadata=dict(consensus.metadata),
781
- deliberation=deliberation,
782
- original_ask=original_ask,
783
- include_member_arguments=include_args,
784
- ),
785
- )
786
- target = out_path.parent / "decision-replay.md"
787
- target.parent.mkdir(parents=True, exist_ok=True)
788
- target.write_text(replay, encoding="utf-8")
789
- return target
790
-
791
-
792
- # ── peer-review (Phase 5 / F1, Karpathy anonymous review) ──────────
793
-
794
-
795
- def _peer_review_active(ai_cfg: dict[str, Any], args: argparse.Namespace) -> bool:
796
- """Return True when peer-review should fire for this invocation.
797
-
798
- Resolution chain (highest priority first):
799
- 1. ``--peer-review`` CLI flag — explicit opt-in.
800
- 2. ``ai_council.peer_review.enabled: true`` in
801
- ``agents/settings/.ai-council.yml`` — opt-in via config.
802
- Both default to false; peer-review is opt-in by R2 verdict.
803
- """
804
- if getattr(args, "peer_review", False):
805
- return True
806
- pr_cfg = ai_cfg.get("peer_review") or {}
807
- return bool(pr_cfg.get("enabled"))
808
-
809
-
810
- def _peer_review_cost_delta(
811
- ai_cfg: dict[str, Any],
812
- args: argparse.Namespace,
813
- estimates: list[Any],
814
- n_billable: int,
815
- ) -> tuple[int, float]:
816
- """Return ``(extra_calls, extra_usd)`` for the peer-review round.
817
-
818
- One extra call per billable member (each reviews the others). The
819
- worst-case cost uses the base per-member estimate as a ceiling —
820
- same heuristic as ``_consensus_cost_delta``.
821
- """
822
- if not _peer_review_active(ai_cfg, args):
823
- return 0, 0.0
824
- if n_billable < 2:
825
- # Need ≥ 2 distinct deliberation outputs for peer-review to
826
- # have anything to review. The orchestrator no-ops below 2.
827
- return 0, 0.0
828
- extra_calls = n_billable
829
- extra_usd = sum(e.total_usd for e in estimates)
830
- return extra_calls, extra_usd
831
-
832
-
833
- def _maybe_run_peer_review(
834
- ai_cfg: dict[str, Any],
835
- args: argparse.Namespace,
836
- question: CouncilQuestion,
837
- members: list[ExternalAIClient],
838
- responses: list[CouncilResponse],
839
- budget: CostBudget,
840
- table: PriceTable,
841
- project: Any,
842
- *,
843
- persona_labels: dict[str, str] | None = None,
844
- ) -> PeerReviewResult | None:
845
- """Run the peer-review pass when opted in.
846
-
847
- No-ops if fewer than 2 successful deliberation responses exist —
848
- the orchestrator surfaces the empty result in that case.
849
-
850
- ``persona_labels`` (Phase 6) flows through to ``anonymize_responses``
851
- so advisor-mode runs render as ``Response A (Contrarian)`` instead
852
- of bare ``Response A``. Plain-member runs pass ``None``.
853
- """
854
- if not _peer_review_active(ai_cfg, args):
855
- return None
856
- result = run_peer_review(
857
- members, responses,
858
- budget=budget, table=table, project=project,
859
- original_ask=args.original_ask,
860
- max_tokens=question.max_tokens,
861
- persona_labels=persona_labels,
862
- )
863
- if not result.responses:
864
- return None
865
- return result
866
-
867
-
868
- def _serialise_peer_review(peer_review: PeerReviewResult) -> dict[str, Any]:
869
- """Project PeerReviewResult onto a JSON-safe dict for session payloads."""
870
- return {
871
- "responses": _serialise_responses(peer_review.responses),
872
- "label_to_source": dict(peer_review.label_to_source),
873
- "persona_labels": dict(peer_review.persona_labels),
874
- }
875
-
876
-
877
- def _deserialise_peer_review(
878
- data: dict[str, Any] | None,
879
- ) -> PeerReviewResult | None:
880
- """Reconstruct a PeerReviewResult from a session payload section.
881
-
882
- Returns ``None`` for payloads predating Phase 5 or runs where the
883
- flag was not passed.
884
- """
885
- if not data:
886
- return None
887
- return PeerReviewResult(
888
- responses=_deserialise_responses(data.get("responses") or []),
889
- label_to_source=dict(data.get("label_to_source") or {}),
890
- persona_labels=dict(data.get("persona_labels") or {}),
891
- )
892
-
893
-
894
- # ── subcommands ─────────────────────────────────────────────────────
895
-
896
-
897
- def _resolve_rounds(args: argparse.Namespace, ai_cfg: dict[str, Any]) -> int:
898
- """Resolve effective debate round count from CLI args + settings.
899
-
900
- Resolution chain (highest priority first):
901
- 1. ``--rounds N`` — explicit user override, any value.
902
- 2. ``--depth deep`` — uses ``ai_council.deep_min_rounds``,
903
- floored at ``min_rounds`` so the deep tier is monotonic.
904
- 3. ``ai_council.min_rounds`` — default 2.
905
-
906
- Sub-commands (rule/skill/command) declare ``council_depth: deep``
907
- in their frontmatter; the host agent reads that and translates it
908
- to ``--depth deep`` on the CLI invocation. The CLI itself stays
909
- unaware of frontmatter — the contract is the flag.
910
- """
911
- if getattr(args, "rounds", None) is not None:
912
- return int(args.rounds)
913
- min_rounds = int(ai_cfg.get("min_rounds", 2))
914
- if getattr(args, "depth", "standard") == "deep":
915
- deep = int(ai_cfg.get("deep_min_rounds", min_rounds))
916
- return max(deep, min_rounds)
917
- return min_rounds
918
-
919
-
920
- def _resolve_max_tokens(args: argparse.Namespace, ai_cfg: dict[str, Any]) -> int:
921
- """Resolve the per-call output budget passed to each member.
922
-
923
- Resolution chain (highest priority first):
924
- 1. ``--max-tokens N`` — explicit invocation override.
925
- 2. ``ai_council.max_output_tokens`` — settings value (project file
926
- is authoritative; this key is not user-global-mergeable).
927
- 3. ``DEFAULT_MAX_TOKENS`` — package fallback (2048).
928
-
929
- A value of ``0`` at any layer means "unlimited"; it is widened to
930
- ``UNLIMITED_TOKENS_FALLBACK`` before reaching the SDK because
931
- Anthropic rejects ``max_tokens=0``. Estimation uses the same expanded
932
- value so the cost preview reflects the worst-case ceiling.
933
- """
934
- cli = getattr(args, "max_tokens", None)
935
- if cli is not None:
936
- value = int(cli)
937
- elif "max_output_tokens" in ai_cfg:
938
- value = int(ai_cfg.get("max_output_tokens") or 0)
939
- else:
940
- value = DEFAULT_MAX_TOKENS
941
- if value <= 0:
942
- return UNLIMITED_TOKENS_FALLBACK
943
- return value
944
-
945
-
946
- def cmd_estimate(
947
- args: argparse.Namespace,
948
- *,
949
- settings: dict[str, Any] | None = None,
950
- members: list[ExternalAIClient] | None = None,
951
- table: PriceTable | None = None,
952
- ) -> int:
953
- """Print per-member cost preview. No API calls."""
954
- if settings is None:
955
- settings = load_settings()
956
- ai_cfg = (settings.get("ai_council") or {}) if isinstance(settings, dict) else {}
957
- advisor_plans = _build_advisor_plans(ai_cfg, REPO_ROOT)
958
- explicit_overrides = _parse_model_overrides(getattr(args, "model", None))
959
- skipped: list[dict[str, Any]] = []
960
- if members is None:
961
- members = build_members(
962
- settings,
963
- invocation_mode=args.mode_override,
964
- model_overrides=_advisor_model_overrides(
965
- advisor_plans, explicit_overrides,
966
- ),
967
- siblings_overrides=_parse_siblings_overrides(getattr(args, "siblings", None)),
968
- skipped=skipped,
969
- )
970
- if table is None:
971
- table = load_prices()
972
- question, _ = build_question(
973
- input_path=Path(args.question), input_mode=args.input_mode,
974
- max_tokens=_resolve_max_tokens(args, ai_cfg),
975
- prompt_mode_override=getattr(args, "prompt_mode", None),
976
- )
977
- project = detect_project_context(REPO_ROOT)
978
- billable = [m for m in members if getattr(m, "billable", True)]
979
- estimates = estimate(question, billable, table,
980
- project=project, original_ask=args.original_ask,
981
- advisor_plans=advisor_plans)
982
- if getattr(args, "debate", False):
983
- return _emit_debate_estimate(
984
- args, ai_cfg, members, billable, estimates, advisor_plans,
985
- skipped=skipped,
986
- )
987
- extra_calls, extra_usd = _consensus_cost_delta(
988
- ai_cfg, question.mode, estimates, len(billable),
989
- )
990
- pr_extra_calls, pr_extra_usd = _peer_review_cost_delta(
991
- ai_cfg, args, estimates, len(billable),
992
- )
993
- sys.stdout.write(
994
- f"council:estimate · mode={question.mode} · members={len(members)} "
995
- f"(billable={len(billable)})\n"
996
- )
997
- advisor_summary = _format_advisor_summary(advisor_plans, billable)
998
- if advisor_summary:
999
- sys.stdout.write(advisor_summary + "\n")
1000
- if skipped:
1001
- sys.stdout.write(format_install_hints(skipped) + "\n")
1002
- sys.stdout.write(
1003
- format_estimate_table(
1004
- billable, estimates,
1005
- consensus_delta_usd=extra_usd,
1006
- consensus_extra_calls=extra_calls,
1007
- peer_review_delta_usd=pr_extra_usd,
1008
- peer_review_extra_calls=pr_extra_calls,
1009
- ) + "\n"
1010
- )
1011
- return 0
1012
-
1013
-
1014
- def _emit_debate_estimate(
1015
- args: argparse.Namespace,
1016
- ai_cfg: dict[str, Any],
1017
- members: list[ExternalAIClient],
1018
- billable: list[ExternalAIClient],
1019
- estimates: list[Any],
1020
- advisor_plans: Any,
1021
- *,
1022
- skipped: list[dict[str, Any]] | None = None,
1023
- ) -> int:
1024
- """Render the round-by-round debate cost projection.
1025
-
1026
- Upper bound only — progressive disclosure may stop the debate early.
1027
- Cost shape mirrors ``cmd_debate``: one call per billable member per
1028
- round, default ``ai_council.min_rounds`` (typically 2), capped at
1029
- ``ai_council.debate_max_rounds`` (typically 4).
1030
- """
1031
- min_rounds = int(ai_cfg.get("min_rounds", 2))
1032
- max_rounds_cap = int(ai_cfg.get("debate_max_rounds", 4))
1033
- requested = (
1034
- int(args.rounds) if getattr(args, "rounds", None) is not None
1035
- else min_rounds
1036
- )
1037
- if requested < 1:
1038
- raise argparse.ArgumentTypeError(
1039
- f"--rounds must be >= 1 (got {requested})"
1040
- )
1041
- if requested > max_rounds_cap:
1042
- raise argparse.ArgumentTypeError(
1043
- f"--rounds={requested} exceeds debate_max_rounds={max_rounds_cap}; "
1044
- f"raise the cap in agents/settings/.ai-council.yml or lower --rounds."
1045
- )
1046
- rounds = requested
1047
- per_round_usd = sum(e.total_usd for e in estimates)
1048
- projected_total = per_round_usd * rounds
1049
- sys.stdout.write(
1050
- f"council:estimate · mode=debate · members={len(members)} "
1051
- f"(billable={len(billable)}) · rounds={rounds} "
1052
- f"(cap={max_rounds_cap})\n"
1053
- )
1054
- advisor_summary = _format_advisor_summary(advisor_plans, billable)
1055
- if advisor_summary:
1056
- sys.stdout.write(advisor_summary + "\n")
1057
- if skipped:
1058
- sys.stdout.write(format_install_hints(skipped) + "\n")
1059
- for round_idx in range(1, rounds + 1):
1060
- sys.stdout.write(f"\nRound {round_idx} of {rounds}:\n")
1061
- sys.stdout.write(format_estimate_table(billable, estimates) + "\n")
1062
- if round_idx < rounds:
1063
- sys.stdout.write(" " + "─" * 40 + "\n")
1064
- sys.stdout.write(
1065
- f"\n PROJECTED TOTAL ({rounds} rounds): ${projected_total:.4f}\n"
1066
- )
1067
- sys.stdout.write(
1068
- " Note: progressive disclosure may stop the debate early; "
1069
- "this is an upper bound.\n"
1070
- )
1071
- return 0
1072
-
1073
-
1074
- def _serialise_responses(responses: list[CouncilResponse]) -> list[dict[str, Any]]:
1075
- out: list[dict[str, Any]] = []
1076
- for r in responses:
1077
- d = asdict(r)
1078
- # `metadata` may contain non-JSON types; coerce.
1079
- d["metadata"] = {k: str(v) for k, v in (d.get("metadata") or {}).items()}
1080
- out.append(d)
1081
- return out
1082
-
1083
-
1084
- def _deserialise_responses(items: list[dict[str, Any]]) -> list[CouncilResponse]:
1085
- out: list[CouncilResponse] = []
1086
- for d in items:
1087
- out.append(CouncilResponse(
1088
- provider=d.get("provider", ""),
1089
- model=d.get("model", ""),
1090
- text=d.get("text", ""),
1091
- input_tokens=int(d.get("input_tokens", 0) or 0),
1092
- output_tokens=int(d.get("output_tokens", 0) or 0),
1093
- latency_ms=int(d.get("latency_ms", 0) or 0),
1094
- error=d.get("error"),
1095
- metadata=dict(d.get("metadata") or {}),
1096
- ))
1097
- return out
1098
-
1099
-
1100
- def _deserialise_consensus(data: dict[str, Any] | None) -> ConsensusResult | None:
1101
- """Reconstruct a ConsensusResult from a serialised payload section.
1102
-
1103
- Used by ``cmd_render`` to re-render saved sessions that captured a
1104
- consensus round. Returns ``None`` when the payload predates Phase 4
1105
- or the round was skipped for the lens.
1106
- """
1107
- if not data:
1108
- return None
1109
- from scripts.ai_council.consensus import (
1110
- ConsensusMetadata, Finding, FindingScore,
1111
- aggregate_scores, bucket_by_threshold,
1112
- )
1113
- findings = [
1114
- Finding(id=f["id"], source=f["source"], text=f["text"])
1115
- for f in (data.get("findings") or [])
1116
- ]
1117
- scores = [
1118
- FindingScore(
1119
- finding_id=s["finding_id"], scorer=s["scorer"],
1120
- score=int(s["score"]), agree=bool(s["agree"]),
1121
- reason=s.get("reason", ""),
1122
- )
1123
- for s in (data.get("scores") or [])
1124
- ]
1125
- metadata = aggregate_scores(findings, scores)
1126
- bucket = bucket_by_threshold(findings, metadata)
1127
- return ConsensusResult(
1128
- bucket=bucket, findings=findings, scores=scores, metadata=metadata,
1129
- extraction_responses=_deserialise_responses(
1130
- data.get("extraction_responses") or [],
1131
- ),
1132
- scoring_responses=_deserialise_responses(
1133
- data.get("scoring_responses") or [],
1134
- ),
1135
- )
1136
-
1137
-
1138
- def _resolve_necessity_mode(
1139
- ai_cfg: dict[str, Any],
1140
- lens: str,
1141
- invocation: str = "agent",
1142
- ) -> tuple[bool, str]:
1143
- """Return ``(enabled, effective_mode)`` for the necessity classifier.
1144
-
1145
- Two-tier resolution (step-8 D2):
1146
-
1147
- - ``invocation="agent"`` → reads ``necessity_classifier.mode`` with
1148
- per-lens override at ``lenses.<lens>.necessity_classifier.mode``
1149
- (default ``educate``).
1150
- - ``invocation="user_explicit"`` → reads
1151
- ``necessity_classifier.user_explicit_mode`` with per-lens override
1152
- at ``lenses.<lens>.necessity_classifier.user_explicit_mode``
1153
- (default ``warn-only``).
1154
-
1155
- Reads the synthesized dict shape produced by
1156
- :func:`_synthesize_ai_council_block`, so both typed-config and
1157
- legacy-settings paths are honoured.
1158
- """
1159
- nc_block = ai_cfg.get("necessity_classifier") or {}
1160
- enabled = bool(nc_block.get("enabled", True))
1161
- lens_overrides = ai_cfg.get("lens_overrides") or {}
1162
- if invocation == "user_explicit":
1163
- global_mode = str(nc_block.get("user_explicit_mode", "warn-only"))
1164
- overrides = (
1165
- lens_overrides.get("necessity_classifier_user_explicit_mode") or {}
1166
- )
1167
- else:
1168
- global_mode = str(nc_block.get("mode", "educate"))
1169
- overrides = lens_overrides.get("necessity_classifier_mode") or {}
1170
- return enabled, str(overrides.get(lens, global_mode))
1171
-
1172
-
1173
- def _provider_caps_snapshot(ai_cfg: dict[str, Any]) -> dict[str, dict[str, str]]:
1174
- """Return ``{provider: {mode, model}}`` for enabled members.
1175
-
1176
- Step-8 D3 events-log snapshot. Captures only public capability
1177
- metadata (no API keys, no prompt content) so the log line stays
1178
- within the privacy floor. Disabled members are excluded.
1179
- """
1180
- members = ai_cfg.get("members") or {}
1181
- snapshot: dict[str, dict[str, str]] = {}
1182
- if not isinstance(members, dict):
1183
- return snapshot
1184
- for name, cfg in members.items():
1185
- if not isinstance(cfg, dict) or not cfg.get("enabled", True):
1186
- continue
1187
- snapshot[str(name)] = {
1188
- "mode": str(cfg.get("mode", "")),
1189
- "model": str(cfg.get("model", "")),
1190
- }
1191
- return snapshot
1192
-
1193
-
1194
- def _necessity_gate(
1195
- *, prompt: str, lens: str, invocation: str, proceed_anyway: bool,
1196
- ai_cfg: dict[str, Any], stdout=None, original_ask: str = "",
1197
- ) -> tuple[bool, int, ClassificationResult | None]:
1198
- """Apply the Phase-6 necessity classifier before any member fires.
1199
-
1200
- Returns ``(proceed, exit_code, result)``. ``proceed=True`` means the
1201
- dispatcher continues; ``proceed=False`` means the caller should
1202
- return ``exit_code`` immediately. ``result`` carries the verdict for
1203
- session.md provenance on the proceed path (None when classifier is
1204
- disabled / off).
1205
-
1206
- Step-8 D3: every non-disabled branch emits one
1207
- :func:`append_event` line. ``original_ask`` is forwarded to the
1208
- events log so the sha256[:12] hash anchors the line to the
1209
- user-side question without leaking content. When the caller does
1210
- not have an ``original_ask`` value, the prompt itself is hashed
1211
- (legacy CLIs route through this path).
1212
- """
1213
- out = stdout if stdout is not None else sys.stdout
1214
- enabled, mode = _resolve_necessity_mode(ai_cfg, lens, invocation=invocation)
1215
- if not enabled or mode == "off":
1216
- return True, 0, None
1217
- result = classify_necessity(prompt, lens=lens, invocation=invocation)
1218
- caps = _provider_caps_snapshot(ai_cfg)
1219
- hashed = original_ask or prompt
1220
-
1221
- def _emit(action: str) -> None:
1222
- append_event({
1223
- "lens": lens, "invocation": invocation,
1224
- "action": action, "verdict": result.verdict,
1225
- "category": result.category,
1226
- "mode": mode, "provider_caps": caps,
1227
- "original_ask": hashed,
1228
- })
1229
-
1230
- if result.verdict != "unnecessary":
1231
- if result.verdict == "borderline":
1232
- out.write(
1233
- f"council:necessity · borderline ({result.category}) · "
1234
- f"{result.rationale}\n"
1235
- )
1236
- _emit("proceed")
1237
- return True, 0, result
1238
- # verdict == "unnecessary"
1239
- if mode == "warn-only":
1240
- # Annotated but never skips (step-8 D2). Applies to both
1241
- # invocation tiers when the mode resolves to warn-only.
1242
- out.write(
1243
- f"council:necessity · warn-only ({result.category}) · "
1244
- f"{result.rationale}\n"
1245
- )
1246
- _emit("proceed")
1247
- return True, 0, result
1248
- if mode == "block":
1249
- out.write(
1250
- f"council:necessity · skipped ({result.category}) · "
1251
- f"{result.rationale}\n"
1252
- f"council:necessity · mode=block — `--proceed-anyway` has "
1253
- f"no effect on the block path.\n"
1254
- )
1255
- _emit("skip_necessity")
1256
- return False, 0, result
1257
- # mode == "educate"
1258
- if invocation == "agent":
1259
- out.write(
1260
- f"council:necessity · skipped (agent, {result.category}) · "
1261
- f"{result.rationale}\n"
1262
- )
1263
- _emit("skip_necessity")
1264
- return False, 0, result
1265
- # invocation == "user_explicit"
1266
- if proceed_anyway:
1267
- out.write(
1268
- f"council:necessity · override (user_explicit + "
1269
- f"--proceed-anyway, {result.category}) · "
1270
- f"{result.rationale}\n"
1271
- )
1272
- _emit("proceed")
1273
- return True, 0, result
1274
- out.write(educate_message(result, lens) + "\n")
1275
- _emit("skip_necessity")
1276
- return False, 2, result
1277
-
1278
-
1279
- def _resolve_model_downgrade(
1280
- ai_cfg: dict[str, Any], lens: str,
1281
- ) -> tuple[bool, bool]:
1282
- """Return ``(enabled, auto_apply)`` for the size-fit downgrade gate.
1283
-
1284
- Per-lens override at ``lenses.<lens>.model_downgrade`` wins over the
1285
- global ``model_downgrade`` block. Reads the synthesized dict shape
1286
- from :func:`_synthesize_ai_council_block` so both typed-config and
1287
- legacy paths are honoured.
1288
- """
1289
- md_block = ai_cfg.get("model_downgrade") or {}
1290
- enabled = bool(md_block.get("enabled", True))
1291
- auto_apply = bool(md_block.get("auto_apply", False))
1292
- overrides = (
1293
- (ai_cfg.get("lens_overrides") or {}).get("model_downgrade") or {}
1294
- )
1295
- lens_override = overrides.get(lens) if isinstance(overrides, dict) else None
1296
- if isinstance(lens_override, dict):
1297
- enabled = bool(lens_override.get("enabled", enabled))
1298
- auto_apply = bool(lens_override.get("auto_apply", auto_apply))
1299
- return enabled, auto_apply
1300
-
1301
-
1302
- def _size_fit_gate(
1303
- *, prompt: str, lens: str, members: list[ExternalAIClient],
1304
- ai_cfg: dict[str, Any], stdout=None,
1305
- ) -> list[tuple[str, SizeFitVerdict, bool]]:
1306
- """Apply the Phase-7 size-fit classifier across enabled members.
1307
-
1308
- Iterates every member with a configured ``model_ladder`` and runs
1309
- :func:`classify_size_fit`. When ``auto_apply`` is true and a
1310
- downgrade is suggested, the member's ``model`` attribute is rewritten
1311
- in place; otherwise the suggestion is surfaced as a stdout notice
1312
- and the original model stands. Members without a ladder are skipped
1313
- silently.
1314
-
1315
- Returns a list of ``(member_name, verdict, applied)`` tuples for
1316
- session.md provenance. Never blocks the dispatch — Phase 7 is a
1317
- suggestion gate, not a refusal gate.
1318
- """
1319
- out = stdout if stdout is not None else sys.stdout
1320
- enabled, auto_apply = _resolve_model_downgrade(ai_cfg, lens)
1321
- decisions: list[tuple[str, SizeFitVerdict, bool]] = []
1322
- if not enabled:
1323
- return decisions
1324
- members_cfg = ai_cfg.get("members") or {}
1325
- for member in members:
1326
- member_cfg = members_cfg.get(member.name) or {}
1327
- ladder = member_cfg.get("model_ladder") or ()
1328
- if not ladder:
1329
- continue
1330
- verdict = classify_size_fit(
1331
- prompt, current_model=member.model, ladder=ladder, lens=lens,
1332
- )
1333
- applied = False
1334
- if not verdict.fit and verdict.suggested_model:
1335
- if auto_apply:
1336
- out.write(
1337
- f"council:size-fit · {member.name} · auto-downgrade "
1338
- f"`{member.model}` → `{verdict.suggested_model}` · "
1339
- f"{verdict.reason}\n"
1340
- )
1341
- member.model = verdict.suggested_model
1342
- applied = True
1343
- else:
1344
- out.write(
1345
- f"council:size-fit · {member.name} · "
1346
- f"{downgrade_message(verdict, member.model)}\n"
1347
- )
1348
- decisions.append((member.name, verdict, applied))
1349
- return decisions
1350
-
1351
-
1352
- def _resolve_cost_disclosure(
1353
- ai_cfg: dict[str, Any], lens: str,
1354
- ) -> tuple[str, float, bool]:
1355
- """Return ``(mode, threshold_usd, show_per_member)`` for the lens.
1356
-
1357
- Per-lens override at ``lenses.<lens>.cost_disclosure`` wins over the
1358
- global ``debate.cost_disclosure`` block. The ``debate`` lens gets
1359
- the debate-scoped defaults; other lenses default to ``off`` unless
1360
- explicitly overridden (Phase 8 step 5 \u2014 cheap lenses are opt-in).
1361
- """
1362
- debate_block = ai_cfg.get("debate") or {}
1363
- debate_disc = debate_block.get("cost_disclosure") or {}
1364
- if lens == "debate":
1365
- mode = str(debate_disc.get("mode", "always"))
1366
- threshold = float(debate_disc.get("threshold_usd", 1.00))
1367
- show_per_member = bool(debate_disc.get("show_per_member", True))
1368
- else:
1369
- mode = "off"
1370
- threshold = 1.00
1371
- show_per_member = True
1372
- overrides = (
1373
- (ai_cfg.get("lens_overrides") or {}).get("cost_disclosure") or {}
1374
- )
1375
- lens_override = overrides.get(lens) if isinstance(overrides, dict) else None
1376
- if isinstance(lens_override, dict):
1377
- mode = str(lens_override.get("mode", mode))
1378
- threshold = float(lens_override.get("threshold_usd", threshold))
1379
- show_per_member = bool(lens_override.get("show_per_member", show_per_member))
1380
- return mode, threshold, show_per_member
1381
-
1382
-
1383
- def _format_cost_disclosure(
1384
- est: DebateCostEstimate, *, lens: str, show_per_member: bool,
1385
- ) -> str:
1386
- """Render the pre-flight disclosure block for stdout.
1387
-
1388
- Mirrors the roadmap spec: total range across N members \u00d7 R rounds,
1389
- optional per-member breakdown, and a subscription-member call-out
1390
- for CLI / manual transports that don't sum into USD totals.
1391
- """
1392
- lines = [
1393
- f"council:{lens} \u00b7 cost-disclosure \u00b7 estimated "
1394
- f"${est.low_usd:.4f} \u2013 ${est.high_usd:.4f} "
1395
- f"(expected ${est.expected_usd:.4f}) across "
1396
- f"{len(est.per_member)} billable members \u00d7 {est.rounds} rounds",
1397
- ]
1398
- if show_per_member and est.per_member:
1399
- lines.append(" per member:")
1400
- for pm in est.per_member:
1401
- lines.append(
1402
- f" \u00b7 {pm['name']:<14} {pm['model']:<22} "
1403
- f"${pm['low_usd']:.4f} \u2013 ${pm['high_usd']:.4f}",
1404
- )
1405
- if est.subscription_members:
1406
- lines.append(" subscription (no USD spend):")
1407
- for sm in est.subscription_members:
1408
- label = sm.get("subscription_label") or sm.get("transport", "")
1409
- lines.append(
1410
- f" \u00b7 {sm['name']:<14} {sm['model']:<22} ({label})",
1411
- )
1412
- return "\n".join(lines) + "\n"
1413
-
1414
-
1415
- def _debate_refusal_cap(
1416
- ai_cfg: dict[str, Any],
1417
- ) -> float:
1418
- """Resolve the hard refusal cap (``debate.max_cost_usd``).
1419
-
1420
- Returns 0.0 when disabled. The cap is unconditional \u2014 no
1421
- ``--proceed-anyway`` override (the user must lower rounds, drop
1422
- members, or raise the cap explicitly).
1423
- """
1424
- debate_block = ai_cfg.get("debate") or {}
1425
- return float(debate_block.get("max_cost_usd", 5.00) or 0.0)
1426
-
1427
-
1428
- def _emit_shadow_slo_banner() -> None:
1429
- """Pre-flight SLO banner for solo-dispatch invocations (step-9 P10).
1430
-
1431
- Reads ``agents/runtime/council/shadow-log.jsonl`` and prints the 7-day rolling
1432
- disagreement rate. ``OK``, ``WARN``, ``BREACH`` are all surfaced so the
1433
- user can see when single-member quality is drifting. Never auto-flips
1434
- back to full council \u2014 visibility-first, action-second (D10).
1435
- """
1436
- try:
1437
- from scripts.ai_council import shadow_dispatch as _sd
1438
- rate, n = _sd.compute_disagreement_rate(_sd.SHADOW_LOG_PATH)
1439
- if n == 0:
1440
- return
1441
- sys.stdout.write(_sd.slo_banner(rate, n) + "\n")
1442
- except Exception: # noqa: BLE001 \u2014 banner must never break dispatch.
1443
- return
1444
-
1445
-
1446
- def _apply_solo_dispatch(
1447
- members: list[ExternalAIClient],
1448
- ) -> tuple[list[ExternalAIClient], str | None]:
1449
- """Filter ``members`` to a single solo-dispatch pick (step-9 P9).
1450
-
1451
- Loads the routing chain from ``agents/settings/.ai-council.yml`` and asks
1452
- :func:`select_solo_member` for the first chain entry whose member
1453
- is runtime-present. The probe is conservative: a member counts as
1454
- auth-valid iff ``build_members`` returned a runtime client for it
1455
- \u2014 build_members has already filtered out missing binaries / bad
1456
- keys via the ``skipped`` list. Deep CLI auth probes (e.g.
1457
- ``claude auth status``) are reserved for the shadow-mode path.
1458
-
1459
- Returns ``(filtered_members, marker)``. ``marker`` is a one-line
1460
- info banner the caller prints to stdout (``None`` when no banner
1461
- is needed, e.g. config missing). Returns the unfiltered list when
1462
- no solo member can be picked \u2014 caller never fails the decision.
1463
- """
1464
- try:
1465
- cfg = load_council_config(AI_COUNCIL_FILE)
1466
- except (CouncilConfigError, FileNotFoundError):
1467
- return members, None
1468
- if not cfg.routing.solo_member_fallback_chain:
1469
- return (
1470
- members,
1471
- "council:solo \u00b7 WARN \u00b7 --single requested but "
1472
- "routing.solo_member_fallback_chain is empty \u2014 "
1473
- "escalating to full council.",
1474
- )
1475
- runtime_names = {getattr(m, "name", "") for m in members}
1476
- pick = select_solo_member(
1477
- cfg.routing,
1478
- cfg.members,
1479
- auth_cache=AuthCache(),
1480
- probe=lambda name, _t: name in runtime_names,
1481
- )
1482
- if pick is None:
1483
- return (
1484
- members,
1485
- "council:solo \u00b7 WARN \u00b7 solo dispatch unavailable "
1486
- "(no chain member runtime-present) \u2014 escalating to "
1487
- "full council.",
1488
- )
1489
- filtered = [m for m in members if getattr(m, "name", "") == pick]
1490
- if not filtered:
1491
- # Defensive: ``pick`` came from runtime_names so this should
1492
- # be unreachable. If we ever get here, escalate rather than
1493
- # ship an empty council.
1494
- return (
1495
- members,
1496
- "council:solo \u00b7 WARN \u00b7 selected member vanished "
1497
- "between probe and filter \u2014 escalating to full council.",
1498
- )
1499
- return (
1500
- filtered,
1501
- f"council:solo \u00b7 dispatching to {pick} only "
1502
- f"(routing.solo_member_fallback_chain).",
1503
- )
1504
-
1505
-
1506
- def cmd_run(
1507
- args: argparse.Namespace,
1508
- *,
1509
- settings: dict[str, Any] | None = None,
1510
- members: list[ExternalAIClient] | None = None,
1511
- table: PriceTable | None = None,
1512
- ) -> int:
1513
- """Estimate, then run the council. Requires --confirm to spend."""
1514
- if settings is None:
1515
- settings = load_settings()
1516
- ai_cfg = (settings.get("ai_council") or {}) if isinstance(settings, dict) else {}
1517
- advisor_plans = _build_advisor_plans(ai_cfg, REPO_ROOT)
1518
- explicit_overrides = _parse_model_overrides(getattr(args, "model", None))
1519
- skipped: list[dict[str, Any]] = []
1520
- if members is None:
1521
- members = build_members(
1522
- settings,
1523
- invocation_mode=args.mode_override,
1524
- model_overrides=_advisor_model_overrides(
1525
- advisor_plans, explicit_overrides,
1526
- ),
1527
- siblings_overrides=_parse_siblings_overrides(getattr(args, "siblings", None)),
1528
- skipped=skipped,
1529
- )
1530
- if getattr(args, "single", False):
1531
- members, solo_banner = _apply_solo_dispatch(members)
1532
- if solo_banner:
1533
- sys.stdout.write(solo_banner + "\n")
1534
- _emit_shadow_slo_banner()
1535
- if table is None:
1536
- table = load_prices()
1537
- question, artefact = build_question(
1538
- input_path=Path(args.question), input_mode=args.input_mode,
1539
- max_tokens=_resolve_max_tokens(args, ai_cfg),
1540
- prompt_mode_override=getattr(args, "prompt_mode", None),
1541
- )
1542
- proceed, gate_exit, _necessity_result = _necessity_gate(
1543
- prompt=question.user_prompt,
1544
- lens=question.mode,
1545
- invocation=getattr(args, "invocation", "agent"),
1546
- proceed_anyway=getattr(args, "proceed_anyway", False),
1547
- ai_cfg=ai_cfg,
1548
- original_ask=getattr(args, "original_ask", "") or "",
1549
- )
1550
- if not proceed:
1551
- return gate_exit
1552
- _size_fit_gate(
1553
- prompt=question.user_prompt,
1554
- lens=question.mode,
1555
- members=members,
1556
- ai_cfg=ai_cfg,
1557
- )
1558
- project = detect_project_context(REPO_ROOT)
1559
- billable = [m for m in members if getattr(m, "billable", True)]
1560
- estimates = estimate(question, billable, table,
1561
- project=project, original_ask=args.original_ask,
1562
- advisor_plans=advisor_plans)
1563
- extra_calls, extra_usd = _consensus_cost_delta(
1564
- ai_cfg, question.mode, estimates, len(billable),
1565
- )
1566
- pr_extra_calls, pr_extra_usd = _peer_review_cost_delta(
1567
- ai_cfg, args, estimates, len(billable),
1568
- )
1569
- sys.stdout.write(
1570
- f"council:run · mode={question.mode} · members={len(members)} "
1571
- f"(billable={len(billable)})\n"
1572
- )
1573
- advisor_summary = _format_advisor_summary(advisor_plans, billable)
1574
- if advisor_summary:
1575
- sys.stdout.write(advisor_summary + "\n")
1576
- if skipped:
1577
- sys.stdout.write(format_install_hints(skipped) + "\n")
1578
- sys.stdout.write(
1579
- format_estimate_table(
1580
- billable, estimates,
1581
- consensus_delta_usd=extra_usd,
1582
- consensus_extra_calls=extra_calls,
1583
- peer_review_delta_usd=pr_extra_usd,
1584
- peer_review_extra_calls=pr_extra_calls,
1585
- ) + "\n"
1586
- )
1587
-
1588
- # Step-8 P1 — pre-run quota summary. After estimate / before
1589
- # dispatch so the user sees the budget shape before --confirm.
1590
- # Uncapped providers are omitted by ``quota_summary_line``; when
1591
- # no CLI member has a configured cap the summary is empty and we
1592
- # write nothing.
1593
- cli_members = [m for m in members if isinstance(m, CliClient)]
1594
- summary, warn_providers = quota_summary_line(cli_members)
1595
- if summary:
1596
- sys.stdout.write(summary + "\n")
1597
- for prov in warn_providers:
1598
- sys.stdout.write(f"council:quota · WARN · {prov} near limit\n")
1599
-
1600
- # Phase 8 step 5 — opt-in cost disclosure for non-debate lenses.
1601
- # Default mode is "off" for analysis / default (cheap enough that
1602
- # the disclosure is friction); users opt in by setting
1603
- # `lenses.<name>.cost_disclosure.mode` in agents/settings/.ai-council.yml.
1604
- disc_mode, disc_threshold, disc_show = _resolve_cost_disclosure(
1605
- ai_cfg, question.mode,
1606
- )
1607
- if disc_mode != "off":
1608
- run_estimate = estimate_debate_cost(
1609
- question, members, table,
1610
- rounds=1, project=project,
1611
- original_ask=args.original_ask,
1612
- advisor_plans=advisor_plans,
1613
- )
1614
- if disc_mode == "always" or (
1615
- disc_mode == "above_threshold"
1616
- and run_estimate.expected_usd > disc_threshold
1617
- ):
1618
- sys.stdout.write(
1619
- _format_cost_disclosure(
1620
- run_estimate, lens=question.mode,
1621
- show_per_member=disc_show,
1622
- )
1623
- )
1624
-
1625
- if not args.confirm:
1626
- sys.stdout.write(
1627
- "\nNo --confirm flag — estimate only. Re-run with --confirm to "
1628
- "invoke the council and write the response.\n"
1629
- )
1630
- return 0
1631
-
1632
- cost_cfg = ai_cfg.get("cost_budget") or {}
1633
- budget = CostBudget(
1634
- max_input_tokens=int(cost_cfg.get("max_input_tokens", 50_000)),
1635
- max_output_tokens=int(cost_cfg.get("max_output_tokens", 20_000)),
1636
- max_calls=int(cost_cfg.get("max_calls", 10)),
1637
- max_total_usd=float(cost_cfg.get("max_total_usd", 0.0) or 0.0),
1638
- )
1639
- rounds = _resolve_rounds(args, ai_cfg)
1640
- responses = consult(
1641
- members, question, budget,
1642
- table=table, project=project,
1643
- original_ask=args.original_ask, rounds=rounds,
1644
- advisor_plans=advisor_plans,
1645
- )
1646
- # Pipeline order (R4 verdict): deliberation → peer-review → consensus
1647
- # → synthesis. Peer-review anonymises only deliberation outputs;
1648
- # consensus-scoring runs on the de-anonymised findings.
1649
- persona_labels = build_persona_labels(advisor_plans, billable)
1650
- peer_review = _maybe_run_peer_review(
1651
- ai_cfg, args, question, members, responses, budget, table, project,
1652
- persona_labels=persona_labels,
1653
- )
1654
- consensus = _maybe_run_consensus(
1655
- ai_cfg, question, members, responses, budget, table, project, args,
1656
- )
1657
- estimated_total = sum(e.total_usd for e in estimates)
1658
- actual_total = 0.0
1659
- all_responses: list[CouncilResponse] = list(responses)
1660
- if peer_review is not None:
1661
- all_responses.extend(peer_review.responses)
1662
- if consensus is not None:
1663
- all_responses.extend(consensus.extraction_responses)
1664
- all_responses.extend(consensus.scoring_responses)
1665
- for r in all_responses:
1666
- if r.error:
1667
- continue
1668
- ce = estimate_cost(r.provider, r.model, r.input_tokens, r.output_tokens, table)
1669
- actual_total += ce.total_usd
1670
- payload = {
1671
- "schema_version": SCHEMA_VERSION,
1672
- "mode": question.mode,
1673
- "prompt_mode": getattr(args, "prompt_mode", None),
1674
- "prose_synthesis": getattr(args, "prose_synthesis", None),
1675
- "peer_review_enabled": _peer_review_active(ai_cfg, args),
1676
- "artefact": artefact,
1677
- "original_ask": args.original_ask,
1678
- "members": [f"{m.name}/{m.model}" for m in members],
1679
- "rounds": rounds,
1680
- "cost_usd_estimated": round(estimated_total, 6),
1681
- "cost_usd_actual": round(actual_total, 6),
1682
- "responses": _serialise_responses(responses),
1683
- }
1684
- if peer_review is not None:
1685
- payload["peer_review"] = _serialise_peer_review(peer_review)
1686
- if consensus is not None:
1687
- payload["consensus"] = _serialise_consensus(consensus)
1688
- out_path = _validate_council_output_path(
1689
- args.output, kind="responses", subcommand="run",
1690
- )
1691
- out_path.parent.mkdir(parents=True, exist_ok=True)
1692
- out_path.write_text(json.dumps(payload, indent=2) + "\n", encoding="utf-8")
1693
- sys.stdout.write(
1694
- f"\ncouncil:run · wrote {out_path} "
1695
- f"(estimated ${estimated_total:.4f} / actual ${actual_total:.4f})\n"
1696
- )
1697
- replay_path = _maybe_write_decision_replay(
1698
- ai_cfg=ai_cfg, lens=question.mode, out_path=out_path,
1699
- consensus=consensus, deliberation=responses,
1700
- original_ask=args.original_ask,
1701
- )
1702
- if replay_path is not None:
1703
- sys.stdout.write(f"council:run · wrote {replay_path}\n")
1704
- errors = [r for r in responses if r.error]
1705
- return 1 if errors and len(errors) == len(responses) else 0
1706
-
1707
-
1708
- def _debate_round_filename(round_number: int) -> str:
1709
- return f"debate-round-{round_number}.json"
1710
-
1711
-
1712
- def _write_debate_round(
1713
- out_dir: Path,
1714
- round_number: int,
1715
- responses: list[CouncilResponse],
1716
- *,
1717
- question: CouncilQuestion,
1718
- members: list[ExternalAIClient],
1719
- artefact: str,
1720
- original_ask: str,
1721
- total_planned_rounds: int,
1722
- table: PriceTable,
1723
- prompt_mode: str | None,
1724
- prose_synthesis: bool | None,
1725
- ) -> Path:
1726
- """Persist a single debate round as a self-contained JSON.
1727
-
1728
- Each round file mirrors the ``cmd_run`` payload shape — re-rendering
1729
- via ``council render <debate-round-N.json>`` works without special
1730
- handling. Round-specific keys (``debate_round``, ``debate_total_rounds``)
1731
- are additive so the renderer can ignore them safely.
1732
- """
1733
- out_dir.mkdir(parents=True, exist_ok=True)
1734
- actual_total = 0.0
1735
- for r in responses:
1736
- if r.error:
1737
- continue
1738
- ce = estimate_cost(r.provider, r.model, r.input_tokens, r.output_tokens, table)
1739
- actual_total += ce.total_usd
1740
- payload = {
1741
- "schema_version": SCHEMA_VERSION,
1742
- "mode": question.mode,
1743
- "prompt_mode": prompt_mode,
1744
- "prose_synthesis": prose_synthesis,
1745
- "artefact": artefact,
1746
- "original_ask": original_ask,
1747
- "members": [f"{m.name}/{m.model}" for m in members],
1748
- "debate_round": round_number,
1749
- "debate_total_rounds": total_planned_rounds,
1750
- "rounds": 1,
1751
- "cost_usd_actual": round(actual_total, 6),
1752
- "responses": _serialise_responses(responses),
1753
- }
1754
- out_path = out_dir / _debate_round_filename(round_number)
1755
- out_path.write_text(json.dumps(payload, indent=2) + "\n", encoding="utf-8")
1756
- return out_path
1757
-
1758
-
1759
- def _load_debate_seed(
1760
- path: Path,
1761
- expected_members: list[ExternalAIClient],
1762
- ) -> list[CouncilResponse]:
1763
- """Load `--continue-as-debate` seed: round-1 responses from a prior session.
1764
-
1765
- The seed file must be the JSON written by ``cmd_run`` (or a prior
1766
- debate round). Members + models must match the current invocation —
1767
- a mismatch is a hard error per the Phase 7 contract, not a silent
1768
- fallback. The host agent surfaces the mismatch and asks the user
1769
- to either re-run with matching members or drop ``--continue-as-debate``.
1770
- """
1771
- if not path.exists():
1772
- raise FileNotFoundError(
1773
- f"--continue-as-debate path not found: {path}"
1774
- )
1775
- payload = json.loads(path.read_text(encoding="utf-8"))
1776
- source_members = list(payload.get("members") or [])
1777
- expected_labels = [f"{m.name}/{m.model}" for m in expected_members]
1778
- if source_members != expected_labels:
1779
- raise CouncilDisabledError(
1780
- f"--continue-as-debate member mismatch: source session has "
1781
- f"{source_members!r}, current invocation has {expected_labels!r}. "
1782
- f"Re-run with matching members or drop --continue-as-debate."
1783
- )
1784
- return _deserialise_responses(payload.get("responses") or [])
1785
-
1786
-
1787
- def _make_debate_continue_prompt(
1788
- *, auto_continue: bool,
1789
- stream: Any = None,
1790
- ) -> Any:
1791
- """Build the on_continue callback for `run_debate()`.
1792
-
1793
- ``--auto-continue`` returns ``None`` so the orchestrator skips the
1794
- gate entirely (still subject to the hard-cap check). Interactive
1795
- mode prints the checkpoint line and reads y/N from stdin.
1796
- """
1797
- if auto_continue:
1798
- return None
1799
- out = stream or sys.stdout
1800
-
1801
- def _prompt(checkpoint: DebateCheckpoint) -> bool:
1802
- out.write(
1803
- f"\ndebate:checkpoint round={checkpoint.completed_round}/"
1804
- f"{checkpoint.total_planned_rounds} "
1805
- f"cost_so_far=${checkpoint.cost_so_far_usd:.4f} "
1806
- f"next_round_estimate=${checkpoint.next_round_estimate_usd:.4f} "
1807
- f"— continue? [y/N]: "
1808
- )
1809
- out.flush()
1810
- try:
1811
- answer = sys.stdin.readline().strip().lower()
1812
- except (EOFError, KeyboardInterrupt):
1813
- return False
1814
- return answer in {"y", "yes"}
1815
-
1816
- return _prompt
1817
-
1818
-
1819
- def cmd_debate(
1820
- args: argparse.Namespace,
1821
- *,
1822
- settings: dict[str, Any] | None = None,
1823
- members: list[ExternalAIClient] | None = None,
1824
- table: PriceTable | None = None,
1825
- ) -> int:
1826
- """Run a multi-round debate with progressive cost disclosure.
1827
-
1828
- Phase 7 contract: each member produces an initial position in
1829
- Round 1, then rebuts the strongest opposing position in subsequent
1830
- rounds. The orchestrator pauses after each round and asks the user
1831
- to continue (``--auto-continue`` bypasses the prompt). Round files
1832
- are persisted incrementally so an interrupted debate leaves a
1833
- recoverable trail.
1834
- """
1835
- if settings is None:
1836
- settings = load_settings()
1837
- ai_cfg = (settings.get("ai_council") or {}) if isinstance(settings, dict) else {}
1838
- advisor_plans = _build_advisor_plans(ai_cfg, REPO_ROOT)
1839
- explicit_overrides = _parse_model_overrides(getattr(args, "model", None))
1840
- skipped: list[dict[str, Any]] = []
1841
- if members is None:
1842
- members = build_members(
1843
- settings,
1844
- invocation_mode=args.mode_override,
1845
- model_overrides=_advisor_model_overrides(
1846
- advisor_plans, explicit_overrides,
1847
- ),
1848
- siblings_overrides=_parse_siblings_overrides(
1849
- getattr(args, "siblings", None),
1850
- ),
1851
- skipped=skipped,
1852
- )
1853
- if table is None:
1854
- table = load_prices()
1855
- question, artefact = build_question(
1856
- input_path=Path(args.question), input_mode=args.input_mode,
1857
- max_tokens=_resolve_max_tokens(args, ai_cfg),
1858
- prompt_mode_override="debate",
1859
- )
1860
- proceed, gate_exit, _necessity_result = _necessity_gate(
1861
- prompt=question.user_prompt,
1862
- lens="debate",
1863
- invocation=getattr(args, "invocation", "agent"),
1864
- proceed_anyway=getattr(args, "proceed_anyway", False),
1865
- ai_cfg=ai_cfg,
1866
- original_ask=getattr(args, "original_ask", "") or "",
1867
- )
1868
- if not proceed:
1869
- return gate_exit
1870
- _size_fit_gate(
1871
- prompt=question.user_prompt,
1872
- lens="debate",
1873
- members=members,
1874
- ai_cfg=ai_cfg,
1875
- )
1876
- project = detect_project_context(REPO_ROOT)
1877
- billable = [m for m in members if getattr(m, "billable", True)]
1878
-
1879
- # Resolve round count: explicit --rounds wins; otherwise default 2.
1880
- # Hard ceiling: ai_council.debate_max_rounds (Phase 0 reserved key).
1881
- max_rounds_cap = int(ai_cfg.get("debate_max_rounds", 4))
1882
- requested = (
1883
- int(args.rounds) if getattr(args, "rounds", None) is not None else 2
1884
- )
1885
- if requested < 1:
1886
- raise argparse.ArgumentTypeError(
1887
- f"--rounds must be >= 1 (got {requested})"
1888
- )
1889
- if requested > max_rounds_cap:
1890
- raise argparse.ArgumentTypeError(
1891
- f"--rounds={requested} exceeds debate_max_rounds={max_rounds_cap}; "
1892
- f"raise the cap in agents/settings/.ai-council.yml or lower --rounds."
1893
- )
1894
- rounds = requested
1895
-
1896
- estimates = estimate(
1897
- question, billable, table,
1898
- project=project, original_ask=args.original_ask,
1899
- advisor_plans=advisor_plans,
1900
- )
1901
- per_round_usd = sum(e.total_usd for e in estimates)
1902
- projected_total = per_round_usd * rounds
1903
- sys.stdout.write(
1904
- f"council:debate · members={len(members)} (billable={len(billable)}) "
1905
- f"· rounds={rounds} (cap={max_rounds_cap})\n"
1906
- )
1907
- advisor_summary = _format_advisor_summary(advisor_plans, billable)
1908
- if advisor_summary:
1909
- sys.stdout.write(advisor_summary + "\n")
1910
- if skipped:
1911
- sys.stdout.write(format_install_hints(skipped) + "\n")
1912
- sys.stdout.write(
1913
- format_estimate_table(billable, estimates) + "\n"
1914
- )
1915
- sys.stdout.write(
1916
- f" × {rounds} rounds (worst case, before progressive disclosure)\n"
1917
- f" PROJECTED TOTAL: ${projected_total:.4f}\n"
1918
- )
1919
-
1920
- # Phase 8 — pre-flight cost disclosure + hard refusal cap.
1921
- debate_estimate = estimate_debate_cost(
1922
- question, members, table,
1923
- rounds=rounds, project=project,
1924
- original_ask=args.original_ask,
1925
- advisor_plans=advisor_plans,
1926
- )
1927
- disc_mode, disc_threshold, disc_show = _resolve_cost_disclosure(
1928
- ai_cfg, "debate",
1929
- )
1930
- should_disclose = (
1931
- disc_mode == "always"
1932
- or (
1933
- disc_mode == "above_threshold"
1934
- and debate_estimate.expected_usd > disc_threshold
1935
- )
1936
- )
1937
- if should_disclose:
1938
- sys.stdout.write(
1939
- _format_cost_disclosure(
1940
- debate_estimate, lens="debate", show_per_member=disc_show,
1941
- )
1942
- )
1943
- cap = _debate_refusal_cap(ai_cfg)
1944
- if cap > 0 and debate_estimate.high_usd > cap:
1945
- sys.stderr.write(
1946
- f"❌ council:debate refused · high-end estimate "
1947
- f"${debate_estimate.high_usd:.4f} exceeds "
1948
- f"debate.max_cost_usd=${cap:.2f}. Lower --rounds, drop "
1949
- f"members, or raise the cap in agents/settings/.ai-council.yml.\n"
1950
- )
1951
- return 4
1952
-
1953
- if not args.confirm:
1954
- sys.stdout.write(
1955
- "\nNo --confirm flag — estimate only. Re-run with --confirm to "
1956
- "start the debate.\n"
1957
- )
1958
- return 0
1959
-
1960
- cost_cfg = ai_cfg.get("cost_budget") or {}
1961
- budget = CostBudget(
1962
- max_input_tokens=int(cost_cfg.get("max_input_tokens", 50_000)),
1963
- max_output_tokens=int(cost_cfg.get("max_output_tokens", 20_000)),
1964
- max_calls=int(cost_cfg.get("max_calls", 10)),
1965
- max_total_usd=float(cost_cfg.get("max_total_usd", 0.0) or 0.0),
1966
- )
1967
-
1968
- out_dir = _validate_council_output_path(
1969
- args.output, kind="responses", subcommand="debate",
1970
- )
1971
- seed: list[CouncilResponse] | None = None
1972
- if getattr(args, "continue_as_debate", None):
1973
- seed = _load_debate_seed(Path(args.continue_as_debate), billable)
1974
- sys.stdout.write(
1975
- f"council:debate · seeding round 1 from "
1976
- f"{args.continue_as_debate} ({len(seed)} responses)\n"
1977
- )
1978
-
1979
- written: list[Path] = []
1980
-
1981
- def _on_round_complete(round_number: int, results: list[CouncilResponse]) -> None:
1982
- path = _write_debate_round(
1983
- out_dir, round_number, results,
1984
- question=question, members=members,
1985
- artefact=artefact, original_ask=args.original_ask,
1986
- total_planned_rounds=rounds, table=table,
1987
- prompt_mode="debate",
1988
- prose_synthesis=getattr(args, "prose_synthesis", None),
1989
- )
1990
- written.append(path)
1991
- errors = [r for r in results if r.error]
1992
- sys.stdout.write(
1993
- f"council:debate · wrote {path} "
1994
- f"({len(results) - len(errors)}/{len(results)} ok)\n"
1995
- )
1996
-
1997
- on_continue = _make_debate_continue_prompt(
1998
- auto_continue=bool(getattr(args, "auto_continue", False)),
1999
- )
2000
-
2001
- try:
2002
- all_rounds = run_debate(
2003
- members, question,
2004
- budget=budget, table=table, project=project,
2005
- original_ask=args.original_ask,
2006
- max_rounds=rounds,
2007
- on_round_complete=_on_round_complete,
2008
- on_continue=on_continue,
2009
- advisor_plans=advisor_plans,
2010
- seed_round_1=seed,
2011
- )
2012
- except DebateCapExceeded as exc:
2013
- sys.stderr.write(
2014
- f"❌ council:debate cap reached after round {exc.completed_round}: "
2015
- f"{exc}\n"
2016
- f"Partial debate persisted under {out_dir} "
2017
- f"({len(written)} rounds).\n"
2018
- )
2019
- return 3
2020
-
2021
- actual_total = 0.0
2022
- for rnd in all_rounds:
2023
- for r in rnd:
2024
- if r.error:
2025
- continue
2026
- ce = estimate_cost(
2027
- r.provider, r.model, r.input_tokens, r.output_tokens, table,
2028
- )
2029
- actual_total += ce.total_usd
2030
- sys.stdout.write(
2031
- f"\ncouncil:debate · {len(all_rounds)} round(s) complete · "
2032
- f"actual ${actual_total:.4f} (cap projection ${projected_total:.4f})\n"
2033
- )
2034
- errors_last = [r for r in all_rounds[-1] if r.error] if all_rounds else []
2035
- return 1 if errors_last and len(errors_last) == len(all_rounds[-1]) else 0
2036
-
2037
-
2038
- def cmd_render(args: argparse.Namespace) -> int:
2039
- """Re-render a saved responses JSON to the markdown report.
2040
-
2041
- Lens resolution order: explicit ``--prompt-mode`` > ``prompt_mode``
2042
- in the payload > ``mode`` in the payload > ``None`` (default decision
2043
- template). R4 Q4 escape hatch ``--prose-synthesis`` overrides the
2044
- table. ``--output`` writes to ``agents/runtime/council/sessions/`` (enforced);
2045
- omit it for stdout.
2046
- """
2047
- payload = json.loads(Path(args.responses).read_text(encoding="utf-8"))
2048
- items = payload.get("responses") or []
2049
- explicit = getattr(args, "prompt_mode", None)
2050
- mode = explicit or payload.get("prompt_mode") or payload.get("mode")
2051
- prose = getattr(args, "prose_synthesis", None)
2052
- if prose is None:
2053
- prose = payload.get("prose_synthesis")
2054
- consensus = _deserialise_consensus(payload.get("consensus"))
2055
- peer_review = _deserialise_peer_review(payload.get("peer_review"))
2056
- body = render(
2057
- _deserialise_responses(items),
2058
- mode=mode,
2059
- prose_synthesis=prose,
2060
- consensus=consensus,
2061
- peer_review=peer_review,
2062
- )
2063
- if getattr(args, "output", None):
2064
- out_path = _validate_council_output_path(
2065
- args.output, kind="sessions", subcommand="render",
2066
- )
2067
- out_path.parent.mkdir(parents=True, exist_ok=True)
2068
- out_path.write_text(body + "\n", encoding="utf-8")
2069
- sys.stdout.write(f"council:render · wrote {out_path}\n")
2070
- return 0
2071
- sys.stdout.write(body + "\n")
2072
- return 0
2073
-
2074
-
2075
- def _cmd_replay_low_impact_stats(args: argparse.Namespace) -> int:
2076
- """Summarise the session's ``low-impact-resolutions.md`` (Phase 11).
2077
-
2078
- The log file lives next to the ``responses`` JSON. Missing or empty
2079
- log → prints an explicit "no entries" line and returns 0 (a session
2080
- with no low-impact resolutions is not an error).
2081
- """
2082
- from scripts.ai_council.low_impact import ( # noqa: WPS433 — local import
2083
- parse_low_impact_log,
2084
- render_low_impact_stats,
2085
- )
2086
-
2087
- responses_path = Path(args.responses)
2088
- log_path = responses_path.parent / "low-impact-resolutions.md"
2089
- if not log_path.exists():
2090
- sys.stdout.write(
2091
- "council:replay · no low-impact-resolutions.md alongside "
2092
- f"{responses_path} — session had no fast-path entries.\n",
2093
- )
2094
- return 0
2095
- body = log_path.read_text(encoding="utf-8")
2096
- stats = parse_low_impact_log(body)
2097
- out = render_low_impact_stats(stats)
2098
- if getattr(args, "output", None):
2099
- target = _validate_council_output_path(
2100
- args.output, kind="sessions", subcommand="replay",
2101
- )
2102
- target.parent.mkdir(parents=True, exist_ok=True)
2103
- target.write_text(out, encoding="utf-8")
2104
- sys.stdout.write(f"council:replay · wrote {target}\n")
2105
- return 0
2106
- sys.stdout.write(out)
2107
- return 0
2108
-
2109
-
2110
- def cmd_replay(args: argparse.Namespace) -> int:
2111
- """Re-render the ``decision-replay.md`` audit trail (Phase 9).
2112
-
2113
- Reads a saved ``council:run`` JSON payload, rebuilds the consensus
2114
- bundle, and emits the replay markdown to stdout (default) or to
2115
- ``--output``. Pure re-projection — no model calls. Returns 2 when
2116
- the payload lacks consensus data (Phase 9 prerequisite).
2117
-
2118
- When ``--low-impact-stats`` is set, the consensus replay is skipped
2119
- and the session's ``low-impact-resolutions.md`` (Phase 11) is
2120
- summarised instead — count, status breakdown, members used, cost.
2121
- """
2122
- if getattr(args, "low_impact_stats", False):
2123
- return _cmd_replay_low_impact_stats(args)
2124
- payload = json.loads(Path(args.responses).read_text(encoding="utf-8"))
2125
- consensus = _deserialise_consensus(payload.get("consensus"))
2126
- if consensus is None:
2127
- sys.stderr.write(
2128
- "❌ council:replay: payload has no `consensus` block — "
2129
- "rerun with consensus_scoring enabled for this lens.\n"
2130
- )
2131
- return 2
2132
- deliberation = _deserialise_responses(payload.get("responses") or [])
2133
- include_args = (
2134
- bool(args.include_member_arguments)
2135
- if args.include_member_arguments is not None
2136
- else True
2137
- )
2138
- body = render_decision_replay(
2139
- DecisionReplayInputs(
2140
- findings=list(consensus.findings),
2141
- scores=list(consensus.scores),
2142
- metadata=dict(consensus.metadata),
2143
- deliberation=deliberation,
2144
- original_ask=str(payload.get("original_ask", "")),
2145
- include_member_arguments=include_args,
2146
- ),
2147
- )
2148
- if getattr(args, "output", None):
2149
- out_path = _validate_council_output_path(
2150
- args.output, kind="sessions", subcommand="replay",
2151
- )
2152
- out_path.parent.mkdir(parents=True, exist_ok=True)
2153
- out_path.write_text(body, encoding="utf-8")
2154
- sys.stdout.write(f"council:replay · wrote {out_path}\n")
2155
- else:
2156
- sys.stdout.write(body)
2157
- return 0
2158
-
2159
-
2160
- # ── argparse + main ─────────────────────────────────────────────────
2161
-
2162
-
2163
- def _parse_model_overrides(items: list[str] | None) -> dict[str, str]:
2164
- """Parse repeated `--model name=model-id` flags into a dict.
2165
-
2166
- Empty/None list → empty dict (no override). Bad shape raises
2167
- `argparse.ArgumentTypeError` so the CLI surfaces the error.
2168
- """
2169
- out: dict[str, str] = {}
2170
- for raw in items or []:
2171
- if "=" not in raw:
2172
- raise argparse.ArgumentTypeError(
2173
- f"--model expects '<member>=<model-id>', got {raw!r}."
2174
- )
2175
- name, model = raw.split("=", 1)
2176
- name, model = name.strip(), model.strip()
2177
- if not name or not model:
2178
- raise argparse.ArgumentTypeError(
2179
- f"--model member and model-id must both be non-empty: {raw!r}."
2180
- )
2181
- out[name] = model
2182
- return out
2183
-
2184
-
2185
- def _parse_siblings_overrides(items: list[str] | None) -> dict[str, list[str]]:
2186
- """Parse repeated `--siblings name=model1,model2[,...]` flags.
2187
-
2188
- Requires ≥ 2 distinct, non-empty models per provider — sibling
2189
- mode without diversity has no purpose. Repeating the same provider
2190
- flag is rejected as ambiguous.
2191
- """
2192
- out: dict[str, list[str]] = {}
2193
- for raw in items or []:
2194
- if "=" not in raw:
2195
- raise argparse.ArgumentTypeError(
2196
- f"--siblings expects '<member>=<model1>,<model2>[,...]', got {raw!r}."
2197
- )
2198
- name, models_csv = raw.split("=", 1)
2199
- name = name.strip()
2200
- models = [m.strip() for m in models_csv.split(",") if m.strip()]
2201
- if not name or not models:
2202
- raise argparse.ArgumentTypeError(
2203
- f"--siblings member and model list must both be non-empty: {raw!r}."
2204
- )
2205
- if len(set(models)) < 2:
2206
- raise argparse.ArgumentTypeError(
2207
- f"--siblings requires ≥ 2 distinct models for {name!r}, got {models!r}."
2208
- )
2209
- if name in out:
2210
- raise argparse.ArgumentTypeError(
2211
- f"--siblings repeated for member {name!r}; combine into one flag."
2212
- )
2213
- out[name] = models
2214
- return out
2215
-
2216
-
2217
- def _add_common_input_args(p: argparse.ArgumentParser) -> None:
2218
- p.add_argument("question", type=str,
2219
- help="Path to the question file (text or roadmap).")
2220
- p.add_argument("--input-mode", choices=["prompt", "roadmap"],
2221
- default="prompt",
2222
- help="How to bundle the file (default: prompt).")
2223
- p.add_argument("--prompt-mode",
2224
- choices=["pr", "design", "optimize", "analysis"],
2225
- default=None, dest="prompt_mode",
2226
- help="Lens-override for the system-prompt addendum. "
2227
- "The bundle shape stays as --input-mode; only "
2228
- "the per-mode neutrality addendum is swapped "
2229
- "(see scripts/ai_council/prompts.py _MODE_TABLE). "
2230
- "Routed by the /council pr|design|optimize|"
2231
- "analysis wrappers.")
2232
- p.add_argument("--max-tokens", type=int, default=None,
2233
- help="Per-member output budget. Default reads "
2234
- "ai_council.max_output_tokens from .agent-settings.yml "
2235
- "(2048 if unset). 0 = unlimited (widened to the safe "
2236
- "provider ceiling before the SDK call).")
2237
- p.add_argument("--mode-override", choices=["api", "manual"], default=None,
2238
- help="Override every member's transport mode.")
2239
- p.add_argument("--model", action="append", default=None, dest="model",
2240
- metavar="MEMBER=MODEL_ID",
2241
- help="Per-invocation model override, e.g. "
2242
- "--model anthropic=claude-sonnet-4-5. Repeatable. "
2243
- "Wins over `ai_council.members.<name>.model` in "
2244
- ".agent-settings.yml; the settings file is not "
2245
- "modified.")
2246
- p.add_argument("--siblings", action="append", default=None, dest="siblings",
2247
- metavar="MEMBER=MODEL1,MODEL2[,...]",
2248
- help="Fan one provider out to ≥ 2 sibling models in a "
2249
- "single run, e.g. --siblings anthropic=claude-sonnet-4-5,"
2250
- "claude-opus-4-1. Each model becomes its own billable "
2251
- "member with independent cost tracking. Mutually "
2252
- "exclusive with --model for the same provider; "
2253
- "requires the provider to be enabled with mode=api. "
2254
- "Single-provider degraded-run strategy per ai-council "
2255
- "skill.")
2256
- p.add_argument("--original-ask", default="",
2257
- help="The user's framing sentence (flows into handoff).")
2258
- p.add_argument("--peer-review", dest="peer_review", action="store_true",
2259
- default=False,
2260
- help="Run an anonymous peer-review pass after the main "
2261
- "deliberation. Each member critiques the others' "
2262
- "(anonymised) responses for blind spots before "
2263
- "synthesis. Adds N extra API calls. Opt-in per the "
2264
- "R2 verdict; also accepts ai_council.peer_review."
2265
- "enabled: true in agents/settings/.ai-council.yml.")
2266
-
2267
-
2268
- def cmd_shadow_report(args: argparse.Namespace) -> int:
2269
- """Print the 7-day rolling disagreement rate + SLO status (step-9 P10)."""
2270
- from pathlib import Path as _Path
2271
-
2272
- from scripts.ai_council import shadow_dispatch as _sd
2273
-
2274
- log_path = _Path(args.log) if args.log else _sd.SHADOW_LOG_PATH
2275
- rate, n = _sd.compute_disagreement_rate(
2276
- log_path, window_days=int(args.window_days)
2277
- )
2278
- print(_sd.slo_banner(rate, n))
2279
- return 0
2280
-
2281
-
2282
- def cmd_quota(
2283
- args: argparse.Namespace,
2284
- *,
2285
- settings: dict[str, Any] | None = None,
2286
- ) -> int:
2287
- """Dump today's CLI-quota state (step-8 P1, D1).
2288
-
2289
- Reads ``~/.event4u/agent-config/cli-calls.json`` plus the configured
2290
- caps from ``.agent-settings.yml`` and prints one line per provider
2291
- that has a configured ``max_calls_per_day``. ``--reset <provider>``
2292
- (gated behind ``--confirm``) clears the counter for that provider.
2293
- """
2294
- s = settings if settings is not None else load_settings()
2295
- ai_cfg = (s.get("ai_council") or {}) if isinstance(s, dict) else {}
2296
- cli_budget_cfg = (
2297
- (ai_cfg.get("cli_call_budget") or {}) if isinstance(ai_cfg, dict) else {}
2298
- )
2299
- caps = (
2300
- (cli_budget_cfg.get("max_calls_per_day") or {})
2301
- if isinstance(cli_budget_cfg, dict)
2302
- else {}
2303
- )
2304
- warn_at = (
2305
- float(cli_budget_cfg.get("warn_at", 0.8))
2306
- if isinstance(cli_budget_cfg, dict)
2307
- else 0.8
2308
- )
2309
-
2310
- if getattr(args, "reset", None):
2311
- provider = args.reset
2312
- if not getattr(args, "confirm", False):
2313
- sys.stderr.write(
2314
- f"❌ council:quota: --reset {provider} requires --confirm.\n"
2315
- )
2316
- return 2
2317
- reset_cli_call_counts(provider=provider)
2318
- sys.stdout.write(f"council:quota · reset · {provider}\n")
2319
- return 0
2320
-
2321
- counts = load_cli_call_counts()
2322
- if not caps:
2323
- sys.stdout.write(
2324
- "council:quota · no providers have a configured "
2325
- "cli_call_budget.max_calls_per_day cap.\n"
2326
- )
2327
- return 0
2328
- for provider in sorted(caps):
2329
- limit = int(caps[provider])
2330
- used = int(counts.get(provider, 0))
2331
- ratio = used / limit if limit > 0 else 0.0
2332
- status = "ok"
2333
- if used >= limit:
2334
- status = "exhausted"
2335
- elif ratio >= warn_at:
2336
- status = "warn"
2337
- sys.stdout.write(
2338
- f"council:quota · {provider} · {used}/{limit} · {status}\n"
2339
- )
2340
- return 0
2341
-
2342
-
2343
- def build_parser() -> argparse.ArgumentParser:
2344
- parser = argparse.ArgumentParser(
2345
- prog="agent-config council",
2346
- description="Non-interactive council orchestration.",
2347
- )
2348
- sub = parser.add_subparsers(dest="cmd", required=True)
2349
-
2350
- p_est = sub.add_parser("estimate", help="Pre-call cost preview (no spend).")
2351
- _add_common_input_args(p_est)
2352
- p_est.add_argument("--debate", action="store_true", default=False,
2353
- help="Render the round-by-round projection for a "
2354
- "debate run (one call per member per round). "
2355
- "Progressive disclosure may stop the debate "
2356
- "early — this is an upper bound.")
2357
- p_est.add_argument("--rounds", type=int, default=None,
2358
- help="Debate round count for --debate. Defaults to "
2359
- "ai_council.min_rounds (typically 2); capped "
2360
- "at ai_council.debate_max_rounds (typically 4).")
2361
-
2362
- p_run = sub.add_parser("run", help="Run the council; --confirm required to spend.")
2363
- _add_common_input_args(p_run)
2364
- p_run.add_argument("--output", required=True,
2365
- help="Path to write the responses JSON.")
2366
- p_run.add_argument("--confirm", action="store_true",
2367
- help="Required to actually invoke the council.")
2368
- p_run.add_argument("--rounds", type=int, default=None,
2369
- help="Number of debate rounds (1-3). Explicit override; "
2370
- "wins over --depth. Defaults to ai_council.min_rounds "
2371
- "in .agent-settings.yml (or 2 if unset).")
2372
- p_run.add_argument("--depth", choices=["standard", "deep"], default="standard",
2373
- help="Reasoning-depth tier. 'deep' floors rounds at "
2374
- "ai_council.deep_min_rounds (max'd with min_rounds) "
2375
- "for architecture, refactoring, or bug-diagnosis "
2376
- "artefacts. Set by the host agent when the consuming "
2377
- "rule/skill/command declares council_depth: deep. "
2378
- "Overridden by explicit --rounds.")
2379
- p_run.add_argument("--invocation", choices=["agent", "user_explicit"],
2380
- default="agent",
2381
- help="Source signal for the necessity classifier "
2382
- "(Phase 6). 'agent' = autonomous (default; silent "
2383
- "skip when unnecessary). 'user_explicit' = manual "
2384
- "user invocation (educate path when unnecessary, "
2385
- "requires --proceed-anyway to override).")
2386
- p_run.add_argument("--proceed-anyway", action="store_true",
2387
- dest="proceed_anyway", default=False,
2388
- help="Override the necessity-classifier skip / educate "
2389
- "verdict for this invocation (Phase 6). Has no "
2390
- "effect when the classifier verdict is "
2391
- "`necessary` or `borderline`.")
2392
- p_run.add_argument("--single", action="store_true", default=False,
2393
- help="Dispatch to a single member from "
2394
- "routing.solo_member_fallback_chain (step-9 P9). "
2395
- "Falls back to the full council when the chain is "
2396
- "empty or no chain member is runtime-present. "
2397
- "Overridden by env "
2398
- "AGENT_CONFIG_FORCE_FULL_COUNCIL=1.")
2399
- _add_prose_synthesis_arg(p_run)
2400
-
2401
- p_deb = sub.add_parser(
2402
- "debate",
2403
- help="Multi-round debate with progressive cost disclosure (Phase 7).",
2404
- )
2405
- _add_common_input_args(p_deb)
2406
- p_deb.add_argument("--output", required=True,
2407
- help="Directory to write debate-round-N.json files.")
2408
- p_deb.add_argument("--confirm", action="store_true",
2409
- help="Required to actually start the debate.")
2410
- p_deb.add_argument("--rounds", type=int, default=None,
2411
- help="Number of debate rounds (default 2). Capped by "
2412
- "ai_council.debate_max_rounds in agents/settings/.ai-council.yml.")
2413
- p_deb.add_argument("--auto-continue", action="store_true",
2414
- default=False, dest="auto_continue",
2415
- help="Skip the between-round y/N prompt. The hard cap "
2416
- "against cost_budget.max_total_usd still applies.")
2417
- p_deb.add_argument("--continue-as-debate", default=None,
2418
- dest="continue_as_debate", metavar="PATH",
2419
- help="Seed round 1 from an existing council session "
2420
- "JSON. Members + models must match the current "
2421
- "invocation.")
2422
- p_deb.add_argument("--invocation", choices=["agent", "user_explicit"],
2423
- default="agent",
2424
- help="Source signal for the necessity classifier "
2425
- "(Phase 6). 'agent' = autonomous (default; silent "
2426
- "skip when unnecessary). 'user_explicit' = manual "
2427
- "user invocation (educate path when unnecessary, "
2428
- "requires --proceed-anyway to override).")
2429
- p_deb.add_argument("--proceed-anyway", action="store_true",
2430
- dest="proceed_anyway", default=False,
2431
- help="Override the necessity-classifier skip / educate "
2432
- "verdict for this invocation (Phase 6). Has no "
2433
- "effect when the classifier verdict is "
2434
- "`necessary` or `borderline`.")
2435
- _add_prose_synthesis_arg(p_deb)
2436
-
2437
- p_ren = sub.add_parser("render", help="Re-render a saved responses JSON.")
2438
- p_ren.add_argument("responses",
2439
- help="Path to the JSON written by `council run`.")
2440
- p_ren.add_argument("--prompt-mode",
2441
- choices=["default", "pr", "design", "optimize", "analysis",
2442
- "prompt", "roadmap", "diff", "files"],
2443
- default=None, dest="prompt_mode",
2444
- help="Override the synthesis-template lens. Defaults "
2445
- "to the `mode` recorded in the responses JSON.")
2446
- p_ren.add_argument("--output", default=None,
2447
- help="Write the rendered markdown to a file under "
2448
- "agents/runtime/council/sessions/ (enforced). Omit for "
2449
- "stdout. Prefer this over shell redirects so "
2450
- "the canonical-path check fires at write-time.")
2451
- _add_prose_synthesis_arg(p_ren)
2452
-
2453
- p_rep = sub.add_parser(
2454
- "replay",
2455
- help="Re-render decision-replay.md from a saved responses JSON (Phase 9).",
2456
- )
2457
- p_rep.add_argument("responses",
2458
- help="Path to the JSON written by `council run`.")
2459
- p_rep.add_argument("--output", default=None,
2460
- help="Optional file to write the replay markdown. "
2461
- "Defaults to stdout.")
2462
- rep_group = p_rep.add_mutually_exclusive_group()
2463
- rep_group.add_argument("--redact-member-arguments",
2464
- dest="include_member_arguments",
2465
- action="store_const", const=False, default=None,
2466
- help="Emit the redacted view (consensus + dissent "
2467
- "counts only, no per-member arguments).")
2468
- rep_group.add_argument("--include-member-arguments",
2469
- dest="include_member_arguments",
2470
- action="store_const", const=True,
2471
- help="Include per-member arguments (default).")
2472
- p_rep.add_argument("--low-impact-stats", action="store_true", default=False,
2473
- help="Skip the decision replay and print a summary of "
2474
- "low-impact fast-path resolutions for the session "
2475
- "(parses `low-impact-resolutions.md` alongside the "
2476
- "responses JSON).")
2477
-
2478
- p_quo = sub.add_parser(
2479
- "quota",
2480
- help="Dump today's CLI-quota state and configured caps (step-8 P1).",
2481
- )
2482
- p_quo.add_argument("--reset", default=None, metavar="PROVIDER",
2483
- help="Reset today's counter for one provider. "
2484
- "Requires --confirm.")
2485
- p_quo.add_argument("--confirm", action="store_true", default=False,
2486
- help="Confirm a mutating --reset operation.")
2487
-
2488
- p_sha = sub.add_parser(
2489
- "shadow-report",
2490
- help="Read agents/runtime/council/shadow-log.jsonl and print the 7-day "
2491
- "rolling disagreement rate + SLO status (step-9 P10).",
2492
- )
2493
- p_sha.add_argument("--log", default=None,
2494
- help="Path to the shadow log (default: "
2495
- "agents/runtime/council/shadow-log.jsonl).")
2496
- p_sha.add_argument("--window-days", type=int, default=7,
2497
- help="Rolling window in days (default: 7).")
2498
-
2499
- return parser
2500
-
2501
-
2502
- def _add_prose_synthesis_arg(p: argparse.ArgumentParser) -> None:
2503
- """R4 Q4 escape hatch — toggle structured vs prose synthesis."""
2504
- group = p.add_mutually_exclusive_group()
2505
- group.add_argument("--prose-synthesis", dest="prose_synthesis",
2506
- action="store_const", const=True, default=None,
2507
- help="Force open-ended prose synthesis (bare slot) "
2508
- "regardless of lens. R4 Q4 escape hatch.")
2509
- group.add_argument("--no-prose-synthesis", dest="prose_synthesis",
2510
- action="store_const", const=False,
2511
- help="Force the structured default decision-lens "
2512
- "template even on a creative lens "
2513
- "(design / optimize). Symmetric escape hatch.")
2514
-
2515
-
2516
- def main(argv: list[str] | None = None) -> int:
2517
- args = build_parser().parse_args(argv)
2518
- try:
2519
- if args.cmd == "estimate":
2520
- return cmd_estimate(args)
2521
- if args.cmd == "run":
2522
- return cmd_run(args)
2523
- if args.cmd == "debate":
2524
- return cmd_debate(args)
2525
- if args.cmd == "render":
2526
- return cmd_render(args)
2527
- if args.cmd == "replay":
2528
- return cmd_replay(args)
2529
- if args.cmd == "quota":
2530
- return cmd_quota(args)
2531
- if args.cmd == "shadow-report":
2532
- return cmd_shadow_report(args)
2533
- except CouncilDisabledError as exc:
2534
- sys.stderr.write(f"❌ council:{args.cmd}: {exc}\n")
2535
- return 2
2536
- except (BundleTooLarge, InvalidModeError, FileNotFoundError,
2537
- argparse.ArgumentTypeError) as exc:
2538
- sys.stderr.write(f"❌ council:{args.cmd}: {exc}\n")
2539
- return 2
2540
- return 1
2541
-
2542
-
2543
- if __name__ == "__main__":
2544
- raise SystemExit(main())