@gcunharodrigues/wrxn 0.1.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.
- package/LICENSE +21 -0
- package/README.md +38 -0
- package/bin/wrxn.cjs +342 -0
- package/lib/connect.cjs +216 -0
- package/lib/executor.cjs +238 -0
- package/lib/install.cjs +105 -0
- package/lib/manifest.cjs +67 -0
- package/lib/migrate.cjs +93 -0
- package/lib/onboard.cjs +84 -0
- package/lib/semver.cjs +14 -0
- package/lib/update.cjs +91 -0
- package/lib/worktree.cjs +217 -0
- package/manifest.json +451 -0
- package/migrations/README.md +21 -0
- package/package.json +23 -0
- package/payload/.claude/constitution.local.md +13 -0
- package/payload/.claude/constitution.md +28 -0
- package/payload/.claude/hooks/code-intel-push.cjs +108 -0
- package/payload/.claude/hooks/enforce-managed-guard.cjs +68 -0
- package/payload/.claude/hooks/enforce-managed-precommit.cjs +74 -0
- package/payload/.claude/hooks/enforce-push-authority.cjs +51 -0
- package/payload/.claude/hooks/enforce-review-marker.cjs +62 -0
- package/payload/.claude/hooks/enforce-tests-on-push.cjs +40 -0
- package/payload/.claude/hooks/recall-surface.cjs +127 -0
- package/payload/.claude/hooks/reference-detect.cjs +83 -0
- package/payload/.claude/hooks/session-end.cjs +132 -0
- package/payload/.claude/hooks/session-history.cjs +76 -0
- package/payload/.claude/hooks/session-start.cjs +117 -0
- package/payload/.claude/hooks/synapse-engine.cjs +351 -0
- package/payload/.claude/hooks/wiki-lint.cjs +104 -0
- package/payload/.claude/settings.json +60 -0
- package/payload/.claude/skills/audit/SKILL.md +23 -0
- package/payload/.claude/skills/diagnose/SKILL.md +117 -0
- package/payload/.claude/skills/diagnose/scripts/hitl-loop.template.sh +41 -0
- package/payload/.claude/skills/grill-me/SKILL.md +10 -0
- package/payload/.claude/skills/grill-with-docs/ADR-FORMAT.md +47 -0
- package/payload/.claude/skills/grill-with-docs/CONTEXT-FORMAT.md +60 -0
- package/payload/.claude/skills/grill-with-docs/SKILL.md +88 -0
- package/payload/.claude/skills/handoff/SKILL.md +19 -0
- package/payload/.claude/skills/improve-codebase-architecture/DEEPENING.md +37 -0
- package/payload/.claude/skills/improve-codebase-architecture/HTML-REPORT.md +123 -0
- package/payload/.claude/skills/improve-codebase-architecture/INTERFACE-DESIGN.md +44 -0
- package/payload/.claude/skills/improve-codebase-architecture/LANGUAGE.md +53 -0
- package/payload/.claude/skills/improve-codebase-architecture/SKILL.md +81 -0
- package/payload/.claude/skills/level-up/SKILL.md +28 -0
- package/payload/.claude/skills/memory/SKILL.md +79 -0
- package/payload/.claude/skills/onboard/SKILL.md +43 -0
- package/payload/.claude/skills/prototype/LOGIC.md +79 -0
- package/payload/.claude/skills/prototype/SKILL.md +30 -0
- package/payload/.claude/skills/prototype/UI.md +112 -0
- package/payload/.claude/skills/qa-walk/SKILL.md +227 -0
- package/payload/.claude/skills/qa-walk/references/cli-mode.md +28 -0
- package/payload/.claude/skills/qa-walk/references/finding-issue-template.md +48 -0
- package/payload/.claude/skills/qa-walk/references/walk-report-template.md +56 -0
- package/payload/.claude/skills/qa-walk/references/web-mode.md +112 -0
- package/payload/.claude/skills/setup-matt-pocock-skills/SKILL.md +121 -0
- package/payload/.claude/skills/setup-matt-pocock-skills/domain.md +51 -0
- package/payload/.claude/skills/setup-matt-pocock-skills/issue-tracker-github.md +22 -0
- package/payload/.claude/skills/setup-matt-pocock-skills/issue-tracker-gitlab.md +23 -0
- package/payload/.claude/skills/setup-matt-pocock-skills/issue-tracker-local.md +19 -0
- package/payload/.claude/skills/setup-matt-pocock-skills/triage-labels.md +15 -0
- package/payload/.claude/skills/skill-creator/LICENSE.txt +202 -0
- package/payload/.claude/skills/skill-creator/SKILL.md +209 -0
- package/payload/.claude/skills/skill-creator/scripts/init_skill.py +303 -0
- package/payload/.claude/skills/skill-creator/scripts/package_skill.py +110 -0
- package/payload/.claude/skills/skill-creator/scripts/quick_validate.py +65 -0
- package/payload/.claude/skills/synapse/SKILL.md +132 -0
- package/payload/.claude/skills/synapse/assets/README.md +50 -0
- package/payload/.claude/skills/synapse/references/brackets.md +100 -0
- package/payload/.claude/skills/synapse/references/commands.md +118 -0
- package/payload/.claude/skills/synapse/references/domains.md +126 -0
- package/payload/.claude/skills/synapse/references/layers.md +186 -0
- package/payload/.claude/skills/synapse/references/manifest.md +142 -0
- package/payload/.claude/skills/tdd/SKILL.md +22 -0
- package/payload/.claude/skills/tech-search/SKILL.md +431 -0
- package/payload/.claude/skills/tech-search/prompts/page-extract.md +133 -0
- package/payload/.claude/skills/to-issues/SKILL.md +83 -0
- package/payload/.claude/skills/to-prd/SKILL.md +74 -0
- package/payload/.claude/skills/triage/AGENT-BRIEF.md +168 -0
- package/payload/.claude/skills/triage/OUT-OF-SCOPE.md +101 -0
- package/payload/.claude/skills/triage/SKILL.md +103 -0
- package/payload/.claude/skills/write-a-skill/SKILL.md +117 -0
- package/payload/.recon.json +3 -0
- package/payload/.synapse/global +6 -0
- package/payload/.synapse/manifest +38 -0
- package/payload/.synapse/pipeline +6 -0
- package/payload/.synapse/routing +8 -0
- package/payload/.wrxn/continuity/.gitkeep +0 -0
- package/payload/.wrxn/history/.gitkeep +0 -0
- package/payload/.wrxn/wiki/.gitkeep +0 -0
- package/payload/.wrxn/wiki/concepts/.gitkeep +0 -0
- package/payload/.wrxn/wiki/decisions/.gitkeep +0 -0
- package/payload/.wrxn/wiki/gotchas/.gitkeep +0 -0
- package/payload/.wrxn/wiki/sessions/.gitkeep +0 -0
- package/payload/.wrxn/wiki.cjs +164 -0
- package/payload/aios-intake.md +32 -0
- package/payload/connections.md +15 -0
- package/payload/decisions/log.md +18 -0
- package/payload/docs/agents/domain.md +38 -0
- package/payload/docs/agents/issue-tracker.md +25 -0
- package/payload/docs/agents/triage-labels.md +15 -0
- package/payload/docs/workspace/operator-layer.md +14 -0
|
@@ -0,0 +1,74 @@
|
|
|
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 seams at which you're going to test the feature. Existing seams should be preferred to new ones. Use the highest seam possible. If new seams are needed, propose them at the highest point you can.
|
|
15
|
+
|
|
16
|
+
Check with the user that these seams match their expectations.
|
|
17
|
+
|
|
18
|
+
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.
|
|
19
|
+
|
|
20
|
+
<prd-template>
|
|
21
|
+
|
|
22
|
+
## Problem Statement
|
|
23
|
+
|
|
24
|
+
The problem that the user is facing, from the user's perspective.
|
|
25
|
+
|
|
26
|
+
## Solution
|
|
27
|
+
|
|
28
|
+
The solution to the problem, from the user's perspective.
|
|
29
|
+
|
|
30
|
+
## User Stories
|
|
31
|
+
|
|
32
|
+
A LONG, numbered list of user stories. Each user story should be in the format of:
|
|
33
|
+
|
|
34
|
+
1. As an <actor>, I want a <feature>, so that <benefit>
|
|
35
|
+
|
|
36
|
+
<user-story-example>
|
|
37
|
+
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
|
|
38
|
+
</user-story-example>
|
|
39
|
+
|
|
40
|
+
This list of user stories should be extremely extensive and cover all aspects of the feature.
|
|
41
|
+
|
|
42
|
+
## Implementation Decisions
|
|
43
|
+
|
|
44
|
+
A list of implementation decisions that were made. This can include:
|
|
45
|
+
|
|
46
|
+
- The modules that will be built/modified
|
|
47
|
+
- The interfaces of those modules that will be modified
|
|
48
|
+
- Technical clarifications from the developer
|
|
49
|
+
- Architectural decisions
|
|
50
|
+
- Schema changes
|
|
51
|
+
- API contracts
|
|
52
|
+
- Specific interactions
|
|
53
|
+
|
|
54
|
+
Do NOT include specific file paths or code snippets. They may end up being outdated very quickly.
|
|
55
|
+
|
|
56
|
+
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.
|
|
57
|
+
|
|
58
|
+
## Testing Decisions
|
|
59
|
+
|
|
60
|
+
A list of testing decisions that were made. Include:
|
|
61
|
+
|
|
62
|
+
- A description of what makes a good test (only test external behavior, not implementation details)
|
|
63
|
+
- Which modules will be tested
|
|
64
|
+
- Prior art for the tests (i.e. similar types of tests in the codebase)
|
|
65
|
+
|
|
66
|
+
## Out of Scope
|
|
67
|
+
|
|
68
|
+
A description of the things that are out of scope for this PRD.
|
|
69
|
+
|
|
70
|
+
## Further Notes
|
|
71
|
+
|
|
72
|
+
Any further notes about the feature.
|
|
73
|
+
|
|
74
|
+
</prd-template>
|
|
@@ -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,117 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: write-a-skill
|
|
3
|
+
description: Create new agent skills with proper structure, progressive disclosure, and bundled resources. Use when user wants to create, write, or build a new skill.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Writing Skills
|
|
7
|
+
|
|
8
|
+
## Process
|
|
9
|
+
|
|
10
|
+
1. **Gather requirements** - ask user about:
|
|
11
|
+
- What task/domain does the skill cover?
|
|
12
|
+
- What specific use cases should it handle?
|
|
13
|
+
- Does it need executable scripts or just instructions?
|
|
14
|
+
- Any reference materials to include?
|
|
15
|
+
|
|
16
|
+
2. **Draft the skill** - create:
|
|
17
|
+
- SKILL.md with concise instructions
|
|
18
|
+
- Additional reference files if content exceeds 500 lines
|
|
19
|
+
- Utility scripts if deterministic operations needed
|
|
20
|
+
|
|
21
|
+
3. **Review with user** - present draft and ask:
|
|
22
|
+
- Does this cover your use cases?
|
|
23
|
+
- Anything missing or unclear?
|
|
24
|
+
- Should any section be more/less detailed?
|
|
25
|
+
|
|
26
|
+
## Skill Structure
|
|
27
|
+
|
|
28
|
+
```
|
|
29
|
+
skill-name/
|
|
30
|
+
├── SKILL.md # Main instructions (required)
|
|
31
|
+
├── REFERENCE.md # Detailed docs (if needed)
|
|
32
|
+
├── EXAMPLES.md # Usage examples (if needed)
|
|
33
|
+
└── scripts/ # Utility scripts (if needed)
|
|
34
|
+
└── helper.js
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
## SKILL.md Template
|
|
38
|
+
|
|
39
|
+
```md
|
|
40
|
+
---
|
|
41
|
+
name: skill-name
|
|
42
|
+
description: Brief description of capability. Use when [specific triggers].
|
|
43
|
+
---
|
|
44
|
+
|
|
45
|
+
# Skill Name
|
|
46
|
+
|
|
47
|
+
## Quick start
|
|
48
|
+
|
|
49
|
+
[Minimal working example]
|
|
50
|
+
|
|
51
|
+
## Workflows
|
|
52
|
+
|
|
53
|
+
[Step-by-step processes with checklists for complex tasks]
|
|
54
|
+
|
|
55
|
+
## Advanced features
|
|
56
|
+
|
|
57
|
+
[Link to separate files: See [REFERENCE.md](REFERENCE.md)]
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
## Description Requirements
|
|
61
|
+
|
|
62
|
+
The description is **the only thing your agent sees** when deciding which skill to load. It's surfaced in the system prompt alongside all other installed skills. Your agent reads these descriptions and picks the relevant skill based on the user's request.
|
|
63
|
+
|
|
64
|
+
**Goal**: Give your agent just enough info to know:
|
|
65
|
+
|
|
66
|
+
1. What capability this skill provides
|
|
67
|
+
2. When/why to trigger it (specific keywords, contexts, file types)
|
|
68
|
+
|
|
69
|
+
**Format**:
|
|
70
|
+
|
|
71
|
+
- Max 1024 chars
|
|
72
|
+
- Write in third person
|
|
73
|
+
- First sentence: what it does
|
|
74
|
+
- Second sentence: "Use when [specific triggers]"
|
|
75
|
+
|
|
76
|
+
**Good example**:
|
|
77
|
+
|
|
78
|
+
```
|
|
79
|
+
Extract text and tables from PDF files, fill forms, merge documents. Use when working with PDF files or when user mentions PDFs, forms, or document extraction.
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
**Bad example**:
|
|
83
|
+
|
|
84
|
+
```
|
|
85
|
+
Helps with documents.
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
The bad example gives your agent no way to distinguish this from other document skills.
|
|
89
|
+
|
|
90
|
+
## When to Add Scripts
|
|
91
|
+
|
|
92
|
+
Add utility scripts when:
|
|
93
|
+
|
|
94
|
+
- Operation is deterministic (validation, formatting)
|
|
95
|
+
- Same code would be generated repeatedly
|
|
96
|
+
- Errors need explicit handling
|
|
97
|
+
|
|
98
|
+
Scripts save tokens and improve reliability vs generated code.
|
|
99
|
+
|
|
100
|
+
## When to Split Files
|
|
101
|
+
|
|
102
|
+
Split into separate files when:
|
|
103
|
+
|
|
104
|
+
- SKILL.md exceeds 100 lines
|
|
105
|
+
- Content has distinct domains (finance vs sales schemas)
|
|
106
|
+
- Advanced features are rarely needed
|
|
107
|
+
|
|
108
|
+
## Review Checklist
|
|
109
|
+
|
|
110
|
+
After drafting, verify:
|
|
111
|
+
|
|
112
|
+
- [ ] Description includes triggers ("Use when...")
|
|
113
|
+
- [ ] SKILL.md under 100 lines
|
|
114
|
+
- [ ] No time-sensitive info
|
|
115
|
+
- [ ] Consistent terminology
|
|
116
|
+
- [ ] Concrete examples included
|
|
117
|
+
- [ ] References one level deep
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
# Domain: global (L1) — WRXN operational invariants. Always-on. Managed kernel file.
|
|
2
|
+
GLOBAL_RULE_0=git push, PR creation, and release tags are EXCLUSIVE to the devops role — every other agent delegates, never runs them directly (Constitution Art. I).
|
|
3
|
+
GLOBAL_RULE_1=The unit of work is an issue with explicit acceptance criteria — no code is written without one (Constitution Art. II).
|
|
4
|
+
GLOBAL_RULE_2=Before building, apply the decision hierarchy: REUSE (>=90% match) > ADAPT (60-89%, <30% change) > CREATE (justify it).
|
|
5
|
+
GLOBAL_RULE_3=Use conventional commits and reference the issue id (e.g. `feat(x): ... [issue-id]`).
|
|
6
|
+
GLOBAL_RULE_4=Tests and typecheck pass on every commit; the full green suite is the push gate (Constitution Art. III).
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
# SYNAPSE Manifest — domain registry (flat KEY=VALUE)
|
|
2
|
+
#
|
|
3
|
+
# The context-injection engine (.claude/hooks/synapse-engine.cjs) reads this on every
|
|
4
|
+
# UserPromptSubmit to know which domains exist and how each fires. Managed kernel file.
|
|
5
|
+
#
|
|
6
|
+
# Per-domain keys:
|
|
7
|
+
# <DOMAIN>_STATE=active|inactive — a domain is only ever loaded when active.
|
|
8
|
+
# <DOMAIN>_ALWAYS_ON=true — load on every prompt (L0/L1).
|
|
9
|
+
# <DOMAIN>_RECALL=word1,word2,... — load only when a trigger word appears in the prompt (L6).
|
|
10
|
+
# A domain's rules live in the sibling file .synapse/<domain> (lowercased), as <DOMAIN>_RULE_N=...
|
|
11
|
+
# The CONSTITUTION domain is special: its body is sourced from .claude/constitution.md, not a domain file.
|
|
12
|
+
|
|
13
|
+
# L0 — Constitution (NON-NEGOTIABLE). Always; never trimmed by the budget governor.
|
|
14
|
+
CONSTITUTION_STATE=active
|
|
15
|
+
CONSTITUTION_ALWAYS_ON=true
|
|
16
|
+
|
|
17
|
+
# L1 — Global operational invariants. Always-on.
|
|
18
|
+
GLOBAL_STATE=active
|
|
19
|
+
GLOBAL_ALWAYS_ON=true
|
|
20
|
+
|
|
21
|
+
# L1 — Pipeline routing (the unified-dev build route). Always-on.
|
|
22
|
+
PIPELINE_STATE=active
|
|
23
|
+
PIPELINE_ALWAYS_ON=true
|
|
24
|
+
|
|
25
|
+
# L6 — Keyword-recall. Loads .synapse/routing only when a trigger word appears in the prompt.
|
|
26
|
+
# The domain file is SEEDED (operator-owned); this registry line is managed.
|
|
27
|
+
ROUTING_STATE=active
|
|
28
|
+
ROUTING_RECALL=deploy,worktree,push,pull request,release,new project,issue
|
|
29
|
+
|
|
30
|
+
# Budget governor — ceiling (in tokens) on the TRIMMABLE sections (everything except the
|
|
31
|
+
# Constitution, which is always kept). Over-budget sections are dropped lowest-priority-first
|
|
32
|
+
# with a visible [SYNAPSE-RULES-TRIM] marker. Override with WRXN_RULES_BUDGET.
|
|
33
|
+
RULES_BUDGET_TOKENS=600
|
|
34
|
+
|
|
35
|
+
# Forced-handoff threshold — fraction of the REAL model window consumed at which the engine injects
|
|
36
|
+
# the NON-BLOCKING [HANDOFF REQUIRED] directive. The window is read from ~/.claude.json ([1m] tag ⇒
|
|
37
|
+
# 1M else 200k); resident tokens from the transcript's last assistant usage. Override WRXN_HANDOFF_PCT.
|
|
38
|
+
HANDOFF_PCT=0.40
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
# Domain: pipeline (L1) — the unified-dev build route. Always-on. Managed kernel file.
|
|
2
|
+
PIPELINE_RULE_0=The default build route is unified-dev: grill -> research -> prototype -> PRD -> issues -> verticality review -> tdd -> code review -> security review -> QA-walk -> operator accepts.
|
|
3
|
+
PIPELINE_RULE_1=The HITL spine (grill, PRD, issues, accept) runs in the main conversation; the build/review/security/QA-walk executors run as isolated subagents.
|
|
4
|
+
PIPELINE_RULE_2=Scale the front half to the task — a clear, scoped, low-novelty change thins it (grill -> PRD -> issues -> build); a net-new or unclear-approach change runs the full front half.
|
|
5
|
+
PIPELINE_RULE_3=An issue is ready-for-agent only after the verticality-review gate passes (no horizontal, not-demoable, too-coarse, or dependency-error slices).
|
|
6
|
+
PIPELINE_RULE_4=Each AFK executor reads and follows the actual skill file for its phase (tdd, qa-walk, triage) — never a paraphrase of the loop.
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
# Domain: routing (L6 keyword-recall) — fires only when a trigger word appears in the prompt.
|
|
2
|
+
# SEEDED: operator-owned, created once at init, never overwritten on `wrxn update`. This is the
|
|
3
|
+
# representative keyword domain — add your own recall rules here, or register more domains in
|
|
4
|
+
# .synapse/manifest with a <DOMAIN>_RECALL=word1,word2 line and a sibling .synapse/<domain> file.
|
|
5
|
+
ROUTING_RULE_0=git push, PR creation, and release tags go through the devops role only — delegate, never run them directly.
|
|
6
|
+
ROUTING_RULE_1=A new project is a git worktree (e.g. `wrxn init --project` under projects/<slug>), never a bare mkdir.
|
|
7
|
+
ROUTING_RULE_2=Deploys: the first `vercel deploy` auto-promotes to production — confirm intent before shipping.
|
|
8
|
+
ROUTING_RULE_3=An issue is the unit of work; cut vertical tracer-bullet slices, each independently buildable and walkable.
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|