tribunal-kit 4.0.0 → 4.2.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 (108) hide show
  1. package/.agent/GEMINI.md +4 -2
  2. package/.agent/agents/api-architect.md +66 -0
  3. package/.agent/agents/db-latency-auditor.md +216 -0
  4. package/.agent/agents/precedence-reviewer.md +41 -4
  5. package/.agent/agents/resilience-reviewer.md +88 -0
  6. package/.agent/agents/schema-reviewer.md +67 -0
  7. package/.agent/agents/throughput-optimizer.md +299 -0
  8. package/.agent/agents/vitals-reviewer.md +223 -0
  9. package/.agent/history/case-law/cases/case-0001.json +33 -0
  10. package/.agent/history/case-law/index.json +35 -0
  11. package/.agent/rules/GEMINI.md +20 -3
  12. package/.agent/scripts/case_law_manager.py +237 -7
  13. package/.agent/skills/agent-organizer/SKILL.md +42 -0
  14. package/.agent/skills/agentic-patterns/SKILL.md +42 -0
  15. package/.agent/skills/ai-prompt-injection-defense/SKILL.md +42 -0
  16. package/.agent/skills/api-patterns/SKILL.md +42 -0
  17. package/.agent/skills/api-security-auditor/SKILL.md +42 -0
  18. package/.agent/skills/app-builder/SKILL.md +42 -0
  19. package/.agent/skills/app-builder/templates/SKILL.md +70 -0
  20. package/.agent/skills/appflow-wireframe/SKILL.md +42 -0
  21. package/.agent/skills/architecture/SKILL.md +42 -0
  22. package/.agent/skills/authentication-best-practices/SKILL.md +42 -0
  23. package/.agent/skills/bash-linux/SKILL.md +42 -0
  24. package/.agent/skills/behavioral-modes/SKILL.md +42 -0
  25. package/.agent/skills/brainstorming/SKILL.md +42 -0
  26. package/.agent/skills/building-native-ui/SKILL.md +42 -0
  27. package/.agent/skills/clean-code/SKILL.md +42 -0
  28. package/.agent/skills/code-review-checklist/SKILL.md +42 -0
  29. package/.agent/skills/config-validator/SKILL.md +42 -0
  30. package/.agent/skills/csharp-developer/SKILL.md +42 -0
  31. package/.agent/skills/data-validation-schemas/SKILL.md +320 -0
  32. package/.agent/skills/database-design/SKILL.md +42 -0
  33. package/.agent/skills/deployment-procedures/SKILL.md +42 -0
  34. package/.agent/skills/devops-engineer/SKILL.md +42 -0
  35. package/.agent/skills/devops-incident-responder/SKILL.md +42 -0
  36. package/.agent/skills/documentation-templates/SKILL.md +42 -0
  37. package/.agent/skills/edge-computing/SKILL.md +42 -0
  38. package/.agent/skills/error-resilience/SKILL.md +420 -0
  39. package/.agent/skills/extract-design-system/SKILL.md +42 -0
  40. package/.agent/skills/framer-motion-expert/SKILL.md +42 -0
  41. package/.agent/skills/frontend-design/SKILL.md +42 -0
  42. package/.agent/skills/game-design-expert/SKILL.md +42 -0
  43. package/.agent/skills/game-engineering-expert/SKILL.md +42 -0
  44. package/.agent/skills/geo-fundamentals/SKILL.md +42 -0
  45. package/.agent/skills/github-operations/SKILL.md +42 -0
  46. package/.agent/skills/gsap-core/SKILL.md +302 -0
  47. package/.agent/skills/gsap-frameworks/SKILL.md +201 -0
  48. package/.agent/skills/gsap-performance/SKILL.md +127 -0
  49. package/.agent/skills/gsap-plugins/SKILL.md +474 -0
  50. package/.agent/skills/gsap-react/SKILL.md +183 -0
  51. package/.agent/skills/gsap-scrolltrigger/SKILL.md +344 -0
  52. package/.agent/skills/gsap-timeline/SKILL.md +155 -0
  53. package/.agent/skills/gsap-utils/SKILL.md +332 -0
  54. package/.agent/skills/i18n-localization/SKILL.md +42 -0
  55. package/.agent/skills/intelligent-routing/SKILL.md +72 -1
  56. package/.agent/skills/lint-and-validate/SKILL.md +42 -0
  57. package/.agent/skills/llm-engineering/SKILL.md +42 -0
  58. package/.agent/skills/local-first/SKILL.md +42 -0
  59. package/.agent/skills/mcp-builder/SKILL.md +42 -0
  60. package/.agent/skills/mobile-design/SKILL.md +42 -0
  61. package/.agent/skills/monorepo-management/SKILL.md +326 -0
  62. package/.agent/skills/motion-engineering/SKILL.md +42 -0
  63. package/.agent/skills/nextjs-react-expert/SKILL.md +42 -0
  64. package/.agent/skills/nodejs-best-practices/SKILL.md +42 -0
  65. package/.agent/skills/observability/SKILL.md +42 -0
  66. package/.agent/skills/parallel-agents/SKILL.md +42 -0
  67. package/.agent/skills/performance-profiling/SKILL.md +42 -0
  68. package/.agent/skills/plan-writing/SKILL.md +42 -0
  69. package/.agent/skills/platform-engineer/SKILL.md +42 -0
  70. package/.agent/skills/playwright-best-practices/SKILL.md +42 -0
  71. package/.agent/skills/powershell-windows/SKILL.md +42 -0
  72. package/.agent/skills/project-idioms/SKILL.md +42 -0
  73. package/.agent/skills/python-patterns/SKILL.md +42 -0
  74. package/.agent/skills/python-pro/SKILL.md +42 -0
  75. package/.agent/skills/react-specialist/SKILL.md +42 -0
  76. package/.agent/skills/readme-builder/SKILL.md +42 -0
  77. package/.agent/skills/realtime-patterns/SKILL.md +42 -0
  78. package/.agent/skills/red-team-tactics/SKILL.md +42 -0
  79. package/.agent/skills/rust-pro/SKILL.md +42 -0
  80. package/.agent/skills/seo-fundamentals/SKILL.md +42 -0
  81. package/.agent/skills/server-management/SKILL.md +42 -0
  82. package/.agent/skills/shadcn-ui-expert/SKILL.md +42 -0
  83. package/.agent/skills/skill-creator/SKILL.md +42 -0
  84. package/.agent/skills/sql-pro/SKILL.md +42 -0
  85. package/.agent/skills/supabase-postgres-best-practices/SKILL.md +42 -0
  86. package/.agent/skills/swiftui-expert/SKILL.md +42 -0
  87. package/.agent/skills/systematic-debugging/SKILL.md +42 -0
  88. package/.agent/skills/tailwind-patterns/SKILL.md +42 -0
  89. package/.agent/skills/tdd-workflow/SKILL.md +42 -0
  90. package/.agent/skills/test-result-analyzer/SKILL.md +42 -0
  91. package/.agent/skills/testing-patterns/SKILL.md +42 -0
  92. package/.agent/skills/trend-researcher/SKILL.md +42 -0
  93. package/.agent/skills/typescript-advanced/SKILL.md +327 -0
  94. package/.agent/skills/ui-ux-pro-max/SKILL.md +42 -0
  95. package/.agent/skills/ui-ux-researcher/SKILL.md +42 -0
  96. package/.agent/skills/vue-expert/SKILL.md +42 -0
  97. package/.agent/skills/vulnerability-scanner/SKILL.md +42 -0
  98. package/.agent/skills/web-accessibility-auditor/SKILL.md +42 -0
  99. package/.agent/skills/web-design-guidelines/SKILL.md +42 -0
  100. package/.agent/skills/webapp-testing/SKILL.md +42 -0
  101. package/.agent/skills/whimsy-injector/SKILL.md +42 -0
  102. package/.agent/skills/workflow-optimizer/SKILL.md +42 -0
  103. package/.agent/workflows/tribunal-backend.md +13 -2
  104. package/.agent/workflows/tribunal-full.md +15 -8
  105. package/.agent/workflows/tribunal-speed.md +183 -0
  106. package/bin/tribunal-kit.js +17 -10
  107. package/package.json +5 -2
  108. package/.agent/skills/gsap-expert/SKILL.md +0 -194
