@gallop.software/canon 2.26.0 → 2.29.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.
@@ -1,11 +1,32 @@
1
1
  import * as fs from 'fs';
2
2
  import * as path from 'path';
3
3
  import { version, patterns, guarantees } from '../../index.js';
4
+ import { loadConfig } from '../config.js';
5
+ /**
6
+ * Detect output format from filename
7
+ */
8
+ function detectFormat(filename) {
9
+ const base = path.basename(filename).toLowerCase();
10
+ if (base === 'claude.md')
11
+ return 'claude';
12
+ if (base === 'copilot-instructions.md')
13
+ return 'copilot';
14
+ return 'cursorrules';
15
+ }
16
+ /**
17
+ * Get all output targets when generating all files
18
+ */
19
+ function getAllTargets() {
20
+ return [
21
+ { output: '.cursorrules', format: 'cursorrules' },
22
+ { output: 'CLAUDE.md', format: 'claude' },
23
+ { output: '.github/copilot-instructions.md', format: 'copilot' },
24
+ ];
25
+ }
4
26
  /**
5
27
  * Read a pattern markdown file and extract sections
6
28
  */
7
29
  function readPatternFile(patternFile) {
8
- // Try to find the canon package patterns directory
9
30
  const possiblePaths = [
10
31
  path.join(process.cwd(), 'node_modules/@gallop.software/canon', patternFile),
11
32
  // Fallback for development
@@ -24,7 +45,6 @@ function readPatternFile(patternFile) {
24
45
  function extractExamples(content) {
25
46
  const good = [];
26
47
  const bad = [];
27
- // Find code blocks after "### Good" or "### Bad" headers
28
48
  const goodMatch = content.match(/### Good\s*\n```[\s\S]*?```/g);
29
49
  const badMatch = content.match(/### Bad\s*\n```[\s\S]*?```/g);
30
50
  if (goodMatch) {
@@ -41,71 +61,105 @@ function extractExamples(content) {
41
61
  }
42
62
  return { good, bad };
43
63
  }
44
- /**
45
- * Generate .cursorrules content from Canon
46
- */
47
- function generateCursorrules() {
64
+ // ─── Shared section generators ────────────────────────────────────────────
65
+ function generateHeader(format) {
48
66
  const lines = [];
49
- // Header
50
- lines.push(`# Gallop Canon v${version} - AI Rules`);
51
- lines.push('');
52
- lines.push('This file is auto-generated from @gallop.software/canon. Do not edit manually.');
53
- lines.push('Regenerate with: npm run generate:ai-rules');
54
- lines.push('');
55
- // Tech stack (Canon-compatible templates)
56
- lines.push('## Tech Stack');
57
- lines.push('');
58
- lines.push('- Next.js 16 with App Router');
59
- lines.push('- React 19');
60
- lines.push('- TypeScript');
61
- lines.push('- Tailwind CSS v4');
62
- lines.push('- clsx for conditional class names');
67
+ if (format === 'claude') {
68
+ lines.push(`# CLAUDE.md Project-Specific Intelligence`);
69
+ lines.push('');
70
+ lines.push(`> Auto-generated from Gallop Canon v${version}. Do not edit manually.`);
71
+ lines.push(`> Regenerate with: npm run generate:ai-rules`);
72
+ }
73
+ else if (format === 'copilot') {
74
+ lines.push(`# Gallop Canon v${version} - Copilot Instructions`);
75
+ lines.push('');
76
+ lines.push('This file is auto-generated from @gallop.software/canon. Do not edit manually.');
77
+ lines.push('Regenerate with: npm run generate:ai-rules');
78
+ }
79
+ else {
80
+ lines.push(`# Gallop Canon v${version} - AI Rules`);
81
+ lines.push('');
82
+ lines.push('This file is auto-generated from @gallop.software/canon. Do not edit manually.');
83
+ lines.push('Regenerate with: npm run generate:ai-rules');
84
+ }
63
85
  lines.push('');
64
- // Enforced patterns (ESLint rules)
86
+ return lines;
87
+ }
88
+ function generateTechStack() {
89
+ return [
90
+ '## Tech Stack',
91
+ '',
92
+ '- Next.js 16 with App Router',
93
+ '- React 19',
94
+ '- TypeScript',
95
+ '- Tailwind CSS v4',
96
+ '- clsx for conditional class names',
97
+ '',
98
+ ];
99
+ }
100
+ function generateEnforcedPatterns(format) {
101
+ const lines = [];
102
+ const enforcedPatterns = patterns.filter(p => p.enforcement === 'eslint' && p.rule);
65
103
  lines.push('## Enforced Patterns (ESLint)');
66
104
  lines.push('');
67
105
  lines.push('These patterns are enforced by `@gallop.software/canon/eslint`. Violations will be flagged.');
68
106
  lines.push('');
69
- const enforcedPatterns = patterns.filter(p => p.enforcement === 'eslint' && p.rule);
70
- for (const pattern of enforcedPatterns) {
71
- lines.push(`### ${pattern.id}: ${pattern.title}`);
72
- lines.push('');
73
- lines.push(pattern.summary);
74
- lines.push('');
75
- lines.push(`- **ESLint Rule:** \`${pattern.rule}\``);
76
- lines.push(`- **Category:** ${pattern.category}`);
107
+ if (format === 'claude') {
108
+ // Claude can run lint — brief list with rule names
109
+ for (const pattern of enforcedPatterns) {
110
+ lines.push(`- **${pattern.id}: ${pattern.title}** — \`${pattern.rule}\` — ${pattern.summary}`);
111
+ }
77
112
  lines.push('');
78
- // Try to read and include examples
79
- const content = readPatternFile(pattern.file);
80
- if (content) {
81
- const { good, bad } = extractExamples(content);
82
- if (bad.length > 0) {
83
- lines.push('**Bad:**');
84
- lines.push('');
85
- lines.push(bad[0]);
86
- lines.push('');
87
- }
88
- if (good.length > 0) {
89
- lines.push('**Good:**');
90
- lines.push('');
91
- lines.push(good[0]);
92
- lines.push('');
113
+ }
114
+ else {
115
+ // Cursorrules and Copilot: full examples
116
+ for (const pattern of enforcedPatterns) {
117
+ lines.push(`### ${pattern.id}: ${pattern.title}`);
118
+ lines.push('');
119
+ lines.push(pattern.summary);
120
+ lines.push('');
121
+ lines.push(`- **ESLint Rule:** \`${pattern.rule}\``);
122
+ lines.push(`- **Category:** ${pattern.category}`);
123
+ lines.push('');
124
+ if (format === 'cursorrules') {
125
+ const content = readPatternFile(pattern.file);
126
+ if (content) {
127
+ const { good, bad } = extractExamples(content);
128
+ if (bad.length > 0) {
129
+ lines.push('**Bad:**');
130
+ lines.push('');
131
+ lines.push(bad[0]);
132
+ lines.push('');
133
+ }
134
+ if (good.length > 0) {
135
+ lines.push('**Good:**');
136
+ lines.push('');
137
+ lines.push(good[0]);
138
+ lines.push('');
139
+ }
140
+ }
93
141
  }
94
142
  }
95
143
  }
96
- // Documentation patterns
144
+ return lines;
145
+ }
146
+ function generateDocPatterns() {
147
+ const lines = [];
148
+ const docPatterns = patterns.filter(p => p.enforcement === 'documentation');
97
149
  lines.push('## Documentation Patterns');
98
150
  lines.push('');
99
151
  lines.push('These patterns are not enforced by ESLint but should be followed.');
100
152
  lines.push('');
101
- const docPatterns = patterns.filter(p => p.enforcement === 'documentation');
102
153
  for (const pattern of docPatterns) {
103
154
  lines.push(`### ${pattern.id}: ${pattern.title}`);
104
155
  lines.push('');
105
156
  lines.push(pattern.summary);
106
157
  lines.push('');
107
158
  }
108
- // Guarantees
159
+ return lines;
160
+ }
161
+ function generateGuarantees() {
162
+ const lines = [];
109
163
  lines.push('## Canon Guarantees');
110
164
  lines.push('');
111
165
  lines.push('Following these patterns provides these guarantees:');
@@ -114,37 +168,67 @@ function generateCursorrules() {
114
168
  lines.push(`- **${guarantee.name}** (${guarantee.id}): Patterns ${guarantee.patterns.join(', ')}`);
115
169
  }
116
170
  lines.push('');
117
- // Quick reference for components
171
+ return lines;
172
+ }
173
+ function generateComponentReference(config) {
174
+ const lines = [];
118
175
  lines.push('## Component Quick Reference');
119
176
  lines.push('');
120
- lines.push('### Typography');
121
- lines.push('- `Heading` - props: `as`, `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`');
122
- lines.push('- `Paragraph` - props: `color`, `margin`, `fontSize`, `lineHeight`, `textAlign`');
123
- lines.push('- `Span` - props: `color`, `margin`, `fontSize` (inline text, mb-0 default)');
124
- lines.push('- `Label` - props: `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`');
125
- lines.push('- `Quote` - props: `variant`, `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`');
126
- lines.push('');
127
- lines.push('### Layout');
128
- lines.push('- `Section` - semantic section wrapper');
129
- lines.push('- `Columns` - grid layout, props: `cols`, `gap`, `align`');
130
- lines.push('- `Column` - column child');
131
- lines.push('');
132
- lines.push('### Interactive');
133
- lines.push('- `Button` - props: `href`, `variant`, `icon`, `iconPlacement`, `margin`');
134
- lines.push('- `Icon` - Iconify icon wrapper');
177
+ if (config?.components?.length) {
178
+ for (const comp of config.components) {
179
+ const propsStr = comp.props?.length ? ` - props: ${comp.props.map(p => `\`${p}\``).join(', ')}` : '';
180
+ const noteStr = comp.notes ? ` (${comp.notes})` : '';
181
+ lines.push(`- \`${comp.name}\`${propsStr}${noteStr}`);
182
+ }
183
+ }
184
+ else {
185
+ // Fallback: hardcoded component list
186
+ lines.push('### Typography');
187
+ lines.push('- `Heading` - props: `as`, `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`');
188
+ lines.push('- `Paragraph` - props: `color`, `margin`, `fontSize`, `lineHeight`, `textAlign`');
189
+ lines.push('- `Span` - props: `color`, `margin`, `fontSize` (inline text, mb-0 default)');
190
+ lines.push('- `Label` - props: `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`');
191
+ lines.push('- `Quote` - props: `variant`, `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`');
192
+ lines.push('');
193
+ lines.push('### Layout');
194
+ lines.push('- `Section` - semantic section wrapper');
195
+ lines.push('- `Columns` - grid layout, props: `cols`, `gap`, `align`');
196
+ lines.push('- `Column` - column child');
197
+ lines.push('');
198
+ lines.push('### Interactive');
199
+ lines.push('- `Button` - props: `href`, `variant`, `icon`, `iconPlacement`, `margin`');
200
+ lines.push('- `Icon` - Iconify icon wrapper');
201
+ }
135
202
  lines.push('');
136
- // Do NOT section
203
+ return lines;
204
+ }
205
+ function generateDoNotSection(config) {
206
+ const lines = [];
137
207
  lines.push('## Do NOT');
138
208
  lines.push('');
139
- lines.push('- Use `\'use client\'` in blocks - extract to components');
140
- lines.push('- Use raw `<p>` or `<span>` - use Paragraph/Span components');
209
+ // Default rules always present
210
+ lines.push("- Use `'use client'` in blocks - extract to components");
211
+ lines.push('- Use raw `<p>`, `<span>`, or `<h1>`–`<h6>` - use Paragraph/Span/Heading components');
141
212
  lines.push('- Use className for margin/color/fontSize when component has props');
142
213
  lines.push('- Use Container inside Section - Section already provides containment');
143
214
  lines.push('- Use `classnames` package - use `clsx` instead');
144
215
  lines.push('- Use inline styles for hover states - use Tailwind classes');
145
216
  lines.push('- Use native `IntersectionObserver` - use `react-intersection-observer` package');
217
+ lines.push('- Use inline `<svg>` in blocks - use the Icon component with Iconify icons');
218
+ lines.push('- Use deep relative imports (`../../`) - use `@/` alias imports');
219
+ // Template-specific rules
220
+ if (config?.rules) {
221
+ for (const rule of config.rules) {
222
+ if (rule.type === 'doNot') {
223
+ lines.push(`- ${rule.rule}`);
224
+ }
225
+ }
226
+ }
146
227
  lines.push('');
147
- // File & Folder Authority section
228
+ return lines;
229
+ }
230
+ function generateFileAuthority() {
231
+ const lines = [];
148
232
  lines.push('## File & Folder Authority');
149
233
  lines.push('');
150
234
  lines.push('These rules govern what AI is allowed and forbidden to do when creating, moving, or modifying files and folders.');
@@ -220,29 +304,206 @@ function generateCursorrules() {
220
304
  lines.push('- Import from `_scripts/` or `_data/` in runtime code');
221
305
  lines.push('- Manually edit files in `_data/` (generated only)');
222
306
  lines.push('');
223
- // Post-edit verification
307
+ return lines;
308
+ }
309
+ function generateVerification(config) {
310
+ const lines = [];
224
311
  lines.push('## Post-Edit Verification');
225
312
  lines.push('');
226
313
  lines.push('After editing files:');
227
- lines.push('1. Run `npm run lint` to check for errors');
228
- lines.push('2. Fix any violations before committing');
314
+ if (config?.verification?.length) {
315
+ let step = 1;
316
+ for (const cmd of config.verification) {
317
+ lines.push(`${step}. Run \`${cmd}\``);
318
+ step++;
319
+ }
320
+ lines.push(`${step}. Fix any violations before committing`);
321
+ }
322
+ else {
323
+ lines.push('1. Run `npm run lint` to check for errors');
324
+ lines.push('2. Fix any violations before committing');
325
+ }
229
326
  lines.push('');
230
327
  lines.push('Note: Only lint files you edited, not the entire codebase.');
231
328
  lines.push('');
329
+ return lines;
330
+ }
331
+ // ─── Claude-specific sections ─────────────────────────────────────────────
332
+ function generateAutoGenFiles(config) {
333
+ if (!config?.generatedFiles?.length)
334
+ return [];
335
+ const lines = [];
336
+ lines.push('## Auto-Generated Files — Never Edit Manually');
337
+ lines.push('');
338
+ lines.push('| File | Regenerate With | Triggered By |');
339
+ lines.push('|---|---|---|');
340
+ for (const file of config.generatedFiles) {
341
+ lines.push(`| \`${file.path}\` | \`${file.command}\` | ${file.trigger} |`);
342
+ }
343
+ lines.push('');
344
+ return lines;
345
+ }
346
+ function generateBuildCommands(config) {
347
+ if (!config?.buildCommands?.length)
348
+ return [];
349
+ const lines = [];
350
+ lines.push('## Build Commands');
351
+ lines.push('');
352
+ lines.push('| Command | Purpose |');
353
+ lines.push('|---|---|');
354
+ for (const cmd of config.buildCommands) {
355
+ lines.push(`| \`${cmd.script}\` | ${cmd.description} |`);
356
+ }
357
+ lines.push('');
358
+ return lines;
359
+ }
360
+ function generateColorTokens(config) {
361
+ if (!config?.colorTokens)
362
+ return [];
363
+ const lines = [];
364
+ const ct = config.colorTokens;
365
+ lines.push('## Color Token System');
366
+ lines.push('');
367
+ lines.push('All colors use semantic tokens defined in `src/styles/tailwind.css` `@theme`:');
368
+ lines.push('');
369
+ if (ct.surface?.length) {
370
+ lines.push(`- **Surface**: ${ct.surface.map(s => `\`${s}\``).join(', ')}`);
371
+ }
372
+ if (ct.text?.length) {
373
+ lines.push(`- **Text**: ${ct.text.map(s => `\`${s}\``).join(', ')}`);
374
+ }
375
+ if (ct.overlay?.length) {
376
+ lines.push(`- **Overlay** (fixed — don't flip in dark mode): ${ct.overlay.map(s => `\`${s}\``).join(', ')}`);
377
+ }
378
+ if (ct.accents?.length) {
379
+ lines.push(`- **Accents**: ${ct.accents.map(s => `\`${s}\``).join(', ')}`);
380
+ }
381
+ lines.push('');
382
+ lines.push('**Never use**: `gray-*`, `white`, `black`, `slate-*` — always map to a semantic token.');
383
+ lines.push('');
384
+ return lines;
385
+ }
386
+ function generateStateManagement(config) {
387
+ if (!config?.state)
388
+ return [];
389
+ const lines = [];
390
+ const st = config.state;
391
+ lines.push('## State Management');
392
+ lines.push('');
393
+ lines.push(`${st.library} store at \`${st.file}\`. Read with \`${st.readPattern}\`, write with \`${st.writePattern}\`.`);
394
+ lines.push('');
395
+ if (st.properties?.length) {
396
+ lines.push(`Available state: ${st.properties.map(p => `\`${p}\``).join(', ')}.`);
397
+ lines.push('');
398
+ }
399
+ return lines;
400
+ }
401
+ function generateTemplateRules(config) {
402
+ if (!config?.rules?.length)
403
+ return [];
404
+ const doRules = config.rules.filter(r => r.type === 'do');
405
+ if (!doRules.length)
406
+ return [];
407
+ const lines = [];
408
+ lines.push('## Template-Specific Rules');
409
+ lines.push('');
410
+ for (const rule of doRules) {
411
+ lines.push(`- ${rule.rule}`);
412
+ }
413
+ lines.push('');
414
+ return lines;
415
+ }
416
+ // ─── Format generators ────────────────────────────────────────────────────
417
+ function generateCursorrules(config) {
418
+ const lines = [
419
+ ...generateHeader('cursorrules'),
420
+ ...generateTechStack(),
421
+ ...generateEnforcedPatterns('cursorrules'),
422
+ ...generateDocPatterns(),
423
+ ...generateGuarantees(),
424
+ ...generateComponentReference(config),
425
+ ...generateDoNotSection(config),
426
+ ...generateFileAuthority(),
427
+ ...generateVerification(config),
428
+ ];
232
429
  return lines.join('\n');
233
430
  }
431
+ function generateClaudeMd(config) {
432
+ const lines = [
433
+ ...generateHeader('claude'),
434
+ ...generateAutoGenFiles(config),
435
+ ...generateBuildCommands(config),
436
+ ...generateEnforcedPatterns('claude'),
437
+ ...generateDocPatterns(),
438
+ ...generateColorTokens(config),
439
+ ...generateComponentReference(config),
440
+ ...generateStateManagement(config),
441
+ ...generateTemplateRules(config),
442
+ ...generateDoNotSection(config),
443
+ ...generateVerification(config),
444
+ ];
445
+ return lines.join('\n');
446
+ }
447
+ function generateCopilotInstructions(config) {
448
+ const lines = [
449
+ ...generateHeader('copilot'),
450
+ ...generateTechStack(),
451
+ ...generateEnforcedPatterns('copilot'),
452
+ ...generateDocPatterns(),
453
+ ...generateComponentReference(config),
454
+ ...generateDoNotSection(config),
455
+ ...generateVerification(config),
456
+ ];
457
+ return lines.join('\n');
458
+ }
459
+ function generateContent(format, config) {
460
+ switch (format) {
461
+ case 'claude':
462
+ return generateClaudeMd(config);
463
+ case 'copilot':
464
+ return generateCopilotInstructions(config);
465
+ case 'cursorrules':
466
+ default:
467
+ return generateCursorrules(config);
468
+ }
469
+ }
470
+ function writeOutput(content, outputPath) {
471
+ const dir = path.dirname(outputPath);
472
+ if (!fs.existsSync(dir)) {
473
+ fs.mkdirSync(dir, { recursive: true });
474
+ }
475
+ fs.writeFileSync(outputPath, content, 'utf-8');
476
+ }
477
+ // ─── Public API ───────────────────────────────────────────────────────────
234
478
  export async function generate(options) {
235
- const content = generateCursorrules();
236
- if (options.output === '-') {
237
- // Output to stdout
479
+ const config = loadConfig();
480
+ if (options.output === 'all') {
481
+ // Generate all targets
482
+ const targets = getAllTargets();
483
+ for (const target of targets) {
484
+ const content = generateContent(target.format, config);
485
+ const outputPath = path.resolve(process.cwd(), target.output);
486
+ writeOutput(content, outputPath);
487
+ console.log(`✓ Generated ${target.output}`);
488
+ }
489
+ console.log(` Canon v${version} — ${patterns.length} patterns, ${guarantees.length} guarantees`);
490
+ if (config) {
491
+ console.log(` Template config: ${config.name}`);
492
+ }
493
+ }
494
+ else if (options.output === '-') {
495
+ const content = generateContent(options.format, config);
238
496
  console.log(content);
239
497
  }
240
498
  else {
241
- // Write to file
499
+ const content = generateContent(options.format, config);
242
500
  const outputPath = path.resolve(process.cwd(), options.output);
243
- fs.writeFileSync(outputPath, content, 'utf-8');
501
+ writeOutput(content, outputPath);
244
502
  console.log(`✓ Generated ${options.output} from Canon v${version}`);
245
503
  console.log(` ${patterns.length} patterns, ${guarantees.length} guarantees`);
504
+ if (config) {
505
+ console.log(` Template config: ${config.name}`);
506
+ }
246
507
  }
247
508
  }
248
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generate.js","sourceRoot":"","sources":["../../../src/cli/commands/generate.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs'\nimport * as path from 'path'\nimport { version, patterns, categories, guarantees } from '../../index.js'\n\ninterface GenerateOptions {\n  output: string\n  format: 'cursorrules' | 'markdown'\n}\n\n/**\n * Read a pattern markdown file and extract sections\n */\nfunction readPatternFile(patternFile: string): string | null {\n  // Try to find the canon package patterns directory\n  const possiblePaths = [\n    path.join(process.cwd(), 'node_modules/@gallop.software/canon', patternFile),\n    // Fallback for development\n    path.join(import.meta.dirname, '../../../', patternFile),\n  ]\n\n  for (const filePath of possiblePaths) {\n    if (fs.existsSync(filePath)) {\n      return fs.readFileSync(filePath, 'utf-8')\n    }\n  }\n\n  return null\n}\n\n/**\n * Extract examples from pattern markdown\n */\nfunction extractExamples(content: string): { good: string[]; bad: string[] } {\n  const good: string[] = []\n  const bad: string[] = []\n\n  // Find code blocks after \"### Good\" or \"### Bad\" headers\n  const goodMatch = content.match(/### Good\\s*\\n```[\\s\\S]*?```/g)\n  const badMatch = content.match(/### Bad\\s*\\n```[\\s\\S]*?```/g)\n\n  if (goodMatch) {\n    for (const match of goodMatch) {\n      const code = match.replace(/### Good\\s*\\n/, '').trim()\n      good.push(code)\n    }\n  }\n\n  if (badMatch) {\n    for (const match of badMatch) {\n      const code = match.replace(/### Bad\\s*\\n/, '').trim()\n      bad.push(code)\n    }\n  }\n\n  return { good, bad }\n}\n\n/**\n * Generate .cursorrules content from Canon\n */\nfunction generateCursorrules(): string {\n  const lines: string[] = []\n\n  // Header\n  lines.push(`# Gallop Canon v${version} - AI Rules`)\n  lines.push('')\n  lines.push('This file is auto-generated from @gallop.software/canon. Do not edit manually.')\n  lines.push('Regenerate with: npm run generate:ai-rules')\n  lines.push('')\n\n  // Tech stack (Canon-compatible templates)\n  lines.push('## Tech Stack')\n  lines.push('')\n  lines.push('- Next.js 16 with App Router')\n  lines.push('- React 19')\n  lines.push('- TypeScript')\n  lines.push('- Tailwind CSS v4')\n  lines.push('- clsx for conditional class names')\n  lines.push('')\n\n  // Enforced patterns (ESLint rules)\n  lines.push('## Enforced Patterns (ESLint)')\n  lines.push('')\n  lines.push('These patterns are enforced by `@gallop.software/canon/eslint`. Violations will be flagged.')\n  lines.push('')\n\n  const enforcedPatterns = patterns.filter(p => p.enforcement === 'eslint' && p.rule)\n  for (const pattern of enforcedPatterns) {\n    lines.push(`### ${pattern.id}: ${pattern.title}`)\n    lines.push('')\n    lines.push(pattern.summary)\n    lines.push('')\n    lines.push(`- **ESLint Rule:** \\`${pattern.rule}\\``)\n    lines.push(`- **Category:** ${pattern.category}`)\n    lines.push('')\n\n    // Try to read and include examples\n    const content = readPatternFile(pattern.file)\n    if (content) {\n      const { good, bad } = extractExamples(content)\n      if (bad.length > 0) {\n        lines.push('**Bad:**')\n        lines.push('')\n        lines.push(bad[0])\n        lines.push('')\n      }\n      if (good.length > 0) {\n        lines.push('**Good:**')\n        lines.push('')\n        lines.push(good[0])\n        lines.push('')\n      }\n    }\n  }\n\n  // Documentation patterns\n  lines.push('## Documentation Patterns')\n  lines.push('')\n  lines.push('These patterns are not enforced by ESLint but should be followed.')\n  lines.push('')\n\n  const docPatterns = patterns.filter(p => p.enforcement === 'documentation')\n  for (const pattern of docPatterns) {\n    lines.push(`### ${pattern.id}: ${pattern.title}`)\n    lines.push('')\n    lines.push(pattern.summary)\n    lines.push('')\n  }\n\n  // Guarantees\n  lines.push('## Canon Guarantees')\n  lines.push('')\n  lines.push('Following these patterns provides these guarantees:')\n  lines.push('')\n\n  for (const guarantee of guarantees) {\n    lines.push(`- **${guarantee.name}** (${guarantee.id}): Patterns ${guarantee.patterns.join(', ')}`)\n  }\n  lines.push('')\n\n  // Quick reference for components\n  lines.push('## Component Quick Reference')\n  lines.push('')\n  lines.push('### Typography')\n  lines.push('- `Heading` - props: `as`, `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`')\n  lines.push('- `Paragraph` - props: `color`, `margin`, `fontSize`, `lineHeight`, `textAlign`')\n  lines.push('- `Span` - props: `color`, `margin`, `fontSize` (inline text, mb-0 default)')\n  lines.push('- `Label` - props: `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`')\n  lines.push('- `Quote` - props: `variant`, `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`')\n  lines.push('')\n  lines.push('### Layout')\n  lines.push('- `Section` - semantic section wrapper')\n  lines.push('- `Columns` - grid layout, props: `cols`, `gap`, `align`')\n  lines.push('- `Column` - column child')\n  lines.push('')\n  lines.push('### Interactive')\n  lines.push('- `Button` - props: `href`, `variant`, `icon`, `iconPlacement`, `margin`')\n  lines.push('- `Icon` - Iconify icon wrapper')\n  lines.push('')\n\n  // Do NOT section\n  lines.push('## Do NOT')\n  lines.push('')\n  lines.push('- Use `\\'use client\\'` in blocks - extract to components')\n  lines.push('- Use raw `<p>` or `<span>` - use Paragraph/Span components')\n  lines.push('- Use className for margin/color/fontSize when component has props')\n  lines.push('- Use Container inside Section - Section already provides containment')\n  lines.push('- Use `classnames` package - use `clsx` instead')\n  lines.push('- Use inline styles for hover states - use Tailwind classes')\n  lines.push('- Use native `IntersectionObserver` - use `react-intersection-observer` package')\n  lines.push('')\n\n  // File & Folder Authority section\n  lines.push('## File & Folder Authority')\n  lines.push('')\n  lines.push('These rules govern what AI is allowed and forbidden to do when creating, moving, or modifying files and folders.')\n  lines.push('')\n\n  lines.push('### Defined `/src` Structure')\n  lines.push('')\n  lines.push('```')\n  lines.push('src/')\n  lines.push('├── app/          # Routes, layouts, metadata (Next.js App Router)')\n  lines.push('├── blocks/       # Page-level content sections')\n  lines.push('├── blog/         # Blog content (archive content type)')\n  lines.push('├── components/   # Reusable UI primitives')\n  lines.push('├── hooks/        # Custom React hooks')\n  lines.push('├── styles/       # CSS, Tailwind, fonts')\n  lines.push('├── template/     # Template-level components')\n  lines.push('├── tools/        # Utility tools')\n  lines.push('├── types/        # TypeScript types')\n  lines.push('├── utils/        # Utility functions')\n  lines.push('└── state.ts      # Global state')\n  lines.push('```')\n  lines.push('')\n\n  lines.push('### App Router Structure')\n  lines.push('')\n  lines.push('Routes must use Next.js route groups. At minimum, `(default)` must exist:')\n  lines.push('')\n  lines.push('```')\n  lines.push('src/app/')\n  lines.push('├── (default)/        # Required - default layout group')\n  lines.push('│   ├── layout.tsx')\n  lines.push('│   └── {routes}/')\n  lines.push('├── (hero)/           # Optional - hero layout variant')\n  lines.push('├── api/              # API routes (exception - no grouping)')\n  lines.push('├── layout.tsx        # Root layout')\n  lines.push('└── metadata.tsx      # Shared metadata')\n  lines.push('```')\n  lines.push('')\n  lines.push('- All page routes must be inside a route group (parentheses folder)')\n  lines.push('- Never create routes directly under `src/app/` (except `api/`, root files)')\n  lines.push('- New route groups are allowed freely when a new layout variant is needed')\n  lines.push('')\n\n  lines.push('### File Structure Rules')\n  lines.push('')\n  lines.push('**Blocks:**')\n  lines.push('- Always single files directly in `src/blocks/`')\n  lines.push('- Never create folders inside `src/blocks/`')\n  lines.push('- Example: `src/blocks/hero-1.tsx`, `src/blocks/testimonial-3.tsx`')\n  lines.push('')\n  lines.push('**Components:**')\n  lines.push('- Simple components: Single file in `src/components/`')\n  lines.push('- Complex components: Folder with `index.tsx`')\n  lines.push('- Use folders when component has multiple sub-files')\n  lines.push('')\n\n  lines.push('### DO - What AI IS Allowed To Do')\n  lines.push('')\n  lines.push('- Create files only inside existing Canon-defined zones')\n  lines.push('- Place new files in the zone that matches their architectural role')\n  lines.push('- Follow existing folder conventions within a zone')\n  lines.push('- Reuse existing folders when possible')\n  lines.push('- Create new route groups in `src/app/` when new layouts are needed')\n  lines.push('- Create new archive content folders (like `blog/`, `portfolio/`) in `/src`')\n  lines.push('- Create dotfiles/directories at project root (`.github/`, `.cursor/`, etc.)')\n  lines.push('- Ask for confirmation if the correct zone is ambiguous')\n  lines.push('')\n\n  lines.push('### DO NOT - What AI Is Forbidden To Do')\n  lines.push('')\n  lines.push('- Create new top-level directories (except dotfiles)')\n  lines.push('- Create new folders in `/src` (except archive content or route groups)')\n  lines.push('- Place files outside Canon-defined zones')\n  lines.push('- Mix responsibilities across zones (components importing blocks, etc.)')\n  lines.push('- Reorganize or move folders without explicit instruction')\n  lines.push('- Invent new organizational conventions')\n  lines.push('- Create placeholder or speculative files')\n  lines.push('- Import from `_scripts/` or `_data/` in runtime code')\n  lines.push('- Manually edit files in `_data/` (generated only)')\n  lines.push('')\n\n  // Post-edit verification\n  lines.push('## Post-Edit Verification')\n  lines.push('')\n  lines.push('After editing files:')\n  lines.push('1. Run `npm run lint` to check for errors')\n  lines.push('2. Fix any violations before committing')\n  lines.push('')\n  lines.push('Note: Only lint files you edited, not the entire codebase.')\n  lines.push('')\n\n  return lines.join('\\n')\n}\n\nexport async function generate(options: GenerateOptions): Promise<void> {\n  const content = generateCursorrules()\n\n  if (options.output === '-') {\n    // Output to stdout\n    console.log(content)\n  } else {\n    // Write to file\n    const outputPath = path.resolve(process.cwd(), options.output)\n    fs.writeFileSync(outputPath, content, 'utf-8')\n    console.log(`✓ Generated ${options.output} from Canon v${version}`)\n    console.log(`  ${patterns.length} patterns, ${guarantees.length} guarantees`)\n  }\n}\n"]}
509
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generate.js","sourceRoot":"","sources":["../../../src/cli/commands/generate.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs'\nimport * as path from 'path'\nimport { version, patterns, guarantees } from '../../index.js'\nimport { loadConfig } from '../config.js'\nimport type { CanonTemplateConfig } from '../../types/config.js'\n\ntype OutputFormat = 'cursorrules' | 'claude' | 'copilot'\n\ninterface GenerateOptions {\n  output: string\n  format: OutputFormat\n}\n\n/**\n * Detect output format from filename\n */\nfunction detectFormat(filename: string): OutputFormat {\n  const base = path.basename(filename).toLowerCase()\n  if (base === 'claude.md') return 'claude'\n  if (base === 'copilot-instructions.md') return 'copilot'\n  return 'cursorrules'\n}\n\n/**\n * Get all output targets when generating all files\n */\nfunction getAllTargets(): GenerateOptions[] {\n  return [\n    { output: '.cursorrules', format: 'cursorrules' },\n    { output: 'CLAUDE.md', format: 'claude' },\n    { output: '.github/copilot-instructions.md', format: 'copilot' },\n  ]\n}\n\n/**\n * Read a pattern markdown file and extract sections\n */\nfunction readPatternFile(patternFile: string): string | null {\n  const possiblePaths = [\n    path.join(process.cwd(), 'node_modules/@gallop.software/canon', patternFile),\n    // Fallback for development\n    path.join(import.meta.dirname, '../../../', patternFile),\n  ]\n\n  for (const filePath of possiblePaths) {\n    if (fs.existsSync(filePath)) {\n      return fs.readFileSync(filePath, 'utf-8')\n    }\n  }\n\n  return null\n}\n\n/**\n * Extract examples from pattern markdown\n */\nfunction extractExamples(content: string): { good: string[]; bad: string[] } {\n  const good: string[] = []\n  const bad: string[] = []\n\n  const goodMatch = content.match(/### Good\\s*\\n```[\\s\\S]*?```/g)\n  const badMatch = content.match(/### Bad\\s*\\n```[\\s\\S]*?```/g)\n\n  if (goodMatch) {\n    for (const match of goodMatch) {\n      const code = match.replace(/### Good\\s*\\n/, '').trim()\n      good.push(code)\n    }\n  }\n\n  if (badMatch) {\n    for (const match of badMatch) {\n      const code = match.replace(/### Bad\\s*\\n/, '').trim()\n      bad.push(code)\n    }\n  }\n\n  return { good, bad }\n}\n\n// ─── Shared section generators ────────────────────────────────────────────\n\nfunction generateHeader(format: OutputFormat): string[] {\n  const lines: string[] = []\n\n  if (format === 'claude') {\n    lines.push(`# CLAUDE.md — Project-Specific Intelligence`)\n    lines.push('')\n    lines.push(`> Auto-generated from Gallop Canon v${version}. Do not edit manually.`)\n    lines.push(`> Regenerate with: npm run generate:ai-rules`)\n  } else if (format === 'copilot') {\n    lines.push(`# Gallop Canon v${version} - Copilot Instructions`)\n    lines.push('')\n    lines.push('This file is auto-generated from @gallop.software/canon. Do not edit manually.')\n    lines.push('Regenerate with: npm run generate:ai-rules')\n  } else {\n    lines.push(`# Gallop Canon v${version} - AI Rules`)\n    lines.push('')\n    lines.push('This file is auto-generated from @gallop.software/canon. Do not edit manually.')\n    lines.push('Regenerate with: npm run generate:ai-rules')\n  }\n\n  lines.push('')\n  return lines\n}\n\nfunction generateTechStack(): string[] {\n  return [\n    '## Tech Stack',\n    '',\n    '- Next.js 16 with App Router',\n    '- React 19',\n    '- TypeScript',\n    '- Tailwind CSS v4',\n    '- clsx for conditional class names',\n    '',\n  ]\n}\n\nfunction generateEnforcedPatterns(format: OutputFormat): string[] {\n  const lines: string[] = []\n  const enforcedPatterns = patterns.filter(p => p.enforcement === 'eslint' && p.rule)\n\n  lines.push('## Enforced Patterns (ESLint)')\n  lines.push('')\n  lines.push('These patterns are enforced by `@gallop.software/canon/eslint`. Violations will be flagged.')\n  lines.push('')\n\n  if (format === 'claude') {\n    // Claude can run lint — brief list with rule names\n    for (const pattern of enforcedPatterns) {\n      lines.push(`- **${pattern.id}: ${pattern.title}** — \\`${pattern.rule}\\` — ${pattern.summary}`)\n    }\n    lines.push('')\n  } else {\n    // Cursorrules and Copilot: full examples\n    for (const pattern of enforcedPatterns) {\n      lines.push(`### ${pattern.id}: ${pattern.title}`)\n      lines.push('')\n      lines.push(pattern.summary)\n      lines.push('')\n      lines.push(`- **ESLint Rule:** \\`${pattern.rule}\\``)\n      lines.push(`- **Category:** ${pattern.category}`)\n      lines.push('')\n\n      if (format === 'cursorrules') {\n        const content = readPatternFile(pattern.file)\n        if (content) {\n          const { good, bad } = extractExamples(content)\n          if (bad.length > 0) {\n            lines.push('**Bad:**')\n            lines.push('')\n            lines.push(bad[0])\n            lines.push('')\n          }\n          if (good.length > 0) {\n            lines.push('**Good:**')\n            lines.push('')\n            lines.push(good[0])\n            lines.push('')\n          }\n        }\n      }\n    }\n  }\n\n  return lines\n}\n\nfunction generateDocPatterns(): string[] {\n  const lines: string[] = []\n  const docPatterns = patterns.filter(p => p.enforcement === 'documentation')\n\n  lines.push('## Documentation Patterns')\n  lines.push('')\n  lines.push('These patterns are not enforced by ESLint but should be followed.')\n  lines.push('')\n\n  for (const pattern of docPatterns) {\n    lines.push(`### ${pattern.id}: ${pattern.title}`)\n    lines.push('')\n    lines.push(pattern.summary)\n    lines.push('')\n  }\n\n  return lines\n}\n\nfunction generateGuarantees(): string[] {\n  const lines: string[] = []\n\n  lines.push('## Canon Guarantees')\n  lines.push('')\n  lines.push('Following these patterns provides these guarantees:')\n  lines.push('')\n\n  for (const guarantee of guarantees) {\n    lines.push(`- **${guarantee.name}** (${guarantee.id}): Patterns ${guarantee.patterns.join(', ')}`)\n  }\n  lines.push('')\n\n  return lines\n}\n\nfunction generateComponentReference(config: CanonTemplateConfig | null): string[] {\n  const lines: string[] = []\n\n  lines.push('## Component Quick Reference')\n  lines.push('')\n\n  if (config?.components?.length) {\n    for (const comp of config.components) {\n      const propsStr = comp.props?.length ? ` - props: ${comp.props.map(p => `\\`${p}\\``).join(', ')}` : ''\n      const noteStr = comp.notes ? ` (${comp.notes})` : ''\n      lines.push(`- \\`${comp.name}\\`${propsStr}${noteStr}`)\n    }\n  } else {\n    // Fallback: hardcoded component list\n    lines.push('### Typography')\n    lines.push('- `Heading` - props: `as`, `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`')\n    lines.push('- `Paragraph` - props: `color`, `margin`, `fontSize`, `lineHeight`, `textAlign`')\n    lines.push('- `Span` - props: `color`, `margin`, `fontSize` (inline text, mb-0 default)')\n    lines.push('- `Label` - props: `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`')\n    lines.push('- `Quote` - props: `variant`, `color`, `margin`, `fontSize`, `fontWeight`, `textAlign`')\n    lines.push('')\n    lines.push('### Layout')\n    lines.push('- `Section` - semantic section wrapper')\n    lines.push('- `Columns` - grid layout, props: `cols`, `gap`, `align`')\n    lines.push('- `Column` - column child')\n    lines.push('')\n    lines.push('### Interactive')\n    lines.push('- `Button` - props: `href`, `variant`, `icon`, `iconPlacement`, `margin`')\n    lines.push('- `Icon` - Iconify icon wrapper')\n  }\n\n  lines.push('')\n  return lines\n}\n\nfunction generateDoNotSection(config: CanonTemplateConfig | null): string[] {\n  const lines: string[] = []\n\n  lines.push('## Do NOT')\n  lines.push('')\n\n  // Default rules always present\n  lines.push(\"- Use `'use client'` in blocks - extract to components\")\n  lines.push('- Use raw `<p>`, `<span>`, or `<h1>`–`<h6>` - use Paragraph/Span/Heading components')\n  lines.push('- Use className for margin/color/fontSize when component has props')\n  lines.push('- Use Container inside Section - Section already provides containment')\n  lines.push('- Use `classnames` package - use `clsx` instead')\n  lines.push('- Use inline styles for hover states - use Tailwind classes')\n  lines.push('- Use native `IntersectionObserver` - use `react-intersection-observer` package')\n  lines.push('- Use inline `<svg>` in blocks - use the Icon component with Iconify icons')\n  lines.push('- Use deep relative imports (`../../`) - use `@/` alias imports')\n\n  // Template-specific rules\n  if (config?.rules) {\n    for (const rule of config.rules) {\n      if (rule.type === 'doNot') {\n        lines.push(`- ${rule.rule}`)\n      }\n    }\n  }\n\n  lines.push('')\n  return lines\n}\n\nfunction generateFileAuthority(): string[] {\n  const lines: string[] = []\n\n  lines.push('## File & Folder Authority')\n  lines.push('')\n  lines.push('These rules govern what AI is allowed and forbidden to do when creating, moving, or modifying files and folders.')\n  lines.push('')\n\n  lines.push('### Defined `/src` Structure')\n  lines.push('')\n  lines.push('```')\n  lines.push('src/')\n  lines.push('├── app/          # Routes, layouts, metadata (Next.js App Router)')\n  lines.push('├── blocks/       # Page-level content sections')\n  lines.push('├── blog/         # Blog content (archive content type)')\n  lines.push('├── components/   # Reusable UI primitives')\n  lines.push('├── hooks/        # Custom React hooks')\n  lines.push('├── styles/       # CSS, Tailwind, fonts')\n  lines.push('├── template/     # Template-level components')\n  lines.push('├── tools/        # Utility tools')\n  lines.push('├── types/        # TypeScript types')\n  lines.push('├── utils/        # Utility functions')\n  lines.push('└── state.ts      # Global state')\n  lines.push('```')\n  lines.push('')\n\n  lines.push('### App Router Structure')\n  lines.push('')\n  lines.push('Routes must use Next.js route groups. At minimum, `(default)` must exist:')\n  lines.push('')\n  lines.push('```')\n  lines.push('src/app/')\n  lines.push('├── (default)/        # Required - default layout group')\n  lines.push('│   ├── layout.tsx')\n  lines.push('│   └── {routes}/')\n  lines.push('├── (hero)/           # Optional - hero layout variant')\n  lines.push('├── api/              # API routes (exception - no grouping)')\n  lines.push('├── layout.tsx        # Root layout')\n  lines.push('└── metadata.tsx      # Shared metadata')\n  lines.push('```')\n  lines.push('')\n  lines.push('- All page routes must be inside a route group (parentheses folder)')\n  lines.push('- Never create routes directly under `src/app/` (except `api/`, root files)')\n  lines.push('- New route groups are allowed freely when a new layout variant is needed')\n  lines.push('')\n\n  lines.push('### File Structure Rules')\n  lines.push('')\n  lines.push('**Blocks:**')\n  lines.push('- Always single files directly in `src/blocks/`')\n  lines.push('- Never create folders inside `src/blocks/`')\n  lines.push('- Example: `src/blocks/hero-1.tsx`, `src/blocks/testimonial-3.tsx`')\n  lines.push('')\n  lines.push('**Components:**')\n  lines.push('- Simple components: Single file in `src/components/`')\n  lines.push('- Complex components: Folder with `index.tsx`')\n  lines.push('- Use folders when component has multiple sub-files')\n  lines.push('')\n\n  lines.push('### DO - What AI IS Allowed To Do')\n  lines.push('')\n  lines.push('- Create files only inside existing Canon-defined zones')\n  lines.push('- Place new files in the zone that matches their architectural role')\n  lines.push('- Follow existing folder conventions within a zone')\n  lines.push('- Reuse existing folders when possible')\n  lines.push('- Create new route groups in `src/app/` when new layouts are needed')\n  lines.push('- Create new archive content folders (like `blog/`, `portfolio/`) in `/src`')\n  lines.push('- Create dotfiles/directories at project root (`.github/`, `.cursor/`, etc.)')\n  lines.push('- Ask for confirmation if the correct zone is ambiguous')\n  lines.push('')\n\n  lines.push('### DO NOT - What AI Is Forbidden To Do')\n  lines.push('')\n  lines.push('- Create new top-level directories (except dotfiles)')\n  lines.push('- Create new folders in `/src` (except archive content or route groups)')\n  lines.push('- Place files outside Canon-defined zones')\n  lines.push('- Mix responsibilities across zones (components importing blocks, etc.)')\n  lines.push('- Reorganize or move folders without explicit instruction')\n  lines.push('- Invent new organizational conventions')\n  lines.push('- Create placeholder or speculative files')\n  lines.push('- Import from `_scripts/` or `_data/` in runtime code')\n  lines.push('- Manually edit files in `_data/` (generated only)')\n  lines.push('')\n\n  return lines\n}\n\nfunction generateVerification(config: CanonTemplateConfig | null): string[] {\n  const lines: string[] = []\n\n  lines.push('## Post-Edit Verification')\n  lines.push('')\n  lines.push('After editing files:')\n\n  if (config?.verification?.length) {\n    let step = 1\n    for (const cmd of config.verification) {\n      lines.push(`${step}. Run \\`${cmd}\\``)\n      step++\n    }\n    lines.push(`${step}. Fix any violations before committing`)\n  } else {\n    lines.push('1. Run `npm run lint` to check for errors')\n    lines.push('2. Fix any violations before committing')\n  }\n\n  lines.push('')\n  lines.push('Note: Only lint files you edited, not the entire codebase.')\n  lines.push('')\n\n  return lines\n}\n\n// ─── Claude-specific sections ─────────────────────────────────────────────\n\nfunction generateAutoGenFiles(config: CanonTemplateConfig | null): string[] {\n  if (!config?.generatedFiles?.length) return []\n\n  const lines: string[] = []\n\n  lines.push('## Auto-Generated Files — Never Edit Manually')\n  lines.push('')\n  lines.push('| File | Regenerate With | Triggered By |')\n  lines.push('|---|---|---|')\n\n  for (const file of config.generatedFiles) {\n    lines.push(`| \\`${file.path}\\` | \\`${file.command}\\` | ${file.trigger} |`)\n  }\n\n  lines.push('')\n  return lines\n}\n\nfunction generateBuildCommands(config: CanonTemplateConfig | null): string[] {\n  if (!config?.buildCommands?.length) return []\n\n  const lines: string[] = []\n\n  lines.push('## Build Commands')\n  lines.push('')\n  lines.push('| Command | Purpose |')\n  lines.push('|---|---|')\n\n  for (const cmd of config.buildCommands) {\n    lines.push(`| \\`${cmd.script}\\` | ${cmd.description} |`)\n  }\n\n  lines.push('')\n  return lines\n}\n\nfunction generateColorTokens(config: CanonTemplateConfig | null): string[] {\n  if (!config?.colorTokens) return []\n\n  const lines: string[] = []\n  const ct = config.colorTokens\n\n  lines.push('## Color Token System')\n  lines.push('')\n  lines.push('All colors use semantic tokens defined in `src/styles/tailwind.css` `@theme`:')\n  lines.push('')\n\n  if (ct.surface?.length) {\n    lines.push(`- **Surface**: ${ct.surface.map(s => `\\`${s}\\``).join(', ')}`)\n  }\n  if (ct.text?.length) {\n    lines.push(`- **Text**: ${ct.text.map(s => `\\`${s}\\``).join(', ')}`)\n  }\n  if (ct.overlay?.length) {\n    lines.push(`- **Overlay** (fixed — don't flip in dark mode): ${ct.overlay.map(s => `\\`${s}\\``).join(', ')}`)\n  }\n  if (ct.accents?.length) {\n    lines.push(`- **Accents**: ${ct.accents.map(s => `\\`${s}\\``).join(', ')}`)\n  }\n\n  lines.push('')\n\n  lines.push('**Never use**: `gray-*`, `white`, `black`, `slate-*` — always map to a semantic token.')\n  lines.push('')\n\n  return lines\n}\n\nfunction generateStateManagement(config: CanonTemplateConfig | null): string[] {\n  if (!config?.state) return []\n\n  const lines: string[] = []\n  const st = config.state\n\n  lines.push('## State Management')\n  lines.push('')\n  lines.push(`${st.library} store at \\`${st.file}\\`. Read with \\`${st.readPattern}\\`, write with \\`${st.writePattern}\\`.`)\n  lines.push('')\n\n  if (st.properties?.length) {\n    lines.push(`Available state: ${st.properties.map(p => `\\`${p}\\``).join(', ')}.`)\n    lines.push('')\n  }\n\n  return lines\n}\n\nfunction generateTemplateRules(config: CanonTemplateConfig | null): string[] {\n  if (!config?.rules?.length) return []\n\n  const doRules = config.rules.filter(r => r.type === 'do')\n  if (!doRules.length) return []\n\n  const lines: string[] = []\n\n  lines.push('## Template-Specific Rules')\n  lines.push('')\n\n  for (const rule of doRules) {\n    lines.push(`- ${rule.rule}`)\n  }\n\n  lines.push('')\n  return lines\n}\n\n// ─── Format generators ────────────────────────────────────────────────────\n\nfunction generateCursorrules(config: CanonTemplateConfig | null): string {\n  const lines: string[] = [\n    ...generateHeader('cursorrules'),\n    ...generateTechStack(),\n    ...generateEnforcedPatterns('cursorrules'),\n    ...generateDocPatterns(),\n    ...generateGuarantees(),\n    ...generateComponentReference(config),\n    ...generateDoNotSection(config),\n    ...generateFileAuthority(),\n    ...generateVerification(config),\n  ]\n\n  return lines.join('\\n')\n}\n\nfunction generateClaudeMd(config: CanonTemplateConfig | null): string {\n  const lines: string[] = [\n    ...generateHeader('claude'),\n    ...generateAutoGenFiles(config),\n    ...generateBuildCommands(config),\n    ...generateEnforcedPatterns('claude'),\n    ...generateDocPatterns(),\n    ...generateColorTokens(config),\n    ...generateComponentReference(config),\n    ...generateStateManagement(config),\n    ...generateTemplateRules(config),\n    ...generateDoNotSection(config),\n    ...generateVerification(config),\n  ]\n\n  return lines.join('\\n')\n}\n\nfunction generateCopilotInstructions(config: CanonTemplateConfig | null): string {\n  const lines: string[] = [\n    ...generateHeader('copilot'),\n    ...generateTechStack(),\n    ...generateEnforcedPatterns('copilot'),\n    ...generateDocPatterns(),\n    ...generateComponentReference(config),\n    ...generateDoNotSection(config),\n    ...generateVerification(config),\n  ]\n\n  return lines.join('\\n')\n}\n\nfunction generateContent(format: OutputFormat, config: CanonTemplateConfig | null): string {\n  switch (format) {\n    case 'claude':\n      return generateClaudeMd(config)\n    case 'copilot':\n      return generateCopilotInstructions(config)\n    case 'cursorrules':\n    default:\n      return generateCursorrules(config)\n  }\n}\n\nfunction writeOutput(content: string, outputPath: string): void {\n  const dir = path.dirname(outputPath)\n  if (!fs.existsSync(dir)) {\n    fs.mkdirSync(dir, { recursive: true })\n  }\n  fs.writeFileSync(outputPath, content, 'utf-8')\n}\n\n// ─── Public API ───────────────────────────────────────────────────────────\n\nexport async function generate(options: GenerateOptions): Promise<void> {\n  const config = loadConfig()\n\n  if (options.output === 'all') {\n    // Generate all targets\n    const targets = getAllTargets()\n    for (const target of targets) {\n      const content = generateContent(target.format, config)\n      const outputPath = path.resolve(process.cwd(), target.output)\n      writeOutput(content, outputPath)\n      console.log(`✓ Generated ${target.output}`)\n    }\n    console.log(`  Canon v${version} — ${patterns.length} patterns, ${guarantees.length} guarantees`)\n    if (config) {\n      console.log(`  Template config: ${config.name}`)\n    }\n  } else if (options.output === '-') {\n    const content = generateContent(options.format, config)\n    console.log(content)\n  } else {\n    const content = generateContent(options.format, config)\n    const outputPath = path.resolve(process.cwd(), options.output)\n    writeOutput(content, outputPath)\n    console.log(`✓ Generated ${options.output} from Canon v${version}`)\n    console.log(`  ${patterns.length} patterns, ${guarantees.length} guarantees`)\n    if (config) {\n      console.log(`  Template config: ${config.name}`)\n    }\n  }\n}\n"]}