@pennyfarthing/core 10.4.0 → 11.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 (797) hide show
  1. package/README.md +4 -4
  2. package/package.json +16 -14
  3. package/packages/core/dist/benchmark/benchmark-integration.d.ts +182 -0
  4. package/packages/core/dist/benchmark/benchmark-integration.d.ts.map +1 -0
  5. package/packages/core/dist/benchmark/benchmark-integration.js +710 -0
  6. package/packages/core/dist/benchmark/benchmark-integration.js.map +1 -0
  7. package/packages/core/dist/benchmark/benchmark-integration.test.d.ts +6 -0
  8. package/packages/core/dist/benchmark/benchmark-integration.test.d.ts.map +1 -0
  9. package/packages/core/dist/benchmark/benchmark-integration.test.js +41 -0
  10. package/packages/core/dist/benchmark/benchmark-integration.test.js.map +1 -0
  11. package/packages/core/dist/benchmark/index.d.ts +3 -0
  12. package/packages/core/dist/benchmark/index.d.ts.map +1 -0
  13. package/packages/core/dist/benchmark/index.js +5 -0
  14. package/packages/core/dist/benchmark/index.js.map +1 -0
  15. package/packages/core/dist/benchmark/job-fair-aggregator.d.ts +150 -0
  16. package/packages/core/dist/benchmark/job-fair-aggregator.d.ts.map +1 -0
  17. package/packages/core/dist/benchmark/job-fair-aggregator.js +547 -0
  18. package/packages/core/dist/benchmark/job-fair-aggregator.js.map +1 -0
  19. package/packages/core/dist/benchmark/job-fair-aggregator.test.d.ts +6 -0
  20. package/packages/core/dist/benchmark/job-fair-aggregator.test.d.ts.map +1 -0
  21. package/packages/core/dist/benchmark/job-fair-aggregator.test.js +35 -0
  22. package/packages/core/dist/benchmark/job-fair-aggregator.test.js.map +1 -0
  23. package/packages/core/dist/cli/commands/hook-chaining.test.d.ts +17 -0
  24. package/packages/core/dist/cli/commands/hook-chaining.test.d.ts.map +1 -0
  25. package/packages/core/dist/cli/commands/hook-chaining.test.js +386 -0
  26. package/packages/core/dist/cli/commands/hook-chaining.test.js.map +1 -0
  27. package/packages/core/dist/cli/commands/init.d.ts +6 -1
  28. package/packages/core/dist/cli/commands/init.d.ts.map +1 -1
  29. package/packages/core/dist/cli/commands/init.js +83 -30
  30. package/packages/core/dist/cli/commands/init.js.map +1 -1
  31. package/packages/core/dist/cli/commands/uninstall.d.ts.map +1 -1
  32. package/packages/core/dist/cli/commands/uninstall.js +20 -3
  33. package/packages/core/dist/cli/commands/uninstall.js.map +1 -1
  34. package/packages/core/dist/cli/commands/uninstall.test.d.ts +8 -0
  35. package/packages/core/dist/cli/commands/uninstall.test.d.ts.map +1 -0
  36. package/packages/core/dist/cli/commands/uninstall.test.js +120 -0
  37. package/packages/core/dist/cli/commands/uninstall.test.js.map +1 -0
  38. package/packages/core/dist/cli/commands/update.js +4 -4
  39. package/packages/core/dist/cli/commands/update.js.map +1 -1
  40. package/packages/core/dist/cli/cyclist-migration.test.js +2 -1
  41. package/packages/core/dist/cli/cyclist-migration.test.js.map +1 -1
  42. package/packages/core/dist/cli/ocean-profiles.test.js +5 -4
  43. package/packages/core/dist/cli/ocean-profiles.test.js.map +1 -1
  44. package/packages/core/dist/cli/theme-maker.test.js +5 -4
  45. package/packages/core/dist/cli/theme-maker.test.js.map +1 -1
  46. package/packages/core/dist/cli/utils/008-sprint-shard-migration.test.d.ts +15 -0
  47. package/packages/core/dist/cli/utils/008-sprint-shard-migration.test.d.ts.map +1 -0
  48. package/packages/core/dist/cli/utils/008-sprint-shard-migration.test.js +295 -0
  49. package/packages/core/dist/cli/utils/008-sprint-shard-migration.test.js.map +1 -0
  50. package/packages/core/dist/cli/utils/settings-consolidation.test.js +26 -0
  51. package/packages/core/dist/cli/utils/settings-consolidation.test.js.map +1 -1
  52. package/packages/core/dist/cli/utils/settings-merge.d.ts +128 -0
  53. package/packages/core/dist/cli/utils/settings-merge.d.ts.map +1 -0
  54. package/packages/core/dist/cli/utils/settings-merge.js +303 -0
  55. package/packages/core/dist/cli/utils/settings-merge.js.map +1 -0
  56. package/packages/core/dist/cli/utils/settings-merge.test.d.ts +15 -0
  57. package/packages/core/dist/cli/utils/settings-merge.test.d.ts.map +1 -0
  58. package/packages/core/dist/cli/utils/settings-merge.test.js +781 -0
  59. package/packages/core/dist/cli/utils/settings-merge.test.js.map +1 -0
  60. package/packages/core/dist/cli/utils/settings.d.ts.map +1 -1
  61. package/packages/core/dist/cli/utils/settings.js +3 -0
  62. package/packages/core/dist/cli/utils/settings.js.map +1 -1
  63. package/packages/core/dist/cli/utils/symlinks.d.ts +6 -16
  64. package/packages/core/dist/cli/utils/symlinks.d.ts.map +1 -1
  65. package/packages/core/dist/cli/utils/symlinks.js +100 -171
  66. package/packages/core/dist/cli/utils/symlinks.js.map +1 -1
  67. package/packages/core/dist/cli/utils/symlinks.test.d.ts +10 -0
  68. package/packages/core/dist/cli/utils/symlinks.test.d.ts.map +1 -0
  69. package/packages/core/dist/cli/utils/symlinks.test.js +266 -0
  70. package/packages/core/dist/cli/utils/symlinks.test.js.map +1 -0
  71. package/packages/core/dist/cli/utils/themes.js +1 -1
  72. package/packages/core/dist/cli/workspace.test.js +2 -5
  73. package/packages/core/dist/cli/workspace.test.js.map +1 -1
  74. package/packages/core/dist/consolidation.test.d.ts +11 -0
  75. package/packages/core/dist/consolidation.test.d.ts.map +1 -0
  76. package/packages/core/dist/consolidation.test.js +249 -0
  77. package/packages/core/dist/consolidation.test.js.map +1 -0
  78. package/packages/core/dist/index.d.ts +2 -0
  79. package/packages/core/dist/index.d.ts.map +1 -1
  80. package/packages/core/dist/index.js +4 -0
  81. package/packages/core/dist/index.js.map +1 -1
  82. package/packages/core/dist/plugins/plugin-discovery.js +1 -1
  83. package/packages/core/dist/plugins/plugin-discovery.js.map +1 -1
  84. package/packages/core/dist/plugins/plugin-discovery.test.d.ts +1 -1
  85. package/packages/core/dist/plugins/plugin-discovery.test.js +47 -36
  86. package/packages/core/dist/plugins/plugin-discovery.test.js.map +1 -1
  87. package/packages/core/dist/public/css/react.css +1 -0
  88. package/packages/core/dist/public/js/react/react.js +82 -0
  89. package/packages/core/dist/scripts/generate-report.test.js +2 -2
  90. package/packages/core/dist/scripts/generate-spider-report.test.js +2 -2
  91. package/packages/core/dist/scripts/generate-spider.test.js +2 -1
  92. package/packages/core/dist/scripts/generate-spider.test.js.map +1 -1
  93. package/packages/core/dist/server/agent-context.d.ts +5 -0
  94. package/packages/core/dist/server/agent-context.d.ts.map +1 -0
  95. package/packages/core/dist/server/agent-context.js +5 -0
  96. package/packages/core/dist/server/agent-context.js.map +1 -0
  97. package/packages/core/dist/server/agent-evaluation.d.ts +17 -0
  98. package/packages/core/dist/server/agent-evaluation.d.ts.map +1 -0
  99. package/packages/core/dist/server/agent-evaluation.js +15 -0
  100. package/packages/core/dist/server/agent-evaluation.js.map +1 -0
  101. package/packages/core/dist/server/api/agent-load.d.ts +3 -0
  102. package/packages/core/dist/server/api/agent-load.d.ts.map +1 -0
  103. package/packages/core/dist/server/api/agent-load.js +19 -0
  104. package/packages/core/dist/server/api/agent-load.js.map +1 -0
  105. package/packages/core/dist/server/api/audit-log.d.ts +3 -0
  106. package/packages/core/dist/server/api/audit-log.d.ts.map +1 -0
  107. package/packages/core/dist/server/api/audit-log.js +31 -0
  108. package/packages/core/dist/server/api/audit-log.js.map +1 -0
  109. package/packages/core/dist/server/api/background-tasks.d.ts +27 -0
  110. package/packages/core/dist/server/api/background-tasks.d.ts.map +1 -0
  111. package/packages/core/dist/server/api/background-tasks.js +56 -0
  112. package/packages/core/dist/server/api/background-tasks.js.map +1 -0
  113. package/packages/core/dist/server/api/bell.d.ts +19 -0
  114. package/packages/core/dist/server/api/bell.d.ts.map +1 -0
  115. package/packages/core/dist/server/api/bell.js +34 -0
  116. package/packages/core/dist/server/api/bell.js.map +1 -0
  117. package/packages/core/dist/server/api/code-markers.d.ts +9 -0
  118. package/packages/core/dist/server/api/code-markers.d.ts.map +1 -0
  119. package/packages/core/dist/server/api/code-markers.js +62 -0
  120. package/packages/core/dist/server/api/code-markers.js.map +1 -0
  121. package/packages/core/dist/server/api/complexity.d.ts +3 -0
  122. package/packages/core/dist/server/api/complexity.d.ts.map +1 -0
  123. package/packages/core/dist/server/api/complexity.js +47 -0
  124. package/packages/core/dist/server/api/complexity.js.map +1 -0
  125. package/packages/core/dist/server/api/context.d.ts +38 -0
  126. package/packages/core/dist/server/api/context.d.ts.map +1 -0
  127. package/packages/core/dist/server/api/context.js +144 -0
  128. package/packages/core/dist/server/api/context.js.map +1 -0
  129. package/packages/core/dist/server/api/dead-code.d.ts +3 -0
  130. package/packages/core/dist/server/api/dead-code.d.ts.map +1 -0
  131. package/packages/core/dist/server/api/dead-code.js +70 -0
  132. package/packages/core/dist/server/api/dead-code.js.map +1 -0
  133. package/packages/core/dist/server/api/dependencies.d.ts +3 -0
  134. package/packages/core/dist/server/api/dependencies.d.ts.map +1 -0
  135. package/packages/core/dist/server/api/dependencies.js +43 -0
  136. package/packages/core/dist/server/api/dependencies.js.map +1 -0
  137. package/packages/core/dist/server/api/evaluation.d.ts +3 -0
  138. package/packages/core/dist/server/api/evaluation.d.ts.map +1 -0
  139. package/packages/core/dist/server/api/evaluation.js +33 -0
  140. package/packages/core/dist/server/api/evaluation.js.map +1 -0
  141. package/packages/core/dist/server/api/file-browser.d.ts +9 -0
  142. package/packages/core/dist/server/api/file-browser.d.ts.map +1 -0
  143. package/packages/core/dist/server/api/file-browser.js +133 -0
  144. package/packages/core/dist/server/api/file-browser.js.map +1 -0
  145. package/packages/core/dist/server/api/git-fetch-cooldown.test.d.ts +10 -0
  146. package/packages/core/dist/server/api/git-fetch-cooldown.test.d.ts.map +1 -0
  147. package/packages/core/dist/server/api/git-fetch-cooldown.test.js +30 -0
  148. package/packages/core/dist/server/api/git-fetch-cooldown.test.js.map +1 -0
  149. package/packages/core/dist/server/api/git.d.ts +55 -0
  150. package/packages/core/dist/server/api/git.d.ts.map +1 -0
  151. package/packages/core/dist/server/api/git.js +382 -0
  152. package/packages/core/dist/server/api/git.js.map +1 -0
  153. package/packages/core/dist/server/api/health-score.d.ts +3 -0
  154. package/packages/core/dist/server/api/health-score.d.ts.map +1 -0
  155. package/packages/core/dist/server/api/health-score.js +47 -0
  156. package/packages/core/dist/server/api/health-score.js.map +1 -0
  157. package/packages/core/dist/server/api/hook-request.d.ts +41 -0
  158. package/packages/core/dist/server/api/hook-request.d.ts.map +1 -0
  159. package/packages/core/dist/server/api/hook-request.js +278 -0
  160. package/packages/core/dist/server/api/hook-request.js.map +1 -0
  161. package/packages/core/dist/server/api/hotspots.d.ts +3 -0
  162. package/packages/core/dist/server/api/hotspots.d.ts.map +1 -0
  163. package/packages/core/dist/server/api/hotspots.js +62 -0
  164. package/packages/core/dist/server/api/hotspots.js.map +1 -0
  165. package/packages/core/dist/server/api/identity.d.ts +17 -0
  166. package/packages/core/dist/server/api/identity.d.ts.map +1 -0
  167. package/packages/core/dist/server/api/identity.js +79 -0
  168. package/packages/core/dist/server/api/identity.js.map +1 -0
  169. package/packages/core/dist/server/api/index.d.ts +36 -0
  170. package/packages/core/dist/server/api/index.d.ts.map +1 -0
  171. package/packages/core/dist/server/api/index.js +47 -0
  172. package/packages/core/dist/server/api/index.js.map +1 -0
  173. package/packages/core/dist/server/api/mode.d.ts +24 -0
  174. package/packages/core/dist/server/api/mode.d.ts.map +1 -0
  175. package/packages/core/dist/server/api/mode.js +40 -0
  176. package/packages/core/dist/server/api/mode.js.map +1 -0
  177. package/packages/core/dist/server/api/otlp.d.ts +3 -0
  178. package/packages/core/dist/server/api/otlp.d.ts.map +1 -0
  179. package/packages/core/dist/server/api/otlp.js +40 -0
  180. package/packages/core/dist/server/api/otlp.js.map +1 -0
  181. package/packages/core/dist/server/api/permissions.d.ts +16 -0
  182. package/packages/core/dist/server/api/permissions.d.ts.map +1 -0
  183. package/packages/core/dist/server/api/permissions.js +67 -0
  184. package/packages/core/dist/server/api/permissions.js.map +1 -0
  185. package/packages/core/dist/server/api/persona.d.ts +9 -0
  186. package/packages/core/dist/server/api/persona.d.ts.map +1 -0
  187. package/packages/core/dist/server/api/persona.js +68 -0
  188. package/packages/core/dist/server/api/persona.js.map +1 -0
  189. package/packages/core/dist/server/api/portrait.d.ts +6 -0
  190. package/packages/core/dist/server/api/portrait.d.ts.map +1 -0
  191. package/packages/core/dist/server/api/portrait.js +28 -0
  192. package/packages/core/dist/server/api/portrait.js.map +1 -0
  193. package/packages/core/dist/server/api/settings.d.ts +14 -0
  194. package/packages/core/dist/server/api/settings.d.ts.map +1 -0
  195. package/packages/core/dist/server/api/settings.js +68 -0
  196. package/packages/core/dist/server/api/settings.js.map +1 -0
  197. package/packages/core/dist/server/api/spans.d.ts +3 -0
  198. package/packages/core/dist/server/api/spans.d.ts.map +1 -0
  199. package/packages/core/dist/server/api/spans.js +33 -0
  200. package/packages/core/dist/server/api/spans.js.map +1 -0
  201. package/packages/core/dist/server/api/stats.d.ts +13 -0
  202. package/packages/core/dist/server/api/stats.d.ts.map +1 -0
  203. package/packages/core/dist/server/api/stats.js +85 -0
  204. package/packages/core/dist/server/api/stats.js.map +1 -0
  205. package/packages/core/dist/server/api/story.d.ts +3 -0
  206. package/packages/core/dist/server/api/story.d.ts.map +1 -0
  207. package/packages/core/dist/server/api/story.js +15 -0
  208. package/packages/core/dist/server/api/story.js.map +1 -0
  209. package/packages/core/dist/server/api/telemetry.d.ts +3 -0
  210. package/packages/core/dist/server/api/telemetry.d.ts.map +1 -0
  211. package/packages/core/dist/server/api/telemetry.js +30 -0
  212. package/packages/core/dist/server/api/telemetry.js.map +1 -0
  213. package/packages/core/dist/server/api/theme-agents.d.ts +10 -0
  214. package/packages/core/dist/server/api/theme-agents.d.ts.map +1 -0
  215. package/packages/core/dist/server/api/theme-agents.js +39 -0
  216. package/packages/core/dist/server/api/theme-agents.js.map +1 -0
  217. package/packages/core/dist/server/api/todos.d.ts +33 -0
  218. package/packages/core/dist/server/api/todos.d.ts.map +1 -0
  219. package/packages/core/dist/server/api/todos.js +44 -0
  220. package/packages/core/dist/server/api/todos.js.map +1 -0
  221. package/packages/core/dist/server/api/token-stats.d.ts +8 -0
  222. package/packages/core/dist/server/api/token-stats.d.ts.map +1 -0
  223. package/packages/core/dist/server/api/token-stats.js +36 -0
  224. package/packages/core/dist/server/api/token-stats.js.map +1 -0
  225. package/packages/core/dist/server/api/welcome.d.ts +22 -0
  226. package/packages/core/dist/server/api/welcome.d.ts.map +1 -0
  227. package/packages/core/dist/server/api/welcome.js +35 -0
  228. package/packages/core/dist/server/api/welcome.js.map +1 -0
  229. package/packages/core/dist/server/bell-mode.d.ts +7 -0
  230. package/packages/core/dist/server/bell-mode.d.ts.map +1 -0
  231. package/packages/core/dist/server/bell-mode.js +7 -0
  232. package/packages/core/dist/server/bell-mode.js.map +1 -0
  233. package/packages/core/dist/server/dangerous-path.d.ts +36 -0
  234. package/packages/core/dist/server/dangerous-path.d.ts.map +1 -0
  235. package/packages/core/dist/server/dangerous-path.js +159 -0
  236. package/packages/core/dist/server/dangerous-path.js.map +1 -0
  237. package/packages/core/dist/server/enriched-span-exporter.d.ts +17 -0
  238. package/packages/core/dist/server/enriched-span-exporter.d.ts.map +1 -0
  239. package/packages/core/dist/server/enriched-span-exporter.js +12 -0
  240. package/packages/core/dist/server/enriched-span-exporter.js.map +1 -0
  241. package/packages/core/dist/server/env.d.ts +6 -0
  242. package/packages/core/dist/server/env.d.ts.map +1 -0
  243. package/packages/core/dist/server/env.js +10 -0
  244. package/packages/core/dist/server/env.js.map +1 -0
  245. package/packages/core/dist/server/file-browser.d.ts +17 -0
  246. package/packages/core/dist/server/file-browser.d.ts.map +1 -0
  247. package/packages/core/dist/server/file-browser.js +11 -0
  248. package/packages/core/dist/server/file-browser.js.map +1 -0
  249. package/packages/core/dist/server/otlp-receiver.d.ts +87 -0
  250. package/packages/core/dist/server/otlp-receiver.d.ts.map +1 -0
  251. package/packages/core/dist/server/otlp-receiver.js +106 -0
  252. package/packages/core/dist/server/otlp-receiver.js.map +1 -0
  253. package/packages/core/dist/server/parser.d.ts +11 -0
  254. package/packages/core/dist/server/parser.d.ts.map +1 -0
  255. package/packages/core/dist/server/parser.js +6 -0
  256. package/packages/core/dist/server/parser.js.map +1 -0
  257. package/packages/core/dist/server/paths.d.ts +37 -0
  258. package/packages/core/dist/server/paths.d.ts.map +1 -0
  259. package/packages/core/dist/server/paths.js +227 -0
  260. package/packages/core/dist/server/paths.js.map +1 -0
  261. package/packages/core/dist/server/pennyfarthing.d.ts +56 -0
  262. package/packages/core/dist/server/pennyfarthing.d.ts.map +1 -0
  263. package/packages/core/dist/server/pennyfarthing.js +356 -0
  264. package/packages/core/dist/server/pennyfarthing.js.map +1 -0
  265. package/packages/core/dist/server/plugin-loader.d.ts +22 -0
  266. package/packages/core/dist/server/plugin-loader.d.ts.map +1 -0
  267. package/packages/core/dist/server/plugin-loader.js +67 -0
  268. package/packages/core/dist/server/plugin-loader.js.map +1 -0
  269. package/packages/core/dist/server/prime.d.ts +12 -0
  270. package/packages/core/dist/server/prime.d.ts.map +1 -0
  271. package/packages/core/dist/server/prime.js +8 -0
  272. package/packages/core/dist/server/prime.js.map +1 -0
  273. package/packages/core/dist/server/server.d.ts +47 -0
  274. package/packages/core/dist/server/server.d.ts.map +1 -0
  275. package/packages/core/dist/server/server.js +353 -0
  276. package/packages/core/dist/server/server.js.map +1 -0
  277. package/packages/core/dist/server/server.test.d.ts +26 -0
  278. package/packages/core/dist/server/server.test.d.ts.map +1 -0
  279. package/packages/core/dist/server/server.test.js +447 -0
  280. package/packages/core/dist/server/server.test.js.map +1 -0
  281. package/packages/core/dist/server/settings-store.d.ts +195 -0
  282. package/packages/core/dist/server/settings-store.d.ts.map +1 -0
  283. package/packages/core/dist/server/settings-store.js +398 -0
  284. package/packages/core/dist/server/settings-store.js.map +1 -0
  285. package/packages/core/dist/server/settings.d.ts +136 -0
  286. package/packages/core/dist/server/settings.d.ts.map +1 -0
  287. package/packages/core/dist/server/settings.js +417 -0
  288. package/packages/core/dist/server/settings.js.map +1 -0
  289. package/packages/core/dist/server/span-hierarchy.d.ts +5 -0
  290. package/packages/core/dist/server/span-hierarchy.d.ts.map +1 -0
  291. package/packages/core/dist/server/span-hierarchy.js +5 -0
  292. package/packages/core/dist/server/span-hierarchy.js.map +1 -0
  293. package/packages/core/dist/server/story-context.d.ts +5 -0
  294. package/packages/core/dist/server/story-context.d.ts.map +1 -0
  295. package/packages/core/dist/server/story-context.js +5 -0
  296. package/packages/core/dist/server/story-context.js.map +1 -0
  297. package/packages/core/dist/server/story-parser.d.ts +74 -0
  298. package/packages/core/dist/server/story-parser.d.ts.map +1 -0
  299. package/packages/core/dist/server/story-parser.js +748 -0
  300. package/packages/core/dist/server/story-parser.js.map +1 -0
  301. package/packages/core/dist/server/tdd-metrics.d.ts +5 -0
  302. package/packages/core/dist/server/tdd-metrics.d.ts.map +1 -0
  303. package/packages/core/dist/server/tdd-metrics.js +5 -0
  304. package/packages/core/dist/server/tdd-metrics.js.map +1 -0
  305. package/packages/core/dist/server/ui-build.test.d.ts +19 -0
  306. package/packages/core/dist/server/ui-build.test.d.ts.map +1 -0
  307. package/packages/core/dist/server/ui-build.test.js +152 -0
  308. package/packages/core/dist/server/ui-build.test.js.map +1 -0
  309. package/packages/core/dist/server/websocket.d.ts +7 -0
  310. package/packages/core/dist/server/websocket.d.ts.map +1 -0
  311. package/packages/core/dist/server/websocket.js +8 -0
  312. package/packages/core/dist/server/websocket.js.map +1 -0
  313. package/packages/core/dist/shared/browser.d.ts +6 -0
  314. package/packages/core/dist/shared/browser.d.ts.map +1 -0
  315. package/packages/core/dist/shared/browser.js +8 -0
  316. package/packages/core/dist/shared/browser.js.map +1 -0
  317. package/packages/core/dist/shared/generate-skill-docs.d.ts +35 -0
  318. package/packages/core/dist/shared/generate-skill-docs.d.ts.map +1 -0
  319. package/packages/core/dist/shared/generate-skill-docs.js +442 -0
  320. package/packages/core/dist/shared/generate-skill-docs.js.map +1 -0
  321. package/packages/core/dist/shared/generate-skill-docs.test.d.ts +13 -0
  322. package/packages/core/dist/shared/generate-skill-docs.test.d.ts.map +1 -0
  323. package/packages/core/dist/shared/generate-skill-docs.test.js +519 -0
  324. package/packages/core/dist/shared/generate-skill-docs.test.js.map +1 -0
  325. package/packages/core/dist/shared/index.d.ts +11 -0
  326. package/packages/core/dist/shared/index.d.ts.map +1 -0
  327. package/packages/core/dist/shared/index.js +13 -0
  328. package/packages/core/dist/shared/index.js.map +1 -0
  329. package/packages/core/dist/shared/marker/constants.d.ts +39 -0
  330. package/packages/core/dist/shared/marker/constants.d.ts.map +1 -0
  331. package/packages/core/dist/shared/marker/constants.js +46 -0
  332. package/packages/core/dist/shared/marker/constants.js.map +1 -0
  333. package/packages/core/dist/shared/marker/continue.test.d.ts +12 -0
  334. package/packages/core/dist/shared/marker/continue.test.d.ts.map +1 -0
  335. package/packages/core/dist/shared/marker/continue.test.js +76 -0
  336. package/packages/core/dist/shared/marker/continue.test.js.map +1 -0
  337. package/packages/core/dist/shared/marker/detect.d.ts +25 -0
  338. package/packages/core/dist/shared/marker/detect.d.ts.map +1 -0
  339. package/packages/core/dist/shared/marker/detect.js +53 -0
  340. package/packages/core/dist/shared/marker/detect.js.map +1 -0
  341. package/packages/core/dist/shared/marker/detect.test.d.ts +10 -0
  342. package/packages/core/dist/shared/marker/detect.test.d.ts.map +1 -0
  343. package/packages/core/dist/shared/marker/detect.test.js +418 -0
  344. package/packages/core/dist/shared/marker/detect.test.js.map +1 -0
  345. package/packages/core/dist/shared/marker/index.d.ts +14 -0
  346. package/packages/core/dist/shared/marker/index.d.ts.map +1 -0
  347. package/packages/core/dist/shared/marker/index.js +15 -0
  348. package/packages/core/dist/shared/marker/index.js.map +1 -0
  349. package/packages/core/dist/shared/marker/strip.d.ts +26 -0
  350. package/packages/core/dist/shared/marker/strip.d.ts.map +1 -0
  351. package/packages/core/dist/shared/marker/strip.js +39 -0
  352. package/packages/core/dist/shared/marker/strip.js.map +1 -0
  353. package/packages/core/dist/shared/marker/types.d.ts +23 -0
  354. package/packages/core/dist/shared/marker/types.d.ts.map +1 -0
  355. package/packages/core/dist/shared/marker/types.js +7 -0
  356. package/packages/core/dist/shared/marker/types.js.map +1 -0
  357. package/packages/core/dist/shared/migrate-theme-schema.test.d.ts +8 -0
  358. package/packages/core/dist/shared/migrate-theme-schema.test.d.ts.map +1 -0
  359. package/packages/core/dist/shared/migrate-theme-schema.test.js +100 -0
  360. package/packages/core/dist/shared/migrate-theme-schema.test.js.map +1 -0
  361. package/packages/core/dist/shared/portrait-resolver.d.ts +35 -0
  362. package/packages/core/dist/shared/portrait-resolver.d.ts.map +1 -0
  363. package/packages/core/dist/shared/portrait-resolver.js +259 -0
  364. package/packages/core/dist/shared/portrait-resolver.js.map +1 -0
  365. package/packages/core/dist/shared/portrait-resolver.test.d.ts +2 -0
  366. package/packages/core/dist/shared/portrait-resolver.test.d.ts.map +1 -0
  367. package/packages/core/dist/shared/portrait-resolver.test.js +157 -0
  368. package/packages/core/dist/shared/portrait-resolver.test.js.map +1 -0
  369. package/packages/core/dist/shared/repos-topology.d.ts +49 -0
  370. package/packages/core/dist/shared/repos-topology.d.ts.map +1 -0
  371. package/packages/core/dist/shared/repos-topology.js +101 -0
  372. package/packages/core/dist/shared/repos-topology.js.map +1 -0
  373. package/packages/core/dist/shared/repos-topology.test.d.ts +8 -0
  374. package/packages/core/dist/shared/repos-topology.test.d.ts.map +1 -0
  375. package/packages/core/dist/shared/repos-topology.test.js +250 -0
  376. package/packages/core/dist/shared/repos-topology.test.js.map +1 -0
  377. package/packages/core/dist/shared/skill-search.d.ts +36 -0
  378. package/packages/core/dist/shared/skill-search.d.ts.map +1 -0
  379. package/packages/core/dist/shared/skill-search.js +300 -0
  380. package/packages/core/dist/shared/skill-search.js.map +1 -0
  381. package/packages/core/dist/shared/skill-search.test.d.ts +16 -0
  382. package/packages/core/dist/shared/skill-search.test.d.ts.map +1 -0
  383. package/packages/core/dist/shared/skill-search.test.js +177 -0
  384. package/packages/core/dist/shared/skill-search.test.js.map +1 -0
  385. package/packages/core/dist/shared/skill-suggest.d.ts +76 -0
  386. package/packages/core/dist/shared/skill-suggest.d.ts.map +1 -0
  387. package/packages/core/dist/shared/skill-suggest.js +256 -0
  388. package/packages/core/dist/shared/skill-suggest.js.map +1 -0
  389. package/packages/core/dist/shared/skill-suggest.test.d.ts +12 -0
  390. package/packages/core/dist/shared/skill-suggest.test.d.ts.map +1 -0
  391. package/packages/core/dist/shared/skill-suggest.test.js +257 -0
  392. package/packages/core/dist/shared/skill-suggest.test.js.map +1 -0
  393. package/packages/core/dist/shared/theme-loader.d.ts +81 -0
  394. package/packages/core/dist/shared/theme-loader.d.ts.map +1 -0
  395. package/packages/core/dist/shared/theme-loader.js +491 -0
  396. package/packages/core/dist/shared/theme-loader.js.map +1 -0
  397. package/packages/core/dist/shared/theme-loader.test.d.ts +8 -0
  398. package/packages/core/dist/shared/theme-loader.test.d.ts.map +1 -0
  399. package/packages/core/dist/shared/theme-loader.test.js +62 -0
  400. package/packages/core/dist/shared/theme-loader.test.js.map +1 -0
  401. package/packages/core/dist/workflow/context-watch.test.js +1 -1
  402. package/packages/core/dist/workflow/context-watch.test.js.map +1 -1
  403. package/packages/core/dist/workflow/variable-resolver.test.js +1 -1
  404. package/packages/core/dist/workflow/variable-resolver.test.js.map +1 -1
  405. package/packages/core/dist/workflow/workflow-migration.test.js +4 -3
  406. package/packages/core/dist/workflow/workflow-migration.test.js.map +1 -1
  407. package/pennyfarthing-dist/agents/architect.md +1 -2
  408. package/pennyfarthing-dist/agents/ba.md +1 -1
  409. package/pennyfarthing-dist/agents/dev.md +2 -3
  410. package/pennyfarthing-dist/agents/devops.md +1 -1
  411. package/pennyfarthing-dist/agents/orchestrator.md +2 -3
  412. package/pennyfarthing-dist/agents/pm.md +2 -2
  413. package/pennyfarthing-dist/agents/reviewer.md +2 -2
  414. package/pennyfarthing-dist/agents/sm-setup.md +7 -7
  415. package/pennyfarthing-dist/agents/sm.md +19 -18
  416. package/pennyfarthing-dist/agents/tea.md +3 -2
  417. package/pennyfarthing-dist/agents/tech-writer.md +1 -1
  418. package/pennyfarthing-dist/agents/ux-designer.md +0 -1
  419. package/pennyfarthing-dist/commands/benchmark-control.md +69 -0
  420. package/pennyfarthing-dist/commands/benchmark.md +485 -0
  421. package/pennyfarthing-dist/commands/job-fair.md +102 -0
  422. package/pennyfarthing-dist/commands/{close-epic.md → pf-close-epic.md} +1 -1
  423. package/pennyfarthing-dist/commands/{new-work.md → pf-new-work.md} +4 -4
  424. package/pennyfarthing-dist/commands/{party-mode.md → pf-party-mode.md} +15 -2
  425. package/pennyfarthing-dist/commands/{patch.md → pf-patch.md} +3 -3
  426. package/pennyfarthing-dist/commands/{release.md → pf-release.md} +17 -10
  427. package/pennyfarthing-dist/commands/{setup.md → pf-setup.md} +2 -2
  428. package/pennyfarthing-dist/commands/{sprint.md → pf-sprint.md} +19 -19
  429. package/pennyfarthing-dist/commands/{standalone.md → pf-standalone.md} +2 -2
  430. package/pennyfarthing-dist/commands/{workflow.md → pf-workflow.md} +7 -7
  431. package/pennyfarthing-dist/commands/solo.md +447 -0
  432. package/pennyfarthing-dist/guides/agent-behavior.md +2 -2
  433. package/pennyfarthing-dist/guides/agent-tag-taxonomy.md +1 -2
  434. package/pennyfarthing-dist/guides/agent-template-strategic.md +1 -1
  435. package/pennyfarthing-dist/guides/agent-template-tactical.md +2 -2
  436. package/pennyfarthing-dist/guides/bikelane.md +6 -6
  437. package/pennyfarthing-dist/guides/permission-protocol.md +1 -1
  438. package/pennyfarthing-dist/guides/scale-levels.md +2 -2
  439. package/pennyfarthing-dist/guides/skill-schema.md +9 -9
  440. package/pennyfarthing-dist/guides/xml-tags.md +2 -2
  441. package/pennyfarthing-dist/personas/themes/dune.yaml +0 -1
  442. package/pennyfarthing-dist/personas/themes/hogans-heroes.yaml +260 -0
  443. package/pennyfarthing-dist/personas/themes/monty-python.yaml +312 -0
  444. package/pennyfarthing-dist/personas/themes/stephen-king.yaml +260 -0
  445. package/pennyfarthing-dist/scripts/core/agent-session.sh +0 -0
  446. package/pennyfarthing-dist/scripts/core/check-context.sh +0 -0
  447. package/pennyfarthing-dist/scripts/core/handoff-marker.sh +0 -0
  448. package/pennyfarthing-dist/scripts/core/phase-check-start.sh +0 -0
  449. package/pennyfarthing-dist/scripts/core/prime.sh +0 -0
  450. package/pennyfarthing-dist/scripts/cyclist/is-cyclist.sh +0 -0
  451. package/pennyfarthing-dist/scripts/git/create-feature-branches.sh +0 -0
  452. package/pennyfarthing-dist/scripts/git/git-status-all.sh +0 -0
  453. package/pennyfarthing-dist/scripts/git/install-git-hooks.sh +84 -21
  454. package/pennyfarthing-dist/scripts/git/release.sh +0 -0
  455. package/pennyfarthing-dist/scripts/git/worktree-manager.sh +0 -0
  456. package/pennyfarthing-dist/scripts/health/drift-detection.sh +0 -0
  457. package/pennyfarthing-dist/scripts/hooks/bell-mode-hook.sh +0 -0
  458. package/pennyfarthing-dist/scripts/hooks/context-circuit-breaker.sh +0 -0
  459. package/pennyfarthing-dist/scripts/hooks/context-warning.sh +0 -0
  460. package/pennyfarthing-dist/scripts/hooks/cyclist-pretooluse-hook.sh +0 -0
  461. package/pennyfarthing-dist/scripts/hooks/dispatcher-template.sh +45 -0
  462. package/pennyfarthing-dist/scripts/hooks/otel-auto-config.sh +0 -0
  463. package/pennyfarthing-dist/scripts/hooks/post-merge.sh +0 -0
  464. package/pennyfarthing-dist/scripts/hooks/pre-commit.sh +27 -2
  465. package/pennyfarthing-dist/scripts/hooks/pre-edit-check.sh +0 -0
  466. package/pennyfarthing-dist/scripts/hooks/pre-push.sh +0 -0
  467. package/pennyfarthing-dist/scripts/hooks/question-reflector-check.sh +0 -0
  468. package/pennyfarthing-dist/scripts/hooks/question_reflector_check.py +0 -0
  469. package/pennyfarthing-dist/scripts/hooks/schema-validation.sh +0 -0
  470. package/pennyfarthing-dist/scripts/hooks/session-start.sh +25 -89
  471. package/pennyfarthing-dist/scripts/hooks/session-stop.sh +0 -0
  472. package/pennyfarthing-dist/scripts/hooks/sprint-yaml-validation.sh +0 -0
  473. package/pennyfarthing-dist/scripts/hooks/welcome-hook.sh +0 -0
  474. package/pennyfarthing-dist/scripts/jira/README.md +1 -1
  475. package/pennyfarthing-dist/scripts/jira/create-jira-epic.sh +0 -0
  476. package/pennyfarthing-dist/scripts/jira/create-jira-story.sh +0 -0
  477. package/pennyfarthing-dist/scripts/jira/jira-claim-story.sh +0 -0
  478. package/pennyfarthing-dist/scripts/jira/jira-reconcile.sh +0 -0
  479. package/pennyfarthing-dist/scripts/jira/jira-sync-story.sh +0 -0
  480. package/pennyfarthing-dist/scripts/jira/sync-epic-jira.sh +0 -0
  481. package/pennyfarthing-dist/scripts/lib/background-tasks.sh +0 -0
  482. package/pennyfarthing-dist/scripts/lib/checkpoint.sh +0 -0
  483. package/pennyfarthing-dist/scripts/lib/common.sh +0 -0
  484. package/pennyfarthing-dist/scripts/lib/file-lock.sh +0 -0
  485. package/pennyfarthing-dist/scripts/lib/logging.sh +0 -0
  486. package/pennyfarthing-dist/scripts/lib/retry.sh +0 -0
  487. package/pennyfarthing-dist/scripts/maintenance/migrate-theme-schema.mjs +0 -0
  488. package/pennyfarthing-dist/scripts/maintenance/sidecar-health.sh +0 -0
  489. package/pennyfarthing-dist/scripts/misc/add-short-names.sh +0 -0
  490. package/pennyfarthing-dist/scripts/misc/add_short_names.py +0 -0
  491. package/pennyfarthing-dist/scripts/misc/backlog.sh +0 -0
  492. package/pennyfarthing-dist/scripts/misc/check-status.sh +0 -0
  493. package/pennyfarthing-dist/scripts/misc/find-related-work.sh +0 -0
  494. package/pennyfarthing-dist/scripts/misc/generate-skill-docs.sh +0 -0
  495. package/pennyfarthing-dist/scripts/misc/log-skill-usage.sh +0 -0
  496. package/pennyfarthing-dist/scripts/misc/migrate-bmad-workflow.sh +0 -0
  497. package/pennyfarthing-dist/scripts/misc/migrate_bmad_workflow.py +0 -0
  498. package/pennyfarthing-dist/scripts/misc/repo-scan.sh +0 -0
  499. package/pennyfarthing-dist/scripts/misc/repo-utils.sh +0 -0
  500. package/pennyfarthing-dist/scripts/misc/run-ci.sh +0 -0
  501. package/pennyfarthing-dist/scripts/misc/run-timestamp.sh +0 -0
  502. package/pennyfarthing-dist/scripts/misc/session-cleanup.sh +0 -0
  503. package/pennyfarthing-dist/scripts/misc/skill-usage-report.sh +0 -0
  504. package/pennyfarthing-dist/scripts/misc/statusline.sh +0 -0
  505. package/pennyfarthing-dist/scripts/misc/uninstall.sh +0 -0
  506. package/pennyfarthing-dist/scripts/misc/validate-subagent-frontmatter.sh +0 -0
  507. package/pennyfarthing-dist/scripts/portraits/generate-portraits.py +50 -26
  508. package/pennyfarthing-dist/scripts/portraits/generate-portraits.sh +18 -6
  509. package/pennyfarthing-dist/scripts/sprint/README.md +1 -1
  510. package/pennyfarthing-dist/scripts/story/README.md +1 -1
  511. package/pennyfarthing-dist/scripts/story/create-story.sh +0 -0
  512. package/pennyfarthing-dist/scripts/story/size-story.sh +0 -0
  513. package/pennyfarthing-dist/scripts/story/story-template.sh +0 -0
  514. package/pennyfarthing-dist/scripts/tests/check.test.sh +0 -0
  515. package/pennyfarthing-dist/scripts/tests/dev-story-workflow-import.test.sh +0 -0
  516. package/pennyfarthing-dist/scripts/tests/epics-and-stories-workflow-import.test.sh +0 -0
  517. package/pennyfarthing-dist/scripts/tests/handoff-phase-update.test.sh +0 -0
  518. package/pennyfarthing-dist/scripts/tests/implementation-readiness-workflow-import.test.sh +0 -0
  519. package/pennyfarthing-dist/scripts/tests/migrate-bmad-workflow.test.sh +0 -0
  520. package/pennyfarthing-dist/scripts/tests/prd-workflow-import.test.sh +0 -0
  521. package/pennyfarthing-dist/scripts/tests/project-context-workflow-import.test.sh +0 -0
  522. package/pennyfarthing-dist/scripts/tests/test-character-voice.sh +0 -0
  523. package/pennyfarthing-dist/scripts/tests/test-drift-detection.sh +0 -0
  524. package/pennyfarthing-dist/scripts/tests/test-post-merge-hook.sh +0 -0
  525. package/pennyfarthing-dist/scripts/tests/test-session-checkpoint.sh +0 -0
  526. package/pennyfarthing-dist/scripts/tests/test-solo-command.sh +0 -0
  527. package/pennyfarthing-dist/scripts/tests/ux-design-workflow-import.test.sh +0 -0
  528. package/pennyfarthing-dist/scripts/theme/list-themes.sh +0 -0
  529. package/pennyfarthing-dist/scripts/validation/validate-agent-schema.sh +0 -0
  530. package/pennyfarthing-dist/scripts/workflow/README.md +1 -1
  531. package/pennyfarthing-dist/scripts/workflow/check.py +0 -0
  532. package/pennyfarthing-dist/scripts/workflow/check.sh +0 -0
  533. package/pennyfarthing-dist/scripts/workflow/complete-step.py +0 -0
  534. package/pennyfarthing-dist/scripts/workflow/finish-story.sh +0 -0
  535. package/pennyfarthing-dist/scripts/workflow/fix-session-phase.sh +0 -0
  536. package/pennyfarthing-dist/scripts/workflow/get-workflow-type.py +0 -0
  537. package/pennyfarthing-dist/scripts/workflow/get-workflow-type.sh +0 -0
  538. package/pennyfarthing-dist/scripts/workflow/list-workflows.sh +0 -0
  539. package/pennyfarthing-dist/scripts/workflow/phase-owner.sh +0 -0
  540. package/pennyfarthing-dist/scripts/workflow/resume-workflow.sh +0 -0
  541. package/pennyfarthing-dist/scripts/workflow/show-workflow.sh +0 -0
  542. package/pennyfarthing-dist/scripts/workflow/start-workflow.sh +0 -0
  543. package/pennyfarthing-dist/scripts/workflow/workflow-status.sh +0 -0
  544. package/pennyfarthing-dist/skills/pf-bc/examples.md +83 -0
  545. package/pennyfarthing-dist/skills/pf-bc/skill.md +51 -0
  546. package/pennyfarthing-dist/skills/pf-bc/usage.md +113 -0
  547. package/pennyfarthing-dist/skills/{cyclist → pf-cyclist}/SKILL.md +5 -5
  548. package/pennyfarthing-dist/skills/pf-finalize-run/SKILL.md +261 -0
  549. package/pennyfarthing-dist/skills/pf-jira/SKILL.md +61 -0
  550. package/pennyfarthing-dist/skills/pf-jira/examples.md +163 -0
  551. package/pennyfarthing-dist/skills/pf-jira/usage.md +213 -0
  552. package/pennyfarthing-dist/skills/pf-judge/SKILL.md +644 -0
  553. package/pennyfarthing-dist/skills/{just → pf-just}/SKILL.md +23 -23
  554. package/pennyfarthing-dist/skills/{permissions → pf-permissions}/skill.md +8 -8
  555. package/pennyfarthing-dist/skills/pf-persona-benchmark/SKILL.md +187 -0
  556. package/pennyfarthing-dist/skills/pf-sprint/examples.md +189 -0
  557. package/pennyfarthing-dist/skills/pf-sprint/skill.md +85 -0
  558. package/pennyfarthing-dist/skills/pf-sprint/usage.md +293 -0
  559. package/pennyfarthing-dist/skills/{story → pf-story}/scripts/create-story.sh +0 -0
  560. package/pennyfarthing-dist/skills/{story → pf-story}/scripts/size-story.sh +0 -0
  561. package/pennyfarthing-dist/skills/{story → pf-story}/scripts/story-template.sh +0 -0
  562. package/pennyfarthing-dist/skills/pf-story/skill.md +27 -0
  563. package/pennyfarthing-dist/skills/{systematic-debugging → pf-systematic-debugging}/SKILL.md +5 -6
  564. package/pennyfarthing-dist/skills/pf-theme/examples.md +92 -0
  565. package/pennyfarthing-dist/skills/pf-theme/skill.md +42 -0
  566. package/pennyfarthing-dist/skills/pf-theme/usage.md +149 -0
  567. package/pennyfarthing-dist/skills/pf-workflow/examples.md +101 -0
  568. package/pennyfarthing-dist/skills/{workflow → pf-workflow}/scripts/list-workflows.sh +0 -0
  569. package/pennyfarthing-dist/skills/{workflow → pf-workflow}/scripts/resume-workflow.sh +0 -0
  570. package/pennyfarthing-dist/skills/{workflow → pf-workflow}/scripts/show-workflow.sh +0 -0
  571. package/pennyfarthing-dist/skills/{workflow → pf-workflow}/scripts/start-workflow.sh +0 -0
  572. package/pennyfarthing-dist/skills/{workflow → pf-workflow}/scripts/workflow-status.sh +0 -0
  573. package/pennyfarthing-dist/skills/pf-workflow/skill.md +49 -0
  574. package/pennyfarthing-dist/skills/pf-workflow/usage.md +145 -0
  575. package/pennyfarthing-dist/skills/skill-registry.yaml +63 -81
  576. package/pennyfarthing-dist/workflows/architecture/data/domain-complexity.csv +13 -0
  577. package/pennyfarthing-dist/workflows/architecture/data/project-types.csv +7 -0
  578. package/pennyfarthing-dist/workflows/epics-and-stories/steps/step-05-import-to-future.md +40 -11
  579. package/pennyfarthing-dist/workflows/party-mode-roleplay/steps/step-01-agent-loading.md +99 -0
  580. package/pennyfarthing-dist/workflows/party-mode-roleplay/steps/step-02-discussion.md +130 -0
  581. package/pennyfarthing-dist/workflows/party-mode-roleplay/steps/step-03-exit.md +100 -0
  582. package/pennyfarthing-dist/workflows/party-mode-roleplay/workflow.yaml +62 -0
  583. package/pennyfarthing-dist/workflows/prd/data/domain-complexity.csv +2 -0
  584. package/pennyfarthing-dist/workflows/prd/data/prd-purpose.md +2 -0
  585. package/pennyfarthing-dist/workflows/prd/steps-v/step-v-08-domain-compliance-validation.md +16 -0
  586. package/pennyfarthing-dist/workflows/project-setup/steps/step-04-claude-md.md +3 -3
  587. package/pennyfarthing-dist/workflows/quick-spec/steps/step-01-understand.md +193 -0
  588. package/pennyfarthing-dist/workflows/quick-spec/steps/step-02-investigate.md +148 -0
  589. package/pennyfarthing-dist/workflows/quick-spec/steps/step-03-generate.md +141 -0
  590. package/pennyfarthing-dist/workflows/quick-spec/steps/step-04-review.md +192 -0
  591. package/pennyfarthing-dist/workflows/quick-spec/tech-spec-template.md +74 -0
  592. package/pennyfarthing-dist/workflows/quick-spec/workflow.yaml +35 -0
  593. package/pennyfarthing-dist/workflows/release/steps/step-01-preflight.md +42 -3
  594. package/pennyfarthing-dist/workflows/release/steps/step-02-bump.md +10 -3
  595. package/pennyfarthing-dist/workflows/release/steps/step-03-changelog.md +1 -1
  596. package/pennyfarthing-dist/workflows/release/steps/step-07-commit.md +13 -4
  597. package/pennyfarthing-dist/workflows/release/steps/step-08-merge.md +31 -6
  598. package/pennyfarthing-dist/workflows/release/steps/step-09-push.md +12 -6
  599. package/pennyfarthing-dist/workflows/release/steps/step-10-publish.md +30 -5
  600. package/pennyfarthing-dist/workflows/release/steps/step-11-finalize.md +29 -0
  601. package/pennyfarthing-dist/workflows/release.yaml +7 -0
  602. package/pennyfarthing_scripts/CLAUDE.md +182 -0
  603. package/pennyfarthing_scripts/__pycache__/cli.cpython-314.pyc +0 -0
  604. package/pennyfarthing_scripts/__pycache__/patch_mode.cpython-314.pyc +0 -0
  605. package/pennyfarthing_scripts/__pycache__/session_start_hook.cpython-314.pyc +0 -0
  606. package/pennyfarthing_scripts/bc/__init__.py +1 -0
  607. package/pennyfarthing_scripts/bc/__pycache__/__init__.cpython-314.pyc +0 -0
  608. package/pennyfarthing_scripts/bc/__pycache__/cli.cpython-314.pyc +0 -0
  609. package/pennyfarthing_scripts/bc/__pycache__/focus.cpython-314.pyc +0 -0
  610. package/pennyfarthing_scripts/bc/cli.py +223 -0
  611. package/pennyfarthing_scripts/bc/focus.py +333 -0
  612. package/pennyfarthing_scripts/bikerack/__init__.py +8 -0
  613. package/pennyfarthing_scripts/bikerack/__pycache__/__init__.cpython-314.pyc +0 -0
  614. package/pennyfarthing_scripts/bikerack/__pycache__/background_panel.cpython-314.pyc +0 -0
  615. package/pennyfarthing_scripts/bikerack/__pycache__/base_panel.cpython-314.pyc +0 -0
  616. package/pennyfarthing_scripts/bikerack/__pycache__/changed_panel.cpython-314.pyc +0 -0
  617. package/pennyfarthing_scripts/bikerack/__pycache__/cli.cpython-314.pyc +0 -0
  618. package/pennyfarthing_scripts/bikerack/__pycache__/diffs_panel.cpython-314.pyc +0 -0
  619. package/pennyfarthing_scripts/bikerack/__pycache__/git_panel.cpython-314.pyc +0 -0
  620. package/pennyfarthing_scripts/bikerack/__pycache__/launcher.cpython-314.pyc +0 -0
  621. package/pennyfarthing_scripts/bikerack/__pycache__/sprint_panel.cpython-314.pyc +0 -0
  622. package/pennyfarthing_scripts/bikerack/__pycache__/tui.cpython-314.pyc +0 -0
  623. package/pennyfarthing_scripts/bikerack/__pycache__/ws_client.cpython-314.pyc +0 -0
  624. package/pennyfarthing_scripts/bikerack/background_panel.py +81 -0
  625. package/pennyfarthing_scripts/bikerack/base_panel.py +100 -0
  626. package/pennyfarthing_scripts/bikerack/changed_panel.py +105 -0
  627. package/pennyfarthing_scripts/bikerack/cli.py +22 -24
  628. package/pennyfarthing_scripts/bikerack/diffs_panel.py +146 -0
  629. package/pennyfarthing_scripts/bikerack/git_panel.py +69 -0
  630. package/pennyfarthing_scripts/bikerack/launcher.py +63 -4
  631. package/pennyfarthing_scripts/bikerack/sprint_panel.py +72 -0
  632. package/pennyfarthing_scripts/bikerack/tui.py +193 -0
  633. package/pennyfarthing_scripts/bikerack/ws_client.py +176 -0
  634. package/pennyfarthing_scripts/brownfield/__pycache__/__init__.cpython-314.pyc +0 -0
  635. package/pennyfarthing_scripts/brownfield/__pycache__/__main__.cpython-314.pyc +0 -0
  636. package/pennyfarthing_scripts/brownfield/__pycache__/cli.cpython-314.pyc +0 -0
  637. package/pennyfarthing_scripts/brownfield/__pycache__/discover.cpython-314.pyc +0 -0
  638. package/pennyfarthing_scripts/cli.py +60 -16
  639. package/pennyfarthing_scripts/codemarkers/__pycache__/formatters.cpython-314.pyc +0 -0
  640. package/pennyfarthing_scripts/complexity/__pycache__/__init__.cpython-314.pyc +0 -0
  641. package/pennyfarthing_scripts/complexity/__pycache__/analyze.cpython-314.pyc +0 -0
  642. package/pennyfarthing_scripts/deadcode/__pycache__/analyze.cpython-314.pyc +0 -0
  643. package/pennyfarthing_scripts/dependencies/__pycache__/__init__.cpython-314.pyc +0 -0
  644. package/pennyfarthing_scripts/dependencies/__pycache__/analyze.cpython-314.pyc +0 -0
  645. package/pennyfarthing_scripts/git/__pycache__/__init__.cpython-314.pyc +0 -0
  646. package/pennyfarthing_scripts/git/__pycache__/create_branches.cpython-314.pyc +0 -0
  647. package/pennyfarthing_scripts/git/__pycache__/status_all.cpython-314.pyc +0 -0
  648. package/pennyfarthing_scripts/healthscore/__pycache__/__main__.cpython-314.pyc +0 -0
  649. package/pennyfarthing_scripts/healthscore/__pycache__/analyze.cpython-314.pyc +0 -0
  650. package/pennyfarthing_scripts/healthscore/analyze.py +15 -1
  651. package/pennyfarthing_scripts/hooks/cyclist-pretooluse-hook.sh +0 -0
  652. package/pennyfarthing_scripts/jira/__pycache__/cli.cpython-314.pyc +0 -0
  653. package/pennyfarthing_scripts/jira/cli.py +10 -2
  654. package/pennyfarthing_scripts/launch/__init__.py +1 -0
  655. package/pennyfarthing_scripts/launch/__pycache__/__init__.cpython-314.pyc +0 -0
  656. package/pennyfarthing_scripts/launch/__pycache__/cli.cpython-314.pyc +0 -0
  657. package/pennyfarthing_scripts/launch/cli.py +231 -0
  658. package/pennyfarthing_scripts/preflight/__pycache__/__init__.cpython-314.pyc +0 -0
  659. package/pennyfarthing_scripts/preflight/__pycache__/finish.cpython-314.pyc +0 -0
  660. package/pennyfarthing_scripts/prime/__pycache__/version_sentinel.cpython-314.pyc +0 -0
  661. package/pennyfarthing_scripts/prime/version_sentinel.py +0 -1
  662. package/pennyfarthing_scripts/session_start_hook.py +192 -0
  663. package/pennyfarthing_scripts/sprint/__pycache__/__main__.cpython-314.pyc +0 -0
  664. package/pennyfarthing_scripts/sprint/__pycache__/archive_epic.cpython-314.pyc +0 -0
  665. package/pennyfarthing_scripts/sprint/__pycache__/cli.cpython-314.pyc +0 -0
  666. package/pennyfarthing_scripts/sprint/__pycache__/epic_add.cpython-314.pyc +0 -0
  667. package/pennyfarthing_scripts/sprint/__pycache__/epic_update.cpython-314.pyc +0 -0
  668. package/pennyfarthing_scripts/sprint/__pycache__/import_epic.cpython-314.pyc +0 -0
  669. package/pennyfarthing_scripts/sprint/__pycache__/loader.cpython-314.pyc +0 -0
  670. package/pennyfarthing_scripts/sprint/__pycache__/story_add.cpython-314.pyc +0 -0
  671. package/pennyfarthing_scripts/sprint/__pycache__/story_finish.cpython-314.pyc +0 -0
  672. package/pennyfarthing_scripts/sprint/__pycache__/story_update.cpython-314.pyc +0 -0
  673. package/pennyfarthing_scripts/sprint/__pycache__/validate_cmd.cpython-314.pyc +0 -0
  674. package/pennyfarthing_scripts/sprint/__pycache__/yaml_io.cpython-314.pyc +0 -0
  675. package/pennyfarthing_scripts/sprint/archive_epic.py +109 -1
  676. package/pennyfarthing_scripts/sprint/cli.py +30 -9
  677. package/pennyfarthing_scripts/sprint/epic_add.py +7 -1
  678. package/pennyfarthing_scripts/sprint/epic_update.py +148 -0
  679. package/pennyfarthing_scripts/sprint/loader.py +33 -0
  680. package/pennyfarthing_scripts/sprint/story_add.py +11 -1
  681. package/pennyfarthing_scripts/sprint/story_finish.py +14 -10
  682. package/pennyfarthing_scripts/sprint/story_update.py +7 -0
  683. package/pennyfarthing_scripts/sprint/validate_cmd.py +2 -1
  684. package/pennyfarthing_scripts/sprint/yaml_io.py +64 -6
  685. package/pennyfarthing_scripts/story/__pycache__/__init__.cpython-314.pyc +0 -0
  686. package/pennyfarthing_scripts/story/__pycache__/size.cpython-314.pyc +0 -0
  687. package/pennyfarthing_scripts/story/__pycache__/template.cpython-314.pyc +0 -0
  688. package/pennyfarthing_scripts/tests/__pycache__/test_archive_epic.cpython-314-pytest-9.0.2.pyc +0 -0
  689. package/pennyfarthing_scripts/tests/__pycache__/test_bc.cpython-314-pytest-9.0.2.pyc +0 -0
  690. package/pennyfarthing_scripts/tests/__pycache__/test_bikerack.cpython-314-pytest-9.0.2.pyc +0 -0
  691. package/pennyfarthing_scripts/tests/__pycache__/test_brownfield.cpython-314-pytest-9.0.2.pyc +0 -0
  692. package/pennyfarthing_scripts/tests/__pycache__/test_cli_modules.cpython-314-pytest-9.0.2.pyc +0 -0
  693. package/pennyfarthing_scripts/tests/__pycache__/test_cli_normalization.cpython-314-pytest-9.0.2.pyc +0 -0
  694. package/pennyfarthing_scripts/tests/__pycache__/test_codemarkers.cpython-314-pytest-9.0.2.pyc +0 -0
  695. package/pennyfarthing_scripts/tests/__pycache__/test_common.cpython-314-pytest-9.0.2.pyc +0 -0
  696. package/pennyfarthing_scripts/tests/__pycache__/test_epic_shard_validation.cpython-314-pytest-9.0.2.pyc +0 -0
  697. package/pennyfarthing_scripts/tests/__pycache__/test_git_utils.cpython-314-pytest-9.0.2.pyc +0 -0
  698. package/pennyfarthing_scripts/tests/__pycache__/test_healthscore.cpython-314-pytest-9.0.2.pyc +0 -0
  699. package/pennyfarthing_scripts/tests/__pycache__/test_jira_package.cpython-314-pytest-9.0.2.pyc +0 -0
  700. package/pennyfarthing_scripts/tests/__pycache__/test_package_structure.cpython-314-pytest-9.0.2.pyc +0 -0
  701. package/pennyfarthing_scripts/tests/__pycache__/test_patch_mode.cpython-314-pytest-9.0.2.pyc +0 -0
  702. package/pennyfarthing_scripts/tests/__pycache__/test_prime.cpython-314-pytest-9.0.2.pyc +0 -0
  703. package/pennyfarthing_scripts/tests/__pycache__/test_sprint_package.cpython-314-pytest-9.0.2.pyc +0 -0
  704. package/pennyfarthing_scripts/tests/__pycache__/test_sprint_panel.cpython-314-pytest-9.0.2.pyc +0 -0
  705. package/pennyfarthing_scripts/tests/__pycache__/test_sprint_validator.cpython-314-pytest-9.0.2.pyc +0 -0
  706. package/pennyfarthing_scripts/tests/__pycache__/test_story_add.cpython-314-pytest-9.0.2.pyc +0 -0
  707. package/pennyfarthing_scripts/tests/__pycache__/test_story_package.cpython-314-pytest-9.0.2.pyc +0 -0
  708. package/pennyfarthing_scripts/tests/__pycache__/test_story_update.cpython-314-pytest-9.0.2.pyc +0 -0
  709. package/pennyfarthing_scripts/tests/__pycache__/test_tiers.cpython-314-pytest-9.0.2.pyc +0 -0
  710. package/pennyfarthing_scripts/tests/__pycache__/test_token_counting.cpython-314-pytest-9.0.2.pyc +0 -0
  711. package/pennyfarthing_scripts/tests/__pycache__/test_topology_loader.cpython-314-pytest-9.0.2.pyc +0 -0
  712. package/pennyfarthing_scripts/tests/__pycache__/test_tui_focus.cpython-314-pytest-9.0.2.pyc +0 -0
  713. package/pennyfarthing_scripts/tests/__pycache__/test_tui_panel_persistence.cpython-314-pytest-9.0.2.pyc +0 -0
  714. package/pennyfarthing_scripts/tests/__pycache__/test_validate_cmd.cpython-314-pytest-9.0.2.pyc +0 -0
  715. package/pennyfarthing_scripts/tests/__pycache__/test_version_sentinel.cpython-314-pytest-9.0.2.pyc +0 -0
  716. package/pennyfarthing_scripts/tests/__pycache__/test_workflow_check.cpython-314-pytest-9.0.2.pyc +0 -0
  717. package/pennyfarthing_scripts/tests/__pycache__/test_yaml_io.cpython-314-pytest-9.0.2.pyc +0 -0
  718. package/pennyfarthing_scripts/tests/test_archive_epic.py +185 -0
  719. package/pennyfarthing_scripts/tests/test_bc.py +490 -0
  720. package/pennyfarthing_scripts/tests/test_cli_normalization.py +295 -0
  721. package/pennyfarthing_scripts/tests/test_sprint_panel.py +531 -0
  722. package/pennyfarthing_scripts/tests/test_tui_focus.py +411 -0
  723. package/pennyfarthing_scripts/tests/test_tui_panel_persistence.py +411 -0
  724. package/pennyfarthing_scripts/tests/test_version_sentinel.py +1 -5
  725. package/pennyfarthing_scripts/tests/test_yaml_io.py +5 -5
  726. package/pennyfarthing_scripts/theme/__pycache__/cli.cpython-314.pyc +0 -0
  727. package/pennyfarthing_scripts/theme/cli.py +25 -2
  728. package/scripts/README.md +41 -0
  729. package/packages/core/dist/scripts/benchmark-integration.test.d.ts +0 -13
  730. package/packages/core/dist/scripts/benchmark-integration.test.d.ts.map +0 -1
  731. package/packages/core/dist/scripts/benchmark-integration.test.js +0 -680
  732. package/packages/core/dist/scripts/benchmark-integration.test.js.map +0 -1
  733. package/packages/core/dist/scripts/debugging-scenarios.test.d.ts +0 -18
  734. package/packages/core/dist/scripts/debugging-scenarios.test.d.ts.map +0 -1
  735. package/packages/core/dist/scripts/debugging-scenarios.test.js +0 -317
  736. package/packages/core/dist/scripts/debugging-scenarios.test.js.map +0 -1
  737. package/packages/core/dist/scripts/job-fair-aggregator.test.d.ts +0 -14
  738. package/packages/core/dist/scripts/job-fair-aggregator.test.d.ts.map +0 -1
  739. package/packages/core/dist/scripts/job-fair-aggregator.test.js +0 -616
  740. package/packages/core/dist/scripts/job-fair-aggregator.test.js.map +0 -1
  741. package/packages/core/dist/scripts/theme-detail.test.d.ts +0 -10
  742. package/packages/core/dist/scripts/theme-detail.test.js +0 -199
  743. package/pennyfarthing-dist/personas/themes/star-trek-tng.yaml +0 -392
  744. package/pennyfarthing-dist/skills/dev-patterns/SKILL.md +0 -461
  745. package/pennyfarthing-dist/skills/jira/SKILL.md +0 -207
  746. package/pennyfarthing-dist/skills/sprint/skill.md +0 -806
  747. package/pennyfarthing-dist/skills/story/skill.md +0 -27
  748. package/pennyfarthing-dist/skills/theme/skill.md +0 -356
  749. package/pennyfarthing-dist/skills/workflow/skill.md +0 -368
  750. /package/pennyfarthing-dist/commands/{architect.md → pf-architect.md} +0 -0
  751. /package/pennyfarthing-dist/commands/{ba.md → pf-ba.md} +0 -0
  752. /package/pennyfarthing-dist/commands/{brainstorming.md → pf-brainstorming.md} +0 -0
  753. /package/pennyfarthing-dist/commands/{check.md → pf-check.md} +0 -0
  754. /package/pennyfarthing-dist/commands/{chore.md → pf-chore.md} +0 -0
  755. /package/pennyfarthing-dist/commands/{continue-session.md → pf-continue-session.md} +0 -0
  756. /package/pennyfarthing-dist/commands/{create-branches-from-story.md → pf-create-branches-from-story.md} +0 -0
  757. /package/pennyfarthing-dist/commands/{create-theme.md → pf-create-theme.md} +0 -0
  758. /package/pennyfarthing-dist/commands/{dev.md → pf-dev.md} +0 -0
  759. /package/pennyfarthing-dist/commands/{devops.md → pf-devops.md} +0 -0
  760. /package/pennyfarthing-dist/commands/{fix-blocker.md → pf-fix-blocker.md} +0 -0
  761. /package/pennyfarthing-dist/commands/{git-cleanup.md → pf-git-cleanup.md} +0 -0
  762. /package/pennyfarthing-dist/commands/{health-check.md → pf-health-check.md} +0 -0
  763. /package/pennyfarthing-dist/commands/{help.md → pf-help.md} +0 -0
  764. /package/pennyfarthing-dist/commands/{list-themes.md → pf-list-themes.md} +0 -0
  765. /package/pennyfarthing-dist/commands/{orchestrator.md → pf-orchestrator.md} +0 -0
  766. /package/pennyfarthing-dist/commands/{parallel-work.md → pf-parallel-work.md} +0 -0
  767. /package/pennyfarthing-dist/commands/{permissions.md → pf-permissions.md} +0 -0
  768. /package/pennyfarthing-dist/commands/{pm.md → pf-pm.md} +0 -0
  769. /package/pennyfarthing-dist/commands/{prime.md → pf-prime.md} +0 -0
  770. /package/pennyfarthing-dist/commands/{repo-status.md → pf-repo-status.md} +0 -0
  771. /package/pennyfarthing-dist/commands/{retro.md → pf-retro.md} +0 -0
  772. /package/pennyfarthing-dist/commands/{reviewer.md → pf-reviewer.md} +0 -0
  773. /package/pennyfarthing-dist/commands/{run-ci.md → pf-run-ci.md} +0 -0
  774. /package/pennyfarthing-dist/commands/{set-theme.md → pf-set-theme.md} +0 -0
  775. /package/pennyfarthing-dist/commands/{show-theme.md → pf-show-theme.md} +0 -0
  776. /package/pennyfarthing-dist/commands/{sm.md → pf-sm.md} +0 -0
  777. /package/pennyfarthing-dist/commands/{sprint-planning.md → pf-sprint-planning.md} +0 -0
  778. /package/pennyfarthing-dist/commands/{start-epic.md → pf-start-epic.md} +0 -0
  779. /package/pennyfarthing-dist/commands/{sync-epic-to-jira.md → pf-sync-epic-to-jira.md} +0 -0
  780. /package/pennyfarthing-dist/commands/{sync-work-with-sprint.md → pf-sync-work-with-sprint.md} +0 -0
  781. /package/pennyfarthing-dist/commands/{tea.md → pf-tea.md} +0 -0
  782. /package/pennyfarthing-dist/commands/{tech-writer.md → pf-tech-writer.md} +0 -0
  783. /package/pennyfarthing-dist/commands/{theme-maker.md → pf-theme-maker.md} +0 -0
  784. /package/pennyfarthing-dist/commands/{theme.md → pf-theme.md} +0 -0
  785. /package/pennyfarthing-dist/commands/{update-domain-docs.md → pf-update-domain-docs.md} +0 -0
  786. /package/pennyfarthing-dist/commands/{ux-designer.md → pf-ux-designer.md} +0 -0
  787. /package/pennyfarthing-dist/commands/{work.md → pf-work.md} +0 -0
  788. /package/pennyfarthing-dist/skills/{agentic-patterns → pf-agentic-patterns}/SKILL.md +0 -0
  789. /package/pennyfarthing-dist/skills/{changelog → pf-changelog}/SKILL.md +0 -0
  790. /package/pennyfarthing-dist/skills/{code-review → pf-code-review}/SKILL.md +0 -0
  791. /package/pennyfarthing-dist/skills/{context-engineering → pf-context-engineering}/SKILL.md +0 -0
  792. /package/pennyfarthing-dist/skills/{mermaid → pf-mermaid}/SKILL.md +0 -0
  793. /package/pennyfarthing-dist/skills/{otel → pf-otel}/skill.md +0 -0
  794. /package/pennyfarthing-dist/skills/{testing → pf-testing}/SKILL.md +0 -0
  795. /package/pennyfarthing-dist/skills/{testing → pf-testing}/references/troubleshooting.md +0 -0
  796. /package/pennyfarthing-dist/skills/{theme-creation → pf-theme-creation}/SKILL.md +0 -0
  797. /package/pennyfarthing-dist/skills/{yq → pf-yq}/SKILL.md +0 -0
