@gallop.software/canon 2.26.0 → 2.30.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/dist/cli/commands/generate.d.ts +2 -1
- package/dist/cli/commands/generate.js +337 -76
- package/dist/cli/config.d.ts +6 -0
- package/dist/cli/config.js +17 -0
- package/dist/cli/index.js +36 -10
- package/dist/eslint/index.d.ts +8 -0
- package/dist/eslint/index.js +13 -1
- package/dist/eslint/rules/no-classnames-package.d.ts +3 -0
- package/dist/eslint/rules/no-classnames-package.js +46 -0
- package/dist/eslint/rules/no-inline-svg.d.ts +3 -0
- package/dist/eslint/rules/no-inline-svg.js +37 -0
- package/dist/eslint/rules/no-raw-colors.d.ts +3 -0
- package/dist/eslint/rules/no-raw-colors.js +139 -0
- package/dist/eslint/rules/prefer-alias-imports.d.ts +3 -0
- package/dist/eslint/rules/prefer-alias-imports.js +105 -0
- package/dist/eslint/rules/prefer-list-components.js +3 -3
- package/dist/eslint/rules/prefer-typography-components.js +7 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -1
- package/dist/types/config.d.ts +36 -0
- package/dist/types/config.js +2 -0
- package/package.json +5 -1
- package/patterns/007-import-paths.md +4 -3
- package/patterns/009-color-tokens.md +4 -3
- package/patterns/012-icon-system.md +4 -3
- package/patterns/014-clsx-not-classnames.md +3 -3
- package/schema.json +8 -8
|
@@ -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
|
-
|
|
46
|
-
*/
|
|
47
|
-
function generateCursorrules() {
|
|
64
|
+
// ─── Shared section generators ────────────────────────────────────────────
|
|
65
|
+
function generateHeader(format) {
|
|
48
66
|
const lines = [];
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
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
|
-
|
|
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
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
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
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
171
|
+
return lines;
|
|
172
|
+
}
|
|
173
|
+
function generateComponentReference(config) {
|
|
174
|
+
const lines = [];
|
|
118
175
|
lines.push('## Component Quick Reference');
|
|
119
176
|
lines.push('');
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
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
|
-
|
|
203
|
+
return lines;
|
|
204
|
+
}
|
|
205
|
+
function generateDoNotSection(config) {
|
|
206
|
+
const lines = [];
|
|
137
207
|
lines.push('## Do NOT');
|
|
138
208
|
lines.push('');
|
|
139
|
-
|
|
140
|
-
lines.push(
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
228
|
-
|
|
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
|
|
236
|
-
if (options.output === '
|
|
237
|
-
//
|
|
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
|
-
|
|
499
|
+
const content = generateContent(options.format, config);
|
|
242
500
|
const outputPath = path.resolve(process.cwd(), options.output);
|
|
243
|
-
|
|
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"]}
|