Loading source
Pulling the file list, source metadata, and syntax-aware rendering for this listing.
Source from bundle
Triage GitHub/Jira/backlog issues through Matt Pocock’s label-driven state machine.
Files
Skill
Size
Entrypoint
Format
Open file
Syntax-highlighted preview of this file as included in the skill package.
OUT-OF-SCOPE.md
1# Out-of-Scope Knowledge Base23The `.out-of-scope/` directory in a repo stores persistent records of rejected feature requests. It serves two purposes:451. **Institutional memory** — why a feature was rejected, so the reasoning isn't lost when the issue is closed62. **Deduplication** — when a new issue comes in that matches a prior rejection, the skill can surface the previous decision instead of re-litigating it78## Directory structure910```11.out-of-scope/12├── dark-mode.md13├── plugin-system.md14└── graphql-api.md15```1617One file per **concept**, not per issue. Multiple issues requesting the same thing are grouped under one file.1819## File format2021The 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.2223```markdown24# Dark Mode2526This project does not support dark mode or user-facing theming.2728## Why this is out of scope2930The rendering pipeline assumes a single color palette defined in31`ThemeConfig`. Supporting multiple themes would require:3233- A theme context provider wrapping the entire component tree34- Per-component theme-aware style resolution35- A persistence layer for user theme preferences3637This is a significant architectural change that doesn't align with the38project's focus on content authoring. Theming is a concern for downstream39consumers who embed or redistribute the output.4041```ts42// The current ThemeConfig interface is not designed for runtime switching:43interface ThemeConfig {44colors: ColorPalette; // single palette, resolved at build time45fonts: FontStack;46}47```4849## Prior requests5051- #42 — "Add dark mode support"52- #87 — "Night theme for accessibility"53- #134 — "Dark theme option"54```5556### Naming the file5758Use 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.5960### Writing the reason6162The reason should be substantive — not "we don't want this" but why. Good reasons reference:6364- 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...")6768The reason should be durable. Avoid referencing temporary circumstances ("we're too busy right now") — those aren't real rejections, they're deferrals.6970## When to check `.out-of-scope/`7172During triage (Step 1: Gather context), read all files in `.out-of-scope/`. When evaluating a new issue:7374- Check if the request matches an existing out-of-scope concept75- 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?"7778The maintainer may:7980- **Confirm** — the new issue gets added to the existing file's "Prior requests" list, then closed81- **Reconsider** — the out-of-scope file gets deleted or updated, and the issue proceeds through normal triage82- **Disagree** — the issues are related but distinct, proceed with normal triage8384## When to write to `.out-of-scope/`8586Only when an **enhancement** (not a bug) is rejected as `wontfix`. The flow:87881. Maintainer decides a feature request is out of scope892. Check if a matching `.out-of-scope/` file already exists903. If yes: append the new issue to the "Prior requests" list914. If no: create a new file with the concept name, decision, reason, and first prior request925. Post a comment on the issue explaining the decision and mentioning the `.out-of-scope/` file936. Close the issue with the `wontfix` label9495## Updating or removing out-of-scope files9697If the maintainer changes their mind about a previously rejected concept:9899- Delete the `.out-of-scope/` file100- The skill does not need to reopen old issues — they're historical records101- The new issue that triggered the reconsideration proceeds through normal triage102