@@ -0,0 +1,327 @@
1
+ ---
2
+ name: typescript-advanced
3
+ description: Advanced TypeScript mastery. Generics with constraints, conditional types, mapped types, template literal types, the satisfies operator, discriminated unions, branded/nominal types, type-level programming, utility type internals, variance annotations, module augmentation, and declaration merging. Use when writing complex type definitions, building type-safe libraries, or solving "how do I type this?" problems.
4
+ allowed-tools: Read, Write, Edit, Glob, Grep
5
+ version: 1.0.0
6
+ last-updated: 2026-04-17
7
+ applies-to-model: gemini-2.5-pro, claude-3-7-sonnet
8
+ ---
9
+
10
+ ## Hallucination Traps (Read First)
11
+ - ❌ Using `as any` to silence type errors -> ✅ Fix the type; `as any` hides bugs that crash at runtime
12
+ - ❌ Using `interface` when `type` is needed (unions, mapped types) -> ✅ `type` for unions/intersections/mapped; `interface` for objects that may be extended
13
+ - ❌ Overcomplicating types — if a type takes 30 seconds to read, simplify it -> ✅ Types serve the developer, not the other way around
14
+
15
+ ---
16
+
17
+ # Advanced TypeScript — Type-Level Mastery
18
+
19
+ ---
20
+
21
+ ## Generics with Constraints
22
+
23
+ ```typescript
24
+ // ✅ Constrained generics — T must have an id
25
+ function findById<T extends { id: string }>(items: T[], id: string): T | undefined {
26
+ return items.find((item) => item.id === id);
27
+ }
28
+
29
+ // ✅ Multiple constraints
30
+ function merge<T extends object, U extends object>(a: T, b: U): T & U {
31
+ return { ...a, ...b };
32
+ }
33
+
34
+ // ✅ keyof constraint — K must be a key of T
35
+ function getProperty<T, K extends keyof T>(obj: T, key: K): T[K] {
36
+ return obj[key];
37
+ }
38
+
39
+ const user = { name: "Alice", age: 30 };
40
+ const name = getProperty(user, "name"); // type: string
41
+ const age = getProperty(user, "age"); // type: number
42
+ // getProperty(user, "email"); // ❌ Compile error — "email" not in keyof
43
+
44
+ // ✅ Default generic parameters
45
+ function createState<T = string>(initial: T): { value: T; set: (v: T) => void } {
46
+ let value = initial;
47
+ return { value, set: (v) => { value = v; } };
48
+ }
49
+ ```
50
+
51
+ ---
52
+
53
+ ## Discriminated Unions (The Most Useful Pattern)
54
+
55
+ ```typescript
56
+ // ✅ Tagged unions — TypeScript narrows automatically
57
+ type Result<T, E = Error> =
58
+ | { success: true; data: T }
59
+ | { success: false; error: E };
60
+
61
+ function divide(a: number, b: number): Result<number, string> {
62
+ if (b === 0) return { success: false, error: "Division by zero" };
63
+ return { success: true, data: a / b };
64
+ }
65
+
66
+ const result = divide(10, 3);
67
+ if (result.success) {
68
+ console.log(result.data); // TypeScript KNOWS data exists
69
+ } else {
70
+ console.log(result.error); // TypeScript KNOWS error exists
71
+ }
72
+
73
+ // ✅ State machines with discriminated unions
74
+ type RequestState<T> =
75
+ | { status: "idle" }
76
+ | { status: "loading" }
77
+ | { status: "success"; data: T }
78
+ | { status: "error"; error: Error };
79
+
80
+ function renderUser(state: RequestState<User>) {
81
+ switch (state.status) {
82
+ case "idle": return <p>Click to load</p>;
83
+ case "loading": return <Spinner />;
84
+ case "success": return <UserCard user={state.data} />;
85
+ case "error": return <ErrorBanner error={state.error} />;
86
+ }
87
+ }
88
+ // ✅ TypeScript ensures ALL cases are handled (exhaustive checking)
89
+ ```
90
+
91
+ ---
92
+
93
+ ## Conditional Types
94
+
95
+ ```typescript
96
+ // ✅ Type-level if/else
97
+ type IsString<T> = T extends string ? true : false;
98
+
99
+ type A = IsString<"hello">; // true
100
+ type B = IsString<42>; // false
101
+
102
+ // ✅ Extract return type of async functions
103
+ type UnwrapPromise<T> = T extends Promise<infer U> ? U : T;
104
+
105
+ type UserData = UnwrapPromise<Promise<{ name: string }>>;
106
+ // → { name: string }
107
+
108
+ // ✅ Practical: API response type extraction
109
+ type ApiResponse<T> = T extends (...args: any[]) => Promise<infer R> ? R : never;
110
+
111
+ declare function getUsers(): Promise<User[]>;
112
+ type Users = ApiResponse<typeof getUsers>; // User[]
113
+
114
+ // ✅ Distributive conditional types
115
+ type NonNullable<T> = T extends null | undefined ? never : T;
116
+
117
+ type Clean = NonNullable<string | null | undefined>; // string
118
+ ```
119
+
120
+ ---
121
+
122
+ ## Mapped Types
123
+
124
+ ```typescript
125
+ // ✅ Transform every property of a type
126
+ type Readonly<T> = { readonly [K in keyof T]: T[K] };
127
+ type Partial<T> = { [K in keyof T]?: T[K] };
128
+ type Required<T> = { [K in keyof T]-?: T[K] };
129
+
130
+ // ✅ Practical: Create a "form touched" state
131
+ type TouchedFields<T> = { [K in keyof T]: boolean };
132
+
133
+ interface LoginForm {
134
+ email: string;
135
+ password: string;
136
+ }
137
+
138
+ type LoginTouched = TouchedFields<LoginForm>;
139
+ // → { email: boolean; password: boolean }
140
+
141
+ // ✅ Key remapping with `as`
142
+ type Getters<T> = {
143
+ [K in keyof T as `get${Capitalize<string & K>}`]: () => T[K];
144
+ };
145
+
146
+ type UserGetters = Getters<{ name: string; age: number }>;
147
+ // → { getName: () => string; getAge: () => number }
148
+
149
+ // ✅ Filter keys by value type
150
+ type StringKeys<T> = {
151
+ [K in keyof T as T[K] extends string ? K : never]: T[K];
152
+ };
153
+
154
+ type OnlyStrings = StringKeys<{ name: string; age: number; email: string }>;
155
+ // → { name: string; email: string }
156
+ ```
157
+
158
+ ---
159
+
160
+ ## Template Literal Types
161
+
162
+ ```typescript
163
+ // ✅ Type-safe string patterns
164
+ type HTTPMethod = "GET" | "POST" | "PUT" | "DELETE";
165
+ type APIRoute = `/api/${string}`;
166
+ type EventName = `on${Capitalize<string>}`;
167
+
168
+ // ✅ Practical: CSS unit types
169
+ type CSSUnit = "px" | "rem" | "em" | "vh" | "vw" | "%";
170
+ type CSSValue = `${number}${CSSUnit}`;
171
+
172
+ const width: CSSValue = "100px"; // ✅
173
+ // const bad: CSSValue = "100"; // ❌ Compile error
174
+
175
+ // ✅ Route parameter extraction
176
+ type ExtractParams<T extends string> =
177
+ T extends `${string}:${infer Param}/${infer Rest}`
178
+ ? Param | ExtractParams<Rest>
179
+ : T extends `${string}:${infer Param}`
180
+ ? Param
181
+ : never;
182
+
183
+ type UserRouteParams = ExtractParams<"/users/:userId/posts/:postId">;
184
+ // → "userId" | "postId"
185
+ ```
186
+
187
+ ---
188
+
189
+ ## The `satisfies` Operator (TS 5.0+)
190
+
191
+ ```typescript
192
+ // ✅ satisfies checks the type WITHOUT widening it
193
+ type ColorMap = Record<string, [number, number, number] | string>;
194
+
195
+ // With `as` — loses specificity
196
+ const colorsAs = {
197
+ red: [255, 0, 0],
198
+ green: "#00ff00",
199
+ } as ColorMap;
200
+ colorsAs.red.map(x => x); // ❌ Error: string | number[] has no .map
201
+
202
+ // With `satisfies` — keeps literal types
203
+ const colors = {
204
+ red: [255, 0, 0],
205
+ green: "#00ff00",
206
+ } satisfies ColorMap;
207
+ colors.red.map(x => x); // ✅ TypeScript knows it's a tuple
208
+ colors.green.toUpperCase(); // ✅ TypeScript knows it's a string
209
+ ```
210
+
211
+ ---
212
+
213
+ ## Branded / Nominal Types
214
+
215
+ ```typescript
216
+ // ✅ Prevent accidental mixing of same-shaped types
217
+ type UserId = string & { readonly __brand: "UserId" };
218
+ type OrderId = string & { readonly __brand: "OrderId" };
219
+
220
+ function createUserId(id: string): UserId { return id as UserId; }
221
+ function createOrderId(id: string): OrderId { return id as OrderId; }
222
+
223
+ function getUser(id: UserId): Promise<User> { ... }
224
+
225
+ const userId = createUserId("user_123");
226
+ const orderId = createOrderId("order_456");
227
+
228
+ getUser(userId); // ✅ Correct
229
+ // getUser(orderId); // ❌ Compile error — OrderId is not UserId
230
+
231
+ // ✅ Branded number types
232
+ type Cents = number & { readonly __brand: "Cents" };
233
+ type Dollars = number & { readonly __brand: "Dollars" };
234
+
235
+ function centsToDollars(cents: Cents): Dollars {
236
+ return (cents / 100) as Dollars;
237
+ }
238
+ ```
239
+
240
+ ---
241
+
242
+ ## Utility Types (Know the Built-ins)
243
+
244
+ ```typescript
245
+ // Don't reimplement what TypeScript provides
246
+
247
+ Pick<T, K> // Select specific keys
248
+ Omit<T, K> // Remove specific keys
249
+ Partial<T> // All properties optional
250
+ Required<T> // All properties required
251
+ Readonly<T> // All properties readonly
252
+ Record<K, V> // Object with keys K and values V
253
+ Extract<T, U> // Members of T assignable to U
254
+ Exclude<T, U> // Members of T NOT assignable to U
255
+ NonNullable<T> // Remove null and undefined
256
+ ReturnType<T> // Return type of a function
257
+ Parameters<T> // Parameter types of a function as tuple
258
+ Awaited<T> // Unwrap Promise<T> recursively
259
+ ```
260
+
261
+ ---
262
+
263
+ ## Anti-Patterns
264
+
265
+ ```
266
+ ❌ `as any` — hides runtime crashes. Fix the type or use `as unknown as T` with a comment.
267
+ ❌ `// @ts-ignore` — use `// @ts-expect-error` with a reason comment instead.
268
+ ❌ `interface` for unions — interfaces can't express `A | B`. Use `type`.
269
+ ❌ Overusing generics — if <T> is only used once, you probably don't need it.
270
+ ❌ `enum` for new code — use `as const` objects or union types instead.
271
+ ❌ Type assertions in tests — use proper type guards or schema validation.
272
+ ❌ `!` (non-null assertion) — it's a lie. Use optional chaining or narrowing.
273
+ ```
274
+
275
+ ```typescript
276
+ // ❌ BAD: Non-null assertion
277
+ const element = document.getElementById("app")!;
278
+
279
+ // ✅ GOOD: Narrowing
280
+ const element = document.getElementById("app");
281
+ if (!element) throw new Error("Missing #app element");
282
+ // element is now guaranteed non-null
283
+ ```
284
+
285
+ ---
286
+
287
+
288
+ ---
289
+
290
+ ## 🤖 LLM-Specific Traps
291
+
292
+ AI coding assistants often fall into specific bad habits when dealing with this domain. These are strictly forbidden:
293
+
294
+ 1. **Over-engineering:** Proposing complex abstractions or distributed systems when a simpler approach suffices.
295
+ 2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
296
+ 3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
297
+ 4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
298
+ 5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
299
+
300
+ ---
301
+
302
+ ## 🏛️ Tribunal Integration (Anti-Hallucination)
303
+
304
+ **Slash command: `/review` or `/tribunal-full`**
305
+ **Active reviewers: `logic-reviewer` · `security-auditor`**
306
+
307
+ ### ❌ Forbidden AI Tropes
308
+
309
+ 1. **Blind Assumptions:** Never make an assumption without documenting it clearly with `// VERIFY: [reason]`.
310
+ 2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
311
+ 3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
312
+
313
+ ### ✅ Pre-Flight Self-Audit
314
+
315
+ Review these questions before confirming output:
316
+ ```
317
+ ✅ Did I rely ONLY on real, verified tools and methods?
318
+ ✅ Is this solution appropriately scoped to the user's constraints?
319
+ ✅ Did I handle potential failure modes and edge cases?
320
+ ✅ Have I avoided generic boilerplate that doesn't add value?
321
+ ```
322
+
323
+ ### 🛑 Verification-Before-Completion (VBC) Protocol
324
+
325
+ **CRITICAL:** You must follow a strict "evidence-based closeout" state machine.
326
+ - ❌ **Forbidden:** Declaring a task complete because the output "looks correct."
327
+ - ✅ **Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.
@@ -73,3 +73,45 @@ Pre-Flight: ✅ All checks passed
73
73
  ```
74
74
 
75
75
  ---
76
+
77
+
78
+ ---
79
+
80
+ ## 🤖 LLM-Specific Traps
81
+
82
+ AI coding assistants often fall into specific bad habits when dealing with this domain. These are strictly forbidden:
83
+
84
+ 1. **Over-engineering:** Proposing complex abstractions or distributed systems when a simpler approach suffices.
85
+ 2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
86
+ 3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
87
+ 4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
88
+ 5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
89
+
90
+ ---
91
+
92
+ ## 🏛️ Tribunal Integration (Anti-Hallucination)
93
+
94
+ **Slash command: `/review` or `/tribunal-full`**
95
+ **Active reviewers: `logic-reviewer` · `security-auditor`**
96
+
97
+ ### ❌ Forbidden AI Tropes
98
+
99
+ 1. **Blind Assumptions:** Never make an assumption without documenting it clearly with `// VERIFY: [reason]`.
100
+ 2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
101
+ 3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
102
+
103
+ ### ✅ Pre-Flight Self-Audit
104
+
105
+ Review these questions before confirming output:
106
+ ```
107
+ ✅ Did I rely ONLY on real, verified tools and methods?
108
+ ✅ Is this solution appropriately scoped to the user's constraints?
109
+ ✅ Did I handle potential failure modes and edge cases?
110
+ ✅ Have I avoided generic boilerplate that doesn't add value?
111
+ ```
112
+
113
+ ### 🛑 Verification-Before-Completion (VBC) Protocol
114
+
115
+ **CRITICAL:** You must follow a strict "evidence-based closeout" state machine.
116
+ - ❌ **Forbidden:** Declaring a task complete because the output "looks correct."
117
+ - ✅ **Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.
@@ -192,3 +192,45 @@ Used as the theoretical backbone for P1 checks:
192
192
  - **Do not invent file paths or line numbers** — only reference code that has been read.
