@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,480 @@
1
+ # Pennyfarthing Agent Coordination Architecture
2
+
3
+ ## Overview
4
+
5
+ This document describes how Pennyfarthing agents are coordinated. The framework supports both single-repo and multi-repo projects.
6
+
7
+ **Key Principle:** Single entry point (`/new-work` or `/work`), state detection via session files, handoffs via Haiku subagents.
8
+
9
+ ## The TDD Flow
10
+
11
+ ```
12
+ /new-work → SM → TEA → Dev → Reviewer → SM (finish)
13
+ │ │ │ │
14
+ setup tests impl review
15
+ │ │ │ │
16
+ └─────┴─────┴────────┘
17
+ subagent handoffs
18
+ ```
19
+
20
+ **Entry points:** `/new-work` (new story) or `/work` (smart resume/start)
21
+ **State detection:** Agents read session file on activation
22
+ **Handoffs:** Agents spawn Haiku subagents to update session file
23
+ **Finish:** SM handles when status = `approved`
24
+
25
+ ## Architecture Principles
26
+
27
+ ### 1. Single Source of Truth
28
+ - **Agent definitions:** `.pennyfarthing/agents/`
29
+ - **Subagent prompts:** `.pennyfarthing/agents/`
30
+ - **Scope configuration:** `.pennyfarthing/guides/agent-scopes.yaml`
31
+ - **Sprint tracking:** `sprint/current-sprint.yaml`
32
+ - **Session state:** `.session/{STORY_ID}-session.md`
33
+
34
+ ### 2. Hierarchical Agent Structure
35
+ ```
36
+ Strategic Agents (Full Scope)
37
+ ├── orchestrator → Orchestrates everything
38
+ ├── pm → Plans across all repos
39
+ ├── architect → Designs across all repos
40
+ └── devops → Infrastructure and deployment
41
+
42
+ Tactical Agents (Story-Scoped) - THE TDD FLOW
43
+ ├── sm → Story setup and finish
44
+ ├── tea → Write failing tests (RED)
45
+ ├── dev → Implement to GREEN, create PR
46
+ └── reviewer → Adversarial code review
47
+
48
+ Support Agents
49
+ ├── tech-writer → Documentation
50
+ └── ux-designer → UI design
51
+ ```
52
+
53
+ ### 3. Context Loading Strategy
54
+ - **Strategic agents** load full project context (both repos)
55
+ - **Tactical agents** load only target repo context based on active story
56
+ - **Context budget** kept under 500-800 lines per agent
57
+ - **Lazy loading** - load docs only when specific task requires them
58
+
59
+ ## Directory Structure
60
+
61
+ ```
62
+ /$CLAUDE_PROJECT_DIR/
63
+ ├── .claude/ # Pennyfarthing coordination directory
64
+ │ ├── agents/ # Agent definitions (symlinks to pennyfarthing-dist)
65
+ │ │ ├── orchestrator.md # Master orchestrator
66
+ │ │ ├── pm.md # Product Manager
67
+ │ │ ├── sm.md # Scrum Master (+ sm-*.md subagents)
68
+ │ │ ├── architect.md # System Architect
69
+ │ │ ├── dev.md # Developer (+ dev-handoff.md)
70
+ │ │ ├── tea.md # Test Engineer (+ tea-handoff.md)
71
+ │ │ ├── reviewer.md # Code Reviewer (+ reviewer-*.md subagents)
72
+ │ │ ├── tech-writer.md # Technical Writer
73
+ │ │ ├── ux-designer.md # UX Designer
74
+ │ │ └── devops.md # DevOps Engineer
75
+ │ │
76
+ │ ├── commands/ # 42 slash commands (symlinks)
77
+ │ ├── guides/ # Behavior guides (symlinks)
78
+ │ ├── skills/ # 18+ knowledge domain skills (symlinks)
79
+ │ ├── scripts/ # Utility scripts (symlinks)
80
+ │ │
81
+ │ ├── project/ # Project-specific overrides
82
+ │ │ ├── agents/ # Agent sidecars (patterns, gotchas, decisions)
83
+ │ │ └── commands/ # Custom project commands
84
+ │ │
85
+ │ ├── persona-config.local.yaml # Theme selection (deprecated, use .pennyfarthing/)
86
+ │ └── CLAUDE.md # Project instructions
87
+
88
+ ├── .session/ # Active work sessions
89
+ │ └── {story-id}-session.md # Session files (one per story)
90
+
91
+ ├── sprint/ # Sprint tracking
92
+ │ ├── current-sprint.yaml # Active sprint and stories
93
+ │ ├── context/ # Epic technical context
94
+ │ ├── archive/ # Completed sprints
95
+ │ └── sidecars/ # Agent learning files
96
+
97
+ └── pennyfarthing-dist/ # Source of truth (if Pennyfarthing project itself)
98
+ ├── agents/ # 10 main agents + 14 subagents
99
+ ├── commands/ # 42 slash commands
100
+ ├── guides/ # Behavior guides and patterns
101
+ ├── skills/ # Knowledge domain skills
102
+ ├── personas/themes/ # 102 themed personas
103
+ └── scripts/ # Utility scripts
104
+ ```
105
+
106
+ ## Agent Types
107
+
108
+ ### Strategic Agents (Full Scope)
109
+
110
+ **Characteristics:**
111
+ - See entire project (both repos)
112
+ - Load all context on activation
113
+ - Make cross-repo decisions
114
+ - Coordinate work across repos
115
+
116
+ **Agents:**
117
+ - **Pennyfarthing Master:** Orchestrates all agents and workflows
118
+ - **PM:** Plans sprints, prioritizes epics, manages backlog
119
+ - **SM:** Creates stories, adds technical context, validates readiness
120
+ - **Architect:** Makes design decisions, defines patterns, ensures consistency
121
+
122
+ **Context Loading:**
123
+ ```yaml
124
+ On Activation:
125
+ 1. sprint/sprint-status.yaml # Full sprint status
126
+ 2. API/.claude/context.md # API context
127
+ 3. UI/.claude/context.md # UI context
128
+ 4. API/docs/epics.md # Epic definitions (PM only)
129
+ 5. .session/{STORY_ID}-session.md # Active work
130
+ ```
131
+
132
+ ### Tactical Agents (Story-Scoped)
133
+
134
+ **Characteristics:**
135
+ - Focus on specific repo(s)
136
+ - Load context based on active story
137
+ - Implement/test/document specific features
138
+ - Narrow, deep expertise
139
+
140
+ **Agents:**
141
+ - **Dev:** Implements features in target repo
142
+ - **TEA:** Tests features in target repo
143
+ - **Tech Writer:** Documents features in target repo
144
+ - **UX Designer:** Designs UI interfaces (UI only)
145
+
146
+ **Context Loading:**
147
+ ```yaml
148
+ On Activation:
149
+ 1. sprint/sprint-status.yaml # Current sprint (story section)
150
+ 2. .session/{STORY_ID}-session.md # Active story
151
+ 3. Determine target repo from story "Repos:" field
152
+ 4. Load target repo context:
153
+ - If API: API/.claude/context.md
154
+ - If UI: UI/.claude/context.md
155
+ - If Both: Load both contexts
156
+ ```
157
+
158
+ ## Context Files
159
+
160
+ ### Base Directory Context
161
+
162
+ #### `sprint/sprint-status.yaml`
163
+ **Purpose:** Unified sprint tracking for all stories
164
+ **Size:** ~100-200 lines
165
+ **Loaded By:** All agents
166
+ **Content:**
167
+ - Sprint goals
168
+ - All stories (API, UI, Both)
169
+ - Story status (backlog, in-progress, review, done)
170
+ - Story metadata (repos, priority, points, files)
171
+
172
+ #### `.session/{STORY_ID}-session.md`
173
+ **Purpose:** Current work session context
174
+ **Size:** ~50-100 lines
175
+ **Loaded By:** All agents
176
+ **Content:**
177
+ - Active story ID
178
+ - Target repo(s)
179
+ - Story context
180
+ - Progress notes
181
+ - Done checklist
182
+
183
+ ### Repository Context
184
+
185
+ #### `API/.claude/context.md`
186
+ **Purpose:** API-specific patterns and structure
187
+ **Size:** ~30-50 lines
188
+ **Loaded By:** Strategic agents + Dev/TEA when working on API
189
+ **Content:**
190
+ - Tech stack (Go, PostgreSQL, MongoDB, Redis)
191
+ - Key patterns (Repository, DI, REST, Middleware)
192
+ - Project structure
193
+ - Quick links to key directories
194
+
195
+ #### `UI/.claude/context.md`
196
+ **Purpose:** UI-specific patterns and structure
197
+ **Size:** ~30-50 lines
198
+ **Loaded By:** Strategic agents + Dev/TEA/UX when working on UI
199
+ **Content:**
200
+ - Tech stack (React, TypeScript, TailwindCSS)
201
+ - Key patterns (Components, Hooks, Context API)
202
+ - Project structure
203
+ - Quick links to key directories
204
+
205
+ ### Documentation
206
+
207
+ #### `API/docs/epics.md`
208
+ **Purpose:** All epic definitions for API
209
+ **Size:** ~800+ lines (load summary only)
210
+ **Loaded By:** PM, Architect
211
+ **Content:**
212
+ - Epic descriptions
213
+ - Story breakdowns
214
+ - Technical context
215
+ - Dependencies
216
+
217
+ ## Agent Activation Protocol
218
+
219
+ ### Step 1: Load Agent Definition
220
+ ```
221
+ Read: .pennyfarthing/agents/[agent].md
222
+ Identify: Strategic or Tactical agent type
223
+ ```
224
+
225
+ ### Step 2: Load Base Context
226
+ ```
227
+ Load files from agent-scopes.yaml:
228
+ - Sprint status
229
+ - Active work (if exists)
230
+ - Repo contexts (based on agent type)
231
+ ```
232
+
233
+ ### Step 3: Determine Scope (Tactical Agents Only)
234
+ ```
235
+ Read: .session/{STORY_ID}-session.md
236
+ Extract: "Repos:" field (API|UI|Both)
237
+ Load: Appropriate repo context
238
+ ```
239
+
240
+ ### Step 4: Present Ready State
241
+ ```
242
+ Display: Agent persona and menu
243
+ Show: Loaded context summary
244
+ Ready: For user input
245
+ ```
246
+
247
+ ## Agent Workflows
248
+
249
+ ### Strategic Agent Workflow (PM Example)
250
+
251
+ ```
252
+ User: @/pm
253
+
254
+ 1. Load PM agent definition (.pennyfarthing/agents/pm.md)
255
+ 2. Load all strategic context:
256
+ - Sprint status (full)
257
+ - API context
258
+ - UI context
259
+ - Epic definitions
260
+ - Active work
261
+ 3. Present PM menu with options
262
+ 4. Execute PM tasks (sprint planning, backlog grooming, etc.)
263
+ 5. Update sprint status
264
+ 6. Hand off to SM or other agents as needed
265
+ ```
266
+
267
+ ### Tactical Agent Workflow (Dev Example)
268
+
269
+ ```
270
+ User: @/dev
271
+
272
+ 1. Load Dev agent definition (.pennyfarthing/agents/dev.md)
273
+ 2. Load base context:
274
+ - Sprint status (story section)
275
+ - Active work
276
+ 3. Determine target repo from active work "Repos:" field
277
+ 4. Load target repo context:
278
+ - If API: API/.claude/context.md
279
+ - If UI: UI/.claude/context.md
280
+ - If Both: Load both
281
+ 5. Present Dev ready state
282
+ 6. Implement story in target repo(s)
283
+ 7. Update sprint status to 'review'
284
+ 8. Hand off to TEA or SM
285
+ ```
286
+
287
+ ## Agent Handoffs (TDD Flow)
288
+
289
+ Handoffs are automated via Haiku subagents in `.pennyfarthing/agents/`.
290
+
291
+ ### The Flow
292
+
293
+ ```
294
+ SM → TEA → Dev → Reviewer → SM
295
+ │ │ │ │ │
296
+ │ │ │ │ └── generic-sm-finish PHASE=execute
297
+ │ │ │ └── generic-handoff VERDICT=approved/rejected
298
+ │ │ └── generic-handoff CURRENT_PHASE=green
299
+ │ └── generic-handoff CURRENT_PHASE=red
300
+ └── generic-sm-setup MODE=setup + sm-handoff
301
+ ```
302
+
303
+ ### Complete Subagent Inventory
304
+
305
+ | Subagent File | Purpose | Model |
306
+ |--------------|---------|-------|
307
+ | **SM Subagents** | | |
308
+ | `generic-sm-setup.md` | Research backlog (MODE=research) or setup story (MODE=setup) | haiku |
309
+ | `generic-sm-finish.md` | Preflight checks (PHASE=preflight) or execute finish (PHASE=execute) | haiku |
310
+ | `sm-handoff.md` | SM → TEA/Dev handoff with Jira/branch verification | haiku |
311
+ | `sm-file-summary.md` | Summarize file changes for commits | haiku |
312
+ | **Shared Subagents** | | |
313
+ | `generic-handoff.md` | Workflow-driven phase transitions (TEA, Dev, Reviewer) | haiku |
314
+ | `testing-runner.md` | Run tests and report results | haiku |
315
+ | **Reviewer Subagents** | | |
316
+ | `reviewer-preflight.md` | Pre-flight checks before review | haiku |
317
+ | **Utility Subagents** | | |
318
+ | `workflow-status-check.md` | Check workflow status across repos | haiku |
319
+
320
+ ### SM → TEA (Story Setup)
321
+ **Trigger:** User selects story via `/new-work`
322
+ **Subagent:** `generic-sm-setup MODE=setup` then `sm-handoff`
323
+ **Action:** Claim Jira, write session file, create branches
324
+ **Handoff phrase:** "TEA, Story X-Y needs tests. Write failing tests for these ACs."
325
+
326
+ ### TEA → Dev (Tests Written)
327
+ **Trigger:** TEA completes failing tests
328
+ **Subagent:** `generic-handoff CURRENT_PHASE=red`
329
+ **Action:** Update session file, transition to green phase
330
+ **Handoff phrase:** "Dev, tests are RED and ready. Make them GREEN."
331
+
332
+ ### Dev → Reviewer (Implementation Complete)
333
+ **Trigger:** Dev creates PR with passing tests
334
+ **Subagent:** `generic-handoff CURRENT_PHASE=green`
335
+ **Action:** Update session file, transition to review phase
336
+ **Handoff phrase:** "Reviewer, PR #N is ready. All tests GREEN."
337
+
338
+ ### Reviewer → SM (Approved)
339
+ **Trigger:** Reviewer approves PR
340
+ **Subagent:** `generic-handoff VERDICT=approved`
341
+ **Action:** Update status to `approved`, transition to finish phase
342
+ **Handoff phrase:** "SM, Story X-Y approved. Run finish-story."
343
+
344
+ ### Reviewer → Dev (Rejected)
345
+ **Trigger:** Reviewer finds issues
346
+ **Subagent:** `generic-handoff VERDICT=rejected`
347
+ **Action:** Update session with issues, route back to implement phase
348
+ **Handoff phrase:** "Dev, {N} issues found. See assessment for details."
349
+
350
+ ### SM → Done (Finish)
351
+ **Trigger:** Status = `approved`
352
+ **Subagent:** `generic-sm-finish PHASE=execute`
353
+ **Action:** Archive session, create summary, update sprint YAML, sync Jira
354
+
355
+ ## Support Agent Handoffs
356
+
357
+ ### Any → Architect
358
+ **Trigger:** Need design decisions or architectural guidance
359
+ **Context:** Technical problem or design question
360
+ **Action:** Architect provides design and implementation guidance
361
+
362
+ ### Any → Tech Writer
363
+ **Trigger:** Feature needs documentation
364
+ **Context:** Implemented feature
365
+ **Action:** Tech Writer creates documentation
366
+
367
+ ### Any → UX Designer
368
+ **Trigger:** Feature needs UI design
369
+ **Context:** User story and requirements
370
+ **Action:** UX Designer creates UI design and specs
371
+
372
+ ## Context Budget Management
373
+
374
+ ### Target Budgets
375
+ - **Agent file:** 200-400 lines
376
+ - **Sprint status:** 100-200 lines (full) or 50 lines (story section)
377
+ - **Repo contexts:** 30-50 lines each
378
+ - **Active work:** 50-100 lines
379
+ - **Total per agent:** 500-800 lines
380
+
381
+ ### Strategic Agent Budget
382
+ ```
383
+ PM Agent Example:
384
+ - pm.md: 200 lines
385
+ - sprint-status.yaml: 150 lines
386
+ - API/context: 30 lines
387
+ - UI/context: 30 lines
388
+ - epics.md (summary): 100 lines
389
+ - active work: 50 lines
390
+ Total: 560 lines ✓
391
+ ```
392
+
393
+ ### Tactical Agent Budget
394
+ ```
395
+ Dev Agent Example (API story):
396
+ - dev.md: 300 lines
397
+ - sprint-status (story): 50 lines
398
+ - API/context: 30 lines
399
+ - active work: 50 lines
400
+ Total: 430 lines ✓
401
+ ```
402
+
403
+ ## Benefits
404
+
405
+ ### ✅ Single Source of Truth
406
+ - All agents defined in one place
407
+ - No duplicate or conflicting agent files
408
+ - Easy to update and maintain
409
+
410
+ ### ✅ Coordinated Planning
411
+ - Strategic agents see full project scope
412
+ - Unified sprint tracking
413
+ - Clear cross-repo dependencies
414
+
415
+ ### ✅ Focused Implementation
416
+ - Tactical agents load only what they need
417
+ - Reduced context overhead
418
+ - Faster agent activation
419
+
420
+ ### ✅ Clear Hierarchy
421
+ - Strategic agents coordinate
422
+ - Tactical agents execute
423
+ - Clean handoffs between agents
424
+
425
+ ### ✅ Scalable
426
+ - Easy to add new agents
427
+ - Context budgets stay manageable
428
+ - Works for solo dev or team
429
+
430
+ ## Architecture History
431
+
432
+ ### Previous Architecture (Pre-December 2025)
433
+ - Separate commands: `/new-work`, `/pickup-work`, `/handoff-work`, `/finish-work`
434
+ - Manual handoff documentation
435
+ - No subagent extraction
436
+
437
+ ### Current Architecture (January 2026)
438
+ - Smart entry point: `/work` (resumes or starts new)
439
+ - Alternative: `/new-work` (explicitly start new story)
440
+ - State detection via session file in `.session/`
441
+ - Handoffs via Haiku subagents in `.pennyfarthing/agents/`
442
+ - SM handles finish-story when status = `approved`
443
+ - 102 themed personas for agent personality
444
+
445
+ ### Directory Structure
446
+ ```
447
+ .pennyfarthing/agents/ # Agent definitions (symlinked)
448
+ .claude/commands/ # 42 slash commands
449
+ .claude/skills/ # 18+ knowledge domain skills
450
+ .session/ # Session files
451
+ sprint/ # Sprint tracking
452
+ ```
453
+
454
+ ### Commands Reference
455
+ ```bash
456
+ # Entry points
457
+ /work # Smart entry - resume or start new
458
+ /new-work # Explicitly start new story
459
+
460
+ # TDD Flow agents
461
+ /sm # Scrum Master (setup + finish)
462
+ /tea # Test Engineer (RED phase)
463
+ /dev # Developer (GREEN phase)
464
+ /reviewer # Code Reviewer
465
+
466
+ # Support agents
467
+ /architect # Architecture design
468
+ /tech-writer # Documentation
469
+ /ux-designer # UI/UX design
470
+ /devops # Infrastructure
471
+
472
+ # Utility
473
+ /check # Run quality gates before handoff
474
+ /chore # Quick commit for small changes
475
+ /release # Merge develop to main
476
+ ```
477
+
478
+ ---
479
+
480
+ **Smart entry. State detection. Subagent handoffs. Themed personas.**
@@ -0,0 +1,201 @@
1
+ # Agent Permission Scopes Guide
2
+
3
+ Pennyfarthing uses a three-tier permission model to control what each agent can access and modify.
4
+
5
+ ## Three-Tier Model
6
+
7
+ | Tier | Agents | Scope | Model |
8
+ |------|--------|-------|-------|
9
+ | **Strategic** | Orchestrator, PM, SM, Architect, DevOps | Full project | Opus |
10
+ | **Tactical** | Dev, TEA, Reviewer, Tech-Writer, UX | Story-focused | Opus |
11
+ | **Helper** | Subagents (testing-runner, handoffs, etc.) | Single task | Haiku |
12
+
13
+ ## Strategic Agents
14
+
15
+ Strategic agents have broad project visibility and coordination responsibilities.
16
+
17
+ ### Capabilities
18
+ - See entire project scope (sprint, all sessions, architecture)
19
+ - Coordinate between agents and stories
20
+ - Make cross-cutting decisions
21
+ - Modify sprint and session files
22
+
23
+ ### Example: Scrum Master (SM)
24
+ ```yaml
25
+ sm:
26
+ scope: full
27
+ permissions:
28
+ - Read
29
+ - Grep
30
+ - Glob
31
+ - Bash
32
+ - Edit(sprint/**)
33
+ - Edit(.session/**)
34
+ - Write(sprint/**)
35
+ - Write(.session/**)
36
+ - Skill(tea)
37
+ - Skill(dev)
38
+ - Skill(reviewer)
39
+ ```
40
+
41
+ ## Tactical Agents
42
+
43
+ Tactical agents focus on the current story and have permissions scoped to their role.
44
+
45
+ ### Capabilities
46
+ - See current session and shared context
47
+ - Modify files relevant to their specialty
48
+ - Spawn helper subagents for mechanical tasks
49
+ - Hand off to next agent in workflow
50
+
51
+ ### Example: Developer (Dev)
52
+ ```yaml
53
+ dev:
54
+ scope: story
55
+ permissions:
56
+ - Read
57
+ - Grep
58
+ - Glob
59
+ - Bash
60
+ - Edit(src/**)
61
+ - Edit(tests/**)
62
+ - Edit(.session/**)
63
+ - Write(src/**)
64
+ - Write(tests/**)
65
+ - Task(testing-runner)
66
+ - Task(dev-handoff)
67
+ ```
68
+
69
+ ### Example: Test Engineer (TEA)
70
+ ```yaml
71
+ tea:
72
+ scope: story
73
+ permissions:
74
+ - Read
75
+ - Grep
76
+ - Glob
77
+ - Bash
78
+ - Edit(tests/**)
79
+ - Edit(.session/**)
80
+ - Write(tests/**)
81
+ - Task(testing-runner)
82
+ - Task(tea-handoff)
83
+ ```
84
+
85
+ ### Example: Reviewer
86
+ ```yaml
87
+ reviewer:
88
+ scope: story
89
+ permissions:
90
+ - Read
91
+ - Grep
92
+ - Glob
93
+ - Bash # For git diff
94
+ - Edit(.session/**) # Assessment only
95
+ - Task(reviewer-preflight)
96
+ - Task(reviewer-handoff-*)
97
+ ```
98
+
99
+ Note: Reviewer has no Edit permissions for source code - they can only read and assess.
100
+
101
+ ## Helper Subagents
102
+
103
+ Helpers are Haiku-powered agents with minimal permissions for specific tasks.
104
+
105
+ ### Capabilities
106
+ - Execute single mechanical task
107
+ - Limited to essential permissions
108
+ - Report results back to parent agent
109
+ - No cross-agent invocation
110
+
111
+ ### Example: Testing Runner
112
+ ```yaml
113
+ testing-runner:
114
+ scope: task
115
+ model: haiku
116
+ permissions:
117
+ - Read
118
+ - Bash
119
+ - Grep
120
+ ```
121
+
122
+ ### Example: Dev Handoff
123
+ ```yaml
124
+ dev-handoff:
125
+ scope: task
126
+ model: haiku
127
+ permissions:
128
+ - Read
129
+ - Bash
130
+ - Edit(.session/**)
131
+ - Grep
132
+ ```
133
+
134
+ ## Permission Pattern Reference
135
+
136
+ ### Tool Permissions
137
+
138
+ | Permission | Description |
139
+ |------------|-------------|
140
+ | `Read` | Read any file |
141
+ | `Grep` | Search file contents |
142
+ | `Glob` | Find files by pattern |
143
+ | `Bash` | Execute shell commands |
144
+ | `Edit(pattern)` | Edit files matching pattern |
145
+ | `Write(pattern)` | Create files matching pattern |
146
+ | `Skill(name)` | Invoke named agent |
147
+ | `Task(type)` | Spawn subagent |
148
+
149
+ ### Path Patterns
150
+
151
+ | Pattern | Matches |
152
+ |---------|---------|
153
+ | `src/**` | All files under src/ |
154
+ | `**/*.md` | All markdown files |
155
+ | `.session/**` | All session files |
156
+ | `sprint/**` | All sprint files |
157
+
158
+ ### Wildcards
159
+
160
+ | Pattern | Meaning |
161
+ |---------|---------|
162
+ | `Skill(*)` | Any skill |
163
+ | `Task(sm-*)` | Any SM subagent |
164
+ | `Edit(**/*)` | Edit any file |
165
+
166
+ ## Scope Inheritance
167
+
168
+ Agents inherit base permissions from their tier:
169
+
170
+ ```
171
+ Strategic: Full read access + tier-specific writes
172
+ Tactical: Story read access + role-specific writes
173
+ Helper: Task-specific access only
174
+ ```
175
+
176
+ ## Customizing Scopes
177
+
178
+ Edit `.claude/project/docs/agent-scopes.yaml` to customize:
179
+
180
+ 1. **Add permissions** for project-specific needs
181
+ 2. **Restrict paths** for sensitive directories
182
+ 3. **Add subagents** for new automation tasks
183
+
184
+ Example: Allow Dev to edit database migrations:
185
+ ```yaml
186
+ dev:
187
+ permissions:
188
+ - Edit(db/migrations/**)
189
+ ```
190
+
191
+ ## Security Considerations
192
+
193
+ - **Helpers cannot invoke other agents** - prevents privilege escalation
194
+ - **Tactical agents can only invoke their helpers** - maintains workflow
195
+ - **Only SM can invoke Dev/TEA/Reviewer** - enforces TDD flow
196
+ - **Edit permissions are path-scoped** - prevents accidental damage
197
+
198
+ ## File Location
199
+
200
+ Configuration: `.claude/project/docs/agent-scopes.yaml`
201
+ Template: `pennyfarthing-dist/templates/agent-scopes.yaml.template`