grimoire-framework 1.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.
Files changed (1174) hide show
  1. package/.claude/CLAUDE.md +318 -0
  2. package/.claude/hooks/README.md +170 -0
  3. package/.claude/hooks/enforce-architecture-first.py +198 -0
  4. package/.claude/hooks/install-hooks.sh +43 -0
  5. package/.claude/hooks/mind-clone-governance.py +192 -0
  6. package/.claude/hooks/pre-commit-version-check.sh +157 -0
  7. package/.claude/hooks/precompact-session-digest.js +47 -0
  8. package/.claude/hooks/read-protection.py +153 -0
  9. package/.claude/hooks/slug-validation.py +176 -0
  10. package/.claude/hooks/sql-governance.py +182 -0
  11. package/.claude/hooks/synapse-engine.js +77 -0
  12. package/.claude/hooks/write-path-validation.py +196 -0
  13. package/.claude/rules/mcp-usage.md +177 -0
  14. package/.grimoire/cli/commands/config/index.js +609 -0
  15. package/.grimoire/cli/commands/generate/index.js +222 -0
  16. package/.grimoire/cli/commands/manifest/index.js +47 -0
  17. package/.grimoire/cli/commands/manifest/regenerate.js +97 -0
  18. package/.grimoire/cli/commands/manifest/validate.js +66 -0
  19. package/.grimoire/cli/commands/mcp/add.js +235 -0
  20. package/.grimoire/cli/commands/mcp/index.js +77 -0
  21. package/.grimoire/cli/commands/mcp/link.js +218 -0
  22. package/.grimoire/cli/commands/mcp/setup.js +165 -0
  23. package/.grimoire/cli/commands/mcp/status.js +184 -0
  24. package/.grimoire/cli/commands/metrics/cleanup.js +91 -0
  25. package/.grimoire/cli/commands/metrics/index.js +66 -0
  26. package/.grimoire/cli/commands/metrics/record.js +154 -0
  27. package/.grimoire/cli/commands/metrics/seed.js +127 -0
  28. package/.grimoire/cli/commands/metrics/show.js +209 -0
  29. package/.grimoire/cli/commands/migrate/analyze.js +355 -0
  30. package/.grimoire/cli/commands/migrate/backup.js +354 -0
  31. package/.grimoire/cli/commands/migrate/execute.js +294 -0
  32. package/.grimoire/cli/commands/migrate/index.js +443 -0
  33. package/.grimoire/cli/commands/migrate/rollback.js +325 -0
  34. package/.grimoire/cli/commands/migrate/update-imports.js +398 -0
  35. package/.grimoire/cli/commands/migrate/validate.js +454 -0
  36. package/.grimoire/cli/commands/pro/index.js +705 -0
  37. package/.grimoire/cli/commands/qa/index.js +57 -0
  38. package/.grimoire/cli/commands/qa/run.js +163 -0
  39. package/.grimoire/cli/commands/qa/status.js +195 -0
  40. package/.grimoire/cli/commands/validate/index.js +431 -0
  41. package/.grimoire/cli/commands/workers/formatters/info-formatter.js +275 -0
  42. package/.grimoire/cli/commands/workers/formatters/list-table.js +265 -0
  43. package/.grimoire/cli/commands/workers/formatters/list-tree.js +160 -0
  44. package/.grimoire/cli/commands/workers/index.js +57 -0
  45. package/.grimoire/cli/commands/workers/info.js +195 -0
  46. package/.grimoire/cli/commands/workers/list.js +215 -0
  47. package/.grimoire/cli/commands/workers/search-filters.js +185 -0
  48. package/.grimoire/cli/commands/workers/search-keyword.js +310 -0
  49. package/.grimoire/cli/commands/workers/search-semantic.js +294 -0
  50. package/.grimoire/cli/commands/workers/search.js +155 -0
  51. package/.grimoire/cli/commands/workers/utils/pagination.js +102 -0
  52. package/.grimoire/cli/index.js +150 -0
  53. package/.grimoire/cli/utils/output-formatter-cli.js +233 -0
  54. package/.grimoire/cli/utils/score-calculator.js +221 -0
  55. package/.grimoire/constitution.md +172 -0
  56. package/.grimoire/core/README.md +231 -0
  57. package/.grimoire/core/code-intel/code-intel-client.js +280 -0
  58. package/.grimoire/core/code-intel/code-intel-enricher.js +160 -0
  59. package/.grimoire/core/code-intel/index.js +137 -0
  60. package/.grimoire/core/code-intel/providers/code-graph-provider.js +201 -0
  61. package/.grimoire/core/code-intel/providers/provider-interface.js +108 -0
  62. package/.grimoire/core/config/config-cache.js +233 -0
  63. package/.grimoire/core/config/config-loader.js +281 -0
  64. package/.grimoire/core/config/config-resolver.js +609 -0
  65. package/.grimoire/core/config/env-interpolator.js +122 -0
  66. package/.grimoire/core/config/merge-utils.js +101 -0
  67. package/.grimoire/core/config/migrate-config.js +293 -0
  68. package/.grimoire/core/config/schemas/framework-config.schema.json +19 -0
  69. package/.grimoire/core/config/schemas/local-config.schema.json +20 -0
  70. package/.grimoire/core/config/schemas/project-config.schema.json +32 -0
  71. package/.grimoire/core/config/schemas/user-config.schema.json +33 -0
  72. package/.grimoire/core/config/templates/user-config.yaml +24 -0
  73. package/.grimoire/core/docs/SHARD-TRANSLATION-GUIDE.md +337 -0
  74. package/.grimoire/core/docs/component-creation-guide.md +459 -0
  75. package/.grimoire/core/docs/session-update-pattern.md +316 -0
  76. package/.grimoire/core/docs/template-syntax.md +267 -0
  77. package/.grimoire/core/docs/troubleshooting-guide.md +626 -0
  78. package/.grimoire/core/elicitation/agent-elicitation.js +272 -0
  79. package/.grimoire/core/elicitation/elicitation-engine.js +486 -0
  80. package/.grimoire/core/elicitation/session-manager.js +322 -0
  81. package/.grimoire/core/elicitation/task-elicitation.js +281 -0
  82. package/.grimoire/core/elicitation/workflow-elicitation.js +349 -0
  83. package/.grimoire/core/events/dashboard-emitter.js +369 -0
  84. package/.grimoire/core/events/index.js +17 -0
  85. package/.grimoire/core/events/types.js +52 -0
  86. package/.grimoire/core/execution/autonomous-build-loop.js +1068 -0
  87. package/.grimoire/core/execution/build-orchestrator.js +1055 -0
  88. package/.grimoire/core/execution/build-state-manager.js +1530 -0
  89. package/.grimoire/core/execution/context-injector.js +537 -0
  90. package/.grimoire/core/execution/parallel-executor.js +292 -0
  91. package/.grimoire/core/execution/parallel-monitor.js +429 -0
  92. package/.grimoire/core/execution/rate-limit-manager.js +314 -0
  93. package/.grimoire/core/execution/result-aggregator.js +486 -0
  94. package/.grimoire/core/execution/semantic-merge-engine.js +1736 -0
  95. package/.grimoire/core/execution/subagent-dispatcher.js +848 -0
  96. package/.grimoire/core/execution/wave-executor.js +397 -0
  97. package/.grimoire/core/health-check/base-check.js +224 -0
  98. package/.grimoire/core/health-check/check-registry.js +253 -0
  99. package/.grimoire/core/health-check/checks/deployment/build-config.js +111 -0
  100. package/.grimoire/core/health-check/checks/deployment/ci-config.js +125 -0
  101. package/.grimoire/core/health-check/checks/deployment/deployment-readiness.js +152 -0
  102. package/.grimoire/core/health-check/checks/deployment/docker-config.js +122 -0
  103. package/.grimoire/core/health-check/checks/deployment/env-file.js +111 -0
  104. package/.grimoire/core/health-check/checks/deployment/index.js +29 -0
  105. package/.grimoire/core/health-check/checks/index.js +56 -0
  106. package/.grimoire/core/health-check/checks/local/disk-space.js +214 -0
  107. package/.grimoire/core/health-check/checks/local/environment-vars.js +136 -0
  108. package/.grimoire/core/health-check/checks/local/git-install.js +158 -0
  109. package/.grimoire/core/health-check/checks/local/ide-detection.js +148 -0
  110. package/.grimoire/core/health-check/checks/local/index.js +35 -0
  111. package/.grimoire/core/health-check/checks/local/memory.js +138 -0
  112. package/.grimoire/core/health-check/checks/local/network.js +170 -0
  113. package/.grimoire/core/health-check/checks/local/npm-install.js +149 -0
  114. package/.grimoire/core/health-check/checks/local/shell-environment.js +120 -0
  115. package/.grimoire/core/health-check/checks/project/agent-config.js +167 -0
  116. package/.grimoire/core/health-check/checks/project/dependencies.js +150 -0
  117. package/.grimoire/core/health-check/checks/project/framework-config.js +133 -0
  118. package/.grimoire/core/health-check/checks/project/grimoire-directory.js +143 -0
  119. package/.grimoire/core/health-check/checks/project/index.js +35 -0
  120. package/.grimoire/core/health-check/checks/project/node-version.js +163 -0
  121. package/.grimoire/core/health-check/checks/project/package-json.js +107 -0
  122. package/.grimoire/core/health-check/checks/project/task-definitions.js +192 -0
  123. package/.grimoire/core/health-check/checks/project/workflow-dependencies.js +214 -0
  124. package/.grimoire/core/health-check/checks/repository/branch-protection.js +107 -0
  125. package/.grimoire/core/health-check/checks/repository/commit-history.js +144 -0
  126. package/.grimoire/core/health-check/checks/repository/conflicts.js +152 -0
  127. package/.grimoire/core/health-check/checks/repository/git-repo.js +159 -0
  128. package/.grimoire/core/health-check/checks/repository/git-status.js +149 -0
  129. package/.grimoire/core/health-check/checks/repository/gitignore.js +194 -0
  130. package/.grimoire/core/health-check/checks/repository/index.js +35 -0
  131. package/.grimoire/core/health-check/checks/repository/large-files.js +183 -0
  132. package/.grimoire/core/health-check/checks/repository/lockfile-integrity.js +144 -0
  133. package/.grimoire/core/health-check/checks/services/api-endpoints.js +168 -0
  134. package/.grimoire/core/health-check/checks/services/claude-code.js +139 -0
  135. package/.grimoire/core/health-check/checks/services/gemini-cli.js +241 -0
  136. package/.grimoire/core/health-check/checks/services/github-cli.js +117 -0
  137. package/.grimoire/core/health-check/checks/services/index.js +29 -0
  138. package/.grimoire/core/health-check/checks/services/mcp-integration.js +125 -0
  139. package/.grimoire/core/health-check/engine.js +407 -0
  140. package/.grimoire/core/health-check/healers/backup-manager.js +340 -0
  141. package/.grimoire/core/health-check/healers/index.js +330 -0
  142. package/.grimoire/core/health-check/index.js +370 -0
  143. package/.grimoire/core/health-check/reporters/console.js +331 -0
  144. package/.grimoire/core/health-check/reporters/index.js +117 -0
  145. package/.grimoire/core/health-check/reporters/json.js +301 -0
  146. package/.grimoire/core/health-check/reporters/markdown.js +323 -0
  147. package/.grimoire/core/ideation/ideation-engine.js +834 -0
  148. package/.grimoire/core/ids/README.md +123 -0
  149. package/.grimoire/core/ids/circuit-breaker.js +156 -0
  150. package/.grimoire/core/ids/framework-governor.js +567 -0
  151. package/.grimoire/core/ids/gates/g1-epic-creation.js +101 -0
  152. package/.grimoire/core/ids/gates/g2-story-creation.js +133 -0
  153. package/.grimoire/core/ids/gates/g3-story-validation.js +166 -0
  154. package/.grimoire/core/ids/gates/g4-dev-context.js +155 -0
  155. package/.grimoire/core/ids/incremental-decision-engine.js +651 -0
  156. package/.grimoire/core/ids/index.js +157 -0
  157. package/.grimoire/core/ids/registry-healer.js +868 -0
  158. package/.grimoire/core/ids/registry-loader.js +281 -0
  159. package/.grimoire/core/ids/registry-updater.js +703 -0
  160. package/.grimoire/core/ids/verification-gate.js +306 -0
  161. package/.grimoire/core/index.esm.js +44 -0
  162. package/.grimoire/core/index.js +90 -0
  163. package/.grimoire/core/manifest/manifest-generator.js +388 -0
  164. package/.grimoire/core/manifest/manifest-validator.js +431 -0
  165. package/.grimoire/core/mcp/config-migrator.js +341 -0
  166. package/.grimoire/core/mcp/global-config-manager.js +370 -0
  167. package/.grimoire/core/mcp/index.js +34 -0
  168. package/.grimoire/core/mcp/os-detector.js +189 -0
  169. package/.grimoire/core/mcp/symlink-manager.js +415 -0
  170. package/.grimoire/core/memory/__tests__/active-modules.verify.js +254 -0
  171. package/.grimoire/core/memory/gotchas-memory.js +1154 -0
  172. package/.grimoire/core/migration/migration-config.yaml +85 -0
  173. package/.grimoire/core/migration/module-mapping.yaml +91 -0
  174. package/.grimoire/core/orchestration/agent-invoker.js +612 -0
  175. package/.grimoire/core/orchestration/bob-orchestrator.js +1032 -0
  176. package/.grimoire/core/orchestration/bob-status-writer.js +482 -0
  177. package/.grimoire/core/orchestration/bob-surface-criteria.yaml +272 -0
  178. package/.grimoire/core/orchestration/brownfield-handler.js +741 -0
  179. package/.grimoire/core/orchestration/checklist-runner.js +328 -0
  180. package/.grimoire/core/orchestration/cli-commands.js +581 -0
  181. package/.grimoire/core/orchestration/condition-evaluator.js +379 -0
  182. package/.grimoire/core/orchestration/context-manager.js +616 -0
  183. package/.grimoire/core/orchestration/dashboard-integration.js +520 -0
  184. package/.grimoire/core/orchestration/data-lifecycle-manager.js +357 -0
  185. package/.grimoire/core/orchestration/epic-context-accumulator.js +396 -0
  186. package/.grimoire/core/orchestration/execution-profile-resolver.js +107 -0
  187. package/.grimoire/core/orchestration/executor-assignment.js +413 -0
  188. package/.grimoire/core/orchestration/executors/epic-3-executor.js +223 -0
  189. package/.grimoire/core/orchestration/executors/epic-4-executor.js +269 -0
  190. package/.grimoire/core/orchestration/executors/epic-5-executor.js +329 -0
  191. package/.grimoire/core/orchestration/executors/epic-6-executor.js +265 -0
  192. package/.grimoire/core/orchestration/executors/epic-executor.js +237 -0
  193. package/.grimoire/core/orchestration/executors/index.js +86 -0
  194. package/.grimoire/core/orchestration/gate-evaluator.js +495 -0
  195. package/.grimoire/core/orchestration/gemini-model-selector.js +161 -0
  196. package/.grimoire/core/orchestration/greenfield-handler.js +890 -0
  197. package/.grimoire/core/orchestration/index.js +323 -0
  198. package/.grimoire/core/orchestration/lock-manager.js +327 -0
  199. package/.grimoire/core/orchestration/master-orchestrator.js +1544 -0
  200. package/.grimoire/core/orchestration/message-formatter.js +279 -0
  201. package/.grimoire/core/orchestration/parallel-executor.js +225 -0
  202. package/.grimoire/core/orchestration/recovery-handler.js +721 -0
  203. package/.grimoire/core/orchestration/session-state.js +876 -0
  204. package/.grimoire/core/orchestration/skill-dispatcher.js +364 -0
  205. package/.grimoire/core/orchestration/subagent-prompt-builder.js +370 -0
  206. package/.grimoire/core/orchestration/surface-checker.js +403 -0
  207. package/.grimoire/core/orchestration/task-complexity-classifier.js +123 -0
  208. package/.grimoire/core/orchestration/tech-stack-detector.js +599 -0
  209. package/.grimoire/core/orchestration/terminal-spawner.js +1044 -0
  210. package/.grimoire/core/orchestration/workflow-executor.js +1182 -0
  211. package/.grimoire/core/orchestration/workflow-orchestrator.js +907 -0
  212. package/.grimoire/core/permissions/__tests__/permission-mode.test.js +293 -0
  213. package/.grimoire/core/permissions/index.js +140 -0
  214. package/.grimoire/core/permissions/operation-guard.js +395 -0
  215. package/.grimoire/core/permissions/permission-mode.js +271 -0
  216. package/.grimoire/core/quality-gates/base-layer.js +134 -0
  217. package/.grimoire/core/quality-gates/checklist-generator.js +329 -0
  218. package/.grimoire/core/quality-gates/focus-area-recommender.js +361 -0
  219. package/.grimoire/core/quality-gates/human-review-orchestrator.js +530 -0
  220. package/.grimoire/core/quality-gates/layer1-precommit.js +336 -0
  221. package/.grimoire/core/quality-gates/layer2-pr-automation.js +331 -0
  222. package/.grimoire/core/quality-gates/layer3-human-review.js +350 -0
  223. package/.grimoire/core/quality-gates/notification-manager.js +551 -0
  224. package/.grimoire/core/quality-gates/quality-gate-config.yaml +87 -0
  225. package/.grimoire/core/quality-gates/quality-gate-manager.js +603 -0
  226. package/.grimoire/core/registry/README.md +181 -0
  227. package/.grimoire/core/registry/build-registry.js +454 -0
  228. package/.grimoire/core/registry/registry-loader.js +331 -0
  229. package/.grimoire/core/registry/registry-schema.json +168 -0
  230. package/.grimoire/core/registry/service-registry.json +6468 -0
  231. package/.grimoire/core/registry/validate-registry.js +341 -0
  232. package/.grimoire/core/session/context-detector.js +233 -0
  233. package/.grimoire/core/session/context-loader.js +443 -0
  234. package/.grimoire/core/synapse/context/context-builder.js +34 -0
  235. package/.grimoire/core/synapse/context/context-tracker.js +190 -0
  236. package/.grimoire/core/synapse/diagnostics/collectors/consistency-collector.js +168 -0
  237. package/.grimoire/core/synapse/diagnostics/collectors/hook-collector.js +129 -0
  238. package/.grimoire/core/synapse/diagnostics/collectors/manifest-collector.js +82 -0
  239. package/.grimoire/core/synapse/diagnostics/collectors/output-analyzer.js +134 -0
  240. package/.grimoire/core/synapse/diagnostics/collectors/pipeline-collector.js +75 -0
  241. package/.grimoire/core/synapse/diagnostics/collectors/quality-collector.js +252 -0
  242. package/.grimoire/core/synapse/diagnostics/collectors/relevance-matrix.js +174 -0
  243. package/.grimoire/core/synapse/diagnostics/collectors/safe-read-json.js +31 -0
  244. package/.grimoire/core/synapse/diagnostics/collectors/session-collector.js +102 -0
  245. package/.grimoire/core/synapse/diagnostics/collectors/timing-collector.js +126 -0
  246. package/.grimoire/core/synapse/diagnostics/collectors/uap-collector.js +83 -0
  247. package/.grimoire/core/synapse/diagnostics/report-formatter.js +485 -0
  248. package/.grimoire/core/synapse/diagnostics/synapse-diagnostics.js +95 -0
  249. package/.grimoire/core/synapse/domain/domain-loader.js +322 -0
  250. package/.grimoire/core/synapse/engine.js +380 -0
  251. package/.grimoire/core/synapse/layers/l0-constitution.js +80 -0
  252. package/.grimoire/core/synapse/layers/l1-global.js +102 -0
  253. package/.grimoire/core/synapse/layers/l2-agent.js +94 -0
  254. package/.grimoire/core/synapse/layers/l3-workflow.js +94 -0
  255. package/.grimoire/core/synapse/layers/l4-task.js +83 -0
  256. package/.grimoire/core/synapse/layers/l5-squad.js +244 -0
  257. package/.grimoire/core/synapse/layers/l6-keyword.js +154 -0
  258. package/.grimoire/core/synapse/layers/l7-star-command.js +169 -0
  259. package/.grimoire/core/synapse/layers/layer-processor.js +82 -0
  260. package/.grimoire/core/synapse/memory/memory-bridge.js +246 -0
  261. package/.grimoire/core/synapse/output/formatter.js +561 -0
  262. package/.grimoire/core/synapse/runtime/hook-runtime.js +61 -0
  263. package/.grimoire/core/synapse/scripts/generate-constitution.js +205 -0
  264. package/.grimoire/core/synapse/session/session-manager.js +403 -0
  265. package/.grimoire/core/synapse/utils/paths.js +57 -0
  266. package/.grimoire/core/synapse/utils/tokens.js +25 -0
  267. package/.grimoire/core/ui/index.js +43 -0
  268. package/.grimoire/core/ui/observability-panel.js +394 -0
  269. package/.grimoire/core/ui/panel-renderer.js +337 -0
  270. package/.grimoire/core/utils/output-formatter.js +299 -0
  271. package/.grimoire/core/utils/security-utils.js +336 -0
  272. package/.grimoire/core/utils/yaml-validator.js +416 -0
  273. package/.grimoire/core-config.yaml +357 -0
  274. package/.grimoire/data/agent-config-requirements.yaml +409 -0
  275. package/.grimoire/data/entity-registry.yaml +9219 -0
  276. package/.grimoire/data/grimoire-kb.md +918 -0
  277. package/.grimoire/data/learned-patterns.yaml +3 -0
  278. package/.grimoire/data/tech-presets/_template.md +259 -0
  279. package/.grimoire/data/tech-presets/nextjs-react.md +933 -0
  280. package/.grimoire/data/technical-preferences.md +85 -0
  281. package/.grimoire/data/workflow-patterns.yaml +836 -0
  282. package/.grimoire/data/workflow-state-schema.yaml +203 -0
  283. package/.grimoire/development/README.md +143 -0
  284. package/.grimoire/development/agent-teams/team-all.yaml +16 -0
  285. package/.grimoire/development/agent-teams/team-fullstack.yaml +19 -0
  286. package/.grimoire/development/agent-teams/team-ide-minimal.yaml +10 -0
  287. package/.grimoire/development/agent-teams/team-no-ui.yaml +14 -0
  288. package/.grimoire/development/agent-teams/team-qa-focused.yaml +155 -0
  289. package/.grimoire/development/agents/analyst.md +261 -0
  290. package/.grimoire/development/agents/architect.md +461 -0
  291. package/.grimoire/development/agents/caravaggio.md +31 -0
  292. package/.grimoire/development/agents/data-engineer.md +482 -0
  293. package/.grimoire/development/agents/dev.md +548 -0
  294. package/.grimoire/development/agents/devops.md +500 -0
  295. package/.grimoire/development/agents/frida.md +31 -0
  296. package/.grimoire/development/agents/grimoire-master.md +447 -0
  297. package/.grimoire/development/agents/picasso.md +31 -0
  298. package/.grimoire/development/agents/pm.md +365 -0
  299. package/.grimoire/development/agents/po.md +323 -0
  300. package/.grimoire/development/agents/qa.md +437 -0
  301. package/.grimoire/development/agents/salvador.md +31 -0
  302. package/.grimoire/development/agents/sm.md +275 -0
  303. package/.grimoire/development/agents/squad-creator.md +330 -0
  304. package/.grimoire/development/agents/tarsila.md +31 -0
  305. package/.grimoire/development/agents/ux-design-expert.md +482 -0
  306. package/.grimoire/development/agents/van-gogh.md +31 -0
  307. package/.grimoire/development/agents/warhol.md +31 -0
  308. package/.grimoire/development/checklists/agent-quality-gate.md +560 -0
  309. package/.grimoire/development/checklists/brownfield-compatibility-checklist.md +116 -0
  310. package/.grimoire/development/checklists/self-critique-checklist.md +274 -0
  311. package/.grimoire/development/data/decision-heuristics-framework.md +622 -0
  312. package/.grimoire/development/data/quality-dimensions-framework.md +427 -0
  313. package/.grimoire/development/data/tier-system-framework.md +476 -0
  314. package/.grimoire/development/scripts/activation-runtime.js +64 -0
  315. package/.grimoire/development/scripts/agent-assignment-resolver.js +231 -0
  316. package/.grimoire/development/scripts/agent-config-loader.js +628 -0
  317. package/.grimoire/development/scripts/agent-exit-hooks.js +97 -0
  318. package/.grimoire/development/scripts/apply-inline-greeting-all-agents.js +147 -0
  319. package/.grimoire/development/scripts/approval-workflow.js +643 -0
  320. package/.grimoire/development/scripts/audit-agent-config.js +382 -0
  321. package/.grimoire/development/scripts/backlog-manager.js +409 -0
  322. package/.grimoire/development/scripts/backup-manager.js +607 -0
  323. package/.grimoire/development/scripts/batch-update-agents-session-context.js +97 -0
  324. package/.grimoire/development/scripts/branch-manager.js +390 -0
  325. package/.grimoire/development/scripts/code-quality-improver.js +1312 -0
  326. package/.grimoire/development/scripts/commit-message-generator.js +850 -0
  327. package/.grimoire/development/scripts/conflict-resolver.js +675 -0
  328. package/.grimoire/development/scripts/decision-context.js +229 -0
  329. package/.grimoire/development/scripts/decision-log-generator.js +294 -0
  330. package/.grimoire/development/scripts/decision-log-indexer.js +285 -0
  331. package/.grimoire/development/scripts/decision-recorder.js +169 -0
  332. package/.grimoire/development/scripts/dependency-analyzer.js +639 -0
  333. package/.grimoire/development/scripts/dev-context-loader.js +298 -0
  334. package/.grimoire/development/scripts/diff-generator.js +352 -0
  335. package/.grimoire/development/scripts/elicitation-engine.js +385 -0
  336. package/.grimoire/development/scripts/elicitation-session-manager.js +300 -0
  337. package/.grimoire/development/scripts/generate-greeting.js +109 -0
  338. package/.grimoire/development/scripts/git-wrapper.js +462 -0
  339. package/.grimoire/development/scripts/greeting-builder.js +1406 -0
  340. package/.grimoire/development/scripts/greeting-config-cli.js +86 -0
  341. package/.grimoire/development/scripts/greeting-preference-manager.js +170 -0
  342. package/.grimoire/development/scripts/manifest-preview.js +245 -0
  343. package/.grimoire/development/scripts/metrics-tracker.js +776 -0
  344. package/.grimoire/development/scripts/migrate-task-to-v2.js +379 -0
  345. package/.grimoire/development/scripts/modification-validator.js +555 -0
  346. package/.grimoire/development/scripts/pattern-learner.js +1225 -0
  347. package/.grimoire/development/scripts/performance-analyzer.js +758 -0
  348. package/.grimoire/development/scripts/populate-entity-registry.js +281 -0
  349. package/.grimoire/development/scripts/refactoring-suggester.js +1139 -0
  350. package/.grimoire/development/scripts/rollback-handler.js +532 -0
  351. package/.grimoire/development/scripts/security-checker.js +359 -0
  352. package/.grimoire/development/scripts/skill-validator.js +343 -0
  353. package/.grimoire/development/scripts/squad/README.md +114 -0
  354. package/.grimoire/development/scripts/squad/index.js +124 -0
  355. package/.grimoire/development/scripts/squad/squad-analyzer.js +638 -0
  356. package/.grimoire/development/scripts/squad/squad-designer.js +1010 -0
  357. package/.grimoire/development/scripts/squad/squad-downloader.js +511 -0
  358. package/.grimoire/development/scripts/squad/squad-extender.js +872 -0
  359. package/.grimoire/development/scripts/squad/squad-generator.js +1406 -0
  360. package/.grimoire/development/scripts/squad/squad-loader.js +359 -0
  361. package/.grimoire/development/scripts/squad/squad-migrator.js +628 -0
  362. package/.grimoire/development/scripts/squad/squad-publisher.js +630 -0
  363. package/.grimoire/development/scripts/squad/squad-validator.js +857 -0
  364. package/.grimoire/development/scripts/story-index-generator.js +339 -0
  365. package/.grimoire/development/scripts/story-manager.js +375 -0
  366. package/.grimoire/development/scripts/story-update-hook.js +259 -0
  367. package/.grimoire/development/scripts/task-identifier-resolver.js +145 -0
  368. package/.grimoire/development/scripts/template-engine.js +240 -0
  369. package/.grimoire/development/scripts/template-validator.js +279 -0
  370. package/.grimoire/development/scripts/test-generator.js +844 -0
  371. package/.grimoire/development/scripts/test-greeting-system.js +143 -0
  372. package/.grimoire/development/scripts/transaction-manager.js +591 -0
  373. package/.grimoire/development/scripts/unified-activation-pipeline.js +796 -0
  374. package/.grimoire/development/scripts/usage-tracker.js +675 -0
  375. package/.grimoire/development/scripts/validate-filenames.js +228 -0
  376. package/.grimoire/development/scripts/validate-task-v2.js +320 -0
  377. package/.grimoire/development/scripts/verify-workflow-gaps.js +1034 -0
  378. package/.grimoire/development/scripts/version-tracker.js +527 -0
  379. package/.grimoire/development/scripts/workflow-navigator.js +328 -0
  380. package/.grimoire/development/scripts/workflow-state-manager.js +652 -0
  381. package/.grimoire/development/scripts/workflow-validator.js +697 -0
  382. package/.grimoire/development/scripts/yaml-validator.js +397 -0
  383. package/.grimoire/development/tasks/add-mcp.md +437 -0
  384. package/.grimoire/development/tasks/advanced-elicitation.md +320 -0
  385. package/.grimoire/development/tasks/analyst-facilitate-brainstorming.md +343 -0
  386. package/.grimoire/development/tasks/analyze-brownfield.md +458 -0
  387. package/.grimoire/development/tasks/analyze-cross-artifact.md +358 -0
  388. package/.grimoire/development/tasks/analyze-framework.md +698 -0
  389. package/.grimoire/development/tasks/analyze-performance.md +639 -0
  390. package/.grimoire/development/tasks/analyze-project-structure.md +623 -0
  391. package/.grimoire/development/tasks/apply-qa-fixes.md +342 -0
  392. package/.grimoire/development/tasks/architect-analyze-impact.md +828 -0
  393. package/.grimoire/development/tasks/audit-codebase.md +431 -0
  394. package/.grimoire/development/tasks/audit-tailwind-config.md +272 -0
  395. package/.grimoire/development/tasks/audit-utilities.md +360 -0
  396. package/.grimoire/development/tasks/blocks/README.md +180 -0
  397. package/.grimoire/development/tasks/blocks/agent-prompt-template.md +117 -0
  398. package/.grimoire/development/tasks/blocks/context-loading.md +110 -0
  399. package/.grimoire/development/tasks/blocks/execution-pattern.md +122 -0
  400. package/.grimoire/development/tasks/blocks/finalization.md +123 -0
  401. package/.grimoire/development/tasks/bootstrap-shadcn-library.md +288 -0
  402. package/.grimoire/development/tasks/brownfield-create-epic.md +533 -0
  403. package/.grimoire/development/tasks/brownfield-create-story.md +358 -0
  404. package/.grimoire/development/tasks/build-autonomous.md +186 -0
  405. package/.grimoire/development/tasks/build-component.md +480 -0
  406. package/.grimoire/development/tasks/build-resume.md +125 -0
  407. package/.grimoire/development/tasks/build-status.md +155 -0
  408. package/.grimoire/development/tasks/build.md +142 -0
  409. package/.grimoire/development/tasks/calculate-roi.md +457 -0
  410. package/.grimoire/development/tasks/check-docs-links.md +114 -0
  411. package/.grimoire/development/tasks/ci-cd-configuration.md +766 -0
  412. package/.grimoire/development/tasks/cleanup-utilities.md +672 -0
  413. package/.grimoire/development/tasks/cleanup-worktrees.md +39 -0
  414. package/.grimoire/development/tasks/collaborative-edit.md +1110 -0
  415. package/.grimoire/development/tasks/compose-molecule.md +286 -0
  416. package/.grimoire/development/tasks/consolidate-patterns.md +416 -0
  417. package/.grimoire/development/tasks/correct-course.md +281 -0
  418. package/.grimoire/development/tasks/create-agent.md +1199 -0
  419. package/.grimoire/development/tasks/create-brownfield-story.md +728 -0
  420. package/.grimoire/development/tasks/create-deep-research-prompt.md +500 -0
  421. package/.grimoire/development/tasks/create-doc.md +318 -0
  422. package/.grimoire/development/tasks/create-next-story.md +776 -0
  423. package/.grimoire/development/tasks/create-service.md +393 -0
  424. package/.grimoire/development/tasks/create-suite.md +285 -0
  425. package/.grimoire/development/tasks/create-task.md +391 -0
  426. package/.grimoire/development/tasks/create-workflow.md +429 -0
  427. package/.grimoire/development/tasks/create-worktree.md +439 -0
  428. package/.grimoire/development/tasks/db-analyze-hotpaths.md +574 -0
  429. package/.grimoire/development/tasks/db-apply-migration.md +383 -0
  430. package/.grimoire/development/tasks/db-bootstrap.md +644 -0
  431. package/.grimoire/development/tasks/db-domain-modeling.md +695 -0
  432. package/.grimoire/development/tasks/db-dry-run.md +295 -0
  433. package/.grimoire/development/tasks/db-env-check.md +262 -0
  434. package/.grimoire/development/tasks/db-explain.md +633 -0
  435. package/.grimoire/development/tasks/db-impersonate.md +497 -0
  436. package/.grimoire/development/tasks/db-load-csv.md +595 -0
  437. package/.grimoire/development/tasks/db-policy-apply.md +655 -0
  438. package/.grimoire/development/tasks/db-rls-audit.md +413 -0
  439. package/.grimoire/development/tasks/db-rollback.md +741 -0
  440. package/.grimoire/development/tasks/db-run-sql.md +615 -0
  441. package/.grimoire/development/tasks/db-schema-audit.md +1013 -0
  442. package/.grimoire/development/tasks/db-seed.md +392 -0
  443. package/.grimoire/development/tasks/db-smoke-test.md +353 -0
  444. package/.grimoire/development/tasks/db-snapshot.md +571 -0
  445. package/.grimoire/development/tasks/db-squad-integration.md +665 -0
  446. package/.grimoire/development/tasks/db-supabase-setup.md +714 -0
  447. package/.grimoire/development/tasks/db-verify-order.md +517 -0
  448. package/.grimoire/development/tasks/deprecate-component.md +958 -0
  449. package/.grimoire/development/tasks/dev-apply-qa-fixes.md +320 -0
  450. package/.grimoire/development/tasks/dev-backlog-debt.md +471 -0
  451. package/.grimoire/development/tasks/dev-develop-story.md +912 -0
  452. package/.grimoire/development/tasks/dev-improve-code-quality.md +874 -0
  453. package/.grimoire/development/tasks/dev-optimize-performance.md +1035 -0
  454. package/.grimoire/development/tasks/dev-suggest-refactoring.md +872 -0
  455. package/.grimoire/development/tasks/dev-validate-next-story.md +350 -0
  456. package/.grimoire/development/tasks/document-gotchas.md +479 -0
  457. package/.grimoire/development/tasks/document-project.md +554 -0
  458. package/.grimoire/development/tasks/environment-bootstrap.md +1391 -0
  459. package/.grimoire/development/tasks/execute-checklist.md +303 -0
  460. package/.grimoire/development/tasks/execute-epic-plan.md +887 -0
  461. package/.grimoire/development/tasks/export-design-tokens-dtcg.md +276 -0
  462. package/.grimoire/development/tasks/extend-pattern.md +271 -0
  463. package/.grimoire/development/tasks/extract-patterns.md +399 -0
  464. package/.grimoire/development/tasks/extract-tokens.md +469 -0
  465. package/.grimoire/development/tasks/facilitate-brainstorming-session.md +520 -0
  466. package/.grimoire/development/tasks/generate-ai-frontend-prompt.md +262 -0
  467. package/.grimoire/development/tasks/generate-documentation.md +286 -0
  468. package/.grimoire/development/tasks/generate-migration-strategy.md +524 -0
  469. package/.grimoire/development/tasks/generate-shock-report.md +503 -0
  470. package/.grimoire/development/tasks/github-devops-github-pr-automation.md +666 -0
  471. package/.grimoire/development/tasks/github-devops-pre-push-quality-gate.md +791 -0
  472. package/.grimoire/development/tasks/github-devops-repository-cleanup.md +376 -0
  473. package/.grimoire/development/tasks/github-devops-version-management.md +485 -0
  474. package/.grimoire/development/tasks/gotcha.md +138 -0
  475. package/.grimoire/development/tasks/gotchas.md +155 -0
  476. package/.grimoire/development/tasks/health-check.yaml +227 -0
  477. package/.grimoire/development/tasks/ids-governor.md +96 -0
  478. package/.grimoire/development/tasks/ids-health.md +91 -0
  479. package/.grimoire/development/tasks/ids-query.md +156 -0
  480. package/.grimoire/development/tasks/improve-self.md +824 -0
  481. package/.grimoire/development/tasks/index-docs.md +389 -0
  482. package/.grimoire/development/tasks/init-project-status.md +508 -0
  483. package/.grimoire/development/tasks/integrate-squad.md +316 -0
  484. package/.grimoire/development/tasks/kb-mode-interaction.md +285 -0
  485. package/.grimoire/development/tasks/learn-patterns.md +902 -0
  486. package/.grimoire/development/tasks/list-mcps.md +33 -0
  487. package/.grimoire/development/tasks/list-worktrees.md +344 -0
  488. package/.grimoire/development/tasks/mcp-workflow.md +438 -0
  489. package/.grimoire/development/tasks/merge-worktree.md +42 -0
  490. package/.grimoire/development/tasks/modify-agent.md +399 -0
  491. package/.grimoire/development/tasks/modify-task.md +442 -0
  492. package/.grimoire/development/tasks/modify-workflow.md +511 -0
  493. package/.grimoire/development/tasks/next.md +327 -0
  494. package/.grimoire/development/tasks/orchestrate-resume.md +60 -0
  495. package/.grimoire/development/tasks/orchestrate-status.md +64 -0
  496. package/.grimoire/development/tasks/orchestrate-stop.md +55 -0
  497. package/.grimoire/development/tasks/orchestrate.md +66 -0
  498. package/.grimoire/development/tasks/patterns.md +336 -0
  499. package/.grimoire/development/tasks/plan-create-context.md +812 -0
  500. package/.grimoire/development/tasks/plan-create-implementation.md +797 -0
  501. package/.grimoire/development/tasks/plan-execute-subtask.md +962 -0
  502. package/.grimoire/development/tasks/po-backlog-add.md +372 -0
  503. package/.grimoire/development/tasks/po-close-story.md +428 -0
  504. package/.grimoire/development/tasks/po-manage-story-backlog.md +525 -0
  505. package/.grimoire/development/tasks/po-pull-story-from-clickup.md +542 -0
  506. package/.grimoire/development/tasks/po-pull-story.md +318 -0
  507. package/.grimoire/development/tasks/po-stories-index.md +353 -0
  508. package/.grimoire/development/tasks/po-sync-story-to-clickup.md +459 -0
  509. package/.grimoire/development/tasks/po-sync-story.md +305 -0
  510. package/.grimoire/development/tasks/pr-automation.md +703 -0
  511. package/.grimoire/development/tasks/propose-modification.md +844 -0
  512. package/.grimoire/development/tasks/publish-npm.md +259 -0
  513. package/.grimoire/development/tasks/qa-after-creation.md +519 -0
  514. package/.grimoire/development/tasks/qa-backlog-add-followup.md +427 -0
  515. package/.grimoire/development/tasks/qa-browser-console-check.md +343 -0
  516. package/.grimoire/development/tasks/qa-create-fix-request.md +625 -0
  517. package/.grimoire/development/tasks/qa-evidence-requirements.md +314 -0
  518. package/.grimoire/development/tasks/qa-false-positive-detection.md +374 -0
  519. package/.grimoire/development/tasks/qa-fix-issues.md +686 -0
  520. package/.grimoire/development/tasks/qa-gate.md +375 -0
  521. package/.grimoire/development/tasks/qa-generate-tests.md +1176 -0
  522. package/.grimoire/development/tasks/qa-library-validation.md +497 -0
  523. package/.grimoire/development/tasks/qa-migration-validation.md +584 -0
  524. package/.grimoire/development/tasks/qa-nfr-assess.md +559 -0
  525. package/.grimoire/development/tasks/qa-review-build.md +1225 -0
  526. package/.grimoire/development/tasks/qa-review-proposal.md +1159 -0
  527. package/.grimoire/development/tasks/qa-review-story.md +684 -0
  528. package/.grimoire/development/tasks/qa-risk-profile.md +568 -0
  529. package/.grimoire/development/tasks/qa-run-tests.md +279 -0
  530. package/.grimoire/development/tasks/qa-security-checklist.md +552 -0
  531. package/.grimoire/development/tasks/qa-test-design.md +389 -0
  532. package/.grimoire/development/tasks/qa-trace-requirements.md +478 -0
  533. package/.grimoire/development/tasks/release-management.md +754 -0
  534. package/.grimoire/development/tasks/remove-mcp.md +35 -0
  535. package/.grimoire/development/tasks/remove-worktree.md +435 -0
  536. package/.grimoire/development/tasks/run-design-system-pipeline.md +642 -0
  537. package/.grimoire/development/tasks/run-workflow-engine.md +861 -0
  538. package/.grimoire/development/tasks/run-workflow.md +389 -0
  539. package/.grimoire/development/tasks/search-mcp.md +309 -0
  540. package/.grimoire/development/tasks/security-audit.md +556 -0
  541. package/.grimoire/development/tasks/security-scan.md +792 -0
  542. package/.grimoire/development/tasks/session-resume.md +193 -0
  543. package/.grimoire/development/tasks/setup-database.md +743 -0
  544. package/.grimoire/development/tasks/setup-design-system.md +464 -0
  545. package/.grimoire/development/tasks/setup-github.md +876 -0
  546. package/.grimoire/development/tasks/setup-llm-routing.md +231 -0
  547. package/.grimoire/development/tasks/setup-mcp-docker.md +628 -0
  548. package/.grimoire/development/tasks/setup-project-docs.md +442 -0
  549. package/.grimoire/development/tasks/shard-doc.md +539 -0
  550. package/.grimoire/development/tasks/sm-create-next-story.md +482 -0
  551. package/.grimoire/development/tasks/spec-assess-complexity.md +461 -0
  552. package/.grimoire/development/tasks/spec-critique.md +595 -0
  553. package/.grimoire/development/tasks/spec-gather-requirements.md +545 -0
  554. package/.grimoire/development/tasks/spec-research-dependencies.md +446 -0
  555. package/.grimoire/development/tasks/spec-write-spec.md +531 -0
  556. package/.grimoire/development/tasks/squad-creator-analyze.md +318 -0
  557. package/.grimoire/development/tasks/squad-creator-create.md +314 -0
  558. package/.grimoire/development/tasks/squad-creator-design.md +335 -0
  559. package/.grimoire/development/tasks/squad-creator-download.md +169 -0
  560. package/.grimoire/development/tasks/squad-creator-extend.md +413 -0
  561. package/.grimoire/development/tasks/squad-creator-list.md +226 -0
  562. package/.grimoire/development/tasks/squad-creator-migrate.md +245 -0
  563. package/.grimoire/development/tasks/squad-creator-publish.md +231 -0
  564. package/.grimoire/development/tasks/squad-creator-sync-grimoire.md +317 -0
  565. package/.grimoire/development/tasks/squad-creator-sync-ide-command.md +403 -0
  566. package/.grimoire/development/tasks/squad-creator-validate.md +160 -0
  567. package/.grimoire/development/tasks/story-checkpoint.md +361 -0
  568. package/.grimoire/development/tasks/sync-documentation.md +866 -0
  569. package/.grimoire/development/tasks/tailwind-upgrade.md +296 -0
  570. package/.grimoire/development/tasks/test-as-user.md +623 -0
  571. package/.grimoire/development/tasks/test-validation-task.md +172 -0
  572. package/.grimoire/development/tasks/undo-last.md +348 -0
  573. package/.grimoire/development/tasks/update-grimoire.md +153 -0
  574. package/.grimoire/development/tasks/update-manifest.md +411 -0
  575. package/.grimoire/development/tasks/update-source-tree.md +138 -0
  576. package/.grimoire/development/tasks/ux-create-wireframe.md +619 -0
  577. package/.grimoire/development/tasks/ux-ds-scan-artifact.md +674 -0
  578. package/.grimoire/development/tasks/ux-user-research.md +561 -0
  579. package/.grimoire/development/tasks/validate-agents.md +117 -0
  580. package/.grimoire/development/tasks/validate-next-story.md +456 -0
  581. package/.grimoire/development/tasks/validate-tech-preset.md +187 -0
  582. package/.grimoire/development/tasks/validate-workflow.md +323 -0
  583. package/.grimoire/development/tasks/verify-subtask.md +237 -0
  584. package/.grimoire/development/tasks/waves.md +206 -0
  585. package/.grimoire/development/tasks/yolo-toggle.md +115 -0
  586. package/.grimoire/development/templates/grimoire-doc-template.md +496 -0
  587. package/.grimoire/development/templates/research-prompt-tmpl.md +486 -0
  588. package/.grimoire/development/templates/service-template/README.md.hbs +159 -0
  589. package/.grimoire/development/templates/service-template/__tests__/index.test.ts.hbs +238 -0
  590. package/.grimoire/development/templates/service-template/client.ts.hbs +404 -0
  591. package/.grimoire/development/templates/service-template/errors.ts.hbs +183 -0
  592. package/.grimoire/development/templates/service-template/index.ts.hbs +121 -0
  593. package/.grimoire/development/templates/service-template/jest.config.js +89 -0
  594. package/.grimoire/development/templates/service-template/package.json.hbs +88 -0
  595. package/.grimoire/development/templates/service-template/tsconfig.json +45 -0
  596. package/.grimoire/development/templates/service-template/types.ts.hbs +146 -0
  597. package/.grimoire/development/templates/squad/agent-template.md +69 -0
  598. package/.grimoire/development/templates/squad/checklist-template.md +82 -0
  599. package/.grimoire/development/templates/squad/data-template.yaml +105 -0
  600. package/.grimoire/development/templates/squad/script-template.js +179 -0
  601. package/.grimoire/development/templates/squad/task-template.md +125 -0
  602. package/.grimoire/development/templates/squad/template-template.md +98 -0
  603. package/.grimoire/development/templates/squad/tool-template.js +103 -0
  604. package/.grimoire/development/templates/squad/workflow-template.yaml +108 -0
  605. package/.grimoire/development/templates/squad-template/LICENSE +21 -0
  606. package/.grimoire/development/templates/squad-template/README.md +37 -0
  607. package/.grimoire/development/templates/squad-template/agents/example-agent.yaml +36 -0
  608. package/.grimoire/development/templates/squad-template/package.json +20 -0
  609. package/.grimoire/development/templates/squad-template/squad.yaml +26 -0
  610. package/.grimoire/development/templates/squad-template/tasks/example-task.yaml +46 -0
  611. package/.grimoire/development/templates/squad-template/templates/example-template.md +24 -0
  612. package/.grimoire/development/templates/squad-template/tests/example-agent.test.js +54 -0
  613. package/.grimoire/development/templates/squad-template/workflows/example-workflow.yaml +54 -0
  614. package/.grimoire/development/templates/subagent-step-prompt.md +122 -0
  615. package/.grimoire/development/workflows/README.md +82 -0
  616. package/.grimoire/development/workflows/auto-worktree.yaml +423 -0
  617. package/.grimoire/development/workflows/brownfield-discovery.yaml +933 -0
  618. package/.grimoire/development/workflows/brownfield-fullstack.yaml +369 -0
  619. package/.grimoire/development/workflows/brownfield-service.yaml +246 -0
  620. package/.grimoire/development/workflows/brownfield-ui.yaml +260 -0
  621. package/.grimoire/development/workflows/design-system-build-quality.yaml +228 -0
  622. package/.grimoire/development/workflows/development-cycle.yaml +427 -0
  623. package/.grimoire/development/workflows/epic-orchestration.yaml +328 -0
  624. package/.grimoire/development/workflows/greenfield-fullstack.yaml +386 -0
  625. package/.grimoire/development/workflows/greenfield-service.yaml +278 -0
  626. package/.grimoire/development/workflows/greenfield-ui.yaml +284 -0
  627. package/.grimoire/development/workflows/qa-loop.yaml +444 -0
  628. package/.grimoire/development/workflows/spec-pipeline.yaml +577 -0
  629. package/.grimoire/development/workflows/story-development-cycle.yaml +285 -0
  630. package/.grimoire/docs/standards/AGENT-PERSONALIZATION-STANDARD-V1.md +574 -0
  631. package/.grimoire/docs/standards/EXECUTOR-DECISION-TREE.md +698 -0
  632. package/.grimoire/docs/standards/OPEN-SOURCE-VS-SERVICE-DIFFERENCES.md +513 -0
  633. package/.grimoire/docs/standards/QUALITY-GATES-SPECIFICATION.md +558 -0
  634. package/.grimoire/docs/standards/STANDARDS-INDEX.md +212 -0
  635. package/.grimoire/docs/standards/STORY-TEMPLATE-V2-SPECIFICATION.md +551 -0
  636. package/.grimoire/docs/standards/TASK-FORMAT-SPECIFICATION-V1.md +1415 -0
  637. package/.grimoire/docs/standards/grimoire-COLOR-PALETTE-QUICK-REFERENCE.md +186 -0
  638. package/.grimoire/docs/standards/grimoire-COLOR-PALETTE-V2.1.md +354 -0
  639. package/.grimoire/docs/standards/grimoire-LIVRO-DE-OURO-V2.1-COMPLETE.md +839 -0
  640. package/.grimoire/docs/standards/grimoire-LIVRO-DE-OURO-V2.2-SUMMARY.md +1341 -0
  641. package/.grimoire/elicitation/agent-elicitation.js +272 -0
  642. package/.grimoire/elicitation/task-elicitation.js +281 -0
  643. package/.grimoire/elicitation/workflow-elicitation.js +315 -0
  644. package/.grimoire/framework-config.yaml +152 -0
  645. package/.grimoire/hooks/gemini/after-tool.js +78 -0
  646. package/.grimoire/hooks/gemini/before-agent.js +80 -0
  647. package/.grimoire/hooks/gemini/before-tool.js +115 -0
  648. package/.grimoire/hooks/gemini/rewind-handler.js +69 -0
  649. package/.grimoire/hooks/gemini/session-end.js +91 -0
  650. package/.grimoire/hooks/gemini/session-start.js +91 -0
  651. package/.grimoire/hooks/ids-post-commit.js +118 -0
  652. package/.grimoire/hooks/ids-pre-push.js +125 -0
  653. package/.grimoire/hooks/unified/README.md +309 -0
  654. package/.grimoire/hooks/unified/hook-interface.js +161 -0
  655. package/.grimoire/hooks/unified/hook-registry.js +143 -0
  656. package/.grimoire/hooks/unified/index.js +36 -0
  657. package/.grimoire/hooks/unified/runners/precompact-runner.js +98 -0
  658. package/.grimoire/index.esm.js +17 -0
  659. package/.grimoire/index.js +17 -0
  660. package/.grimoire/infrastructure/README.md +128 -0
  661. package/.grimoire/infrastructure/contracts/compatibility/grimoire-4.0.4.yaml +46 -0
  662. package/.grimoire/infrastructure/index.js +200 -0
  663. package/.grimoire/infrastructure/integrations/ai-providers/README.md +103 -0
  664. package/.grimoire/infrastructure/integrations/ai-providers/ai-provider-factory.js +286 -0
  665. package/.grimoire/infrastructure/integrations/ai-providers/ai-provider.js +145 -0
  666. package/.grimoire/infrastructure/integrations/ai-providers/claude-provider.js +170 -0
  667. package/.grimoire/infrastructure/integrations/ai-providers/gemini-provider.js +365 -0
  668. package/.grimoire/infrastructure/integrations/ai-providers/index.js +45 -0
  669. package/.grimoire/infrastructure/integrations/gemini-extensions/cloudrun-adapter.js +129 -0
  670. package/.grimoire/infrastructure/integrations/gemini-extensions/index.js +41 -0
  671. package/.grimoire/infrastructure/integrations/gemini-extensions/policy-sync.js +74 -0
  672. package/.grimoire/infrastructure/integrations/gemini-extensions/security-adapter.js +159 -0
  673. package/.grimoire/infrastructure/integrations/gemini-extensions/supabase-adapter.js +88 -0
  674. package/.grimoire/infrastructure/integrations/gemini-extensions/workspace-adapter.js +100 -0
  675. package/.grimoire/infrastructure/integrations/pm-adapters/README.md +60 -0
  676. package/.grimoire/infrastructure/integrations/pm-adapters/clickup-adapter.js +345 -0
  677. package/.grimoire/infrastructure/integrations/pm-adapters/github-adapter.js +393 -0
  678. package/.grimoire/infrastructure/integrations/pm-adapters/jira-adapter.js +449 -0
  679. package/.grimoire/infrastructure/integrations/pm-adapters/local-adapter.js +176 -0
  680. package/.grimoire/infrastructure/schemas/agent-v3-schema.json +160 -0
  681. package/.grimoire/infrastructure/schemas/build-state.schema.json +158 -0
  682. package/.grimoire/infrastructure/schemas/task-v3-schema.json +152 -0
  683. package/.grimoire/infrastructure/scripts/approach-manager.js +1005 -0
  684. package/.grimoire/infrastructure/scripts/approval-workflow.js +644 -0
  685. package/.grimoire/infrastructure/scripts/asset-inventory.js +622 -0
  686. package/.grimoire/infrastructure/scripts/atomic-layer-classifier.js +309 -0
  687. package/.grimoire/infrastructure/scripts/backup-manager.js +607 -0
  688. package/.grimoire/infrastructure/scripts/batch-creator.js +609 -0
  689. package/.grimoire/infrastructure/scripts/branch-manager.js +391 -0
  690. package/.grimoire/infrastructure/scripts/capability-analyzer.js +535 -0
  691. package/.grimoire/infrastructure/scripts/changelog-generator.js +554 -0
  692. package/.grimoire/infrastructure/scripts/cicd-discovery.js +1269 -0
  693. package/.grimoire/infrastructure/scripts/clickup-helpers.js +227 -0
  694. package/.grimoire/infrastructure/scripts/code-quality-improver.js +1312 -0
  695. package/.grimoire/infrastructure/scripts/codebase-mapper.js +1288 -0
  696. package/.grimoire/infrastructure/scripts/codex-skills-sync/index.js +184 -0
  697. package/.grimoire/infrastructure/scripts/codex-skills-sync/validate.js +174 -0
  698. package/.grimoire/infrastructure/scripts/commit-message-generator.js +850 -0
  699. package/.grimoire/infrastructure/scripts/component-generator.js +738 -0
  700. package/.grimoire/infrastructure/scripts/component-metadata.js +628 -0
  701. package/.grimoire/infrastructure/scripts/component-search.js +278 -0
  702. package/.grimoire/infrastructure/scripts/config-cache.js +322 -0
  703. package/.grimoire/infrastructure/scripts/config-loader.js +351 -0
  704. package/.grimoire/infrastructure/scripts/conflict-resolver.js +675 -0
  705. package/.grimoire/infrastructure/scripts/coverage-analyzer.js +882 -0
  706. package/.grimoire/infrastructure/scripts/dashboard-status-writer.js +310 -0
  707. package/.grimoire/infrastructure/scripts/dependency-analyzer.js +639 -0
  708. package/.grimoire/infrastructure/scripts/dependency-impact-analyzer.js +704 -0
  709. package/.grimoire/infrastructure/scripts/diff-generator.js +129 -0
  710. package/.grimoire/infrastructure/scripts/documentation-integrity/brownfield-analyzer.js +502 -0
  711. package/.grimoire/infrastructure/scripts/documentation-integrity/config-generator.js +369 -0
  712. package/.grimoire/infrastructure/scripts/documentation-integrity/deployment-config-loader.js +309 -0
  713. package/.grimoire/infrastructure/scripts/documentation-integrity/doc-generator.js +331 -0
  714. package/.grimoire/infrastructure/scripts/documentation-integrity/gitignore-generator.js +314 -0
  715. package/.grimoire/infrastructure/scripts/documentation-integrity/index.js +75 -0
  716. package/.grimoire/infrastructure/scripts/documentation-integrity/mode-detector.js +391 -0
  717. package/.grimoire/infrastructure/scripts/documentation-synchronizer.js +1432 -0
  718. package/.grimoire/infrastructure/scripts/framework-analyzer.js +763 -0
  719. package/.grimoire/infrastructure/scripts/git-config-detector.js +293 -0
  720. package/.grimoire/infrastructure/scripts/git-hooks/post-commit.js +75 -0
  721. package/.grimoire/infrastructure/scripts/git-wrapper.js +444 -0
  722. package/.grimoire/infrastructure/scripts/gotchas-documenter.js +1296 -0
  723. package/.grimoire/infrastructure/scripts/grimoire-validator.js +295 -0
  724. package/.grimoire/infrastructure/scripts/ide-sync/README.md +220 -0
  725. package/.grimoire/infrastructure/scripts/ide-sync/agent-parser.js +295 -0
  726. package/.grimoire/infrastructure/scripts/ide-sync/gemini-commands.js +207 -0
  727. package/.grimoire/infrastructure/scripts/ide-sync/index.js +540 -0
  728. package/.grimoire/infrastructure/scripts/ide-sync/redirect-generator.js +179 -0
  729. package/.grimoire/infrastructure/scripts/ide-sync/transformers/antigravity.js +107 -0
  730. package/.grimoire/infrastructure/scripts/ide-sync/transformers/claude-code.js +86 -0
  731. package/.grimoire/infrastructure/scripts/ide-sync/transformers/cursor.js +96 -0
  732. package/.grimoire/infrastructure/scripts/ide-sync/validator.js +273 -0
  733. package/.grimoire/infrastructure/scripts/improvement-engine.js +758 -0
  734. package/.grimoire/infrastructure/scripts/improvement-validator.js +710 -0
  735. package/.grimoire/infrastructure/scripts/llm-routing/install-llm-routing.js +282 -0
  736. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-free-tracked.cmd +129 -0
  737. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-free-tracked.sh +108 -0
  738. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-free.cmd +80 -0
  739. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-free.sh +62 -0
  740. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-max.cmd +26 -0
  741. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-max.sh +18 -0
  742. package/.grimoire/infrastructure/scripts/llm-routing/templates/deepseek-proxy.cmd +73 -0
  743. package/.grimoire/infrastructure/scripts/llm-routing/templates/deepseek-proxy.sh +65 -0
  744. package/.grimoire/infrastructure/scripts/llm-routing/templates/deepseek-usage.cmd +53 -0
  745. package/.grimoire/infrastructure/scripts/llm-routing/templates/deepseek-usage.sh +16 -0
  746. package/.grimoire/infrastructure/scripts/llm-routing/usage-tracker/index.js +551 -0
  747. package/.grimoire/infrastructure/scripts/migrate-agent.js +528 -0
  748. package/.grimoire/infrastructure/scripts/modification-risk-assessment.js +970 -0
  749. package/.grimoire/infrastructure/scripts/modification-validator.js +555 -0
  750. package/.grimoire/infrastructure/scripts/output-formatter.js +298 -0
  751. package/.grimoire/infrastructure/scripts/path-analyzer.js +476 -0
  752. package/.grimoire/infrastructure/scripts/pattern-extractor.js +1563 -0
  753. package/.grimoire/infrastructure/scripts/performance-analyzer.js +758 -0
  754. package/.grimoire/infrastructure/scripts/performance-and-error-resolver.js +258 -0
  755. package/.grimoire/infrastructure/scripts/performance-optimizer.js +1902 -0
  756. package/.grimoire/infrastructure/scripts/performance-tracker.js +454 -0
  757. package/.grimoire/infrastructure/scripts/plan-tracker.js +922 -0
  758. package/.grimoire/infrastructure/scripts/pm-adapter-factory.js +182 -0
  759. package/.grimoire/infrastructure/scripts/pm-adapter.js +134 -0
  760. package/.grimoire/infrastructure/scripts/pr-review-ai.js +1062 -0
  761. package/.grimoire/infrastructure/scripts/project-status-loader.js +850 -0
  762. package/.grimoire/infrastructure/scripts/qa-loop-orchestrator.js +1264 -0
  763. package/.grimoire/infrastructure/scripts/qa-report-generator.js +1154 -0
  764. package/.grimoire/infrastructure/scripts/recovery-tracker.js +965 -0
  765. package/.grimoire/infrastructure/scripts/refactoring-suggester.js +1139 -0
  766. package/.grimoire/infrastructure/scripts/repository-detector.js +66 -0
  767. package/.grimoire/infrastructure/scripts/rollback-manager.js +734 -0
  768. package/.grimoire/infrastructure/scripts/sandbox-tester.js +618 -0
  769. package/.grimoire/infrastructure/scripts/security-checker.js +359 -0
  770. package/.grimoire/infrastructure/scripts/spot-check-validator.js +149 -0
  771. package/.grimoire/infrastructure/scripts/status-mapper.js +116 -0
  772. package/.grimoire/infrastructure/scripts/story-worktree-hooks.js +426 -0
  773. package/.grimoire/infrastructure/scripts/stuck-detector.js +1251 -0
  774. package/.grimoire/infrastructure/scripts/subtask-verifier.js +793 -0
  775. package/.grimoire/infrastructure/scripts/template-engine.js +240 -0
  776. package/.grimoire/infrastructure/scripts/template-validator.js +279 -0
  777. package/.grimoire/infrastructure/scripts/test-discovery.js +1259 -0
  778. package/.grimoire/infrastructure/scripts/test-generator.js +845 -0
  779. package/.grimoire/infrastructure/scripts/test-quality-assessment.js +1082 -0
  780. package/.grimoire/infrastructure/scripts/test-utilities-fast.js +126 -0
  781. package/.grimoire/infrastructure/scripts/test-utilities.js +201 -0
  782. package/.grimoire/infrastructure/scripts/tool-resolver.js +362 -0
  783. package/.grimoire/infrastructure/scripts/transaction-manager.js +590 -0
  784. package/.grimoire/infrastructure/scripts/usage-analytics.js +636 -0
  785. package/.grimoire/infrastructure/scripts/validate-agents.js +527 -0
  786. package/.grimoire/infrastructure/scripts/validate-claude-integration.js +103 -0
  787. package/.grimoire/infrastructure/scripts/validate-codex-integration.js +143 -0
  788. package/.grimoire/infrastructure/scripts/validate-gemini-integration.js +153 -0
  789. package/.grimoire/infrastructure/scripts/validate-output-pattern.js +213 -0
  790. package/.grimoire/infrastructure/scripts/validate-parity.js +357 -0
  791. package/.grimoire/infrastructure/scripts/validate-paths.js +144 -0
  792. package/.grimoire/infrastructure/scripts/validate-user-profile.js +251 -0
  793. package/.grimoire/infrastructure/scripts/visual-impact-generator.js +1056 -0
  794. package/.grimoire/infrastructure/scripts/worktree-manager.js +704 -0
  795. package/.grimoire/infrastructure/scripts/yaml-validator.js +397 -0
  796. package/.grimoire/infrastructure/templates/coderabbit.yaml.template +280 -0
  797. package/.grimoire/infrastructure/templates/core-config/core-config-brownfield.tmpl.yaml +177 -0
  798. package/.grimoire/infrastructure/templates/core-config/core-config-greenfield.tmpl.yaml +169 -0
  799. package/.grimoire/infrastructure/templates/github-workflows/README.md +110 -0
  800. package/.grimoire/infrastructure/templates/github-workflows/ci.yml.template +170 -0
  801. package/.grimoire/infrastructure/templates/github-workflows/pr-automation.yml.template +331 -0
  802. package/.grimoire/infrastructure/templates/github-workflows/release.yml.template +197 -0
  803. package/.grimoire/infrastructure/templates/gitignore/gitignore-brownfield-merge.tmpl +20 -0
  804. package/.grimoire/infrastructure/templates/gitignore/gitignore-grimoire-base.tmpl +65 -0
  805. package/.grimoire/infrastructure/templates/gitignore/gitignore-node.tmpl +86 -0
  806. package/.grimoire/infrastructure/templates/gitignore/gitignore-python.tmpl +146 -0
  807. package/.grimoire/infrastructure/templates/grimoire-sync.yaml.template +183 -0
  808. package/.grimoire/infrastructure/templates/project-docs/coding-standards-tmpl.md +347 -0
  809. package/.grimoire/infrastructure/templates/project-docs/source-tree-tmpl.md +179 -0
  810. package/.grimoire/infrastructure/templates/project-docs/tech-stack-tmpl.md +269 -0
  811. package/.grimoire/infrastructure/tests/project-status-loader.test.js +569 -0
  812. package/.grimoire/infrastructure/tests/regression-suite-v2.md +622 -0
  813. package/.grimoire/infrastructure/tests/validate-module.js +98 -0
  814. package/.grimoire/infrastructure/tests/worktree-manager.test.js +620 -0
  815. package/.grimoire/infrastructure/tools/README.md +224 -0
  816. package/.grimoire/infrastructure/tools/cli/github-cli.yaml +200 -0
  817. package/.grimoire/infrastructure/tools/cli/llm-routing.yaml +128 -0
  818. package/.grimoire/infrastructure/tools/cli/railway-cli.yaml +260 -0
  819. package/.grimoire/infrastructure/tools/cli/supabase-cli.yaml +224 -0
  820. package/.grimoire/infrastructure/tools/local/ffmpeg.yaml +261 -0
  821. package/.grimoire/infrastructure/tools/mcp/21st-dev-magic.yaml +127 -0
  822. package/.grimoire/infrastructure/tools/mcp/browser.yaml +103 -0
  823. package/.grimoire/infrastructure/tools/mcp/clickup.yaml +535 -0
  824. package/.grimoire/infrastructure/tools/mcp/context7.yaml +78 -0
  825. package/.grimoire/infrastructure/tools/mcp/desktop-commander.yaml +180 -0
  826. package/.grimoire/infrastructure/tools/mcp/exa.yaml +103 -0
  827. package/.grimoire/infrastructure/tools/mcp/google-workspace.yaml +930 -0
  828. package/.grimoire/infrastructure/tools/mcp/n8n.yaml +551 -0
  829. package/.grimoire/infrastructure/tools/mcp/supabase.yaml +808 -0
  830. package/.grimoire/install-manifest.yaml +4058 -0
  831. package/.grimoire/local-config.yaml.template +73 -0
  832. package/.grimoire/manifests/schema/manifest-schema.json +191 -0
  833. package/.grimoire/monitor/hooks/lib/__init__.py +2 -0
  834. package/.grimoire/monitor/hooks/lib/enrich.py +59 -0
  835. package/.grimoire/monitor/hooks/lib/send_event.py +48 -0
  836. package/.grimoire/monitor/hooks/notification.py +30 -0
  837. package/.grimoire/monitor/hooks/post_tool_use.py +46 -0
  838. package/.grimoire/monitor/hooks/pre_compact.py +30 -0
  839. package/.grimoire/monitor/hooks/pre_tool_use.py +41 -0
  840. package/.grimoire/monitor/hooks/stop.py +30 -0
  841. package/.grimoire/monitor/hooks/subagent_stop.py +30 -0
  842. package/.grimoire/monitor/hooks/user_prompt_submit.py +39 -0
  843. package/.grimoire/package.json +104 -0
  844. package/.grimoire/presets/README.md +359 -0
  845. package/.grimoire/product/README.md +57 -0
  846. package/.grimoire/product/checklists/accessibility-wcag-checklist.md +80 -0
  847. package/.grimoire/product/checklists/architect-checklist.md +444 -0
  848. package/.grimoire/product/checklists/change-checklist.md +183 -0
  849. package/.grimoire/product/checklists/component-quality-checklist.md +74 -0
  850. package/.grimoire/product/checklists/database-design-checklist.md +119 -0
  851. package/.grimoire/product/checklists/dba-predeploy-checklist.md +97 -0
  852. package/.grimoire/product/checklists/dba-rollback-checklist.md +99 -0
  853. package/.grimoire/product/checklists/migration-readiness-checklist.md +75 -0
  854. package/.grimoire/product/checklists/pattern-audit-checklist.md +88 -0
  855. package/.grimoire/product/checklists/pm-checklist.md +376 -0
  856. package/.grimoire/product/checklists/po-master-checklist.md +442 -0
  857. package/.grimoire/product/checklists/pre-push-checklist.md +108 -0
  858. package/.grimoire/product/checklists/release-checklist.md +122 -0
  859. package/.grimoire/product/checklists/self-critique-checklist.md +387 -0
  860. package/.grimoire/product/checklists/story-dod-checklist.md +102 -0
  861. package/.grimoire/product/checklists/story-draft-checklist.md +216 -0
  862. package/.grimoire/product/data/atomic-design-principles.md +108 -0
  863. package/.grimoire/product/data/brainstorming-techniques.md +37 -0
  864. package/.grimoire/product/data/consolidation-algorithms.md +142 -0
  865. package/.grimoire/product/data/database-best-practices.md +182 -0
  866. package/.grimoire/product/data/design-token-best-practices.md +107 -0
  867. package/.grimoire/product/data/elicitation-methods.md +135 -0
  868. package/.grimoire/product/data/integration-patterns.md +207 -0
  869. package/.grimoire/product/data/migration-safety-guide.md +329 -0
  870. package/.grimoire/product/data/mode-selection-best-practices.md +471 -0
  871. package/.grimoire/product/data/postgres-tuning-guide.md +300 -0
  872. package/.grimoire/product/data/rls-security-patterns.md +333 -0
  873. package/.grimoire/product/data/roi-calculation-guide.md +142 -0
  874. package/.grimoire/product/data/supabase-patterns.md +330 -0
  875. package/.grimoire/product/data/test-levels-framework.md +149 -0
  876. package/.grimoire/product/data/test-priorities-matrix.md +175 -0
  877. package/.grimoire/product/data/wcag-compliance-guide.md +267 -0
  878. package/.grimoire/product/templates/activation-instructions-inline-greeting.yaml +64 -0
  879. package/.grimoire/product/templates/activation-instructions-template.md +260 -0
  880. package/.grimoire/product/templates/adr.hbs +126 -0
  881. package/.grimoire/product/templates/agent-template.yaml +122 -0
  882. package/.grimoire/product/templates/architecture-tmpl.yaml +651 -0
  883. package/.grimoire/product/templates/brainstorming-output-tmpl.yaml +156 -0
  884. package/.grimoire/product/templates/brownfield-architecture-tmpl.yaml +476 -0
  885. package/.grimoire/product/templates/brownfield-prd-tmpl.yaml +280 -0
  886. package/.grimoire/product/templates/brownfield-risk-report-tmpl.yaml +278 -0
  887. package/.grimoire/product/templates/changelog-template.md +134 -0
  888. package/.grimoire/product/templates/command-rationalization-matrix.md +154 -0
  889. package/.grimoire/product/templates/competitor-analysis-tmpl.yaml +293 -0
  890. package/.grimoire/product/templates/component-react-tmpl.tsx +98 -0
  891. package/.grimoire/product/templates/current-approach-tmpl.md +56 -0
  892. package/.grimoire/product/templates/dbdr.hbs +242 -0
  893. package/.grimoire/product/templates/design-story-tmpl.yaml +588 -0
  894. package/.grimoire/product/templates/ds-artifact-analysis.md +70 -0
  895. package/.grimoire/product/templates/engine/elicitation.js +298 -0
  896. package/.grimoire/product/templates/engine/index.js +310 -0
  897. package/.grimoire/product/templates/engine/loader.js +232 -0
  898. package/.grimoire/product/templates/engine/renderer.js +343 -0
  899. package/.grimoire/product/templates/engine/schemas/adr.schema.json +102 -0
  900. package/.grimoire/product/templates/engine/schemas/dbdr.schema.json +205 -0
  901. package/.grimoire/product/templates/engine/schemas/epic.schema.json +175 -0
  902. package/.grimoire/product/templates/engine/schemas/pmdr.schema.json +175 -0
  903. package/.grimoire/product/templates/engine/schemas/prd-v2.schema.json +300 -0
  904. package/.grimoire/product/templates/engine/schemas/prd.schema.json +152 -0
  905. package/.grimoire/product/templates/engine/schemas/story.schema.json +222 -0
  906. package/.grimoire/product/templates/engine/schemas/task.schema.json +154 -0
  907. package/.grimoire/product/templates/engine/validator.js +295 -0
  908. package/.grimoire/product/templates/epic.hbs +213 -0
  909. package/.grimoire/product/templates/eslintrc-security.json +32 -0
  910. package/.grimoire/product/templates/front-end-architecture-tmpl.yaml +206 -0
  911. package/.grimoire/product/templates/front-end-spec-tmpl.yaml +349 -0
  912. package/.grimoire/product/templates/fullstack-architecture-tmpl.yaml +805 -0
  913. package/.grimoire/product/templates/gemini/settings.json +81 -0
  914. package/.grimoire/product/templates/github-actions-cd.yml +213 -0
  915. package/.grimoire/product/templates/github-actions-ci.yml +173 -0
  916. package/.grimoire/product/templates/github-pr-template.md +68 -0
  917. package/.grimoire/product/templates/gordon-mcp.yaml +141 -0
  918. package/.grimoire/product/templates/grimoire-ai-config.yaml +107 -0
  919. package/.grimoire/product/templates/ide-rules/antigravity-rules.md +117 -0
  920. package/.grimoire/product/templates/ide-rules/claude-rules.md +233 -0
  921. package/.grimoire/product/templates/ide-rules/codex-rules.md +67 -0
  922. package/.grimoire/product/templates/ide-rules/copilot-rules.md +94 -0
  923. package/.grimoire/product/templates/ide-rules/cursor-rules.md +116 -0
  924. package/.grimoire/product/templates/ide-rules/gemini-rules.md +89 -0
  925. package/.grimoire/product/templates/index-strategy-tmpl.yaml +53 -0
  926. package/.grimoire/product/templates/market-research-tmpl.yaml +252 -0
  927. package/.grimoire/product/templates/mcp-workflow.js +273 -0
  928. package/.grimoire/product/templates/migration-plan-tmpl.yaml +1022 -0
  929. package/.grimoire/product/templates/migration-strategy-tmpl.md +524 -0
  930. package/.grimoire/product/templates/personalized-agent-template.md +260 -0
  931. package/.grimoire/product/templates/personalized-checklist-template.md +341 -0
  932. package/.grimoire/product/templates/personalized-task-template-v2.md +907 -0
  933. package/.grimoire/product/templates/personalized-task-template.md +345 -0
  934. package/.grimoire/product/templates/personalized-template-file.yaml +323 -0
  935. package/.grimoire/product/templates/personalized-workflow-template.yaml +461 -0
  936. package/.grimoire/product/templates/pmdr.hbs +187 -0
  937. package/.grimoire/product/templates/prd-tmpl.yaml +202 -0
  938. package/.grimoire/product/templates/prd-v2.0.hbs +217 -0
  939. package/.grimoire/product/templates/prd.hbs +202 -0
  940. package/.grimoire/product/templates/project-brief-tmpl.yaml +221 -0
  941. package/.grimoire/product/templates/qa-gate-tmpl.yaml +240 -0
  942. package/.grimoire/product/templates/qa-report-tmpl.md +235 -0
  943. package/.grimoire/product/templates/rls-policies-tmpl.yaml +1203 -0
  944. package/.grimoire/product/templates/schema-design-tmpl.yaml +428 -0
  945. package/.grimoire/product/templates/shock-report-tmpl.html +502 -0
  946. package/.grimoire/product/templates/spec-tmpl.md +235 -0
  947. package/.grimoire/product/templates/state-persistence-tmpl.yaml +219 -0
  948. package/.grimoire/product/templates/statusline/statusline-script.js +190 -0
  949. package/.grimoire/product/templates/statusline/track-agent.sh +70 -0
  950. package/.grimoire/product/templates/story-tmpl.yaml +369 -0
  951. package/.grimoire/product/templates/story.hbs +264 -0
  952. package/.grimoire/product/templates/task-execution-report.md +496 -0
  953. package/.grimoire/product/templates/task-template.md +123 -0
  954. package/.grimoire/product/templates/task.hbs +171 -0
  955. package/.grimoire/product/templates/tmpl-comment-on-examples.sql +158 -0
  956. package/.grimoire/product/templates/tmpl-migration-script.sql +91 -0
  957. package/.grimoire/product/templates/tmpl-rls-granular-policies.sql +104 -0
  958. package/.grimoire/product/templates/tmpl-rls-kiss-policy.sql +10 -0
  959. package/.grimoire/product/templates/tmpl-rls-roles.sql +135 -0
  960. package/.grimoire/product/templates/tmpl-rls-simple.sql +77 -0
  961. package/.grimoire/product/templates/tmpl-rls-tenant.sql +152 -0
  962. package/.grimoire/product/templates/tmpl-rollback-script.sql +77 -0
  963. package/.grimoire/product/templates/tmpl-seed-data.sql +140 -0
  964. package/.grimoire/product/templates/tmpl-smoke-test.sql +16 -0
  965. package/.grimoire/product/templates/tmpl-staging-copy-merge.sql +139 -0
  966. package/.grimoire/product/templates/tmpl-stored-proc.sql +140 -0
  967. package/.grimoire/product/templates/tmpl-trigger.sql +152 -0
  968. package/.grimoire/product/templates/tmpl-view-materialized.sql +133 -0
  969. package/.grimoire/product/templates/tmpl-view.sql +177 -0
  970. package/.grimoire/product/templates/token-exports-css-tmpl.css +240 -0
  971. package/.grimoire/product/templates/token-exports-tailwind-tmpl.js +395 -0
  972. package/.grimoire/product/templates/tokens-schema-tmpl.yaml +305 -0
  973. package/.grimoire/product/templates/workflow-template.yaml +152 -0
  974. package/.grimoire/project-config.yaml +166 -0
  975. package/.grimoire/quality/metrics-collector.js +601 -0
  976. package/.grimoire/quality/metrics-hook.js +261 -0
  977. package/.grimoire/quality/schemas/quality-metrics.schema.json +234 -0
  978. package/.grimoire/quality/seed-metrics.js +336 -0
  979. package/.grimoire/schemas/README.md +405 -0
  980. package/.grimoire/schemas/agent-v3-schema.json +395 -0
  981. package/.grimoire/schemas/squad-design-schema.json +300 -0
  982. package/.grimoire/schemas/squad-schema.json +187 -0
  983. package/.grimoire/schemas/task-v3-schema.json +354 -0
  984. package/.grimoire/schemas/validate-v3-schema.js +431 -0
  985. package/.grimoire/scripts/README.md +124 -0
  986. package/.grimoire/scripts/batch-migrate-phase1.ps1 +37 -0
  987. package/.grimoire/scripts/batch-migrate-phase2.ps1 +89 -0
  988. package/.grimoire/scripts/batch-migrate-phase3.ps1 +46 -0
  989. package/.grimoire/scripts/command-execution-hook.js +202 -0
  990. package/.grimoire/scripts/diagnostics/diagnose-installation.js +276 -0
  991. package/.grimoire/scripts/diagnostics/diagnose-npx-issue.ps1 +98 -0
  992. package/.grimoire/scripts/diagnostics/health-dashboard/README.md +123 -0
  993. package/.grimoire/scripts/diagnostics/health-dashboard/index.html +14 -0
  994. package/.grimoire/scripts/diagnostics/health-dashboard/package-lock.json +5262 -0
  995. package/.grimoire/scripts/diagnostics/health-dashboard/package.json +25 -0
  996. package/.grimoire/scripts/diagnostics/health-dashboard/public/favicon.svg +10 -0
  997. package/.grimoire/scripts/diagnostics/health-dashboard/src/App.jsx +22 -0
  998. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/AutoFixLog.css +122 -0
  999. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/AutoFixLog.jsx +72 -0
  1000. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/DomainCard.css +121 -0
  1001. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/DomainCard.jsx +116 -0
  1002. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/HealthScore.css +80 -0
  1003. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/HealthScore.jsx +81 -0
  1004. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/IssuesList.css +184 -0
  1005. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/IssuesList.jsx +145 -0
  1006. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/TechDebtList.css +114 -0
  1007. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/TechDebtList.jsx +72 -0
  1008. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/index.js +9 -0
  1009. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Card.css +44 -0
  1010. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Card.jsx +25 -0
  1011. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Chart.css +14 -0
  1012. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Chart.jsx +138 -0
  1013. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Header.css +54 -0
  1014. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Header.jsx +22 -0
  1015. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/StatusBadge.css +77 -0
  1016. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/StatusBadge.jsx +45 -0
  1017. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/index.js +4 -0
  1018. package/.grimoire/scripts/diagnostics/health-dashboard/src/hooks/index.js +2 -0
  1019. package/.grimoire/scripts/diagnostics/health-dashboard/src/hooks/useAutoRefresh.js +89 -0
  1020. package/.grimoire/scripts/diagnostics/health-dashboard/src/hooks/useHealthData.js +308 -0
  1021. package/.grimoire/scripts/diagnostics/health-dashboard/src/main.jsx +13 -0
  1022. package/.grimoire/scripts/diagnostics/health-dashboard/src/pages/Dashboard.css +238 -0
  1023. package/.grimoire/scripts/diagnostics/health-dashboard/src/pages/Dashboard.jsx +154 -0
  1024. package/.grimoire/scripts/diagnostics/health-dashboard/src/pages/DomainDetail.css +259 -0
  1025. package/.grimoire/scripts/diagnostics/health-dashboard/src/pages/DomainDetail.jsx +164 -0
  1026. package/.grimoire/scripts/diagnostics/health-dashboard/src/pages/index.js +2 -0
  1027. package/.grimoire/scripts/diagnostics/health-dashboard/src/styles/App.css +19 -0
  1028. package/.grimoire/scripts/diagnostics/health-dashboard/src/styles/index.css +67 -0
  1029. package/.grimoire/scripts/diagnostics/health-dashboard/vite.config.js +23 -0
  1030. package/.grimoire/scripts/diagnostics/quick-diagnose.cmd +86 -0
  1031. package/.grimoire/scripts/diagnostics/quick-diagnose.ps1 +118 -0
  1032. package/.grimoire/scripts/grimoire-doc-template.md +326 -0
  1033. package/.grimoire/scripts/migrate-framework-docs.sh +302 -0
  1034. package/.grimoire/scripts/pm.sh +455 -0
  1035. package/.grimoire/scripts/session-context-loader.js +46 -0
  1036. package/.grimoire/scripts/test-template-system.js +942 -0
  1037. package/.grimoire/scripts/update-grimoire.sh +176 -0
  1038. package/.grimoire/scripts/validate-phase1.ps1 +36 -0
  1039. package/.grimoire/scripts/workflow-management.md +70 -0
  1040. package/.grimoire/user-guide.md +1411 -0
  1041. package/.grimoire/utils/format-duration.js +95 -0
  1042. package/.grimoire/utils/grimoire-validator.js +27 -0
  1043. package/.grimoire/workflow-intelligence/__tests__/confidence-scorer.test.js +334 -0
  1044. package/.grimoire/workflow-intelligence/__tests__/integration.test.js +339 -0
  1045. package/.grimoire/workflow-intelligence/__tests__/suggestion-engine.test.js +437 -0
  1046. package/.grimoire/workflow-intelligence/__tests__/wave-analyzer.test.js +447 -0
  1047. package/.grimoire/workflow-intelligence/__tests__/workflow-registry.test.js +302 -0
  1048. package/.grimoire/workflow-intelligence/engine/confidence-scorer.js +306 -0
  1049. package/.grimoire/workflow-intelligence/engine/output-formatter.js +299 -0
  1050. package/.grimoire/workflow-intelligence/engine/suggestion-engine.js +798 -0
  1051. package/.grimoire/workflow-intelligence/engine/wave-analyzer.js +683 -0
  1052. package/.grimoire/workflow-intelligence/index.js +330 -0
  1053. package/.grimoire/workflow-intelligence/learning/capture-hook.js +148 -0
  1054. package/.grimoire/workflow-intelligence/learning/gotcha-registry.js +654 -0
  1055. package/.grimoire/workflow-intelligence/learning/index.js +306 -0
  1056. package/.grimoire/workflow-intelligence/learning/pattern-capture.js +330 -0
  1057. package/.grimoire/workflow-intelligence/learning/pattern-store.js +497 -0
  1058. package/.grimoire/workflow-intelligence/learning/pattern-validator.js +310 -0
  1059. package/.grimoire/workflow-intelligence/learning/qa-feedback.js +586 -0
  1060. package/.grimoire/workflow-intelligence/learning/semantic-search.js +521 -0
  1061. package/.grimoire/workflow-intelligence/registry/workflow-registry.js +357 -0
  1062. package/.grimoire/working-in-the-brownfield.md +362 -0
  1063. package/LICENSE +25 -0
  1064. package/README.md +59 -0
  1065. package/bin/grimoire-ids.js +560 -0
  1066. package/bin/grimoire-init.js +1232 -0
  1067. package/bin/grimoire-minimal.js +40 -0
  1068. package/bin/grimoire.js +1118 -0
  1069. package/bin/modules/env-config.js +436 -0
  1070. package/bin/modules/mcp-installer.js +384 -0
  1071. package/bin/utils/install-errors.js +340 -0
  1072. package/bin/utils/install-transaction.js +447 -0
  1073. package/bin/utils/pro-detector.js +110 -0
  1074. package/package.json +158 -0
  1075. package/packages/gemini-grimoire-extension/README.md +55 -0
  1076. package/packages/gemini-grimoire-extension/commands/grimoire-agent.js +7 -0
  1077. package/packages/gemini-grimoire-extension/commands/grimoire-agents.js +51 -0
  1078. package/packages/gemini-grimoire-extension/commands/grimoire-analyst.js +6 -0
  1079. package/packages/gemini-grimoire-extension/commands/grimoire-architect.js +6 -0
  1080. package/packages/gemini-grimoire-extension/commands/grimoire-data-engineer.js +6 -0
  1081. package/packages/gemini-grimoire-extension/commands/grimoire-dev.js +6 -0
  1082. package/packages/gemini-grimoire-extension/commands/grimoire-devops.js +6 -0
  1083. package/packages/gemini-grimoire-extension/commands/grimoire-master.js +7 -0
  1084. package/packages/gemini-grimoire-extension/commands/grimoire-menu.js +6 -0
  1085. package/packages/gemini-grimoire-extension/commands/grimoire-pm.js +6 -0
  1086. package/packages/gemini-grimoire-extension/commands/grimoire-po.js +6 -0
  1087. package/packages/gemini-grimoire-extension/commands/grimoire-qa.js +6 -0
  1088. package/packages/gemini-grimoire-extension/commands/grimoire-sm.js +6 -0
  1089. package/packages/gemini-grimoire-extension/commands/grimoire-squad-creator.js +6 -0
  1090. package/packages/gemini-grimoire-extension/commands/grimoire-status.js +68 -0
  1091. package/packages/gemini-grimoire-extension/commands/grimoire-ux-design-expert.js +6 -0
  1092. package/packages/gemini-grimoire-extension/commands/grimoire-validate.js +35 -0
  1093. package/packages/gemini-grimoire-extension/commands/lib/agent-launcher.js +147 -0
  1094. package/packages/gemini-grimoire-extension/extension.json +149 -0
  1095. package/packages/gemini-grimoire-extension/gemini-extension.json +149 -0
  1096. package/packages/gemini-grimoire-extension/hooks/hooks.json +72 -0
  1097. package/packages/grimoire-install/.releaserc.json +39 -0
  1098. package/packages/grimoire-install/CHANGELOG.md +33 -0
  1099. package/packages/grimoire-install/README.md +119 -0
  1100. package/packages/grimoire-install/bin/edmcp.js +80 -0
  1101. package/packages/grimoire-install/bin/grimoire-install.js +51 -0
  1102. package/packages/grimoire-install/jest.config.js +27 -0
  1103. package/packages/grimoire-install/package.json +68 -0
  1104. package/packages/grimoire-install/src/dep-checker.js +306 -0
  1105. package/packages/grimoire-install/src/edmcp/index.js +382 -0
  1106. package/packages/grimoire-install/src/installer.js +487 -0
  1107. package/packages/grimoire-install/src/os-detector.js +280 -0
  1108. package/packages/grimoire-pro-cli/bin/grimoire-pro.js +233 -0
  1109. package/packages/grimoire-pro-cli/package.json +38 -0
  1110. package/packages/grimoire-pro-cli/src/recover.js +101 -0
  1111. package/packages/installer/package.json +40 -0
  1112. package/packages/installer/src/__tests__/performance-benchmark.js +384 -0
  1113. package/packages/installer/src/config/configure-environment.js +373 -0
  1114. package/packages/installer/src/config/ide-configs.js +161 -0
  1115. package/packages/installer/src/config/templates/core-config-template.js +199 -0
  1116. package/packages/installer/src/config/templates/env-template.js +272 -0
  1117. package/packages/installer/src/config/validation/config-validator.js +244 -0
  1118. package/packages/installer/src/detection/detect-project-type.js +83 -0
  1119. package/packages/installer/src/installer/brownfield-upgrader.js +440 -0
  1120. package/packages/installer/src/installer/dependency-installer.js +335 -0
  1121. package/packages/installer/src/installer/file-hasher.js +234 -0
  1122. package/packages/installer/src/installer/grimoire-core-installer.js +428 -0
  1123. package/packages/installer/src/installer/manifest-signature.js +380 -0
  1124. package/packages/installer/src/installer/post-install-validator.js +1524 -0
  1125. package/packages/installer/src/merger/index.js +72 -0
  1126. package/packages/installer/src/merger/parsers/env-parser.js +153 -0
  1127. package/packages/installer/src/merger/parsers/markdown-section-parser.js +199 -0
  1128. package/packages/installer/src/merger/strategies/base-merger.js +61 -0
  1129. package/packages/installer/src/merger/strategies/env-merger.js +138 -0
  1130. package/packages/installer/src/merger/strategies/index.js +105 -0
  1131. package/packages/installer/src/merger/strategies/markdown-merger.js +208 -0
  1132. package/packages/installer/src/merger/strategies/replace-merger.js +68 -0
  1133. package/packages/installer/src/merger/types.js +72 -0
  1134. package/packages/installer/src/pro/pro-scaffolder.js +387 -0
  1135. package/packages/installer/src/updater/index.js +814 -0
  1136. package/packages/installer/src/utils/grimoire-colors.js +235 -0
  1137. package/packages/installer/src/wizard/feedback.js +232 -0
  1138. package/packages/installer/src/wizard/i18n.js +230 -0
  1139. package/packages/installer/src/wizard/ide-config-generator.js +993 -0
  1140. package/packages/installer/src/wizard/ide-selector.js +86 -0
  1141. package/packages/installer/src/wizard/index.js +831 -0
  1142. package/packages/installer/src/wizard/pro-setup.js +1223 -0
  1143. package/packages/installer/src/wizard/questions.js +336 -0
  1144. package/packages/installer/src/wizard/validation/index.js +121 -0
  1145. package/packages/installer/src/wizard/validation/report-generator.js +254 -0
  1146. package/packages/installer/src/wizard/validation/troubleshooting-system.js +348 -0
  1147. package/packages/installer/src/wizard/validation/validators/config-validator.js +364 -0
  1148. package/packages/installer/src/wizard/validation/validators/dependency-validator.js +333 -0
  1149. package/packages/installer/src/wizard/validation/validators/file-structure-validator.js +175 -0
  1150. package/packages/installer/src/wizard/validation/validators/mcp-health-checker.js +310 -0
  1151. package/packages/installer/src/wizard/validators.js +274 -0
  1152. package/packages/installer/src/wizard/wizard.js +246 -0
  1153. package/packages/installer/tests/integration/environment-configuration.test.js +331 -0
  1154. package/packages/installer/tests/integration/wizard-detection.test.js +353 -0
  1155. package/packages/installer/tests/unit/config-validator.test.js +316 -0
  1156. package/packages/installer/tests/unit/detection/detect-project-type.test.js +403 -0
  1157. package/packages/installer/tests/unit/env-template.test.js +189 -0
  1158. package/packages/installer/tests/unit/merger/env-merger.test.js +192 -0
  1159. package/packages/installer/tests/unit/merger/markdown-merger.test.js +262 -0
  1160. package/packages/installer/tests/unit/merger/strategies.test.js +153 -0
  1161. package/scripts/check-markdown-links.py +353 -0
  1162. package/scripts/code-intel-health-check.js +344 -0
  1163. package/scripts/dashboard-parallel-dev.sh +184 -0
  1164. package/scripts/dashboard-parallel-phase3.sh +130 -0
  1165. package/scripts/dashboard-parallel-phase4.sh +131 -0
  1166. package/scripts/ensure-manifest.js +59 -0
  1167. package/scripts/generate-install-manifest.js +368 -0
  1168. package/scripts/install-monitor-hooks.sh +83 -0
  1169. package/scripts/package-synapse.js +325 -0
  1170. package/scripts/semantic-lint.js +191 -0
  1171. package/scripts/sign-manifest.ps1 +132 -0
  1172. package/scripts/sign-manifest.sh +122 -0
  1173. package/scripts/validate-manifest.js +267 -0
  1174. package/scripts/validate-package-completeness.js +319 -0
