@su-record/vibe 2.8.52 → 2.8.53

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (417) hide show
  1. package/.env.example +37 -37
  2. package/CLAUDE.md +169 -169
  3. package/LICENSE +21 -21
  4. package/agents/architect-low.md +41 -41
  5. package/agents/architect-medium.md +59 -59
  6. package/agents/architect.md +80 -80
  7. package/agents/build-error-resolver.md +115 -115
  8. package/agents/compounder.md +261 -261
  9. package/agents/diagrammer.md +178 -178
  10. package/agents/docs/api-documenter.md +99 -99
  11. package/agents/docs/changelog-writer.md +93 -93
  12. package/agents/e2e-tester.md +294 -294
  13. package/agents/event/event-comms.md +78 -78
  14. package/agents/event/event-content.md +68 -68
  15. package/agents/event/event-image.md +95 -95
  16. package/agents/event/event-ops.md +84 -84
  17. package/agents/event/event-scheduler.md +69 -69
  18. package/agents/event/event-speaker.md +86 -86
  19. package/agents/explorer-low.md +42 -42
  20. package/agents/explorer-medium.md +59 -59
  21. package/agents/explorer.md +48 -48
  22. package/agents/implementer-low.md +43 -43
  23. package/agents/implementer-medium.md +52 -52
  24. package/agents/implementer.md +54 -54
  25. package/agents/junior-mentor.md +141 -141
  26. package/agents/planning/requirements-analyst.md +84 -84
  27. package/agents/planning/ux-advisor.md +83 -83
  28. package/agents/qa/acceptance-tester.md +86 -86
  29. package/agents/qa/edge-case-finder.md +93 -93
  30. package/agents/qa/qa-coordinator.md +131 -131
  31. package/agents/refactor-cleaner.md +143 -143
  32. package/agents/research/best-practices-agent.md +199 -199
  33. package/agents/research/codebase-patterns-agent.md +157 -157
  34. package/agents/research/framework-docs-agent.md +188 -188
  35. package/agents/research/security-advisory-agent.md +213 -213
  36. package/agents/review/architecture-reviewer.md +107 -107
  37. package/agents/review/complexity-reviewer.md +116 -116
  38. package/agents/review/data-integrity-reviewer.md +88 -88
  39. package/agents/review/git-history-reviewer.md +103 -103
  40. package/agents/review/performance-reviewer.md +86 -86
  41. package/agents/review/python-reviewer.md +150 -150
  42. package/agents/review/rails-reviewer.md +139 -139
  43. package/agents/review/react-reviewer.md +144 -144
  44. package/agents/review/security-reviewer.md +80 -80
  45. package/agents/review/simplicity-reviewer.md +140 -140
  46. package/agents/review/test-coverage-reviewer.md +116 -116
  47. package/agents/review/typescript-reviewer.md +127 -127
  48. package/agents/searcher.md +54 -54
  49. package/agents/simplifier.md +120 -120
  50. package/agents/tester.md +49 -49
  51. package/agents/ui/ui-a11y-auditor.md +93 -93
  52. package/agents/ui/ui-antipattern-detector.md +102 -102
  53. package/agents/ui/ui-dataviz-advisor.md +69 -69
  54. package/agents/ui/ui-design-system-gen.md +57 -57
  55. package/agents/ui/ui-industry-analyzer.md +49 -49
  56. package/agents/ui/ui-layout-architect.md +65 -65
  57. package/agents/ui/ui-stack-implementer.md +68 -68
  58. package/agents/ui/ux-compliance-reviewer.md +81 -81
  59. package/agents/ui-previewer.md +258 -258
  60. package/commands/vibe.analyze.md +379 -379
  61. package/commands/vibe.docs.md +32 -32
  62. package/commands/vibe.event.md +163 -163
  63. package/commands/vibe.figma.md +69 -69
  64. package/commands/vibe.review.md +686 -686
  65. package/commands/vibe.run.md +2276 -2276
  66. package/commands/vibe.spec.md +1195 -1195
  67. package/commands/vibe.spec.review.md +609 -609
  68. package/commands/vibe.trace.md +259 -259
  69. package/commands/vibe.utils.md +413 -413
  70. package/commands/vibe.verify.md +510 -510
  71. package/dist/cli/collaborator.js +52 -52
  72. package/dist/cli/commands/config.js +9 -9
  73. package/dist/cli/commands/evolution.js +12 -12
  74. package/dist/cli/commands/figma.js +20 -20
  75. package/dist/cli/commands/info.js +53 -53
  76. package/dist/cli/commands/init.js +5 -5
  77. package/dist/cli/commands/remove.js +14 -14
  78. package/dist/cli/commands/sentinel.js +27 -27
  79. package/dist/cli/commands/skills.js +5 -5
  80. package/dist/cli/commands/slack.js +10 -10
  81. package/dist/cli/commands/stats.js +6 -6
  82. package/dist/cli/commands/telegram.js +12 -12
  83. package/dist/cli/detect.js +32 -32
  84. package/dist/cli/index.js +51 -51
  85. package/dist/cli/llm/claude-commands.js +16 -16
  86. package/dist/cli/llm/config.js +18 -18
  87. package/dist/cli/llm/gemini-commands.js +16 -16
  88. package/dist/cli/llm/gpt-commands.js +19 -19
  89. package/dist/cli/llm/help.js +21 -21
  90. package/dist/cli/postinstall/cursor-agents.js +32 -32
  91. package/dist/cli/postinstall/cursor-rules.js +83 -83
  92. package/dist/cli/postinstall/cursor-skills.js +743 -743
  93. package/dist/cli/setup/Provisioner.js +42 -42
  94. package/dist/infra/lib/DeepInit.js +24 -24
  95. package/dist/infra/lib/IterationTracker.js +11 -11
  96. package/dist/infra/lib/PythonParser.js +108 -108
  97. package/dist/infra/lib/ReviewRace.js +96 -96
  98. package/dist/infra/lib/SkillFrontmatter.js +28 -28
  99. package/dist/infra/lib/SkillQualityGate.js +9 -9
  100. package/dist/infra/lib/SkillRepository.js +159 -159
  101. package/dist/infra/lib/TokenBudgetTracker.d.ts +13 -0
  102. package/dist/infra/lib/TokenBudgetTracker.d.ts.map +1 -1
  103. package/dist/infra/lib/TokenBudgetTracker.js +44 -3
  104. package/dist/infra/lib/TokenBudgetTracker.js.map +1 -1
  105. package/dist/infra/lib/UltraQA.js +99 -99
  106. package/dist/infra/lib/autonomy/AuditStore.js +41 -41
  107. package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
  108. package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
  109. package/dist/infra/lib/autonomy/PolicyEngine.d.ts +3 -3
  110. package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
  111. package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
  112. package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
  113. package/dist/infra/lib/embedding/VectorStore.js +22 -22
  114. package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
  115. package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
  116. package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
  117. package/dist/infra/lib/evolution/InsightStore.js +90 -90
  118. package/dist/infra/lib/evolution/ParityTester.js +57 -57
  119. package/dist/infra/lib/evolution/RollbackManager.js +5 -5
  120. package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
  121. package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
  122. package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
  123. package/dist/infra/lib/evolution/UsageTracker.js +28 -28
  124. package/dist/infra/lib/gemini/orchestration.js +5 -5
  125. package/dist/infra/lib/gpt/orchestration.js +4 -4
  126. package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
  127. package/dist/infra/lib/memory/MemorySearch.js +57 -57
  128. package/dist/infra/lib/memory/MemoryStorage.js +181 -181
  129. package/dist/infra/lib/memory/ObservationStore.js +28 -28
  130. package/dist/infra/lib/memory/ReflectionStore.js +30 -30
  131. package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
  132. package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
  133. package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
  134. package/dist/infra/orchestrator/AgentManager.js +12 -12
  135. package/dist/infra/orchestrator/AgentRegistry.js +65 -65
  136. package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
  137. package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
  138. package/dist/infra/orchestrator/parallelResearch.js +24 -24
  139. package/dist/tools/convention/analyzeComplexity.test.js +115 -115
  140. package/dist/tools/convention/validateCodeQuality.test.js +104 -104
  141. package/dist/tools/memory/createMemoryTimeline.js +10 -10
  142. package/dist/tools/memory/getMemoryGraph.js +12 -12
  143. package/dist/tools/memory/getSessionContext.js +9 -9
  144. package/dist/tools/memory/linkMemories.js +14 -14
  145. package/dist/tools/memory/listMemories.js +4 -4
  146. package/dist/tools/memory/recallMemory.js +4 -4
  147. package/dist/tools/memory/saveMemory.js +4 -4
  148. package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
  149. package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
  150. package/dist/tools/semantic/astGrep.test.js +6 -6
  151. package/dist/tools/spec/prdParser.test.js +171 -171
  152. package/dist/tools/spec/specGenerator.js +169 -169
  153. package/dist/tools/spec/traceabilityMatrix.js +64 -64
  154. package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
  155. package/hooks/gemini-hooks.json +73 -73
  156. package/hooks/hooks.json +174 -174
  157. package/hooks/scripts/__tests__/keyword-detector.test.js +199 -199
  158. package/hooks/scripts/__tests__/pre-tool-guard.test.js +286 -286
  159. package/hooks/scripts/__tests__/sentinel-guard.test.js +210 -210
  160. package/hooks/scripts/auto-commit.js +97 -97
  161. package/hooks/scripts/auto-format.js +64 -64
  162. package/hooks/scripts/auto-test.js +81 -81
  163. package/hooks/scripts/code-check.js +268 -268
  164. package/hooks/scripts/codex-detect.js +46 -46
  165. package/hooks/scripts/codex-review-gate.js +80 -80
  166. package/hooks/scripts/command-log.js +32 -32
  167. package/hooks/scripts/context-save.js +353 -353
  168. package/hooks/scripts/evolution-engine.js +91 -91
  169. package/hooks/scripts/figma-extract.js +635 -477
  170. package/hooks/scripts/hud-status.js +321 -321
  171. package/hooks/scripts/keyword-detector.js +214 -214
  172. package/hooks/scripts/llm-orchestrate.js +572 -572
  173. package/hooks/scripts/post-edit.js +32 -32
  174. package/hooks/scripts/pr-test-gate.js +52 -52
  175. package/hooks/scripts/pre-tool-guard.js +214 -159
  176. package/hooks/scripts/prompt-dispatcher.js +185 -185
  177. package/hooks/scripts/sentinel-guard.js +131 -131
  178. package/hooks/scripts/session-start.js +177 -177
  179. package/hooks/scripts/skill-injector.js +83 -83
  180. package/hooks/scripts/stop-notify.js +209 -209
  181. package/hooks/scripts/utils.js +243 -243
  182. package/languages/csharp-unity.md +515 -515
  183. package/languages/gdscript-godot.md +470 -470
  184. package/languages/ruby-rails.md +489 -489
  185. package/languages/typescript-angular.md +433 -433
  186. package/languages/typescript-astro.md +416 -416
  187. package/languages/typescript-electron.md +406 -406
  188. package/languages/typescript-nestjs.md +524 -524
  189. package/languages/typescript-svelte.md +407 -407
  190. package/languages/typescript-tauri.md +365 -365
  191. package/package.json +101 -101
  192. package/skills/agents-md/SKILL.md +121 -121
  193. package/skills/agents-md/rubrics/what-to-keep.md +49 -49
  194. package/skills/agents-md/templates/agents-md.md +36 -36
  195. package/skills/arch-guard/SKILL.md +181 -181
  196. package/skills/arch-guard/agents/detector.md +48 -48
  197. package/skills/arch-guard/agents/reporter.md +48 -48
  198. package/skills/arch-guard/agents/rule-generator.md +49 -49
  199. package/skills/arch-guard/agents/violation-checker.md +51 -51
  200. package/skills/arch-guard/frameworks/clean-architecture.md +108 -108
  201. package/skills/arch-guard/frameworks/solid.md +102 -102
  202. package/skills/arch-guard/scripts/check-boundaries.js +90 -90
  203. package/skills/arch-guard/templates/arch-rules.json +47 -47
  204. package/skills/arch-guard/templates/violation-report.md +53 -53
  205. package/skills/brand-assets/SKILL.md +147 -147
  206. package/skills/brand-assets/rubrics/asset-checklist.md +98 -98
  207. package/skills/brand-assets/templates/brand-guide.md +161 -161
  208. package/skills/capability-loop/SKILL.md +168 -168
  209. package/skills/capability-loop/agents/capability-designer.md +61 -61
  210. package/skills/capability-loop/agents/failure-analyst.md +55 -55
  211. package/skills/capability-loop/agents/implementer.md +50 -50
  212. package/skills/capability-loop/agents/tester.md +53 -53
  213. package/skills/capability-loop/templates/capability-spec.md +118 -118
  214. package/skills/capability-loop/templates/failure-analysis.md +118 -118
  215. package/skills/characterization-test/SKILL.md +207 -207
  216. package/skills/characterization-test/agents/behavior-capturer.md +50 -50
  217. package/skills/characterization-test/agents/coverage-checker.md +54 -54
  218. package/skills/characterization-test/agents/reporter.md +50 -50
  219. package/skills/characterization-test/agents/test-writer.md +49 -49
  220. package/skills/characterization-test/rubrics/coverage-criteria.md +53 -53
  221. package/skills/characterization-test/templates/test-template.ts +101 -101
  222. package/skills/chub-usage/SKILL.md +139 -139
  223. package/skills/claude-md-guide/SKILL.md +351 -351
  224. package/skills/claude-md-guide/rubrics/anti-patterns.md +88 -88
  225. package/skills/claude-md-guide/templates/claude-md.md +54 -54
  226. package/skills/commerce-patterns/SKILL.md +64 -64
  227. package/skills/commerce-patterns/rubrics/checkout-flow.md +48 -48
  228. package/skills/commerce-patterns/templates/product-schema.md +85 -85
  229. package/skills/commit-push-pr/SKILL.md +77 -77
  230. package/skills/commit-push-pr/agents/change-analyzer.md +55 -55
  231. package/skills/commit-push-pr/agents/message-writer.md +50 -50
  232. package/skills/commit-push-pr/agents/pr-writer.md +58 -58
  233. package/skills/commit-push-pr/agents/reviewer.md +52 -52
  234. package/skills/commit-push-pr/rubrics/commit-message.md +73 -73
  235. package/skills/commit-push-pr/templates/pr-body.md +63 -63
  236. package/skills/context7-usage/SKILL.md +106 -106
  237. package/skills/context7-usage/rubrics/when-to-use.md +50 -50
  238. package/skills/create-prd/SKILL.md +90 -90
  239. package/skills/create-prd/agents/edge-case-finder.md +48 -48
  240. package/skills/create-prd/agents/prioritizer.md +60 -60
  241. package/skills/create-prd/agents/requirements-writer.md +48 -48
  242. package/skills/create-prd/agents/researcher.md +55 -55
  243. package/skills/create-prd/agents/reviewer.md +54 -54
  244. package/skills/create-prd/frameworks/jobs-to-be-done.md +96 -96
  245. package/skills/create-prd/frameworks/rice-scoring.md +97 -97
  246. package/skills/create-prd/orchestrator.md +70 -70
  247. package/skills/create-prd/rubrics/completeness.md +58 -58
  248. package/skills/create-prd/templates/prd.md +139 -139
  249. package/skills/design-audit/SKILL.md +152 -152
  250. package/skills/design-audit/agents/a11y-auditor.md +43 -43
  251. package/skills/design-audit/agents/performance-auditor.md +46 -46
  252. package/skills/design-audit/agents/responsive-auditor.md +46 -46
  253. package/skills/design-audit/agents/scorer.md +47 -47
  254. package/skills/design-audit/agents/slop-detector.md +47 -47
  255. package/skills/design-audit/frameworks/core-web-vitals.md +107 -107
  256. package/skills/design-audit/frameworks/wcag-checklist.md +64 -64
  257. package/skills/design-audit/orchestrator.md +64 -64
  258. package/skills/design-audit/rubrics/ai-slop-patterns.md +83 -83
  259. package/skills/design-audit/rubrics/scoring.md +63 -63
  260. package/skills/design-audit/templates/report.md +88 -88
  261. package/skills/design-critique/SKILL.md +139 -139
  262. package/skills/design-critique/rubrics/ux-heuristics.md +143 -143
  263. package/skills/design-critique/templates/critique-report.md +86 -86
  264. package/skills/design-distill/SKILL.md +130 -130
  265. package/skills/design-distill/templates/design-system.md +132 -132
  266. package/skills/design-normalize/SKILL.md +133 -133
  267. package/skills/design-normalize/rubrics/token-naming.md +117 -117
  268. package/skills/design-normalize/templates/token-audit.md +89 -89
  269. package/skills/design-polish/SKILL.md +131 -131
  270. package/skills/design-polish/rubrics/polish-checklist.md +68 -68
  271. package/skills/design-polish/templates/polish-report.md +64 -64
  272. package/skills/design-teach/SKILL.md +182 -182
  273. package/skills/design-teach/rubrics/brand-personality.md +73 -73
  274. package/skills/design-teach/templates/design-context.json +36 -36
  275. package/skills/e2e-commerce/SKILL.md +62 -62
  276. package/skills/e2e-commerce/templates/test-scenarios.md +170 -170
  277. package/skills/event-comms/SKILL.md +162 -162
  278. package/skills/event-comms/templates/email-invite.md +99 -99
  279. package/skills/event-comms/templates/sns-post.md +133 -133
  280. package/skills/event-ops/SKILL.md +198 -198
  281. package/skills/event-ops/rubrics/contingency.md +85 -85
  282. package/skills/event-ops/templates/d-day-checklist.md +65 -65
  283. package/skills/event-planning/SKILL.md +132 -132
  284. package/skills/event-planning/rubrics/timeline.md +70 -70
  285. package/skills/event-planning/templates/event-plan.md +91 -91
  286. package/skills/exec-plan/SKILL.md +149 -149
  287. package/skills/exec-plan/agents/decomposer.md +47 -47
  288. package/skills/exec-plan/agents/dependency-mapper.md +44 -44
  289. package/skills/exec-plan/agents/estimator.md +43 -43
  290. package/skills/exec-plan/agents/validator.md +55 -55
  291. package/skills/exec-plan/orchestrator.md +70 -70
  292. package/skills/exec-plan/rubrics/complexity-scoring.md +75 -75
  293. package/skills/exec-plan/templates/plan.md +147 -147
  294. package/skills/git-worktree/SKILL.md +73 -73
  295. package/skills/git-worktree/rubrics/when-to-use.md +55 -55
  296. package/skills/handoff/SKILL.md +110 -110
  297. package/skills/handoff/agents/context-summarizer.md +51 -51
  298. package/skills/handoff/agents/document-writer.md +63 -63
  299. package/skills/handoff/agents/state-collector.md +53 -53
  300. package/skills/handoff/agents/verifier.md +48 -48
  301. package/skills/handoff/rubrics/completeness.md +62 -62
  302. package/skills/handoff/templates/handoff.md +107 -107
  303. package/skills/parallel-research/SKILL.md +89 -89
  304. package/skills/parallel-research/agents/best-practices.md +43 -43
  305. package/skills/parallel-research/agents/codebase-patterns.md +46 -46
  306. package/skills/parallel-research/agents/framework-docs.md +45 -45
  307. package/skills/parallel-research/agents/security-advisory.md +46 -46
  308. package/skills/parallel-research/agents/synthesizer.md +52 -52
  309. package/skills/parallel-research/experts/best-practices.md +50 -50
  310. package/skills/parallel-research/experts/codebase-patterns.md +70 -70
  311. package/skills/parallel-research/experts/framework-docs.md +65 -65
  312. package/skills/parallel-research/experts/security-advisory.md +69 -69
  313. package/skills/parallel-research/orchestrator.md +65 -65
  314. package/skills/parallel-research/templates/synthesis.md +101 -101
  315. package/skills/prioritization-frameworks/SKILL.md +87 -87
  316. package/skills/prioritization-frameworks/rubrics/frameworks.md +79 -79
  317. package/skills/prioritization-frameworks/templates/scoring-matrix.md +69 -69
  318. package/skills/priority-todos/SKILL.md +64 -64
  319. package/skills/priority-todos/rubrics/prioritization.md +70 -70
  320. package/skills/priority-todos/templates/todo-board.md +59 -59
  321. package/skills/seo-checklist/SKILL.md +58 -58
  322. package/skills/seo-checklist/frameworks/structured-data.md +153 -153
  323. package/skills/seo-checklist/rubrics/content-seo.md +42 -42
  324. package/skills/seo-checklist/rubrics/technical-seo.md +48 -48
  325. package/skills/techdebt/SKILL.md +124 -124
  326. package/skills/techdebt/agents/analyzer.md +50 -50
  327. package/skills/techdebt/agents/fixer.md +41 -41
  328. package/skills/techdebt/agents/reviewer.md +47 -47
  329. package/skills/techdebt/agents/scanner.md +44 -44
  330. package/skills/techdebt/orchestrator.md +70 -70
  331. package/skills/techdebt/rubrics/severity.md +51 -51
  332. package/skills/techdebt/scripts/scan.js +90 -90
  333. package/skills/techdebt/templates/report.md +86 -86
  334. package/skills/tool-fallback/SKILL.md +104 -104
  335. package/skills/tool-fallback/rubrics/fallback-chain.md +58 -58
  336. package/skills/typescript-advanced-types/SKILL.md +67 -67
  337. package/skills/typescript-advanced-types/rubrics/type-patterns.md +109 -109
  338. package/skills/ui-ux-pro-max/SKILL.md +236 -236
  339. package/skills/ui-ux-pro-max/reference/color-and-contrast.md +517 -517
  340. package/skills/ui-ux-pro-max/reference/interaction-design.md +544 -544
  341. package/skills/ui-ux-pro-max/reference/motion-design.md +591 -591
  342. package/skills/ui-ux-pro-max/reference/responsive-design.md +463 -463
  343. package/skills/ui-ux-pro-max/reference/spatial-design.md +390 -390
  344. package/skills/ui-ux-pro-max/reference/typography.md +455 -455
  345. package/skills/ui-ux-pro-max/reference/ux-writing.md +469 -469
  346. package/skills/ui-ux-pro-max/rubrics/interaction-states.md +83 -83
  347. package/skills/ui-ux-pro-max/rubrics/responsive-breakpoints.md +99 -99
  348. package/skills/user-personas/SKILL.md +75 -75
  349. package/skills/user-personas/rubrics/research-methods.md +56 -56
  350. package/skills/user-personas/templates/persona.md +89 -89
  351. package/skills/vercel-react-best-practices/SKILL.md +60 -60
  352. package/skills/vercel-react-best-practices/rubrics/performance.md +82 -82
  353. package/skills/vercel-react-best-practices/rubrics/server-components.md +86 -86
  354. package/skills/vibe.docs/SKILL.md +171 -171
  355. package/skills/vibe.docs/templates/architecture.md +80 -80
  356. package/skills/vibe.docs/templates/readme.md +84 -84
  357. package/skills/vibe.docs/templates/release-notes.md +74 -74
  358. package/skills/vibe.figma/SKILL.md +215 -982
  359. package/skills/vibe.figma/rubrics/extraction-checklist.md +51 -51
  360. package/skills/vibe.figma/templates/component-index.md +126 -126
  361. package/skills/vibe.figma/templates/figma-handoff.md +100 -100
  362. package/skills/vibe.figma/templates/remapped-tree.md +277 -277
  363. package/skills/vibe.figma.convert/SKILL.md +188 -511
  364. package/skills/vibe.figma.convert/rubrics/conversion-rules.md +129 -113
  365. package/skills/vibe.figma.convert/templates/component.md +140 -140
  366. package/skills/vibe.figma.extract/SKILL.md +179 -300
  367. package/skills/vibe.figma.extract/rubrics/image-rules.md +145 -137
  368. package/skills/video-production/SKILL.md +52 -52
  369. package/skills/video-production/rubrics/quality-checklist.md +58 -58
  370. package/skills/video-production/templates/production-plan.md +104 -104
  371. package/vibe/config.json +29 -29
  372. package/vibe/constitution.md +227 -227
  373. package/vibe/rules/principles/communication-guide.md +98 -98
  374. package/vibe/rules/principles/development-philosophy.md +52 -52
  375. package/vibe/rules/principles/quick-start.md +102 -102
  376. package/vibe/rules/quality/bdd-contract-testing.md +393 -393
  377. package/vibe/rules/quality/checklist.md +276 -276
  378. package/vibe/rules/quality/performance.md +236 -236
  379. package/vibe/rules/quality/testing-strategy.md +440 -440
  380. package/vibe/rules/standards/anti-patterns.md +541 -541
  381. package/vibe/rules/standards/code-structure.md +291 -291
  382. package/vibe/rules/standards/complexity-metrics.md +313 -313
  383. package/vibe/rules/standards/git-workflow.md +237 -237
  384. package/vibe/rules/standards/naming-conventions.md +198 -198
  385. package/vibe/rules/standards/security.md +305 -305
  386. package/vibe/rules/writing/document-style.md +74 -74
  387. package/vibe/setup.sh +31 -31
  388. package/vibe/templates/constitution-template.md +252 -252
  389. package/vibe/templates/contract-backend-template.md +526 -526
  390. package/vibe/templates/contract-frontend-template.md +599 -599
  391. package/vibe/templates/feature-template.md +96 -96
  392. package/vibe/templates/spec-template.md +221 -221
  393. package/vibe/ui-ux-data/charts.csv +26 -26
  394. package/vibe/ui-ux-data/colors.csv +97 -97
  395. package/vibe/ui-ux-data/icons.csv +101 -101
  396. package/vibe/ui-ux-data/landing.csv +31 -31
  397. package/vibe/ui-ux-data/products.csv +96 -96
  398. package/vibe/ui-ux-data/react-performance.csv +45 -45
  399. package/vibe/ui-ux-data/stacks/astro.csv +54 -54
  400. package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
  401. package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
  402. package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
  403. package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
  404. package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
  405. package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
  406. package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
  407. package/vibe/ui-ux-data/stacks/react.csv +54 -54
  408. package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
  409. package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
  410. package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
  411. package/vibe/ui-ux-data/stacks/vue.csv +50 -50
  412. package/vibe/ui-ux-data/styles.csv +68 -68
  413. package/vibe/ui-ux-data/typography.csv +57 -57
  414. package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
  415. package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
  416. package/vibe/ui-ux-data/version.json +31 -31
  417. package/vibe/ui-ux-data/web-interface.csv +31 -31
