@pennyfarthing/core 6.6.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 (599) hide show
  1. package/README.md +293 -0
  2. package/package.json +58 -0
  3. package/packages/core/bin/pennyfarthing.js +14 -0
  4. package/packages/core/dist/bmad/context-reader.d.ts +71 -0
  5. package/packages/core/dist/bmad/context-reader.d.ts.map +1 -0
  6. package/packages/core/dist/bmad/context-reader.js +369 -0
  7. package/packages/core/dist/bmad/context-reader.js.map +1 -0
  8. package/packages/core/dist/bmad/context-reader.test.d.ts +71 -0
  9. package/packages/core/dist/bmad/context-reader.test.d.ts.map +1 -0
  10. package/packages/core/dist/bmad/context-reader.test.js +878 -0
  11. package/packages/core/dist/bmad/context-reader.test.js.map +1 -0
  12. package/packages/core/dist/bmad/epics-parser.d.ts +61 -0
  13. package/packages/core/dist/bmad/epics-parser.d.ts.map +1 -0
  14. package/packages/core/dist/bmad/epics-parser.js +331 -0
  15. package/packages/core/dist/bmad/epics-parser.js.map +1 -0
  16. package/packages/core/dist/bmad/epics-parser.test.d.ts +7 -0
  17. package/packages/core/dist/bmad/epics-parser.test.d.ts.map +1 -0
  18. package/packages/core/dist/bmad/epics-parser.test.js +449 -0
  19. package/packages/core/dist/bmad/epics-parser.test.js.map +1 -0
  20. package/packages/core/dist/bmad/index.d.ts +11 -0
  21. package/packages/core/dist/bmad/index.d.ts.map +1 -0
  22. package/packages/core/dist/bmad/index.js +24 -0
  23. package/packages/core/dist/bmad/index.js.map +1 -0
  24. package/packages/core/dist/bmad/status-sync.d.ts +173 -0
  25. package/packages/core/dist/bmad/status-sync.d.ts.map +1 -0
  26. package/packages/core/dist/bmad/status-sync.js +463 -0
  27. package/packages/core/dist/bmad/status-sync.js.map +1 -0
  28. package/packages/core/dist/bmad/status-sync.test.d.ts +7 -0
  29. package/packages/core/dist/bmad/status-sync.test.d.ts.map +1 -0
  30. package/packages/core/dist/bmad/status-sync.test.js +702 -0
  31. package/packages/core/dist/bmad/status-sync.test.js.map +1 -0
  32. package/packages/core/dist/bmad/story-exporter.d.ts +55 -0
  33. package/packages/core/dist/bmad/story-exporter.d.ts.map +1 -0
  34. package/packages/core/dist/bmad/story-exporter.js +170 -0
  35. package/packages/core/dist/bmad/story-exporter.js.map +1 -0
  36. package/packages/core/dist/bmad/story-exporter.test.d.ts +51 -0
  37. package/packages/core/dist/bmad/story-exporter.test.d.ts.map +1 -0
  38. package/packages/core/dist/bmad/story-exporter.test.js +603 -0
  39. package/packages/core/dist/bmad/story-exporter.test.js.map +1 -0
  40. package/packages/core/dist/bmad/story-parser.d.ts +44 -0
  41. package/packages/core/dist/bmad/story-parser.d.ts.map +1 -0
  42. package/packages/core/dist/bmad/story-parser.js +307 -0
  43. package/packages/core/dist/bmad/story-parser.js.map +1 -0
  44. package/packages/core/dist/bmad/story-parser.test.d.ts +44 -0
  45. package/packages/core/dist/bmad/story-parser.test.d.ts.map +1 -0
  46. package/packages/core/dist/bmad/story-parser.test.js +693 -0
  47. package/packages/core/dist/bmad/story-parser.test.js.map +1 -0
  48. package/packages/core/dist/cli/commands/command.d.ts +28 -0
  49. package/packages/core/dist/cli/commands/command.d.ts.map +1 -0
  50. package/packages/core/dist/cli/commands/command.js +399 -0
  51. package/packages/core/dist/cli/commands/command.js.map +1 -0
  52. package/packages/core/dist/cli/commands/cyclist.d.ts +46 -0
  53. package/packages/core/dist/cli/commands/cyclist.d.ts.map +1 -0
  54. package/packages/core/dist/cli/commands/cyclist.js +191 -0
  55. package/packages/core/dist/cli/commands/cyclist.js.map +1 -0
  56. package/packages/core/dist/cli/commands/cyclist.test.d.ts +13 -0
  57. package/packages/core/dist/cli/commands/cyclist.test.d.ts.map +1 -0
  58. package/packages/core/dist/cli/commands/cyclist.test.js +243 -0
  59. package/packages/core/dist/cli/commands/cyclist.test.js.map +1 -0
  60. package/packages/core/dist/cli/commands/doctor.d.ts +9 -0
  61. package/packages/core/dist/cli/commands/doctor.d.ts.map +1 -0
  62. package/packages/core/dist/cli/commands/doctor.js +652 -0
  63. package/packages/core/dist/cli/commands/doctor.js.map +1 -0
  64. package/packages/core/dist/cli/commands/init.d.ts +8 -0
  65. package/packages/core/dist/cli/commands/init.d.ts.map +1 -0
  66. package/packages/core/dist/cli/commands/init.js +524 -0
  67. package/packages/core/dist/cli/commands/init.js.map +1 -0
  68. package/packages/core/dist/cli/commands/skill.d.ts +28 -0
  69. package/packages/core/dist/cli/commands/skill.d.ts.map +1 -0
  70. package/packages/core/dist/cli/commands/skill.js +416 -0
  71. package/packages/core/dist/cli/commands/skill.js.map +1 -0
  72. package/packages/core/dist/cli/commands/theme.d.ts +21 -0
  73. package/packages/core/dist/cli/commands/theme.d.ts.map +1 -0
  74. package/packages/core/dist/cli/commands/theme.js +201 -0
  75. package/packages/core/dist/cli/commands/theme.js.map +1 -0
  76. package/packages/core/dist/cli/commands/uninstall.d.ts +8 -0
  77. package/packages/core/dist/cli/commands/uninstall.d.ts.map +1 -0
  78. package/packages/core/dist/cli/commands/uninstall.js +237 -0
  79. package/packages/core/dist/cli/commands/uninstall.js.map +1 -0
  80. package/packages/core/dist/cli/commands/update.d.ts +9 -0
  81. package/packages/core/dist/cli/commands/update.d.ts.map +1 -0
  82. package/packages/core/dist/cli/commands/update.js +545 -0
  83. package/packages/core/dist/cli/commands/update.js.map +1 -0
  84. package/packages/core/dist/cli/commands/version.d.ts +2 -0
  85. package/packages/core/dist/cli/commands/version.d.ts.map +1 -0
  86. package/packages/core/dist/cli/commands/version.js +28 -0
  87. package/packages/core/dist/cli/commands/version.js.map +1 -0
  88. package/packages/core/dist/cli/customization.test.d.ts +12 -0
  89. package/packages/core/dist/cli/customization.test.d.ts.map +1 -0
  90. package/packages/core/dist/cli/customization.test.js +84 -0
  91. package/packages/core/dist/cli/customization.test.js.map +1 -0
  92. package/packages/core/dist/cli/cyclist-migration.test.d.ts +16 -0
  93. package/packages/core/dist/cli/cyclist-migration.test.d.ts.map +1 -0
  94. package/packages/core/dist/cli/cyclist-migration.test.js +224 -0
  95. package/packages/core/dist/cli/cyclist-migration.test.js.map +1 -0
  96. package/packages/core/dist/cli/index.d.ts +3 -0
  97. package/packages/core/dist/cli/index.d.ts.map +1 -0
  98. package/packages/core/dist/cli/index.js +174 -0
  99. package/packages/core/dist/cli/index.js.map +1 -0
  100. package/packages/core/dist/cli/ocean-profiles.test.d.ts +13 -0
  101. package/packages/core/dist/cli/ocean-profiles.test.d.ts.map +1 -0
  102. package/packages/core/dist/cli/ocean-profiles.test.js +134 -0
  103. package/packages/core/dist/cli/ocean-profiles.test.js.map +1 -0
  104. package/packages/core/dist/cli/theme-maker.test.d.ts +11 -0
  105. package/packages/core/dist/cli/theme-maker.test.d.ts.map +1 -0
  106. package/packages/core/dist/cli/theme-maker.test.js +356 -0
  107. package/packages/core/dist/cli/theme-maker.test.js.map +1 -0
  108. package/packages/core/dist/cli/utils/constants.d.ts +60 -0
  109. package/packages/core/dist/cli/utils/constants.d.ts.map +1 -0
  110. package/packages/core/dist/cli/utils/constants.js +52 -0
  111. package/packages/core/dist/cli/utils/constants.js.map +1 -0
  112. package/packages/core/dist/cli/utils/files.d.ts +71 -0
  113. package/packages/core/dist/cli/utils/files.d.ts.map +1 -0
  114. package/packages/core/dist/cli/utils/files.js +162 -0
  115. package/packages/core/dist/cli/utils/files.js.map +1 -0
  116. package/packages/core/dist/cli/utils/logger.d.ts +26 -0
  117. package/packages/core/dist/cli/utils/logger.d.ts.map +1 -0
  118. package/packages/core/dist/cli/utils/logger.js +88 -0
  119. package/packages/core/dist/cli/utils/logger.js.map +1 -0
  120. package/packages/core/dist/cli/utils/manifest.d.ts +47 -0
  121. package/packages/core/dist/cli/utils/manifest.d.ts.map +1 -0
  122. package/packages/core/dist/cli/utils/manifest.js +90 -0
  123. package/packages/core/dist/cli/utils/manifest.js.map +1 -0
  124. package/packages/core/dist/cli/utils/node-modules.d.ts +6 -0
  125. package/packages/core/dist/cli/utils/node-modules.d.ts.map +1 -0
  126. package/packages/core/dist/cli/utils/node-modules.js +22 -0
  127. package/packages/core/dist/cli/utils/node-modules.js.map +1 -0
  128. package/packages/core/dist/cli/utils/prompts.d.ts +34 -0
  129. package/packages/core/dist/cli/utils/prompts.d.ts.map +1 -0
  130. package/packages/core/dist/cli/utils/prompts.js +93 -0
  131. package/packages/core/dist/cli/utils/prompts.js.map +1 -0
  132. package/packages/core/dist/cli/utils/symlinks.d.ts +29 -0
  133. package/packages/core/dist/cli/utils/symlinks.d.ts.map +1 -0
  134. package/packages/core/dist/cli/utils/symlinks.js +181 -0
  135. package/packages/core/dist/cli/utils/symlinks.js.map +1 -0
  136. package/packages/core/dist/cli/utils/themes.d.ts +104 -0
  137. package/packages/core/dist/cli/utils/themes.d.ts.map +1 -0
  138. package/packages/core/dist/cli/utils/themes.js +393 -0
  139. package/packages/core/dist/cli/utils/themes.js.map +1 -0
  140. package/packages/core/dist/cli/utils/themes.test.d.ts +12 -0
  141. package/packages/core/dist/cli/utils/themes.test.d.ts.map +1 -0
  142. package/packages/core/dist/cli/utils/themes.test.js +144 -0
  143. package/packages/core/dist/cli/utils/themes.test.js.map +1 -0
  144. package/packages/core/dist/cli/utils/version.d.ts +10 -0
  145. package/packages/core/dist/cli/utils/version.d.ts.map +1 -0
  146. package/packages/core/dist/cli/utils/version.js +63 -0
  147. package/packages/core/dist/cli/utils/version.js.map +1 -0
  148. package/packages/core/dist/cli/workspace.test.d.ts +8 -0
  149. package/packages/core/dist/cli/workspace.test.d.ts.map +1 -0
  150. package/packages/core/dist/cli/workspace.test.js +154 -0
  151. package/packages/core/dist/cli/workspace.test.js.map +1 -0
  152. package/packages/core/dist/index.d.ts +6 -0
  153. package/packages/core/dist/index.d.ts.map +1 -0
  154. package/packages/core/dist/index.js +10 -0
  155. package/packages/core/dist/index.js.map +1 -0
  156. package/packages/core/dist/permissions/index.d.ts +9 -0
  157. package/packages/core/dist/permissions/index.d.ts.map +1 -0
  158. package/packages/core/dist/permissions/index.js +13 -0
  159. package/packages/core/dist/permissions/index.js.map +1 -0
  160. package/packages/core/dist/permissions/permission-schema.d.ts +89 -0
  161. package/packages/core/dist/permissions/permission-schema.d.ts.map +1 -0
  162. package/packages/core/dist/permissions/permission-schema.js +120 -0
  163. package/packages/core/dist/permissions/permission-schema.js.map +1 -0
  164. package/packages/core/dist/permissions/permission-schema.test.d.ts +40 -0
  165. package/packages/core/dist/permissions/permission-schema.test.d.ts.map +1 -0
  166. package/packages/core/dist/permissions/permission-schema.test.js +367 -0
  167. package/packages/core/dist/permissions/permission-schema.test.js.map +1 -0
  168. package/packages/core/dist/scripts/add-ocean-profiles.d.ts +9 -0
  169. package/packages/core/dist/scripts/add-ocean-profiles.d.ts.map +1 -0
  170. package/packages/core/dist/scripts/add-ocean-profiles.js +695 -0
  171. package/packages/core/dist/scripts/add-ocean-profiles.js.map +1 -0
  172. package/packages/core/dist/scripts/benchmark-integration.d.ts +182 -0
  173. package/packages/core/dist/scripts/benchmark-integration.d.ts.map +1 -0
  174. package/packages/core/dist/scripts/benchmark-integration.js +691 -0
  175. package/packages/core/dist/scripts/benchmark-integration.js.map +1 -0
  176. package/packages/core/dist/scripts/benchmark-integration.test.d.ts +13 -0
  177. package/packages/core/dist/scripts/benchmark-integration.test.d.ts.map +1 -0
  178. package/packages/core/dist/scripts/benchmark-integration.test.js +680 -0
  179. package/packages/core/dist/scripts/benchmark-integration.test.js.map +1 -0
  180. package/packages/core/dist/scripts/debugging-scenarios.test.d.ts +18 -0
  181. package/packages/core/dist/scripts/debugging-scenarios.test.d.ts.map +1 -0
  182. package/packages/core/dist/scripts/debugging-scenarios.test.js +317 -0
  183. package/packages/core/dist/scripts/debugging-scenarios.test.js.map +1 -0
  184. package/packages/core/dist/scripts/generate-all-faces.d.ts +10 -0
  185. package/packages/core/dist/scripts/generate-all-faces.d.ts.map +1 -0
  186. package/packages/core/dist/scripts/generate-all-faces.js +256 -0
  187. package/packages/core/dist/scripts/generate-all-faces.js.map +1 -0
  188. package/packages/core/dist/scripts/generate-all-faces.test.d.ts +17 -0
  189. package/packages/core/dist/scripts/generate-all-faces.test.d.ts.map +1 -0
  190. package/packages/core/dist/scripts/generate-all-faces.test.js +372 -0
  191. package/packages/core/dist/scripts/generate-all-faces.test.js.map +1 -0
  192. package/packages/core/dist/scripts/generate-all-spiders.d.ts +10 -0
  193. package/packages/core/dist/scripts/generate-all-spiders.d.ts.map +1 -0
  194. package/packages/core/dist/scripts/generate-all-spiders.js +306 -0
  195. package/packages/core/dist/scripts/generate-all-spiders.js.map +1 -0
  196. package/packages/core/dist/scripts/generate-ascii-face.d.ts +52 -0
  197. package/packages/core/dist/scripts/generate-ascii-face.d.ts.map +1 -0
  198. package/packages/core/dist/scripts/generate-ascii-face.js +155 -0
  199. package/packages/core/dist/scripts/generate-ascii-face.js.map +1 -0
  200. package/packages/core/dist/scripts/generate-face.d.ts +52 -0
  201. package/packages/core/dist/scripts/generate-face.d.ts.map +1 -0
  202. package/packages/core/dist/scripts/generate-face.js +199 -0
  203. package/packages/core/dist/scripts/generate-face.js.map +1 -0
  204. package/packages/core/dist/scripts/generate-face.test.d.ts +13 -0
  205. package/packages/core/dist/scripts/generate-face.test.d.ts.map +1 -0
  206. package/packages/core/dist/scripts/generate-face.test.js +301 -0
  207. package/packages/core/dist/scripts/generate-face.test.js.map +1 -0
  208. package/packages/core/dist/scripts/generate-report.d.ts +65 -0
  209. package/packages/core/dist/scripts/generate-report.d.ts.map +1 -0
  210. package/packages/core/dist/scripts/generate-report.js +378 -0
  211. package/packages/core/dist/scripts/generate-report.js.map +1 -0
  212. package/packages/core/dist/scripts/generate-report.test.d.ts +13 -0
  213. package/packages/core/dist/scripts/generate-report.test.d.ts.map +1 -0
  214. package/packages/core/dist/scripts/generate-report.test.js +363 -0
  215. package/packages/core/dist/scripts/generate-report.test.js.map +1 -0
  216. package/packages/core/dist/scripts/generate-spider-report.d.ts +65 -0
  217. package/packages/core/dist/scripts/generate-spider-report.d.ts.map +1 -0
  218. package/packages/core/dist/scripts/generate-spider-report.js +366 -0
  219. package/packages/core/dist/scripts/generate-spider-report.js.map +1 -0
  220. package/packages/core/dist/scripts/generate-spider-report.test.d.ts +13 -0
  221. package/packages/core/dist/scripts/generate-spider-report.test.d.ts.map +1 -0
  222. package/packages/core/dist/scripts/generate-spider-report.test.js +367 -0
  223. package/packages/core/dist/scripts/generate-spider-report.test.js.map +1 -0
  224. package/packages/core/dist/scripts/generate-spider.d.ts +37 -0
  225. package/packages/core/dist/scripts/generate-spider.d.ts.map +1 -0
  226. package/packages/core/dist/scripts/generate-spider.js +315 -0
  227. package/packages/core/dist/scripts/generate-spider.js.map +1 -0
  228. package/packages/core/dist/scripts/generate-spider.test.d.ts +14 -0
  229. package/packages/core/dist/scripts/generate-spider.test.d.ts.map +1 -0
  230. package/packages/core/dist/scripts/generate-spider.test.js +269 -0
  231. package/packages/core/dist/scripts/generate-spider.test.js.map +1 -0
  232. package/packages/core/dist/scripts/job-fair-aggregator.d.ts +150 -0
  233. package/packages/core/dist/scripts/job-fair-aggregator.d.ts.map +1 -0
  234. package/packages/core/dist/scripts/job-fair-aggregator.js +547 -0
  235. package/packages/core/dist/scripts/job-fair-aggregator.js.map +1 -0
  236. package/packages/core/dist/scripts/job-fair-aggregator.test.d.ts +14 -0
  237. package/packages/core/dist/scripts/job-fair-aggregator.test.d.ts.map +1 -0
  238. package/packages/core/dist/scripts/job-fair-aggregator.test.js +616 -0
  239. package/packages/core/dist/scripts/job-fair-aggregator.test.js.map +1 -0
  240. package/packages/core/dist/scripts/run-ci.test.d.ts +20 -0
  241. package/packages/core/dist/scripts/run-ci.test.d.ts.map +1 -0
  242. package/packages/core/dist/scripts/run-ci.test.js +127 -0
  243. package/packages/core/dist/scripts/run-ci.test.js.map +1 -0
  244. package/packages/core/dist/scripts/theme-detail.test.d.ts +10 -0
  245. package/packages/core/dist/scripts/theme-detail.test.d.ts.map +1 -0
  246. package/packages/core/dist/scripts/theme-detail.test.js +199 -0
  247. package/packages/core/dist/scripts/theme-detail.test.js.map +1 -0
  248. package/packages/core/dist/scripts/validate-ocean-profiles.d.ts +9 -0
  249. package/packages/core/dist/scripts/validate-ocean-profiles.d.ts.map +1 -0
  250. package/packages/core/dist/scripts/validate-ocean-profiles.js +130 -0
  251. package/packages/core/dist/scripts/validate-ocean-profiles.js.map +1 -0
  252. package/packages/core/dist/workflow/generic-handoff.d.ts +235 -0
  253. package/packages/core/dist/workflow/generic-handoff.d.ts.map +1 -0
  254. package/packages/core/dist/workflow/generic-handoff.js +358 -0
  255. package/packages/core/dist/workflow/generic-handoff.js.map +1 -0
  256. package/packages/core/dist/workflow/generic-handoff.test.d.ts +21 -0
  257. package/packages/core/dist/workflow/generic-handoff.test.d.ts.map +1 -0
  258. package/packages/core/dist/workflow/generic-handoff.test.js +499 -0
  259. package/packages/core/dist/workflow/generic-handoff.test.js.map +1 -0
  260. package/packages/core/dist/workflow/generic-sm-finish.d.ts +89 -0
  261. package/packages/core/dist/workflow/generic-sm-finish.d.ts.map +1 -0
  262. package/packages/core/dist/workflow/generic-sm-finish.js +157 -0
  263. package/packages/core/dist/workflow/generic-sm-finish.js.map +1 -0
  264. package/packages/core/dist/workflow/generic-sm-setup.d.ts +138 -0
  265. package/packages/core/dist/workflow/generic-sm-setup.d.ts.map +1 -0
  266. package/packages/core/dist/workflow/generic-sm-setup.js +382 -0
  267. package/packages/core/dist/workflow/generic-sm-setup.js.map +1 -0
  268. package/packages/core/dist/workflow/sm-subagents.test.d.ts +23 -0
  269. package/packages/core/dist/workflow/sm-subagents.test.d.ts.map +1 -0
  270. package/packages/core/dist/workflow/sm-subagents.test.js +727 -0
  271. package/packages/core/dist/workflow/sm-subagents.test.js.map +1 -0
  272. package/packages/core/dist/workflow/story-workflow-routing.test.d.ts +17 -0
  273. package/packages/core/dist/workflow/story-workflow-routing.test.d.ts.map +1 -0
  274. package/packages/core/dist/workflow/story-workflow-routing.test.js +559 -0
  275. package/packages/core/dist/workflow/story-workflow-routing.test.js.map +1 -0
  276. package/packages/core/dist/workflow/test-cache.d.ts +131 -0
  277. package/packages/core/dist/workflow/test-cache.d.ts.map +1 -0
  278. package/packages/core/dist/workflow/test-cache.js +226 -0
  279. package/packages/core/dist/workflow/test-cache.js.map +1 -0
  280. package/packages/core/dist/workflow/test-cache.test.d.ts +17 -0
  281. package/packages/core/dist/workflow/test-cache.test.d.ts.map +1 -0
  282. package/packages/core/dist/workflow/test-cache.test.js +438 -0
  283. package/packages/core/dist/workflow/test-cache.test.js.map +1 -0
  284. package/packages/core/dist/workflow/workflow-loader.d.ts +76 -0
  285. package/packages/core/dist/workflow/workflow-loader.d.ts.map +1 -0
  286. package/packages/core/dist/workflow/workflow-loader.js +133 -0
  287. package/packages/core/dist/workflow/workflow-loader.js.map +1 -0
  288. package/packages/core/dist/workflow/workflow-loader.test.d.ts +15 -0
  289. package/packages/core/dist/workflow/workflow-loader.test.d.ts.map +1 -0
  290. package/packages/core/dist/workflow/workflow-loader.test.js +354 -0
  291. package/packages/core/dist/workflow/workflow-loader.test.js.map +1 -0
  292. package/packages/core/dist/workflow/workflow-migration.test.d.ts +17 -0
  293. package/packages/core/dist/workflow/workflow-migration.test.d.ts.map +1 -0
  294. package/packages/core/dist/workflow/workflow-migration.test.js +372 -0
  295. package/packages/core/dist/workflow/workflow-migration.test.js.map +1 -0
  296. package/packages/core/dist/workflow/workflow-router.d.ts +55 -0
  297. package/packages/core/dist/workflow/workflow-router.d.ts.map +1 -0
  298. package/packages/core/dist/workflow/workflow-router.js +245 -0
  299. package/packages/core/dist/workflow/workflow-router.js.map +1 -0
  300. package/packages/core/dist/workflow/workflow-router.test.d.ts +20 -0
  301. package/packages/core/dist/workflow/workflow-router.test.d.ts.map +1 -0
  302. package/packages/core/dist/workflow/workflow-router.test.js +607 -0
  303. package/packages/core/dist/workflow/workflow-router.test.js.map +1 -0
  304. package/packages/core/dist/workflow/workflow-schema.d.ts +98 -0
  305. package/packages/core/dist/workflow/workflow-schema.d.ts.map +1 -0
  306. package/packages/core/dist/workflow/workflow-schema.js +230 -0
  307. package/packages/core/dist/workflow/workflow-schema.js.map +1 -0
  308. package/packages/core/dist/workflow/workflow-schema.test.d.ts +45 -0
  309. package/packages/core/dist/workflow/workflow-schema.test.d.ts.map +1 -0
  310. package/packages/core/dist/workflow/workflow-schema.test.js +512 -0
  311. package/packages/core/dist/workflow/workflow-schema.test.js.map +1 -0
  312. package/pennyfarthing-dist/agents/README.md +397 -0
  313. package/pennyfarthing-dist/agents/architect.md +171 -0
  314. package/pennyfarthing-dist/agents/dev.md +225 -0
  315. package/pennyfarthing-dist/agents/devops.md +183 -0
  316. package/pennyfarthing-dist/agents/generic-handoff.md +451 -0
  317. package/pennyfarthing-dist/agents/generic-sm-finish.md +261 -0
  318. package/pennyfarthing-dist/agents/generic-sm-setup.md +214 -0
  319. package/pennyfarthing-dist/agents/orchestrator.md +316 -0
  320. package/pennyfarthing-dist/agents/pm.md +153 -0
  321. package/pennyfarthing-dist/agents/reviewer-preflight.md +224 -0
  322. package/pennyfarthing-dist/agents/reviewer.md +315 -0
  323. package/pennyfarthing-dist/agents/sm-file-summary.md +109 -0
  324. package/pennyfarthing-dist/agents/sm-handoff.md +97 -0
  325. package/pennyfarthing-dist/agents/sm.md +480 -0
  326. package/pennyfarthing-dist/agents/tea.md +191 -0
  327. package/pennyfarthing-dist/agents/tech-writer.md +148 -0
  328. package/pennyfarthing-dist/agents/testing-runner.md +420 -0
  329. package/pennyfarthing-dist/agents/ux-designer.md +158 -0
  330. package/pennyfarthing-dist/agents/workflow-status-check.md +332 -0
  331. package/pennyfarthing-dist/commands/architect.md +62 -0
  332. package/pennyfarthing-dist/commands/benchmark-control.md +69 -0
  333. package/pennyfarthing-dist/commands/benchmark.md +467 -0
  334. package/pennyfarthing-dist/commands/brainstorm.md +91 -0
  335. package/pennyfarthing-dist/commands/check.md +156 -0
  336. package/pennyfarthing-dist/commands/chore.md +178 -0
  337. package/pennyfarthing-dist/commands/close-epic.md +136 -0
  338. package/pennyfarthing-dist/commands/continue-session.md +184 -0
  339. package/pennyfarthing-dist/commands/create-branches-from-story.md +374 -0
  340. package/pennyfarthing-dist/commands/create-theme.md +29 -0
  341. package/pennyfarthing-dist/commands/dev.md +60 -0
  342. package/pennyfarthing-dist/commands/devops.md +59 -0
  343. package/pennyfarthing-dist/commands/git-cleanup.md +340 -0
  344. package/pennyfarthing-dist/commands/health-check.md +108 -0
  345. package/pennyfarthing-dist/commands/help.md +264 -0
  346. package/pennyfarthing-dist/commands/job-fair.md +102 -0
  347. package/pennyfarthing-dist/commands/list-themes.md +17 -0
  348. package/pennyfarthing-dist/commands/new-work.md +127 -0
  349. package/pennyfarthing-dist/commands/orchestrator.md +56 -0
  350. package/pennyfarthing-dist/commands/parallel-work.md +71 -0
  351. package/pennyfarthing-dist/commands/party-mode.md +67 -0
  352. package/pennyfarthing-dist/commands/permissions.md +193 -0
  353. package/pennyfarthing-dist/commands/pm.md +60 -0
  354. package/pennyfarthing-dist/commands/prime.md +140 -0
  355. package/pennyfarthing-dist/commands/release.md +58 -0
  356. package/pennyfarthing-dist/commands/repo-status.md +49 -0
  357. package/pennyfarthing-dist/commands/retro.md +200 -0
  358. package/pennyfarthing-dist/commands/reviewer.md +64 -0
  359. package/pennyfarthing-dist/commands/run-ci.md +116 -0
  360. package/pennyfarthing-dist/commands/set-theme.md +52 -0
  361. package/pennyfarthing-dist/commands/show-theme.md +21 -0
  362. package/pennyfarthing-dist/commands/sm.md +70 -0
  363. package/pennyfarthing-dist/commands/solo.md +411 -0
  364. package/pennyfarthing-dist/commands/sprint-planning.md +109 -0
  365. package/pennyfarthing-dist/commands/start-epic.md +156 -0
  366. package/pennyfarthing-dist/commands/sync-epic-to-jira.md +184 -0
  367. package/pennyfarthing-dist/commands/sync-work-with-sprint.md +376 -0
  368. package/pennyfarthing-dist/commands/tea.md +63 -0
  369. package/pennyfarthing-dist/commands/tech-writer.md +53 -0
  370. package/pennyfarthing-dist/commands/theme-maker.md +671 -0
  371. package/pennyfarthing-dist/commands/update-domain-docs.md +83 -0
  372. package/pennyfarthing-dist/commands/ux-designer.md +62 -0
  373. package/pennyfarthing-dist/commands/work.md +111 -0
  374. package/pennyfarthing-dist/guides/AGENT-COORDINATION.md +480 -0
  375. package/pennyfarthing-dist/guides/AGENT-SCOPES.md +201 -0
  376. package/pennyfarthing-dist/guides/HOOKS.md +230 -0
  377. package/pennyfarthing-dist/guides/PROMPT-PATTERNS.md +338 -0
  378. package/pennyfarthing-dist/guides/SESSION-ARTIFACTS.md +193 -0
  379. package/pennyfarthing-dist/guides/agent-template-strategic.md +148 -0
  380. package/pennyfarthing-dist/guides/agent-template-tactical.md +162 -0
  381. package/pennyfarthing-dist/guides/patterns/approval-gates-pattern.md +746 -0
  382. package/pennyfarthing-dist/guides/patterns/fan-out-fan-in-pattern.md +574 -0
  383. package/pennyfarthing-dist/guides/patterns/helper-delegation-pattern.md +488 -0
  384. package/pennyfarthing-dist/guides/patterns/tdd-flow-pattern.md +402 -0
  385. package/pennyfarthing-dist/guides/permission-protocol.md +188 -0
  386. package/pennyfarthing-dist/guides/persona-loading.md +46 -0
  387. package/pennyfarthing-dist/guides/persona-system.md +294 -0
  388. package/pennyfarthing-dist/guides/shared-agent-behavior.md +388 -0
  389. package/pennyfarthing-dist/guides/shared-context.md +147 -0
  390. package/pennyfarthing-dist/guides/strategic-agent-behavior.md +348 -0
  391. package/pennyfarthing-dist/guides/tactical-agent-behavior.md +1041 -0
  392. package/pennyfarthing-dist/guides/workflow-schema.md +195 -0
  393. package/pennyfarthing-dist/guides/worktree-mode.md +113 -0
  394. package/pennyfarthing-dist/output-styles/teaching.md +33 -0
  395. package/pennyfarthing-dist/output-styles/terse.md +20 -0
  396. package/pennyfarthing-dist/output-styles/verbose.md +28 -0
  397. package/pennyfarthing-dist/personas/themes/1984.yaml +312 -0
  398. package/pennyfarthing-dist/personas/themes/a-team.yaml +207 -0
  399. package/pennyfarthing-dist/personas/themes/agatha-christie.yaml +300 -0
  400. package/pennyfarthing-dist/personas/themes/alice-in-wonderland.yaml +330 -0
  401. package/pennyfarthing-dist/personas/themes/all-stars.yaml +332 -0
  402. package/pennyfarthing-dist/personas/themes/ancient-philosophers.yaml +320 -0
  403. package/pennyfarthing-dist/personas/themes/ancient-strategists.yaml +306 -0
  404. package/pennyfarthing-dist/personas/themes/arcane.yaml +288 -0
  405. package/pennyfarthing-dist/personas/themes/arthurian-mythos.yaml +331 -0
  406. package/pennyfarthing-dist/personas/themes/avatar-the-last-airbender.yaml +288 -0
  407. package/pennyfarthing-dist/personas/themes/babylon-5.yaml +288 -0
  408. package/pennyfarthing-dist/personas/themes/battlestar-galactica.yaml +288 -0
  409. package/pennyfarthing-dist/personas/themes/better-call-saul.yaml +288 -0
  410. package/pennyfarthing-dist/personas/themes/big-lebowski.yaml +300 -0
  411. package/pennyfarthing-dist/personas/themes/black-sails.yaml +300 -0
  412. package/pennyfarthing-dist/personas/themes/blade-runner.yaml +295 -0
  413. package/pennyfarthing-dist/personas/themes/bobiverse.yaml +288 -0
  414. package/pennyfarthing-dist/personas/themes/breaking-bad.yaml +327 -0
  415. package/pennyfarthing-dist/personas/themes/catch-22.yaml +316 -0
  416. package/pennyfarthing-dist/personas/themes/classical-composers.yaml +310 -0
  417. package/pennyfarthing-dist/personas/themes/control.yaml +197 -0
  418. package/pennyfarthing-dist/personas/themes/count-of-monte-cristo.yaml +320 -0
  419. package/pennyfarthing-dist/personas/themes/cowboy-bebop.yaml +323 -0
  420. package/pennyfarthing-dist/personas/themes/deadwood.yaml +300 -0
  421. package/pennyfarthing-dist/personas/themes/dickens.yaml +320 -0
  422. package/pennyfarthing-dist/personas/themes/discworld.yaml +332 -0
  423. package/pennyfarthing-dist/personas/themes/doctor-who.yaml +290 -0
  424. package/pennyfarthing-dist/personas/themes/don-quixote.yaml +320 -0
  425. package/pennyfarthing-dist/personas/themes/dune.yaml +307 -0
  426. package/pennyfarthing-dist/personas/themes/enlightenment-thinkers.yaml +320 -0
  427. package/pennyfarthing-dist/personas/themes/expeditionary-force.yaml +288 -0
  428. package/pennyfarthing-dist/personas/themes/fargo.yaml +330 -0
  429. package/pennyfarthing-dist/personas/themes/film-auteurs.yaml +312 -0
  430. package/pennyfarthing-dist/personas/themes/firefly.yaml +328 -0
  431. package/pennyfarthing-dist/personas/themes/foundation.yaml +290 -0
  432. package/pennyfarthing-dist/personas/themes/futurama.yaml +321 -0
  433. package/pennyfarthing-dist/personas/themes/game-of-thrones.yaml +290 -0
  434. package/pennyfarthing-dist/personas/themes/gilligans-island.yaml +243 -0
  435. package/pennyfarthing-dist/personas/themes/gothic-literature.yaml +308 -0
  436. package/pennyfarthing-dist/personas/themes/great-gatsby.yaml +308 -0
  437. package/pennyfarthing-dist/personas/themes/greek-mythology.yaml +330 -0
  438. package/pennyfarthing-dist/personas/themes/hannibal.yaml +300 -0
  439. package/pennyfarthing-dist/personas/themes/harry-potter.yaml +324 -0
  440. package/pennyfarthing-dist/personas/themes/his-dark-materials.yaml +291 -0
  441. package/pennyfarthing-dist/personas/themes/historical-figures.yaml +288 -0
  442. package/pennyfarthing-dist/personas/themes/hitchhikers-guide.yaml +331 -0
  443. package/pennyfarthing-dist/personas/themes/house-md.yaml +321 -0
  444. package/pennyfarthing-dist/personas/themes/imperial-radch.yaml +289 -0
  445. package/pennyfarthing-dist/personas/themes/inspector-morse.yaml +300 -0
  446. package/pennyfarthing-dist/personas/themes/jane-austen.yaml +287 -0
  447. package/pennyfarthing-dist/personas/themes/jazz-legends.yaml +320 -0
  448. package/pennyfarthing-dist/personas/themes/justified.yaml +300 -0
  449. package/pennyfarthing-dist/personas/themes/legion-of-doom.yaml +219 -0
  450. package/pennyfarthing-dist/personas/themes/les-miserables.yaml +299 -0
  451. package/pennyfarthing-dist/personas/themes/lord-of-the-rings.yaml +334 -0
  452. package/pennyfarthing-dist/personas/themes/lovecraft-mythos.yaml +334 -0
  453. package/pennyfarthing-dist/personas/themes/mad-max.yaml +355 -0
  454. package/pennyfarthing-dist/personas/themes/mad-men.yaml +289 -0
  455. package/pennyfarthing-dist/personas/themes/marvel-mcu.yaml +300 -0
  456. package/pennyfarthing-dist/personas/themes/mash.yaml +334 -0
  457. package/pennyfarthing-dist/personas/themes/mass-effect.yaml +289 -0
  458. package/pennyfarthing-dist/personas/themes/military-commanders.yaml +306 -0
  459. package/pennyfarthing-dist/personas/themes/moby-dick.yaml +320 -0
  460. package/pennyfarthing-dist/personas/themes/monty-python.yaml +303 -0
  461. package/pennyfarthing-dist/personas/themes/neuromancer.yaml +300 -0
  462. package/pennyfarthing-dist/personas/themes/norse-mythology.yaml +329 -0
  463. package/pennyfarthing-dist/personas/themes/parks-and-rec.yaml +242 -0
  464. package/pennyfarthing-dist/personas/themes/peaky-blinders.yaml +298 -0
  465. package/pennyfarthing-dist/personas/themes/princess-bride.yaml +220 -0
  466. package/pennyfarthing-dist/personas/themes/renaissance-masters.yaml +320 -0
  467. package/pennyfarthing-dist/personas/themes/rome.yaml +300 -0
  468. package/pennyfarthing-dist/personas/themes/russian-masters.yaml +318 -0
  469. package/pennyfarthing-dist/personas/themes/sandman.yaml +288 -0
  470. package/pennyfarthing-dist/personas/themes/scientific-revolutionaries.yaml +320 -0
  471. package/pennyfarthing-dist/personas/themes/shakespeare.yaml +301 -0
  472. package/pennyfarthing-dist/personas/themes/sherlock-holmes.yaml +289 -0
  473. package/pennyfarthing-dist/personas/themes/snow-crash.yaml +288 -0
  474. package/pennyfarthing-dist/personas/themes/software-pioneers.yaml +300 -0
  475. package/pennyfarthing-dist/personas/themes/star-trek-tng.yaml +230 -0
  476. package/pennyfarthing-dist/personas/themes/star-trek-tos.yaml +210 -0
  477. package/pennyfarthing-dist/personas/themes/star-wars.yaml +303 -0
  478. package/pennyfarthing-dist/personas/themes/succession.yaml +300 -0
  479. package/pennyfarthing-dist/personas/themes/superfriends.yaml +208 -0
  480. package/pennyfarthing-dist/personas/themes/ted-lasso.yaml +236 -0
  481. package/pennyfarthing-dist/personas/themes/the-americans.yaml +300 -0
  482. package/pennyfarthing-dist/personas/themes/the-crown.yaml +300 -0
  483. package/pennyfarthing-dist/personas/themes/the-expanse.yaml +213 -0
  484. package/pennyfarthing-dist/personas/themes/the-good-place.yaml +322 -0
  485. package/pennyfarthing-dist/personas/themes/the-matrix.yaml +353 -0
  486. package/pennyfarthing-dist/personas/themes/the-odyssey.yaml +300 -0
  487. package/pennyfarthing-dist/personas/themes/the-office.yaml +330 -0
  488. package/pennyfarthing-dist/personas/themes/the-simpsons.yaml +308 -0
  489. package/pennyfarthing-dist/personas/themes/the-sopranos.yaml +300 -0
  490. package/pennyfarthing-dist/personas/themes/the-wire.yaml +311 -0
  491. package/pennyfarthing-dist/personas/themes/the-witcher.yaml +300 -0
  492. package/pennyfarthing-dist/personas/themes/twin-peaks.yaml +302 -0
  493. package/pennyfarthing-dist/personas/themes/vorkosigan-saga.yaml +300 -0
  494. package/pennyfarthing-dist/personas/themes/watchmen.yaml +291 -0
  495. package/pennyfarthing-dist/personas/themes/west-wing.yaml +291 -0
  496. package/pennyfarthing-dist/personas/themes/world-explorers.yaml +320 -0
  497. package/pennyfarthing-dist/personas/themes/wwii-leaders.yaml +307 -0
  498. package/pennyfarthing-dist/personas/themes/x-files.yaml +302 -0
  499. package/pennyfarthing-dist/scripts/add-short-names.mjs +264 -0
  500. package/pennyfarthing-dist/scripts/agent-session.sh +367 -0
  501. package/pennyfarthing-dist/scripts/check-context.sh +187 -0
  502. package/pennyfarthing-dist/scripts/check.sh +497 -0
  503. package/pennyfarthing-dist/scripts/deploy.sh +284 -0
  504. package/pennyfarthing-dist/scripts/doctor-dogfood.sh +360 -0
  505. package/pennyfarthing-dist/scripts/hooks/context-circuit-breaker.sh +61 -0
  506. package/pennyfarthing-dist/scripts/hooks/context-warning.sh +66 -0
  507. package/pennyfarthing-dist/scripts/hooks/otel-auto-config.sh +35 -0
  508. package/pennyfarthing-dist/scripts/hooks/post-merge.sh +166 -0
  509. package/pennyfarthing-dist/scripts/hooks/pre-commit.sh +50 -0
  510. package/pennyfarthing-dist/scripts/hooks/pre-edit-check.sh +71 -0
  511. package/pennyfarthing-dist/scripts/hooks/pre-push.sh +54 -0
  512. package/pennyfarthing-dist/scripts/hooks/session-start.sh +98 -0
  513. package/pennyfarthing-dist/scripts/hooks/session-stop.sh +59 -0
  514. package/pennyfarthing-dist/scripts/install-git-hooks.sh +91 -0
  515. package/pennyfarthing-dist/scripts/prime.sh +161 -0
  516. package/pennyfarthing-dist/scripts/release.sh +198 -0
  517. package/pennyfarthing-dist/scripts/repo-utils.sh +778 -0
  518. package/pennyfarthing-dist/scripts/run-ci.sh +219 -0
  519. package/pennyfarthing-dist/scripts/run.sh +65 -0
  520. package/pennyfarthing-dist/scripts/statusline.sh +264 -0
  521. package/pennyfarthing-dist/scripts/tests/check.test.sh +582 -0
  522. package/pennyfarthing-dist/scripts/tests/test-character-voice.sh +107 -0
  523. package/pennyfarthing-dist/scripts/tests/test-drift-detection.sh +597 -0
  524. package/pennyfarthing-dist/scripts/tests/test-post-merge-hook.sh +514 -0
  525. package/pennyfarthing-dist/scripts/tests/test-session-checkpoint.sh +517 -0
  526. package/pennyfarthing-dist/scripts/tests/test-solo-command.sh +331 -0
  527. package/pennyfarthing-dist/scripts/uninstall.sh +271 -0
  528. package/pennyfarthing-dist/scripts/utils/background-tasks.sh +177 -0
  529. package/pennyfarthing-dist/scripts/utils/check-status.sh +251 -0
  530. package/pennyfarthing-dist/scripts/utils/checkpoint.sh +136 -0
  531. package/pennyfarthing-dist/scripts/utils/common.sh +157 -0
  532. package/pennyfarthing-dist/scripts/utils/create-feature-branches.sh +230 -0
  533. package/pennyfarthing-dist/scripts/utils/file-lock.sh +269 -0
  534. package/pennyfarthing-dist/scripts/utils/find-related-work.sh +231 -0
  535. package/pennyfarthing-dist/scripts/utils/find-root.sh +33 -0
  536. package/pennyfarthing-dist/scripts/utils/generate-skill-docs.sh +110 -0
  537. package/pennyfarthing-dist/scripts/utils/git-status-all.sh +127 -0
  538. package/pennyfarthing-dist/scripts/utils/ground-truth-judge.py +289 -0
  539. package/pennyfarthing-dist/scripts/utils/jira/jira-lib.mjs +443 -0
  540. package/pennyfarthing-dist/scripts/utils/jira/jira-sync-story.mjs +208 -0
  541. package/pennyfarthing-dist/scripts/utils/jira/jira-sync.mjs +198 -0
  542. package/pennyfarthing-dist/scripts/utils/jira-claim-story.sh +162 -0
  543. package/pennyfarthing-dist/scripts/utils/jira-lib.sh +463 -0
  544. package/pennyfarthing-dist/scripts/utils/jira-sync-story.sh +8 -0
  545. package/pennyfarthing-dist/scripts/utils/jira-sync.sh +8 -0
  546. package/pennyfarthing-dist/scripts/utils/log-skill-usage.sh +74 -0
  547. package/pennyfarthing-dist/scripts/utils/logging.sh +186 -0
  548. package/pennyfarthing-dist/scripts/utils/repo-scan.sh +141 -0
  549. package/pennyfarthing-dist/scripts/utils/retry.sh +76 -0
  550. package/pennyfarthing-dist/scripts/utils/run-timestamp.sh +7 -0
  551. package/pennyfarthing-dist/scripts/utils/session-cleanup.sh +319 -0
  552. package/pennyfarthing-dist/scripts/utils/skill-usage-report.sh +193 -0
  553. package/pennyfarthing-dist/scripts/utils/sprint-common.sh +286 -0
  554. package/pennyfarthing-dist/scripts/utils/sprint-metrics.sh +241 -0
  555. package/pennyfarthing-dist/scripts/utils/swebench-judge.py +400 -0
  556. package/pennyfarthing-dist/scripts/utils/sync-epic-to-jira.sh +16 -0
  557. package/pennyfarthing-dist/scripts/utils/test-setup.sh +337 -0
  558. package/pennyfarthing-dist/scripts/utils/validate-subagent-frontmatter.sh +160 -0
  559. package/pennyfarthing-dist/scripts/worktree-manager.sh +498 -0
  560. package/pennyfarthing-dist/skills/agentic-patterns/SKILL.md +236 -0
  561. package/pennyfarthing-dist/skills/changelog/SKILL.md +367 -0
  562. package/pennyfarthing-dist/skills/code-review/SKILL.md +168 -0
  563. package/pennyfarthing-dist/skills/context-engineering/SKILL.md +268 -0
  564. package/pennyfarthing-dist/skills/cyclist/SKILL.md +117 -0
  565. package/pennyfarthing-dist/skills/dev-patterns/SKILL.md +421 -0
  566. package/pennyfarthing-dist/skills/finalize-run/SKILL.md +258 -0
  567. package/pennyfarthing-dist/skills/jira/SKILL.md +281 -0
  568. package/pennyfarthing-dist/skills/judge/SKILL.md +524 -0
  569. package/pennyfarthing-dist/skills/just/SKILL.md +160 -0
  570. package/pennyfarthing-dist/skills/mermaid/SKILL.md +240 -0
  571. package/pennyfarthing-dist/skills/otel/skill.md +222 -0
  572. package/pennyfarthing-dist/skills/permissions/skill.md +172 -0
  573. package/pennyfarthing-dist/skills/persona-benchmark/SKILL.md +173 -0
  574. package/pennyfarthing-dist/skills/skill-registry.schema.json +102 -0
  575. package/pennyfarthing-dist/skills/skill-registry.yaml +335 -0
  576. package/pennyfarthing-dist/skills/sprint-context/SKILL.md +120 -0
  577. package/pennyfarthing-dist/skills/story-management/SKILL.md +208 -0
  578. package/pennyfarthing-dist/skills/testing/SKILL.md +99 -0
  579. package/pennyfarthing-dist/skills/testing/references/troubleshooting.md +124 -0
  580. package/pennyfarthing-dist/skills/theme/skill.md +129 -0
  581. package/pennyfarthing-dist/skills/theme-creation/SKILL.md +169 -0
  582. package/pennyfarthing-dist/skills/workflow/SKILL.md +160 -0
  583. package/pennyfarthing-dist/skills/yq/SKILL.md +264 -0
  584. package/pennyfarthing-dist/templates/LEADERBOARD.schema.yaml +187 -0
  585. package/pennyfarthing-dist/templates/LEADERBOARD.template.md +59 -0
  586. package/pennyfarthing-dist/templates/agent-scopes.yaml.template +276 -0
  587. package/pennyfarthing-dist/templates/pennyfarthing-settings.yaml.template +61 -0
  588. package/pennyfarthing-dist/templates/persona-config.yaml.template +22 -0
  589. package/pennyfarthing-dist/templates/preferences.yaml.template +15 -0
  590. package/pennyfarthing-dist/templates/settings.local.json.template +90 -0
  591. package/pennyfarthing-dist/templates/setup-env.sh.template +18 -0
  592. package/pennyfarthing-dist/templates/shared-context.md.template +70 -0
  593. package/pennyfarthing-dist/templates/sidecar/decisions.md.template +40 -0
  594. package/pennyfarthing-dist/templates/sidecar/gotchas.md.template +37 -0
  595. package/pennyfarthing-dist/templates/sidecar/patterns.md.template +34 -0
  596. package/pennyfarthing-dist/workflows/agent-docs.yaml +70 -0
  597. package/pennyfarthing-dist/workflows/bdd.yaml +58 -0
  598. package/pennyfarthing-dist/workflows/tdd.yaml +50 -0
  599. package/pennyfarthing-dist/workflows/trivial.yaml +40 -0