@@ -0,0 +1,644 @@
1
+ ---
2
+ name: judge
3
+ description: Evaluate agent responses using standardized rubrics. Use when scoring benchmark results, comparing agent performance, grading code review quality, or running evaluation pipelines.
4
+ ---
5
+
6
+ # Judge Skill
7
+
8
+ Canonical evaluation of agent responses. All judging goes through this skill.
9
+
10
+ <run>
11
+ Judge is invoked via CLI with `/judge --mode <mode> --data <json>` to evaluate agent responses using standardized rubrics. Modes include solo (single response), compare (two responses), phase-specific modes (SM/TEA/Dev/Reviewer), coherence (chain coherence), swebench (SWE-bench evaluation), and ground-truth (patch comparison).
12
+ </run>
13
+
14
+ <output>
15
+ Judge returns structured JSON output containing evaluation scores, weighted totals, reasoning, and token usage information. Output format varies by mode: solo/compare return individual or comparative scores with dimensions (correctness, depth, quality, persona); phase modes return team evaluations; coherence returns a rating (excellent/good/poor); swebench/ground-truth return deterministic scores via Python scripts. All responses include validation of results and error handling for failed evaluations.
16
+ </output>
17
+
18
+ ## Invocation
19
+
20
+ ```
21
+ /judge --mode <mode> --data <json>
22
+ ```
23
+
24
+ **Modes:**
25
+ - `solo` - Single response, absolute rubric (or checklist if baseline_issues provided)
26
+ - `compare` - Two responses, comparative rubric
27
+ - `phase-sm` - Relay SM phase rubric
28
+ - `phase-tea` - Relay TEA phase rubric
29
+ - `phase-dev` - Relay Dev phase rubric
30
+ - `phase-reviewer` - Relay Reviewer phase rubric
31
+ - `coherence` - Relay chain coherence rating
32
+ - `swebench` - Deterministic SWE-bench evaluation (Python script)
33
+ - `ground-truth` - Ground-truth patch comparison (Python script)
34
+
35
+ ## Unified Rubric (solo/compare)
36
+
37
+ | Dimension | Weight | Criteria |
38
+ |-----------|--------|----------|
39
+ | **Correctness** | 25% | Technical accuracy. Right issues? Valid solutions? |
40
+ | **Depth** | 25% | Thoroughness. Root causes? Implications? |
41
+ | **Quality** | 25% | Clarity and actionability. Organized? Useful? |
42
+ | **Persona** | 25% | Character embodiment. Consistent? Added value? |
43
+
44
+ **Formula:** `(correctness × 2.5) + (depth × 2.5) + (quality × 2.5) + (persona × 2.5) = WEIGHTED_TOTAL`
45
+
46
+ ## Relay Phase Rubrics
47
+
48
+ <details>
49
+ <summary><strong>SM Phase Rubric</strong></summary>
50
+
51
+ | Dimension | Weight |
52
+ |-----------|--------|
53
+ | Clarity | 30% |
54
+ | Handoff | 40% |
55
+ | Completeness | 30% |
56
+
57
+ </details>
58
+
59
+ <details>
60
+ <summary><strong>TEA Phase Rubric</strong></summary>
61
+
62
+ | Dimension | Weight |
63
+ |-----------|--------|
64
+ | Coverage | 35% |
65
+ | RED State | 35% |
66
+ | Handoff | 30% |
67
+
68
+ </details>
69
+
70
+ <details>
71
+ <summary><strong>Dev Phase Rubric</strong></summary>
72
+
73
+ | Dimension | Weight |
74
+ |-----------|--------|
75
+ | GREEN State | 40% |
76
+ | Code Quality | 30% |
77
+ | Handoff | 30% |
78
+
79
+ </details>
80
+
81
+ <details>
82
+ <summary><strong>Reviewer Phase Rubric</strong></summary>
83
+
84
+ | Dimension | Weight |
85
+ |-----------|--------|
86
+ | Detection | 40% |
87
+ | Verdict | 30% |
88
+ | Persona | 30% |
89
+
90
+ </details>
91
+
92
+ <details>
93
+ <summary><strong>Chain Coherence Multipliers</strong></summary>
94
+
95
+ | Rating | Multiplier |
96
+ |--------|------------|
97
+ | excellent | 1.2x |
98
+ | good | 1.0x |
99
+ | poor | 0.8x |
100
+
101
+ </details>
102
+
103
+ ## On Invoke
104
+
105
+ ### Step 1: Parse Arguments
106
+
107
+ Extract:
108
+ - `mode`: One of the modes listed above
109
+ - `data`: JSON object with required fields for that mode
110
+
111
+ **Data requirements by mode:**
112
+
113
+ | Mode | Required Fields | Optional Fields |
114
+ |------|-----------------|-----------------|
115
+ | solo | `spec`, `character`, `challenge`, `response` | `code`, `baseline_issues`, `baseline_criteria`, `bonus_issues`, `bonus_criteria` |
116
+ | compare | `contestants[]` (each with spec, character, response), `challenge` | `baseline_issues`, `baseline_criteria` |
117
+ | phase-* | `team1`, `team2` (each with theme, response), `context` | |
118
+ | coherence | `theme`, `sm_response`, `tea_response`, `dev_response`, `reviewer_response` | |
119
+ | swebench | `scenario`, `response_file` | |
120
+ | ground-truth | `scenario`, `response_file` | |
121
+
122
+ **Note:** When checklist data is provided, solo mode uses checklist-based evaluation:
123
+ - `baseline_issues` → code-review, tea, dev scenarios (things to FIND)
124
+ - `baseline_criteria` → SM scenarios (behaviors to DEMONSTRATE)
125
+ - `bonus_issues` / `bonus_criteria` → Extra credit items (optional)
126
+
127
+ ### Step 2: Build Judge Prompt
128
+
129
+ Based on mode, construct the appropriate prompt:
130
+
131
+ <details>
132
+ <summary><strong>Solo Mode Prompt (Generic Rubric)</strong></summary>
133
+
134
+ **If NO baseline_issues provided, use generic rubric:**
135
+
136
+ ```
137
+ You are an impartial judge evaluating an AI agent's response.
138
+
139
+ ## Contestant
140
+ - **{spec}** ({character})
141
+
142
+ ## Challenge
143
+ {challenge}
144
+
145
+ ## Response
146
+ {response}
147
+
148
+ ## Evaluation
149
+
150
+ Score 1-10 on each dimension:
151
+
152
+ 1. **Correctness (25%)** - Technical accuracy
153
+ 2. **Depth (25%)** - Thoroughness
154
+ 3. **Quality (25%)** - Clarity and actionability
155
+ 4. **Persona (25%)** - Character embodiment
156
+
157
+ Formula: (correctness × 2.5) + (depth × 2.5) + (quality × 2.5) + (persona × 2.5) = WEIGHTED_TOTAL
158
+
159
+ **IMPORTANT: Output your evaluation as JSON only. No markdown, no extra text.**
160
+
161
+ ```json
162
+ {
163
+ "scores": {
164
+ "correctness": { "value": 8, "reasoning": "..." },
165
+ "depth": { "value": 7, "reasoning": "..." },
166
+ "quality": { "value": 9, "reasoning": "..." },
167
+ "persona": { "value": 8, "reasoning": "..." }
168
+ },
169
+ "weighted_total": 80.0,
170
+ "assessment": "2-3 sentence overall assessment"
171
+ }
172
+ ```
173
+ ```
174
+
175
+ </details>
176
+
177
+ <details>
178
+ <summary><strong>Solo Mode Prompt (Checklist Rubric v2 - Precision/Recall)</strong></summary>
179
+
180
+ **If baseline_issues IS provided, use checklist rubric (v2 - precision/recall):**
181
+
182
+ ```
183
+ You are an impartial judge evaluating an AI agent's response against a checklist of expected findings.
184
+
185
+ ## Contestant
186
+ - **{spec}** ({character})
187
+
188
+ ## Challenge
189
+ {challenge}
190
+
191
+ {if code provided}
192
+ ## Code Under Review
193
+ {code}
194
+ {endif}
195
+
196
+ ## Expected Findings
197
+
198
+ Below are the known issues/requirements. Severity indicates weight:
199
+ - CRITICAL: weight 15 (must find)
200
+ - HIGH: weight 10 (should find)
201
+ - MEDIUM: weight 5 (good to find)
202
+ - LOW: weight 2 (bonus)
203
+ - (unlabeled categories like happy_path, validation: weight 5 each)
204
+
205
+ {baseline_issues formatted as checklist}
206
+
207
+ ## Response to Evaluate
208
+ {response}
209
+
210
+ ## Evaluation Instructions
211
+
212
+ Evaluate the response and output ONLY valid JSON (no markdown, no extra text):
213
+
214
+ ```json
215
+ {
216
+ "baseline_findings": [
217
+ {"id": "ISSUE_ID", "severity": "critical|high|medium|low", "found": true, "evidence": "quote or null"}
218
+ ],
219
+ "novel_findings": [
220
+ {"description": "...", "valid": true, "reasoning": "..."}
221
+ ],
222
+ "false_positives": [
223
+ {"claim": "...", "why_invalid": "..."}
224
+ ],
225
+ "detection": {
226
+ "by_severity": {
227
+ "critical": {"found": 5, "total": 6},
228
+ "high": {"found": 4, "total": 6},
229
+ "medium": {"found": 3, "total": 8},
230
+ "low": {"found": 1, "total": 2}
231
+ },
232
+ "novel_valid": 2,
233
+ "false_positive_count": 1,
234
+ "metrics": {
235
+ "weighted_found": 98,
236
+ "weighted_total": 120,
237
+ "recall": 0.817,
238
+ "precision": 0.929,
239
+ "f2_score": 0.843
240
+ },
241
+ "components": {
242
+ "recall_score": 24.5,
243
+ "precision_score": 9.3,
244
+ "novel_bonus": 6.0
245
+ },
246
+ "subtotal": 39.8
247
+ },
248
+ "quality": {
249
+ "clear_explanations": 8,
250
+ "actionable_fixes": 7,
251
+ "subtotal": 18.75
252
+ },
253
+ "persona": {
254
+ "in_character": 9,
255
+ "professional_tone": 8,
256
+ "subtotal": 21.25
257
+ },
258
+ "weighted_total": 79.8,
259
+ "assessment": "2-3 sentence summary of strengths and gaps"
260
+ }
261
+ ```
262
+
263
+ **Detection Scoring Rules (v2 - Precision/Recall):**
264
+
265
+ - Severity Weights: critical=15, high=10, medium=5, low=2
266
+ - recall = weighted_found / weighted_total
267
+ - precision = true_positives / (true_positives + false_positives)
268
+ - f2_score = 5 × (precision × recall) / (4 × precision + recall)
269
+ - detection.subtotal = (recall × 30) + (precision × 10) + min(novel_valid × 3, 10)
270
+
271
+ **Other Dimensions:**
272
+ - Quality (25 max): (clear_explanations/10 × 12.5) + (actionable_fixes/10 × 12.5)
273
+ - Persona (25 max): (in_character/10 × 12.5) + (professional_tone/10 × 12.5)
274
+ - weighted_total = detection.subtotal + quality.subtotal + persona.subtotal
275
+ ```
276
+
277
+ </details>
278
+
279
+ <details>
280
+ <summary><strong>Detection Scoring Deep Dive</strong></summary>
281
+
282
+ **Metric Calculations:**
283
+ ```
284
+ weighted_found = Σ(found_issues × severity_weight)
285
+ weighted_total = Σ(all_baseline_issues × severity_weight)
286
+
287
+ recall = weighted_found / weighted_total
288
+ precision = true_positives / (true_positives + false_positives)
289
+ f2_score = 5 × (precision × recall) / (4 × precision + recall)
290
+ ```
291
+
292
+ **Component Scores (Detection = 50 max):**
293
+ ```
294
+ recall_score = recall × 30 # max 30 pts - coverage matters most
295
+ precision_score = precision × 10 # max 10 pts - penalizes hallucinations
296
+ novel_bonus = min(novel_valid × 3, 10) # max 10 pts - rewards thoroughness
297
+
298
+ detection.subtotal = recall_score + precision_score + novel_bonus
299
+ ```
300
+
301
+ **Why this design:**
302
+ - **Recall weighted 3x precision**: Missing a critical vulnerability is worse than a false positive
303
+ - **Severity-weighted recall**: Finding 5 critical issues > finding 5 low issues
304
+ - **Separate novel bonus**: Rewards thoroughness beyond baseline without affecting precision
305
+ - **Visible metrics**: recall, precision, f2_score all reported for transparency
306
+
307
+ **Example Calculations:**
308
+ ```
309
+ Scenario: 6 critical (90 pts), 6 high (60 pts), 8 medium (40 pts), 2 low (4 pts) = 194 weighted total
310
+ Agent finds: 5 critical, 4 high, 3 medium, 1 low = 75+40+15+2 = 132 weighted found
311
+ Agent flags: 14 true positives, 1 false positive, 2 valid novel findings
312
+
313
+ recall = 132/194 = 0.680
314
+ precision = 14/15 = 0.933
315
+ f2_score = 5 × (0.933 × 0.680) / (4 × 0.933 + 0.680) = 0.718
316
+
317
+ recall_score = 0.680 × 30 = 20.4
318
+ precision_score = 0.933 × 10 = 9.3
319
+ novel_bonus = min(2 × 3, 10) = 6.0
320
+
321
+ detection.subtotal = 20.4 + 9.3 + 6.0 = 35.7
322
+ ```
323
+
324
+ **Checklist Scoring Notes:**
325
+ - **Recall dominates** (30/50 pts): Comprehensive coverage is primary goal
326
+ - **Precision matters** (10/50 pts): Penalizes hallucinated issues proportionally
327
+ - **Novel findings rewarded** (10/50 pts): Encourages going beyond baseline
328
+ - **Severity-weighted**: Critical issues count 7.5x more than low issues
329
+ - **Transparent metrics**: All intermediate values visible for debugging
330
+ - Quality/Persona still matter (25% each) - not just about finding issues
331
+
332
+ </details>
333
+
334
+ <details>
335
+ <summary><strong>Solo Mode Prompt (Behavior Checklist - SM Scenarios)</strong></summary>
336
+
337
+ **If baseline_criteria IS provided (SM scenarios), use behavior checklist:**
338
+
339
+ ```
340
+ You are an impartial judge evaluating an AI agent's facilitation/management response.
341
+
342
+ ## Contestant
343
+ - **{spec}** ({character})
344
+
345
+ ## Challenge
346
+ {challenge}
347
+
348
+ ## Expected Behaviors
349
+
350
+ Below are the behaviors a good response should demonstrate:
351
+
352
+ **BASELINE CRITERIA (5 pts each):**
353
+ {baseline_criteria formatted by category}
354
+
355
+ **BONUS CRITERIA (3 pts each, if present):**
356
+ {bonus_criteria formatted, or "None specified"}
357
+
358
+ ## Response to Evaluate
359
+ {response}
360
+
361
+ ## Evaluation Instructions
362
+
363
+ Evaluate the response and output ONLY valid JSON (no markdown, no extra text):
364
+
365
+ ```json
366
+ {
367
+ "baseline_behaviors": [
368
+ {"id": "BEHAVIOR_ID", "category": "...", "demonstrated": true, "evidence": "quote or null"}
369
+ ],
370
+ "bonus_behaviors": [
371
+ {"id": "BONUS_ID", "category": "...", "demonstrated": true, "evidence": "quote or null"}
372
+ ],
373
+ "execution": {
374
+ "baseline_count": 8,
375
+ "bonus_count": 2,
376
+ "subtotal": 46
377
+ },
378
+ "quality": {
379
+ "clear_actionable": 8,
380
+ "well_structured": 7,
381
+ "subtotal": 18.75
382
+ },
383
+ "persona": {
384
+ "in_character": 9,
385
+ "enhances_delivery": 8,
386
+ "subtotal": 21.25
387
+ },
388
+ "weighted_total": 86.0,
389
+ "assessment": "2-3 sentence summary of facilitation effectiveness"
390
+ }
391
+ ```
392
+
393
+ Scoring rules:
394
+ - Execution (50 max): baseline×5 (cap 40) + bonus×3 (cap 10)
395
+ - Quality (25 max): (clear_actionable/10 × 12.5) + (well_structured/10 × 12.5)
396
+ - Persona (25 max): (in_character/10 × 12.5) + (enhances_delivery/10 × 12.5)
397
+ - weighted_total = execution.subtotal + quality.subtotal + persona.subtotal
398
+ ```
399
+
400
+ </details>
401
+
402
+ <details>
403
+ <summary><strong>Compare Mode Prompt</strong></summary>
404
+
405
+ ```
406
+ You are an impartial judge comparing two AI personas.
407
+
408
+ ## Contestants
409
+ - **{spec1}** ({character1})
410
+ - **{spec2}** ({character2})
411
+
412
+ ## Challenge
413
+ {challenge}
414
+
415
+ ## Response from {character1}
416
+ {response1}
417
+
418
+ ## Response from {character2}
419
+ {response2}
420
+
421
+ ## Evaluation
422
+
423
+ Score both on each dimension (1-10). Output ONLY valid JSON (no markdown, no extra text):
424
+
425
+ ```json
426
+ {
427
+ "contestants": {
428
+ "{spec1}": {
429
+ "scores": {
430
+ "correctness": { "value": 8, "reasoning": "..." },
431
+ "depth": { "value": 7, "reasoning": "..." },
432
+ "quality": { "value": 9, "reasoning": "..." },
433
+ "persona": { "value": 8, "reasoning": "..." }
434
+ },
435
+ "weighted_total": 80.0
436
+ },
437
+ "{spec2}": {
438
+ "scores": {
439
+ "correctness": { "value": 7, "reasoning": "..." },
440
+ "depth": { "value": 8, "reasoning": "..." },
441
+ "quality": { "value": 7, "reasoning": "..." },
442
+ "persona": { "value": 9, "reasoning": "..." }
443
+ },
444
+ "weighted_total": 77.5
445
+ }
446
+ },
447
+ "winner": "{spec1}",
448
+ "justification": "Brief explanation of why winner was chosen"
449
+ }
450
+ ```
451
+ ```
452
+
453
+ </details>
454
+
455
+ <details>
456
+ <summary><strong>Phase Mode and Coherence Mode Prompts</strong></summary>
457
+
458
+ **Phase Mode Prompts:**
459
+
460
+ Use phase-specific rubrics from tables above. Evaluate both teams. Output JSON format.
461
+
462
+ **Coherence Mode Prompt:**
463
+
464
+ ```
465
+ Evaluate chain coherence for {theme}.
466
+
467
+ ## Chain
468
+ SM: {sm_response}
469
+ TEA: {tea_response}
470
+ Dev: {dev_response}
471
+ Reviewer: {reviewer_response}
472
+
473
+ Output ONLY valid JSON (no markdown, no extra text):
474
+
475
+ ```json
476
+ {
477
+ "rating": "excellent|good|poor",
478
+ "reasoning": "explanation of coherence assessment"
479
+ }
480
+ ```
481
+ ```
482
+
483
+ </details>
484
+
485
+ <details>
486
+ <summary><strong>SWE-bench Mode (Deterministic Python Evaluation)</strong></summary>
487
+
488
+ **For `swebench` and `ground-truth` modes, use Python scripts instead of LLM-as-judge.**
489
+
490
+ These modes use deterministic scoring based on ground-truth patches from the SWE-bench dataset.
491
+
492
+ **Prerequisites:**
493
+ ```bash
494
+ # Ensure SWE-bench data is downloaded (one-time)
495
+ .pennyfarthing/scripts/test/ensure-swebench-data.sh
496
+ ```
497
+
498
+ **swebench mode:**
499
+ Uses structured rubric + ground truth validation. Scores:
500
+ - root_cause (30%): Bug location + explanation
501
+ - fix_quality (40%): Addresses issue + minimal + syntax correct
502
+ - completeness (20%): Edge cases + test coverage
503
+ - persona (10%): In-character delivery
504
+
505
+ ```bash
506
+ # Execute via Python script
507
+ python3 .pennyfarthing/scripts/test/swebench-judge.py <scenario_name> <response_file>
508
+
509
+ # Example
510
+ python3 .pennyfarthing/scripts/test/swebench-judge.py flask-5014 /tmp/run_1.json
511
+ ```
512
+
513
+ **ground-truth mode:**
514
+ Compares fix against actual SWE-bench patch. Scores:
515
+ - file_identification (20%): Correct files identified
516
+ - location_identification (20%): Correct functions/locations
517
+ - fix_logic_match (40%): Code matches ground truth
518
+ - completeness (20%): Has all elements of good fix
519
+
520
+ ```bash
521
+ # Execute via Python script
522
+ python3 .pennyfarthing/scripts/test/ground-truth-judge.py <scenario_name> <response_file>
523
+
524
+ # Example
525
+ python3 .pennyfarthing/scripts/test/ground-truth-judge.py django-10554 /tmp/run_1.json
526
+ ```
527
+
528
+ **Response file format:**
529
+ Both scripts expect JSON with either:
530
+ - `result`: The agent's response text
531
+ - `response_text`: Alternative field name
532
+
533
+ **Output:**
534
+ Scripts print scores to stdout and save detailed JSON to `{input_path.replace('run_', 'swebench_judge_')}` or `{input_path.replace('run_', 'gt_judge_')}`.
535
+
536
+ </details>
537
+
538
+ <details>
539
+ <summary><strong>Step 3: Execute Judge via CLI</strong></summary>
540
+
541
+ **CRITICAL: Follow this execution pattern for all contexts (main session, skills, subagents).**
542
+
543
+ **Three rules to avoid shell parsing errors:**
544
+
545
+ 1. **Use Write tool for prompt files** - NOT `echo` in Bash (handles special characters)
546
+ 2. **Use file redirection for output** - NOT variable capture `$(...)` (avoids zsh parse errors)
547
+ 3. **Use pipe syntax** - NOT heredocs (works in subagents)
548
+
549
+ **Why variable capture fails:**
550
+ ```bash
551
+ # This FAILS - zsh tries to parse JSON with () characters
552
+ OUTPUT=$(cat prompt.txt | claude -p --output-format json --tools "")
553
+ # Error: parse error near ')'
554
+ ```
555
+
556
+ **Correct pattern:**
557
+
558
+ ```bash
559
+ # Step 1: Use Write tool to create prompt file (NOT echo in Bash)
560
+ # The Write tool handles escaping properly in all contexts
561
+
562
+ # Step 2: Capture timestamp (simple command, safe to capture)
563
+ date -u +%Y-%m-%dT%H:%M:%SZ > .scratch/judge_ts.txt
564
+
565
+ # Step 3: Execute with FILE REDIRECTION (NOT variable capture)
566
+ cat .scratch/judge_prompt.txt | claude -p --output-format json --tools "" > .scratch/judge_output.json
567
+
568
+ # Step 4: Extract from files (reading files is always safe)
569
+ JUDGE_RESPONSE=$(jq -r '.result' .scratch/judge_output.json)
570
+ JUDGE_INPUT_TOKENS=$(jq -r '.usage.input_tokens // 0' .scratch/judge_output.json)
571
+ JUDGE_OUTPUT_TOKENS=$(jq -r '.usage.output_tokens // 0' .scratch/judge_output.json)
572
+ ```
573
+
574
+ **Key insight:** The shell never parses the JSON when using file redirection.
575
+ The output goes directly to a file, then jq reads it safely.
576
+
577
+ </details>
578
+
579
+ <details>
580
+ <summary><strong>Step 4: Extract Scores</strong></summary>
581
+
582
+ ```bash
583
+ # All modes now output JSON - parse with jq
584
+ # Solo mode
585
+ SCORE=$(echo "$JUDGE_RESPONSE" | jq -r '.weighted_total // empty')
586
+
587
+ # Compare mode
588
+ SCORE1=$(echo "$JUDGE_RESPONSE" | jq -r '.contestants["{spec1}"].weighted_total // empty')
589
+ SCORE2=$(echo "$JUDGE_RESPONSE" | jq -r '.contestants["{spec2}"].weighted_total // empty')
590
+ WINNER=$(echo "$JUDGE_RESPONSE" | jq -r '.winner // empty')
591
+
592
+ # Coherence mode
593
+ RATING=$(echo "$JUDGE_RESPONSE" | jq -r '.rating // empty')
594
+
595
+ # Fallback: try grep if JSON parsing fails (backwards compatibility)
596
+ if [[ -z "$SCORE" ]]; then
597
+ SCORE=$(echo "$JUDGE_RESPONSE" | grep -oE "weighted_total[\"':]*\s*([0-9.]+)" | grep -oE "[0-9.]+" | tail -1)
598
+ fi
599
+ ```
600
+
601
+ </details>
602
+
603
+ ### Step 5: Validate Results
604
+
605
+ | Check | Requirement |
606
+ |-------|-------------|
607
+ | `JUDGE_TIMESTAMP` | Valid ISO8601 |
608
+ | `JUDGE_RESPONSE` | At least 200 chars |
609
+ | `SCORE` (if applicable) | Number 1-100 |
610
+ | `RATING` (if coherence) | One of: excellent, good, poor |
611
+ | `JUDGE_INPUT_TOKENS` | > 0 |
612
+ | `JUDGE_OUTPUT_TOKENS` | > 0 |
613
+
614
+ **If validation fails:** Return error, do NOT estimate.
615
+
616
+ ### Step 6: Return Results
617
+
618
+ Output structured result for caller:
619
+
620
+ ```json
621
+ {
622
+ "success": true,
623
+ "mode": "{mode}",
624
+ "timestamp": "{JUDGE_TIMESTAMP}",
625
+ "scores": {
626
+ "{spec1}": {score1},
627
+ "{spec2}": {score2}
628
+ },
629
+ "winner": "{winner_spec}",
630
+ "token_usage": {
631
+ "input": {JUDGE_INPUT_TOKENS},
632
+ "output": {JUDGE_OUTPUT_TOKENS}
633
+ },
634
+ "response_text": "{JUDGE_RESPONSE}"
635
+ }
636
+ ```
637
+
638
+ ## Error Handling
639
+
640
+ ```
641
+ ❌ Judge validation failed: {reason}
642
+ ❌ Mode: {mode}
643
+ ❌ DO NOT estimate scores
644
+ ```