@@ -62,22 +62,22 @@ export class MemorySearch {
62
62
  return this.searchKeywordLike(query, limit, category);
63
63
  }
64
64
  if (category) {
65
- const stmt = this.db.prepare(`
66
- SELECT m.*, bm25(memories_fts) as rank
67
- FROM memories_fts fts
68
- JOIN memories m ON m.rowid = fts.rowid
69
- WHERE memories_fts MATCH ? AND m.category = ?
70
- ORDER BY rank
71
- LIMIT ?
65
+ const stmt = this.db.prepare(`
66
+ SELECT m.*, bm25(memories_fts) as rank
67
+ FROM memories_fts fts
68
+ JOIN memories m ON m.rowid = fts.rowid
69
+ WHERE memories_fts MATCH ? AND m.category = ?
70
+ ORDER BY rank
71
+ LIMIT ?
72
72
  `);
73
73
  return stmt.all(MemoryStorage.sanitizeFTS5Query(query), category, limit);
74
74
  }
75
75
  return this.storage.searchFTS(query, limit);
76
76
  }
77
77
  searchKeywordLike(query, limit, category) {
78
- let sql = `
79
- SELECT * FROM memories
80
- WHERE (key LIKE ? OR value LIKE ?)
78
+ let sql = `
79
+ SELECT * FROM memories
80
+ WHERE (key LIKE ? OR value LIKE ?)
81
81
  `;
82
82
  const params = [`%${query}%`, `%${query}%`];
83
83
  if (category) {
@@ -89,20 +89,20 @@ export class MemorySearch {
89
89
  return this.db.prepare(sql).all(...params);
90
90
  }
91
91
  searchTemporal(query, limit) {
92
- const sql = `
93
- SELECT * FROM memories
94
- WHERE key LIKE ? OR value LIKE ?
95
- ORDER BY timestamp DESC
96
- LIMIT ?
92
+ const sql = `
93
+ SELECT * FROM memories
94
+ WHERE key LIKE ? OR value LIKE ?
95
+ ORDER BY timestamp DESC
96
+ LIMIT ?
97
97
  `;
98
98
  return this.db.prepare(sql).all(`%${query}%`, `%${query}%`, limit);
99
99
  }
100
100
  searchByPriority(query, limit) {
101
- const sql = `
102
- SELECT * FROM memories
103
- WHERE key LIKE ? OR value LIKE ?
104
- ORDER BY priority DESC, lastAccessed DESC
105
- LIMIT ?
101
+ const sql = `
102
+ SELECT * FROM memories
103
+ WHERE key LIKE ? OR value LIKE ?
104
+ ORDER BY priority DESC, lastAccessed DESC
105
+ LIMIT ?
106
106
  `;
107
107
  return this.db.prepare(sql).all(`%${query}%`, `%${query}%`, limit);
108
108
  }
@@ -113,26 +113,26 @@ export class MemorySearch {
113
113
  let sql;
114
114
  const params = [];
115
115
  if (category) {
116
- sql = `
117
- SELECT m.*,
118
- (bm25(memories_fts) * -1 + m.priority * 0.5) as relevance_score
119
- FROM memories_fts fts
120
- JOIN memories m ON m.rowid = fts.rowid
121
- WHERE memories_fts MATCH ? AND m.category = ?
122
- ORDER BY relevance_score DESC, m.lastAccessed DESC
123
- LIMIT ?
116
+ sql = `
117
+ SELECT m.*,
118
+ (bm25(memories_fts) * -1 + m.priority * 0.5) as relevance_score
119
+ FROM memories_fts fts
120
+ JOIN memories m ON m.rowid = fts.rowid
121
+ WHERE memories_fts MATCH ? AND m.category = ?
122
+ ORDER BY relevance_score DESC, m.lastAccessed DESC
123
+ LIMIT ?
124
124
  `;
125
125
  params.push(MemoryStorage.sanitizeFTS5Query(query), category, limit);
126
126
  }
127
127
  else {
128
- sql = `
129
- SELECT m.*,
130
- (bm25(memories_fts) * -1 + m.priority * 0.5) as relevance_score
131
- FROM memories_fts fts
132
- JOIN memories m ON m.rowid = fts.rowid
133
- WHERE memories_fts MATCH ?
134
- ORDER BY relevance_score DESC, m.lastAccessed DESC
135
- LIMIT ?
128
+ sql = `
129
+ SELECT m.*,
130
+ (bm25(memories_fts) * -1 + m.priority * 0.5) as relevance_score
131
+ FROM memories_fts fts
132
+ JOIN memories m ON m.rowid = fts.rowid
133
+ WHERE memories_fts MATCH ?
134
+ ORDER BY relevance_score DESC, m.lastAccessed DESC
135
+ LIMIT ?
136
136
  `;
137
137
  params.push(MemoryStorage.sanitizeFTS5Query(query), limit);
138
138
  }
@@ -145,13 +145,13 @@ export class MemorySearch {
145
145
  }
146
146
  }
147
147
  // LIKE-based fallback
148
- let sql = `
149
- SELECT *,
150
- (CASE WHEN key LIKE ? THEN 3 ELSE 0 END +
151
- CASE WHEN value LIKE ? THEN 2 ELSE 0 END +
152
- priority * 0.5) as relevance_score
153
- FROM memories
154
- WHERE key LIKE ? OR value LIKE ?
148
+ let sql = `
149
+ SELECT *,
150
+ (CASE WHEN key LIKE ? THEN 3 ELSE 0 END +
151
+ CASE WHEN value LIKE ? THEN 2 ELSE 0 END +
152
+ priority * 0.5) as relevance_score
153
+ FROM memories
154
+ WHERE key LIKE ? OR value LIKE ?
155
155
  `;
156
156
  const params = [`%${query}%`, `%${query}%`, `%${query}%`, `%${query}%`];
157
157
  if (category) {
@@ -247,24 +247,24 @@ export class MemorySearch {
247
247
  let sql;
248
248
  const params = [];
249
249
  if (category) {
250
- sql = `
251
- SELECT m.key, bm25(memories_fts) as rank
252
- FROM memories_fts fts
253
- JOIN memories m ON m.rowid = fts.rowid
254
- WHERE memories_fts MATCH ? AND m.category = ?
255
- ORDER BY rank
256
- LIMIT ?
250
+ sql = `
251
+ SELECT m.key, bm25(memories_fts) as rank
252
+ FROM memories_fts fts
253
+ JOIN memories m ON m.rowid = fts.rowid
254
+ WHERE memories_fts MATCH ? AND m.category = ?
255
+ ORDER BY rank
256
+ LIMIT ?
257
257
  `;
258
258
  params.push(MemoryStorage.sanitizeFTS5Query(query), category, limit);
259
259
  }
260
260
  else {
261
- sql = `
262
- SELECT m.key, bm25(memories_fts) as rank
263
- FROM memories_fts fts
264
- JOIN memories m ON m.rowid = fts.rowid
265
- WHERE memories_fts MATCH ?
266
- ORDER BY rank
267
- LIMIT ?
261
+ sql = `
262
+ SELECT m.key, bm25(memories_fts) as rank
263
+ FROM memories_fts fts
264
+ JOIN memories m ON m.rowid = fts.rowid
265
+ WHERE memories_fts MATCH ?
266
+ ORDER BY rank
267
+ LIMIT ?
268
268
  `;
269
269
  params.push(MemoryStorage.sanitizeFTS5Query(query), limit);
270
270
  }
@@ -40,111 +40,111 @@ export class MemoryStorage {
40
40
  }
41
41
  initializeDatabase() {
42
42
  // Create memories table
43
- this.db.exec(`
44
- CREATE TABLE IF NOT EXISTS memories (
45
- key TEXT PRIMARY KEY,
46
- value TEXT NOT NULL,
47
- category TEXT NOT NULL DEFAULT 'general',
48
- timestamp TEXT NOT NULL,
49
- lastAccessed TEXT NOT NULL,
50
- priority INTEGER DEFAULT 0
51
- );
52
-
53
- CREATE INDEX IF NOT EXISTS idx_category ON memories(category);
54
- CREATE INDEX IF NOT EXISTS idx_timestamp ON memories(timestamp);
55
- CREATE INDEX IF NOT EXISTS idx_priority ON memories(priority);
56
- CREATE INDEX IF NOT EXISTS idx_lastAccessed ON memories(lastAccessed);
43
+ this.db.exec(`
44
+ CREATE TABLE IF NOT EXISTS memories (
45
+ key TEXT PRIMARY KEY,
46
+ value TEXT NOT NULL,
47
+ category TEXT NOT NULL DEFAULT 'general',
48
+ timestamp TEXT NOT NULL,
49
+ lastAccessed TEXT NOT NULL,
50
+ priority INTEGER DEFAULT 0
51
+ );
52
+
53
+ CREATE INDEX IF NOT EXISTS idx_category ON memories(category);
54
+ CREATE INDEX IF NOT EXISTS idx_timestamp ON memories(timestamp);
55
+ CREATE INDEX IF NOT EXISTS idx_priority ON memories(priority);
56
+ CREATE INDEX IF NOT EXISTS idx_lastAccessed ON memories(lastAccessed);
57
57
  `);
58
58
  // Create memory_relations table for Knowledge Graph
59
- this.db.exec(`
60
- CREATE TABLE IF NOT EXISTS memory_relations (
61
- id INTEGER PRIMARY KEY AUTOINCREMENT,
62
- sourceKey TEXT NOT NULL,
63
- targetKey TEXT NOT NULL,
64
- relationType TEXT NOT NULL,
65
- strength REAL DEFAULT 1.0,
66
- metadata TEXT,
67
- timestamp TEXT NOT NULL,
68
- UNIQUE(sourceKey, targetKey, relationType)
69
- );
70
-
71
- CREATE INDEX IF NOT EXISTS idx_rel_source ON memory_relations(sourceKey);
72
- CREATE INDEX IF NOT EXISTS idx_rel_target ON memory_relations(targetKey);
73
- CREATE INDEX IF NOT EXISTS idx_rel_type ON memory_relations(relationType);
59
+ this.db.exec(`
60
+ CREATE TABLE IF NOT EXISTS memory_relations (
61
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
62
+ sourceKey TEXT NOT NULL,
63
+ targetKey TEXT NOT NULL,
64
+ relationType TEXT NOT NULL,
65
+ strength REAL DEFAULT 1.0,
66
+ metadata TEXT,
67
+ timestamp TEXT NOT NULL,
68
+ UNIQUE(sourceKey, targetKey, relationType)
69
+ );
70
+
71
+ CREATE INDEX IF NOT EXISTS idx_rel_source ON memory_relations(sourceKey);
72
+ CREATE INDEX IF NOT EXISTS idx_rel_target ON memory_relations(targetKey);
73
+ CREATE INDEX IF NOT EXISTS idx_rel_type ON memory_relations(relationType);
74
74
  `);
75
75
  // Create observations table for structured observation capture
76
- this.db.exec(`
77
- CREATE TABLE IF NOT EXISTS observations (
78
- id INTEGER PRIMARY KEY AUTOINCREMENT,
79
- sessionId TEXT,
80
- type TEXT NOT NULL CHECK(type IN ('decision','bugfix','feature','refactor','discovery')),
81
- title TEXT NOT NULL,
82
- narrative TEXT,
83
- facts TEXT,
84
- concepts TEXT,
85
- filesModified TEXT,
86
- timestamp TEXT NOT NULL,
87
- projectPath TEXT
88
- );
89
-
90
- CREATE INDEX IF NOT EXISTS idx_obs_session ON observations(sessionId);
91
- CREATE INDEX IF NOT EXISTS idx_obs_type ON observations(type);
92
- CREATE INDEX IF NOT EXISTS idx_obs_timestamp ON observations(timestamp);
76
+ this.db.exec(`
77
+ CREATE TABLE IF NOT EXISTS observations (
78
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
79
+ sessionId TEXT,
80
+ type TEXT NOT NULL CHECK(type IN ('decision','bugfix','feature','refactor','discovery')),
81
+ title TEXT NOT NULL,
82
+ narrative TEXT,
83
+ facts TEXT,
84
+ concepts TEXT,
85
+ filesModified TEXT,
86
+ timestamp TEXT NOT NULL,
87
+ projectPath TEXT
88
+ );
89
+
90
+ CREATE INDEX IF NOT EXISTS idx_obs_session ON observations(sessionId);
91
+ CREATE INDEX IF NOT EXISTS idx_obs_type ON observations(type);
92
+ CREATE INDEX IF NOT EXISTS idx_obs_timestamp ON observations(timestamp);
93
93
  `);
94
94
  // Create session_summaries table
95
- this.db.exec(`
96
- CREATE TABLE IF NOT EXISTS session_summaries (
97
- id INTEGER PRIMARY KEY AUTOINCREMENT,
98
- sessionId TEXT UNIQUE NOT NULL,
99
- request TEXT,
100
- investigated TEXT,
101
- learned TEXT,
102
- completed TEXT,
103
- nextSteps TEXT,
104
- filesRead TEXT,
105
- filesEdited TEXT,
106
- timestamp TEXT NOT NULL
107
- );
108
-
109
- CREATE INDEX IF NOT EXISTS idx_ss_session ON session_summaries(sessionId);
110
- CREATE INDEX IF NOT EXISTS idx_ss_timestamp ON session_summaries(timestamp);
95
+ this.db.exec(`
96
+ CREATE TABLE IF NOT EXISTS session_summaries (
97
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
98
+ sessionId TEXT UNIQUE NOT NULL,
99
+ request TEXT,
100
+ investigated TEXT,
101
+ learned TEXT,
102
+ completed TEXT,
103
+ nextSteps TEXT,
104
+ filesRead TEXT,
105
+ filesEdited TEXT,
106
+ timestamp TEXT NOT NULL
107
+ );
108
+
109
+ CREATE INDEX IF NOT EXISTS idx_ss_session ON session_summaries(sessionId);
110
+ CREATE INDEX IF NOT EXISTS idx_ss_timestamp ON session_summaries(timestamp);
111
111
  `);
112
112
  // Create usage_events table for self-evolution (Phase 4)
113
- this.db.exec(`
114
- CREATE TABLE IF NOT EXISTS usage_events (
115
- id TEXT PRIMARY KEY,
116
- generationId TEXT NOT NULL,
117
- sessionId TEXT,
118
- matchedPrompt TEXT,
119
- feedback TEXT CHECK(feedback IN ('positive','negative','neutral') OR feedback IS NULL),
120
- createdAt TEXT NOT NULL
121
- );
122
-
123
- CREATE INDEX IF NOT EXISTS idx_ue_gen ON usage_events(generationId);
124
- CREATE INDEX IF NOT EXISTS idx_ue_session ON usage_events(sessionId);
125
- CREATE INDEX IF NOT EXISTS idx_ue_feedback ON usage_events(feedback);
126
- CREATE INDEX IF NOT EXISTS idx_ue_created ON usage_events(createdAt);
113
+ this.db.exec(`
114
+ CREATE TABLE IF NOT EXISTS usage_events (
115
+ id TEXT PRIMARY KEY,
116
+ generationId TEXT NOT NULL,
117
+ sessionId TEXT,
118
+ matchedPrompt TEXT,
119
+ feedback TEXT CHECK(feedback IN ('positive','negative','neutral') OR feedback IS NULL),
120
+ createdAt TEXT NOT NULL
121
+ );
122
+
123
+ CREATE INDEX IF NOT EXISTS idx_ue_gen ON usage_events(generationId);
124
+ CREATE INDEX IF NOT EXISTS idx_ue_session ON usage_events(sessionId);
125
+ CREATE INDEX IF NOT EXISTS idx_ue_feedback ON usage_events(feedback);
126
+ CREATE INDEX IF NOT EXISTS idx_ue_created ON usage_events(createdAt);
127
127
  `);
128
128
  // Create reflections table for self-evolution (Phase 1)
129
- this.db.exec(`
130
- CREATE TABLE IF NOT EXISTS reflections (
131
- id TEXT PRIMARY KEY,
132
- sessionId TEXT,
133
- type TEXT NOT NULL CHECK(type IN ('minor','major')),
134
- trigger TEXT NOT NULL CHECK(trigger IN ('context_pressure','session_end','manual')),
135
- insights TEXT,
136
- decisions TEXT,
137
- patterns TEXT,
138
- filesContext TEXT,
139
- score REAL DEFAULT 0.5 CHECK(score >= 0 AND score <= 1),
140
- createdAt TEXT NOT NULL
141
- );
142
-
143
- CREATE INDEX IF NOT EXISTS idx_refl_session ON reflections(sessionId);
144
- CREATE INDEX IF NOT EXISTS idx_refl_type ON reflections(type);
145
- CREATE INDEX IF NOT EXISTS idx_refl_trigger ON reflections(trigger);
146
- CREATE INDEX IF NOT EXISTS idx_refl_score ON reflections(score);
147
- CREATE INDEX IF NOT EXISTS idx_refl_created ON reflections(createdAt);
129
+ this.db.exec(`
130
+ CREATE TABLE IF NOT EXISTS reflections (
131
+ id TEXT PRIMARY KEY,
132
+ sessionId TEXT,
133
+ type TEXT NOT NULL CHECK(type IN ('minor','major')),
134
+ trigger TEXT NOT NULL CHECK(trigger IN ('context_pressure','session_end','manual')),
135
+ insights TEXT,
136
+ decisions TEXT,
137
+ patterns TEXT,
138
+ filesContext TEXT,
139
+ score REAL DEFAULT 0.5 CHECK(score >= 0 AND score <= 1),
140
+ createdAt TEXT NOT NULL
141
+ );
142
+
143
+ CREATE INDEX IF NOT EXISTS idx_refl_session ON reflections(sessionId);
144
+ CREATE INDEX IF NOT EXISTS idx_refl_type ON reflections(type);
145
+ CREATE INDEX IF NOT EXISTS idx_refl_trigger ON reflections(trigger);
146
+ CREATE INDEX IF NOT EXISTS idx_refl_score ON reflections(score);
147
+ CREATE INDEX IF NOT EXISTS idx_refl_created ON reflections(createdAt);
148
148
  `);
149
149
  // Enable WAL mode for better concurrency
150
150
  this.db.pragma('journal_mode = WAL');
@@ -156,56 +156,56 @@ export class MemoryStorage {
156
156
  initializeFTS5() {
157
157
  try {
158
158
  // Create FTS5 virtual table for memories
159
- this.db.exec(`
160
- CREATE VIRTUAL TABLE IF NOT EXISTS memories_fts
161
- USING fts5(key, value, content=memories, content_rowid=rowid);
159
+ this.db.exec(`
160
+ CREATE VIRTUAL TABLE IF NOT EXISTS memories_fts
161
+ USING fts5(key, value, content=memories, content_rowid=rowid);
162
162
  `);
163
163
  // Triggers to keep FTS5 in sync with memories table
164
- this.db.exec(`
165
- CREATE TRIGGER IF NOT EXISTS memories_ai AFTER INSERT ON memories BEGIN
166
- INSERT INTO memories_fts(rowid, key, value) VALUES (new.rowid, new.key, new.value);
167
- END;
168
- CREATE TRIGGER IF NOT EXISTS memories_ad AFTER DELETE ON memories BEGIN
169
- INSERT INTO memories_fts(memories_fts, rowid, key, value) VALUES('delete', old.rowid, old.key, old.value);
170
- END;
171
- CREATE TRIGGER IF NOT EXISTS memories_au AFTER UPDATE ON memories BEGIN
172
- INSERT INTO memories_fts(memories_fts, rowid, key, value) VALUES('delete', old.rowid, old.key, old.value);
173
- INSERT INTO memories_fts(rowid, key, value) VALUES (new.rowid, new.key, new.value);
174
- END;
164
+ this.db.exec(`
165
+ CREATE TRIGGER IF NOT EXISTS memories_ai AFTER INSERT ON memories BEGIN
166
+ INSERT INTO memories_fts(rowid, key, value) VALUES (new.rowid, new.key, new.value);
167
+ END;
168
+ CREATE TRIGGER IF NOT EXISTS memories_ad AFTER DELETE ON memories BEGIN
169
+ INSERT INTO memories_fts(memories_fts, rowid, key, value) VALUES('delete', old.rowid, old.key, old.value);
170
+ END;
171
+ CREATE TRIGGER IF NOT EXISTS memories_au AFTER UPDATE ON memories BEGIN
172
+ INSERT INTO memories_fts(memories_fts, rowid, key, value) VALUES('delete', old.rowid, old.key, old.value);
173
+ INSERT INTO memories_fts(rowid, key, value) VALUES (new.rowid, new.key, new.value);
174
+ END;
175
175
  `);
176
176
  // Create FTS5 for observations
177
- this.db.exec(`
178
- CREATE VIRTUAL TABLE IF NOT EXISTS observations_fts
179
- USING fts5(title, narrative, facts, concepts, content=observations, content_rowid=id);
180
-
181
- CREATE TRIGGER IF NOT EXISTS observations_ai AFTER INSERT ON observations BEGIN
182
- INSERT INTO observations_fts(rowid, title, narrative, facts, concepts)
183
- VALUES (new.id, new.title, new.narrative, new.facts, new.concepts);
184
- END;
185
- CREATE TRIGGER IF NOT EXISTS observations_ad AFTER DELETE ON observations BEGIN
186
- INSERT INTO observations_fts(observations_fts, rowid, title, narrative, facts, concepts)
187
- VALUES('delete', old.id, old.title, old.narrative, old.facts, old.concepts);
188
- END;
177
+ this.db.exec(`
178
+ CREATE VIRTUAL TABLE IF NOT EXISTS observations_fts
179
+ USING fts5(title, narrative, facts, concepts, content=observations, content_rowid=id);
180
+
181
+ CREATE TRIGGER IF NOT EXISTS observations_ai AFTER INSERT ON observations BEGIN
182
+ INSERT INTO observations_fts(rowid, title, narrative, facts, concepts)
183
+ VALUES (new.id, new.title, new.narrative, new.facts, new.concepts);
184
+ END;
185
+ CREATE TRIGGER IF NOT EXISTS observations_ad AFTER DELETE ON observations BEGIN
186
+ INSERT INTO observations_fts(observations_fts, rowid, title, narrative, facts, concepts)
187
+ VALUES('delete', old.id, old.title, old.narrative, old.facts, old.concepts);
188
+ END;
189
189
  `);
190
190
  // Create FTS5 for reflections
191
- this.db.exec(`
192
- CREATE VIRTUAL TABLE IF NOT EXISTS reflections_fts
193
- USING fts5(insights, decisions, patterns, content=reflections, content_rowid=rowid);
194
-
195
- CREATE TRIGGER IF NOT EXISTS reflections_ai AFTER INSERT ON reflections BEGIN
196
- INSERT INTO reflections_fts(rowid, insights, decisions, patterns)
197
- VALUES (new.rowid, new.insights, new.decisions, new.patterns);
198
- END;
199
- CREATE TRIGGER IF NOT EXISTS reflections_ad AFTER DELETE ON reflections BEGIN
200
- INSERT INTO reflections_fts(reflections_fts, rowid, insights, decisions, patterns)
201
- VALUES('delete', old.rowid, old.insights, old.decisions, old.patterns);
202
- END;
203
- CREATE TRIGGER IF NOT EXISTS reflections_au AFTER UPDATE ON reflections BEGIN
204
- INSERT INTO reflections_fts(reflections_fts, rowid, insights, decisions, patterns)
205
- VALUES('delete', old.rowid, old.insights, old.decisions, old.patterns);
206
- INSERT INTO reflections_fts(rowid, insights, decisions, patterns)
207
- VALUES (new.rowid, new.insights, new.decisions, new.patterns);
208
- END;
191
+ this.db.exec(`
192
+ CREATE VIRTUAL TABLE IF NOT EXISTS reflections_fts
193
+ USING fts5(insights, decisions, patterns, content=reflections, content_rowid=rowid);
194
+
195
+ CREATE TRIGGER IF NOT EXISTS reflections_ai AFTER INSERT ON reflections BEGIN
196
+ INSERT INTO reflections_fts(rowid, insights, decisions, patterns)
197
+ VALUES (new.rowid, new.insights, new.decisions, new.patterns);
198
+ END;
199
+ CREATE TRIGGER IF NOT EXISTS reflections_ad AFTER DELETE ON reflections BEGIN
200
+ INSERT INTO reflections_fts(reflections_fts, rowid, insights, decisions, patterns)
201
+ VALUES('delete', old.rowid, old.insights, old.decisions, old.patterns);
202
+ END;
203
+ CREATE TRIGGER IF NOT EXISTS reflections_au AFTER UPDATE ON reflections BEGIN
204
+ INSERT INTO reflections_fts(reflections_fts, rowid, insights, decisions, patterns)
205
+ VALUES('delete', old.rowid, old.insights, old.decisions, old.patterns);
206
+ INSERT INTO reflections_fts(rowid, insights, decisions, patterns)
207
+ VALUES (new.rowid, new.insights, new.decisions, new.patterns);
208
+ END;
209
209
  `);
210
210
  // Migrate existing data into FTS5 index
211
211
  const ftsCount = this.db.prepare(`SELECT COUNT(*) as cnt FROM memories_fts`).get().cnt;
@@ -227,10 +227,10 @@ export class MemoryStorage {
227
227
  }
228
228
  initializePreparedStatements() {
229
229
  try {
230
- this.recallStmt = this.db.prepare(`
231
- UPDATE memories SET lastAccessed = ?
232
- WHERE key = ?
233
- RETURNING *
230
+ this.recallStmt = this.db.prepare(`
231
+ UPDATE memories SET lastAccessed = ?
232
+ WHERE key = ?
233
+ RETURNING *
234
234
  `);
235
235
  }
236
236
  catch {
@@ -239,9 +239,9 @@ export class MemoryStorage {
239
239
  this.recallSelectStmt = this.db.prepare(`SELECT * FROM memories WHERE key = ?`);
240
240
  this.recallUpdateStmt = this.db.prepare(`UPDATE memories SET lastAccessed = ? WHERE key = ?`);
241
241
  }
242
- this.saveStmt = this.db.prepare(`
243
- INSERT OR REPLACE INTO memories (key, value, category, timestamp, lastAccessed, priority)
244
- VALUES (?, ?, ?, ?, ?, ?)
242
+ this.saveStmt = this.db.prepare(`
243
+ INSERT OR REPLACE INTO memories (key, value, category, timestamp, lastAccessed, priority)
244
+ VALUES (?, ?, ?, ?, ?, ?)
245
245
  `);
246
246
  }
247
247
  migrateFromJSON() {
@@ -253,9 +253,9 @@ export class MemoryStorage {
253
253
  const memories = JSON.parse(jsonData);
254
254
  if (memories.length === 0)
255
255
  return;
256
- const insert = this.db.prepare(`
257
- INSERT OR REPLACE INTO memories (key, value, category, timestamp, lastAccessed, priority)
258
- VALUES (?, ?, ?, ?, ?, ?)
256
+ const insert = this.db.prepare(`
257
+ INSERT OR REPLACE INTO memories (key, value, category, timestamp, lastAccessed, priority)
258
+ VALUES (?, ?, ?, ?, ?, ?)
259
259
  `);
260
260
  const insertMany = this.db.transaction((items) => {
261
261
  for (const item of items) {
@@ -331,9 +331,9 @@ export class MemoryStorage {
331
331
  this.saveStmt.run(key, value, category, timestamp, timestamp, priority);
332
332
  }
333
333
  else {
334
- const stmt = this.db.prepare(`
335
- INSERT OR REPLACE INTO memories (key, value, category, timestamp, lastAccessed, priority)
336
- VALUES (?, ?, ?, ?, ?, ?)
334
+ const stmt = this.db.prepare(`
335
+ INSERT OR REPLACE INTO memories (key, value, category, timestamp, lastAccessed, priority)
336
+ VALUES (?, ?, ?, ?, ?, ?)
337
337
  `);
338
338
  stmt.run(key, value, category, timestamp, timestamp, priority);
339
339
  }
@@ -376,10 +376,10 @@ export class MemoryStorage {
376
376
  */
377
377
  update(key, value) {
378
378
  const timestamp = new Date().toISOString();
379
- const stmt = this.db.prepare(`
380
- UPDATE memories
381
- SET value = ?, timestamp = ?, lastAccessed = ?
382
- WHERE key = ?
379
+ const stmt = this.db.prepare(`
380
+ UPDATE memories
381
+ SET value = ?, timestamp = ?, lastAccessed = ?
382
+ WHERE key = ?
383
383
  `);
384
384
  const result = stmt.run(value, timestamp, timestamp, key);
385
385
  return result.changes > 0;
@@ -389,16 +389,16 @@ export class MemoryStorage {
389
389
  */
390
390
  list(category) {
391
391
  if (category) {
392
- const stmt = this.db.prepare(`
393
- SELECT * FROM memories WHERE category = ?
394
- ORDER BY priority DESC, timestamp DESC
392
+ const stmt = this.db.prepare(`
393
+ SELECT * FROM memories WHERE category = ?
394
+ ORDER BY priority DESC, timestamp DESC
395
395
  `);
396
396
  return stmt.all(category);
397
397
  }
398
398
  else {
399
- const stmt = this.db.prepare(`
400
- SELECT * FROM memories
401
- ORDER BY priority DESC, timestamp DESC
399
+ const stmt = this.db.prepare(`
400
+ SELECT * FROM memories
401
+ ORDER BY priority DESC, timestamp DESC
402
402
  `);
403
403
  return stmt.all();
404
404
  }
@@ -434,13 +434,13 @@ export class MemoryStorage {
434
434
  if (!this.fts5Available) {
435
435
  return this.searchLike(query);
436
436
  }
437
- const stmt = this.db.prepare(`
438
- SELECT m.*, bm25(memories_fts) as rank
439
- FROM memories_fts fts
440
- JOIN memories m ON m.rowid = fts.rowid
441
- WHERE memories_fts MATCH ?
442
- ORDER BY rank
443
- LIMIT ?
437
+ const stmt = this.db.prepare(`
438
+ SELECT m.*, bm25(memories_fts) as rank
439
+ FROM memories_fts fts
440
+ JOIN memories m ON m.rowid = fts.rowid
441
+ WHERE memories_fts MATCH ?
442
+ ORDER BY rank
443
+ LIMIT ?
444
444
  `);
445
445
  return stmt.all(MemoryStorage.sanitizeFTS5Query(query), limit);
446
446
  }
@@ -451,10 +451,10 @@ export class MemoryStorage {
451
451
  return this.fts5Available;
452
452
  }
453
453
  searchLike(query) {
454
- const stmt = this.db.prepare(`
455
- SELECT * FROM memories
456
- WHERE key LIKE ? OR value LIKE ?
457
- ORDER BY priority DESC, timestamp DESC
454
+ const stmt = this.db.prepare(`
455
+ SELECT * FROM memories
456
+ WHERE key LIKE ? OR value LIKE ?
457
+ ORDER BY priority DESC, timestamp DESC
458
458
  `);
459
459
  const pattern = `%${query}%`;
460
460
  return stmt.all(pattern, pattern);
@@ -463,10 +463,10 @@ export class MemoryStorage {
463
463
  * Get memories by priority level
464
464
  */
465
465
  getByPriority(priority) {
466
- const stmt = this.db.prepare(`
467
- SELECT * FROM memories
468
- WHERE priority = ?
469
- ORDER BY timestamp DESC
466
+ const stmt = this.db.prepare(`
467
+ SELECT * FROM memories
468
+ WHERE priority = ?
469
+ ORDER BY timestamp DESC
470
470
  `);
471
471
  return stmt.all(priority);
472
472
  }
@@ -482,10 +482,10 @@ export class MemoryStorage {
482
482
  * Get memory statistics
483
483
  */
484
484
  getStats() {
485
- const categories = this.db.prepare(`
486
- SELECT category, COUNT(*) as count
487
- FROM memories
488
- GROUP BY category
485
+ const categories = this.db.prepare(`
486
+ SELECT category, COUNT(*) as count
487
+ FROM memories
488
+ GROUP BY category
489
489
  `).all();
490
490
  const byCategory = {};
491
491
  let total = 0;