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,1736 @@
1
+ /**
2
+ * Semantic Merge Engine
3
+ * Story 8.3 - Enhanced Implementation
4
+ *
5
+ * AI-powered semantic merge system for resolving conflicts between
6
+ * parallel agent work. Analyzes code at semantic level (functions, imports,
7
+ * classes) rather than line-by-line to enable intelligent merge resolution.
8
+ *
9
+ * Architecture:
10
+ * 1. SemanticAnalyzer - Extracts semantic elements from code
11
+ * 2. ConflictDetector - Detects conflicts using compatibility rules
12
+ * 3. AutoMerger - Resolves simple conflicts deterministically
13
+ * 4. AIResolver - Uses Claude for complex conflict resolution
14
+ * 5. MergeOrchestrator - Coordinates the complete pipeline
15
+ *
16
+ * Based on Auto-Claude's merge system architecture.
17
+ */
18
+
19
+ const { execSync } = require('child_process');
20
+ const fs = require('fs');
21
+ const path = require('path');
22
+ const EventEmitter = require('events');
23
+ const yaml = require('js-yaml');
24
+
25
+ // ============================================================================
26
+ // TYPES & ENUMS
27
+ // ============================================================================
28
+
29
+ const ChangeType = {
30
+ IMPORT_ADDED: 'import_added',
31
+ IMPORT_REMOVED: 'import_removed',
32
+ IMPORT_MODIFIED: 'import_modified',
33
+ FUNCTION_ADDED: 'function_added',
34
+ FUNCTION_REMOVED: 'function_removed',
35
+ FUNCTION_MODIFIED: 'function_modified',
36
+ CLASS_ADDED: 'class_added',
37
+ CLASS_REMOVED: 'class_removed',
38
+ CLASS_MODIFIED: 'class_modified',
39
+ VARIABLE_ADDED: 'variable_added',
40
+ VARIABLE_REMOVED: 'variable_removed',
41
+ VARIABLE_MODIFIED: 'variable_modified',
42
+ JSX_ADDED: 'jsx_added',
43
+ JSX_MODIFIED: 'jsx_modified',
44
+ COMMENT_ADDED: 'comment_added',
45
+ COMMENT_MODIFIED: 'comment_modified',
46
+ STYLE_ADDED: 'style_added',
47
+ STYLE_MODIFIED: 'style_modified',
48
+ CONFIG_MODIFIED: 'config_modified',
49
+ UNKNOWN: 'unknown',
50
+ };
51
+
52
+ const MergeStrategy = {
53
+ COMBINE: 'combine', // Both changes can coexist
54
+ TAKE_NEWER: 'take_newer', // Take the more recent change
55
+ TAKE_LARGER: 'take_larger', // Take the more comprehensive change
56
+ AI_REQUIRED: 'ai_required', // Needs AI to resolve
57
+ HUMAN_REQUIRED: 'human_required', // Too complex, needs human
58
+ };
59
+
60
+ const ConflictSeverity = {
61
+ LOW: 'low', // Auto-mergeable
62
+ MEDIUM: 'medium', // AI can likely resolve
63
+ HIGH: 'high', // AI required with review
64
+ CRITICAL: 'critical', // Human intervention required
65
+ };
66
+
67
+ const MergeDecision = {
68
+ AUTO_MERGED: 'auto_merged',
69
+ AI_MERGED: 'ai_merged',
70
+ NEEDS_HUMAN_REVIEW: 'needs_human_review',
71
+ FAILED: 'failed',
72
+ };
73
+
74
+ // ============================================================================
75
+ // SEMANTIC ANALYZER
76
+ // ============================================================================
77
+
78
+ class SemanticAnalyzer {
79
+ constructor() {
80
+ this.patterns = {
81
+ // JavaScript/TypeScript patterns
82
+ jsImport:
83
+ /^(?:import\s+(?:(?:\{[^}]*\}|\*\s+as\s+\w+|\w+)(?:\s*,\s*)?)+\s+from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"])/gm,
84
+ jsFunction:
85
+ /(?:(?:export\s+)?(?:async\s+)?function\s+(\w+)|(?:const|let|var)\s+(\w+)\s*=\s*(?:async\s+)?(?:\([^)]*\)|[^=])\s*=>|(\w+)\s*:\s*(?:async\s+)?(?:function|\([^)]*\)\s*=>))/gm,
86
+ jsClass: /(?:export\s+)?class\s+(\w+)(?:\s+extends\s+\w+)?/gm,
87
+ jsVariable: /(?:export\s+)?(?:const|let|var)\s+(\w+)\s*=/gm,
88
+
89
+ // JSX patterns
90
+ jsxComponent: /<(\w+)(?:\s[^>]*)?\/?>/gm,
91
+
92
+ // Python patterns
93
+ pyImport: /^(?:from\s+\S+\s+import\s+.+|import\s+.+)$/gm,
94
+ pyFunction: /^(?:async\s+)?def\s+(\w+)\s*\(/gm,
95
+ pyClass: /^class\s+(\w+)(?:\([^)]*\))?:/gm,
96
+
97
+ // CSS patterns
98
+ cssSelector: /^([.#]?\w[\w-]*(?:\s*[,>+~]\s*[.#]?\w[\w-]*)*)\s*\{/gm,
99
+ cssProperty: /^\s*([\w-]+)\s*:/gm,
100
+ };
101
+ }
102
+
103
+ /**
104
+ * Analyze semantic differences between two versions of a file
105
+ * @param {string} filePath - Path to file
106
+ * @param {string} before - Content before changes
107
+ * @param {string} after - Content after changes
108
+ * @param {string} taskId - Task identifier
109
+ * @returns {Object} FileAnalysis with semantic changes
110
+ */
111
+ analyzeDiff(filePath, before, after, taskId = null) {
112
+ const ext = path.extname(filePath).toLowerCase();
113
+ const language = this.detectLanguage(ext);
114
+
115
+ const beforeElements = this.extractElements(before, language);
116
+ const afterElements = this.extractElements(after, language);
117
+
118
+ const changes = this.computeChanges(beforeElements, afterElements, language);
119
+
120
+ return {
121
+ filePath,
122
+ taskId,
123
+ language,
124
+ changes,
125
+ functionsModified: changes
126
+ .filter((c) => c.changeType.includes('function'))
127
+ .map((c) => c.target),
128
+ functionsAdded: changes
129
+ .filter((c) => c.changeType === ChangeType.FUNCTION_ADDED)
130
+ .map((c) => c.target),
131
+ importsAdded: changes
132
+ .filter((c) => c.changeType === ChangeType.IMPORT_ADDED)
133
+ .map((c) => c.target),
134
+ totalLinesChanged: this.countChangedLines(before, after),
135
+ };
136
+ }
137
+
138
+ /**
139
+ * Detect programming language from file extension
140
+ */
141
+ detectLanguage(ext) {
142
+ const languageMap = {
143
+ '.js': 'javascript',
144
+ '.jsx': 'javascript',
145
+ '.ts': 'typescript',
146
+ '.tsx': 'typescript',
147
+ '.py': 'python',
148
+ '.css': 'css',
149
+ '.scss': 'scss',
150
+ '.json': 'json',
151
+ '.md': 'markdown',
152
+ '.yaml': 'yaml',
153
+ '.yml': 'yaml',
154
+ };
155
+ return languageMap[ext] || 'text';
156
+ }
157
+
158
+ /**
159
+ * Extract semantic elements from code
160
+ */
161
+ extractElements(content, language) {
162
+ const elements = {
163
+ imports: [],
164
+ functions: [],
165
+ classes: [],
166
+ variables: [],
167
+ jsx: [],
168
+ other: [],
169
+ };
170
+
171
+ if (!content) return elements;
172
+
173
+ if (language === 'javascript' || language === 'typescript') {
174
+ // Extract imports
175
+ const importMatches = content.match(this.patterns.jsImport) || [];
176
+ elements.imports = importMatches.map((m) => ({
177
+ type: 'import',
178
+ content: m.trim(),
179
+ source: this.extractImportSource(m),
180
+ }));
181
+
182
+ // Extract functions
183
+ let match;
184
+ const funcRegex = new RegExp(this.patterns.jsFunction.source, 'gm');
185
+ while ((match = funcRegex.exec(content)) !== null) {
186
+ const name = match[1] || match[2] || match[3];
187
+ if (name) {
188
+ elements.functions.push({
189
+ type: 'function',
190
+ name,
191
+ content: this.extractFunctionBody(content, match.index),
192
+ location: this.getLocation(content, match.index),
193
+ });
194
+ }
195
+ }
196
+
197
+ // Extract classes
198
+ const classRegex = new RegExp(this.patterns.jsClass.source, 'gm');
199
+ while ((match = classRegex.exec(content)) !== null) {
200
+ elements.classes.push({
201
+ type: 'class',
202
+ name: match[1],
203
+ content: this.extractClassBody(content, match.index),
204
+ location: this.getLocation(content, match.index),
205
+ });
206
+ }
207
+ } else if (language === 'python') {
208
+ // Extract Python imports
209
+ const pyImportMatches = content.match(this.patterns.pyImport) || [];
210
+ elements.imports = pyImportMatches.map((m) => ({
211
+ type: 'import',
212
+ content: m.trim(),
213
+ }));
214
+
215
+ // Extract Python functions
216
+ let match;
217
+ const pyFuncRegex = new RegExp(this.patterns.pyFunction.source, 'gm');
218
+ while ((match = pyFuncRegex.exec(content)) !== null) {
219
+ elements.functions.push({
220
+ type: 'function',
221
+ name: match[1],
222
+ location: this.getLocation(content, match.index),
223
+ });
224
+ }
225
+
226
+ // Extract Python classes
227
+ const pyClassRegex = new RegExp(this.patterns.pyClass.source, 'gm');
228
+ while ((match = pyClassRegex.exec(content)) !== null) {
229
+ elements.classes.push({
230
+ type: 'class',
231
+ name: match[1],
232
+ location: this.getLocation(content, match.index),
233
+ });
234
+ }
235
+ }
236
+
237
+ return elements;
238
+ }
239
+
240
+ /**
241
+ * Compute semantic changes between two element sets
242
+ */
243
+ computeChanges(before, after, _language) {
244
+ const changes = [];
245
+
246
+ // Compare imports
247
+ const beforeImports = new Set(before.imports.map((i) => i.content));
248
+ const afterImports = new Set(after.imports.map((i) => i.content));
249
+
250
+ for (const imp of after.imports) {
251
+ if (!beforeImports.has(imp.content)) {
252
+ changes.push({
253
+ changeType: ChangeType.IMPORT_ADDED,
254
+ target: imp.content,
255
+ location: 'imports',
256
+ });
257
+ }
258
+ }
259
+
260
+ for (const imp of before.imports) {
261
+ if (!afterImports.has(imp.content)) {
262
+ changes.push({
263
+ changeType: ChangeType.IMPORT_REMOVED,
264
+ target: imp.content,
265
+ location: 'imports',
266
+ });
267
+ }
268
+ }
269
+
270
+ // Compare functions
271
+ const beforeFuncs = new Map(before.functions.map((f) => [f.name, f]));
272
+ const afterFuncs = new Map(after.functions.map((f) => [f.name, f]));
273
+
274
+ for (const [name, func] of afterFuncs) {
275
+ if (!beforeFuncs.has(name)) {
276
+ changes.push({
277
+ changeType: ChangeType.FUNCTION_ADDED,
278
+ target: name,
279
+ location: func.location,
280
+ });
281
+ } else if (beforeFuncs.get(name).content !== func.content) {
282
+ changes.push({
283
+ changeType: ChangeType.FUNCTION_MODIFIED,
284
+ target: name,
285
+ location: func.location,
286
+ });
287
+ }
288
+ }
289
+
290
+ for (const [name, func] of beforeFuncs) {
291
+ if (!afterFuncs.has(name)) {
292
+ changes.push({
293
+ changeType: ChangeType.FUNCTION_REMOVED,
294
+ target: name,
295
+ location: func.location,
296
+ });
297
+ }
298
+ }
299
+
300
+ // Compare classes
301
+ const beforeClasses = new Map(before.classes.map((c) => [c.name, c]));
302
+ const afterClasses = new Map(after.classes.map((c) => [c.name, c]));
303
+
304
+ for (const [name, cls] of afterClasses) {
305
+ if (!beforeClasses.has(name)) {
306
+ changes.push({
307
+ changeType: ChangeType.CLASS_ADDED,
308
+ target: name,
309
+ location: cls.location,
310
+ });
311
+ } else if (beforeClasses.get(name).content !== cls.content) {
312
+ changes.push({
313
+ changeType: ChangeType.CLASS_MODIFIED,
314
+ target: name,
315
+ location: cls.location,
316
+ });
317
+ }
318
+ }
319
+
320
+ for (const [name] of beforeClasses) {
321
+ if (!afterClasses.has(name)) {
322
+ changes.push({
323
+ changeType: ChangeType.CLASS_REMOVED,
324
+ target: name,
325
+ location: 'class',
326
+ });
327
+ }
328
+ }
329
+
330
+ return changes;
331
+ }
332
+
333
+ // Helper methods
334
+ extractImportSource(importStr) {
335
+ const match = importStr.match(/from\s+['"]([^'"]+)['"]/);
336
+ return match ? match[1] : importStr;
337
+ }
338
+
339
+ extractFunctionBody(content, startIndex) {
340
+ // Simplified extraction - gets first 500 chars
341
+ return content.substring(startIndex, startIndex + 500);
342
+ }
343
+
344
+ extractClassBody(content, startIndex) {
345
+ return content.substring(startIndex, startIndex + 1000);
346
+ }
347
+
348
+ getLocation(content, index) {
349
+ const lines = content.substring(0, index).split('\n');
350
+ return `line ${lines.length}`;
351
+ }
352
+
353
+ countChangedLines(before, after) {
354
+ const beforeLines = (before || '').split('\n').length;
355
+ const afterLines = (after || '').split('\n').length;
356
+ return Math.abs(afterLines - beforeLines);
357
+ }
358
+ }
359
+
360
+ // ============================================================================
361
+ // CONFLICT DETECTOR
362
+ // ============================================================================
363
+
364
+ class ConflictDetector {
365
+ constructor(rulesLoader = null) {
366
+ this.rulesLoader = rulesLoader;
367
+ this.rules = this.buildCompatibilityRules();
368
+ }
369
+
370
+ /**
371
+ * Build compatibility rules for different change type combinations
372
+ * Merges default rules with custom rules from project configuration
373
+ */
374
+ buildCompatibilityRules() {
375
+ return new Map([
376
+ // Compatible combinations (can auto-merge)
377
+ [
378
+ `${ChangeType.IMPORT_ADDED}:${ChangeType.IMPORT_ADDED}`,
379
+ {
380
+ compatible: true,
381
+ strategy: MergeStrategy.COMBINE,
382
+ reason: 'Different imports can coexist',
383
+ },
384
+ ],
385
+ [
386
+ `${ChangeType.FUNCTION_ADDED}:${ChangeType.FUNCTION_ADDED}`,
387
+ {
388
+ compatible: true,
389
+ strategy: MergeStrategy.COMBINE,
390
+ reason: 'Different functions can coexist',
391
+ },
392
+ ],
393
+ [
394
+ `${ChangeType.FUNCTION_ADDED}:${ChangeType.IMPORT_ADDED}`,
395
+ {
396
+ compatible: true,
397
+ strategy: MergeStrategy.COMBINE,
398
+ reason: 'Function and import additions are independent',
399
+ },
400
+ ],
401
+ [
402
+ `${ChangeType.CLASS_ADDED}:${ChangeType.FUNCTION_ADDED}`,
403
+ {
404
+ compatible: true,
405
+ strategy: MergeStrategy.COMBINE,
406
+ reason: 'Class and function additions are independent',
407
+ },
408
+ ],
409
+
410
+ // Incompatible combinations (need resolution)
411
+ [
412
+ `${ChangeType.FUNCTION_MODIFIED}:${ChangeType.FUNCTION_MODIFIED}`,
413
+ {
414
+ compatible: false,
415
+ strategy: MergeStrategy.AI_REQUIRED,
416
+ severity: ConflictSeverity.MEDIUM,
417
+ reason: 'Same function modified by multiple tasks',
418
+ },
419
+ ],
420
+ [
421
+ `${ChangeType.CLASS_MODIFIED}:${ChangeType.CLASS_MODIFIED}`,
422
+ {
423
+ compatible: false,
424
+ strategy: MergeStrategy.AI_REQUIRED,
425
+ severity: ConflictSeverity.HIGH,
426
+ reason: 'Same class modified by multiple tasks',
427
+ },
428
+ ],
429
+ [
430
+ `${ChangeType.FUNCTION_REMOVED}:${ChangeType.FUNCTION_MODIFIED}`,
431
+ {
432
+ compatible: false,
433
+ strategy: MergeStrategy.HUMAN_REQUIRED,
434
+ severity: ConflictSeverity.CRITICAL,
435
+ reason: 'Function removed by one task, modified by another',
436
+ },
437
+ ],
438
+ [
439
+ `${ChangeType.IMPORT_REMOVED}:${ChangeType.IMPORT_MODIFIED}`,
440
+ {
441
+ compatible: false,
442
+ strategy: MergeStrategy.AI_REQUIRED,
443
+ severity: ConflictSeverity.MEDIUM,
444
+ reason: 'Import removed by one task, modified by another',
445
+ },
446
+ ],
447
+ ]);
448
+ }
449
+
450
+ /**
451
+ * Detect conflicts between multiple task analyses
452
+ * @param {Object} taskAnalyses - Map of taskId -> FileAnalysis
453
+ * @returns {Array} List of conflict regions
454
+ */
455
+ detectConflicts(taskAnalyses) {
456
+ const conflicts = [];
457
+ const taskIds = Object.keys(taskAnalyses);
458
+
459
+ if (taskIds.length < 2) {
460
+ return conflicts;
461
+ }
462
+
463
+ // Compare each pair of tasks
464
+ for (let i = 0; i < taskIds.length; i++) {
465
+ for (let j = i + 1; j < taskIds.length; j++) {
466
+ const taskA = taskIds[i];
467
+ const taskB = taskIds[j];
468
+ const analysisA = taskAnalyses[taskA];
469
+ const analysisB = taskAnalyses[taskB];
470
+
471
+ // Find overlapping changes
472
+ const taskConflicts = this.findOverlappingChanges(
473
+ taskA,
474
+ analysisA.changes,
475
+ taskB,
476
+ analysisB.changes,
477
+ analysisA.filePath,
478
+ );
479
+
480
+ conflicts.push(...taskConflicts);
481
+ }
482
+ }
483
+
484
+ return conflicts;
485
+ }
486
+
487
+ /**
488
+ * Find overlapping changes between two tasks
489
+ */
490
+ findOverlappingChanges(taskA, changesA, taskB, changesB, filePath) {
491
+ const conflicts = [];
492
+
493
+ for (const changeA of changesA) {
494
+ for (const changeB of changesB) {
495
+ // Check if changes affect the same target
496
+ if (changeA.target === changeB.target || changeA.location === changeB.location) {
497
+ const ruleKey = `${changeA.changeType}:${changeB.changeType}`;
498
+ const reverseKey = `${changeB.changeType}:${changeA.changeType}`;
499
+
500
+ const rule = this.rules.get(ruleKey) || this.rules.get(reverseKey);
501
+
502
+ if (rule && !rule.compatible) {
503
+ conflicts.push({
504
+ filePath,
505
+ location: changeA.location || changeB.location,
506
+ tasksInvolved: [taskA, taskB],
507
+ changeTypes: [changeA.changeType, changeB.changeType],
508
+ targets: [changeA.target, changeB.target],
509
+ severity: rule.severity || ConflictSeverity.MEDIUM,
510
+ mergeStrategy: rule.strategy,
511
+ reason: rule.reason,
512
+ canAutoMerge: rule.strategy === MergeStrategy.COMBINE,
513
+ });
514
+ }
515
+ }
516
+ }
517
+ }
518
+
519
+ return conflicts;
520
+ }
521
+
522
+ /**
523
+ * Get compatibility information for two change types
524
+ * Checks custom rules first, then falls back to defaults
525
+ */
526
+ getCompatibility(changeTypeA, changeTypeB) {
527
+ // Check custom rules first if loader is available
528
+ if (this.rulesLoader) {
529
+ const customRule = this.rulesLoader.getCompatibilityRule(changeTypeA, changeTypeB);
530
+ if (customRule) {
531
+ return {
532
+ compatible: customRule.compatible ?? false,
533
+ strategy: this.mapStrategy(customRule.strategy),
534
+ severity: this.mapSeverity(customRule.severity),
535
+ reason: customRule.reason || 'Custom rule',
536
+ };
537
+ }
538
+ }
539
+
540
+ // Fall back to default rules
541
+ const key = `${changeTypeA}:${changeTypeB}`;
542
+ const reverseKey = `${changeTypeB}:${changeTypeA}`;
543
+ return (
544
+ this.rules.get(key) ||
545
+ this.rules.get(reverseKey) || {
546
+ compatible: false,
547
+ strategy: MergeStrategy.AI_REQUIRED,
548
+ severity: ConflictSeverity.MEDIUM,
549
+ reason: 'Unknown change type combination',
550
+ }
551
+ );
552
+ }
553
+
554
+ /**
555
+ * Map string strategy to MergeStrategy enum
556
+ */
557
+ mapStrategy(strategy) {
558
+ if (!strategy) return MergeStrategy.AI_REQUIRED;
559
+ const strategyMap = {
560
+ combine: MergeStrategy.COMBINE,
561
+ take_newer: MergeStrategy.TAKE_NEWER,
562
+ take_larger: MergeStrategy.TAKE_LARGER,
563
+ ai_required: MergeStrategy.AI_REQUIRED,
564
+ human_required: MergeStrategy.HUMAN_REQUIRED,
565
+ };
566
+ return strategyMap[strategy.toLowerCase()] || MergeStrategy.AI_REQUIRED;
567
+ }
568
+
569
+ /**
570
+ * Map string severity to ConflictSeverity enum
571
+ */
572
+ mapSeverity(severity) {
573
+ if (!severity) return ConflictSeverity.MEDIUM;
574
+ const severityMap = {
575
+ low: ConflictSeverity.LOW,
576
+ medium: ConflictSeverity.MEDIUM,
577
+ high: ConflictSeverity.HIGH,
578
+ critical: ConflictSeverity.CRITICAL,
579
+ };
580
+ return severityMap[severity.toLowerCase()] || ConflictSeverity.MEDIUM;
581
+ }
582
+ }
583
+
584
+ // ============================================================================
585
+ // AUTO MERGER
586
+ // ============================================================================
587
+
588
+ class AutoMerger {
589
+ /**
590
+ * Attempt to automatically merge changes without AI
591
+ * @param {Object} conflict - Conflict region
592
+ * @param {string} baseContent - Original file content
593
+ * @param {Object} taskContents - Map of taskId -> modified content
594
+ * @returns {Object} MergeResult
595
+ */
596
+ tryAutoMerge(conflict, baseContent, taskContents) {
597
+ const { mergeStrategy, changeTypes, targets } = conflict;
598
+
599
+ // Only handle COMBINE strategy automatically
600
+ if (mergeStrategy !== MergeStrategy.COMBINE) {
601
+ return {
602
+ success: false,
603
+ reason: 'Strategy requires AI resolution',
604
+ };
605
+ }
606
+
607
+ // Handle import combinations
608
+ if (changeTypes.every((ct) => ct.includes('import_added'))) {
609
+ return this.combineImports(baseContent, taskContents);
610
+ }
611
+
612
+ // Handle function additions
613
+ if (changeTypes.every((ct) => ct === ChangeType.FUNCTION_ADDED)) {
614
+ return this.combineFunctions(baseContent, taskContents, targets);
615
+ }
616
+
617
+ return {
618
+ success: false,
619
+ reason: 'No auto-merge strategy available for this change combination',
620
+ };
621
+ }
622
+
623
+ /**
624
+ * Combine import statements from multiple tasks
625
+ */
626
+ combineImports(baseContent, taskContents) {
627
+ const allImports = new Set();
628
+ const importRegex = /^(?:import\s+.+|from\s+.+import\s+.+)$/gm;
629
+
630
+ // Collect all imports from all versions
631
+ for (const content of Object.values(taskContents)) {
632
+ const matches = content.match(importRegex) || [];
633
+ matches.forEach((imp) => allImports.add(imp.trim()));
634
+ }
635
+
636
+ // Sort imports
637
+ const sortedImports = Array.from(allImports).sort();
638
+
639
+ // Replace imports in base content
640
+ const result = baseContent.replace(importRegex, '');
641
+
642
+ // Find first non-empty, non-comment line to insert imports
643
+ const lines = result.split('\n');
644
+ let insertIndex = 0;
645
+ for (let i = 0; i < lines.length; i++) {
646
+ if (
647
+ lines[i].trim() &&
648
+ !lines[i].trim().startsWith('//') &&
649
+ !lines[i].trim().startsWith('#')
650
+ ) {
651
+ insertIndex = i;
652
+ break;
653
+ }
654
+ }
655
+
656
+ lines.splice(insertIndex, 0, ...sortedImports, '');
657
+
658
+ return {
659
+ success: true,
660
+ mergedContent: lines.join('\n'),
661
+ decision: MergeDecision.AUTO_MERGED,
662
+ explanation: `Combined ${allImports.size} imports from ${Object.keys(taskContents).length} tasks`,
663
+ };
664
+ }
665
+
666
+ /**
667
+ * Combine function additions from multiple tasks
668
+ */
669
+ combineFunctions(baseContent, taskContents, functionNames) {
670
+ // This is a simplified version - real implementation would parse AST
671
+ let mergedContent = baseContent;
672
+
673
+ for (const [_taskId, content] of Object.entries(taskContents)) {
674
+ for (const funcName of functionNames) {
675
+ // Check if function exists in this task's content but not in merged
676
+ const funcRegex = new RegExp(
677
+ `(?:export\\s+)?(?:async\\s+)?function\\s+${funcName}\\s*\\([^)]*\\)\\s*\\{[^}]*\\}`,
678
+ 'g',
679
+ );
680
+
681
+ const match = content.match(funcRegex);
682
+ if (match && !mergedContent.includes(`function ${funcName}`)) {
683
+ // Append function to merged content
684
+ mergedContent += '\n\n' + match[0];
685
+ }
686
+ }
687
+ }
688
+
689
+ return {
690
+ success: true,
691
+ mergedContent,
692
+ decision: MergeDecision.AUTO_MERGED,
693
+ explanation: `Combined ${functionNames.length} function additions`,
694
+ };
695
+ }
696
+ }
697
+
698
+ // ============================================================================
699
+ // AI RESOLVER
700
+ // ============================================================================
701
+
702
+ class AIResolver {
703
+ constructor(config = {}) {
704
+ this.maxContextTokens = config.maxContextTokens || 4000;
705
+ this.confidenceThreshold = config.confidenceThreshold || 0.7;
706
+ this.callCount = 0;
707
+ this.totalTokens = 0;
708
+ }
709
+
710
+ /**
711
+ * Resolve a conflict using AI (Claude CLI)
712
+ * @param {Object} conflict - Conflict region
713
+ * @param {string} baseContent - Original content
714
+ * @param {Object} taskSnapshots - Task changes and intents
715
+ * @returns {Promise<Object>} MergeResult
716
+ */
717
+ async resolveConflict(conflict, baseContent, taskSnapshots) {
718
+ const context = this.buildContext(conflict, baseContent, taskSnapshots);
719
+
720
+ // Check token limit
721
+ const estimatedTokens = Math.ceil(context.length / 4);
722
+ if (estimatedTokens > this.maxContextTokens) {
723
+ return {
724
+ decision: MergeDecision.NEEDS_HUMAN_REVIEW,
725
+ reason: `Context too large (${estimatedTokens} tokens)`,
726
+ conflict,
727
+ };
728
+ }
729
+
730
+ const prompt = this.buildMergePrompt(conflict, context);
731
+
732
+ try {
733
+ const response = await this.callClaude(prompt);
734
+ this.callCount++;
735
+ this.totalTokens += estimatedTokens;
736
+
737
+ const mergedCode = this.extractCodeBlock(response);
738
+
739
+ if (mergedCode) {
740
+ return {
741
+ decision: MergeDecision.AI_MERGED,
742
+ mergedContent: mergedCode,
743
+ explanation: `AI resolved conflict at ${conflict.location}`,
744
+ confidence: this.assessConfidence(response),
745
+ aiCallsMade: 1,
746
+ tokensUsed: estimatedTokens,
747
+ };
748
+ } else {
749
+ return {
750
+ decision: MergeDecision.NEEDS_HUMAN_REVIEW,
751
+ reason: 'Could not parse AI response',
752
+ rawResponse: response,
753
+ conflict,
754
+ };
755
+ }
756
+ } catch (error) {
757
+ return {
758
+ decision: MergeDecision.FAILED,
759
+ error: error.message,
760
+ conflict,
761
+ };
762
+ }
763
+ }
764
+
765
+ /**
766
+ * Build context for AI resolution
767
+ */
768
+ buildContext(conflict, baseContent, taskSnapshots) {
769
+ let context = '## Conflict Location\n';
770
+ context += `File: ${conflict.filePath}\n`;
771
+ context += `Location: ${conflict.location}\n`;
772
+ context += `Severity: ${conflict.severity}\n\n`;
773
+
774
+ context += `## Original Code (baseline)\n\`\`\`\n${baseContent}\n\`\`\`\n\n`;
775
+
776
+ context += '## Task Changes\n';
777
+ for (const [taskId, snapshot] of Object.entries(taskSnapshots)) {
778
+ if (conflict.tasksInvolved.includes(taskId)) {
779
+ context += `### ${taskId}\n`;
780
+ context += `Intent: ${snapshot.intent || 'Not specified'}\n`;
781
+ context += `Changes: ${snapshot.changes?.map((c) => c.changeType).join(', ')}\n`;
782
+ context += `\`\`\`\n${snapshot.content || ''}\n\`\`\`\n\n`;
783
+ }
784
+ }
785
+
786
+ return context;
787
+ }
788
+
789
+ /**
790
+ * Build the merge prompt for Claude
791
+ */
792
+ buildMergePrompt(conflict, context) {
793
+ return `You are a code merge specialist. Your task is to merge conflicting changes from multiple development tasks into a single coherent result.
794
+
795
+ ${context}
796
+
797
+ ## Instructions
798
+ 1. Analyze the intent of each task's changes
799
+ 2. Preserve the functionality from ALL tasks where possible
800
+ 3. Resolve any syntactic conflicts
801
+ 4. Ensure the merged code is valid and follows best practices
802
+ 5. If changes are incompatible, prioritize based on the apparent importance
803
+
804
+ ## Output
805
+ Provide ONLY the merged code in a code block. No explanations outside the code block.
806
+
807
+ \`\`\`
808
+ // Your merged code here
809
+ \`\`\``;
810
+ }
811
+
812
+ /**
813
+ * Call Claude CLI for merge resolution
814
+ */
815
+ async callClaude(prompt) {
816
+ return new Promise((resolve, reject) => {
817
+ try {
818
+ // Use Claude CLI in print mode
819
+ const result = execSync(
820
+ `claude --print --dangerously-skip-permissions -p "${prompt.replace(/"/g, '\\"').replace(/\n/g, '\\n')}"`,
821
+ {
822
+ encoding: 'utf8',
823
+ maxBuffer: 10 * 1024 * 1024,
824
+ timeout: 120000,
825
+ },
826
+ );
827
+ resolve(result);
828
+ } catch (error) {
829
+ reject(new Error(`Claude CLI error: ${error.message}`));
830
+ }
831
+ });
832
+ }
833
+
834
+ /**
835
+ * Extract code block from AI response
836
+ */
837
+ extractCodeBlock(response) {
838
+ const codeBlockRegex = /```(?:\w+)?\n([\s\S]*?)```/;
839
+ const match = response.match(codeBlockRegex);
840
+ return match ? match[1].trim() : null;
841
+ }
842
+
843
+ /**
844
+ * Assess confidence in AI resolution
845
+ */
846
+ assessConfidence(response) {
847
+ // Simple heuristic based on response characteristics
848
+ const hasCodeBlock = /```[\s\S]*```/.test(response);
849
+ const hasExplanation = response.length > 500;
850
+ const noErrorIndicators = !/(error|failed|cannot|unable)/i.test(response);
851
+
852
+ let confidence = 0.5;
853
+ if (hasCodeBlock) confidence += 0.3;
854
+ if (noErrorIndicators) confidence += 0.15;
855
+ if (hasExplanation) confidence += 0.05;
856
+
857
+ return Math.min(confidence, 1.0);
858
+ }
859
+
860
+ /**
861
+ * Get usage statistics
862
+ */
863
+ getStats() {
864
+ return {
865
+ callsMade: this.callCount,
866
+ estimatedTokensUsed: this.totalTokens,
867
+ };
868
+ }
869
+ }
870
+
871
+ // ============================================================================
872
+ // CUSTOM RULES LOADER
873
+ // ============================================================================
874
+
875
+ /**
876
+ * Custom rules loader with caching (following ConfigLoader pattern)
877
+ * Loads project-specific merge rules from .grimoire/merge-rules.yaml
878
+ */
879
+ class CustomRulesLoader {
880
+ constructor(rootPath = process.cwd()) {
881
+ this.rootPath = rootPath;
882
+ this.rulesPath = path.join(rootPath, '.grimoire', 'merge-rules.yaml');
883
+ this.cache = {
884
+ rules: null,
885
+ lastLoad: null,
886
+ TTL: 5 * 60 * 1000, // 5 minutes
887
+ };
888
+ }
889
+
890
+ /**
891
+ * Check if cache is valid
892
+ */
893
+ isCacheValid() {
894
+ if (!this.cache.lastLoad || !this.cache.rules) return false;
895
+ const age = Date.now() - this.cache.lastLoad;
896
+ return age < this.cache.TTL;
897
+ }
898
+
899
+ /**
900
+ * Load custom rules from project
901
+ * @returns {Object|null} Custom rules or null if not found
902
+ */
903
+ loadCustomRules() {
904
+ // Check cache first
905
+ if (this.isCacheValid()) {
906
+ return this.cache.rules;
907
+ }
908
+
909
+ try {
910
+ if (!fs.existsSync(this.rulesPath)) {
911
+ return null;
912
+ }
913
+
914
+ const content = fs.readFileSync(this.rulesPath, 'utf8');
915
+ const rules = yaml.load(content);
916
+
917
+ // Cache the rules
918
+ this.cache.rules = rules;
919
+ this.cache.lastLoad = Date.now();
920
+
921
+ return rules;
922
+ } catch (error) {
923
+ console.warn(`Warning: Could not load custom rules from ${this.rulesPath}: ${error.message}`);
924
+ return null;
925
+ }
926
+ }
927
+
928
+ /**
929
+ * Clear the cache
930
+ */
931
+ clearCache() {
932
+ this.cache.rules = null;
933
+ this.cache.lastLoad = null;
934
+ }
935
+
936
+ /**
937
+ * Get default rules
938
+ */
939
+ getDefaultRules() {
940
+ return {
941
+ compatibility: { rules: {} },
942
+ file_patterns: {
943
+ skip: [
944
+ 'node_modules/**',
945
+ '.git/**',
946
+ 'package-lock.json',
947
+ 'yarn.lock',
948
+ '*.log',
949
+ '*.min.*',
950
+ 'dist/**',
951
+ 'build/**',
952
+ ],
953
+ auto_merge: ['*.md', '*.txt', '.gitignore'],
954
+ human_review: ['package.json', 'tsconfig.json', '*.config.js', '.env*'],
955
+ ai_preferred: ['src/**/*.ts', 'src/**/*.tsx', 'src/**/*.js', 'src/**/*.jsx'],
956
+ },
957
+ languages: {
958
+ javascript: {
959
+ patterns: { imports: true, functions: true, classes: true, variables: true, jsx: true },
960
+ imports: { deduplicate: true, sort: true, group: true },
961
+ },
962
+ typescript: {
963
+ patterns: {
964
+ imports: true,
965
+ functions: true,
966
+ classes: true,
967
+ variables: true,
968
+ jsx: true,
969
+ types: true,
970
+ interfaces: true,
971
+ },
972
+ imports: { deduplicate: true, sort: true, group: true },
973
+ },
974
+ python: {
975
+ patterns: { imports: true, functions: true, classes: true },
976
+ imports: { deduplicate: true, sort: true },
977
+ },
978
+ css: {
979
+ patterns: { selectors: true, properties: true },
980
+ conflict_resolution: 'take_newer',
981
+ },
982
+ },
983
+ strategies: {
984
+ default: 'ai_required',
985
+ scenarios: {
986
+ parallel_additions: { strategy: 'combine', order: 'alphabetical' },
987
+ concurrent_modifications: { strategy: 'ai_required' },
988
+ remove_vs_modify: { strategy: 'human_required' },
989
+ },
990
+ },
991
+ ai: {
992
+ enabled: true,
993
+ max_context_tokens: 4000,
994
+ confidence_threshold: 0.7,
995
+ max_calls_per_merge: 10,
996
+ },
997
+ severity: {
998
+ lines_threshold: { low: 10, medium: 50, high: 100, critical: 200 },
999
+ functions_threshold: { low: 1, medium: 3, high: 5, critical: 10 },
1000
+ human_review_threshold: 'high',
1001
+ },
1002
+ hooks: {
1003
+ pre_merge: null,
1004
+ post_merge: null,
1005
+ on_conflict: null,
1006
+ on_human_review: null,
1007
+ },
1008
+ notifications: {
1009
+ on_complete: true,
1010
+ on_conflict: true,
1011
+ channels: [],
1012
+ },
1013
+ };
1014
+ }
1015
+
1016
+ /**
1017
+ * Merge custom rules with defaults
1018
+ * Custom rules take precedence over defaults
1019
+ * @returns {Object} Merged rules
1020
+ */
1021
+ getMergedRules() {
1022
+ const defaults = this.getDefaultRules();
1023
+ const custom = this.loadCustomRules();
1024
+
1025
+ if (!custom) {
1026
+ return defaults;
1027
+ }
1028
+
1029
+ // Deep merge with custom taking precedence
1030
+ return this.deepMerge(defaults, custom);
1031
+ }
1032
+
1033
+ /**
1034
+ * Deep merge two objects
1035
+ * @param {Object} target - Base object
1036
+ * @param {Object} source - Object to merge (takes precedence)
1037
+ * @returns {Object} Merged object
1038
+ */
1039
+ deepMerge(target, source) {
1040
+ const result = { ...target };
1041
+
1042
+ for (const key of Object.keys(source)) {
1043
+ if (source[key] === null || source[key] === undefined) {
1044
+ continue;
1045
+ }
1046
+
1047
+ if (
1048
+ typeof source[key] === 'object' &&
1049
+ !Array.isArray(source[key]) &&
1050
+ typeof target[key] === 'object' &&
1051
+ !Array.isArray(target[key])
1052
+ ) {
1053
+ result[key] = this.deepMerge(target[key] || {}, source[key]);
1054
+ } else {
1055
+ result[key] = source[key];
1056
+ }
1057
+ }
1058
+
1059
+ return result;
1060
+ }
1061
+
1062
+ /**
1063
+ * Check if file matches any pattern in list
1064
+ * @param {string} filePath - File path to check
1065
+ * @param {string[]} patterns - Glob patterns to match against
1066
+ * @returns {boolean} True if matches any pattern
1067
+ */
1068
+ matchesPattern(filePath, patterns) {
1069
+ if (!patterns || !Array.isArray(patterns)) return false;
1070
+
1071
+ for (const pattern of patterns) {
1072
+ // Escape special regex characters first, then convert glob patterns
1073
+ const regexPattern = pattern
1074
+ .replace(/[.+^${}()|[\]\\]/g, '\\$&') // Escape regex special chars
1075
+ .replace(/\*\*/g, '<<<GLOBSTAR>>>') // Temp placeholder for **
1076
+ .replace(/\*/g, '[^/]*') // Single * = anything except /
1077
+ .replace(/<<<GLOBSTAR>>>/g, '.*') // ** = anything including /
1078
+ .replace(/\?/g, '.'); // ? = single char
1079
+
1080
+ // Allow pattern to match anywhere in the path (not just start)
1081
+ // For patterns like 'node_modules/**', match anywhere
1082
+ const regex = new RegExp(`(^|/)${regexPattern}(/|$)|^${regexPattern}$`);
1083
+
1084
+ if (regex.test(filePath)) {
1085
+ return true;
1086
+ }
1087
+ }
1088
+
1089
+ return false;
1090
+ }
1091
+
1092
+ /**
1093
+ * Get file handling category based on patterns
1094
+ * @param {string} filePath - File path to categorize
1095
+ * @returns {string} Category: 'skip', 'auto_merge', 'human_review', 'ai_preferred', 'default'
1096
+ */
1097
+ getFileCategory(filePath) {
1098
+ const rules = this.getMergedRules();
1099
+ const patterns = rules.file_patterns || {};
1100
+
1101
+ if (this.matchesPattern(filePath, patterns.skip)) return 'skip';
1102
+ if (this.matchesPattern(filePath, patterns.human_review)) return 'human_review';
1103
+ if (this.matchesPattern(filePath, patterns.auto_merge)) return 'auto_merge';
1104
+ if (this.matchesPattern(filePath, patterns.ai_preferred)) return 'ai_preferred';
1105
+
1106
+ return 'default';
1107
+ }
1108
+
1109
+ /**
1110
+ * Get compatibility rule for change type combination
1111
+ * @param {string} changeTypeA - First change type
1112
+ * @param {string} changeTypeB - Second change type
1113
+ * @returns {Object|null} Custom rule or null if not defined
1114
+ */
1115
+ getCompatibilityRule(changeTypeA, changeTypeB) {
1116
+ const rules = this.getMergedRules();
1117
+ const customRules = rules.compatibility?.rules || {};
1118
+
1119
+ // Check both orderings
1120
+ const key1 = `${changeTypeA}:${changeTypeB}`;
1121
+ const key2 = `${changeTypeB}:${changeTypeA}`;
1122
+
1123
+ return customRules[key1] || customRules[key2] || null;
1124
+ }
1125
+
1126
+ /**
1127
+ * Get language-specific configuration
1128
+ * @param {string} language - Language name
1129
+ * @returns {Object} Language config
1130
+ */
1131
+ getLanguageConfig(language) {
1132
+ const rules = this.getMergedRules();
1133
+ return rules.languages?.[language] || {};
1134
+ }
1135
+
1136
+ /**
1137
+ * Get AI configuration
1138
+ * @returns {Object} AI config
1139
+ */
1140
+ getAIConfig() {
1141
+ const rules = this.getMergedRules();
1142
+ return rules.ai || { enabled: true, max_context_tokens: 4000, confidence_threshold: 0.7 };
1143
+ }
1144
+
1145
+ /**
1146
+ * Get severity thresholds
1147
+ * @returns {Object} Severity config
1148
+ */
1149
+ getSeverityConfig() {
1150
+ const rules = this.getMergedRules();
1151
+ return rules.severity || {};
1152
+ }
1153
+
1154
+ /**
1155
+ * Get hooks configuration
1156
+ * @returns {Object} Hooks config
1157
+ */
1158
+ getHooks() {
1159
+ const rules = this.getMergedRules();
1160
+ return rules.hooks || {};
1161
+ }
1162
+
1163
+ /**
1164
+ * Execute a hook if defined
1165
+ * @param {string} hookName - Name of hook to execute
1166
+ * @param {Object} context - Context data for the hook
1167
+ * @returns {Promise<boolean>} True if hook executed successfully
1168
+ */
1169
+ async executeHook(hookName, context = {}) {
1170
+ const hooks = this.getHooks();
1171
+ const hookCommand = hooks[hookName];
1172
+
1173
+ if (!hookCommand) return true;
1174
+
1175
+ try {
1176
+ execSync(hookCommand, {
1177
+ cwd: this.rootPath,
1178
+ encoding: 'utf8',
1179
+ env: {
1180
+ ...process.env,
1181
+ grimoire_MERGE_HOOK: hookName,
1182
+ grimoire_MERGE_CONTEXT: JSON.stringify(context),
1183
+ },
1184
+ });
1185
+ return true;
1186
+ } catch (error) {
1187
+ console.warn(`Warning: Hook ${hookName} failed: ${error.message}`);
1188
+ return false;
1189
+ }
1190
+ }
1191
+ }
1192
+
1193
+ // ============================================================================
1194
+ // SEMANTIC MERGE ENGINE (ORCHESTRATOR)
1195
+ // ============================================================================
1196
+
1197
+ class SemanticMergeEngine extends EventEmitter {
1198
+ constructor(config = {}) {
1199
+ super();
1200
+
1201
+ this.rootPath = config.rootPath || process.cwd();
1202
+ this.dryRun = config.dryRun || false;
1203
+
1204
+ // Initialize custom rules loader
1205
+ this.rulesLoader = new CustomRulesLoader(this.rootPath);
1206
+ const aiConfig = this.rulesLoader.getAIConfig();
1207
+
1208
+ // Apply config with custom rules as defaults
1209
+ this.enableAI = config.enableAI !== undefined ? config.enableAI : aiConfig.enabled;
1210
+ this.confidenceThreshold = config.confidenceThreshold || aiConfig.confidence_threshold || 0.7;
1211
+
1212
+ // Initialize components
1213
+ this.analyzer = new SemanticAnalyzer();
1214
+ this.detector = new ConflictDetector(this.rulesLoader);
1215
+ this.autoMerger = new AutoMerger();
1216
+ this.aiResolver = new AIResolver({
1217
+ maxContextTokens: config.maxContextTokens || aiConfig.max_context_tokens || 4000,
1218
+ confidenceThreshold: this.confidenceThreshold,
1219
+ });
1220
+
1221
+ // Storage
1222
+ this.storageDir = config.storageDir || path.join(this.rootPath, '.grimoire', 'merge');
1223
+ }
1224
+
1225
+ /**
1226
+ * Merge changes from multiple task worktrees
1227
+ * @param {Array} taskRequests - Array of { taskId, worktreePath, branch }
1228
+ * @param {string} targetBranch - Branch to merge into
1229
+ * @returns {Promise<Object>} MergeReport
1230
+ */
1231
+ async merge(taskRequests, targetBranch = 'main') {
1232
+ const report = {
1233
+ startedAt: new Date().toISOString(),
1234
+ tasks: taskRequests.map((t) => t.taskId),
1235
+ targetBranch,
1236
+ filesAnalyzed: 0,
1237
+ conflictsDetected: 0,
1238
+ autoMerged: 0,
1239
+ aiMerged: 0,
1240
+ needsHumanReview: 0,
1241
+ failed: 0,
1242
+ results: [],
1243
+ errors: [],
1244
+ rulesUsed: this.rulesLoader ? 'custom' : 'default',
1245
+ };
1246
+
1247
+ this.emit('merge_started', { tasks: report.tasks, targetBranch });
1248
+
1249
+ try {
1250
+ // Execute pre_merge hook if defined
1251
+ if (this.rulesLoader) {
1252
+ await this.rulesLoader.executeHook('pre_merge', {
1253
+ tasks: report.tasks,
1254
+ targetBranch,
1255
+ });
1256
+ }
1257
+
1258
+ // Step 1: Get baseline (target branch content)
1259
+ const baseline = await this.getBaseline(targetBranch);
1260
+
1261
+ // Step 2: Get changes from each task
1262
+ const taskSnapshots = {};
1263
+ for (const request of taskRequests) {
1264
+ taskSnapshots[request.taskId] = await this.getTaskSnapshot(request);
1265
+ }
1266
+
1267
+ // Step 3: Find modified files across all tasks
1268
+ const modifiedFiles = this.findModifiedFiles(taskSnapshots);
1269
+ report.filesAnalyzed = modifiedFiles.size;
1270
+
1271
+ // Step 4: Process each file
1272
+ for (const filePath of modifiedFiles) {
1273
+ const fileResult = await this.mergeFile(filePath, baseline[filePath] || '', taskSnapshots);
1274
+
1275
+ report.results.push(fileResult);
1276
+
1277
+ switch (fileResult.decision) {
1278
+ case MergeDecision.AUTO_MERGED:
1279
+ report.autoMerged++;
1280
+ break;
1281
+ case MergeDecision.AI_MERGED:
1282
+ report.aiMerged++;
1283
+ break;
1284
+ case MergeDecision.NEEDS_HUMAN_REVIEW:
1285
+ report.needsHumanReview++;
1286
+ // Execute on_human_review hook
1287
+ if (this.rulesLoader) {
1288
+ await this.rulesLoader.executeHook('on_human_review', {
1289
+ filePath,
1290
+ conflicts: fileResult.conflicts,
1291
+ });
1292
+ }
1293
+ break;
1294
+ case MergeDecision.FAILED:
1295
+ report.failed++;
1296
+ break;
1297
+ }
1298
+
1299
+ // Execute on_conflict hook for files with conflicts
1300
+ if (fileResult.conflicts && fileResult.conflicts.length > 0 && this.rulesLoader) {
1301
+ await this.rulesLoader.executeHook('on_conflict', {
1302
+ filePath,
1303
+ conflictCount: fileResult.conflicts.length,
1304
+ });
1305
+ }
1306
+ }
1307
+
1308
+ // Step 5: Apply merged changes (if not dry run)
1309
+ if (!this.dryRun) {
1310
+ await this.applyMergedChanges(report.results);
1311
+ }
1312
+
1313
+ report.completedAt = new Date().toISOString();
1314
+ report.status =
1315
+ report.failed === 0 && report.needsHumanReview === 0
1316
+ ? 'success'
1317
+ : report.needsHumanReview > 0
1318
+ ? 'needs_review'
1319
+ : 'partial';
1320
+
1321
+ this.emit('merge_completed', report);
1322
+
1323
+ // Execute post_merge hook if defined
1324
+ if (this.rulesLoader) {
1325
+ await this.rulesLoader.executeHook('post_merge', {
1326
+ status: report.status,
1327
+ filesAnalyzed: report.filesAnalyzed,
1328
+ autoMerged: report.autoMerged,
1329
+ aiMerged: report.aiMerged,
1330
+ });
1331
+ }
1332
+
1333
+ // Save report
1334
+ await this.saveReport(report);
1335
+
1336
+ return report;
1337
+ } catch (error) {
1338
+ report.errors.push(error.message);
1339
+ report.status = 'error';
1340
+ report.completedAt = new Date().toISOString();
1341
+
1342
+ this.emit('merge_error', { error: error.message });
1343
+
1344
+ return report;
1345
+ }
1346
+ }
1347
+
1348
+ /**
1349
+ * Merge a single file from multiple tasks
1350
+ */
1351
+ async mergeFile(filePath, baseContent, taskSnapshots) {
1352
+ this.emit('file_processing', { filePath });
1353
+
1354
+ // Check file category for special handling
1355
+ const category = this.getFileCategory(filePath);
1356
+
1357
+ // Handle human_review category
1358
+ if (category === 'human_review') {
1359
+ return {
1360
+ filePath,
1361
+ decision: MergeDecision.NEEDS_HUMAN_REVIEW,
1362
+ mergedContent: baseContent,
1363
+ explanation: `File ${filePath} is marked for human review in merge rules`,
1364
+ category,
1365
+ };
1366
+ }
1367
+
1368
+ // Step 1: Analyze changes from each task
1369
+ const taskAnalyses = {};
1370
+ const taskContents = {};
1371
+
1372
+ for (const [taskId, snapshot] of Object.entries(taskSnapshots)) {
1373
+ const taskContent = snapshot.files?.[filePath];
1374
+ if (taskContent !== undefined) {
1375
+ taskAnalyses[taskId] = this.analyzer.analyzeDiff(
1376
+ filePath,
1377
+ baseContent,
1378
+ taskContent,
1379
+ taskId,
1380
+ );
1381
+ taskContents[taskId] = taskContent;
1382
+ }
1383
+ }
1384
+
1385
+ // If only one task modified the file, no conflict
1386
+ if (Object.keys(taskAnalyses).length <= 1) {
1387
+ const [taskId, content] = Object.entries(taskContents)[0] || [null, baseContent];
1388
+ return {
1389
+ filePath,
1390
+ decision: MergeDecision.AUTO_MERGED,
1391
+ mergedContent: content,
1392
+ explanation: taskId ? `Single task ${taskId} modified file` : 'No changes',
1393
+ category,
1394
+ };
1395
+ }
1396
+
1397
+ // Handle auto_merge category (simpler merge, take most recent)
1398
+ if (category === 'auto_merge') {
1399
+ // Take the content with most changes
1400
+ let maxChanges = 0;
1401
+ let bestContent = baseContent;
1402
+ let bestTaskId = null;
1403
+
1404
+ for (const [taskId, analysis] of Object.entries(taskAnalyses)) {
1405
+ if (analysis.changes.length > maxChanges) {
1406
+ maxChanges = analysis.changes.length;
1407
+ bestContent = taskContents[taskId];
1408
+ bestTaskId = taskId;
1409
+ }
1410
+ }
1411
+
1412
+ return {
1413
+ filePath,
1414
+ decision: MergeDecision.AUTO_MERGED,
1415
+ mergedContent: bestContent,
1416
+ explanation: `Auto-merge category: used changes from task ${bestTaskId}`,
1417
+ category,
1418
+ };
1419
+ }
1420
+
1421
+ // Step 2: Detect conflicts
1422
+ const conflicts = this.detector.detectConflicts(taskAnalyses);
1423
+
1424
+ if (conflicts.length === 0) {
1425
+ // No conflicts - combine all changes
1426
+ const combined = this.combineNonConflictingChanges(baseContent, taskContents, taskAnalyses);
1427
+ return {
1428
+ filePath,
1429
+ decision: MergeDecision.AUTO_MERGED,
1430
+ mergedContent: combined,
1431
+ explanation: 'No conflicts detected, changes combined',
1432
+ };
1433
+ }
1434
+
1435
+ // Step 3: Try auto-merge for each conflict
1436
+ const results = [];
1437
+ for (const conflict of conflicts) {
1438
+ const autoResult = this.autoMerger.tryAutoMerge(conflict, baseContent, taskContents);
1439
+
1440
+ if (autoResult.success) {
1441
+ results.push({
1442
+ conflict,
1443
+ result: autoResult,
1444
+ decision: MergeDecision.AUTO_MERGED,
1445
+ });
1446
+ } else if (this.enableAI && conflict.mergeStrategy === MergeStrategy.AI_REQUIRED) {
1447
+ // Step 4: Use AI for complex conflicts
1448
+ const aiResult = await this.aiResolver.resolveConflict(
1449
+ conflict,
1450
+ baseContent,
1451
+ taskSnapshots,
1452
+ );
1453
+ results.push({
1454
+ conflict,
1455
+ result: aiResult,
1456
+ decision: aiResult.decision,
1457
+ });
1458
+ } else {
1459
+ results.push({
1460
+ conflict,
1461
+ result: { reason: 'No auto-merge strategy and AI disabled' },
1462
+ decision: MergeDecision.NEEDS_HUMAN_REVIEW,
1463
+ });
1464
+ }
1465
+ }
1466
+
1467
+ // Determine overall file decision
1468
+ const decisions = results.map((r) => r.decision);
1469
+ let finalDecision;
1470
+ let finalContent = baseContent;
1471
+
1472
+ if (decisions.every((d) => d === MergeDecision.AUTO_MERGED || d === MergeDecision.AI_MERGED)) {
1473
+ finalDecision = decisions.includes(MergeDecision.AI_MERGED)
1474
+ ? MergeDecision.AI_MERGED
1475
+ : MergeDecision.AUTO_MERGED;
1476
+
1477
+ // Apply all successful merges
1478
+ for (const r of results) {
1479
+ if (r.result.mergedContent) {
1480
+ finalContent = r.result.mergedContent;
1481
+ }
1482
+ }
1483
+ } else if (decisions.includes(MergeDecision.FAILED)) {
1484
+ finalDecision = MergeDecision.FAILED;
1485
+ } else {
1486
+ finalDecision = MergeDecision.NEEDS_HUMAN_REVIEW;
1487
+ }
1488
+
1489
+ return {
1490
+ filePath,
1491
+ decision: finalDecision,
1492
+ mergedContent: finalContent,
1493
+ conflicts: results,
1494
+ explanation: `${results.length} conflicts processed`,
1495
+ };
1496
+ }
1497
+
1498
+ /**
1499
+ * Combine non-conflicting changes from multiple tasks
1500
+ */
1501
+ combineNonConflictingChanges(baseContent, taskContents, taskAnalyses) {
1502
+ // Simple strategy: use the most changed version
1503
+ let maxChanges = 0;
1504
+ let bestContent = baseContent;
1505
+
1506
+ for (const [taskId, analysis] of Object.entries(taskAnalyses)) {
1507
+ if (analysis.changes.length > maxChanges) {
1508
+ maxChanges = analysis.changes.length;
1509
+ bestContent = taskContents[taskId];
1510
+ }
1511
+ }
1512
+
1513
+ return bestContent;
1514
+ }
1515
+
1516
+ /**
1517
+ * Get baseline content from target branch
1518
+ */
1519
+ async getBaseline(branch) {
1520
+ const files = {};
1521
+
1522
+ try {
1523
+ // Get list of files
1524
+ const fileList = execSync(`git ls-tree -r --name-only ${branch}`, {
1525
+ cwd: this.rootPath,
1526
+ encoding: 'utf8',
1527
+ })
1528
+ .trim()
1529
+ .split('\n');
1530
+
1531
+ for (const filePath of fileList) {
1532
+ if (this.shouldProcessFile(filePath)) {
1533
+ try {
1534
+ const content = execSync(`git show ${branch}:${filePath}`, {
1535
+ cwd: this.rootPath,
1536
+ encoding: 'utf8',
1537
+ });
1538
+ files[filePath] = content;
1539
+ } catch {
1540
+ // File might not exist in this branch
1541
+ }
1542
+ }
1543
+ }
1544
+ } catch (error) {
1545
+ console.warn(`Warning: Could not get baseline from ${branch}: ${error.message}`);
1546
+ }
1547
+
1548
+ return files;
1549
+ }
1550
+
1551
+ /**
1552
+ * Get snapshot of task changes
1553
+ */
1554
+ async getTaskSnapshot(request) {
1555
+ const { taskId, worktreePath, branch, intent } = request;
1556
+ const snapshot = {
1557
+ taskId,
1558
+ intent,
1559
+ files: {},
1560
+ changes: [],
1561
+ };
1562
+
1563
+ const workDir = worktreePath || this.rootPath;
1564
+
1565
+ try {
1566
+ // Get modified files in this task
1567
+ const diffOutput = execSync(`git diff --name-only ${branch || 'main'}...HEAD`, {
1568
+ cwd: workDir,
1569
+ encoding: 'utf8',
1570
+ }).trim();
1571
+
1572
+ const modifiedFiles = diffOutput ? diffOutput.split('\n') : [];
1573
+
1574
+ for (const filePath of modifiedFiles) {
1575
+ if (this.shouldProcessFile(filePath)) {
1576
+ try {
1577
+ const fullPath = path.join(workDir, filePath);
1578
+ if (fs.existsSync(fullPath)) {
1579
+ snapshot.files[filePath] = fs.readFileSync(fullPath, 'utf8');
1580
+ }
1581
+ } catch {
1582
+ // Skip files that can't be read
1583
+ }
1584
+ }
1585
+ }
1586
+ } catch (error) {
1587
+ console.warn(`Warning: Could not get snapshot for ${taskId}: ${error.message}`);
1588
+ }
1589
+
1590
+ return snapshot;
1591
+ }
1592
+
1593
+ /**
1594
+ * Find all files modified across tasks
1595
+ */
1596
+ findModifiedFiles(taskSnapshots) {
1597
+ const files = new Set();
1598
+
1599
+ for (const snapshot of Object.values(taskSnapshots)) {
1600
+ for (const filePath of Object.keys(snapshot.files || {})) {
1601
+ files.add(filePath);
1602
+ }
1603
+ }
1604
+
1605
+ return files;
1606
+ }
1607
+
1608
+ /**
1609
+ * Check if file should be processed
1610
+ * Uses custom rules if available, otherwise falls back to defaults
1611
+ */
1612
+ shouldProcessFile(filePath) {
1613
+ // Use custom rules if available
1614
+ if (this.rulesLoader) {
1615
+ const category = this.rulesLoader.getFileCategory(filePath);
1616
+ return category !== 'skip';
1617
+ }
1618
+
1619
+ // Default skip patterns
1620
+ const skipPatterns = [
1621
+ /node_modules/,
1622
+ /\.git/,
1623
+ /package-lock\.json/,
1624
+ /yarn\.lock/,
1625
+ /\.log$/,
1626
+ /\.min\./,
1627
+ /dist\//,
1628
+ /build\//,
1629
+ ];
1630
+
1631
+ return !skipPatterns.some((pattern) => pattern.test(filePath));
1632
+ }
1633
+
1634
+ /**
1635
+ * Get file category for special handling
1636
+ * @param {string} filePath - Path to file
1637
+ * @returns {string} Category: 'skip', 'auto_merge', 'human_review', 'ai_preferred', 'default'
1638
+ */
1639
+ getFileCategory(filePath) {
1640
+ if (this.rulesLoader) {
1641
+ return this.rulesLoader.getFileCategory(filePath);
1642
+ }
1643
+ return 'default';
1644
+ }
1645
+
1646
+ /**
1647
+ * Get custom rules (for external access)
1648
+ * @returns {Object} Merged rules
1649
+ */
1650
+ getRules() {
1651
+ if (this.rulesLoader) {
1652
+ return this.rulesLoader.getMergedRules();
1653
+ }
1654
+ return null;
1655
+ }
1656
+
1657
+ /**
1658
+ * Reload custom rules (clear cache and reload)
1659
+ */
1660
+ reloadRules() {
1661
+ if (this.rulesLoader) {
1662
+ this.rulesLoader.clearCache();
1663
+ // Re-initialize detector with fresh rules
1664
+ this.detector = new ConflictDetector(this.rulesLoader);
1665
+ }
1666
+ }
1667
+
1668
+ /**
1669
+ * Apply merged changes to files
1670
+ */
1671
+ async applyMergedChanges(results) {
1672
+ for (const result of results) {
1673
+ if (
1674
+ result.mergedContent &&
1675
+ (result.decision === MergeDecision.AUTO_MERGED ||
1676
+ result.decision === MergeDecision.AI_MERGED)
1677
+ ) {
1678
+ const fullPath = path.join(this.rootPath, result.filePath);
1679
+ const dir = path.dirname(fullPath);
1680
+
1681
+ if (!fs.existsSync(dir)) {
1682
+ fs.mkdirSync(dir, { recursive: true });
1683
+ }
1684
+
1685
+ fs.writeFileSync(fullPath, result.mergedContent, 'utf8');
1686
+ this.emit('file_merged', { filePath: result.filePath, decision: result.decision });
1687
+ }
1688
+ }
1689
+ }
1690
+
1691
+ /**
1692
+ * Save merge report
1693
+ */
1694
+ async saveReport(report) {
1695
+ if (!fs.existsSync(this.storageDir)) {
1696
+ fs.mkdirSync(this.storageDir, { recursive: true });
1697
+ }
1698
+
1699
+ const reportPath = path.join(
1700
+ this.storageDir,
1701
+ `merge-report-${new Date().toISOString().replace(/[:.]/g, '-')}.json`,
1702
+ );
1703
+
1704
+ fs.writeFileSync(reportPath, JSON.stringify(report, null, 2));
1705
+
1706
+ // Also save latest
1707
+ const latestPath = path.join(this.storageDir, 'merge-report-latest.json');
1708
+ fs.writeFileSync(latestPath, JSON.stringify(report, null, 2));
1709
+ }
1710
+
1711
+ /**
1712
+ * Get AI resolver statistics
1713
+ */
1714
+ getAIStats() {
1715
+ return this.aiResolver.getStats();
1716
+ }
1717
+ }
1718
+
1719
+ // ============================================================================
1720
+ // EXPORTS
1721
+ // ============================================================================
1722
+
1723
+ module.exports = SemanticMergeEngine;
1724
+ module.exports.SemanticMergeEngine = SemanticMergeEngine;
1725
+ module.exports.SemanticAnalyzer = SemanticAnalyzer;
1726
+ module.exports.ConflictDetector = ConflictDetector;
1727
+ module.exports.AutoMerger = AutoMerger;
1728
+ module.exports.AIResolver = AIResolver;
1729
+ module.exports.CustomRulesLoader = CustomRulesLoader;
1730
+
1731
+ // Enums
1732
+ module.exports.ChangeType = ChangeType;
1733
+ module.exports.MergeStrategy = MergeStrategy;
1734
+ module.exports.ConflictSeverity = ConflictSeverity;
1735
+ module.exports.MergeDecision = MergeDecision;
1736
+