faf-cli 5.1.0 → 6.0.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/README.md +80 -52
- package/dist/cli.js +313 -1884
- package/dist/index.js +4 -46
- package/package.json +29 -104
- package/project.faf +33 -141
- package/assets/project-faf-screenshot.png +0 -0
- package/dist/big-orange/bigo-push.d.ts +0 -18
- package/dist/big-orange/bigo-push.d.ts.map +0 -1
- package/dist/big-orange/bigo-push.js +0 -88
- package/dist/big-orange/bigo-push.js.map +0 -1
- package/dist/big-orange/compare.d.ts +0 -11
- package/dist/big-orange/compare.d.ts.map +0 -1
- package/dist/big-orange/compare.js +0 -179
- package/dist/big-orange/compare.js.map +0 -1
- package/dist/big-orange/faf-generator.d.ts +0 -22
- package/dist/big-orange/faf-generator.d.ts.map +0 -1
- package/dist/big-orange/faf-generator.js +0 -215
- package/dist/big-orange/faf-generator.js.map +0 -1
- package/dist/big-orange/index.d.ts +0 -7
- package/dist/big-orange/index.d.ts.map +0 -1
- package/dist/big-orange/index.js +0 -96
- package/dist/big-orange/index.js.map +0 -1
- package/dist/big-orange/types.d.ts +0 -62
- package/dist/big-orange/types.d.ts.map +0 -1
- package/dist/big-orange/types.js +0 -7
- package/dist/big-orange/types.js.map +0 -1
- package/dist/cli.d.ts +0 -8
- package/dist/cli.d.ts.map +0 -1
- package/dist/cli.js.map +0 -1
- package/dist/commands/agents.d.ts +0 -14
- package/dist/commands/agents.d.ts.map +0 -1
- package/dist/commands/agents.js +0 -353
- package/dist/commands/agents.js.map +0 -1
- package/dist/commands/ai-analyze.d.ts +0 -18
- package/dist/commands/ai-analyze.d.ts.map +0 -1
- package/dist/commands/ai-analyze.js +0 -190
- package/dist/commands/ai-analyze.js.map +0 -1
- package/dist/commands/ai-enhance.d.ts +0 -17
- package/dist/commands/ai-enhance.d.ts.map +0 -1
- package/dist/commands/ai-enhance.js +0 -275
- package/dist/commands/ai-enhance.js.map +0 -1
- package/dist/commands/antigravity.d.ts +0 -16
- package/dist/commands/antigravity.d.ts.map +0 -1
- package/dist/commands/antigravity.js +0 -398
- package/dist/commands/antigravity.js.map +0 -1
- package/dist/commands/audit.d.ts +0 -11
- package/dist/commands/audit.d.ts.map +0 -1
- package/dist/commands/audit.js +0 -148
- package/dist/commands/audit.js.map +0 -1
- package/dist/commands/auto.d.ts +0 -27
- package/dist/commands/auto.d.ts.map +0 -1
- package/dist/commands/auto.js +0 -498
- package/dist/commands/auto.js.map +0 -1
- package/dist/commands/bi-sync.d.ts +0 -50
- package/dist/commands/bi-sync.d.ts.map +0 -1
- package/dist/commands/bi-sync.js +0 -307
- package/dist/commands/bi-sync.js.map +0 -1
- package/dist/commands/chat.d.ts +0 -7
- package/dist/commands/chat.d.ts.map +0 -1
- package/dist/commands/chat.js +0 -415
- package/dist/commands/chat.js.map +0 -1
- package/dist/commands/check.d.ts +0 -31
- package/dist/commands/check.d.ts.map +0 -1
- package/dist/commands/check.js +0 -301
- package/dist/commands/check.js.map +0 -1
- package/dist/commands/clear.d.ts +0 -15
- package/dist/commands/clear.d.ts.map +0 -1
- package/dist/commands/clear.js +0 -167
- package/dist/commands/clear.js.map +0 -1
- package/dist/commands/compile.d.ts +0 -12
- package/dist/commands/compile.d.ts.map +0 -1
- package/dist/commands/compile.js +0 -51
- package/dist/commands/compile.js.map +0 -1
- package/dist/commands/conductor.d.ts +0 -15
- package/dist/commands/conductor.d.ts.map +0 -1
- package/dist/commands/conductor.js +0 -339
- package/dist/commands/conductor.js.map +0 -1
- package/dist/commands/convert.d.ts +0 -19
- package/dist/commands/convert.d.ts.map +0 -1
- package/dist/commands/convert.js +0 -99
- package/dist/commands/convert.js.map +0 -1
- package/dist/commands/credit.d.ts +0 -13
- package/dist/commands/credit.d.ts.map +0 -1
- package/dist/commands/credit.js +0 -149
- package/dist/commands/credit.js.map +0 -1
- package/dist/commands/cursor.d.ts +0 -13
- package/dist/commands/cursor.d.ts.map +0 -1
- package/dist/commands/cursor.js +0 -310
- package/dist/commands/cursor.js.map +0 -1
- package/dist/commands/decompile.d.ts +0 -9
- package/dist/commands/decompile.d.ts.map +0 -1
- package/dist/commands/decompile.js +0 -21
- package/dist/commands/decompile.js.map +0 -1
- package/dist/commands/demo.d.ts +0 -20
- package/dist/commands/demo.d.ts.map +0 -1
- package/dist/commands/demo.js +0 -205
- package/dist/commands/demo.js.map +0 -1
- package/dist/commands/doctor.d.ts +0 -6
- package/dist/commands/doctor.d.ts.map +0 -1
- package/dist/commands/doctor.js +0 -230
- package/dist/commands/doctor.js.map +0 -1
- package/dist/commands/drift.d.ts +0 -16
- package/dist/commands/drift.d.ts.map +0 -1
- package/dist/commands/drift.js +0 -524
- package/dist/commands/drift.js.map +0 -1
- package/dist/commands/edit-helper.d.ts +0 -6
- package/dist/commands/edit-helper.d.ts.map +0 -1
- package/dist/commands/edit-helper.js +0 -52
- package/dist/commands/edit-helper.js.map +0 -1
- package/dist/commands/edit.d.ts +0 -14
- package/dist/commands/edit.d.ts.map +0 -1
- package/dist/commands/edit.js +0 -196
- package/dist/commands/edit.js.map +0 -1
- package/dist/commands/enhance-real.d.ts +0 -18
- package/dist/commands/enhance-real.d.ts.map +0 -1
- package/dist/commands/enhance-real.js +0 -1164
- package/dist/commands/enhance-real.js.map +0 -1
- package/dist/commands/faf-auth.d.ts +0 -10
- package/dist/commands/faf-auth.d.ts.map +0 -1
- package/dist/commands/faf-auth.js +0 -162
- package/dist/commands/faf-auth.js.map +0 -1
- package/dist/commands/faf-dna.d.ts +0 -9
- package/dist/commands/faf-dna.d.ts.map +0 -1
- package/dist/commands/faf-dna.js +0 -141
- package/dist/commands/faf-dna.js.map +0 -1
- package/dist/commands/faf-log.d.ts +0 -9
- package/dist/commands/faf-log.d.ts.map +0 -1
- package/dist/commands/faf-log.js +0 -135
- package/dist/commands/faf-log.js.map +0 -1
- package/dist/commands/faf-recover.d.ts +0 -3
- package/dist/commands/faf-recover.d.ts.map +0 -1
- package/dist/commands/faf-recover.js +0 -296
- package/dist/commands/faf-recover.js.map +0 -1
- package/dist/commands/faf-update.d.ts +0 -9
- package/dist/commands/faf-update.d.ts.map +0 -1
- package/dist/commands/faf-update.js +0 -68
- package/dist/commands/faf-update.js.map +0 -1
- package/dist/commands/fam.d.ts +0 -15
- package/dist/commands/fam.d.ts.map +0 -1
- package/dist/commands/fam.js +0 -339
- package/dist/commands/fam.js.map +0 -1
- package/dist/commands/faq.d.ts +0 -12
- package/dist/commands/faq.d.ts.map +0 -1
- package/dist/commands/faq.js +0 -84
- package/dist/commands/faq.js.map +0 -1
- package/dist/commands/formats.d.ts +0 -12
- package/dist/commands/formats.d.ts.map +0 -1
- package/dist/commands/formats.js +0 -107
- package/dist/commands/formats.js.map +0 -1
- package/dist/commands/gemini.d.ts +0 -15
- package/dist/commands/gemini.d.ts.map +0 -1
- package/dist/commands/gemini.js +0 -357
- package/dist/commands/gemini.js.map +0 -1
- package/dist/commands/git.d.ts +0 -25
- package/dist/commands/git.d.ts.map +0 -1
- package/dist/commands/git.js +0 -365
- package/dist/commands/git.js.map +0 -1
- package/dist/commands/go.d.ts +0 -23
- package/dist/commands/go.d.ts.map +0 -1
- package/dist/commands/go.js +0 -283
- package/dist/commands/go.js.map +0 -1
- package/dist/commands/human.d.ts +0 -19
- package/dist/commands/human.d.ts.map +0 -1
- package/dist/commands/human.js +0 -204
- package/dist/commands/human.js.map +0 -1
- package/dist/commands/index.d.ts +0 -26
- package/dist/commands/index.d.ts.map +0 -1
- package/dist/commands/index.js +0 -438
- package/dist/commands/index.js.map +0 -1
- package/dist/commands/init.d.ts +0 -19
- package/dist/commands/init.d.ts.map +0 -1
- package/dist/commands/init.js +0 -409
- package/dist/commands/init.js.map +0 -1
- package/dist/commands/lint.d.ts +0 -11
- package/dist/commands/lint.d.ts.map +0 -1
- package/dist/commands/lint.js +0 -233
- package/dist/commands/lint.js.map +0 -1
- package/dist/commands/memory.d.ts +0 -14
- package/dist/commands/memory.d.ts.map +0 -1
- package/dist/commands/memory.js +0 -293
- package/dist/commands/memory.js.map +0 -1
- package/dist/commands/migrate.d.ts +0 -11
- package/dist/commands/migrate.d.ts.map +0 -1
- package/dist/commands/migrate.js +0 -85
- package/dist/commands/migrate.js.map +0 -1
- package/dist/commands/notifications.d.ts +0 -12
- package/dist/commands/notifications.d.ts.map +0 -1
- package/dist/commands/notifications.js +0 -35
- package/dist/commands/notifications.js.map +0 -1
- package/dist/commands/plugin-install.d.ts +0 -20
- package/dist/commands/plugin-install.d.ts.map +0 -1
- package/dist/commands/plugin-install.js +0 -183
- package/dist/commands/plugin-install.js.map +0 -1
- package/dist/commands/pro.d.ts +0 -10
- package/dist/commands/pro.d.ts.map +0 -1
- package/dist/commands/pro.js +0 -113
- package/dist/commands/pro.js.map +0 -1
- package/dist/commands/quick.d.ts +0 -10
- package/dist/commands/quick.d.ts.map +0 -1
- package/dist/commands/quick.js +0 -207
- package/dist/commands/quick.js.map +0 -1
- package/dist/commands/ram.d.ts +0 -17
- package/dist/commands/ram.d.ts.map +0 -1
- package/dist/commands/ram.js +0 -322
- package/dist/commands/ram.js.map +0 -1
- package/dist/commands/readme.d.ts +0 -21
- package/dist/commands/readme.d.ts.map +0 -1
- package/dist/commands/readme.js +0 -519
- package/dist/commands/readme.js.map +0 -1
- package/dist/commands/rename.d.ts +0 -18
- package/dist/commands/rename.d.ts.map +0 -1
- package/dist/commands/rename.js +0 -212
- package/dist/commands/rename.js.map +0 -1
- package/dist/commands/score-v3.d.ts +0 -15
- package/dist/commands/score-v3.d.ts.map +0 -1
- package/dist/commands/score-v3.js +0 -224
- package/dist/commands/score-v3.js.map +0 -1
- package/dist/commands/score.d.ts +0 -16
- package/dist/commands/score.d.ts.map +0 -1
- package/dist/commands/score.js +0 -19
- package/dist/commands/score.js.map +0 -1
- package/dist/commands/search.d.ts +0 -16
- package/dist/commands/search.d.ts.map +0 -1
- package/dist/commands/search.js +0 -174
- package/dist/commands/search.js.map +0 -1
- package/dist/commands/share.d.ts +0 -17
- package/dist/commands/share.d.ts.map +0 -1
- package/dist/commands/share.js +0 -261
- package/dist/commands/share.js.map +0 -1
- package/dist/commands/show.d.ts +0 -10
- package/dist/commands/show.d.ts.map +0 -1
- package/dist/commands/show.js +0 -142
- package/dist/commands/show.js.map +0 -1
- package/dist/commands/sixws.d.ts +0 -6
- package/dist/commands/sixws.d.ts.map +0 -1
- package/dist/commands/sixws.js +0 -154
- package/dist/commands/sixws.js.map +0 -1
- package/dist/commands/skills.d.ts +0 -8
- package/dist/commands/skills.d.ts.map +0 -1
- package/dist/commands/skills.js +0 -43
- package/dist/commands/skills.js.map +0 -1
- package/dist/commands/stacks.d.ts +0 -51
- package/dist/commands/stacks.d.ts.map +0 -1
- package/dist/commands/stacks.js +0 -180
- package/dist/commands/stacks.js.map +0 -1
- package/dist/commands/status.d.ts +0 -14
- package/dist/commands/status.d.ts.map +0 -1
- package/dist/commands/status.js +0 -210
- package/dist/commands/status.js.map +0 -1
- package/dist/commands/sync.d.ts +0 -11
- package/dist/commands/sync.d.ts.map +0 -1
- package/dist/commands/sync.js +0 -543
- package/dist/commands/sync.js.map +0 -1
- package/dist/commands/taf-init.d.ts +0 -14
- package/dist/commands/taf-init.d.ts.map +0 -1
- package/dist/commands/taf-init.js +0 -138
- package/dist/commands/taf-init.js.map +0 -1
- package/dist/commands/taf-log.d.ts +0 -31
- package/dist/commands/taf-log.d.ts.map +0 -1
- package/dist/commands/taf-log.js +0 -351
- package/dist/commands/taf-log.js.map +0 -1
- package/dist/commands/taf-stars.d.ts +0 -8
- package/dist/commands/taf-stars.d.ts.map +0 -1
- package/dist/commands/taf-stars.js +0 -105
- package/dist/commands/taf-stars.js.map +0 -1
- package/dist/commands/taf-stats.d.ts +0 -8
- package/dist/commands/taf-stats.d.ts.map +0 -1
- package/dist/commands/taf-stats.js +0 -133
- package/dist/commands/taf-stats.js.map +0 -1
- package/dist/commands/taf-validate.d.ts +0 -8
- package/dist/commands/taf-validate.d.ts.map +0 -1
- package/dist/commands/taf-validate.js +0 -108
- package/dist/commands/taf-validate.js.map +0 -1
- package/dist/commands/taf.d.ts +0 -14
- package/dist/commands/taf.d.ts.map +0 -1
- package/dist/commands/taf.js +0 -106
- package/dist/commands/taf.js.map +0 -1
- package/dist/commands/todo.d.ts +0 -14
- package/dist/commands/todo.d.ts.map +0 -1
- package/dist/commands/todo.js +0 -282
- package/dist/commands/todo.js.map +0 -1
- package/dist/commands/trust.d.ts +0 -33
- package/dist/commands/trust.d.ts.map +0 -1
- package/dist/commands/trust.js +0 -308
- package/dist/commands/trust.js.map +0 -1
- package/dist/commands/tsa.d.ts +0 -9
- package/dist/commands/tsa.d.ts.map +0 -1
- package/dist/commands/tsa.js +0 -60
- package/dist/commands/tsa.js.map +0 -1
- package/dist/commands/validate.d.ts +0 -11
- package/dist/commands/validate.d.ts.map +0 -1
- package/dist/commands/validate.js +0 -64
- package/dist/commands/validate.js.map +0 -1
- package/dist/commands/verify.d.ts +0 -36
- package/dist/commands/verify.d.ts.map +0 -1
- package/dist/commands/verify.js +0 -194
- package/dist/commands/verify.js.map +0 -1
- package/dist/commands/version.d.ts +0 -5
- package/dist/commands/version.d.ts.map +0 -1
- package/dist/commands/version.js +0 -29
- package/dist/commands/version.js.map +0 -1
- package/dist/commands/vibe.d.ts +0 -7
- package/dist/commands/vibe.d.ts.map +0 -1
- package/dist/commands/vibe.js +0 -73
- package/dist/commands/vibe.js.map +0 -1
- package/dist/commands/welcome.d.ts +0 -10
- package/dist/commands/welcome.d.ts.map +0 -1
- package/dist/commands/welcome.js +0 -117
- package/dist/commands/welcome.js.map +0 -1
- package/dist/commands/yolo.d.ts +0 -12
- package/dist/commands/yolo.d.ts.map +0 -1
- package/dist/commands/yolo.js +0 -212
- package/dist/commands/yolo.js.map +0 -1
- package/dist/compiler/faf-compiler.d.ts +0 -176
- package/dist/compiler/faf-compiler.d.ts.map +0 -1
- package/dist/compiler/faf-compiler.js +0 -1587
- package/dist/compiler/faf-compiler.js.map +0 -1
- package/dist/converters/faf-converters.d.ts +0 -43
- package/dist/converters/faf-converters.d.ts.map +0 -1
- package/dist/converters/faf-converters.js +0 -197
- package/dist/converters/faf-converters.js.map +0 -1
- package/dist/core-extraction-fixes.d.ts +0 -92
- package/dist/core-extraction-fixes.d.ts.map +0 -1
- package/dist/core-extraction-fixes.js +0 -265
- package/dist/core-extraction-fixes.js.map +0 -1
- package/dist/engines/art-ansi-renderer.d.ts +0 -335
- package/dist/engines/art-ansi-renderer.d.ts.map +0 -1
- package/dist/engines/art-ansi-renderer.js +0 -290
- package/dist/engines/art-ansi-renderer.js.map +0 -1
- package/dist/engines/c-mirror/broadcast/terminal-display.d.ts +0 -23
- package/dist/engines/c-mirror/broadcast/terminal-display.d.ts.map +0 -1
- package/dist/engines/c-mirror/broadcast/terminal-display.js +0 -194
- package/dist/engines/c-mirror/broadcast/terminal-display.js.map +0 -1
- package/dist/engines/c-mirror/core/claude-to-faf.d.ts +0 -28
- package/dist/engines/c-mirror/core/claude-to-faf.d.ts.map +0 -1
- package/dist/engines/c-mirror/core/claude-to-faf.js +0 -195
- package/dist/engines/c-mirror/core/claude-to-faf.js.map +0 -1
- package/dist/engines/c-mirror/core/events/event-emitter.d.ts +0 -36
- package/dist/engines/c-mirror/core/events/event-emitter.d.ts.map +0 -1
- package/dist/engines/c-mirror/core/events/event-emitter.js +0 -77
- package/dist/engines/c-mirror/core/events/event-emitter.js.map +0 -1
- package/dist/engines/c-mirror/core/events/mirror-events.d.ts +0 -103
- package/dist/engines/c-mirror/core/events/mirror-events.d.ts.map +0 -1
- package/dist/engines/c-mirror/core/events/mirror-events.js +0 -65
- package/dist/engines/c-mirror/core/events/mirror-events.js.map +0 -1
- package/dist/engines/c-mirror/core/faf-to-claude.d.ts +0 -18
- package/dist/engines/c-mirror/core/faf-to-claude.d.ts.map +0 -1
- package/dist/engines/c-mirror/core/faf-to-claude.js +0 -162
- package/dist/engines/c-mirror/core/faf-to-claude.js.map +0 -1
- package/dist/engines/c-mirror/core/interfaces.d.ts +0 -153
- package/dist/engines/c-mirror/core/interfaces.d.ts.map +0 -1
- package/dist/engines/c-mirror/core/interfaces.js +0 -8
- package/dist/engines/c-mirror/core/interfaces.js.map +0 -1
- package/dist/engines/c-mirror/core/mirror-engine.d.ts +0 -49
- package/dist/engines/c-mirror/core/mirror-engine.d.ts.map +0 -1
- package/dist/engines/c-mirror/core/mirror-engine.js +0 -315
- package/dist/engines/c-mirror/core/mirror-engine.js.map +0 -1
- package/dist/engines/c-mirror/faf-extensions/faf-mirror.d.ts +0 -33
- package/dist/engines/c-mirror/faf-extensions/faf-mirror.d.ts.map +0 -1
- package/dist/engines/c-mirror/faf-extensions/faf-mirror.js +0 -115
- package/dist/engines/c-mirror/faf-extensions/faf-mirror.js.map +0 -1
- package/dist/engines/c-mirror/strategies/atomic-write.d.ts +0 -34
- package/dist/engines/c-mirror/strategies/atomic-write.d.ts.map +0 -1
- package/dist/engines/c-mirror/strategies/atomic-write.js +0 -132
- package/dist/engines/c-mirror/strategies/atomic-write.js.map +0 -1
- package/dist/engines/claude-todo-engine.d.ts +0 -115
- package/dist/engines/claude-todo-engine.d.ts.map +0 -1
- package/dist/engines/claude-todo-engine.js +0 -346
- package/dist/engines/claude-todo-engine.js.map +0 -1
- package/dist/engines/dependency-tsa.d.ts +0 -89
- package/dist/engines/dependency-tsa.d.ts.map +0 -1
- package/dist/engines/dependency-tsa.js +0 -365
- package/dist/engines/dependency-tsa.js.map +0 -1
- package/dist/engines/drop-coach.d.ts +0 -64
- package/dist/engines/drop-coach.d.ts.map +0 -1
- package/dist/engines/drop-coach.js +0 -222
- package/dist/engines/drop-coach.js.map +0 -1
- package/dist/engines/execution-context.d.ts +0 -75
- package/dist/engines/execution-context.d.ts.map +0 -1
- package/dist/engines/execution-context.js +0 -308
- package/dist/engines/execution-context.js.map +0 -1
- package/dist/engines/fab-formats-processor.d.ts +0 -179
- package/dist/engines/fab-formats-processor.d.ts.map +0 -1
- package/dist/engines/fab-formats-processor.js +0 -1524
- package/dist/engines/fab-formats-processor.js.map +0 -1
- package/dist/engines/faf-dna.d.ts +0 -160
- package/dist/engines/faf-dna.d.ts.map +0 -1
- package/dist/engines/faf-dna.js +0 -547
- package/dist/engines/faf-dna.js.map +0 -1
- package/dist/engines/relentless-context-extractor.d.ts +0 -105
- package/dist/engines/relentless-context-extractor.d.ts.map +0 -1
- package/dist/engines/relentless-context-extractor.js +0 -698
- package/dist/engines/relentless-context-extractor.js.map +0 -1
- package/dist/engines/v252-hybrid-engine.d.ts +0 -60
- package/dist/engines/v252-hybrid-engine.d.ts.map +0 -1
- package/dist/engines/v252-hybrid-engine.js +0 -290
- package/dist/engines/v252-hybrid-engine.js.map +0 -1
- package/dist/family/detectors/n8n.d.ts +0 -10
- package/dist/family/detectors/n8n.d.ts.map +0 -1
- package/dist/family/detectors/n8n.js +0 -102
- package/dist/family/detectors/n8n.js.map +0 -1
- package/dist/family/detectors/next.d.ts +0 -8
- package/dist/family/detectors/next.d.ts.map +0 -1
- package/dist/family/detectors/next.js +0 -106
- package/dist/family/detectors/next.js.map +0 -1
- package/dist/family/detectors/react.d.ts +0 -8
- package/dist/family/detectors/react.d.ts.map +0 -1
- package/dist/family/detectors/react.js +0 -85
- package/dist/family/detectors/react.js.map +0 -1
- package/dist/family/detectors/svelte.d.ts +0 -8
- package/dist/family/detectors/svelte.d.ts.map +0 -1
- package/dist/family/detectors/svelte.js +0 -102
- package/dist/family/detectors/svelte.js.map +0 -1
- package/dist/family/detectors/typescript.d.ts +0 -8
- package/dist/family/detectors/typescript.d.ts.map +0 -1
- package/dist/family/detectors/typescript.js +0 -112
- package/dist/family/detectors/typescript.js.map +0 -1
- package/dist/family/detectors/vite.d.ts +0 -8
- package/dist/family/detectors/vite.d.ts.map +0 -1
- package/dist/family/detectors/vite.js +0 -97
- package/dist/family/detectors/vite.js.map +0 -1
- package/dist/family/index.d.ts +0 -21
- package/dist/family/index.d.ts.map +0 -1
- package/dist/family/index.js +0 -73
- package/dist/family/index.js.map +0 -1
- package/dist/family/registry.d.ts +0 -57
- package/dist/family/registry.d.ts.map +0 -1
- package/dist/family/registry.js +0 -156
- package/dist/family/registry.js.map +0 -1
- package/dist/family/types.d.ts +0 -102
- package/dist/family/types.d.ts.map +0 -1
- package/dist/family/types.js +0 -8
- package/dist/family/types.js.map +0 -1
- package/dist/fix-once/colors.d.ts +0 -105
- package/dist/fix-once/colors.d.ts.map +0 -1
- package/dist/fix-once/colors.js +0 -248
- package/dist/fix-once/colors.js.map +0 -1
- package/dist/fix-once/commander.d.ts +0 -18
- package/dist/fix-once/commander.d.ts.map +0 -1
- package/dist/fix-once/commander.js +0 -25
- package/dist/fix-once/commander.js.map +0 -1
- package/dist/fix-once/types.d.ts +0 -258
- package/dist/fix-once/types.d.ts.map +0 -1
- package/dist/fix-once/types.js +0 -26
- package/dist/fix-once/types.js.map +0 -1
- package/dist/fix-once/yaml.d.ts +0 -58
- package/dist/fix-once/yaml.d.ts.map +0 -1
- package/dist/fix-once/yaml.js +0 -172
- package/dist/fix-once/yaml.js.map +0 -1
- package/dist/framework-detector.d.ts +0 -307
- package/dist/framework-detector.d.ts.map +0 -1
- package/dist/framework-detector.js +0 -951
- package/dist/framework-detector.js.map +0 -1
- package/dist/generators/faf-generator-championship.d.ts +0 -17
- package/dist/generators/faf-generator-championship.d.ts.map +0 -1
- package/dist/generators/faf-generator-championship.js +0 -612
- package/dist/generators/faf-generator-championship.js.map +0 -1
- package/dist/github/current-score-calculator.d.ts +0 -15
- package/dist/github/current-score-calculator.d.ts.map +0 -1
- package/dist/github/current-score-calculator.js +0 -125
- package/dist/github/current-score-calculator.js.map +0 -1
- package/dist/github/faf-git-generator.d.ts +0 -52
- package/dist/github/faf-git-generator.d.ts.map +0 -1
- package/dist/github/faf-git-generator.js +0 -527
- package/dist/github/faf-git-generator.js.map +0 -1
- package/dist/github/github-extractor.d.ts +0 -60
- package/dist/github/github-extractor.d.ts.map +0 -1
- package/dist/github/github-extractor.js +0 -381
- package/dist/github/github-extractor.js.map +0 -1
- package/dist/github/popular-repos.d.ts +0 -43
- package/dist/github/popular-repos.d.ts.map +0 -1
- package/dist/github/popular-repos.js +0 -205
- package/dist/github/popular-repos.js.map +0 -1
- package/dist/github/repo-selector.d.ts +0 -48
- package/dist/github/repo-selector.d.ts.map +0 -1
- package/dist/github/repo-selector.js +0 -297
- package/dist/github/repo-selector.js.map +0 -1
- package/dist/index.d.ts +0 -20
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/licensing/license-messages.d.ts +0 -20
- package/dist/licensing/license-messages.d.ts.map +0 -1
- package/dist/licensing/license-messages.js +0 -77
- package/dist/licensing/license-messages.js.map +0 -1
- package/dist/licensing/pro-gate.d.ts +0 -54
- package/dist/licensing/pro-gate.d.ts.map +0 -1
- package/dist/licensing/pro-gate.js +0 -243
- package/dist/licensing/pro-gate.js.map +0 -1
- package/dist/output/experience-manager.d.ts +0 -58
- package/dist/output/experience-manager.d.ts.map +0 -1
- package/dist/output/experience-manager.js +0 -215
- package/dist/output/experience-manager.js.map +0 -1
- package/dist/schema/faf-schema.d.ts +0 -97
- package/dist/schema/faf-schema.d.ts.map +0 -1
- package/dist/schema/faf-schema.js +0 -173
- package/dist/schema/faf-schema.js.map +0 -1
- package/dist/smart-faf.d.ts +0 -68
- package/dist/smart-faf.d.ts.map +0 -1
- package/dist/smart-faf.js +0 -400
- package/dist/smart-faf.js.map +0 -1
- package/dist/systems/question-system.d.ts +0 -122
- package/dist/systems/question-system.d.ts.map +0 -1
- package/dist/systems/question-system.js +0 -413
- package/dist/systems/question-system.js.map +0 -1
- package/dist/taf/index.d.ts +0 -21
- package/dist/taf/index.d.ts.map +0 -1
- package/dist/taf/index.js +0 -72
- package/dist/taf/index.js.map +0 -1
- package/dist/taf/logger.d.ts +0 -88
- package/dist/taf/logger.d.ts.map +0 -1
- package/dist/taf/logger.js +0 -137
- package/dist/taf/logger.js.map +0 -1
- package/dist/taf/parser.d.ts +0 -32
- package/dist/taf/parser.d.ts.map +0 -1
- package/dist/taf/parser.js +0 -161
- package/dist/taf/parser.js.map +0 -1
- package/dist/taf/star-badge.d.ts +0 -32
- package/dist/taf/star-badge.d.ts.map +0 -1
- package/dist/taf/star-badge.js +0 -158
- package/dist/taf/star-badge.js.map +0 -1
- package/dist/taf/star-rating.d.ts +0 -30
- package/dist/taf/star-rating.d.ts.map +0 -1
- package/dist/taf/star-rating.js +0 -79
- package/dist/taf/star-rating.js.map +0 -1
- package/dist/taf/stats.d.ts +0 -31
- package/dist/taf/stats.d.ts.map +0 -1
- package/dist/taf/stats.js +0 -190
- package/dist/taf/stats.js.map +0 -1
- package/dist/taf/test-output-parser.d.ts +0 -42
- package/dist/taf/test-output-parser.d.ts.map +0 -1
- package/dist/taf/test-output-parser.js +0 -127
- package/dist/taf/test-output-parser.js.map +0 -1
- package/dist/taf/types.d.ts +0 -77
- package/dist/taf/types.d.ts.map +0 -1
- package/dist/taf/types.js +0 -9
- package/dist/taf/types.js.map +0 -1
- package/dist/taf/validator.d.ts +0 -18
- package/dist/taf/validator.d.ts.map +0 -1
- package/dist/taf/validator.js +0 -148
- package/dist/taf/validator.js.map +0 -1
- package/dist/telemetry/analytics.d.ts +0 -74
- package/dist/telemetry/analytics.d.ts.map +0 -1
- package/dist/telemetry/analytics.js +0 -370
- package/dist/telemetry/analytics.js.map +0 -1
- package/dist/tests/test-chrome-fuzzy.d.ts +0 -5
- package/dist/tests/test-chrome-fuzzy.d.ts.map +0 -1
- package/dist/tests/test-chrome-fuzzy.js +0 -68
- package/dist/tests/test-chrome-fuzzy.js.map +0 -1
- package/dist/types/faf-types.d.ts +0 -144
- package/dist/types/faf-types.d.ts.map +0 -1
- package/dist/types/faf-types.js +0 -21
- package/dist/types/faf-types.js.map +0 -1
- package/dist/types/index.d.ts +0 -36
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js +0 -7
- package/dist/types/index.js.map +0 -1
- package/dist/utils/agents-parser.d.ts +0 -60
- package/dist/utils/agents-parser.d.ts.map +0 -1
- package/dist/utils/agents-parser.js +0 -339
- package/dist/utils/agents-parser.js.map +0 -1
- package/dist/utils/announcements.d.ts +0 -16
- package/dist/utils/announcements.d.ts.map +0 -1
- package/dist/utils/announcements.js +0 -131
- package/dist/utils/announcements.js.map +0 -1
- package/dist/utils/balance-visualizer.d.ts +0 -38
- package/dist/utils/balance-visualizer.d.ts.map +0 -1
- package/dist/utils/balance-visualizer.js +0 -190
- package/dist/utils/balance-visualizer.js.map +0 -1
- package/dist/utils/championship-core.d.ts +0 -127
- package/dist/utils/championship-core.d.ts.map +0 -1
- package/dist/utils/championship-core.js +0 -212
- package/dist/utils/championship-core.js.map +0 -1
- package/dist/utils/championship-style.d.ts +0 -110
- package/dist/utils/championship-style.d.ts.map +0 -1
- package/dist/utils/championship-style.js +0 -219
- package/dist/utils/championship-style.js.map +0 -1
- package/dist/utils/chrome-extension-confirmer.d.ts +0 -41
- package/dist/utils/chrome-extension-confirmer.d.ts.map +0 -1
- package/dist/utils/chrome-extension-confirmer.js +0 -203
- package/dist/utils/chrome-extension-confirmer.js.map +0 -1
- package/dist/utils/chrome-extension-detector.d.ts +0 -74
- package/dist/utils/chrome-extension-detector.d.ts.map +0 -1
- package/dist/utils/chrome-extension-detector.js +0 -268
- package/dist/utils/chrome-extension-detector.js.map +0 -1
- package/dist/utils/color-utils.d.ts +0 -17
- package/dist/utils/color-utils.d.ts.map +0 -1
- package/dist/utils/color-utils.js +0 -112
- package/dist/utils/color-utils.js.map +0 -1
- package/dist/utils/conductor-parser.d.ts +0 -86
- package/dist/utils/conductor-parser.d.ts.map +0 -1
- package/dist/utils/conductor-parser.js +0 -293
- package/dist/utils/conductor-parser.js.map +0 -1
- package/dist/utils/cursorrules-parser.d.ts +0 -56
- package/dist/utils/cursorrules-parser.d.ts.map +0 -1
- package/dist/utils/cursorrules-parser.js +0 -327
- package/dist/utils/cursorrules-parser.js.map +0 -1
- package/dist/utils/email-opt-in.d.ts +0 -31
- package/dist/utils/email-opt-in.d.ts.map +0 -1
- package/dist/utils/email-opt-in.js +0 -199
- package/dist/utils/email-opt-in.js.map +0 -1
- package/dist/utils/fab-formats-engine.d.ts +0 -83
- package/dist/utils/fab-formats-engine.d.ts.map +0 -1
- package/dist/utils/fab-formats-engine.js +0 -502
- package/dist/utils/fab-formats-engine.js.map +0 -1
- package/dist/utils/fafb-compiler.d.ts +0 -62
- package/dist/utils/fafb-compiler.d.ts.map +0 -1
- package/dist/utils/fafb-compiler.js +0 -225
- package/dist/utils/fafb-compiler.js.map +0 -1
- package/dist/utils/fafb-detector.d.ts +0 -26
- package/dist/utils/fafb-detector.d.ts.map +0 -1
- package/dist/utils/fafb-detector.js +0 -180
- package/dist/utils/fafb-detector.js.map +0 -1
- package/dist/utils/fafignore-parser.d.ts +0 -21
- package/dist/utils/fafignore-parser.d.ts.map +0 -1
- package/dist/utils/fafignore-parser.js +0 -178
- package/dist/utils/fafignore-parser.js.map +0 -1
- package/dist/utils/feedback-messages.d.ts +0 -13
- package/dist/utils/feedback-messages.d.ts.map +0 -1
- package/dist/utils/feedback-messages.js +0 -118
- package/dist/utils/feedback-messages.js.map +0 -1
- package/dist/utils/file-utils.d.ts +0 -113
- package/dist/utils/file-utils.d.ts.map +0 -1
- package/dist/utils/file-utils.js +0 -949
- package/dist/utils/file-utils.js.map +0 -1
- package/dist/utils/gemini-parser.d.ts +0 -58
- package/dist/utils/gemini-parser.d.ts.map +0 -1
- package/dist/utils/gemini-parser.js +0 -263
- package/dist/utils/gemini-parser.js.map +0 -1
- package/dist/utils/markdown-to-context.d.ts +0 -28
- package/dist/utils/markdown-to-context.d.ts.map +0 -1
- package/dist/utils/markdown-to-context.js +0 -206
- package/dist/utils/markdown-to-context.js.map +0 -1
- package/dist/utils/memory-parser.d.ts +0 -95
- package/dist/utils/memory-parser.d.ts.map +0 -1
- package/dist/utils/memory-parser.js +0 -408
- package/dist/utils/memory-parser.js.map +0 -1
- package/dist/utils/memory-topic-writer.d.ts +0 -52
- package/dist/utils/memory-topic-writer.d.ts.map +0 -1
- package/dist/utils/memory-topic-writer.js +0 -415
- package/dist/utils/memory-topic-writer.js.map +0 -1
- package/dist/utils/native-cli-parser.d.ts +0 -152
- package/dist/utils/native-cli-parser.d.ts.map +0 -1
- package/dist/utils/native-cli-parser.js +0 -466
- package/dist/utils/native-cli-parser.js.map +0 -1
- package/dist/utils/native-file-finder.d.ts +0 -116
- package/dist/utils/native-file-finder.d.ts.map +0 -1
- package/dist/utils/native-file-finder.js +0 -211
- package/dist/utils/native-file-finder.js.map +0 -1
- package/dist/utils/platform-detector.d.ts +0 -31
- package/dist/utils/platform-detector.d.ts.map +0 -1
- package/dist/utils/platform-detector.js +0 -220
- package/dist/utils/platform-detector.js.map +0 -1
- package/dist/utils/score-header.d.ts +0 -22
- package/dist/utils/score-header.d.ts.map +0 -1
- package/dist/utils/score-header.js +0 -88
- package/dist/utils/score-header.js.map +0 -1
- package/dist/utils/slot-counter.d.ts +0 -56
- package/dist/utils/slot-counter.d.ts.map +0 -1
- package/dist/utils/slot-counter.js +0 -100
- package/dist/utils/slot-counter.js.map +0 -1
- package/dist/utils/technical-credit.d.ts +0 -36
- package/dist/utils/technical-credit.d.ts.map +0 -1
- package/dist/utils/technical-credit.js +0 -286
- package/dist/utils/technical-credit.js.map +0 -1
- package/dist/utils/trust-cache.d.ts +0 -29
- package/dist/utils/trust-cache.d.ts.map +0 -1
- package/dist/utils/trust-cache.js +0 -122
- package/dist/utils/trust-cache.js.map +0 -1
- package/dist/utils/turbo-cat-knowledge.d.ts +0 -105
- package/dist/utils/turbo-cat-knowledge.d.ts.map +0 -1
- package/dist/utils/turbo-cat-knowledge.js +0 -1941
- package/dist/utils/turbo-cat-knowledge.js.map +0 -1
- package/dist/utils/turbo-cat-pyramid.d.ts +0 -48
- package/dist/utils/turbo-cat-pyramid.d.ts.map +0 -1
- package/dist/utils/turbo-cat-pyramid.js +0 -380
- package/dist/utils/turbo-cat-pyramid.js.map +0 -1
- package/dist/utils/turbo-cat.d.ts +0 -99
- package/dist/utils/turbo-cat.d.ts.map +0 -1
- package/dist/utils/turbo-cat.js +0 -456
- package/dist/utils/turbo-cat.js.map +0 -1
- package/dist/utils/universal-fuzzy-detector.d.ts +0 -64
- package/dist/utils/universal-fuzzy-detector.d.ts.map +0 -1
- package/dist/utils/universal-fuzzy-detector.js +0 -386
- package/dist/utils/universal-fuzzy-detector.js.map +0 -1
- package/dist/utils/update-checker.d.ts +0 -15
- package/dist/utils/update-checker.d.ts.map +0 -1
- package/dist/utils/update-checker.js +0 -200
- package/dist/utils/update-checker.js.map +0 -1
- package/dist/utils/vibe-sync.d.ts +0 -25
- package/dist/utils/vibe-sync.d.ts.map +0 -1
- package/dist/utils/vibe-sync.js +0 -175
- package/dist/utils/vibe-sync.js.map +0 -1
- package/dist/utils/yaml-generator.d.ts +0 -52
- package/dist/utils/yaml-generator.d.ts.map +0 -1
- package/dist/utils/yaml-generator.js +0 -432
- package/dist/utils/yaml-generator.js.map +0 -1
- package/faf-banner.png +0 -0
- package/scripts/ANTHROPIC-DEMO.sh +0 -203
- package/scripts/boris-ready.sh +0 -169
- package/scripts/bundle-yaml.js +0 -87
- package/scripts/check-version.js +0 -88
- package/scripts/clean-build.js +0 -34
- package/scripts/cleanup-unused.sh +0 -54
- package/scripts/debug-django.txt +0 -9
- package/scripts/debug-mongo.txt +0 -9
- package/scripts/debug-react.txt +0 -9
- package/scripts/debug-rust.txt +0 -9
- package/scripts/debug-whisper.cpp.txt +0 -9
- package/scripts/evaluate-family-member.ts +0 -300
- package/scripts/generate-docs.ts +0 -358
- package/scripts/generate-drift-reports.sh +0 -111
- package/scripts/industry-showcase.json +0 -122
- package/scripts/mcp-ecosystem-research.sh +0 -58
- package/scripts/migrate-yaml-imports.sh +0 -55
- package/scripts/migrate-yaml.ts +0 -132
- package/scripts/performance-validation.ts +0 -460
- package/scripts/postinstall.js +0 -30
- package/scripts/prepare-release.ts +0 -421
- package/scripts/run-industry-showcase.ts +0 -237
- package/scripts/run-test-showcase.ts +0 -244
- package/scripts/setup-github-watch.sh +0 -43
- package/scripts/sync-version.js +0 -35
- package/scripts/test-integration-detection.ts +0 -93
- package/scripts/test-integration-simple.js +0 -93
- package/scripts/test-medal-progression.sh +0 -143
- package/scripts/test-showcase-results.json +0 -109
- package/scripts/test-showcase.json +0 -32
- package/scripts/update-version.js +0 -148
- package/scripts/verify-build.js +0 -343
- package/scripts/version-check.js +0 -78
- package/scripts/watch-discussions.sh +0 -86
|
@@ -1,315 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* 🔗 Mirror Engine - The Orchestrator
|
|
4
|
-
* Coordinates all C-Mirror operations
|
|
5
|
-
*
|
|
6
|
-
* This is the main engine that:
|
|
7
|
-
* - Detects which files need syncing
|
|
8
|
-
* - Calls the transformation functions
|
|
9
|
-
* - Uses atomic writes for safety
|
|
10
|
-
* - Emits events for broadcasting
|
|
11
|
-
* - Ensures zero slippage
|
|
12
|
-
*
|
|
13
|
-
* Usage:
|
|
14
|
-
* const engine = new MirrorEngine(config);
|
|
15
|
-
* const result = await engine.sync();
|
|
16
|
-
*/
|
|
17
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
18
|
-
if (k2 === undefined) k2 = k;
|
|
19
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
20
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
21
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
22
|
-
}
|
|
23
|
-
Object.defineProperty(o, k2, desc);
|
|
24
|
-
}) : (function(o, m, k, k2) {
|
|
25
|
-
if (k2 === undefined) k2 = k;
|
|
26
|
-
o[k2] = m[k];
|
|
27
|
-
}));
|
|
28
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
29
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
30
|
-
}) : function(o, v) {
|
|
31
|
-
o["default"] = v;
|
|
32
|
-
});
|
|
33
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
34
|
-
var ownKeys = function(o) {
|
|
35
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
36
|
-
var ar = [];
|
|
37
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
38
|
-
return ar;
|
|
39
|
-
};
|
|
40
|
-
return ownKeys(o);
|
|
41
|
-
};
|
|
42
|
-
return function (mod) {
|
|
43
|
-
if (mod && mod.__esModule) return mod;
|
|
44
|
-
var result = {};
|
|
45
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
46
|
-
__setModuleDefault(result, mod);
|
|
47
|
-
return result;
|
|
48
|
-
};
|
|
49
|
-
})();
|
|
50
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
51
|
-
exports.MirrorEngine = void 0;
|
|
52
|
-
const yaml_1 = require("../../../fix-once/yaml");
|
|
53
|
-
const faf_to_claude_1 = require("./faf-to-claude");
|
|
54
|
-
const claude_to_faf_1 = require("./claude-to-faf");
|
|
55
|
-
const atomic_write_1 = require("../strategies/atomic-write");
|
|
56
|
-
const event_emitter_1 = require("./events/event-emitter");
|
|
57
|
-
const mirror_events_1 = require("./events/mirror-events");
|
|
58
|
-
class MirrorEngine {
|
|
59
|
-
config;
|
|
60
|
-
projectPath;
|
|
61
|
-
constructor(config) {
|
|
62
|
-
this.config = {
|
|
63
|
-
atomicWrites: true, // Default to safe writes
|
|
64
|
-
selfHealing: true, // Default to auto-recovery
|
|
65
|
-
...config
|
|
66
|
-
};
|
|
67
|
-
this.projectPath = config.projectPath || process.cwd();
|
|
68
|
-
}
|
|
69
|
-
/**
|
|
70
|
-
* Main sync operation
|
|
71
|
-
* Intelligently syncs .faf ↔ CLAUDE.md
|
|
72
|
-
*/
|
|
73
|
-
async sync() {
|
|
74
|
-
const startTime = Date.now();
|
|
75
|
-
const result = {
|
|
76
|
-
success: false,
|
|
77
|
-
direction: 'none',
|
|
78
|
-
filesChanged: [],
|
|
79
|
-
conflicts: [],
|
|
80
|
-
duration: 0,
|
|
81
|
-
integrity: 'perfect'
|
|
82
|
-
};
|
|
83
|
-
try {
|
|
84
|
-
// Step 1: Analyze file states
|
|
85
|
-
const analysis = await this.analyzeFiles();
|
|
86
|
-
// Step 2: Determine sync strategy
|
|
87
|
-
const strategy = this.determineSyncStrategy(analysis);
|
|
88
|
-
result.direction = strategy;
|
|
89
|
-
// Step 3: Execute sync based on strategy
|
|
90
|
-
if (strategy === 'none') {
|
|
91
|
-
// No sync needed
|
|
92
|
-
result.success = true;
|
|
93
|
-
result.duration = Date.now() - startTime;
|
|
94
|
-
return result;
|
|
95
|
-
}
|
|
96
|
-
if (strategy === 'faf-to-claude') {
|
|
97
|
-
await this.syncFafToClaude(analysis);
|
|
98
|
-
result.filesChanged.push(this.config.readableFile);
|
|
99
|
-
}
|
|
100
|
-
else if (strategy === 'claude-to-faf') {
|
|
101
|
-
await this.syncClaudeToFaf(analysis);
|
|
102
|
-
result.filesChanged.push(this.config.structuredFile);
|
|
103
|
-
}
|
|
104
|
-
else if (strategy === 'bidirectional') {
|
|
105
|
-
// Both files changed - attempt intelligent merge
|
|
106
|
-
// For now, faf wins (can be enhanced later)
|
|
107
|
-
await this.syncFafToClaude(analysis);
|
|
108
|
-
result.filesChanged.push(this.config.readableFile);
|
|
109
|
-
result.conflicts.push('Both files modified - .faf took precedence');
|
|
110
|
-
}
|
|
111
|
-
// Step 4: Verify integrity
|
|
112
|
-
const integrityCheck = await this.verifyIntegrity();
|
|
113
|
-
result.integrity = integrityCheck.status;
|
|
114
|
-
// Step 5: Success
|
|
115
|
-
result.success = true;
|
|
116
|
-
result.duration = Date.now() - startTime;
|
|
117
|
-
// EMIT: Score update (if available)
|
|
118
|
-
if (integrityCheck.score) {
|
|
119
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.SCORE_UPDATE, {
|
|
120
|
-
score: integrityCheck.score
|
|
121
|
-
}, {
|
|
122
|
-
projectPath: this.projectPath,
|
|
123
|
-
score: integrityCheck.score,
|
|
124
|
-
duration: result.duration
|
|
125
|
-
}));
|
|
126
|
-
}
|
|
127
|
-
return result;
|
|
128
|
-
}
|
|
129
|
-
catch (error) {
|
|
130
|
-
result.success = false;
|
|
131
|
-
result.error = error instanceof Error ? error.message : String(error);
|
|
132
|
-
result.duration = Date.now() - startTime;
|
|
133
|
-
result.integrity = 'failed';
|
|
134
|
-
return result;
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
/**
|
|
138
|
-
* Analyze file states to determine what needs syncing
|
|
139
|
-
*/
|
|
140
|
-
async analyzeFiles() {
|
|
141
|
-
const fafPath = this.config.structuredFile;
|
|
142
|
-
const claudePath = this.config.readableFile;
|
|
143
|
-
const fafExists = await (0, atomic_write_1.fileExists)(fafPath);
|
|
144
|
-
const claudeExists = await (0, atomic_write_1.fileExists)(claudePath);
|
|
145
|
-
const fafModified = fafExists ? await (0, atomic_write_1.getFileModifiedTime)(fafPath) : null;
|
|
146
|
-
const claudeModified = claudeExists ? await (0, atomic_write_1.getFileModifiedTime)(claudePath) : null;
|
|
147
|
-
const fafState = {
|
|
148
|
-
path: fafPath,
|
|
149
|
-
exists: fafExists,
|
|
150
|
-
modified: fafModified || undefined
|
|
151
|
-
};
|
|
152
|
-
const claudeState = {
|
|
153
|
-
path: claudePath,
|
|
154
|
-
exists: claudeExists,
|
|
155
|
-
modified: claudeModified || undefined
|
|
156
|
-
};
|
|
157
|
-
return { fafState, claudeState };
|
|
158
|
-
}
|
|
159
|
-
/**
|
|
160
|
-
* Determine sync strategy based on file states
|
|
161
|
-
*/
|
|
162
|
-
determineSyncStrategy(analysis) {
|
|
163
|
-
const { fafState, claudeState } = analysis;
|
|
164
|
-
// If neither exists, nothing to sync
|
|
165
|
-
if (!fafState.exists && !claudeState.exists) {
|
|
166
|
-
return 'none';
|
|
167
|
-
}
|
|
168
|
-
// If only .faf exists, create CLAUDE.md
|
|
169
|
-
if (fafState.exists && !claudeState.exists) {
|
|
170
|
-
return 'faf-to-claude';
|
|
171
|
-
}
|
|
172
|
-
// If only CLAUDE.md exists, create .faf (unusual but handle it)
|
|
173
|
-
if (!fafState.exists && claudeState.exists) {
|
|
174
|
-
return 'claude-to-faf';
|
|
175
|
-
}
|
|
176
|
-
// Both exist - check modification times
|
|
177
|
-
if (fafState.modified && claudeState.modified) {
|
|
178
|
-
const fafTime = fafState.modified.getTime();
|
|
179
|
-
const claudeTime = claudeState.modified.getTime();
|
|
180
|
-
// If .faf is newer, sync to CLAUDE.md
|
|
181
|
-
if (fafTime > claudeTime) {
|
|
182
|
-
return 'faf-to-claude';
|
|
183
|
-
}
|
|
184
|
-
// If CLAUDE.md is newer, sync to .faf
|
|
185
|
-
if (claudeTime > fafTime) {
|
|
186
|
-
return 'claude-to-faf';
|
|
187
|
-
}
|
|
188
|
-
// If same time, no sync needed
|
|
189
|
-
return 'none';
|
|
190
|
-
}
|
|
191
|
-
// Default: faf to claude
|
|
192
|
-
return 'faf-to-claude';
|
|
193
|
-
}
|
|
194
|
-
/**
|
|
195
|
-
* Sync .faf → CLAUDE.md
|
|
196
|
-
* RULE: Score can only improve - never downgrade rich custom content
|
|
197
|
-
*/
|
|
198
|
-
async syncFafToClaude(analysis) {
|
|
199
|
-
const fafContent = await (0, atomic_write_1.safeRead)(this.config.structuredFile, this.projectPath);
|
|
200
|
-
const generatedContent = await (0, faf_to_claude_1.fafToClaudeMd)(fafContent, this.projectPath);
|
|
201
|
-
// If CLAUDE.md exists, check if we'd be downgrading
|
|
202
|
-
if (analysis.claudeState.exists) {
|
|
203
|
-
const existingContent = await (0, atomic_write_1.safeRead)(this.config.readableFile, this.projectPath);
|
|
204
|
-
// Check if existing is richer (custom content)
|
|
205
|
-
const existingLines = existingContent.split('\n').length;
|
|
206
|
-
const generatedLines = generatedContent.split('\n').length;
|
|
207
|
-
const existingLength = existingContent.length;
|
|
208
|
-
const generatedLength = generatedContent.length;
|
|
209
|
-
// Markers that indicate custom content (not generated by bi-sync)
|
|
210
|
-
const hasCustomMarkers = !existingContent.includes('🏎️⚡️_championship_sync') || // No bi-sync footer
|
|
211
|
-
existingContent.includes('## TOOLS') || // Custom sections
|
|
212
|
-
existingContent.includes('## ENDPOINTS') ||
|
|
213
|
-
existingContent.includes('## AUTH') ||
|
|
214
|
-
existingContent.includes('## COMMANDS') ||
|
|
215
|
-
existingContent.includes('| Tool |') || // Tables
|
|
216
|
-
existingContent.includes('| Endpoint |') ||
|
|
217
|
-
existingContent.includes('```bash'); // Code blocks
|
|
218
|
-
// If existing has custom markers, preserve it (RULE: score can only improve)
|
|
219
|
-
if (hasCustomMarkers) {
|
|
220
|
-
// Only update the sync footer, preserve custom content
|
|
221
|
-
const syncFooter = `\n---\n\n**STATUS: BI-SYNC ACTIVE 🔗 - Synchronized with .faf context!**\n\n*Last Sync: ${new Date().toISOString()}*\n*Sync Engine: F1-Inspired Software Engineering*\n*🏎️⚡️_championship_sync*\n`;
|
|
222
|
-
// Remove old footer if present, add new one
|
|
223
|
-
let updatedContent = existingContent.replace(/\n---\n\n\*\*STATUS: BI-SYNC ACTIVE.*?_championship_sync\*\n?$/s, '');
|
|
224
|
-
updatedContent = updatedContent.trimEnd() + syncFooter;
|
|
225
|
-
if (this.config.atomicWrites) {
|
|
226
|
-
await (0, atomic_write_1.atomicWrite)(this.config.readableFile, updatedContent, this.projectPath);
|
|
227
|
-
}
|
|
228
|
-
else {
|
|
229
|
-
const fs = await Promise.resolve().then(() => __importStar(require('fs/promises')));
|
|
230
|
-
await fs.writeFile(this.config.readableFile, updatedContent, 'utf-8');
|
|
231
|
-
}
|
|
232
|
-
// Emit event indicating custom content preserved
|
|
233
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.SYNC_PROGRESS, {
|
|
234
|
-
step: 'preserving-custom',
|
|
235
|
-
progress: 100,
|
|
236
|
-
message: 'Custom CLAUDE.md preserved - footer updated only'
|
|
237
|
-
}, { projectPath: this.projectPath }));
|
|
238
|
-
return;
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
// Standard sync - write generated content
|
|
242
|
-
if (this.config.atomicWrites) {
|
|
243
|
-
await (0, atomic_write_1.atomicWrite)(this.config.readableFile, generatedContent, this.projectPath);
|
|
244
|
-
}
|
|
245
|
-
else {
|
|
246
|
-
// Direct write (not recommended)
|
|
247
|
-
const fs = await Promise.resolve().then(() => __importStar(require('fs/promises')));
|
|
248
|
-
await fs.writeFile(this.config.readableFile, generatedContent, 'utf-8');
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
/**
|
|
252
|
-
* Sync CLAUDE.md → .faf
|
|
253
|
-
*/
|
|
254
|
-
async syncClaudeToFaf(analysis) {
|
|
255
|
-
const claudeContent = await (0, atomic_write_1.safeRead)(this.config.readableFile, this.projectPath);
|
|
256
|
-
// Load existing .faf data (or create minimal structure)
|
|
257
|
-
let existingFafData = {};
|
|
258
|
-
if (analysis.fafState.exists) {
|
|
259
|
-
const fafContent = await (0, atomic_write_1.safeRead)(this.config.structuredFile, this.projectPath);
|
|
260
|
-
existingFafData = (0, yaml_1.parse)(fafContent);
|
|
261
|
-
}
|
|
262
|
-
const updatedFafContent = await (0, claude_to_faf_1.claudeMdToFaf)(claudeContent, existingFafData, this.projectPath);
|
|
263
|
-
if (this.config.atomicWrites) {
|
|
264
|
-
await (0, atomic_write_1.atomicWrite)(this.config.structuredFile, updatedFafContent, this.projectPath);
|
|
265
|
-
}
|
|
266
|
-
else {
|
|
267
|
-
// Direct write (not recommended)
|
|
268
|
-
const fs = await Promise.resolve().then(() => __importStar(require('fs/promises')));
|
|
269
|
-
await fs.writeFile(this.config.structuredFile, updatedFafContent, 'utf-8');
|
|
270
|
-
}
|
|
271
|
-
}
|
|
272
|
-
/**
|
|
273
|
-
* Verify integrity after sync
|
|
274
|
-
* Ensures mirror is perfect
|
|
275
|
-
*/
|
|
276
|
-
async verifyIntegrity() {
|
|
277
|
-
try {
|
|
278
|
-
// Check both files exist
|
|
279
|
-
const fafExists = await (0, atomic_write_1.fileExists)(this.config.structuredFile);
|
|
280
|
-
const claudeExists = await (0, atomic_write_1.fileExists)(this.config.readableFile);
|
|
281
|
-
if (!fafExists || !claudeExists) {
|
|
282
|
-
return { status: 'failed' };
|
|
283
|
-
}
|
|
284
|
-
// Parse .faf to get score
|
|
285
|
-
const fafContent = await (0, atomic_write_1.safeRead)(this.config.structuredFile, this.projectPath);
|
|
286
|
-
const parsedData = (0, yaml_1.parse)(fafContent);
|
|
287
|
-
const fafData = (!parsedData || typeof parsedData !== 'object') ? {} : parsedData;
|
|
288
|
-
const score = fafData.ai_score !== undefined && fafData.human_score !== undefined ? {
|
|
289
|
-
ai: fafData.ai_score,
|
|
290
|
-
human: fafData.human_score,
|
|
291
|
-
total: fafData.faf_score ? parseInt(fafData.faf_score) : fafData.ai_score + fafData.human_score
|
|
292
|
-
} : undefined;
|
|
293
|
-
// Basic validation passed
|
|
294
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.INTEGRITY_PERFECT, {
|
|
295
|
-
message: 'Mirror integrity verified'
|
|
296
|
-
}, {
|
|
297
|
-
projectPath: this.projectPath,
|
|
298
|
-
integrity: 'perfect',
|
|
299
|
-
score
|
|
300
|
-
}));
|
|
301
|
-
return { status: 'perfect', score };
|
|
302
|
-
}
|
|
303
|
-
catch (error) {
|
|
304
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.INTEGRITY_FAILED, {
|
|
305
|
-
error: error instanceof Error ? error.message : String(error)
|
|
306
|
-
}, {
|
|
307
|
-
projectPath: this.projectPath,
|
|
308
|
-
integrity: 'failed'
|
|
309
|
-
}));
|
|
310
|
-
return { status: 'failed' };
|
|
311
|
-
}
|
|
312
|
-
}
|
|
313
|
-
}
|
|
314
|
-
exports.MirrorEngine = MirrorEngine;
|
|
315
|
-
//# sourceMappingURL=mirror-engine.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mirror-engine.js","sourceRoot":"","sources":["../../../../src/engines/c-mirror/core/mirror-engine.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 🩵 FAF Mirror - Convenience Wrapper
|
|
3
|
-
* Simple FAF-specific interface for C-Mirror
|
|
4
|
-
*
|
|
5
|
-
* This wrapper:
|
|
6
|
-
* - Uses FAF defaults (.faf and CLAUDE.md)
|
|
7
|
-
* - Includes FAF-specific validators
|
|
8
|
-
* - Integrates with FAF DNA chain
|
|
9
|
-
* - Provides championship communication
|
|
10
|
-
*
|
|
11
|
-
* Usage:
|
|
12
|
-
* const mirror = new FAFMirror();
|
|
13
|
-
* await mirror.sync();
|
|
14
|
-
*/
|
|
15
|
-
import { IMirrorConfig, IMirrorResult } from '../core/interfaces';
|
|
16
|
-
export declare class FAFMirror {
|
|
17
|
-
private engine;
|
|
18
|
-
private projectPath;
|
|
19
|
-
private displayStarted;
|
|
20
|
-
private initPromise;
|
|
21
|
-
constructor(projectPath?: string, options?: Partial<IMirrorConfig>);
|
|
22
|
-
private initialize;
|
|
23
|
-
/**
|
|
24
|
-
* Sync .faf ↔ CLAUDE.md
|
|
25
|
-
* With championship terminal display
|
|
26
|
-
*/
|
|
27
|
-
sync(): Promise<IMirrorResult>;
|
|
28
|
-
/**
|
|
29
|
-
* Stop display (cleanup)
|
|
30
|
-
*/
|
|
31
|
-
stop(): void;
|
|
32
|
-
}
|
|
33
|
-
//# sourceMappingURL=faf-mirror.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"faf-mirror.d.ts","sourceRoot":"","sources":["../../../../src/engines/c-mirror/faf-extensions/faf-mirror.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAIH,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAIlE,qBAAa,SAAS;IACpB,OAAO,CAAC,MAAM,CAA6B;IAC3C,OAAO,CAAC,WAAW,CAAS;IAC5B,OAAO,CAAC,cAAc,CAAkB;IACxC,OAAO,CAAC,WAAW,CAAgB;gBAEvB,WAAW,GAAE,MAAsB,EAAE,OAAO,GAAE,OAAO,CAAC,aAAa,CAAM;YAOvE,UAAU;IAuBxB;;;OAGG;IACG,IAAI,IAAI,OAAO,CAAC,aAAa,CAAC;IAoBpC;;OAEG;IACH,IAAI,IAAI,IAAI;CAMb"}
|
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* 🩵 FAF Mirror - Convenience Wrapper
|
|
4
|
-
* Simple FAF-specific interface for C-Mirror
|
|
5
|
-
*
|
|
6
|
-
* This wrapper:
|
|
7
|
-
* - Uses FAF defaults (.faf and CLAUDE.md)
|
|
8
|
-
* - Includes FAF-specific validators
|
|
9
|
-
* - Integrates with FAF DNA chain
|
|
10
|
-
* - Provides championship communication
|
|
11
|
-
*
|
|
12
|
-
* Usage:
|
|
13
|
-
* const mirror = new FAFMirror();
|
|
14
|
-
* await mirror.sync();
|
|
15
|
-
*/
|
|
16
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
17
|
-
if (k2 === undefined) k2 = k;
|
|
18
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
19
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
20
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
21
|
-
}
|
|
22
|
-
Object.defineProperty(o, k2, desc);
|
|
23
|
-
}) : (function(o, m, k, k2) {
|
|
24
|
-
if (k2 === undefined) k2 = k;
|
|
25
|
-
o[k2] = m[k];
|
|
26
|
-
}));
|
|
27
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
28
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
29
|
-
}) : function(o, v) {
|
|
30
|
-
o["default"] = v;
|
|
31
|
-
});
|
|
32
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
33
|
-
var ownKeys = function(o) {
|
|
34
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
35
|
-
var ar = [];
|
|
36
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
37
|
-
return ar;
|
|
38
|
-
};
|
|
39
|
-
return ownKeys(o);
|
|
40
|
-
};
|
|
41
|
-
return function (mod) {
|
|
42
|
-
if (mod && mod.__esModule) return mod;
|
|
43
|
-
var result = {};
|
|
44
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
45
|
-
__setModuleDefault(result, mod);
|
|
46
|
-
return result;
|
|
47
|
-
};
|
|
48
|
-
})();
|
|
49
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
50
|
-
exports.FAFMirror = void 0;
|
|
51
|
-
const path = __importStar(require("path"));
|
|
52
|
-
const mirror_engine_1 = require("../core/mirror-engine");
|
|
53
|
-
const terminal_display_1 = require("../broadcast/terminal-display");
|
|
54
|
-
const file_utils_1 = require("../../../utils/file-utils");
|
|
55
|
-
class FAFMirror {
|
|
56
|
-
engine = null;
|
|
57
|
-
projectPath;
|
|
58
|
-
displayStarted = false;
|
|
59
|
-
initPromise;
|
|
60
|
-
constructor(projectPath = process.cwd(), options = {}) {
|
|
61
|
-
this.projectPath = projectPath;
|
|
62
|
-
// Initialize async to find correct .faf file
|
|
63
|
-
this.initPromise = this.initialize(options);
|
|
64
|
-
}
|
|
65
|
-
async initialize(options = {}) {
|
|
66
|
-
// Find actual .faf file (project.faf preferred over .faf)
|
|
67
|
-
const fafPath = await (0, file_utils_1.findFafFile)(this.projectPath);
|
|
68
|
-
const structuredFile = fafPath || path.join(this.projectPath, 'project.faf');
|
|
69
|
-
// FAF defaults
|
|
70
|
-
const config = {
|
|
71
|
-
structuredFile,
|
|
72
|
-
readableFile: path.join(this.projectPath, 'CLAUDE.md'),
|
|
73
|
-
projectPath: this.projectPath,
|
|
74
|
-
atomicWrites: true, // Always use safe writes
|
|
75
|
-
selfHealing: true, // Always auto-recover
|
|
76
|
-
dnaChain: {
|
|
77
|
-
enabled: true, // DNA logging
|
|
78
|
-
path: path.join(this.projectPath, '.faf-dna.json'),
|
|
79
|
-
logLevel: 'standard'
|
|
80
|
-
},
|
|
81
|
-
...options
|
|
82
|
-
};
|
|
83
|
-
this.engine = new mirror_engine_1.MirrorEngine(config);
|
|
84
|
-
}
|
|
85
|
-
/**
|
|
86
|
-
* Sync .faf ↔ CLAUDE.md
|
|
87
|
-
* With championship terminal display
|
|
88
|
-
*/
|
|
89
|
-
async sync() {
|
|
90
|
-
// Wait for initialization to complete
|
|
91
|
-
await this.initPromise;
|
|
92
|
-
if (!this.engine) {
|
|
93
|
-
throw new Error('FAFMirror failed to initialize');
|
|
94
|
-
}
|
|
95
|
-
// Start terminal display (listens to events)
|
|
96
|
-
if (!this.displayStarted) {
|
|
97
|
-
(0, terminal_display_1.startTerminalDisplay)();
|
|
98
|
-
this.displayStarted = true;
|
|
99
|
-
}
|
|
100
|
-
// Run the sync
|
|
101
|
-
const result = await this.engine.sync();
|
|
102
|
-
return result;
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Stop display (cleanup)
|
|
106
|
-
*/
|
|
107
|
-
stop() {
|
|
108
|
-
if (this.displayStarted) {
|
|
109
|
-
(0, terminal_display_1.stopTerminalDisplay)();
|
|
110
|
-
this.displayStarted = false;
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
exports.FAFMirror = FAFMirror;
|
|
115
|
-
//# sourceMappingURL=faf-mirror.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"faf-mirror.js","sourceRoot":"","sources":["../../../../src/engines/c-mirror/faf-extensions/faf-mirror.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;GAaG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,2CAA6B;AAC7B,yDAAqD;AAErD,oEAA0F;AAC1F,0DAAwD;AAExD,MAAa,SAAS;IACZ,MAAM,GAAwB,IAAI,CAAC;IACnC,WAAW,CAAS;IACpB,cAAc,GAAY,KAAK,CAAC;IAChC,WAAW,CAAgB;IAEnC,YAAY,cAAsB,OAAO,CAAC,GAAG,EAAE,EAAE,UAAkC,EAAE;QACnF,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAE/B,6CAA6C;QAC7C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAC9C,CAAC;IAEO,KAAK,CAAC,UAAU,CAAC,UAAkC,EAAE;QAC3D,0DAA0D;QAC1D,MAAM,OAAO,GAAG,MAAM,IAAA,wBAAW,EAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpD,MAAM,cAAc,GAAG,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;QAE7E,eAAe;QACf,MAAM,MAAM,GAAkB;YAC5B,cAAc;YACd,YAAY,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC;YACtD,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,YAAY,EAAE,IAAI,EAAS,yBAAyB;YACpD,WAAW,EAAE,IAAI,EAAW,sBAAsB;YAClD,QAAQ,EAAE;gBACR,OAAO,EAAE,IAAI,EAAa,cAAc;gBACxC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,eAAe,CAAC;gBAClD,QAAQ,EAAE,UAAU;aACrB;YACD,GAAG,OAAO;SACX,CAAC;QAEF,IAAI,CAAC,MAAM,GAAG,IAAI,4BAAY,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,IAAI;QACR,sCAAsC;QACtC,MAAM,IAAI,CAAC,WAAW,CAAC;QAEvB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;QACpD,CAAC;QAED,6CAA6C;QAC7C,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,IAAA,uCAAoB,GAAE,CAAC;YACvB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC7B,CAAC;QAED,eAAe;QACf,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QAExC,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACH,IAAI;QACF,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,IAAA,sCAAmB,GAAE,CAAC;YACtB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC9B,CAAC;IACH,CAAC;CACF;AArED,8BAqEC"}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ⚛️ Atomic File Writer
|
|
3
|
-
* All-or-nothing file operations - Zero slippage design
|
|
4
|
-
*
|
|
5
|
-
* Strategy:
|
|
6
|
-
* 1. Write to .tmp file first
|
|
7
|
-
* 2. Validate the write succeeded
|
|
8
|
-
* 3. Atomic rename (OS-level atomic operation)
|
|
9
|
-
* 4. If ANY step fails, original file is untouched
|
|
10
|
-
*
|
|
11
|
-
* User NEVER sees partial state
|
|
12
|
-
*/
|
|
13
|
-
/**
|
|
14
|
-
* Atomic file write
|
|
15
|
-
* Implements all-or-nothing operation
|
|
16
|
-
*
|
|
17
|
-
* @param filePath - Target file path
|
|
18
|
-
* @param content - Content to write
|
|
19
|
-
* @param projectPath - Project root (for events)
|
|
20
|
-
*/
|
|
21
|
-
export declare function atomicWrite(filePath: string, content: string, projectPath?: string): Promise<void>;
|
|
22
|
-
/**
|
|
23
|
-
* Safe file read with error handling
|
|
24
|
-
*/
|
|
25
|
-
export declare function safeRead(filePath: string, projectPath?: string): Promise<string>;
|
|
26
|
-
/**
|
|
27
|
-
* Check if file exists
|
|
28
|
-
*/
|
|
29
|
-
export declare function fileExists(filePath: string): Promise<boolean>;
|
|
30
|
-
/**
|
|
31
|
-
* Get file modification time
|
|
32
|
-
*/
|
|
33
|
-
export declare function getFileModifiedTime(filePath: string): Promise<Date | null>;
|
|
34
|
-
//# sourceMappingURL=atomic-write.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"atomic-write.d.ts","sourceRoot":"","sources":["../../../../src/engines/c-mirror/strategies/atomic-write.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAOH;;;;;;;GAOG;AACH,wBAAsB,WAAW,CAC/B,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,EACf,WAAW,GAAE,MAAsB,GAClC,OAAO,CAAC,IAAI,CAAC,CAqFf;AAED;;GAEG;AACH,wBAAsB,QAAQ,CAC5B,QAAQ,EAAE,MAAM,EAChB,WAAW,GAAE,MAAsB,GAClC,OAAO,CAAC,MAAM,CAAC,CAqBjB;AAED;;GAEG;AACH,wBAAsB,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAEnE;AAED;;GAEG;AACH,wBAAsB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,CAOhF"}
|
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* ⚛️ Atomic File Writer
|
|
4
|
-
* All-or-nothing file operations - Zero slippage design
|
|
5
|
-
*
|
|
6
|
-
* Strategy:
|
|
7
|
-
* 1. Write to .tmp file first
|
|
8
|
-
* 2. Validate the write succeeded
|
|
9
|
-
* 3. Atomic rename (OS-level atomic operation)
|
|
10
|
-
* 4. If ANY step fails, original file is untouched
|
|
11
|
-
*
|
|
12
|
-
* User NEVER sees partial state
|
|
13
|
-
*/
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.atomicWrite = atomicWrite;
|
|
16
|
-
exports.safeRead = safeRead;
|
|
17
|
-
exports.fileExists = fileExists;
|
|
18
|
-
exports.getFileModifiedTime = getFileModifiedTime;
|
|
19
|
-
const fs_1 = require("fs");
|
|
20
|
-
const event_emitter_1 = require("../core/events/event-emitter");
|
|
21
|
-
const mirror_events_1 = require("../core/events/mirror-events");
|
|
22
|
-
/**
|
|
23
|
-
* Atomic file write
|
|
24
|
-
* Implements all-or-nothing operation
|
|
25
|
-
*
|
|
26
|
-
* @param filePath - Target file path
|
|
27
|
-
* @param content - Content to write
|
|
28
|
-
* @param projectPath - Project root (for events)
|
|
29
|
-
*/
|
|
30
|
-
async function atomicWrite(filePath, content, projectPath = process.cwd()) {
|
|
31
|
-
const tmpPath = `${filePath}.tmp`;
|
|
32
|
-
const backupPath = `${filePath}.backup`;
|
|
33
|
-
try {
|
|
34
|
-
// EMIT: Starting write
|
|
35
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.FILE_WRITE, {
|
|
36
|
-
file: filePath,
|
|
37
|
-
step: 'start'
|
|
38
|
-
}, { projectPath }));
|
|
39
|
-
// Step 1: Create backup of existing file (if exists)
|
|
40
|
-
const fileExists = await fs_1.promises.access(filePath).then(() => true).catch(() => false);
|
|
41
|
-
if (fileExists) {
|
|
42
|
-
await fs_1.promises.copyFile(filePath, backupPath);
|
|
43
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.FILE_BACKUP, {
|
|
44
|
-
original: filePath,
|
|
45
|
-
backup: backupPath
|
|
46
|
-
}, { projectPath }));
|
|
47
|
-
}
|
|
48
|
-
// Step 2: Write to temporary file
|
|
49
|
-
await fs_1.promises.writeFile(tmpPath, content, 'utf-8');
|
|
50
|
-
// Step 3: Validate the temporary file
|
|
51
|
-
const writtenContent = await fs_1.promises.readFile(tmpPath, 'utf-8');
|
|
52
|
-
if (writtenContent !== content) {
|
|
53
|
-
throw new Error('File validation failed: written content does not match');
|
|
54
|
-
}
|
|
55
|
-
// Step 4: Atomic rename (OS-level atomic operation)
|
|
56
|
-
await fs_1.promises.rename(tmpPath, filePath);
|
|
57
|
-
// Step 5: Clean up backup
|
|
58
|
-
if (fileExists) {
|
|
59
|
-
await fs_1.promises.unlink(backupPath).catch(() => {
|
|
60
|
-
// Ignore backup cleanup errors
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
// EMIT: Success
|
|
64
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.FILE_WRITE, {
|
|
65
|
-
file: filePath,
|
|
66
|
-
step: 'complete',
|
|
67
|
-
success: true
|
|
68
|
-
}, { projectPath }));
|
|
69
|
-
}
|
|
70
|
-
catch (error) {
|
|
71
|
-
// Cleanup temporary file if it exists
|
|
72
|
-
await fs_1.promises.unlink(tmpPath).catch(() => {
|
|
73
|
-
// Ignore cleanup errors
|
|
74
|
-
});
|
|
75
|
-
// Restore from backup if we have one
|
|
76
|
-
const backupExists = await fs_1.promises.access(backupPath).then(() => true).catch(() => false);
|
|
77
|
-
if (backupExists) {
|
|
78
|
-
await fs_1.promises.rename(backupPath, filePath).catch(() => {
|
|
79
|
-
// If restore fails, emit error but don't throw
|
|
80
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.ERROR, {
|
|
81
|
-
message: 'Failed to restore backup',
|
|
82
|
-
file: filePath
|
|
83
|
-
}, { projectPath }));
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
// EMIT: Error
|
|
87
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.ERROR, {
|
|
88
|
-
message: error instanceof Error ? error.message : String(error),
|
|
89
|
-
file: filePath,
|
|
90
|
-
recoverable: backupExists
|
|
91
|
-
}, { projectPath }));
|
|
92
|
-
throw error;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Safe file read with error handling
|
|
97
|
-
*/
|
|
98
|
-
async function safeRead(filePath, projectPath = process.cwd()) {
|
|
99
|
-
try {
|
|
100
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.FILE_READ, {
|
|
101
|
-
file: filePath
|
|
102
|
-
}, { projectPath }));
|
|
103
|
-
const content = await fs_1.promises.readFile(filePath, 'utf-8');
|
|
104
|
-
return content;
|
|
105
|
-
}
|
|
106
|
-
catch (error) {
|
|
107
|
-
event_emitter_1.mirrorEvents.emitMirrorEvent((0, mirror_events_1.createMirrorEvent)(mirror_events_1.MirrorEventType.ERROR, {
|
|
108
|
-
message: `Failed to read ${filePath}: ${error instanceof Error ? error.message : String(error)}`,
|
|
109
|
-
file: filePath
|
|
110
|
-
}, { projectPath }));
|
|
111
|
-
throw error;
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
/**
|
|
115
|
-
* Check if file exists
|
|
116
|
-
*/
|
|
117
|
-
async function fileExists(filePath) {
|
|
118
|
-
return fs_1.promises.access(filePath).then(() => true).catch(() => false);
|
|
119
|
-
}
|
|
120
|
-
/**
|
|
121
|
-
* Get file modification time
|
|
122
|
-
*/
|
|
123
|
-
async function getFileModifiedTime(filePath) {
|
|
124
|
-
try {
|
|
125
|
-
const stats = await fs_1.promises.stat(filePath);
|
|
126
|
-
return stats.mtime;
|
|
127
|
-
}
|
|
128
|
-
catch {
|
|
129
|
-
return null;
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
//# sourceMappingURL=atomic-write.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"atomic-write.js","sourceRoot":"","sources":["../../../../src/engines/c-mirror/strategies/atomic-write.ts"],"names":[],"mappings":"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"}
|