@athenaflow/plugin-matt-pocock-skills 0.1.1

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 (172) hide show
  1. package/.claude-plugin/plugin.json +24 -0
  2. package/.codex-plugin/plugin.json +16 -0
  3. package/NOTICE.md +11 -0
  4. package/dist/0.1.1/.agents/plugins/marketplace.json +14 -0
  5. package/dist/0.1.1/GENERATED.md +12 -0
  6. package/dist/0.1.1/claude/plugin/.claude-plugin/plugin.json +24 -0
  7. package/dist/0.1.1/claude/plugin/NOTICE.md +11 -0
  8. package/dist/0.1.1/claude/plugin/package.json +21 -0
  9. package/dist/0.1.1/claude/plugin/skills/diagnose/SKILL.md +117 -0
  10. package/dist/0.1.1/claude/plugin/skills/diagnose/agents/claude.yaml +2 -0
  11. package/dist/0.1.1/claude/plugin/skills/diagnose/agents/openai.yaml +4 -0
  12. package/dist/0.1.1/claude/plugin/skills/diagnose/scripts/hitl-loop.template.sh +41 -0
  13. package/dist/0.1.1/claude/plugin/skills/grill-me/SKILL.md +10 -0
  14. package/dist/0.1.1/claude/plugin/skills/grill-me/agents/claude.yaml +2 -0
  15. package/dist/0.1.1/claude/plugin/skills/grill-me/agents/openai.yaml +4 -0
  16. package/dist/0.1.1/claude/plugin/skills/grill-with-docs/ADR-FORMAT.md +47 -0
  17. package/dist/0.1.1/claude/plugin/skills/grill-with-docs/CONTEXT-FORMAT.md +77 -0
  18. package/dist/0.1.1/claude/plugin/skills/grill-with-docs/SKILL.md +88 -0
  19. package/dist/0.1.1/claude/plugin/skills/grill-with-docs/agents/claude.yaml +2 -0
  20. package/dist/0.1.1/claude/plugin/skills/grill-with-docs/agents/openai.yaml +4 -0
  21. package/dist/0.1.1/claude/plugin/skills/improve-codebase-architecture/DEEPENING.md +37 -0
  22. package/dist/0.1.1/claude/plugin/skills/improve-codebase-architecture/INTERFACE-DESIGN.md +44 -0
  23. package/dist/0.1.1/claude/plugin/skills/improve-codebase-architecture/LANGUAGE.md +53 -0
  24. package/dist/0.1.1/claude/plugin/skills/improve-codebase-architecture/SKILL.md +71 -0
  25. package/dist/0.1.1/claude/plugin/skills/improve-codebase-architecture/agents/claude.yaml +2 -0
  26. package/dist/0.1.1/claude/plugin/skills/improve-codebase-architecture/agents/openai.yaml +4 -0
  27. package/dist/0.1.1/claude/plugin/skills/prototype/LOGIC.md +79 -0
  28. package/dist/0.1.1/claude/plugin/skills/prototype/SKILL.md +30 -0
  29. package/dist/0.1.1/claude/plugin/skills/prototype/UI.md +112 -0
  30. package/dist/0.1.1/claude/plugin/skills/prototype/agents/claude.yaml +2 -0
  31. package/dist/0.1.1/claude/plugin/skills/prototype/agents/openai.yaml +4 -0
  32. package/dist/0.1.1/claude/plugin/skills/setup-matt-pocock-skills/SKILL.md +120 -0
  33. package/dist/0.1.1/claude/plugin/skills/setup-matt-pocock-skills/agents/claude.yaml +3 -0
  34. package/dist/0.1.1/claude/plugin/skills/setup-matt-pocock-skills/agents/openai.yaml +4 -0
  35. package/dist/0.1.1/claude/plugin/skills/setup-matt-pocock-skills/domain.md +51 -0
  36. package/dist/0.1.1/claude/plugin/skills/setup-matt-pocock-skills/issue-tracker-github.md +22 -0
  37. package/dist/0.1.1/claude/plugin/skills/setup-matt-pocock-skills/issue-tracker-gitlab.md +23 -0
  38. package/dist/0.1.1/claude/plugin/skills/setup-matt-pocock-skills/issue-tracker-local.md +19 -0
  39. package/dist/0.1.1/claude/plugin/skills/setup-matt-pocock-skills/triage-labels.md +15 -0
  40. package/dist/0.1.1/claude/plugin/skills/tdd/SKILL.md +109 -0
  41. package/dist/0.1.1/claude/plugin/skills/tdd/agents/claude.yaml +2 -0
  42. package/dist/0.1.1/claude/plugin/skills/tdd/agents/openai.yaml +4 -0
  43. package/dist/0.1.1/claude/plugin/skills/tdd/deep-modules.md +33 -0
  44. package/dist/0.1.1/claude/plugin/skills/tdd/interface-design.md +31 -0
  45. package/dist/0.1.1/claude/plugin/skills/tdd/mocking.md +59 -0
  46. package/dist/0.1.1/claude/plugin/skills/tdd/refactoring.md +10 -0
  47. package/dist/0.1.1/claude/plugin/skills/tdd/tests.md +61 -0
  48. package/dist/0.1.1/claude/plugin/skills/to-issues/SKILL.md +83 -0
  49. package/dist/0.1.1/claude/plugin/skills/to-issues/agents/claude.yaml +2 -0
  50. package/dist/0.1.1/claude/plugin/skills/to-issues/agents/openai.yaml +4 -0
  51. package/dist/0.1.1/claude/plugin/skills/to-prd/SKILL.md +76 -0
  52. package/dist/0.1.1/claude/plugin/skills/to-prd/agents/claude.yaml +2 -0
  53. package/dist/0.1.1/claude/plugin/skills/to-prd/agents/openai.yaml +4 -0
  54. package/dist/0.1.1/claude/plugin/skills/triage/AGENT-BRIEF.md +168 -0
  55. package/dist/0.1.1/claude/plugin/skills/triage/OUT-OF-SCOPE.md +101 -0
  56. package/dist/0.1.1/claude/plugin/skills/triage/SKILL.md +103 -0
  57. package/dist/0.1.1/claude/plugin/skills/triage/agents/claude.yaml +2 -0
  58. package/dist/0.1.1/claude/plugin/skills/triage/agents/openai.yaml +4 -0
  59. package/dist/0.1.1/claude/plugin/skills/zoom-out/SKILL.md +6 -0
  60. package/dist/0.1.1/claude/plugin/skills/zoom-out/agents/claude.yaml +3 -0
  61. package/dist/0.1.1/claude/plugin/skills/zoom-out/agents/openai.yaml +4 -0
  62. package/dist/0.1.1/codex/plugin/.codex-plugin/plugin.json +16 -0
  63. package/dist/0.1.1/codex/plugin/NOTICE.md +11 -0
  64. package/dist/0.1.1/codex/plugin/package.json +21 -0
  65. package/dist/0.1.1/codex/plugin/skills/diagnose/SKILL.md +117 -0
  66. package/dist/0.1.1/codex/plugin/skills/diagnose/agents/claude.yaml +2 -0
  67. package/dist/0.1.1/codex/plugin/skills/diagnose/agents/openai.yaml +4 -0
  68. package/dist/0.1.1/codex/plugin/skills/diagnose/scripts/hitl-loop.template.sh +41 -0
  69. package/dist/0.1.1/codex/plugin/skills/grill-me/SKILL.md +10 -0
  70. package/dist/0.1.1/codex/plugin/skills/grill-me/agents/claude.yaml +2 -0
  71. package/dist/0.1.1/codex/plugin/skills/grill-me/agents/openai.yaml +4 -0
  72. package/dist/0.1.1/codex/plugin/skills/grill-with-docs/ADR-FORMAT.md +47 -0
  73. package/dist/0.1.1/codex/plugin/skills/grill-with-docs/CONTEXT-FORMAT.md +77 -0
  74. package/dist/0.1.1/codex/plugin/skills/grill-with-docs/SKILL.md +88 -0
  75. package/dist/0.1.1/codex/plugin/skills/grill-with-docs/agents/claude.yaml +2 -0
  76. package/dist/0.1.1/codex/plugin/skills/grill-with-docs/agents/openai.yaml +4 -0
  77. package/dist/0.1.1/codex/plugin/skills/improve-codebase-architecture/DEEPENING.md +37 -0
  78. package/dist/0.1.1/codex/plugin/skills/improve-codebase-architecture/INTERFACE-DESIGN.md +44 -0
  79. package/dist/0.1.1/codex/plugin/skills/improve-codebase-architecture/LANGUAGE.md +53 -0
  80. package/dist/0.1.1/codex/plugin/skills/improve-codebase-architecture/SKILL.md +71 -0
  81. package/dist/0.1.1/codex/plugin/skills/improve-codebase-architecture/agents/claude.yaml +2 -0
  82. package/dist/0.1.1/codex/plugin/skills/improve-codebase-architecture/agents/openai.yaml +4 -0
  83. package/dist/0.1.1/codex/plugin/skills/prototype/LOGIC.md +79 -0
  84. package/dist/0.1.1/codex/plugin/skills/prototype/SKILL.md +30 -0
  85. package/dist/0.1.1/codex/plugin/skills/prototype/UI.md +112 -0
  86. package/dist/0.1.1/codex/plugin/skills/prototype/agents/claude.yaml +2 -0
  87. package/dist/0.1.1/codex/plugin/skills/prototype/agents/openai.yaml +4 -0
  88. package/dist/0.1.1/codex/plugin/skills/setup-matt-pocock-skills/SKILL.md +120 -0
  89. package/dist/0.1.1/codex/plugin/skills/setup-matt-pocock-skills/agents/claude.yaml +3 -0
  90. package/dist/0.1.1/codex/plugin/skills/setup-matt-pocock-skills/agents/openai.yaml +4 -0
  91. package/dist/0.1.1/codex/plugin/skills/setup-matt-pocock-skills/domain.md +51 -0
  92. package/dist/0.1.1/codex/plugin/skills/setup-matt-pocock-skills/issue-tracker-github.md +22 -0
  93. package/dist/0.1.1/codex/plugin/skills/setup-matt-pocock-skills/issue-tracker-gitlab.md +23 -0
  94. package/dist/0.1.1/codex/plugin/skills/setup-matt-pocock-skills/issue-tracker-local.md +19 -0
  95. package/dist/0.1.1/codex/plugin/skills/setup-matt-pocock-skills/triage-labels.md +15 -0
  96. package/dist/0.1.1/codex/plugin/skills/tdd/SKILL.md +109 -0
  97. package/dist/0.1.1/codex/plugin/skills/tdd/agents/claude.yaml +2 -0
  98. package/dist/0.1.1/codex/plugin/skills/tdd/agents/openai.yaml +4 -0
  99. package/dist/0.1.1/codex/plugin/skills/tdd/deep-modules.md +33 -0
  100. package/dist/0.1.1/codex/plugin/skills/tdd/interface-design.md +31 -0
  101. package/dist/0.1.1/codex/plugin/skills/tdd/mocking.md +59 -0
  102. package/dist/0.1.1/codex/plugin/skills/tdd/refactoring.md +10 -0
  103. package/dist/0.1.1/codex/plugin/skills/tdd/tests.md +61 -0
  104. package/dist/0.1.1/codex/plugin/skills/to-issues/SKILL.md +83 -0
  105. package/dist/0.1.1/codex/plugin/skills/to-issues/agents/claude.yaml +2 -0
  106. package/dist/0.1.1/codex/plugin/skills/to-issues/agents/openai.yaml +4 -0
  107. package/dist/0.1.1/codex/plugin/skills/to-prd/SKILL.md +76 -0
  108. package/dist/0.1.1/codex/plugin/skills/to-prd/agents/claude.yaml +2 -0
  109. package/dist/0.1.1/codex/plugin/skills/to-prd/agents/openai.yaml +4 -0
  110. package/dist/0.1.1/codex/plugin/skills/triage/AGENT-BRIEF.md +168 -0
  111. package/dist/0.1.1/codex/plugin/skills/triage/OUT-OF-SCOPE.md +101 -0
  112. package/dist/0.1.1/codex/plugin/skills/triage/SKILL.md +103 -0
  113. package/dist/0.1.1/codex/plugin/skills/triage/agents/claude.yaml +2 -0
  114. package/dist/0.1.1/codex/plugin/skills/triage/agents/openai.yaml +4 -0
  115. package/dist/0.1.1/codex/plugin/skills/zoom-out/SKILL.md +6 -0
  116. package/dist/0.1.1/codex/plugin/skills/zoom-out/agents/claude.yaml +3 -0
  117. package/dist/0.1.1/codex/plugin/skills/zoom-out/agents/openai.yaml +4 -0
  118. package/dist/0.1.1/release.json +18 -0
  119. package/package.json +25 -0
  120. package/skills/diagnose/SKILL.md +117 -0
  121. package/skills/diagnose/agents/claude.yaml +2 -0
  122. package/skills/diagnose/agents/openai.yaml +4 -0
  123. package/skills/diagnose/scripts/hitl-loop.template.sh +41 -0
  124. package/skills/grill-me/SKILL.md +10 -0
  125. package/skills/grill-me/agents/claude.yaml +2 -0
  126. package/skills/grill-me/agents/openai.yaml +4 -0
  127. package/skills/grill-with-docs/ADR-FORMAT.md +47 -0
  128. package/skills/grill-with-docs/CONTEXT-FORMAT.md +77 -0
  129. package/skills/grill-with-docs/SKILL.md +88 -0
  130. package/skills/grill-with-docs/agents/claude.yaml +2 -0
  131. package/skills/grill-with-docs/agents/openai.yaml +4 -0
  132. package/skills/improve-codebase-architecture/DEEPENING.md +37 -0
  133. package/skills/improve-codebase-architecture/INTERFACE-DESIGN.md +44 -0
  134. package/skills/improve-codebase-architecture/LANGUAGE.md +53 -0
  135. package/skills/improve-codebase-architecture/SKILL.md +71 -0
  136. package/skills/improve-codebase-architecture/agents/claude.yaml +2 -0
  137. package/skills/improve-codebase-architecture/agents/openai.yaml +4 -0
  138. package/skills/prototype/LOGIC.md +79 -0
  139. package/skills/prototype/SKILL.md +30 -0
  140. package/skills/prototype/UI.md +112 -0
  141. package/skills/prototype/agents/claude.yaml +2 -0
  142. package/skills/prototype/agents/openai.yaml +4 -0
  143. package/skills/setup-matt-pocock-skills/SKILL.md +120 -0
  144. package/skills/setup-matt-pocock-skills/agents/claude.yaml +3 -0
  145. package/skills/setup-matt-pocock-skills/agents/openai.yaml +4 -0
  146. package/skills/setup-matt-pocock-skills/domain.md +51 -0
  147. package/skills/setup-matt-pocock-skills/issue-tracker-github.md +22 -0
  148. package/skills/setup-matt-pocock-skills/issue-tracker-gitlab.md +23 -0
  149. package/skills/setup-matt-pocock-skills/issue-tracker-local.md +19 -0
  150. package/skills/setup-matt-pocock-skills/triage-labels.md +15 -0
  151. package/skills/tdd/SKILL.md +109 -0
  152. package/skills/tdd/agents/claude.yaml +2 -0
  153. package/skills/tdd/agents/openai.yaml +4 -0
  154. package/skills/tdd/deep-modules.md +33 -0
  155. package/skills/tdd/interface-design.md +31 -0
  156. package/skills/tdd/mocking.md +59 -0
  157. package/skills/tdd/refactoring.md +10 -0
  158. package/skills/tdd/tests.md +61 -0
  159. package/skills/to-issues/SKILL.md +83 -0
  160. package/skills/to-issues/agents/claude.yaml +2 -0
  161. package/skills/to-issues/agents/openai.yaml +4 -0
  162. package/skills/to-prd/SKILL.md +76 -0
  163. package/skills/to-prd/agents/claude.yaml +2 -0
  164. package/skills/to-prd/agents/openai.yaml +4 -0
  165. package/skills/triage/AGENT-BRIEF.md +168 -0
  166. package/skills/triage/OUT-OF-SCOPE.md +101 -0
  167. package/skills/triage/SKILL.md +103 -0
  168. package/skills/triage/agents/claude.yaml +2 -0
  169. package/skills/triage/agents/openai.yaml +4 -0
  170. package/skills/zoom-out/SKILL.md +6 -0
  171. package/skills/zoom-out/agents/claude.yaml +3 -0
  172. package/skills/zoom-out/agents/openai.yaml +4 -0