@@ -0,0 +1,1432 @@
1
+ /**
2
+ * grimoire Documentation Synchronizer
3
+ *
4
+ * Automatically synchronizes documentation with code changes,
5
+ * ensuring documentation stays up-to-date with implementation.
6
+ */
7
+
8
+ const fs = require('fs').promises;
9
+ const path = require('path');
10
+ const { EventEmitter } = require('events');
11
+ const parser = require('@babel/parser');
12
+ const traverse = require('@babel/traverse').default;
13
+ const generate = require('@babel/generator').default;
14
+ const t = require('@babel/types');
15
+ const yaml = require('js-yaml');
16
+ const marked = require('marked');
17
+
18
+ class DocumentationSynchronizer extends EventEmitter {
19
+ constructor(options = {}) {
20
+ super();
21
+ this.rootPath = options.rootPath || process.cwd();
22
+ this.syncedComponents = new Map();
23
+ this.documentationIndex = new Map();
24
+ this.syncHistory = [];
25
+ this.options = {
26
+ autoSync: options.autoSync !== false,
27
+ syncInterval: options.syncInterval || 60000, // 1 minute
28
+ docFormats: options.docFormats || ['.md', '.yaml', '.yml', '.json'],
29
+ codeFormats: options.codeFormats || ['.js', '.jsx', '.ts', '.tsx'],
30
+ syncStrategies: options.syncStrategies || ['jsdoc', 'markdown', 'schema', 'api', 'examples'],
31
+ ...options,
32
+ };
33
+
34
+ this.syncStrategies = new Map();
35
+ this.initializeSyncStrategies();
36
+
37
+ if (this.options.autoSync) {
38
+ this.startAutoSync();
39
+ }
40
+ }
41
+
42
+ initializeSyncStrategies() {
43
+ // JSDoc synchronization
44
+ this.syncStrategies.set('jsdoc', {
45
+ name: 'JSDoc Synchronization',
46
+ description: 'Sync JSDoc comments with markdown documentation',
47
+ detector: this.detectJSDocChanges.bind(this),
48
+ synchronizer: this.syncJSDoc.bind(this),
49
+ priority: 'high',
50
+ });
51
+
52
+ // Markdown documentation
53
+ this.syncStrategies.set('markdown', {
54
+ name: 'Markdown Documentation',
55
+ description: 'Update markdown files with code changes',
56
+ detector: this.detectMarkdownChanges.bind(this),
57
+ synchronizer: this.syncMarkdown.bind(this),
58
+ priority: 'medium',
59
+ });
60
+
61
+ // Schema synchronization
62
+ this.syncStrategies.set('schema', {
63
+ name: 'Schema Documentation',
64
+ description: 'Sync YAML/JSON schemas with code structures',
65
+ detector: this.detectSchemaChanges.bind(this),
66
+ synchronizer: this.syncSchema.bind(this),
67
+ priority: 'high',
68
+ });
69
+
70
+ // API documentation
71
+ this.syncStrategies.set('api', {
72
+ name: 'API Documentation',
73
+ description: 'Update API documentation with endpoint changes',
74
+ detector: this.detectAPIChanges.bind(this),
75
+ synchronizer: this.syncAPI.bind(this),
76
+ priority: 'high',
77
+ });
78
+
79
+ // Code examples
80
+ this.syncStrategies.set('examples', {
81
+ name: 'Code Examples',
82
+ description: 'Update code examples in documentation',
83
+ detector: this.detectExampleChanges.bind(this),
84
+ synchronizer: this.syncExamples.bind(this),
85
+ priority: 'medium',
86
+ });
87
+ }
88
+
89
+ async initialize() {
90
+ try {
91
+ // Build documentation index
92
+ await this.buildDocumentationIndex();
93
+
94
+ // Analyze code-documentation relationships
95
+ await this.analyzeRelationships();
96
+
97
+ this.emit('initialized', {
98
+ documentationFiles: this.documentationIndex.size,
99
+ syncedComponents: this.syncedComponents.size,
100
+ });
101
+
102
+ } catch (error) {
103
+ this.emit('error', { phase: 'initialization', error });
104
+ throw error;
105
+ }
106
+ }
107
+
108
+ async buildDocumentationIndex() {
109
+ const docFiles = await this.findDocumentationFiles();
110
+
111
+ for (const docFile of docFiles) {
112
+ try {
113
+ const content = await fs.readFile(docFile, 'utf-8');
114
+ const metadata = await this.extractDocumentationMetadata(docFile, content);
115
+
116
+ this.documentationIndex.set(docFile, {
117
+ path: docFile,
118
+ content,
119
+ metadata,
120
+ lastSync: null,
121
+ linkedComponents: [],
122
+ });
123
+ } catch (error) {
124
+ console.warn(`Failed to index documentation: ${docFile}`, error);
125
+ }
126
+ }
127
+ }
128
+
129
+ async findDocumentationFiles() {
130
+ const files = [];
131
+ const docsDir = path.join(this.rootPath, 'docs');
132
+ const readmeFiles = ['README.md', 'readme.md', 'README.MD'];
133
+
134
+ // Find documentation in docs directory
135
+ if (await this.exists(docsDir)) {
136
+ await this.scanDirectory(docsDir, files);
137
+ }
138
+
139
+ // Find README files throughout the project
140
+ await this.scanForReadme(this.rootPath, files, readmeFiles);
141
+
142
+ // Find inline documentation (markdown in code directories)
143
+ await this.scanForInlineDocs(this.rootPath, files);
144
+
145
+ return files;
146
+ }
147
+
148
+ async scanDirectory(dir, files) {
149
+ const entries = await fs.readdir(dir, { withFileTypes: true });
150
+
151
+ for (const entry of entries) {
152
+ const fullPath = path.join(dir, entry.name);
153
+
154
+ if (entry.isDirectory() && !entry.name.startsWith('.')) {
155
+ await this.scanDirectory(fullPath, files);
156
+ } else if (entry.isFile()) {
157
+ const ext = path.extname(entry.name);
158
+ if (this.options.docFormats.includes(ext)) {
159
+ files.push(fullPath);
160
+ }
161
+ }
162
+ }
163
+ }
164
+
165
+ async extractDocumentationMetadata(filePath, content) {
166
+ const metadata = {
167
+ title: null,
168
+ description: null,
169
+ linkedFiles: [],
170
+ codeBlocks: [],
171
+ schemas: [],
172
+ apis: [],
173
+ lastModified: null,
174
+ };
175
+
176
+ const ext = path.extname(filePath);
177
+
178
+ if (ext === '.md') {
179
+ // Extract markdown metadata
180
+ const lines = content.split('\n');
181
+
182
+ // Find title
183
+ const titleMatch = lines.find(line => line.startsWith('# '));
184
+ if (titleMatch) {
185
+ metadata.title = titleMatch.substring(2).trim();
186
+ }
187
+
188
+ // Find code blocks
189
+ const codeBlockRegex = /```(\w+)?\n([\s\S]*?)```/g;
190
+ let match;
191
+ while ((match = codeBlockRegex.exec(content)) !== null) {
192
+ metadata.codeBlocks.push({
193
+ language: match[1] || 'text',
194
+ code: match[2].trim(),
195
+ startIndex: match.index,
196
+ endIndex: match.index + match[0].length,
197
+ });
198
+ }
199
+
200
+ // Find file references
201
+ const fileRefRegex = /\[([^\]]+)\]\(([^)]+)\)/g;
202
+ while ((match = fileRefRegex.exec(content)) !== null) {
203
+ if (match[2].endsWith('.js') || match[2].endsWith('.ts')) {
204
+ metadata.linkedFiles.push({
205
+ text: match[1],
206
+ path: match[2],
207
+ });
208
+ }
209
+ }
210
+ } else if (ext === '.yaml' || ext === '.yml') {
211
+ // Extract YAML metadata
212
+ try {
213
+ const data = yaml.load(content);
214
+ metadata.title = data.name || data.title || path.basename(filePath, ext);
215
+ metadata.description = data.description;
216
+ metadata.schemas.push(data);
217
+ } catch (error) {
218
+ console.warn(`Failed to parse YAML: ${filePath}`, error);
219
+ }
220
+ }
221
+
222
+ // Get file stats
223
+ const stats = await fs.stat(filePath);
224
+ metadata.lastModified = stats.mtime;
225
+
226
+ return metadata;
227
+ }
228
+
229
+ async analyzeRelationships() {
230
+ // Find relationships between code and documentation
231
+ for (const [docPath, docInfo] of this.documentationIndex) {
232
+ const relationships = await this.findCodeRelationships(docPath, docInfo);
233
+
234
+ for (const relationship of relationships) {
235
+ this.syncedComponents.set(relationship.codePath, {
236
+ codePath: relationship.codePath,
237
+ docPath: docPath,
238
+ type: relationship.type,
239
+ lastSync: null,
240
+ syncStrategies: relationship.strategies,
241
+ });
242
+
243
+ docInfo.linkedComponents.push(relationship.codePath);
244
+ }
245
+ }
246
+ }
247
+
248
+ async findCodeRelationships(docPath, docInfo) {
249
+ const relationships = [];
250
+ const docDir = path.dirname(docPath);
251
+ const docName = path.basename(docPath, path.extname(docPath));
252
+
253
+ // Strategy 1: Same directory, same name
254
+ const codeExtensions = ['.js', '.jsx', '.ts', '.tsx'];
255
+ for (const ext of codeExtensions) {
256
+ const codePath = path.join(docDir, docName + ext);
257
+ if (await this.exists(codePath)) {
258
+ relationships.push({
259
+ codePath,
260
+ type: 'same-name',
261
+ strategies: ['jsdoc', 'examples'],
262
+ });
263
+ }
264
+ }
265
+
266
+ // Strategy 2: Referenced files in documentation
267
+ for (const linkedFile of docInfo.metadata.linkedFiles) {
268
+ const codePath = path.resolve(docDir, linkedFile.path);
269
+ if (await this.exists(codePath)) {
270
+ relationships.push({
271
+ codePath,
272
+ type: 'referenced',
273
+ strategies: ['jsdoc', 'api', 'examples'],
274
+ });
275
+ }
276
+ }
277
+
278
+ // Strategy 3: Agent/Task/Workflow documentation
279
+ if (docPath.includes('agents') || docPath.includes('tasks') || docPath.includes('workflows')) {
280
+ const componentType = docPath.includes('agents') ? 'agent' :
281
+ docPath.includes('tasks') ? 'task' : 'workflow';
282
+
283
+ // Find manifest file
284
+ const manifestPath = path.join(docDir, 'manifest.yaml');
285
+ if (await this.exists(manifestPath)) {
286
+ relationships.push({
287
+ codePath: manifestPath,
288
+ type: componentType,
289
+ strategies: ['schema', 'markdown'],
290
+ });
291
+ }
292
+ }
293
+
294
+ return relationships;
295
+ }
296
+
297
+ async synchronizeComponent(componentPath, options = {}) {
298
+ const component = this.syncedComponents.get(componentPath);
299
+ if (!component) {
300
+ throw new Error(`Component not found in sync registry: ${componentPath}`);
301
+ }
302
+
303
+ const doc = this.documentationIndex.get(component.docPath);
304
+ if (!doc) {
305
+ throw new Error(`Documentation not found: ${component.docPath}`);
306
+ }
307
+
308
+ const changes = [];
309
+ const strategies = options.strategies || component.syncStrategies;
310
+
311
+ for (const strategyName of strategies) {
312
+ const strategy = this.syncStrategies.get(strategyName);
313
+ if (!strategy) continue;
314
+
315
+ try {
316
+ // Detect changes
317
+ const detected = await strategy.detector(componentPath, component.docPath);
318
+
319
+ if (detected && detected.length > 0) {
320
+ // Apply synchronization
321
+ const result = await strategy.synchronizer(
322
+ componentPath,
323
+ component.docPath,
324
+ detected,
325
+ options,
326
+ );
327
+
328
+ changes.push({
329
+ strategy: strategyName,
330
+ changes: result.changes,
331
+ success: result.success,
332
+ });
333
+ }
334
+ } catch (error) {
335
+ changes.push({
336
+ strategy: strategyName,
337
+ error: error.message,
338
+ success: false,
339
+ });
340
+ }
341
+ }
342
+
343
+ // Update sync metadata
344
+ component.lastSync = new Date().toISOString();
345
+ doc.lastSync = new Date().toISOString();
346
+
347
+ // Record in history
348
+ this.syncHistory.push({
349
+ timestamp: new Date().toISOString(),
350
+ componentPath,
351
+ docPath: component.docPath,
352
+ changes,
353
+ success: changes.every(c => c.success),
354
+ });
355
+
356
+ this.emit('synchronized', {
357
+ componentPath,
358
+ docPath: component.docPath,
359
+ changes,
360
+ });
361
+
362
+ return changes;
363
+ }
364
+
365
+ async detectJSDocChanges(codePath, docPath) {
366
+ const changes = [];
367
+
368
+ try {
369
+ const codeContent = await fs.readFile(codePath, 'utf-8');
370
+ const docContent = await fs.readFile(docPath, 'utf-8');
371
+
372
+ // Parse code for JSDoc comments
373
+ const jsdocComments = await this.extractJSDocComments(codeContent);
374
+
375
+ // Find corresponding sections in documentation
376
+ for (const jsdoc of jsdocComments) {
377
+ const docSection = this.findDocumentationSection(
378
+ docContent,
379
+ jsdoc.name,
380
+ jsdoc.type,
381
+ );
382
+
383
+ if (docSection) {
384
+ // Compare and detect changes
385
+ const diff = this.compareJSDocWithDoc(jsdoc, docSection);
386
+ if (diff) {
387
+ changes.push({
388
+ type: 'jsdoc-update',
389
+ name: jsdoc.name,
390
+ jsdoc,
391
+ docSection,
392
+ diff,
393
+ });
394
+ }
395
+ } else {
396
+ // New function/class not in documentation
397
+ changes.push({
398
+ type: 'jsdoc-new',
399
+ name: jsdoc.name,
400
+ jsdoc,
401
+ });
402
+ }
403
+ }
404
+ } catch (error) {
405
+ console.error(`Error detecting JSDoc changes: ${error.message}`);
406
+ }
407
+
408
+ return changes;
409
+ }
410
+
411
+ async extractJSDocComments(codeContent) {
412
+ const comments = [];
413
+
414
+ try {
415
+ const ast = parser.parse(codeContent, {
416
+ sourceType: 'module',
417
+ plugins: ['jsx', 'typescript'],
418
+ attachComment: true,
419
+ });
420
+
421
+ traverse(ast, {
422
+ enter(path) {
423
+ if (path.node.leadingComments) {
424
+ for (const comment of path.node.leadingComments) {
425
+ if (comment.type === 'CommentBlock' && comment.value.startsWith('*')) {
426
+ const jsdoc = this.parseJSDoc(comment.value);
427
+ if (jsdoc) {
428
+ // Attach the associated node info
429
+ if (t.isFunctionDeclaration(path.node) || t.isClassDeclaration(path.node)) {
430
+ jsdoc.name = path.node.id?.name;
431
+ jsdoc.type = path.node.type;
432
+ } else if (t.isVariableDeclarator(path.node)) {
433
+ jsdoc.name = path.node.id?.name;
434
+ jsdoc.type = 'VariableDeclarator';
435
+ }
436
+
437
+ if (jsdoc.name) {
438
+ comments.push(jsdoc);
439
+ }
440
+ }
441
+ }
442
+ }
443
+ }
444
+ },
445
+ });
446
+ } catch (error) {
447
+ console.error(`Error parsing code: ${error.message}`);
448
+ }
449
+
450
+ return comments;
451
+ }
452
+
453
+ parseJSDoc(commentText) {
454
+ const jsdoc = {
455
+ description: '',
456
+ params: [],
457
+ returns: null,
458
+ examples: [],
459
+ tags: {},
460
+ };
461
+
462
+ const lines = commentText.split('\n').map(line =>
463
+ line.trim().replace(/^\* ?/, ''),
464
+ );
465
+
466
+ let currentSection = 'description';
467
+ let currentParam = null;
468
+
469
+ for (const line of lines) {
470
+ if (line.startsWith('@param')) {
471
+ const paramMatch = line.match(/@param\s+(?:\{([^}]+)\}\s+)?(\w+)(?:\s+-\s+(.*))?/);
472
+ if (paramMatch) {
473
+ currentParam = {
474
+ type: paramMatch[1],
475
+ name: paramMatch[2],
476
+ description: paramMatch[3] || '',
477
+ };
478
+ jsdoc.params.push(currentParam);
479
+ currentSection = 'param';
480
+ }
481
+ } else if (line.startsWith('@returns') || line.startsWith('@return')) {
482
+ const returnMatch = line.match(/@returns?\s+(?:\{([^}]+)\}\s+)?(.*)$/);
483
+ if (returnMatch) {
484
+ jsdoc.returns = {
485
+ type: returnMatch[1],
486
+ description: returnMatch[2] || '',
487
+ };
488
+ currentSection = 'returns';
489
+ }
490
+ } else if (line.startsWith('@example')) {
491
+ currentSection = 'example';
492
+ jsdoc.examples.push('');
493
+ } else if (line.startsWith('@')) {
494
+ const tagMatch = line.match(/@(\w+)(?:\s+(.*))?/);
495
+ if (tagMatch) {
496
+ jsdoc.tags[tagMatch[1]] = tagMatch[2] || true;
497
+ currentSection = tagMatch[1];
498
+ }
499
+ } else if (line) {
500
+ // Continue current section
501
+ if (currentSection === 'description') {
502
+ jsdoc.description += (jsdoc.description ? '\n' : '') + line;
503
+ } else if (currentSection === 'param' && currentParam) {
504
+ currentParam.description += (currentParam.description ? '\n' : '') + line;
505
+ } else if (currentSection === 'returns' && jsdoc.returns) {
506
+ jsdoc.returns.description += (jsdoc.returns.description ? '\n' : '') + line;
507
+ } else if (currentSection === 'example' && jsdoc.examples.length > 0) {
508
+ const lastExample = jsdoc.examples.length - 1;
509
+ jsdoc.examples[lastExample] += (jsdoc.examples[lastExample] ? '\n' : '') + line;
510
+ }
511
+ }
512
+ }
513
+
514
+ return jsdoc;
515
+ }
516
+
517
+ async syncJSDoc(codePath, docPath, changes, options = {}) {
518
+ const result = {
519
+ changes: [],
520
+ success: true,
521
+ };
522
+
523
+ try {
524
+ let docContent = await fs.readFile(docPath, 'utf-8');
525
+ const backup = docContent; // Keep backup for rollback
526
+
527
+ for (const change of changes) {
528
+ if (change.type === 'jsdoc-update') {
529
+ // Update existing documentation section
530
+ docContent = this.updateDocumentationSection(
531
+ docContent,
532
+ change.name,
533
+ change.jsdoc,
534
+ change.docSection,
535
+ );
536
+
537
+ result.changes.push({
538
+ type: 'updated',
539
+ name: change.name,
540
+ description: `Updated documentation for ${change.name}`,
541
+ });
542
+ } else if (change.type === 'jsdoc-new') {
543
+ // Add new documentation section
544
+ docContent = this.addDocumentationSection(
545
+ docContent,
546
+ change.jsdoc,
547
+ );
548
+
549
+ result.changes.push({
550
+ type: 'added',
551
+ name: change.name,
552
+ description: `Added documentation for ${change.name}`,
553
+ });
554
+ }
555
+ }
556
+
557
+ // Write updated documentation
558
+ if (docContent !== backup) {
559
+ await fs.writeFile(docPath, docContent);
560
+ }
561
+
562
+ } catch (error) {
563
+ result.success = false;
564
+ result.error = error.message;
565
+ }
566
+
567
+ return result;
568
+ }
569
+
570
+ findDocumentationSection(docContent, name, type) {
571
+ // Look for section headers that match the function/class name
572
+ const patterns = [
573
+ new RegExp(`^#+\\s*${name}\\s*$`, 'gm'),
574
+ new RegExp(`^#+\\s*\\W?${name}\\(`, 'gm'),
575
+ new RegExp(`^#+\\s*class\\s+${name}`, 'gm'),
576
+ new RegExp(`^#+\\s*function\\s+${name}`, 'gm'),
577
+ ];
578
+
579
+ for (const pattern of patterns) {
580
+ const match = pattern.exec(docContent);
581
+ if (match) {
582
+ // Extract section content
583
+ const startIndex = match.index;
584
+ const headerLevel = match[0].match(/^#+/)[0].length;
585
+
586
+ // Find end of section (next header of same or higher level)
587
+ const endPattern = new RegExp(`^#{1,${headerLevel}}\\s`, 'gm');
588
+ endPattern.lastIndex = startIndex + match[0].length;
589
+
590
+ const endMatch = endPattern.exec(docContent);
591
+ const endIndex = endMatch ? endMatch.index : docContent.length;
592
+
593
+ return {
594
+ startIndex,
595
+ endIndex,
596
+ content: docContent.substring(startIndex, endIndex),
597
+ headerLevel,
598
+ };
599
+ }
600
+ }
601
+
602
+ return null;
603
+ }
604
+
605
+ updateDocumentationSection(docContent, name, jsdoc, docSection) {
606
+ // Generate updated documentation
607
+ const updatedSection = this.generateDocumentationSection(jsdoc, docSection.headerLevel);
608
+
609
+ // Replace the section
610
+ return docContent.substring(0, docSection.startIndex) +
611
+ updatedSection +
612
+ docContent.substring(docSection.endIndex);
613
+ }
614
+
615
+ addDocumentationSection(docContent, jsdoc) {
616
+ // Find appropriate place to add the new section
617
+ const sectionHeader = this.generateDocumentationSection(jsdoc, 3);
618
+
619
+ // Try to find a suitable location (e.g., after "## API" or "## Functions")
620
+ const apiMatch = /^##\s*(API|Functions|Methods)/gm.exec(docContent);
621
+
622
+ if (apiMatch) {
623
+ // Find the end of the API section
624
+ const nextSectionMatch = /^#{1,2}\s/gm.exec(
625
+ docContent.substring(apiMatch.index + apiMatch[0].length),
626
+ );
627
+
628
+ const insertIndex = nextSectionMatch ?
629
+ apiMatch.index + apiMatch[0].length + nextSectionMatch.index :
630
+ docContent.length;
631
+
632
+ return docContent.substring(0, insertIndex) +
633
+ '\n\n' + sectionHeader +
634
+ docContent.substring(insertIndex);
635
+ } else {
636
+ // Append to end
637
+ return docContent + '\n\n## API\n\n' + sectionHeader;
638
+ }
639
+ }
640
+
641
+ generateDocumentationSection(jsdoc, headerLevel = 3) {
642
+ const header = '#'.repeat(headerLevel);
643
+ let section = `${header} ${jsdoc.name}\n\n`;
644
+
645
+ if (jsdoc.description) {
646
+ section += `${jsdoc.description}\n\n`;
647
+ }
648
+
649
+ if (jsdoc.params.length > 0) {
650
+ section += '**Parameters:**\n';
651
+ for (const param of jsdoc.params) {
652
+ section += `- \`${param.name}\``;
653
+ if (param.type) section += ` _{${param.type}}_`;
654
+ if (param.description) section += ` - ${param.description}`;
655
+ section += '\n';
656
+ }
657
+ section += '\n';
658
+ }
659
+
660
+ if (jsdoc.returns) {
661
+ section += '**Returns:**\n';
662
+ if (jsdoc.returns.type) section += `_{${jsdoc.returns.type}}_ `;
663
+ section += jsdoc.returns.description + '\n\n';
664
+ }
665
+
666
+ if (jsdoc.examples.length > 0) {
667
+ section += '**Examples:**\n';
668
+ for (const example of jsdoc.examples) {
669
+ section += '```javascript\n';
670
+ section += example + '\n';
671
+ section += '```\n\n';
672
+ }
673
+ }
674
+
675
+ return section;
676
+ }
677
+
678
+ async detectMarkdownChanges(codePath, docPath) {
679
+ // Detect changes that affect markdown documentation
680
+ const changes = [];
681
+
682
+ try {
683
+ const codeContent = await fs.readFile(codePath, 'utf-8');
684
+ const docContent = await fs.readFile(docPath, 'utf-8');
685
+
686
+ // Check for command pattern changes in tasks
687
+ if (codePath.endsWith('.md') && codePath.includes('tasks')) {
688
+ const commandPattern = this.extractCommandPattern(codeContent);
689
+ const docCommandPattern = this.extractCommandPattern(docContent);
690
+
691
+ if (commandPattern && docCommandPattern && commandPattern !== docCommandPattern) {
692
+ changes.push({
693
+ type: 'command-pattern',
694
+ oldPattern: docCommandPattern,
695
+ newPattern: commandPattern,
696
+ });
697
+ }
698
+ }
699
+
700
+ // Check for implementation changes
701
+ const codeBlocks = this.extractCodeBlocks(docContent);
702
+ for (const block of codeBlocks) {
703
+ if (block.language === 'javascript' || block.language === 'typescript') {
704
+ // Check if code block references actual implementation
705
+ const referenced = this.findReferencedCode(block.code, codeContent);
706
+ if (referenced && referenced.changed) {
707
+ changes.push({
708
+ type: 'code-block',
709
+ block,
710
+ referenced,
711
+ });
712
+ }
713
+ }
714
+ }
715
+ } catch (error) {
716
+ console.error(`Error detecting markdown changes: ${error.message}`);
717
+ }
718
+
719
+ return changes;
720
+ }
721
+
722
+ async syncMarkdown(codePath, docPath, changes, options = {}) {
723
+ const result = {
724
+ changes: [],
725
+ success: true,
726
+ };
727
+
728
+ try {
729
+ let docContent = await fs.readFile(docPath, 'utf-8');
730
+ const backup = docContent;
731
+
732
+ for (const change of changes) {
733
+ if (change.type === 'command-pattern') {
734
+ // Update command pattern
735
+ docContent = docContent.replace(
736
+ change.oldPattern,
737
+ change.newPattern,
738
+ );
739
+
740
+ result.changes.push({
741
+ type: 'command-pattern',
742
+ description: 'Updated command pattern',
743
+ });
744
+ } else if (change.type === 'code-block') {
745
+ // Update code block
746
+ docContent = this.updateCodeBlock(
747
+ docContent,
748
+ change.block,
749
+ change.referenced.newCode,
750
+ );
751
+
752
+ result.changes.push({
753
+ type: 'code-block',
754
+ description: 'Updated code example',
755
+ });
756
+ }
757
+ }
758
+
759
+ if (docContent !== backup) {
760
+ await fs.writeFile(docPath, docContent);
761
+ }
762
+
763
+ } catch (error) {
764
+ result.success = false;
765
+ result.error = error.message;
766
+ }
767
+
768
+ return result;
769
+ }
770
+
771
+ extractCommandPattern(content) {
772
+ const match = content.match(/^\*[\w-]+(?:\s+<[^>]+>)*(?:\s+\[[^\]]+\])*/m);
773
+ return match ? match[0] : null;
774
+ }
775
+
776
+ extractCodeBlocks(content) {
777
+ const blocks = [];
778
+ const regex = /```(\w+)?\n([\s\S]*?)```/g;
779
+ let match;
780
+
781
+ while ((match = regex.exec(content)) !== null) {
782
+ blocks.push({
783
+ language: match[1] || 'text',
784
+ code: match[2].trim(),
785
+ startIndex: match.index,
786
+ endIndex: match.index + match[0].length,
787
+ fullMatch: match[0],
788
+ });
789
+ }
790
+
791
+ return blocks;
792
+ }
793
+
794
+ updateCodeBlock(docContent, block, newCode) {
795
+ const newBlock = '```' + block.language + '\n' + newCode + '\n```';
796
+
797
+ return docContent.substring(0, block.startIndex) +
798
+ newBlock +
799
+ docContent.substring(block.endIndex);
800
+ }
801
+
802
+ async detectSchemaChanges(codePath, docPath) {
803
+ // Detect changes in YAML/JSON schemas
804
+ const changes = [];
805
+
806
+ if (!codePath.endsWith('.yaml') && !codePath.endsWith('.yml') && !codePath.endsWith('.json')) {
807
+ return changes;
808
+ }
809
+
810
+ try {
811
+ const schemaContent = await fs.readFile(codePath, 'utf-8');
812
+ const docContent = await fs.readFile(docPath, 'utf-8');
813
+
814
+ // Parse schema
815
+ const schema = codePath.endsWith('.json') ?
816
+ JSON.parse(schemaContent) :
817
+ yaml.load(schemaContent);
818
+
819
+ // Find schema documentation
820
+ if (docPath.endsWith('.md')) {
821
+ // Look for schema tables or descriptions in markdown
822
+ const schemaTables = this.extractSchemaTables(docContent);
823
+ const schemaFields = this.extractSchemaFields(schema);
824
+
825
+ // Compare fields
826
+ for (const field of schemaFields) {
827
+ const documented = schemaTables.find(t => t.fields.includes(field.name));
828
+ if (!documented) {
829
+ changes.push({
830
+ type: 'schema-field-new',
831
+ field,
832
+ });
833
+ }
834
+ }
835
+ }
836
+ } catch (error) {
837
+ console.error(`Error detecting schema changes: ${error.message}`);
838
+ }
839
+
840
+ return changes;
841
+ }
842
+
843
+ async syncSchema(codePath, docPath, changes, options = {}) {
844
+ const result = {
845
+ changes: [],
846
+ success: true,
847
+ };
848
+
849
+ try {
850
+ let docContent = await fs.readFile(docPath, 'utf-8');
851
+ const backup = docContent;
852
+
853
+ for (const change of changes) {
854
+ if (change.type === 'schema-field-new') {
855
+ // Add new field to documentation
856
+ docContent = this.addSchemaFieldDoc(docContent, change.field);
857
+
858
+ result.changes.push({
859
+ type: 'schema-field',
860
+ description: `Added documentation for field: ${change.field.name}`,
861
+ });
862
+ }
863
+ }
864
+
865
+ if (docContent !== backup) {
866
+ await fs.writeFile(docPath, docContent);
867
+ }
868
+
869
+ } catch (error) {
870
+ result.success = false;
871
+ result.error = error.message;
872
+ }
873
+
874
+ return result;
875
+ }
876
+
877
+ extractSchemaFields(schema, prefix = '') {
878
+ const fields = [];
879
+
880
+ function traverse(obj, path) {
881
+ for (const [key, value] of Object.entries(obj)) {
882
+ const fieldPath = path ? `${path}.${key}` : key;
883
+
884
+ fields.push({
885
+ name: key,
886
+ path: fieldPath,
887
+ type: typeof value,
888
+ required: obj.required?.includes(key),
889
+ description: value.description || '',
890
+ });
891
+
892
+ if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
893
+ if (!value.type || value.properties) {
894
+ traverse(value.properties || value, fieldPath);
895
+ }
896
+ }
897
+ }
898
+ }
899
+
900
+ traverse(schema.properties || schema, prefix);
901
+ return fields;
902
+ }
903
+
904
+ async detectAPIChanges(codePath, docPath) {
905
+ // Detect API endpoint changes
906
+ const changes = [];
907
+
908
+ try {
909
+ const codeContent = await fs.readFile(codePath, 'utf-8');
910
+
911
+ // Look for Express/Koa route definitions
912
+ const routes = this.extractAPIRoutes(codeContent);
913
+
914
+ if (routes.length > 0) {
915
+ const docContent = await fs.readFile(docPath, 'utf-8');
916
+ const documentedRoutes = this.extractDocumentedRoutes(docContent);
917
+
918
+ // Compare routes
919
+ for (const route of routes) {
920
+ const documented = documentedRoutes.find(
921
+ r => r.method === route.method && r.path === route.path,
922
+ );
923
+
924
+ if (!documented) {
925
+ changes.push({
926
+ type: 'api-route-new',
927
+ route,
928
+ });
929
+ } else if (this.routeChanged(route, documented)) {
930
+ changes.push({
931
+ type: 'api-route-update',
932
+ route,
933
+ documented,
934
+ });
935
+ }
936
+ }
937
+ }
938
+ } catch (error) {
939
+ console.error(`Error detecting API changes: ${error.message}`);
940
+ }
941
+
942
+ return changes;
943
+ }
944
+
945
+ extractAPIRoutes(codeContent) {
946
+ const routes = [];
947
+
948
+ // Express pattern: app.get('/path', ...)
949
+ const expressPattern = /app\.(get|post|put|delete|patch)\s*\(\s*['"`]([^'"`]+)['"`]/g;
950
+ let match;
951
+
952
+ while ((match = expressPattern.exec(codeContent)) !== null) {
953
+ routes.push({
954
+ method: match[1].toUpperCase(),
955
+ path: match[2],
956
+ lineNumber: codeContent.substring(0, match.index).split('\n').length,
957
+ });
958
+ }
959
+
960
+ // Router pattern: router.get('/path', ...)
961
+ const routerPattern = /router\.(get|post|put|delete|patch)\s*\(\s*['"`]([^'"`]+)['"`]/g;
962
+
963
+ while ((match = routerPattern.exec(codeContent)) !== null) {
964
+ routes.push({
965
+ method: match[1].toUpperCase(),
966
+ path: match[2],
967
+ lineNumber: codeContent.substring(0, match.index).split('\n').length,
968
+ });
969
+ }
970
+
971
+ return routes;
972
+ }
973
+
974
+ async syncAPI(codePath, docPath, changes, options = {}) {
975
+ const result = {
976
+ changes: [],
977
+ success: true,
978
+ };
979
+
980
+ try {
981
+ let docContent = await fs.readFile(docPath, 'utf-8');
982
+ const backup = docContent;
983
+
984
+ for (const change of changes) {
985
+ if (change.type === 'api-route-new') {
986
+ // Add new route documentation
987
+ docContent = this.addAPIRouteDoc(docContent, change.route);
988
+
989
+ result.changes.push({
990
+ type: 'api-route',
991
+ description: `Added documentation for ${change.route.method} ${change.route.path}`,
992
+ });
993
+ } else if (change.type === 'api-route-update') {
994
+ // Update existing route documentation
995
+ docContent = this.updateAPIRouteDoc(
996
+ docContent,
997
+ change.route,
998
+ change.documented,
999
+ );
1000
+
1001
+ result.changes.push({
1002
+ type: 'api-route',
1003
+ description: `Updated documentation for ${change.route.method} ${change.route.path}`,
1004
+ });
1005
+ }
1006
+ }
1007
+
1008
+ if (docContent !== backup) {
1009
+ await fs.writeFile(docPath, docContent);
1010
+ }
1011
+
1012
+ } catch (error) {
1013
+ result.success = false;
1014
+ result.error = error.message;
1015
+ }
1016
+
1017
+ return result;
1018
+ }
1019
+
1020
+ async detectExampleChanges(codePath, docPath) {
1021
+ // Detect changes in code examples
1022
+ const changes = [];
1023
+
1024
+ try {
1025
+ const docContent = await fs.readFile(docPath, 'utf-8');
1026
+ const codeBlocks = this.extractCodeBlocks(docContent);
1027
+
1028
+ for (const block of codeBlocks) {
1029
+ if (block.code.includes('// Example') || block.code.includes('// Usage')) {
1030
+ // Check if example is still valid
1031
+ const validation = await this.validateExample(block.code, codePath);
1032
+
1033
+ if (!validation.valid) {
1034
+ changes.push({
1035
+ type: 'example-invalid',
1036
+ block,
1037
+ validation,
1038
+ });
1039
+ }
1040
+ }
1041
+ }
1042
+ } catch (error) {
1043
+ console.error(`Error detecting example changes: ${error.message}`);
1044
+ }
1045
+
1046
+ return changes;
1047
+ }
1048
+
1049
+ async syncExamples(codePath, docPath, changes, options = {}) {
1050
+ const result = {
1051
+ changes: [],
1052
+ success: true,
1053
+ };
1054
+
1055
+ try {
1056
+ let docContent = await fs.readFile(docPath, 'utf-8');
1057
+ const backup = docContent;
1058
+
1059
+ for (const change of changes) {
1060
+ if (change.type === 'example-invalid') {
1061
+ // Update invalid example
1062
+ const updatedExample = await this.updateExample(
1063
+ change.block.code,
1064
+ change.validation,
1065
+ );
1066
+
1067
+ if (updatedExample) {
1068
+ docContent = this.updateCodeBlock(
1069
+ docContent,
1070
+ change.block,
1071
+ updatedExample,
1072
+ );
1073
+
1074
+ result.changes.push({
1075
+ type: 'example',
1076
+ description: 'Updated code example',
1077
+ });
1078
+ }
1079
+ }
1080
+ }
1081
+
1082
+ if (docContent !== backup) {
1083
+ await fs.writeFile(docPath, docContent);
1084
+ }
1085
+
1086
+ } catch (error) {
1087
+ result.success = false;
1088
+ result.error = error.message;
1089
+ }
1090
+
1091
+ return result;
1092
+ }
1093
+
1094
+ async validateExample(exampleCode, referencedFile) {
1095
+ const validation = {
1096
+ valid: true,
1097
+ errors: [],
1098
+ warnings: [],
1099
+ };
1100
+
1101
+ try {
1102
+ // Parse the example
1103
+ const ast = parser.parse(exampleCode, {
1104
+ sourceType: 'module',
1105
+ plugins: ['jsx', 'typescript'],
1106
+ errorRecovery: true,
1107
+ });
1108
+
1109
+ // Check for undefined references
1110
+ const referencedCode = await fs.readFile(referencedFile, 'utf-8');
1111
+
1112
+ traverse(ast, {
1113
+ Identifier(path) {
1114
+ const name = path.node.name;
1115
+
1116
+ // Check if identifier exists in referenced file
1117
+ if (!referencedCode.includes(name)) {
1118
+ validation.warnings.push({
1119
+ type: 'undefined-reference',
1120
+ name,
1121
+ line: path.node.loc?.start.line,
1122
+ });
1123
+ }
1124
+ },
1125
+ });
1126
+
1127
+ if (validation.errors.length > 0) {
1128
+ validation.valid = false;
1129
+ }
1130
+
1131
+ } catch (error) {
1132
+ validation.valid = false;
1133
+ validation.errors.push({
1134
+ type: 'parse-error',
1135
+ message: error.message,
1136
+ });
1137
+ }
1138
+
1139
+ return validation;
1140
+ }
1141
+
1142
+ async startAutoSync() {
1143
+ this.syncInterval = setInterval(async () => {
1144
+ try {
1145
+ await this.checkForChanges();
1146
+ } catch (error) {
1147
+ this.emit('error', { phase: 'auto-sync', error });
1148
+ }
1149
+ }, this.options.syncInterval);
1150
+ }
1151
+
1152
+ async checkForChanges() {
1153
+ const changes = [];
1154
+
1155
+ for (const [componentPath, component] of this.syncedComponents) {
1156
+ try {
1157
+ const stats = await fs.stat(componentPath);
1158
+ const lastModified = stats.mtime.toISOString();
1159
+
1160
+ if (!component.lastSync || lastModified > component.lastSync) {
1161
+ // Component changed since last sync
1162
+ const syncResult = await this.synchronizeComponent(componentPath);
1163
+
1164
+ if (syncResult.length > 0) {
1165
+ changes.push({
1166
+ componentPath,
1167
+ syncResult,
1168
+ });
1169
+ }
1170
+ }
1171
+ } catch (error) {
1172
+ console.warn(`Failed to check component: ${componentPath}`, error);
1173
+ }
1174
+ }
1175
+
1176
+ if (changes.length > 0) {
1177
+ this.emit('auto-sync', { changes });
1178
+ }
1179
+ }
1180
+
1181
+ async generateSyncReport() {
1182
+ const report = {
1183
+ timestamp: new Date().toISOString(),
1184
+ summary: {
1185
+ totalComponents: this.syncedComponents.size,
1186
+ totalDocumentation: this.documentationIndex.size,
1187
+ syncHistory: this.syncHistory.length,
1188
+ lastSync: this.syncHistory[this.syncHistory.length - 1]?.timestamp,
1189
+ },
1190
+ components: [],
1191
+ documentation: [],
1192
+ recentSync: this.syncHistory.slice(-10),
1193
+ };
1194
+
1195
+ // Component details
1196
+ for (const [path, component] of this.syncedComponents) {
1197
+ report.components.push({
1198
+ path: path.replace(this.rootPath, '.'),
1199
+ docPath: component.docPath.replace(this.rootPath, '.'),
1200
+ type: component.type,
1201
+ lastSync: component.lastSync,
1202
+ strategies: component.syncStrategies,
1203
+ });
1204
+ }
1205
+
1206
+ // Documentation details
1207
+ for (const [path, doc] of this.documentationIndex) {
1208
+ report.documentation.push({
1209
+ path: path.replace(this.rootPath, '.'),
1210
+ title: doc.metadata.title,
1211
+ linkedComponents: doc.linkedComponents.length,
1212
+ lastSync: doc.lastSync,
1213
+ });
1214
+ }
1215
+
1216
+ return report;
1217
+ }
1218
+
1219
+ async exists(filePath) {
1220
+ try {
1221
+ await fs.access(filePath);
1222
+ return true;
1223
+ } catch {
1224
+ return false;
1225
+ }
1226
+ }
1227
+
1228
+ compareJSDocWithDoc(jsdoc, docSection) {
1229
+ // Simple comparison - could be made more sophisticated
1230
+ const docText = docSection.content.toLowerCase();
1231
+ const jsdocText = JSON.stringify(jsdoc).toLowerCase();
1232
+
1233
+ // Check if key information is missing
1234
+ const differences = [];
1235
+
1236
+ if (jsdoc.params.length > 0) {
1237
+ for (const param of jsdoc.params) {
1238
+ if (!docText.includes(param.name.toLowerCase())) {
1239
+ differences.push({ type: 'missing-param', param: param.name });
1240
+ }
1241
+ }
1242
+ }
1243
+
1244
+ if (jsdoc.returns && !docText.includes('return')) {
1245
+ differences.push({ type: 'missing-returns' });
1246
+ }
1247
+
1248
+ return differences.length > 0 ? differences : null;
1249
+ }
1250
+
1251
+ findReferencedCode(codeBlock, actualCode) {
1252
+ // Try to find the code block in the actual implementation
1253
+ const normalizedBlock = codeBlock.replace(/\s+/g, ' ').trim();
1254
+ const normalizedActual = actualCode.replace(/\s+/g, ' ');
1255
+
1256
+ if (normalizedActual.includes(normalizedBlock)) {
1257
+ return { changed: false };
1258
+ }
1259
+
1260
+ // Try to find similar code (this is simplified)
1261
+ const blockLines = codeBlock.split('\n').filter(l => l.trim());
1262
+ let matchCount = 0;
1263
+
1264
+ for (const line of blockLines) {
1265
+ if (actualCode.includes(line.trim())) {
1266
+ matchCount++;
1267
+ }
1268
+ }
1269
+
1270
+ const matchRatio = matchCount / blockLines.length;
1271
+
1272
+ if (matchRatio < 0.8) {
1273
+ return {
1274
+ changed: true,
1275
+ matchRatio,
1276
+ newCode: this.findSimilarCode(codeBlock, actualCode),
1277
+ };
1278
+ }
1279
+
1280
+ return { changed: false };
1281
+ }
1282
+
1283
+ findSimilarCode(codeBlock, actualCode) {
1284
+ // This is a placeholder - real implementation would use more sophisticated matching
1285
+ return codeBlock;
1286
+ }
1287
+
1288
+ extractSchemaTables(markdown) {
1289
+ const tables = [];
1290
+ const tableRegex = /\|(.+)\|[\s\S]+?\|(.+)\|/g;
1291
+
1292
+ let match;
1293
+ while ((match = tableRegex.exec(markdown)) !== null) {
1294
+ // Simple table extraction - could be improved
1295
+ tables.push({
1296
+ content: match[0],
1297
+ fields: [], // Would need to parse table properly
1298
+ });
1299
+ }
1300
+
1301
+ return tables;
1302
+ }
1303
+
1304
+ addSchemaFieldDoc(docContent, field) {
1305
+ // Find schema documentation section
1306
+ const schemaSection = /^##\s*Schema/m.exec(docContent);
1307
+
1308
+ if (schemaSection) {
1309
+ // Add to existing schema section
1310
+ const insertion = `\n- \`${field.name}\` _(${field.type})_ - ${field.description || 'No description'}${field.required ? ' **Required**' : ''}`;
1311
+
1312
+ return docContent.substring(0, schemaSection.index + schemaSection[0].length) +
1313
+ insertion +
1314
+ docContent.substring(schemaSection.index + schemaSection[0].length);
1315
+ } else {
1316
+ // Add new schema section
1317
+ return docContent + '\n\n## Schema\n\n' +
1318
+ `- \`${field.name}\` _(${field.type})_ - ${field.description || 'No description'}${field.required ? ' **Required**' : ''}`;
1319
+ }
1320
+ }
1321
+
1322
+ extractDocumentedRoutes(docContent) {
1323
+ const routes = [];
1324
+
1325
+ // Look for API documentation patterns
1326
+ // Example: ### GET /api/users
1327
+ const routePattern = /^###\s*(GET|POST|PUT|DELETE|PATCH)\s+([^\s]+)/gm;
1328
+ let match;
1329
+
1330
+ while ((match = routePattern.exec(docContent)) !== null) {
1331
+ routes.push({
1332
+ method: match[1],
1333
+ path: match[2],
1334
+ startIndex: match.index,
1335
+ });
1336
+ }
1337
+
1338
+ return routes;
1339
+ }
1340
+
1341
+ routeChanged(route, documented) {
1342
+ // Simple comparison - could check parameters, responses, etc.
1343
+ return false;
1344
+ }
1345
+
1346
+ addAPIRouteDoc(docContent, route) {
1347
+ // Find API section
1348
+ const apiSection = /^##\s*API/m.exec(docContent);
1349
+
1350
+ const routeDoc = `\n\n### ${route.method} ${route.path}\n\n` +
1351
+ 'Description of the endpoint.\n\n' +
1352
+ '**Parameters:**\n' +
1353
+ '- None\n\n' +
1354
+ '**Response:**\n' +
1355
+ '```json\n{\n // Response structure\n}\n```\n';
1356
+
1357
+ if (apiSection) {
1358
+ // Find insertion point
1359
+ const nextSection = /^##\s/m.exec(
1360
+ docContent.substring(apiSection.index + apiSection[0].length),
1361
+ );
1362
+
1363
+ const insertIndex = nextSection ?
1364
+ apiSection.index + apiSection[0].length + nextSection.index :
1365
+ docContent.length;
1366
+
1367
+ return docContent.substring(0, insertIndex) +
1368
+ routeDoc +
1369
+ docContent.substring(insertIndex);
1370
+ } else {
1371
+ // Add API section
1372
+ return docContent + '\n\n## API\n' + routeDoc;
1373
+ }
1374
+ }
1375
+
1376
+ updateAPIRouteDoc(docContent, route, documented) {
1377
+ // This would update existing route documentation
1378
+ // For now, just return unchanged
1379
+ return docContent;
1380
+ }
1381
+
1382
+ updateExample(exampleCode, validation) {
1383
+ // This would fix the example based on validation errors
1384
+ // For now, just return the original
1385
+ return exampleCode;
1386
+ }
1387
+
1388
+ async scanForReadme(dir, files, readmeNames) {
1389
+ try {
1390
+ const entries = await fs.readdir(dir, { withFileTypes: true });
1391
+
1392
+ for (const entry of entries) {
1393
+ const fullPath = path.join(dir, entry.name);
1394
+
1395
+ if (entry.isFile() && readmeNames.includes(entry.name)) {
1396
+ files.push(fullPath);
1397
+ } else if (entry.isDirectory() && !entry.name.startsWith('.') && entry.name !== 'node_modules') {
1398
+ await this.scanForReadme(fullPath, files, readmeNames);
1399
+ }
1400
+ }
1401
+ } catch (error) {
1402
+ // Ignore permission errors
1403
+ }
1404
+ }
1405
+
1406
+ async scanForInlineDocs(dir, files) {
1407
+ try {
1408
+ const entries = await fs.readdir(dir, { withFileTypes: true });
1409
+
1410
+ for (const entry of entries) {
1411
+ const fullPath = path.join(dir, entry.name);
1412
+
1413
+ if (entry.isDirectory() && !entry.name.startsWith('.') && entry.name !== 'node_modules' && entry.name !== 'docs') {
1414
+ await this.scanForInlineDocs(fullPath, files);
1415
+ } else if (entry.isFile() && entry.name.endsWith('.md') && !entry.name.toLowerCase().startsWith('readme')) {
1416
+ files.push(fullPath);
1417
+ }
1418
+ }
1419
+ } catch (error) {
1420
+ // Ignore permission errors
1421
+ }
1422
+ }
1423
+
1424
+ stopAutoSync() {
1425
+ if (this.syncInterval) {
1426
+ clearInterval(this.syncInterval);
1427
+ this.syncInterval = null;
1428
+ }
1429
+ }
1430
+ }
1431
+
1432
+ module.exports = DocumentationSynchronizer;