agents-reverse-engineer 0.3.2 → 0.3.3
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.
|
@@ -18,6 +18,7 @@ export declare function getOpenCodeTemplates(): IntegrationTemplate[];
|
|
|
18
18
|
export declare function getGeminiTemplates(): IntegrationTemplate[];
|
|
19
19
|
/**
|
|
20
20
|
* Get session-end hook template for automatic documentation updates
|
|
21
|
+
* Uses ES module syntax for compatibility with ESM projects
|
|
21
22
|
*/
|
|
22
23
|
export declare function getHookTemplate(): string;
|
|
23
24
|
//# sourceMappingURL=templates.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"templates.d.ts","sourceRoot":"","sources":["../../src/integration/templates.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"templates.d.ts","sourceRoot":"","sources":["../../src/integration/templates.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAsnBtD;;GAEG;AACH,wBAAgB,kBAAkB,IAAI,mBAAmB,EAAE,CAE1D;AAED;;GAEG;AACH,wBAAgB,oBAAoB,IAAI,mBAAmB,EAAE,CAE5D;AAED;;GAEG;AACH,wBAAgB,kBAAkB,IAAI,mBAAmB,EAAE,CAE1D;AAED;;;GAGG;AACH,wBAAgB,eAAe,IAAI,MAAM,CAyCxC"}
|
|
@@ -101,8 +101,17 @@ For each directory (in post-order):
|
|
|
101
101
|
Generate root documents:
|
|
102
102
|
|
|
103
103
|
1. **CLAUDE.md** - Synthesize all AGENTS.md into project overview
|
|
104
|
-
2. **ARCHITECTURE.md** - Document system architecture
|
|
105
|
-
|
|
104
|
+
2. **ARCHITECTURE.md** - Document system architecture (if 20+ source files)
|
|
105
|
+
|
|
106
|
+
Generate per-package documents (at each directory containing package.json, requirements.txt, Cargo.toml, etc.):
|
|
107
|
+
|
|
108
|
+
1. **STACK.md** - Technology stack from manifest file
|
|
109
|
+
2. **STRUCTURE.md** - Codebase structure and organization
|
|
110
|
+
3. **CONVENTIONS.md** - Coding conventions and patterns
|
|
111
|
+
4. **TESTING.md** - Test setup and patterns
|
|
112
|
+
5. **INTEGRATIONS.md** - External services and APIs
|
|
113
|
+
|
|
114
|
+
In monorepos, these appear in each package directory (e.g., \`packages/api/STACK.md\`).
|
|
106
115
|
|
|
107
116
|
## Completion
|
|
108
117
|
|
|
@@ -226,42 +235,289 @@ Suggest running \`/are:discover --plan\` to start fresh.
|
|
|
226
235
|
description: 'Show available ARE commands and usage guide',
|
|
227
236
|
argumentHint: '',
|
|
228
237
|
// Content uses COMMAND_PREFIX placeholder, replaced per platform
|
|
229
|
-
content:
|
|
238
|
+
content: `<objective>
|
|
239
|
+
Display the complete ARE command reference.
|
|
230
240
|
|
|
231
|
-
|
|
232
|
-
|
|
241
|
+
Output ONLY the reference content below. Do NOT add:
|
|
242
|
+
- Project-specific analysis
|
|
243
|
+
- Git status or file context
|
|
244
|
+
- Next-step suggestions
|
|
245
|
+
- Any commentary beyond the reference
|
|
246
|
+
</objective>
|
|
247
|
+
|
|
248
|
+
<reference>
|
|
249
|
+
# agents-reverse-engineer (ARE) Command Reference
|
|
250
|
+
|
|
251
|
+
**ARE** generates AI-friendly documentation for codebases, creating structured summaries optimized for AI assistants.
|
|
252
|
+
|
|
253
|
+
## Quick Start
|
|
254
|
+
|
|
255
|
+
1. \`COMMAND_PREFIXinit\` — Create configuration file
|
|
256
|
+
2. \`COMMAND_PREFIXdiscover --plan\` — Scan codebase, create execution plan
|
|
257
|
+
3. \`COMMAND_PREFIXgenerate\` — Generate documentation from the plan
|
|
258
|
+
4. \`COMMAND_PREFIXupdate\` — Keep docs in sync after code changes
|
|
259
|
+
|
|
260
|
+
## Commands Reference
|
|
261
|
+
|
|
262
|
+
### \`COMMAND_PREFIXinit\`
|
|
263
|
+
Initialize configuration in this project.
|
|
264
|
+
|
|
265
|
+
Creates \`.agents-reverse-engineer/config.yaml\` with customizable settings.
|
|
266
|
+
|
|
267
|
+
**Usage:** \`COMMAND_PREFIXinit\`
|
|
268
|
+
**CLI:** \`npx are init\`
|
|
269
|
+
|
|
270
|
+
---
|
|
271
|
+
|
|
272
|
+
### \`COMMAND_PREFIXdiscover\`
|
|
273
|
+
Discover files that would be analyzed for documentation.
|
|
274
|
+
|
|
275
|
+
**Options:**
|
|
276
|
+
| Flag | Description |
|
|
277
|
+
|------|-------------|
|
|
278
|
+
| \`[path]\` | Target directory (default: current directory) |
|
|
279
|
+
| \`--plan\` | Generate \`GENERATION-PLAN.md\` execution plan |
|
|
280
|
+
| \`--show-excluded\` | List excluded files with reasons |
|
|
281
|
+
| \`--quiet, -q\` | Suppress output except errors |
|
|
282
|
+
|
|
283
|
+
**Usage:**
|
|
284
|
+
- \`COMMAND_PREFIXdiscover\` — List discoverable files
|
|
285
|
+
- \`COMMAND_PREFIXdiscover --plan\` — Create execution plan for generate
|
|
286
|
+
- \`COMMAND_PREFIXdiscover --show-excluded\` — Debug exclusion rules
|
|
287
|
+
|
|
288
|
+
**CLI:**
|
|
289
|
+
\`\`\`bash
|
|
290
|
+
npx are discover
|
|
291
|
+
npx are discover --plan
|
|
292
|
+
npx are discover ./src --show-excluded
|
|
293
|
+
\`\`\`
|
|
294
|
+
|
|
295
|
+
---
|
|
296
|
+
|
|
297
|
+
### \`COMMAND_PREFIXgenerate\`
|
|
298
|
+
Generate comprehensive documentation for the codebase.
|
|
299
|
+
|
|
300
|
+
**Requires:** Run \`COMMAND_PREFIXdiscover --plan\` first to create \`GENERATION-PLAN.md\`.
|
|
301
|
+
|
|
302
|
+
**Options:**
|
|
303
|
+
| Flag | Description |
|
|
304
|
+
|------|-------------|
|
|
305
|
+
| \`--budget N\` | Override token budget (default: from config) |
|
|
306
|
+
| \`--dry-run\` | Show what would be generated without writing |
|
|
307
|
+
| \`--execute\` | Output JSON execution plan for AI agents |
|
|
308
|
+
| \`--stream\` | Output tasks as streaming JSON, one per line |
|
|
309
|
+
| \`--verbose, -v\` | Show detailed task breakdown |
|
|
310
|
+
| \`--quiet, -q\` | Suppress output except errors |
|
|
311
|
+
|
|
312
|
+
**Usage:**
|
|
313
|
+
- \`COMMAND_PREFIXgenerate\` — Generate docs (resumes from plan)
|
|
314
|
+
- \`COMMAND_PREFIXgenerate --dry-run\` — Preview without writing
|
|
315
|
+
|
|
316
|
+
**CLI:**
|
|
317
|
+
\`\`\`bash
|
|
318
|
+
npx are generate
|
|
319
|
+
npx are generate --dry-run
|
|
320
|
+
npx are generate --budget 50000
|
|
321
|
+
npx are generate --execute # For programmatic use
|
|
322
|
+
\`\`\`
|
|
323
|
+
|
|
324
|
+
**How it works:**
|
|
325
|
+
1. Reads \`GENERATION-PLAN.md\` and finds unchecked tasks
|
|
326
|
+
2. Spawns parallel subagents to analyze each file
|
|
327
|
+
3. Writes \`.sum\` summary files alongside source files
|
|
328
|
+
4. Generates \`AGENTS.md\` for each directory (post-order)
|
|
329
|
+
5. Creates root documents: \`CLAUDE.md\`, \`ARCHITECTURE.md\`
|
|
330
|
+
6. Creates per-package documents at each manifest location: \`STACK.md\`, \`STRUCTURE.md\`, \`CONVENTIONS.md\`, \`TESTING.md\`, \`INTEGRATIONS.md\`
|
|
331
|
+
|
|
332
|
+
---
|
|
333
|
+
|
|
334
|
+
### \`COMMAND_PREFIXupdate\`
|
|
335
|
+
Incrementally update documentation for changed files.
|
|
336
|
+
|
|
337
|
+
**Options:**
|
|
338
|
+
| Flag | Description |
|
|
339
|
+
|------|-------------|
|
|
340
|
+
| \`--uncommitted\` | Include staged but uncommitted changes |
|
|
341
|
+
| \`--dry-run\` | Show what would be updated without writing |
|
|
342
|
+
| \`--budget N\` | Override token budget |
|
|
343
|
+
| \`--verbose, -v\` | Show detailed output |
|
|
344
|
+
| \`--quiet, -q\` | Suppress output except errors |
|
|
345
|
+
|
|
346
|
+
**Usage:**
|
|
347
|
+
- \`COMMAND_PREFIXupdate\` — Update docs for committed changes
|
|
348
|
+
- \`COMMAND_PREFIXupdate --uncommitted\` — Include uncommitted changes
|
|
349
|
+
|
|
350
|
+
**CLI:**
|
|
351
|
+
\`\`\`bash
|
|
352
|
+
npx are update
|
|
353
|
+
npx are update --uncommitted --verbose
|
|
354
|
+
npx are update --dry-run
|
|
355
|
+
\`\`\`
|
|
356
|
+
|
|
357
|
+
---
|
|
358
|
+
|
|
359
|
+
### \`COMMAND_PREFIXclean\`
|
|
360
|
+
Remove all generated documentation artifacts.
|
|
361
|
+
|
|
362
|
+
**Options:**
|
|
363
|
+
| Flag | Description |
|
|
364
|
+
|------|-------------|
|
|
365
|
+
| \`--dry-run\` | Show what would be deleted without deleting |
|
|
366
|
+
|
|
367
|
+
**What gets deleted:**
|
|
368
|
+
- \`.agents-reverse-engineer/GENERATION-PLAN.md\`
|
|
369
|
+
- All \`*.sum\` files
|
|
370
|
+
- All \`AGENTS.md\` files
|
|
371
|
+
- Root docs: \`CLAUDE.md\`, \`ARCHITECTURE.md\`
|
|
372
|
+
- Per-package docs: \`STACK.md\`, \`STRUCTURE.md\`, \`CONVENTIONS.md\`, \`TESTING.md\`, \`INTEGRATIONS.md\`
|
|
233
373
|
|
|
234
|
-
|
|
374
|
+
**Usage:**
|
|
375
|
+
- \`COMMAND_PREFIXclean --dry-run\` — Preview deletions
|
|
376
|
+
- \`COMMAND_PREFIXclean\` — Delete all artifacts
|
|
235
377
|
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
| \`COMMAND_PREFIXupdate\` | Update docs for changed files only |
|
|
243
|
-
| \`COMMAND_PREFIXclean\` | Remove all generated documentation |
|
|
378
|
+
---
|
|
379
|
+
|
|
380
|
+
### \`COMMAND_PREFIXhelp\`
|
|
381
|
+
Show this command reference.
|
|
382
|
+
|
|
383
|
+
## CLI Installation
|
|
244
384
|
|
|
245
|
-
|
|
385
|
+
Install ARE commands to your AI assistant:
|
|
386
|
+
|
|
387
|
+
\`\`\`bash
|
|
388
|
+
npx agents-reverse-engineer install # Interactive mode
|
|
389
|
+
npx agents-reverse-engineer install --runtime claude -g # Global Claude
|
|
390
|
+
npx agents-reverse-engineer install --runtime claude -l # Local project
|
|
391
|
+
npx agents-reverse-engineer install --runtime all -g # All runtimes
|
|
392
|
+
\`\`\`
|
|
246
393
|
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
394
|
+
**Install/Uninstall Options:**
|
|
395
|
+
| Flag | Description |
|
|
396
|
+
|------|-------------|
|
|
397
|
+
| \`--runtime <name>\` | Target: \`claude\`, \`opencode\`, \`gemini\`, \`all\` |
|
|
398
|
+
| \`-g, --global\` | Install to global config directory |
|
|
399
|
+
| \`-l, --local\` | Install to current project directory |
|
|
400
|
+
| \`--force\` | Overwrite existing files (install only) |
|
|
401
|
+
|
|
402
|
+
## Configuration
|
|
403
|
+
|
|
404
|
+
**File:** \`.agents-reverse-engineer/config.yaml\`
|
|
405
|
+
|
|
406
|
+
\`\`\`yaml
|
|
407
|
+
# Exclusion patterns
|
|
408
|
+
exclude:
|
|
409
|
+
patterns:
|
|
410
|
+
- "**/*.test.ts"
|
|
411
|
+
- "**/__mocks__/**"
|
|
412
|
+
vendorDirs:
|
|
413
|
+
- node_modules
|
|
414
|
+
- dist
|
|
415
|
+
- .git
|
|
416
|
+
binaryExtensions:
|
|
417
|
+
- .png
|
|
418
|
+
- .jpg
|
|
419
|
+
- .pdf
|
|
420
|
+
|
|
421
|
+
# Options
|
|
422
|
+
options:
|
|
423
|
+
followSymlinks: false
|
|
424
|
+
maxFileSize: 100000
|
|
425
|
+
|
|
426
|
+
# Output settings
|
|
427
|
+
output:
|
|
428
|
+
verbose: false
|
|
429
|
+
colors: true
|
|
430
|
+
|
|
431
|
+
# Generation settings
|
|
432
|
+
generation:
|
|
433
|
+
tokenBudget: 50000
|
|
434
|
+
\`\`\`
|
|
251
435
|
|
|
252
436
|
## Generated Files
|
|
253
437
|
|
|
254
|
-
|
|
255
|
-
- \`AGENTS.md\` — Per-directory overviews
|
|
256
|
-
- \`CLAUDE.md\` — Project entry point
|
|
257
|
-
- \`ARCHITECTURE.md\` — System design overview
|
|
258
|
-
- \`STACK.md\` — Technology stack
|
|
438
|
+
### Per Source File
|
|
259
439
|
|
|
260
|
-
|
|
440
|
+
**\`*.sum\`** — File summaries with YAML frontmatter + detailed prose.
|
|
261
441
|
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
442
|
+
\`\`\`yaml
|
|
443
|
+
---
|
|
444
|
+
file_type: service
|
|
445
|
+
generated_at: 2025-01-15T10:30:00Z
|
|
446
|
+
content_hash: abc123...
|
|
447
|
+
purpose: Handles user authentication and session management
|
|
448
|
+
public_interface: [login(), logout(), refreshToken(), AuthService]
|
|
449
|
+
dependencies: [express, jsonwebtoken, ./user-model]
|
|
450
|
+
patterns: [singleton, factory, observer]
|
|
451
|
+
related_files: [./types.ts, ./middleware.ts]
|
|
452
|
+
---
|
|
453
|
+
|
|
454
|
+
<300-500 word summary covering implementation, patterns, edge cases>
|
|
455
|
+
\`\`\`
|
|
456
|
+
|
|
457
|
+
### Per Directory
|
|
458
|
+
|
|
459
|
+
**\`AGENTS.md\`** — Directory overview synthesized from \`.sum\` files. Groups files by purpose and links to subdirectories.
|
|
460
|
+
|
|
461
|
+
### Root Documents
|
|
462
|
+
|
|
463
|
+
| File | Purpose |
|
|
464
|
+
|------|---------|
|
|
465
|
+
| \`CLAUDE.md\` | Project entry point — synthesizes all AGENTS.md |
|
|
466
|
+
| \`ARCHITECTURE.md\` | System design, layers, data flow (if 20+ files) |
|
|
467
|
+
|
|
468
|
+
### Per-Package Documents (at each manifest file location)
|
|
469
|
+
|
|
470
|
+
Generated alongside \`package.json\`, \`requirements.txt\`, \`Cargo.toml\`, etc.:
|
|
471
|
+
|
|
472
|
+
| File | Purpose |
|
|
473
|
+
|------|---------|
|
|
474
|
+
| \`STACK.md\` | Technology stack from manifest |
|
|
475
|
+
| \`STRUCTURE.md\` | Codebase structure and organization |
|
|
476
|
+
| \`CONVENTIONS.md\` | Coding conventions and patterns |
|
|
477
|
+
| \`TESTING.md\` | Test setup and patterns |
|
|
478
|
+
| \`INTEGRATIONS.md\` | External services and APIs |
|
|
479
|
+
|
|
480
|
+
In monorepos, these appear in each package directory (e.g., \`packages/api/STACK.md\`).
|
|
481
|
+
|
|
482
|
+
## Common Workflows
|
|
483
|
+
|
|
484
|
+
**Initial documentation:**
|
|
485
|
+
\`\`\`
|
|
486
|
+
COMMAND_PREFIXinit
|
|
487
|
+
COMMAND_PREFIXdiscover --plan
|
|
488
|
+
COMMAND_PREFIXgenerate
|
|
489
|
+
\`\`\`
|
|
490
|
+
|
|
491
|
+
**After code changes:**
|
|
492
|
+
\`\`\`
|
|
493
|
+
COMMAND_PREFIXupdate
|
|
494
|
+
\`\`\`
|
|
495
|
+
|
|
496
|
+
**Full regeneration:**
|
|
497
|
+
\`\`\`
|
|
498
|
+
COMMAND_PREFIXclean
|
|
499
|
+
COMMAND_PREFIXdiscover --plan
|
|
500
|
+
COMMAND_PREFIXgenerate
|
|
501
|
+
\`\`\`
|
|
502
|
+
|
|
503
|
+
**Preview before generating:**
|
|
504
|
+
\`\`\`
|
|
505
|
+
COMMAND_PREFIXdiscover --show-excluded # Check exclusions
|
|
506
|
+
COMMAND_PREFIXgenerate --dry-run # Preview generation
|
|
507
|
+
\`\`\`
|
|
508
|
+
|
|
509
|
+
## Tips
|
|
510
|
+
|
|
511
|
+
- **Resume generation**: If interrupted, run \`COMMAND_PREFIXgenerate\` again — it resumes from unchecked tasks in \`GENERATION-PLAN.md\`
|
|
512
|
+
- **Large codebases**: Use \`--budget N\` to limit token usage per run
|
|
513
|
+
- **Custom exclusions**: Edit \`.agents-reverse-engineer/config.yaml\` to skip files
|
|
514
|
+
- **Hook auto-update**: Install creates a session-end hook that auto-runs update
|
|
515
|
+
|
|
516
|
+
## Resources
|
|
517
|
+
|
|
518
|
+
- **Repository:** https://github.com/GeoloeG-IsT/agents-reverse-engineer
|
|
519
|
+
- **Update:** \`npx agents-reverse-engineer@latest install --force\`
|
|
520
|
+
</reference>`,
|
|
265
521
|
},
|
|
266
522
|
};
|
|
267
523
|
const PLATFORM_CONFIGS = {
|
|
@@ -344,14 +600,15 @@ export function getGeminiTemplates() {
|
|
|
344
600
|
}
|
|
345
601
|
/**
|
|
346
602
|
* Get session-end hook template for automatic documentation updates
|
|
603
|
+
* Uses ES module syntax for compatibility with ESM projects
|
|
347
604
|
*/
|
|
348
605
|
export function getHookTemplate() {
|
|
349
606
|
return `#!/usr/bin/env node
|
|
350
607
|
// .claude/hooks/are-session-end.js
|
|
351
608
|
// Triggers are update when session ends (if there are uncommitted changes)
|
|
352
609
|
|
|
353
|
-
|
|
354
|
-
|
|
610
|
+
import { execSync, spawn } from 'child_process';
|
|
611
|
+
import { existsSync, readFileSync } from 'fs';
|
|
355
612
|
|
|
356
613
|
// Check for disable flag
|
|
357
614
|
if (process.env.ARE_DISABLE_HOOK === '1') {
|
|
@@ -360,8 +617,8 @@ if (process.env.ARE_DISABLE_HOOK === '1') {
|
|
|
360
617
|
|
|
361
618
|
// Check config file for permanent disable
|
|
362
619
|
const configPath = '.agents-reverse-engineer.yaml';
|
|
363
|
-
if (
|
|
364
|
-
const config =
|
|
620
|
+
if (existsSync(configPath)) {
|
|
621
|
+
const config = readFileSync(configPath, 'utf-8');
|
|
365
622
|
if (config.includes('hook_enabled: false')) {
|
|
366
623
|
process.exit(0);
|
|
367
624
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"templates.js","sourceRoot":"","sources":["../../src/integration/templates.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAIH,gFAAgF;AAChF,yBAAyB;AACzB,gFAAgF;AAEhF,MAAM,QAAQ,GAAG;IACf,QAAQ,EAAE;QACR,WAAW,EAAE,4DAA4D;QACzE,YAAY,EAAE,0BAA0B;QACxC,OAAO,EAAE
|
|
1
|
+
{"version":3,"file":"templates.js","sourceRoot":"","sources":["../../src/integration/templates.ts"],"names":[],"mappings":"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"}
|