@@ -0,0 +1,2 @@
1
+ frontmatter:
2
+ user-invocable: true
@@ -0,0 +1,4 @@
1
+ interface:
2
+ display_name: "To Issues"
3
+ short_description: "Break a plan, spec, or PRD into independently-grabbable issues using vertical slices"
4
+ default_prompt: "Break this PRD into vertical-slice issues with clear acceptance criteria."
@@ -0,0 +1,76 @@
1
+ ---
2
+ name: to-prd
3
+ description: Turn the current conversation context into a PRD and publish it to the project issue tracker. Use when user wants to create a PRD from the current context.
4
+ ---
5
+
6
+ This skill takes the current conversation context and codebase understanding and produces a PRD. Do NOT interview the user — just synthesize what you already know.
7
+
8
+ The issue tracker and triage label vocabulary should have been provided to you — run `/setup-matt-pocock-skills` if not.
9
+
10
+ ## Process
11
+
12
+ 1. Explore the repo to understand the current state of the codebase, if you haven't already. Use the project's domain glossary vocabulary throughout the PRD, and respect any ADRs in the area you're touching.
13
+
14
+ 2. Sketch out the major modules you will need to build or modify to complete the implementation. Actively look for opportunities to extract deep modules that can be tested in isolation.
15
+
16
+ A deep module (as opposed to a shallow module) is one which encapsulates a lot of functionality in a simple, testable interface which rarely changes.
17
+
18
+ Check with the user that these modules match their expectations. Check with the user which modules they want tests written for.
19
+
20
+ 3. Write the PRD using the template below, then publish it to the project issue tracker. Apply the `ready-for-agent` triage label - no need for additional triage.
21
+
22
+ <prd-template>
23
+
24
+ ## Problem Statement
25
+
26
+ The problem that the user is facing, from the user's perspective.
27
+
28
+ ## Solution
29
+
30
+ The solution to the problem, from the user's perspective.
31
+
32
+ ## User Stories
33
+
34
+ A LONG, numbered list of user stories. Each user story should be in the format of:
35
+
36
+ 1. As an <actor>, I want a <feature>, so that <benefit>
37
+
38
+ <user-story-example>
39
+ 1. As a mobile bank customer, I want to see balance on my accounts, so that I can make better informed decisions about my spending
40
+ </user-story-example>
41
+
42
+ This list of user stories should be extremely extensive and cover all aspects of the feature.
43
+
44
+ ## Implementation Decisions
45
+
46
+ A list of implementation decisions that were made. This can include:
47
+
48
+ - The modules that will be built/modified
49
+ - The interfaces of those modules that will be modified
50
+ - Technical clarifications from the developer
51
+ - Architectural decisions
52
+ - Schema changes
53
+ - API contracts
54
+ - Specific interactions
55
+
56
+ Do NOT include specific file paths or code snippets. They may end up being outdated very quickly.
57
+
58
+ Exception: if a prototype produced a snippet that encodes a decision more precisely than prose can (state machine, reducer, schema, type shape), inline it within the relevant decision and note briefly that it came from a prototype. Trim to the decision-rich parts — not a working demo, just the important bits.
59
+
60
+ ## Testing Decisions
61
+
62
+ A list of testing decisions that were made. Include:
63
+
64
+ - A description of what makes a good test (only test external behavior, not implementation details)
65
+ - Which modules will be tested
66
+ - Prior art for the tests (i.e. similar types of tests in the codebase)
67
+
68
+ ## Out of Scope
69
+
70
+ A description of the things that are out of scope for this PRD.
71
+
72
+ ## Further Notes
73
+
74
+ Any further notes about the feature.
75
+
76
+ </prd-template>
@@ -0,0 +1,2 @@
1
+ frontmatter:
2
+ user-invocable: true
@@ -0,0 +1,4 @@
1
+ interface:
2
+ display_name: "To PRD"
3
+ short_description: "Synthesize the current conversation into a PRD on the issue tracker"
4
+ default_prompt: "Turn what we just discussed into a PRD and submit it as an issue."
@@ -0,0 +1,168 @@
1
+ # Writing Agent Briefs
2
+
3
+ An agent brief is a structured comment posted on a GitHub issue when it moves to `ready-for-agent`. It is the authoritative specification that an AFK agent will work from. The original issue body and discussion are context — the agent brief is the contract.
4
+
5
+ ## Principles
6
+
7
+ ### Durability over precision
8
+
9
+ The issue may sit in `ready-for-agent` for days or weeks. The codebase will change in the meantime. Write the brief so it stays useful even as files are renamed, moved, or refactored.
10
+
11
+ - **Do** describe interfaces, types, and behavioral contracts
12
+ - **Do** name specific types, function signatures, or config shapes that the agent should look for or modify
13
+ - **Don't** reference file paths — they go stale
14
+ - **Don't** reference line numbers
15
+ - **Don't** assume the current implementation structure will remain the same
16
+
17
+ ### Behavioral, not procedural
18
+
19
+ Describe **what** the system should do, not **how** to implement it. The agent will explore the codebase fresh and make its own implementation decisions.
20
+
21
+ - **Good:** "The `SkillConfig` type should accept an optional `schedule` field of type `CronExpression`"
22
+ - **Bad:** "Open src/types/skill.ts and add a schedule field on line 42"
23
+ - **Good:** "When a user runs `/triage` with no arguments, they should see a summary of issues needing attention"
24
+ - **Bad:** "Add a switch statement in the main handler function"
25
+
26
+ ### Complete acceptance criteria
27
+
28
+ The agent needs to know when it's done. Every agent brief must have concrete, testable acceptance criteria. Each criterion should be independently verifiable.
29
+
30
+ - **Good:** "Running `gh issue list --label needs-triage` returns issues that have been through initial classification"
31
+ - **Bad:** "Triage should work correctly"
32
+
33
+ ### Explicit scope boundaries
34
+
35
+ State what is out of scope. This prevents the agent from gold-plating or making assumptions about adjacent features.
36
+
37
+ ## Template
38
+
39
+ ```markdown
40
+ ## Agent Brief
41
+
42
+ **Category:** bug / enhancement
43
+ **Summary:** one-line description of what needs to happen
44
+
45
+ **Current behavior:**
46
+ Describe what happens now. For bugs, this is the broken behavior.
47
+ For enhancements, this is the status quo the feature builds on.
48
+
49
+ **Desired behavior:**
50
+ Describe what should happen after the agent's work is complete.
51
+ Be specific about edge cases and error conditions.
52
+
53
+ **Key interfaces:**
54
+ - `TypeName` — what needs to change and why
55
+ - `functionName()` return type — what it currently returns vs what it should return
56
+ - Config shape — any new configuration options needed
57
+
58
+ **Acceptance criteria:**
59
+ - [ ] Specific, testable criterion 1
60
+ - [ ] Specific, testable criterion 2
61
+ - [ ] Specific, testable criterion 3
62
+
63
+ **Out of scope:**
64
+ - Thing that should NOT be changed or addressed in this issue
65
+ - Adjacent feature that might seem related but is separate
66
+ ```
67
+
68
+ ## Examples
69
+
70
+ ### Good agent brief (bug)
71
+
72
+ ```markdown
73
+ ## Agent Brief
74
+
75
+ **Category:** bug
76
+ **Summary:** Skill description truncation drops mid-word, producing broken output
77
+
78
+ **Current behavior:**
79
+ When a skill description exceeds 1024 characters, it is truncated at exactly
80
+ 1024 characters regardless of word boundaries. This produces descriptions
81
+ that end mid-word (e.g. "Use when the user wants to confi").
82
+
83
+ **Desired behavior:**
84
+ Truncation should break at the last word boundary before 1024 characters
85
+ and append "..." to indicate truncation.
86
+
87
+ **Key interfaces:**
88
+ - The `SkillMetadata` type's `description` field — no type change needed,
89
+ but the validation/processing logic that populates it needs to respect
90
+ word boundaries
91
+ - Any function that reads SKILL.md frontmatter and extracts the description
92
+
93
+ **Acceptance criteria:**
94
+ - [ ] Descriptions under 1024 chars are unchanged
95
+ - [ ] Descriptions over 1024 chars are truncated at the last word boundary
96
+ before 1024 chars
97
+ - [ ] Truncated descriptions end with "..."
98
+ - [ ] The total length including "..." does not exceed 1024 chars
99
+
100
+ **Out of scope:**
101
+ - Changing the 1024 char limit itself
102
+ - Multi-line description support
103
+ ```
104
+
105
+ ### Good agent brief (enhancement)
106
+
107
+ ```markdown
108
+ ## Agent Brief
109
+
110
+ **Category:** enhancement
111
+ **Summary:** Add `.out-of-scope/` directory support for tracking rejected feature requests
112
+
113
+ **Current behavior:**
114
+ When a feature request is rejected, the issue is closed with a `wontfix` label
115
+ and a comment. There is no persistent record of the decision or reasoning.
116
+ Future similar requests require the maintainer to recall or search for the
117
+ prior discussion.
118
+
119
+ **Desired behavior:**
120
+ Rejected feature requests should be documented in `.out-of-scope/<concept>.md`
121
+ files that capture the decision, reasoning, and links to all issues that
122
+ requested the feature. When triaging new issues, these files should be
123
+ checked for matches.
124
+
125
+ **Key interfaces:**
126
+ - Markdown file format in `.out-of-scope/` — each file should have a
127
+ `# Concept Name` heading, a `**Decision:**` line, a `**Reason:**` line,
128
+ and a `**Prior requests:**` list with issue links
129
+ - The triage workflow should read all `.out-of-scope/*.md` files early
130
+ and match incoming issues against them by concept similarity
131
+
132
+ **Acceptance criteria:**
133
+ - [ ] Closing a feature as wontfix creates/updates a file in `.out-of-scope/`
134
+ - [ ] The file includes the decision, reasoning, and link to the closed issue
135
+ - [ ] If a matching `.out-of-scope/` file already exists, the new issue is
136
+ appended to its "Prior requests" list rather than creating a duplicate
137
+ - [ ] During triage, existing `.out-of-scope/` files are checked and surfaced
138
+ when a new issue matches a prior rejection
139
+
140
+ **Out of scope:**
141
+ - Automated matching (human confirms the match)
142
+ - Reopening previously rejected features
143
+ - Bug reports (only enhancement rejections go to `.out-of-scope/`)
144
+ ```
145
+
146
+ ### Bad agent brief
147
+
148
+ ```markdown
149
+ ## Agent Brief
150
+
151
+ **Summary:** Fix the triage bug
152
+
153
+ **What to do:**
154
+ The triage thing is broken. Look at the main file and fix it.
155
+ The function around line 150 has the issue.
156
+
157
+ **Files to change:**
158
+ - src/triage/handler.ts (line 150)
159
+ - src/types.ts (line 42)
160
+ ```
161
+
162
+ This is bad because:
163
+ - No category
164
+ - Vague description ("the triage thing is broken")
165
+ - References file paths and line numbers that will go stale
166
+ - No acceptance criteria
167
+ - No scope boundaries
168
+ - No description of current vs desired behavior
@@ -0,0 +1,101 @@
1
+ # Out-of-Scope Knowledge Base
2
+
3
+ The `.out-of-scope/` directory in a repo stores persistent records of rejected feature requests. It serves two purposes:
4
+
5
+ 1. **Institutional memory** — why a feature was rejected, so the reasoning isn't lost when the issue is closed
6
+ 2. **Deduplication** — when a new issue comes in that matches a prior rejection, the skill can surface the previous decision instead of re-litigating it
7
+
8
+ ## Directory structure
9
+
10
+ ```
11
+ .out-of-scope/
12
+ ├── dark-mode.md
13
+ ├── plugin-system.md
14
+ └── graphql-api.md
15
+ ```
16
+
17
+ One file per **concept**, not per issue. Multiple issues requesting the same thing are grouped under one file.
18
+
19
+ ## File format
20
+
21
+ The file should be written in a relaxed, readable style — more like a short design document than a database entry. Use paragraphs, code samples, and examples to make the reasoning clear and useful to someone encountering it for the first time.
22
+
23
+ ```markdown
24
+ # Dark Mode
25
+
26
+ This project does not support dark mode or user-facing theming.
27
+
28
+ ## Why this is out of scope
29
+
30
+ The rendering pipeline assumes a single color palette defined in
31
+ `ThemeConfig`. Supporting multiple themes would require:
32
+
33
+ - A theme context provider wrapping the entire component tree
34
+ - Per-component theme-aware style resolution
35
+ - A persistence layer for user theme preferences
36
+
37
+ This is a significant architectural change that doesn't align with the
38
+ project's focus on content authoring. Theming is a concern for downstream
39
+ consumers who embed or redistribute the output.
40
+
41
+ ```ts
42
+ // The current ThemeConfig interface is not designed for runtime switching:
43
+ interface ThemeConfig {
44
+ colors: ColorPalette; // single palette, resolved at build time
45
+ fonts: FontStack;
46
+ }
47
+ ```
48
+
49
+ ## Prior requests
50
+
51
+ - #42 — "Add dark mode support"
52
+ - #87 — "Night theme for accessibility"
53
+ - #134 — "Dark theme option"
54
+ ```
55
+
56
+ ### Naming the file
57
+
58
+ Use a short, descriptive kebab-case name for the concept: `dark-mode.md`, `plugin-system.md`, `graphql-api.md`. The name should be recognizable enough that someone browsing the directory understands what was rejected without opening the file.
59
+
60
+ ### Writing the reason
61
+
62
+ The reason should be substantive — not "we don't want this" but why. Good reasons reference:
63
+
64
+ - Project scope or philosophy ("This project focuses on X; theming is a downstream concern")
65
+ - Technical constraints ("Supporting this would require Y, which conflicts with our Z architecture")
66
+ - Strategic decisions ("We chose to use A instead of B because...")
67
+
68
+ The reason should be durable. Avoid referencing temporary circumstances ("we're too busy right now") — those aren't real rejections, they're deferrals.
69
+
70
+ ## When to check `.out-of-scope/`
71
+
72
+ During triage (Step 1: Gather context), read all files in `.out-of-scope/`. When evaluating a new issue:
73
+
74
+ - Check if the request matches an existing out-of-scope concept
75
+ - Matching is by concept similarity, not keyword — "night theme" matches `dark-mode.md`
76
+ - If there's a match, surface it to the maintainer: "This is similar to `.out-of-scope/dark-mode.md` — we rejected this before because [reason]. Do you still feel the same way?"
77
+
78
+ The maintainer may:
79
+
80
+ - **Confirm** — the new issue gets added to the existing file's "Prior requests" list, then closed
81
+ - **Reconsider** — the out-of-scope file gets deleted or updated, and the issue proceeds through normal triage
82
+ - **Disagree** — the issues are related but distinct, proceed with normal triage
83
+
84
+ ## When to write to `.out-of-scope/`
85
+
86
+ Only when an **enhancement** (not a bug) is rejected as `wontfix`. The flow:
87
+
88
+ 1. Maintainer decides a feature request is out of scope
89
+ 2. Check if a matching `.out-of-scope/` file already exists
90
+ 3. If yes: append the new issue to the "Prior requests" list
91
+ 4. If no: create a new file with the concept name, decision, reason, and first prior request
92
+ 5. Post a comment on the issue explaining the decision and mentioning the `.out-of-scope/` file
93
+ 6. Close the issue with the `wontfix` label
94
+
95
+ ## Updating or removing out-of-scope files
96
+
97
+ If the maintainer changes their mind about a previously rejected concept:
98
+
99
+ - Delete the `.out-of-scope/` file
100
+ - The skill does not need to reopen old issues — they're historical records
101
+ - The new issue that triggered the reconsideration proceeds through normal triage
@@ -0,0 +1,103 @@
1
+ ---
2
+ name: triage
3
+ description: Triage issues through a state machine driven by triage roles. Use when user wants to create an issue, triage issues, review incoming bugs or feature requests, prepare issues for an AFK agent, or manage issue workflow.
4
+ ---
5
+
6
+ # Triage
7
+
8
+ Move issues on the project issue tracker through a small state machine of triage roles.
9
+
10
+ Every comment or issue posted to the issue tracker during triage **must** start with this disclaimer:
11
+
12
+ ```
13
+ > *This was generated by AI during triage.*
14
+ ```
15
+
16
+ ## Reference docs
17
+
18
+ - [AGENT-BRIEF.md](AGENT-BRIEF.md) — how to write durable agent briefs
19
+ - [OUT-OF-SCOPE.md](OUT-OF-SCOPE.md) — how the `.out-of-scope/` knowledge base works
20
+
21
+ ## Roles
22
+
23
+ Two **category** roles:
24
+
25
+ - `bug` — something is broken
26
+ - `enhancement` — new feature or improvement
27
+
28
+ Five **state** roles:
29
+
30
+ - `needs-triage` — maintainer needs to evaluate
31
+ - `needs-info` — waiting on reporter for more information
32
+ - `ready-for-agent` — fully specified, ready for an AFK agent
33
+ - `ready-for-human` — needs human implementation
34
+ - `wontfix` — will not be actioned
35
+
36
+ Every triaged issue should carry exactly one category role and one state role. If state roles conflict, flag it and ask the maintainer before doing anything else.
37
+
38
+ These are canonical role names — the actual label strings used in the issue tracker may differ. The mapping should have been provided to you - run `/setup-matt-pocock-skills` if not.
39
+
40
+ State transitions: an unlabeled issue normally goes to `needs-triage` first; from there it moves to `needs-info`, `ready-for-agent`, `ready-for-human`, or `wontfix`. `needs-info` returns to `needs-triage` once the reporter replies. The maintainer can override at any time — flag transitions that look unusual and ask before proceeding.
41
+
42
+ ## Invocation
43
+
44
+ The maintainer invokes `/triage` and describes what they want in natural language. Interpret the request and act. Examples:
45
+
46
+ - "Show me anything that needs my attention"
47
+ - "Let's look at #42"
48
+ - "Move #42 to ready-for-agent"
49
+ - "What's ready for agents to pick up?"
50
+
51
+ ## Show what needs attention
52
+
53
+ Query the issue tracker and present three buckets, oldest first:
54
+
55
+ 1. **Unlabeled** — never triaged.
56
+ 2. **`needs-triage`** — evaluation in progress.
57
+ 3. **`needs-info` with reporter activity since the last triage notes** — needs re-evaluation.
58
+
59
+ Show counts and a one-line summary per issue. Let the maintainer pick.
60
+
61
+ ## Triage a specific issue
62
+
63
+ 1. **Gather context.** Read the full issue (body, comments, labels, reporter, dates). Parse any prior triage notes so you don't re-ask resolved questions. Explore the codebase using the project's domain glossary, respecting ADRs in the area. Read `.out-of-scope/*.md` and surface any prior rejection that resembles this issue.
64
+
65
+ 2. **Recommend.** Tell the maintainer your category and state recommendation with reasoning, plus a brief codebase summary relevant to the issue. Wait for direction.
66
+
67
+ 3. **Reproduce (bugs only).** Before any grilling, attempt reproduction: read the reporter's steps, trace the relevant code, run tests or commands. Report what happened — successful repro with code path, failed repro, or insufficient detail (a strong `needs-info` signal). A confirmed repro makes a much stronger agent brief.
68
+
69
+ 4. **Grill (if needed).** If the issue needs fleshing out, run a `/grill-with-docs` session.
70
+
71
+ 5. **Apply the outcome:**
72
+ - `ready-for-agent` — post an agent brief comment ([AGENT-BRIEF.md](AGENT-BRIEF.md)).
73
+ - `ready-for-human` — same structure as an agent brief, but note why it can't be delegated (judgment calls, external access, design decisions, manual testing).
74
+ - `needs-info` — post triage notes (template below).
75
+ - `wontfix` (bug) — polite explanation, then close.
76
+ - `wontfix` (enhancement) — write to `.out-of-scope/`, link to it from a comment, then close ([OUT-OF-SCOPE.md](OUT-OF-SCOPE.md)).
77
+ - `needs-triage` — apply the role. Optional comment if there's partial progress.
78
+
79
+ ## Quick state override
80
+
81
+ If the maintainer says "move #42 to ready-for-agent", trust them and apply the role directly. Confirm what you're about to do (role changes, comment, close), then act. Skip grilling. If moving to `ready-for-agent` without a grilling session, ask whether they want to write an agent brief.
82
+
83
+ ## Needs-info template
84
+
85
+ ```markdown
86
+ ## Triage Notes
87
+
88
+ **What we've established so far:**
89
+
90
+ - point 1
91
+ - point 2
92
+
93
+ **What we still need from you (@reporter):**
94
+
95
+ - question 1
96
+ - question 2
97
+ ```
98
+
99
+ Capture everything resolved during grilling under "established so far" so the work isn't lost. Questions must be specific and actionable, not "please provide more info".
100
+
101
+ ## Resuming a previous session
102
+
103
+ If prior triage notes exist on the issue, read them, check whether the reporter has answered any outstanding questions, and present an updated picture before continuing. Don't re-ask resolved questions.
@@ -0,0 +1,2 @@
1
+ frontmatter:
2
+ user-invocable: true
@@ -0,0 +1,4 @@
1
+ interface:
2
+ display_name: "Triage"
3
+ short_description: "Triage incoming issues through a state machine of triage roles"
4
+ default_prompt: "Triage the next batch of incoming issues into needs-info, ready-for-agent, ready-for-human, or wontfix."
@@ -0,0 +1,6 @@
1
+ ---
2
+ name: zoom-out
3
+ description: Tell the agent to zoom out and give broader context or a higher-level perspective. Use when you're unfamiliar with a section of code or need to understand how it fits into the bigger picture.
4
+ ---
5
+
6
+ I don't know this area of code well. Go up a layer of abstraction. Give me a map of all the relevant modules and callers, using the project's domain glossary vocabulary.
@@ -0,0 +1,3 @@
1
+ frontmatter:
2
+ user-invocable: true
3
+ disable-model-invocation: true
@@ -0,0 +1,4 @@
1
+ interface:
2
+ display_name: "Zoom Out"
3
+ short_description: "Give broader context and a higher-level perspective on an unfamiliar section of code"
4
+ default_prompt: "Zoom out and give a system-level map of this code area using the project glossary."
@@ -0,0 +1,18 @@
1
+ {
2
+ "schemaVersion": 1,
3
+ "pluginRef": "matt-pocock-skills@athena-workflow-marketplace",
4
+ "pluginName": "matt-pocock-skills",
5
+ "marketplaceName": "athena-workflow-marketplace",
6
+ "version": "0.1.1",
7
+ "artifacts": {
8
+ "claude": {
9
+ "type": "directory",
10
+ "path": "./claude/plugin"
11
+ },
12
+ "codex": {
13
+ "type": "marketplace",
14
+ "marketplacePath": "./.agents/plugins/marketplace.json",
15
+ "pluginPath": "./codex/plugin"
16
+ }
17
+ }
18
+ }
package/package.json ADDED
@@ -0,0 +1,25 @@
1
+ {
2
+ "name": "@athenaflow/plugin-matt-pocock-skills",
3
+ "version": "0.1.1",
4
+ "description": "Bundled subset of Matt Pocock's Skills For Real Engineers (https://github.com/mattpocock/skills) used by the fullstack-engineering workflow.",
5
+ "license": "SEE LICENSE IN NOTICE.md",
6
+ "repository": {
7
+ "type": "git",
8
+ "url": "git+https://github.com/lespaceman/athena-workflow-marketplace.git",
9
+ "directory": "plugins/matt-pocock-skills"
10
+ },
11
+ "publishConfig": {
12
+ "access": "public"
13
+ },
14
+ "files": [
15
+ ".claude-plugin/",
16
+ ".codex-plugin/",
17
+ "skills/",
18
+ "dist/",
19
+ "NOTICE.md"
20
+ ],
21
+ "scripts": {
22
+ "build:artifacts": "node ../../scripts/build-plugin-artifacts.mjs .",
23
+ "prepack": "npm run build:artifacts"
24
+ }
25
+ }
@@ -0,0 +1,117 @@
1
+ ---
2
+ name: diagnose
3
+ description: Disciplined diagnosis loop for hard bugs and performance regressions. Reproduce → minimise → hypothesise → instrument → fix → regression-test. Use when user says "diagnose this" / "debug this", reports a bug, says something is broken/throwing/failing, or describes a performance regression.
4
+ ---
5
+
6
+ # Diagnose
7
+
8
+ A discipline for hard bugs. Skip phases only when explicitly justified.
9
+
10
+ When exploring the codebase, use the project's domain glossary to get a clear mental model of the relevant modules, and check ADRs in the area you're touching.
11
+
12
+ ## Phase 1 — Build a feedback loop
13
+
14
+ **This is the skill.** Everything else is mechanical. If you have a fast, deterministic, agent-runnable pass/fail signal for the bug, you will find the cause — bisection, hypothesis-testing, and instrumentation all just consume that signal. If you don't have one, no amount of staring at code will save you.
15
+
16
+ Spend disproportionate effort here. **Be aggressive. Be creative. Refuse to give up.**
17
+
18
+ ### Ways to construct one — try them in roughly this order
19
+
20
+ 1. **Failing test** at whatever seam reaches the bug — unit, integration, e2e.
21
+ 2. **Curl / HTTP script** against a running dev server.
22
+ 3. **CLI invocation** with a fixture input, diffing stdout against a known-good snapshot.
23
+ 4. **Headless browser script** (Playwright / Puppeteer) — drives the UI, asserts on DOM/console/network.
24
+ 5. **Replay a captured trace.** Save a real network request / payload / event log to disk; replay it through the code path in isolation.
25
+ 6. **Throwaway harness.** Spin up a minimal subset of the system (one service, mocked deps) that exercises the bug code path with a single function call.
26
+ 7. **Property / fuzz loop.** If the bug is "sometimes wrong output", run 1000 random inputs and look for the failure mode.
27
+ 8. **Bisection harness.** If the bug appeared between two known states (commit, dataset, version), automate "boot at state X, check, repeat" so you can `git bisect run` it.
28
+ 9. **Differential loop.** Run the same input through old-version vs new-version (or two configs) and diff outputs.
29
+ 10. **HITL bash script.** Last resort. If a human must click, drive _them_ with `scripts/hitl-loop.template.sh` so the loop is still structured. Captured output feeds back to you.
30
+
31
+ Build the right feedback loop, and the bug is 90% fixed.
32
+
33
+ ### Iterate on the loop itself
34
+
35
+ Treat the loop as a product. Once you have _a_ loop, ask:
36
+
37
+ - Can I make it faster? (Cache setup, skip unrelated init, narrow the test scope.)
38
+ - Can I make the signal sharper? (Assert on the specific symptom, not "didn't crash".)
39
+ - Can I make it more deterministic? (Pin time, seed RNG, isolate filesystem, freeze network.)
40
+
41
+ A 30-second flaky loop is barely better than no loop. A 2-second deterministic loop is a debugging superpower.
42
+
43
+ ### Non-deterministic bugs
44
+
45
+ The goal is not a clean repro but a **higher reproduction rate**. Loop the trigger 100×, parallelise, add stress, narrow timing windows, inject sleeps. A 50%-flake bug is debuggable; 1% is not — keep raising the rate until it's debuggable.
46
+
47
+ ### When you genuinely cannot build a loop
48
+
49
+ Stop and say so explicitly. List what you tried. Ask the user for: (a) access to whatever environment reproduces it, (b) a captured artifact (HAR file, log dump, core dump, screen recording with timestamps), or (c) permission to add temporary production instrumentation. Do **not** proceed to hypothesise without a loop.
50
+
51
+ Do not proceed to Phase 2 until you have a loop you believe in.
52
+
53
+ ## Phase 2 — Reproduce
54
+
55
+ Run the loop. Watch the bug appear.
56
+
57
+ Confirm:
58
+
59
+ - [ ] The loop produces the failure mode the **user** described — not a different failure that happens to be nearby. Wrong bug = wrong fix.
60
+ - [ ] The failure is reproducible across multiple runs (or, for non-deterministic bugs, reproducible at a high enough rate to debug against).
61
+ - [ ] You have captured the exact symptom (error message, wrong output, slow timing) so later phases can verify the fix actually addresses it.
62
+
63
+ Do not proceed until you reproduce the bug.
64
+
65
+ ## Phase 3 — Hypothesise
66
+
67
+ Generate **3–5 ranked hypotheses** before testing any of them. Single-hypothesis generation anchors on the first plausible idea.
68
+
69
+ Each hypothesis must be **falsifiable**: state the prediction it makes.
70
+
71
+ > Format: "If <X> is the cause, then <changing Y> will make the bug disappear / <changing Z> will make it worse."
72
+
73
+ If you cannot state the prediction, the hypothesis is a vibe — discard or sharpen it.
74
+
75
+ **Show the ranked list to the user before testing.** They often have domain knowledge that re-ranks instantly ("we just deployed a change to #3"), or know hypotheses they've already ruled out. Cheap checkpoint, big time saver. Don't block on it — proceed with your ranking if the user is AFK.
76
+
77
+ ## Phase 4 — Instrument
78
+
79
+ Each probe must map to a specific prediction from Phase 3. **Change one variable at a time.**
80
+
81
+ Tool preference:
82
+
83
+ 1. **Debugger / REPL inspection** if the env supports it. One breakpoint beats ten logs.
84
+ 2. **Targeted logs** at the boundaries that distinguish hypotheses.
85
+ 3. Never "log everything and grep".
86
+
87
+ **Tag every debug log** with a unique prefix, e.g. `[DEBUG-a4f2]`. Cleanup at the end becomes a single grep. Untagged logs survive; tagged logs die.
88
+
89
+ **Perf branch.** For performance regressions, logs are usually wrong. Instead: establish a baseline measurement (timing harness, `performance.now()`, profiler, query plan), then bisect. Measure first, fix second.
90
+
91
+ ## Phase 5 — Fix + regression test
92
+
93
+ Write the regression test **before the fix** — but only if there is a **correct seam** for it.
94
+
95
+ A correct seam is one where the test exercises the **real bug pattern** as it occurs at the call site. If the only available seam is too shallow (single-caller test when the bug needs multiple callers, unit test that can't replicate the chain that triggered the bug), a regression test there gives false confidence.
96
+
97
+ **If no correct seam exists, that itself is the finding.** Note it. The codebase architecture is preventing the bug from being locked down. Flag this for the next phase.
98
+
99
+ If a correct seam exists:
100
+
101
+ 1. Turn the minimised repro into a failing test at that seam.
102
+ 2. Watch it fail.
103
+ 3. Apply the fix.
104
+ 4. Watch it pass.
105
+ 5. Re-run the Phase 1 feedback loop against the original (un-minimised) scenario.
106
+
107
+ ## Phase 6 — Cleanup + post-mortem
108
+
109
+ Required before declaring done:
110
+
111
+ - [ ] Original repro no longer reproduces (re-run the Phase 1 loop)
112
+ - [ ] Regression test passes (or absence of seam is documented)
113
+ - [ ] All `[DEBUG-...]` instrumentation removed (`grep` the prefix)
114
+ - [ ] Throwaway prototypes deleted (or moved to a clearly-marked debug location)
115
+ - [ ] The hypothesis that turned out correct is stated in the commit / PR message — so the next debugger learns
116
+
117
+ **Then ask: what would have prevented this bug?** If the answer involves architectural change (no good test seam, tangled callers, hidden coupling) hand off to the `/improve-codebase-architecture` skill with the specifics. Make the recommendation **after** the fix is in, not before — you have more information now than when you started.
@@ -0,0 +1,2 @@
1
+ frontmatter:
2
+ user-invocable: true