@@ -0,0 +1,451 @@
1
+ ---
2
+ name: generic-handoff
3
+ description: Workflow-driven handoff that reads phase requirements from workflow definition
4
+ tools: Bash, Read, Edit, Grep
5
+ model: haiku
6
+ ---
7
+ You are a workflow-driven handoff assistant. Complete the handoff for story {STORY_ID}.
8
+
9
+ ## Parameters (provided by calling agent)
10
+
11
+ | Param | Required | Description |
12
+ |-------|----------|-------------|
13
+ | `STORY_ID` | Yes | Story identifier (e.g., "31-10") |
14
+ | `WORKFLOW` | Yes | Workflow name (e.g., "tdd", "trivial") |
15
+ | `CURRENT_PHASE` | Yes | Current phase name (e.g., "red", "green", "review") |
16
+ | `REPOS` | Yes | Repository or "pennyfarthing" |
17
+ | `SESSION_FILE` | No | Defaults to `.session/{STORY_ID}-session.md` |
18
+ | `VERDICT` | No | For review phase: "approved" or "rejected" |
19
+ | `TEST_RESULT` | No | For test gates: "RED" or "GREEN" |
20
+ | `ASSESSMENT_SECTION` | No | Section name to verify exists (e.g., "TEA Assessment") |
21
+ | `PR_NUMBER` | No | For green→review: PR number to verify |
22
+ | `BRANCH` | No | Feature branch name |
23
+
24
+ ## Workflow-Driven Logic
25
+
26
+ This handoff uses the CLI wrapper (`scripts/generic-handoff-cli.sh`) which calls the
27
+ TypeScript implementation in `packages/core/src/workflow/generic-handoff.ts`.
28
+
29
+ **Key operations:**
30
+ 1. Check gate conditions: `./scripts/generic-handoff-cli.sh check-gate`
31
+ 2. Find next phase: `./scripts/generic-handoff-cli.sh next-phase`
32
+ 3. Format transitions: `./scripts/generic-handoff-cli.sh format-transition`
33
+
34
+ **Gate types:**
35
+ - `tests_fail` - Tests must be RED (TEA → Dev)
36
+ - `tests_pass` - Tests must be GREEN (Dev → Reviewer)
37
+ - `approval` - Requires APPROVED or REJECTED verdict (Reviewer → SM/Dev)
38
+ - `manual` - No checks required, always passes (SM setup/finish)
39
+ - `(none)` - Phases without gates are treated as `manual` (always pass)
40
+
41
+ ### Step 1: Find Current Phase and Gate Type
42
+
43
+ ```bash
44
+ # Get current phase details including gate type
45
+ ./scripts/generic-handoff-cli.sh find-phase --workflow {WORKFLOW} --phase {CURRENT_PHASE}
46
+ ```
47
+
48
+ Returns JSON with phase name, agent, and gate type (or null if no gate).
49
+
50
+ ### Step 2: Verify Assessment Exists
51
+
52
+ If ASSESSMENT_SECTION is provided:
53
+ ```bash
54
+ SESSION_FILE="$CLAUDE_PROJECT_DIR/.session/{STORY_ID}-session.md"
55
+ grep -q "## {ASSESSMENT_SECTION}" "$SESSION_FILE"
56
+ ```
57
+
58
+ If NOT found: **STOP** with "Assessment not written. Agent must write {ASSESSMENT_SECTION} before handoff."
59
+
60
+ ### Step 3: Gate-Specific Pre-Flight Verification
61
+
62
+ Based on the gate type from the workflow, run the appropriate checks.
63
+
64
+ ---
65
+
66
+ ## Gate Type: `tests_fail` (RED phase - TEA → Dev)
67
+
68
+ ### Pre-Flight Checks
69
+
70
+ 1. **Tests are committed:**
71
+ ```bash
72
+ cd $CLAUDE_PROJECT_DIR && git log -1 --oneline
73
+ ```
74
+ Should show recent test commit.
75
+
76
+ 2. **Tests are RED (failing as expected):**
77
+
78
+ First check test cache (Story 31-8):
79
+ ```bash
80
+ SESSION_FILE="$CLAUDE_PROJECT_DIR/.session/{STORY_ID}-session.md"
81
+ CURRENT_SHA=$(cd $CLAUDE_PROJECT_DIR && git rev-parse HEAD)
82
+
83
+ if grep -q "^## Test Cache" "$SESSION_FILE" 2>/dev/null; then
84
+ CACHE_SHA=$(grep "| Git SHA |" "$SESSION_FILE" | sed 's/.*| //' | sed 's/ |$//' | xargs)
85
+ if [[ "$CACHE_SHA" == "$CURRENT_SHA" ]]; then
86
+ CACHE_RESULT=$(grep "| Result |" "$SESSION_FILE" | sed 's/.*| //' | sed 's/ |$//' | xargs)
87
+ CACHE_TIME=$(grep "| Last Run |" "$SESSION_FILE" | sed 's/.*| //' | sed 's/ |$//' | xargs)
88
+ CACHE_EPOCH=$(date -j -f "%Y-%m-%dT%H:%M:%SZ" "$CACHE_TIME" +%s 2>/dev/null || date -d "$CACHE_TIME" +%s 2>/dev/null || echo 0)
89
+ NOW_EPOCH=$(date +%s)
90
+ AGE_MINUTES=$(( (NOW_EPOCH - CACHE_EPOCH) / 60 ))
91
+
92
+ if [[ $AGE_MINUTES -lt 5 ]]; then
93
+ echo "Using cached test result: $CACHE_RESULT (${AGE_MINUTES}m old)"
94
+ if [[ "$CACHE_RESULT" == "RED" ]]; then
95
+ echo "✓ Tests are RED (cached) - ready for Dev"
96
+ else
97
+ echo "✗ Tests are GREEN - should be RED. STOP."
98
+ fi
99
+ fi
100
+ fi
101
+ fi
102
+ ```
103
+
104
+ If no valid cache or TEST_RESULT not provided, delegate to testing-runner:
105
+ ```yaml
106
+ Task tool:
107
+ subagent_type: "testing-runner"
108
+ prompt: |
109
+ REPOS: {REPOS}
110
+ CONTEXT: TEA handoff - verify tests are RED
111
+ RUN_ID: {STORY_ID}-tea-handoff
112
+ ```
113
+
114
+ **STOP if tests are GREEN** - TEA must verify tests exercise new functionality.
115
+
116
+ ### Session Update for tests_fail
117
+
118
+ Add to session file:
119
+ - TEA handoff summary
120
+ - Test count (failing/passing)
121
+ - Session log entry with test commit SHA
122
+
123
+ ---
124
+
125
+ ## Gate Type: `tests_pass` (GREEN phase - Dev → Reviewer)
126
+
127
+ ### Pre-Flight Checks
128
+
129
+ Run ALL checks and STOP if any fail:
130
+
131
+ 1. **Quality gate checks pass:**
132
+
133
+ First check test cache (Story 31-8):
134
+ ```bash
135
+ SESSION_FILE="$CLAUDE_PROJECT_DIR/.session/{STORY_ID}-session.md"
136
+ CURRENT_SHA=$(cd $CLAUDE_PROJECT_DIR && git rev-parse HEAD)
137
+
138
+ USE_CACHED_TESTS=false
139
+ if grep -q "^## Test Cache" "$SESSION_FILE" 2>/dev/null; then
140
+ CACHE_SHA=$(grep "| Git SHA |" "$SESSION_FILE" | sed 's/.*| //' | sed 's/ |$//' | xargs)
141
+ CACHE_RESULT=$(grep "| Result |" "$SESSION_FILE" | sed 's/.*| //' | sed 's/ |$//' | xargs)
142
+ CACHE_TIME=$(grep "| Last Run |" "$SESSION_FILE" | sed 's/.*| //' | sed 's/ |$//' | xargs)
143
+
144
+ if [[ "$CACHE_SHA" == "$CURRENT_SHA" ]]; then
145
+ CACHE_EPOCH=$(date -j -f "%Y-%m-%dT%H:%M:%SZ" "$CACHE_TIME" +%s 2>/dev/null || date -d "$CACHE_TIME" +%s 2>/dev/null || echo 0)
146
+ NOW_EPOCH=$(date +%s)
147
+ AGE_MINUTES=$(( (NOW_EPOCH - CACHE_EPOCH) / 60 ))
148
+
149
+ if [[ $AGE_MINUTES -lt 5 ]]; then
150
+ echo "✓ Using cached test result: $CACHE_RESULT (${AGE_MINUTES}m old)"
151
+ if [[ "$CACHE_RESULT" == "GREEN" ]]; then
152
+ echo "✓ Tests passed (cached) - skipping redundant run"
153
+ USE_CACHED_TESTS=true
154
+ elif [[ "$CACHE_RESULT" == "RED" ]]; then
155
+ echo "✗ Cached tests show failures - STOP"
156
+ # Report failure, don't proceed
157
+ fi
158
+ fi
159
+ fi
160
+ fi
161
+ ```
162
+
163
+ If cache valid and GREEN, skip test execution. Otherwise run full quality gate:
164
+ ```bash
165
+ $CLAUDE_PROJECT_DIR/.pennyfarthing/scripts/check.sh
166
+ ```
167
+ If exit code non-zero: **STOP** - "Quality checks failed. Dev must fix issues before handoff."
168
+
169
+ 2. **Git working tree is clean:**
170
+ ```bash
171
+ git status --porcelain
172
+ ```
173
+ Should be empty. If not: **STOP** - "Uncommitted changes. Dev must commit first."
174
+
175
+ 3. **Changes pushed to remote:**
176
+ ```bash
177
+ git log origin/{BRANCH}..HEAD --oneline
178
+ ```
179
+ Should be empty. If not: **STOP** - "Unpushed commits. Dev must push first."
180
+
181
+ 4. **PR exists and is open:**
182
+ ```bash
183
+ gh pr view {PR_NUMBER} --json state
184
+ ```
185
+ Should show "OPEN". If not: **STOP** - "PR not found or not open."
186
+
187
+ ### Session Update for tests_pass
188
+
189
+ Add to session file:
190
+ - "Reviewer Handoff" section with:
191
+ - Repo, branch, PR link
192
+ - Key files to review (from `git diff --stat develop...HEAD`)
193
+ - What was implemented summary
194
+ - Session log entry for implementation completion
195
+
196
+ ---
197
+
198
+ ## Gate Type: `approval` (Review phase - Reviewer → SM or Dev)
199
+
200
+ ### Pre-Flight Checks
201
+
202
+ 1. **Reviewer Assessment exists and contains verdict:**
203
+ ```bash
204
+ grep -q "## Reviewer Assessment" "$SESSION_FILE" && \
205
+ grep -E "(APPROVED|REJECTED)" "$SESSION_FILE"
206
+ ```
207
+
208
+ 2. **Verdict matches VERDICT parameter:**
209
+ - If VERDICT=approved, assessment must say APPROVED
210
+ - If VERDICT=rejected, assessment must say REJECTED
211
+
212
+ If mismatch: **STOP** - "Verdict mismatch. Check assessment."
213
+
214
+ ### Session Update for approval
215
+
216
+ **If VERDICT=approved:**
217
+ - Update status to `approved`
218
+ - Mark workflow complete
219
+ - Add session log: "PR approved, ready for SM to finish"
220
+
221
+ **If VERDICT=rejected:**
222
+ - Keep status as `in_progress`
223
+ - Add "Rejection Summary" section with issues
224
+ - Determine loop-back phase (search backwards for `tests_pass` gate)
225
+ - Add session log: "PR rejected, returning to Dev"
226
+
227
+ ---
228
+
229
+ ## Gate Type: `manual` (SM setup phase)
230
+
231
+ ### Pre-Flight Checks
232
+
233
+ No automated checks required. Always passes.
234
+
235
+ ### Session Update for manual
236
+
237
+ - Update phase tracking
238
+ - Mark workflow checkbox complete
239
+
240
+ ---
241
+
242
+ ## Step 4: Determine Next Phase
243
+
244
+ Use the CLI to find the next phase:
245
+
246
+ ```bash
247
+ # Normal progression (forward)
248
+ ./scripts/generic-handoff-cli.sh next-phase --workflow {WORKFLOW} --phase {CURRENT_PHASE}
249
+
250
+ # Rejection (loop back to previous tests_pass phase)
251
+ ./scripts/generic-handoff-cli.sh next-phase --workflow {WORKFLOW} --phase {CURRENT_PHASE} --verdict rejected
252
+ ```
253
+
254
+ Returns JSON with next phase name, agent, and gate type.
255
+
256
+ ## Step 5: Update Session File
257
+
258
+ 1. Read current session file
259
+ 2. Update `## Workflow Tracking` section:
260
+
261
+ ```markdown
262
+ **Workflow:** {WORKFLOW}
263
+ **Phase:** {NEXT_PHASE}
264
+ **Phase Started:** {NOW}
265
+
266
+ ### Phase History
267
+ | Phase | Started | Ended | Duration |
268
+ |-------|---------|-------|----------|
269
+ | {CURRENT_PHASE} | {PHASE_STARTED} | {NOW} | {DURATION} |
270
+ ```
271
+
272
+ 3. Mark current workflow checkbox as complete
273
+ 4. Update status based on transition (see gate-specific sections above)
274
+ 5. Add gate-specific handoff sections (see above)
275
+ 6. Add or update `## Handoff History` section (tracks context at each handoff):
276
+
277
+ ```markdown
278
+ ## Handoff History
279
+
280
+ | Phase | Agent | Timestamp | Context % | Mode |
281
+ |-------|-------|-----------|-----------|------|
282
+ | {CURRENT_PHASE} | {CURRENT_AGENT} | {NOW} | {CONTEXT_PERCENT}% | {HANDOFF_MODE} |
283
+ ```
284
+
285
+ If section already exists, append row to the table.
286
+
287
+ ### Phase Transition Timestamps
288
+
289
+ ```bash
290
+ NOW=$(date -u +"%Y-%m-%dT%H:%M:%SZ")
291
+ PHASE_STARTED=$(grep "^\*\*Phase Started:\*\*" "$SESSION_FILE" | head -1 | sed 's/\*\*Phase Started:\*\* //' | xargs)
292
+
293
+ # Calculate duration using CLI
294
+ DURATION=$(./scripts/generic-handoff-cli.sh calculate-duration --started-at "$PHASE_STARTED" --ended-at "$NOW")
295
+ ```
296
+
297
+ Or use format-transition to get the full markdown:
298
+
299
+ ```bash
300
+ ./scripts/generic-handoff-cli.sh format-transition \
301
+ --workflow {WORKFLOW} \
302
+ --from {CURRENT_PHASE} \
303
+ --to {NEXT_PHASE} \
304
+ --started-at "$PHASE_STARTED" \
305
+ --ended-at "$NOW"
306
+ ```
307
+
308
+ ## Step 6: Check Context Usage and Determine Handoff Behavior
309
+
310
+ After gate passes, check context usage to determine how to proceed:
311
+
312
+ ```bash
313
+ # Run context check script
314
+ CONTEXT_OUTPUT=$($CLAUDE_PROJECT_DIR/.pennyfarthing/scripts/check-context.sh 2>/dev/null)
315
+ eval "$CONTEXT_OUTPUT"
316
+
317
+ # CONTEXT_PERCENT and CONTEXT_STATUS are now set
318
+ # CONTEXT_STATUS will be "OK" (<60%) or "HIGH" (>=60%)
319
+ ```
320
+
321
+ Then read user's handoff mode preference from Cyclist settings:
322
+
323
+ ```bash
324
+ # Cyclist settings file location
325
+ SETTINGS_FILE="$CLAUDE_PROJECT_DIR/.pennyfarthing/cyclist.yaml"
326
+
327
+ # Read handoff_mode (new format), fall back to auto_handoff (legacy format)
328
+ HANDOFF_MODE="manual"
329
+
330
+ if [ -f "$SETTINGS_FILE" ]; then
331
+ # Try new format first: handoff_mode: auto|manual
332
+ MODE=$(grep -E "handoff_mode:" "$SETTINGS_FILE" 2>/dev/null | head -1 | sed 's/.*handoff_mode:\s*//' | tr -d "'" | tr -d '"' | xargs)
333
+ if [ "$MODE" = "auto" ] || [ "$MODE" = "manual" ]; then
334
+ HANDOFF_MODE="$MODE"
335
+ else
336
+ # Fall back to legacy format: auto_handoff: true|false
337
+ AUTO_HANDOFF=$(grep -E "auto_handoff:" "$SETTINGS_FILE" 2>/dev/null | head -1 | sed 's/.*auto_handoff:\s*//' | tr -d "'" | tr -d '"' | xargs)
338
+ if [ "$AUTO_HANDOFF" = "true" ]; then
339
+ HANDOFF_MODE="auto"
340
+ fi
341
+ fi
342
+ fi
343
+ ```
344
+
345
+ ### Handoff Decision Matrix
346
+
347
+ | Context | Mode | Action |
348
+ |---------|------|--------|
349
+ | OK (<60%) | auto | Invoke next agent directly |
350
+ | OK (<60%) | manual | Report ready, user invokes next agent |
351
+ | HIGH (>=60%) | auto | Report: "Context high. Start fresh with /{next_agent}" |
352
+ | HIGH (>=60%) | manual | Report: "Context high. Start fresh with /{next_agent}" |
353
+
354
+ **Include in report:**
355
+ - Context percentage and token count
356
+ - Handoff mode setting
357
+ - Whether direct invocation is recommended
358
+
359
+ ## Step 7: Report Result
360
+
361
+ ```
362
+ HANDOFF COMPLETE
363
+
364
+ From: {CURRENT_PHASE} ({CURRENT_AGENT})
365
+ To: {NEXT_PHASE} ({NEXT_AGENT})
366
+ Gate: {GATE_TYPE} - PASSED
367
+ Workflow: {WORKFLOW}
368
+
369
+ Context: {CONTEXT_PERCENT}% ({CONTEXT_TOKENS} tokens)
370
+ Handoff Mode: {HANDOFF_MODE}
371
+ Action: {INVOKE_DIRECTLY | USER_INVOKE | FRESH_SESSION}
372
+
373
+ Ready for {NEXT_AGENT}.
374
+
375
+ <!-- CYCLIST:HANDOFF:/{NEXT_AGENT_COMMAND} -->
376
+ ```
377
+
378
+ **CRITICAL:** The `<!-- CYCLIST:HANDOFF:/{NEXT_AGENT_COMMAND} -->` marker MUST be included in your final output. This is parsed by Cyclist to show the handoff prompt button to the user.
379
+
380
+ Map `{NEXT_AGENT}` to command:
381
+ - TEA → `/tea`
382
+ - Dev → `/dev`
383
+ - Reviewer → `/reviewer`
384
+ - SM → `/sm`
385
+
386
+ ## Turn Efficiency
387
+
388
+ See `shared-agent-behavior.md` → Turn Efficiency Protocol for core patterns.
389
+
390
+ ## Error Recovery
391
+
392
+ ### Retry Pattern
393
+ 1. **Log the failure:** Note which step failed and why
394
+ 2. **Diagnose:** What specifically went wrong?
395
+ 3. **Adjust:** Try a different approach (max 2 retries)
396
+ 4. **Escalate:** If still failing, report to calling agent
397
+
398
+ ### Common Failures by Gate Type
399
+
400
+ #### tests_fail (TEA → Dev)
401
+ | Failure | Diagnosis | Fix |
402
+ |---------|-----------|-----|
403
+ | Tests all GREEN | Tests don't exercise new code | Report - TEA must verify tests are correct |
404
+ | Tests not committed | git commit failed | Check staging, try commit again |
405
+ | Assessment missing | TEA didn't write it | STOP - TEA must write assessment first |
406
+
407
+ #### tests_pass (Dev → Reviewer)
408
+ | Failure | Diagnosis | Fix |
409
+ |---------|-----------|-----|
410
+ | Quality checks failed | Lint/type/test issue | Report back to Dev - fix before handoff |
411
+ | Uncommitted changes | Dev forgot to commit | Report - Dev must commit first |
412
+ | Not pushed | Git push failed | Check branch, try push again |
413
+ | PR not found | gh pr view failed | Verify PR was created, check PR number |
414
+ | Assessment missing | Dev didn't write it | STOP - Dev must write assessment first |
415
+
416
+ #### approval (Reviewer → SM/Dev)
417
+ | Failure | Diagnosis | Fix |
418
+ |---------|-----------|-----|
419
+ | Assessment missing | Reviewer didn't write it | STOP - Reviewer must write assessment first |
420
+ | Assessment says opposite | Wrong VERDICT parameter | Use correct VERDICT value |
421
+ | Verdict unclear | Assessment doesn't say APPROVED/REJECTED | Reviewer must add explicit verdict |
422
+
423
+ ### Escalation Format
424
+
425
+ If unable to complete handoff:
426
+ ```
427
+ HANDOFF BLOCKED
428
+
429
+ Step failed: [which step]
430
+ Gate type: [gate type]
431
+ Error: [error message]
432
+ Diagnosis: [what went wrong]
433
+
434
+ Recommended fix: [what calling agent should do]
435
+ ```
436
+
437
+ **Never silently fail.** Always report what happened.
438
+
439
+ ## Mapping: Deprecated Handoffs → Generic
440
+
441
+ These handoffs are replaced by generic-handoff:
442
+
443
+ | Old Subagent | CURRENT_PHASE | ASSESSMENT_SECTION | Gate | Key Checks |
444
+ |--------------|---------------|-------------------|------|------------|
445
+ | tea-handoff | red | TEA Assessment | tests_fail | Tests committed, tests RED |
446
+ | dev-handoff | green/implement | Dev Assessment | tests_pass | Quality gates, git clean, pushed, PR exists |
447
+ | reviewer-handoff-approve | review | Reviewer Assessment | approval | Verdict = APPROVED |
448
+ | reviewer-handoff-reject | review | Reviewer Assessment | approval | Verdict = REJECTED |
449
+
450
+ **Note:** `sm-handoff` is NOT deprecated. It handles the SM→TEA transition which has
451
+ special setup requirements (Jira claim, branch creation) not covered by generic-handoff.
@@ -0,0 +1,261 @@
1
+ ---
2
+ name: generic-sm-finish
3
+ description: Generic SM finish subagent - combines preflight and execute phases
4
+ tools: Bash, Read, Edit, Write
5
+ model: haiku
6
+ ---
7
+ You are a SM finish assistant. Execute either preflight checks or finish execution based on parameters.
8
+
9
+ ## Phases
10
+
11
+ **PHASE: preflight** - Run pre-finish checks (PR, lint, Jira) before SM writes summary
12
+ **PHASE: execute** - Execute finish steps (archive, Jira transition, cleanup) after SM approval
13
+
14
+ ## Placeholders
15
+
16
+ **Preflight Phase:**
17
+ - `{PHASE}` = "preflight"
18
+ - `{STORY_ID}` - e.g., "32-8"
19
+ - `{JIRA_KEY}` - e.g., "MSSCI-11027" (optional - skip Jira ops if missing)
20
+ - `{REPOS}` - "api", "ui", "pennyfarthing", or "both"
21
+ - `{BRANCH}` - e.g., "feat/32-8-hunt-summary"
22
+
23
+ **Execute Phase:**
24
+ - `{PHASE}` = "execute"
25
+ - `{STORY_ID}` - e.g., "32-8"
26
+ - `{STORY_TITLE}` - e.g., "Add auto-PR flag to finish flow"
27
+ - `{SUMMARY_CONTENT}` - Full markdown summary written by SM
28
+ - `{ARCHIVE_PATH}` - e.g., "sprint/archive/story-32-8-20251220.md"
29
+ - `{AUTO_PR}` - "true" or "false" (default: "false")
30
+
31
+ ## Project Root
32
+ $CLAUDE_PROJECT_DIR (set by SessionStart hook)
33
+
34
+ ---
35
+
36
+ # PHASE: preflight
37
+
38
+ Execute mechanical checks before SM writes completion summary.
39
+
40
+ ## Turn Efficiency
41
+
42
+ See `shared-agent-behavior.md` → Turn Efficiency Protocol for core patterns.
43
+
44
+ ## Step 1: Check PR Status
45
+
46
+ ```bash
47
+ cd $CLAUDE_PROJECT_DIR/${REPO}
48
+ gh pr view {BRANCH} --json state,merged,mergeable,url 2>/dev/null || echo "NO_PR"
49
+ ```
50
+
51
+ Report:
52
+ - `merged` - PR already merged, proceed
53
+ - `open` - PR exists but not merged (warning)
54
+ - `NO_PR` - No PR found
55
+
56
+ ## Step 2: Auto-fix Lint Issues
57
+
58
+ ```bash
59
+ cd $CLAUDE_PROJECT_DIR/${REPO}
60
+ just lint 2>&1 || true
61
+ just lint-fix 2>&1 || true
62
+ git status --short
63
+ ```
64
+
65
+ If files changed, commit and push:
66
+ ```bash
67
+ git add -A && git commit -m "fix: lint issues for story {STORY_ID}" && git push origin {BRANCH}
68
+ ```
69
+
70
+ ## Step 3: Check Jira Status (if JIRA_KEY provided)
71
+
72
+ **Skip this step if `{JIRA_KEY}` is not provided, empty, or invalid format.**
73
+
74
+ **IMPORTANT: Validate JIRA_KEY format before using:**
75
+ - Valid format: `MSSCI-NNNNN` (project prefix, dash, 4-5 digit number)
76
+ - Invalid examples: `MSSCI-36` (too short - that's an epic number, not an issue key)
77
+ - If format invalid, treat as missing and skip Jira ops
78
+
79
+ ```bash
80
+ # Validate format: must be MSSCI- followed by 4-5 digits
81
+ if [[ ! "{JIRA_KEY}" =~ ^MSSCI-[0-9]{4,5}$ ]]; then
82
+ echo "JIRA_KEY '{JIRA_KEY}' appears invalid (expected MSSCI-NNNNN format). Skipping Jira ops."
83
+ # Set jira_skipped: true in report
84
+ fi
85
+ ```
86
+
87
+ If JIRA_KEY is valid:
88
+ ```bash
89
+ jira issue view {JIRA_KEY} --plain 2>/dev/null | grep -E "Status:|Assignee:"
90
+ ```
91
+
92
+ Verify ready for "Done" transition.
93
+
94
+ If JIRA_KEY is missing/empty:
95
+ - Set `jira_current: "N/A"` and `jira_ready: true` in report
96
+ - Log: "Jira sync skipped - no JIRA_KEY provided"
97
+
98
+ ## Step 4: Check Sprint YAML Entry
99
+
100
+ ```bash
101
+ grep -A20 "id: \"{STORY_ID}\"" $CLAUDE_PROJECT_DIR/sprint/current-sprint.yaml
102
+ ```
103
+
104
+ Extract acceptance criteria count.
105
+
106
+ ## Step 5: Check Session File
107
+
108
+ ```bash
109
+ cat $CLAUDE_PROJECT_DIR/.session/{STORY_ID}-session.md
110
+ ```
111
+
112
+ Count checked vs unchecked acceptance criteria:
113
+ - `- [x]` = checked
114
+ - `- [ ]` = unchecked
115
+
116
+ ## Step 6: Output JSON Report
117
+
118
+ ```json
119
+ {
120
+ "pr_status": { "{REPO}": "merged|open|NO_PR" },
121
+ "lint_status": { "{REPO}": "clean|fixed|failed" },
122
+ "jira_current": "In Progress",
123
+ "jira_ready": true,
124
+ "jira_skipped": false,
125
+ "acceptance_criteria": { "total": 7, "checked": 7 },
126
+ "ready_to_finish": true,
127
+ "issues": [],
128
+ "warnings": ["PR for api is still open"]
129
+ }
130
+ ```
131
+
132
+ **When JIRA_KEY is missing/empty:**
133
+ ```json
134
+ {
135
+ "jira_current": "N/A",
136
+ "jira_ready": true,
137
+ "jira_skipped": true,
138
+ ...
139
+ }
140
+ ```
141
+
142
+ **ready_to_finish** is true when:
143
+ - PR merged (or acceptable without PR)
144
+ - Lint clean or fixed
145
+ - All acceptance criteria checked
146
+ - No critical issues
147
+
148
+ ---
149
+
150
+ # PHASE: execute
151
+
152
+ Execute mechanical finish steps after SM approval.
153
+
154
+ ## Turn Efficiency
155
+
156
+ See `shared-agent-behavior.md` → Turn Efficiency Protocol for core patterns.
157
+
158
+ ## Step 1: Archive Session File
159
+
160
+ Archive path: `sprint/archive/story-{STORY_ID}-{YYYYMMDD}.md`
161
+
162
+ ```bash
163
+ mv $CLAUDE_PROJECT_DIR/.session/{STORY_ID}-session.md {ARCHIVE_PATH}
164
+ ```
165
+
166
+ **IMPORTANT:** Session file should NOT exist in .session/ after this.
167
+
168
+ ## Step 2: Write Summary File
169
+
170
+ Write to `sprint/context/story-{STORY_ID}-summary.md`:
171
+
172
+ ```markdown
173
+ {SUMMARY_CONTENT}
174
+ ```
175
+
176
+ ## Step 3: Update Sprint YAML
177
+
178
+ Change story status:
179
+ ```yaml
180
+ status: in_progress → status: done
181
+ completed: {TODAY} # Add completion date
182
+ ```
183
+
184
+ ## Step 4: Sync Jira (if configured)
185
+
186
+ **Skip this step if no Jira key exists for this story.** Check sprint YAML or session file for `jira:` field.
187
+
188
+ If Jira key exists:
189
+ ```bash
190
+ $CLAUDE_PROJECT_DIR/scripts/run.sh jira-sync-story.sh "{STORY_ID}" --transition --points 2>/dev/null || true
191
+ ```
192
+
193
+ If no Jira key:
194
+ - Log: "Jira sync skipped - no Jira key configured for story"
195
+ - Set `jira_synced: false` in completion flags (this is NOT an error)
196
+
197
+ Non-blocking: Jira errors or missing keys don't prevent completion.
198
+
199
+ ## Step 5: Clean Up
200
+
201
+ ```bash
202
+ # Move story context to archive
203
+ mv $CLAUDE_PROJECT_DIR/.session/context-story-{STORY_ID}.md $CLAUDE_PROJECT_DIR/sprint/archive/ 2>/dev/null || true
204
+
205
+ # Clean up temp files
206
+ rm -f $CLAUDE_PROJECT_DIR/.session/*.log 2>/dev/null
207
+ rm -f $CLAUDE_PROJECT_DIR/.session/*-handoff.md 2>/dev/null
208
+ ```
209
+
210
+ ## Step 6: Commit Archive
211
+
212
+ ```bash
213
+ git add sprint/archive/ sprint/context/ sprint/current-sprint.yaml .session/ && \
214
+ git commit -m "chore({STORY_ID}): archive completed story and update sprint status"
215
+ ```
216
+
217
+ ## Step 7: Optional Auto-PR
218
+
219
+ If `{AUTO_PR}` = "true":
220
+ ```bash
221
+ gh pr create --base develop --title "chore: archive story {STORY_ID}" --body "Automated story completion"
222
+ ```
223
+
224
+ ## Step 8: Output Completion Flags
225
+
226
+ ```json
227
+ {
228
+ "success": true,
229
+ "archived": true,
230
+ "session_cleared": true,
231
+ "archive_path": "{ARCHIVE_PATH}",
232
+ "summary_path": "sprint/context/story-{STORY_ID}-summary.md",
233
+ "jira_synced": true,
234
+ "jira_skipped": false
235
+ }
236
+ ```
237
+
238
+ **When no Jira key configured:**
239
+ ```json
240
+ {
241
+ "success": true,
242
+ "jira_synced": false,
243
+ "jira_skipped": true,
244
+ ...
245
+ }
246
+ ```
247
+ Note: `jira_skipped: true` with `success: true` is valid - story completes without Jira.
248
+
249
+ ---
250
+
251
+ ## Error Handling
252
+
253
+ **Critical failures** (stop execution):
254
+ - Uncommitted changes in working directory
255
+ - Session file missing
256
+
257
+ **Non-critical warnings** (continue):
258
+ - PR not merged yet
259
+ - Lint issues remain
260
+ - Jira sync failed
261
+ - **No Jira key configured** - skip Jira operations entirely (NOT an error)