193
193
 
194
194
  ---
195
+
196
+
197
+ ---
198
+
199
+ ## 🤖 LLM-Specific Traps
200
+
201
+ AI coding assistants often fall into specific bad habits when dealing with this domain. These are strictly forbidden:
202
+
203
+ 1. **Over-engineering:** Proposing complex abstractions or distributed systems when a simpler approach suffices.
204
+ 2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
205
+ 3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
206
+ 4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
207
+ 5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
208
+
209
+ ---
210
+
211
+ ## 🏛️ Tribunal Integration (Anti-Hallucination)
212
+
213
+ **Slash command: `/review` or `/tribunal-full`**
214
+ **Active reviewers: `logic-reviewer` · `security-auditor`**
215
+
216
+ ### ❌ Forbidden AI Tropes
217
+
218
+ 1. **Blind Assumptions:** Never make an assumption without documenting it clearly with `// VERIFY: [reason]`.
219
+ 2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
220
+ 3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
221
+
222
+ ### ✅ Pre-Flight Self-Audit
223
+
224
+ Review these questions before confirming output:
225
+ ```
226
+ ✅ Did I rely ONLY on real, verified tools and methods?
227
+ ✅ Is this solution appropriately scoped to the user's constraints?
228
+ ✅ Did I handle potential failure modes and edge cases?
229
+ ✅ Have I avoided generic boilerplate that doesn't add value?
230
+ ```
231
+
232
+ ### 🛑 Verification-Before-Completion (VBC) Protocol
233
+
234
+ **CRITICAL:** You must follow a strict "evidence-based closeout" state machine.
235
+ - ❌ **Forbidden:** Declaring a task complete because the output "looks correct."
236
+ - ✅ **Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.
@@ -223,3 +223,45 @@ const { data, error, refresh } = await useFetch(`/api/users/${id}`, {
223
223
  - ✅ `:key` on `<component :is>` forces re-mount on route change (prevents stale state)
224
224
  - ❌ Avoid deeply nested reactive objects — use `shallowRef`/`shallowReactive` for large data
225
225
  - ❌ Never mutate props — emit events instead
226
+
227
+
228
+ ---
229
+
230
+ ## 🤖 LLM-Specific Traps
231
+
232
+ AI coding assistants often fall into specific bad habits when dealing with this domain. These are strictly forbidden:
233
+
234
+ 1. **Over-engineering:** Proposing complex abstractions or distributed systems when a simpler approach suffices.
235
+ 2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
236
+ 3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
237
+ 4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
238
+ 5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
239
+
240
+ ---
241
+
242
+ ## 🏛️ Tribunal Integration (Anti-Hallucination)
243
+
244
+ **Slash command: `/review` or `/tribunal-full`**
245
+ **Active reviewers: `logic-reviewer` · `security-auditor`**
246
+
247
+ ### ❌ Forbidden AI Tropes
248
+
249
+ 1. **Blind Assumptions:** Never make an assumption without documenting it clearly with `// VERIFY: [reason]`.
250
+ 2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
251
+ 3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
252
+
253
+ ### ✅ Pre-Flight Self-Audit
254
+
255
+ Review these questions before confirming output:
256
+ ```
257
+ ✅ Did I rely ONLY on real, verified tools and methods?
258
+ ✅ Is this solution appropriately scoped to the user's constraints?
259
+ ✅ Did I handle potential failure modes and edge cases?
260
+ ✅ Have I avoided generic boilerplate that doesn't add value?
261
+ ```
262
+
263
+ ### 🛑 Verification-Before-Completion (VBC) Protocol
264
+
265
+ **CRITICAL:** You must follow a strict "evidence-based closeout" state machine.
266
+ - ❌ **Forbidden:** Declaring a task complete because the output "looks correct."
267
+ - ✅ **Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.
@@ -352,3 +352,45 @@ If a secret is committed:
352
352
  ---
353
353
 
354
354
  **Usage:** Copy relevant checklists into your PLAN.md or security report.
355
+
356
+
357
+ ---
358
+
359
+ ## 🤖 LLM-Specific Traps
360
+
361
+ AI coding assistants often fall into specific bad habits when dealing with this domain. These are strictly forbidden:
362
+
363
+ 1. **Over-engineering:** Proposing complex abstractions or distributed systems when a simpler approach suffices.
364
+ 2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
365
+ 3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
366
+ 4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
367
+ 5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
368
+
369
+ ---
370
+
371
+ ## 🏛️ Tribunal Integration (Anti-Hallucination)
372
+
373
+ **Slash command: `/review` or `/tribunal-full`**
374
+ **Active reviewers: `logic-reviewer` · `security-auditor`**
375
+
376
+ ### ❌ Forbidden AI Tropes
377
+
378
+ 1. **Blind Assumptions:** Never make an assumption without documenting it clearly with `// VERIFY: [reason]`.
379
+ 2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
380
+ 3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
381
+
382
+ ### ✅ Pre-Flight Self-Audit
383
+
384
+ Review these questions before confirming output:
385
+ ```
386
+ ✅ Did I rely ONLY on real, verified tools and methods?
387
+ ✅ Is this solution appropriately scoped to the user's constraints?
388
+ ✅ Did I handle potential failure modes and edge cases?
389
+ ✅ Have I avoided generic boilerplate that doesn't add value?
390
+ ```
391
+
392
+ ### 🛑 Verification-Before-Completion (VBC) Protocol
393
+
394
+ **CRITICAL:** You must follow a strict "evidence-based closeout" state machine.
395
+ - ❌ **Forbidden:** Declaring a task complete because the output "looks correct."
396
+ - ✅ **Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.
@@ -166,3 +166,45 @@ When content changes dynamically without a page reload (e.g., Toast notification
166
166
  ```
167
167
 
168
168
  ---
169
+
170
+
171
+ ---
172
+
173
+ ## 🤖 LLM-Specific Traps
174
+
175
+ AI coding assistants often fall into specific bad habits when dealing with this domain. These are strictly forbidden:
176
+
177
+ 1. **Over-engineering:** Proposing complex abstractions or distributed systems when a simpler approach suffices.
178
+ 2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
179
+ 3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
180
+ 4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
181
+ 5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
182
+
183
+ ---
184
+
185
+ ## 🏛️ Tribunal Integration (Anti-Hallucination)
186
+
187
+ **Slash command: `/review` or `/tribunal-full`**
188
+ **Active reviewers: `logic-reviewer` · `security-auditor`**
189
+
190
+ ### ❌ Forbidden AI Tropes
191
+
192
+ 1. **Blind Assumptions:** Never make an assumption without documenting it clearly with `// VERIFY: [reason]`.
193
+ 2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
194
+ 3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
195
+
196
+ ### ✅ Pre-Flight Self-Audit
197
+
198
+ Review these questions before confirming output:
199
+ ```
200
+ ✅ Did I rely ONLY on real, verified tools and methods?
201
+ ✅ Is this solution appropriately scoped to the user's constraints?
202
+ ✅ Did I handle potential failure modes and edge cases?
203
+ ✅ Have I avoided generic boilerplate that doesn't add value?
204
+ ```
205
+
206
+ ### 🛑 Verification-Before-Completion (VBC) Protocol
207
+
208
+ **CRITICAL:** You must follow a strict "evidence-based closeout" state machine.
209
+ - ❌ **Forbidden:** Declaring a task complete because the output "looks correct."
210
+ - ✅ **Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.
@@ -134,3 +134,45 @@ Pre-Flight: ✅ All checks passed
134
134
  ```
135
135
 
136
136
  ---
137
+
138
+
139
+ ---
140
+
141
+ ## 🤖 LLM-Specific Traps
142
+
143
+ AI coding assistants often fall into specific bad habits when dealing with this domain. These are strictly forbidden:
144
+
145
+ 1. **Over-engineering:** Proposing complex abstractions or distributed systems when a simpler approach suffices.
146
+ 2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
147
+ 3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
148
+ 4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
149
+ 5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
150
+
151
+ ---
152
+
153
+ ## 🏛️ Tribunal Integration (Anti-Hallucination)
154
+
155
+ **Slash command: `/review` or `/tribunal-full`**
156
+ **Active reviewers: `logic-reviewer` · `security-auditor`**
157
+
158
+ ### ❌ Forbidden AI Tropes
159
+
160
+ 1. **Blind Assumptions:** Never make an assumption without documenting it clearly with `// VERIFY: [reason]`.
161
+ 2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
162
+ 3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
163
+
164
+ ### ✅ Pre-Flight Self-Audit
165
+
166
+ Review these questions before confirming output:
167
+ ```
168
+ ✅ Did I rely ONLY on real, verified tools and methods?
169
+ ✅ Is this solution appropriately scoped to the user's constraints?
170
+ ✅ Did I handle potential failure modes and edge cases?
171
+ ✅ Have I avoided generic boilerplate that doesn't add value?
172
+ ```
173
+
174
+ ### 🛑 Verification-Before-Completion (VBC) Protocol
175
+
176
+ **CRITICAL:** You must follow a strict "evidence-based closeout" state machine.
177
+ - ❌ **Forbidden:** Declaring a task complete because the output "looks correct."
178
+ - ✅ **Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.
@@ -117,3 +117,45 @@ describe('calculateTax()', () => {
117
117
  ```
118
118
 
119
119
  ---
120
+
121
+
122
+ ---
123
+
124
+ ## 🤖 LLM-Specific Traps
125
+
126
+ AI coding assistants often fall into specific bad habits when dealing with this domain. These are strictly forbidden:
127
+
128
+ 1. **Over-engineering:** Proposing complex abstractions or distributed systems when a simpler approach suffices.
129
+ 2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
130
+ 3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
131
+ 4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
132
+ 5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
133
+
134
+ ---
135
+
136
+ ## 🏛️ Tribunal Integration (Anti-Hallucination)
137
+
138
+ **Slash command: `/review` or `/tribunal-full`**
139
+ **Active reviewers: `logic-reviewer` · `security-auditor`**
140
+
141
+ ### ❌ Forbidden AI Tropes
142
+
143
+ 1. **Blind Assumptions:** Never make an assumption without documenting it clearly with `// VERIFY: [reason]`.
144
+ 2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
145
+ 3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
146
+
147
+ ### ✅ Pre-Flight Self-Audit
148
+
149
+ Review these questions before confirming output:
150
+ ```
151
+ ✅ Did I rely ONLY on real, verified tools and methods?
152
+ ✅ Is this solution appropriately scoped to the user's constraints?
153
+ ✅ Did I handle potential failure modes and edge cases?
154
+ ✅ Have I avoided generic boilerplate that doesn't add value?
155
+ ```
156
+
157
+ ### 🛑 Verification-Before-Completion (VBC) Protocol
158
+
159
+ **CRITICAL:** You must follow a strict "evidence-based closeout" state machine.
160
+ - ❌ **Forbidden:** Declaring a task complete because the output "looks correct."
161
+ - ✅ **Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.