@claude-flow/cli 3.7.0-alpha.1 → 3.7.0-alpha.11

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 (476) hide show
  1. package/.claude/agents/analysis/analyze-code-quality.md +178 -178
  2. package/.claude/agents/analysis/code-analyzer.md +209 -209
  3. package/.claude/agents/analysis/code-review/analyze-code-quality.md +178 -178
  4. package/.claude/agents/architecture/arch-system-design.md +156 -156
  5. package/.claude/agents/architecture/system-design/arch-system-design.md +154 -154
  6. package/.claude/agents/browser/browser-agent.yaml +182 -182
  7. package/.claude/agents/consensus/byzantine-coordinator.md +62 -62
  8. package/.claude/agents/consensus/crdt-synchronizer.md +996 -996
  9. package/.claude/agents/consensus/gossip-coordinator.md +62 -62
  10. package/.claude/agents/consensus/performance-benchmarker.md +850 -850
  11. package/.claude/agents/consensus/quorum-manager.md +822 -822
  12. package/.claude/agents/consensus/raft-manager.md +62 -62
  13. package/.claude/agents/consensus/security-manager.md +621 -621
  14. package/.claude/agents/core/coder.md +452 -452
  15. package/.claude/agents/core/planner.md +374 -374
  16. package/.claude/agents/core/researcher.md +368 -368
  17. package/.claude/agents/core/reviewer.md +519 -519
  18. package/.claude/agents/core/tester.md +511 -511
  19. package/.claude/agents/custom/test-long-runner.md +44 -44
  20. package/.claude/agents/data/data-ml-model.md +444 -444
  21. package/.claude/agents/data/ml/data-ml-model.md +192 -192
  22. package/.claude/agents/development/backend/dev-backend-api.md +141 -141
  23. package/.claude/agents/development/dev-backend-api.md +344 -344
  24. package/.claude/agents/devops/ci-cd/ops-cicd-github.md +163 -163
  25. package/.claude/agents/devops/ops-cicd-github.md +164 -164
  26. package/.claude/agents/documentation/api-docs/docs-api-openapi.md +173 -173
  27. package/.claude/agents/documentation/docs-api-openapi.md +354 -354
  28. package/.claude/agents/flow-nexus/app-store.md +87 -87
  29. package/.claude/agents/flow-nexus/authentication.md +68 -68
  30. package/.claude/agents/flow-nexus/challenges.md +80 -80
  31. package/.claude/agents/flow-nexus/neural-network.md +87 -87
  32. package/.claude/agents/flow-nexus/payments.md +82 -82
  33. package/.claude/agents/flow-nexus/sandbox.md +75 -75
  34. package/.claude/agents/flow-nexus/swarm.md +75 -75
  35. package/.claude/agents/flow-nexus/user-tools.md +95 -95
  36. package/.claude/agents/flow-nexus/workflow.md +83 -83
  37. package/.claude/agents/github/code-review-swarm.md +377 -377
  38. package/.claude/agents/github/github-modes.md +172 -172
  39. package/.claude/agents/github/issue-tracker.md +575 -575
  40. package/.claude/agents/github/multi-repo-swarm.md +552 -552
  41. package/.claude/agents/github/pr-manager.md +437 -437
  42. package/.claude/agents/github/project-board-sync.md +508 -508
  43. package/.claude/agents/github/release-manager.md +604 -604
  44. package/.claude/agents/github/release-swarm.md +582 -582
  45. package/.claude/agents/github/repo-architect.md +397 -397
  46. package/.claude/agents/github/swarm-issue.md +572 -572
  47. package/.claude/agents/github/swarm-pr.md +427 -427
  48. package/.claude/agents/github/sync-coordinator.md +451 -451
  49. package/.claude/agents/github/workflow-automation.md +902 -902
  50. package/.claude/agents/goal/agent.md +815 -815
  51. package/.claude/agents/goal/goal-planner.md +72 -72
  52. package/.claude/agents/optimization/benchmark-suite.md +664 -664
  53. package/.claude/agents/optimization/load-balancer.md +430 -430
  54. package/.claude/agents/optimization/performance-monitor.md +671 -671
  55. package/.claude/agents/optimization/resource-allocator.md +673 -673
  56. package/.claude/agents/optimization/topology-optimizer.md +807 -807
  57. package/.claude/agents/payments/agentic-payments.md +126 -126
  58. package/.claude/agents/sona/sona-learning-optimizer.md +74 -74
  59. package/.claude/agents/sparc/architecture.md +698 -698
  60. package/.claude/agents/sparc/pseudocode.md +519 -519
  61. package/.claude/agents/sparc/refinement.md +801 -801
  62. package/.claude/agents/sparc/specification.md +477 -477
  63. package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +224 -224
  64. package/.claude/agents/specialized/spec-mobile-react-native.md +226 -226
  65. package/.claude/agents/sublinear/consensus-coordinator.md +337 -337
  66. package/.claude/agents/sublinear/matrix-optimizer.md +184 -184
  67. package/.claude/agents/sublinear/pagerank-analyzer.md +298 -298
  68. package/.claude/agents/sublinear/performance-optimizer.md +367 -367
  69. package/.claude/agents/sublinear/trading-predictor.md +245 -245
  70. package/.claude/agents/swarm/adaptive-coordinator.md +1126 -1126
  71. package/.claude/agents/swarm/hierarchical-coordinator.md +709 -709
  72. package/.claude/agents/swarm/mesh-coordinator.md +962 -962
  73. package/.claude/agents/templates/automation-smart-agent.md +204 -204
  74. package/.claude/agents/templates/base-template-generator.md +289 -289
  75. package/.claude/agents/templates/coordinator-swarm-init.md +89 -89
  76. package/.claude/agents/templates/github-pr-manager.md +176 -176
  77. package/.claude/agents/templates/implementer-sparc-coder.md +258 -258
  78. package/.claude/agents/templates/memory-coordinator.md +186 -186
  79. package/.claude/agents/templates/orchestrator-task.md +138 -138
  80. package/.claude/agents/templates/performance-analyzer.md +198 -198
  81. package/.claude/agents/templates/sparc-coordinator.md +513 -513
  82. package/.claude/agents/testing/production-validator.md +394 -394
  83. package/.claude/agents/testing/tdd-london-swarm.md +243 -243
  84. package/.claude/agents/v3/adr-architect.md +184 -184
  85. package/.claude/agents/v3/aidefence-guardian.md +282 -282
  86. package/.claude/agents/v3/claims-authorizer.md +208 -208
  87. package/.claude/agents/v3/collective-intelligence-coordinator.md +993 -993
  88. package/.claude/agents/v3/ddd-domain-expert.md +220 -220
  89. package/.claude/agents/v3/injection-analyst.md +236 -236
  90. package/.claude/agents/v3/memory-specialist.md +995 -995
  91. package/.claude/agents/v3/performance-engineer.md +1233 -1233
  92. package/.claude/agents/v3/pii-detector.md +151 -151
  93. package/.claude/agents/v3/reasoningbank-learner.md +213 -213
  94. package/.claude/agents/v3/security-architect-aidefence.md +410 -410
  95. package/.claude/agents/v3/security-architect.md +867 -867
  96. package/.claude/agents/v3/security-auditor.md +771 -771
  97. package/.claude/agents/v3/sparc-orchestrator.md +182 -182
  98. package/.claude/agents/v3/swarm-memory-manager.md +157 -157
  99. package/.claude/agents/v3/v3-integration-architect.md +205 -205
  100. package/.claude/commands/agents/README.md +50 -50
  101. package/.claude/commands/agents/agent-capabilities.md +140 -140
  102. package/.claude/commands/agents/agent-coordination.md +28 -28
  103. package/.claude/commands/agents/agent-spawning.md +28 -28
  104. package/.claude/commands/agents/agent-types.md +216 -216
  105. package/.claude/commands/agents/health.md +139 -139
  106. package/.claude/commands/agents/list.md +100 -100
  107. package/.claude/commands/agents/logs.md +130 -130
  108. package/.claude/commands/agents/metrics.md +122 -122
  109. package/.claude/commands/agents/pool.md +127 -127
  110. package/.claude/commands/agents/spawn.md +140 -140
  111. package/.claude/commands/agents/status.md +115 -115
  112. package/.claude/commands/agents/stop.md +102 -102
  113. package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +53 -53
  114. package/.claude/commands/analysis/README.md +9 -9
  115. package/.claude/commands/analysis/bottleneck-detect.md +162 -162
  116. package/.claude/commands/analysis/performance-bottlenecks.md +58 -58
  117. package/.claude/commands/analysis/performance-report.md +25 -25
  118. package/.claude/commands/analysis/token-efficiency.md +44 -44
  119. package/.claude/commands/analysis/token-usage.md +25 -25
  120. package/.claude/commands/automation/README.md +9 -9
  121. package/.claude/commands/automation/auto-agent.md +122 -122
  122. package/.claude/commands/automation/self-healing.md +105 -105
  123. package/.claude/commands/automation/session-memory.md +89 -89
  124. package/.claude/commands/automation/smart-agents.md +72 -72
  125. package/.claude/commands/automation/smart-spawn.md +25 -25
  126. package/.claude/commands/automation/workflow-select.md +25 -25
  127. package/.claude/commands/claude-flow-help.md +103 -103
  128. package/.claude/commands/claude-flow-memory.md +107 -107
  129. package/.claude/commands/claude-flow-swarm.md +205 -205
  130. package/.claude/commands/coordination/README.md +9 -9
  131. package/.claude/commands/coordination/agent-spawn.md +25 -25
  132. package/.claude/commands/coordination/init.md +44 -44
  133. package/.claude/commands/coordination/orchestrate.md +43 -43
  134. package/.claude/commands/coordination/spawn.md +45 -45
  135. package/.claude/commands/coordination/swarm-init.md +85 -85
  136. package/.claude/commands/coordination/task-orchestrate.md +25 -25
  137. package/.claude/commands/flow-nexus/app-store.md +123 -123
  138. package/.claude/commands/flow-nexus/challenges.md +119 -119
  139. package/.claude/commands/flow-nexus/login-registration.md +64 -64
  140. package/.claude/commands/flow-nexus/neural-network.md +133 -133
  141. package/.claude/commands/flow-nexus/payments.md +115 -115
  142. package/.claude/commands/flow-nexus/sandbox.md +82 -82
  143. package/.claude/commands/flow-nexus/swarm.md +86 -86
  144. package/.claude/commands/flow-nexus/user-tools.md +151 -151
  145. package/.claude/commands/flow-nexus/workflow.md +114 -114
  146. package/.claude/commands/github/README.md +11 -11
  147. package/.claude/commands/github/code-review-swarm.md +513 -513
  148. package/.claude/commands/github/code-review.md +25 -25
  149. package/.claude/commands/github/github-modes.md +146 -146
  150. package/.claude/commands/github/github-swarm.md +121 -121
  151. package/.claude/commands/github/issue-tracker.md +291 -291
  152. package/.claude/commands/github/issue-triage.md +25 -25
  153. package/.claude/commands/github/multi-repo-swarm.md +518 -518
  154. package/.claude/commands/github/pr-enhance.md +26 -26
  155. package/.claude/commands/github/pr-manager.md +169 -169
  156. package/.claude/commands/github/project-board-sync.md +470 -470
  157. package/.claude/commands/github/release-manager.md +337 -337
  158. package/.claude/commands/github/release-swarm.md +543 -543
  159. package/.claude/commands/github/repo-analyze.md +25 -25
  160. package/.claude/commands/github/repo-architect.md +366 -366
  161. package/.claude/commands/github/swarm-issue.md +481 -481
  162. package/.claude/commands/github/swarm-pr.md +284 -284
  163. package/.claude/commands/github/sync-coordinator.md +300 -300
  164. package/.claude/commands/github/workflow-automation.md +441 -441
  165. package/.claude/commands/hive-mind/README.md +17 -17
  166. package/.claude/commands/hive-mind/hive-mind-consensus.md +8 -8
  167. package/.claude/commands/hive-mind/hive-mind-init.md +18 -18
  168. package/.claude/commands/hive-mind/hive-mind-memory.md +8 -8
  169. package/.claude/commands/hive-mind/hive-mind-metrics.md +8 -8
  170. package/.claude/commands/hive-mind/hive-mind-resume.md +8 -8
  171. package/.claude/commands/hive-mind/hive-mind-sessions.md +8 -8
  172. package/.claude/commands/hive-mind/hive-mind-spawn.md +21 -21
  173. package/.claude/commands/hive-mind/hive-mind-status.md +8 -8
  174. package/.claude/commands/hive-mind/hive-mind-stop.md +8 -8
  175. package/.claude/commands/hive-mind/hive-mind-wizard.md +8 -8
  176. package/.claude/commands/hive-mind/hive-mind.md +27 -27
  177. package/.claude/commands/hooks/README.md +11 -11
  178. package/.claude/commands/hooks/overview.md +57 -57
  179. package/.claude/commands/hooks/post-edit.md +117 -117
  180. package/.claude/commands/hooks/post-task.md +112 -112
  181. package/.claude/commands/hooks/pre-edit.md +113 -113
  182. package/.claude/commands/hooks/pre-task.md +111 -111
  183. package/.claude/commands/hooks/session-end.md +118 -118
  184. package/.claude/commands/hooks/setup.md +102 -102
  185. package/.claude/commands/memory/README.md +9 -9
  186. package/.claude/commands/memory/memory-persist.md +25 -25
  187. package/.claude/commands/memory/memory-search.md +25 -25
  188. package/.claude/commands/memory/memory-usage.md +25 -25
  189. package/.claude/commands/memory/neural.md +47 -47
  190. package/.claude/commands/monitoring/README.md +9 -9
  191. package/.claude/commands/monitoring/agent-metrics.md +25 -25
  192. package/.claude/commands/monitoring/agents.md +44 -44
  193. package/.claude/commands/monitoring/real-time-view.md +25 -25
  194. package/.claude/commands/monitoring/status.md +46 -46
  195. package/.claude/commands/monitoring/swarm-monitor.md +25 -25
  196. package/.claude/commands/optimization/README.md +9 -9
  197. package/.claude/commands/optimization/auto-topology.md +61 -61
  198. package/.claude/commands/optimization/cache-manage.md +25 -25
  199. package/.claude/commands/optimization/parallel-execute.md +25 -25
  200. package/.claude/commands/optimization/parallel-execution.md +49 -49
  201. package/.claude/commands/optimization/topology-optimize.md +25 -25
  202. package/.claude/commands/pair/README.md +260 -260
  203. package/.claude/commands/pair/commands.md +545 -545
  204. package/.claude/commands/pair/config.md +509 -509
  205. package/.claude/commands/pair/examples.md +511 -511
  206. package/.claude/commands/pair/modes.md +347 -347
  207. package/.claude/commands/pair/session.md +406 -406
  208. package/.claude/commands/pair/start.md +208 -208
  209. package/.claude/commands/sparc/analyzer.md +51 -51
  210. package/.claude/commands/sparc/architect.md +53 -53
  211. package/.claude/commands/sparc/ask.md +97 -97
  212. package/.claude/commands/sparc/batch-executor.md +54 -54
  213. package/.claude/commands/sparc/code.md +89 -89
  214. package/.claude/commands/sparc/coder.md +54 -54
  215. package/.claude/commands/sparc/debug.md +83 -83
  216. package/.claude/commands/sparc/debugger.md +54 -54
  217. package/.claude/commands/sparc/designer.md +53 -53
  218. package/.claude/commands/sparc/devops.md +109 -109
  219. package/.claude/commands/sparc/docs-writer.md +80 -80
  220. package/.claude/commands/sparc/documenter.md +54 -54
  221. package/.claude/commands/sparc/innovator.md +54 -54
  222. package/.claude/commands/sparc/integration.md +83 -83
  223. package/.claude/commands/sparc/mcp.md +117 -117
  224. package/.claude/commands/sparc/memory-manager.md +54 -54
  225. package/.claude/commands/sparc/optimizer.md +54 -54
  226. package/.claude/commands/sparc/orchestrator.md +131 -131
  227. package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -83
  228. package/.claude/commands/sparc/refinement-optimization-mode.md +83 -83
  229. package/.claude/commands/sparc/researcher.md +54 -54
  230. package/.claude/commands/sparc/reviewer.md +54 -54
  231. package/.claude/commands/sparc/security-review.md +80 -80
  232. package/.claude/commands/sparc/sparc-modes.md +174 -174
  233. package/.claude/commands/sparc/sparc.md +111 -111
  234. package/.claude/commands/sparc/spec-pseudocode.md +80 -80
  235. package/.claude/commands/sparc/supabase-admin.md +348 -348
  236. package/.claude/commands/sparc/swarm-coordinator.md +54 -54
  237. package/.claude/commands/sparc/tdd.md +54 -54
  238. package/.claude/commands/sparc/tester.md +54 -54
  239. package/.claude/commands/sparc/tutorial.md +79 -79
  240. package/.claude/commands/sparc/workflow-manager.md +54 -54
  241. package/.claude/commands/sparc.md +166 -166
  242. package/.claude/commands/stream-chain/pipeline.md +120 -120
  243. package/.claude/commands/stream-chain/run.md +69 -69
  244. package/.claude/commands/swarm/README.md +15 -15
  245. package/.claude/commands/swarm/analysis.md +95 -95
  246. package/.claude/commands/swarm/development.md +96 -96
  247. package/.claude/commands/swarm/examples.md +168 -168
  248. package/.claude/commands/swarm/maintenance.md +102 -102
  249. package/.claude/commands/swarm/optimization.md +117 -117
  250. package/.claude/commands/swarm/research.md +136 -136
  251. package/.claude/commands/swarm/swarm-analysis.md +8 -8
  252. package/.claude/commands/swarm/swarm-background.md +8 -8
  253. package/.claude/commands/swarm/swarm-init.md +19 -19
  254. package/.claude/commands/swarm/swarm-modes.md +8 -8
  255. package/.claude/commands/swarm/swarm-monitor.md +8 -8
  256. package/.claude/commands/swarm/swarm-spawn.md +19 -19
  257. package/.claude/commands/swarm/swarm-status.md +8 -8
  258. package/.claude/commands/swarm/swarm-strategies.md +8 -8
  259. package/.claude/commands/swarm/swarm.md +87 -87
  260. package/.claude/commands/swarm/testing.md +131 -131
  261. package/.claude/commands/training/README.md +9 -9
  262. package/.claude/commands/training/model-update.md +25 -25
  263. package/.claude/commands/training/neural-patterns.md +107 -107
  264. package/.claude/commands/training/neural-train.md +75 -75
  265. package/.claude/commands/training/pattern-learn.md +25 -25
  266. package/.claude/commands/training/specialization.md +62 -62
  267. package/.claude/commands/truth/start.md +142 -142
  268. package/.claude/commands/verify/check.md +49 -49
  269. package/.claude/commands/verify/start.md +127 -127
  270. package/.claude/commands/workflows/README.md +9 -9
  271. package/.claude/commands/workflows/development.md +77 -77
  272. package/.claude/commands/workflows/research.md +62 -62
  273. package/.claude/commands/workflows/workflow-create.md +25 -25
  274. package/.claude/commands/workflows/workflow-execute.md +25 -25
  275. package/.claude/commands/workflows/workflow-export.md +25 -25
  276. package/.claude/helpers/README.md +96 -96
  277. package/.claude/helpers/adr-compliance.sh +186 -186
  278. package/.claude/helpers/auto-commit.sh +178 -178
  279. package/.claude/helpers/auto-memory-hook.mjs +368 -368
  280. package/.claude/helpers/checkpoint-manager.sh +251 -251
  281. package/.claude/helpers/daemon-manager.sh +252 -252
  282. package/.claude/helpers/ddd-tracker.sh +144 -144
  283. package/.claude/helpers/github-safe.js +121 -121
  284. package/.claude/helpers/github-setup.sh +28 -28
  285. package/.claude/helpers/guidance-hook.sh +13 -13
  286. package/.claude/helpers/guidance-hooks.sh +102 -102
  287. package/.claude/helpers/health-monitor.sh +108 -108
  288. package/.claude/helpers/hook-handler.cjs +278 -278
  289. package/.claude/helpers/intelligence.cjs +1031 -1031
  290. package/.claude/helpers/learning-hooks.sh +329 -329
  291. package/.claude/helpers/learning-optimizer.sh +127 -127
  292. package/.claude/helpers/learning-service.mjs +1144 -1144
  293. package/.claude/helpers/memory.js +83 -83
  294. package/.claude/helpers/metrics-db.mjs +488 -488
  295. package/.claude/helpers/pattern-consolidator.sh +86 -86
  296. package/.claude/helpers/perf-worker.sh +160 -160
  297. package/.claude/helpers/post-commit +16 -16
  298. package/.claude/helpers/pre-commit +26 -26
  299. package/.claude/helpers/quick-start.sh +19 -19
  300. package/.claude/helpers/router.js +66 -66
  301. package/.claude/helpers/security-scanner.sh +127 -127
  302. package/.claude/helpers/session.js +135 -135
  303. package/.claude/helpers/setup-mcp.sh +18 -18
  304. package/.claude/helpers/standard-checkpoint-hooks.sh +189 -189
  305. package/.claude/helpers/statusline-hook.sh +21 -21
  306. package/.claude/helpers/statusline.cjs +575 -575
  307. package/.claude/helpers/statusline.js +321 -321
  308. package/.claude/helpers/swarm-comms.sh +353 -353
  309. package/.claude/helpers/swarm-hooks.sh +761 -761
  310. package/.claude/helpers/swarm-monitor.sh +210 -210
  311. package/.claude/helpers/sync-v3-metrics.sh +245 -245
  312. package/.claude/helpers/update-v3-progress.sh +165 -165
  313. package/.claude/helpers/v3-quick-status.sh +57 -57
  314. package/.claude/helpers/v3.sh +110 -110
  315. package/.claude/helpers/validate-v3-config.sh +215 -215
  316. package/.claude/helpers/worker-manager.sh +170 -170
  317. package/.claude/settings.json +182 -182
  318. package/.claude/skills/agentdb-advanced/SKILL.md +550 -550
  319. package/.claude/skills/agentdb-learning/SKILL.md +545 -545
  320. package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -339
  321. package/.claude/skills/agentdb-optimization/SKILL.md +509 -509
  322. package/.claude/skills/agentdb-vector-search/SKILL.md +339 -339
  323. package/.claude/skills/agentic-jujutsu/SKILL.md +645 -645
  324. package/.claude/skills/aidefence-scan.md +151 -151
  325. package/.claude/skills/aidefence.yaml +297 -297
  326. package/.claude/skills/browser/SKILL.md +204 -204
  327. package/.claude/skills/flow-nexus-neural/SKILL.md +738 -738
  328. package/.claude/skills/flow-nexus-platform/SKILL.md +1157 -1157
  329. package/.claude/skills/flow-nexus-swarm/SKILL.md +610 -610
  330. package/.claude/skills/github-code-review/SKILL.md +1140 -1140
  331. package/.claude/skills/github-multi-repo/SKILL.md +874 -874
  332. package/.claude/skills/github-project-management/SKILL.md +1290 -1277
  333. package/.claude/skills/github-release-management/SKILL.md +1081 -1081
  334. package/.claude/skills/github-workflow-automation/SKILL.md +1065 -1065
  335. package/.claude/skills/hive-mind-advanced/SKILL.md +712 -712
  336. package/.claude/skills/hooks-automation/SKILL.md +1201 -1201
  337. package/.claude/skills/pair-programming/SKILL.md +1202 -1202
  338. package/.claude/skills/performance-analysis/SKILL.md +563 -563
  339. package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -446
  340. package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -201
  341. package/.claude/skills/secure-review.md +181 -181
  342. package/.claude/skills/skill-builder/SKILL.md +910 -910
  343. package/.claude/skills/sparc-methodology/SKILL.md +1115 -1115
  344. package/.claude/skills/stream-chain/SKILL.md +563 -563
  345. package/.claude/skills/swarm-advanced/SKILL.md +973 -973
  346. package/.claude/skills/swarm-orchestration/SKILL.md +179 -179
  347. package/.claude/skills/v3-cli-modernization/SKILL.md +871 -871
  348. package/.claude/skills/v3-core-implementation/SKILL.md +796 -796
  349. package/.claude/skills/v3-ddd-architecture/SKILL.md +441 -441
  350. package/.claude/skills/v3-integration-deep/SKILL.md +240 -240
  351. package/.claude/skills/v3-mcp-optimization/SKILL.md +776 -776
  352. package/.claude/skills/v3-memory-unification/SKILL.md +173 -173
  353. package/.claude/skills/v3-performance-optimization/SKILL.md +389 -389
  354. package/.claude/skills/v3-security-overhaul/SKILL.md +81 -81
  355. package/.claude/skills/v3-swarm-coordination/SKILL.md +339 -339
  356. package/.claude/skills/verification-quality/SKILL.md +649 -649
  357. package/.claude/skills/worker-benchmarks/skill.md +135 -135
  358. package/.claude/skills/worker-integration/skill.md +154 -154
  359. package/README.md +393 -391
  360. package/bin/cli.js +220 -220
  361. package/bin/mcp-server.js +224 -224
  362. package/bin/preinstall.cjs +2 -2
  363. package/dist/src/commands/agent-wasm.js +2 -2
  364. package/dist/src/commands/agent-wasm.js.map +1 -1
  365. package/dist/src/commands/completions.js +409 -409
  366. package/dist/src/commands/daemon.d.ts.map +1 -1
  367. package/dist/src/commands/daemon.js +19 -3
  368. package/dist/src/commands/daemon.js.map +1 -1
  369. package/dist/src/commands/doctor.d.ts.map +1 -1
  370. package/dist/src/commands/doctor.js +105 -23
  371. package/dist/src/commands/doctor.js.map +1 -1
  372. package/dist/src/commands/embeddings.js +26 -26
  373. package/dist/src/commands/hive-mind.d.ts.map +1 -1
  374. package/dist/src/commands/hive-mind.js +122 -104
  375. package/dist/src/commands/hive-mind.js.map +1 -1
  376. package/dist/src/commands/hooks.d.ts.map +1 -1
  377. package/dist/src/commands/hooks.js +34 -21
  378. package/dist/src/commands/hooks.js.map +1 -1
  379. package/dist/src/commands/memory.d.ts.map +1 -1
  380. package/dist/src/commands/memory.js +68 -0
  381. package/dist/src/commands/memory.js.map +1 -1
  382. package/dist/src/commands/ruvector/backup.js +23 -23
  383. package/dist/src/commands/ruvector/benchmark.js +31 -31
  384. package/dist/src/commands/ruvector/import.js +14 -14
  385. package/dist/src/commands/ruvector/init.js +115 -115
  386. package/dist/src/commands/ruvector/migrate.js +99 -99
  387. package/dist/src/commands/ruvector/optimize.js +51 -51
  388. package/dist/src/commands/ruvector/setup.js +624 -624
  389. package/dist/src/commands/ruvector/status.js +38 -38
  390. package/dist/src/index.d.ts +5 -1
  391. package/dist/src/index.d.ts.map +1 -1
  392. package/dist/src/index.js +59 -18
  393. package/dist/src/index.js.map +1 -1
  394. package/dist/src/init/claudemd-generator.js +226 -226
  395. package/dist/src/init/executor.d.ts.map +1 -1
  396. package/dist/src/init/executor.js +511 -453
  397. package/dist/src/init/executor.js.map +1 -1
  398. package/dist/src/init/helpers-generator.js +645 -645
  399. package/dist/src/init/settings-generator.d.ts.map +1 -1
  400. package/dist/src/init/settings-generator.js +11 -5
  401. package/dist/src/init/settings-generator.js.map +1 -1
  402. package/dist/src/init/statusline-generator.js +858 -858
  403. package/dist/src/init/types.d.ts +7 -0
  404. package/dist/src/init/types.d.ts.map +1 -1
  405. package/dist/src/init/types.js.map +1 -1
  406. package/dist/src/mcp-tools/agentdb-tools.d.ts +3 -0
  407. package/dist/src/mcp-tools/agentdb-tools.d.ts.map +1 -1
  408. package/dist/src/mcp-tools/agentdb-tools.js +108 -0
  409. package/dist/src/mcp-tools/agentdb-tools.js.map +1 -1
  410. package/dist/src/mcp-tools/hooks-tools.d.ts.map +1 -1
  411. package/dist/src/mcp-tools/hooks-tools.js +4 -2
  412. package/dist/src/mcp-tools/hooks-tools.js.map +1 -1
  413. package/dist/src/mcp-tools/memory-tools.d.ts.map +1 -1
  414. package/dist/src/mcp-tools/memory-tools.js +19 -0
  415. package/dist/src/mcp-tools/memory-tools.js.map +1 -1
  416. package/dist/src/mcp-tools/neural-tools.d.ts.map +1 -1
  417. package/dist/src/mcp-tools/neural-tools.js +14 -1
  418. package/dist/src/mcp-tools/neural-tools.js.map +1 -1
  419. package/dist/src/mcp-tools/security-tools.d.ts.map +1 -1
  420. package/dist/src/mcp-tools/security-tools.js +28 -3
  421. package/dist/src/mcp-tools/security-tools.js.map +1 -1
  422. package/dist/src/mcp-tools/swarm-tools.d.ts.map +1 -1
  423. package/dist/src/mcp-tools/swarm-tools.js +72 -3
  424. package/dist/src/mcp-tools/swarm-tools.js.map +1 -1
  425. package/dist/src/mcp-tools/wasm-agent-tools.js +1 -1
  426. package/dist/src/mcp-tools/wasm-agent-tools.js.map +1 -1
  427. package/dist/src/memory/intelligence.d.ts.map +1 -1
  428. package/dist/src/memory/intelligence.js +28 -3
  429. package/dist/src/memory/intelligence.js.map +1 -1
  430. package/dist/src/memory/memory-bridge.d.ts +69 -0
  431. package/dist/src/memory/memory-bridge.d.ts.map +1 -1
  432. package/dist/src/memory/memory-bridge.js +319 -66
  433. package/dist/src/memory/memory-bridge.js.map +1 -1
  434. package/dist/src/memory/memory-initializer.d.ts +5 -0
  435. package/dist/src/memory/memory-initializer.d.ts.map +1 -1
  436. package/dist/src/memory/memory-initializer.js +369 -363
  437. package/dist/src/memory/memory-initializer.js.map +1 -1
  438. package/dist/src/memory/neural-package-bridge.d.ts +48 -0
  439. package/dist/src/memory/neural-package-bridge.d.ts.map +1 -0
  440. package/dist/src/memory/neural-package-bridge.js +87 -0
  441. package/dist/src/memory/neural-package-bridge.js.map +1 -0
  442. package/dist/src/memory/rabitq-index.js +5 -5
  443. package/dist/src/memory/sona-optimizer.d.ts.map +1 -1
  444. package/dist/src/memory/sona-optimizer.js +1 -0
  445. package/dist/src/memory/sona-optimizer.js.map +1 -1
  446. package/dist/src/parser.d.ts +9 -0
  447. package/dist/src/parser.d.ts.map +1 -1
  448. package/dist/src/parser.js +11 -0
  449. package/dist/src/parser.js.map +1 -1
  450. package/dist/src/runtime/headless.js +28 -28
  451. package/dist/src/ruvector/agent-wasm.d.ts.map +1 -1
  452. package/dist/src/ruvector/agent-wasm.js +4 -1
  453. package/dist/src/ruvector/agent-wasm.js.map +1 -1
  454. package/dist/src/ruvector/index.d.ts +0 -2
  455. package/dist/src/ruvector/index.d.ts.map +1 -1
  456. package/dist/src/ruvector/index.js +8 -2
  457. package/dist/src/ruvector/index.js.map +1 -1
  458. package/dist/src/ruvector/model-router.d.ts +22 -1
  459. package/dist/src/ruvector/model-router.d.ts.map +1 -1
  460. package/dist/src/ruvector/model-router.js +125 -5
  461. package/dist/src/ruvector/model-router.js.map +1 -1
  462. package/dist/src/services/headless-worker-executor.js +84 -84
  463. package/dist/src/transfer/deploy-seraphine.js +23 -23
  464. package/dist/tsconfig.tsbuildinfo +1 -1
  465. package/package.json +5 -4
  466. package/scripts/deploy-ipfs-node.sh +153 -153
  467. package/scripts/postinstall.cjs +153 -153
  468. package/scripts/publish-registry.ts +345 -345
  469. package/scripts/publish.sh +57 -57
  470. package/scripts/setup-ipfs-registry.md +366 -366
  471. package/dist/src/services/event-stream.d.ts.map +0 -1
  472. package/dist/src/services/event-stream.js.map +0 -1
  473. package/dist/src/services/loop-worker-runner.d.ts.map +0 -1
  474. package/dist/src/services/loop-worker-runner.js.map +0 -1
  475. package/dist/src/services/runtime-capabilities.d.ts.map +0 -1
  476. package/dist/src/services/runtime-capabilities.js.map +0 -1
@@ -1,645 +1,645 @@
1
- ---
2
- name: agentic-jujutsu
3
- version: 2.3.2
4
- description: Quantum-resistant, self-learning version control for AI agents with ReasoningBank intelligence and multi-agent coordination
5
- ---
6
-
7
- # Agentic Jujutsu - AI Agent Version Control
8
-
9
- > Quantum-ready, self-learning version control designed for multiple AI agents working simultaneously without conflicts.
10
-
11
- ## When to Use This Skill
12
-
13
- Use **agentic-jujutsu** when you need:
14
- - ✅ Multiple AI agents modifying code simultaneously
15
- - ✅ Lock-free version control (23x faster than Git)
16
- - ✅ Self-learning AI that improves from experience
17
- - ✅ Quantum-resistant security for future-proof protection
18
- - ✅ Automatic conflict resolution (87% success rate)
19
- - ✅ Pattern recognition and intelligent suggestions
20
- - ✅ Multi-agent coordination without blocking
21
-
22
- ## Quick Start
23
-
24
- ### Installation
25
-
26
- ```bash
27
- npx agentic-jujutsu
28
- ```
29
-
30
- ### Basic Usage
31
-
32
- ```javascript
33
- const { JjWrapper } = require('agentic-jujutsu');
34
-
35
- const jj = new JjWrapper();
36
-
37
- // Basic operations
38
- await jj.status();
39
- await jj.newCommit('Add feature');
40
- await jj.log(10);
41
-
42
- // Self-learning trajectory
43
- const id = jj.startTrajectory('Implement authentication');
44
- await jj.branchCreate('feature/auth');
45
- await jj.newCommit('Add auth');
46
- jj.addToTrajectory();
47
- jj.finalizeTrajectory(0.9, 'Clean implementation');
48
-
49
- // Get AI suggestions
50
- const suggestion = JSON.parse(jj.getSuggestion('Add logout feature'));
51
- console.log(`Confidence: ${suggestion.confidence}`);
52
- ```
53
-
54
- ## Core Capabilities
55
-
56
- ### 1. Self-Learning with ReasoningBank
57
-
58
- Track operations, learn patterns, and get intelligent suggestions:
59
-
60
- ```javascript
61
- // Start learning trajectory
62
- const trajectoryId = jj.startTrajectory('Deploy to production');
63
-
64
- // Perform operations (automatically tracked)
65
- await jj.execute(['git', 'push', 'origin', 'main']);
66
- await jj.branchCreate('release/v1.0');
67
- await jj.newCommit('Release v1.0');
68
-
69
- // Record operations to trajectory
70
- jj.addToTrajectory();
71
-
72
- // Finalize with success score (0.0-1.0) and critique
73
- jj.finalizeTrajectory(0.95, 'Deployment successful, no issues');
74
-
75
- // Later: Get AI-powered suggestions for similar tasks
76
- const suggestion = JSON.parse(jj.getSuggestion('Deploy to staging'));
77
- console.log('AI Recommendation:', suggestion.reasoning);
78
- console.log('Confidence:', (suggestion.confidence * 100).toFixed(1) + '%');
79
- console.log('Expected Success:', (suggestion.expectedSuccessRate * 100).toFixed(1) + '%');
80
- ```
81
-
82
- **Validation (v2.3.1)**:
83
- - ✅ Tasks must be non-empty (max 10KB)
84
- - ✅ Success scores must be 0.0-1.0
85
- - ✅ Must have operations before finalizing
86
- - ✅ Contexts cannot be empty
87
-
88
- ### 2. Pattern Discovery
89
-
90
- Automatically identify successful operation sequences:
91
-
92
- ```javascript
93
- // Get discovered patterns
94
- const patterns = JSON.parse(jj.getPatterns());
95
-
96
- patterns.forEach(pattern => {
97
- console.log(`Pattern: ${pattern.name}`);
98
- console.log(` Success rate: ${(pattern.successRate * 100).toFixed(1)}%`);
99
- console.log(` Used ${pattern.observationCount} times`);
100
- console.log(` Operations: ${pattern.operationSequence.join(' → ')}`);
101
- console.log(` Confidence: ${(pattern.confidence * 100).toFixed(1)}%`);
102
- });
103
- ```
104
-
105
- ### 3. Learning Statistics
106
-
107
- Track improvement over time:
108
-
109
- ```javascript
110
- const stats = JSON.parse(jj.getLearningStats());
111
-
112
- console.log('Learning Progress:');
113
- console.log(` Total trajectories: ${stats.totalTrajectories}`);
114
- console.log(` Patterns discovered: ${stats.totalPatterns}`);
115
- console.log(` Average success: ${(stats.avgSuccessRate * 100).toFixed(1)}%`);
116
- console.log(` Improvement rate: ${(stats.improvementRate * 100).toFixed(1)}%`);
117
- console.log(` Prediction accuracy: ${(stats.predictionAccuracy * 100).toFixed(1)}%`);
118
- ```
119
-
120
- ### 4. Multi-Agent Coordination
121
-
122
- Multiple agents work concurrently without conflicts:
123
-
124
- ```javascript
125
- // Agent 1: Developer
126
- const dev = new JjWrapper();
127
- dev.startTrajectory('Implement feature');
128
- await dev.newCommit('Add feature X');
129
- dev.addToTrajectory();
130
- dev.finalizeTrajectory(0.85);
131
-
132
- // Agent 2: Reviewer (learns from Agent 1)
133
- const reviewer = new JjWrapper();
134
- const suggestion = JSON.parse(reviewer.getSuggestion('Review feature X'));
135
-
136
- if (suggestion.confidence > 0.7) {
137
- console.log('High confidence approach:', suggestion.reasoning);
138
- }
139
-
140
- // Agent 3: Tester (benefits from both)
141
- const tester = new JjWrapper();
142
- const similar = JSON.parse(tester.queryTrajectories('test feature', 5));
143
- console.log(`Found ${similar.length} similar test approaches`);
144
- ```
145
-
146
- ### 5. Quantum-Resistant Security (v2.3.0+)
147
-
148
- Fast integrity verification with quantum-resistant cryptography:
149
-
150
- ```javascript
151
- const { generateQuantumFingerprint, verifyQuantumFingerprint } = require('agentic-jujutsu');
152
-
153
- // Generate SHA3-512 fingerprint (NIST FIPS 202)
154
- const data = Buffer.from('commit-data');
155
- const fingerprint = generateQuantumFingerprint(data);
156
- console.log('Fingerprint:', fingerprint.toString('hex'));
157
-
158
- // Verify integrity (<1ms)
159
- const isValid = verifyQuantumFingerprint(data, fingerprint);
160
- console.log('Valid:', isValid);
161
-
162
- // HQC-128 encryption for trajectories
163
- const crypto = require('crypto');
164
- const key = crypto.randomBytes(32).toString('base64');
165
- jj.enableEncryption(key);
166
- ```
167
-
168
- ### 6. Operation Tracking with AgentDB
169
-
170
- Automatic tracking of all operations:
171
-
172
- ```javascript
173
- // Operations are tracked automatically
174
- await jj.status();
175
- await jj.newCommit('Fix bug');
176
- await jj.rebase('main');
177
-
178
- // Get operation statistics
179
- const stats = JSON.parse(jj.getStats());
180
- console.log(`Total operations: ${stats.total_operations}`);
181
- console.log(`Success rate: ${(stats.success_rate * 100).toFixed(1)}%`);
182
- console.log(`Avg duration: ${stats.avg_duration_ms.toFixed(2)}ms`);
183
-
184
- // Query recent operations
185
- const ops = jj.getOperations(10);
186
- ops.forEach(op => {
187
- console.log(`${op.operationType}: ${op.command}`);
188
- console.log(` Duration: ${op.durationMs}ms, Success: ${op.success}`);
189
- });
190
-
191
- // Get user operations (excludes snapshots)
192
- const userOps = jj.getUserOperations(20);
193
- ```
194
-
195
- ## Advanced Use Cases
196
-
197
- ### Use Case 1: Adaptive Workflow Optimization
198
-
199
- Learn and improve deployment workflows:
200
-
201
- ```javascript
202
- async function adaptiveDeployment(jj, environment) {
203
- // Get AI suggestion based on past deployments
204
- const suggestion = JSON.parse(jj.getSuggestion(`Deploy to ${environment}`));
205
-
206
- console.log(`Deploying with ${(suggestion.confidence * 100).toFixed(0)}% confidence`);
207
- console.log(`Expected duration: ${suggestion.estimatedDurationMs}ms`);
208
-
209
- // Start tracking
210
- jj.startTrajectory(`Deploy to ${environment}`);
211
-
212
- // Execute recommended operations
213
- for (const op of suggestion.recommendedOperations) {
214
- console.log(`Executing: ${op}`);
215
- await executeOperation(op);
216
- }
217
-
218
- jj.addToTrajectory();
219
-
220
- // Record outcome
221
- const success = await verifyDeployment();
222
- jj.finalizeTrajectory(
223
- success ? 0.95 : 0.5,
224
- success ? 'Deployment successful' : 'Issues detected'
225
- );
226
- }
227
- ```
228
-
229
- ### Use Case 2: Multi-Agent Code Review
230
-
231
- Coordinate review across multiple agents:
232
-
233
- ```javascript
234
- async function coordinatedReview(agents) {
235
- const reviews = await Promise.all(agents.map(async (agent) => {
236
- const jj = new JjWrapper();
237
-
238
- // Start review trajectory
239
- jj.startTrajectory(`Review by ${agent.name}`);
240
-
241
- // Get AI suggestion for review approach
242
- const suggestion = JSON.parse(jj.getSuggestion('Code review'));
243
-
244
- // Perform review
245
- const diff = await jj.diff('@', '@-');
246
- const issues = await agent.analyze(diff);
247
-
248
- jj.addToTrajectory();
249
- jj.finalizeTrajectory(
250
- issues.length === 0 ? 0.9 : 0.6,
251
- `Found ${issues.length} issues`
252
- );
253
-
254
- return { agent: agent.name, issues, suggestion };
255
- }));
256
-
257
- // Aggregate learning from all agents
258
- return reviews;
259
- }
260
- ```
261
-
262
- ### Use Case 3: Error Pattern Detection
263
-
264
- Learn from failures to prevent future issues:
265
-
266
- ```javascript
267
- async function smartMerge(jj, branch) {
268
- // Query similar merge attempts
269
- const similar = JSON.parse(jj.queryTrajectories(`merge ${branch}`, 10));
270
-
271
- // Analyze past failures
272
- const failures = similar.filter(t => t.successScore < 0.5);
273
-
274
- if (failures.length > 0) {
275
- console.log('⚠️ Similar merges failed in the past:');
276
- failures.forEach(f => {
277
- if (f.critique) {
278
- console.log(` - ${f.critique}`);
279
- }
280
- });
281
- }
282
-
283
- // Get AI recommendation
284
- const suggestion = JSON.parse(jj.getSuggestion(`merge ${branch}`));
285
-
286
- if (suggestion.confidence < 0.7) {
287
- console.log('⚠️ Low confidence. Recommended steps:');
288
- suggestion.recommendedOperations.forEach(op => console.log(` - ${op}`));
289
- }
290
-
291
- // Execute merge with tracking
292
- jj.startTrajectory(`Merge ${branch}`);
293
- try {
294
- await jj.execute(['merge', branch]);
295
- jj.addToTrajectory();
296
- jj.finalizeTrajectory(0.9, 'Merge successful');
297
- } catch (err) {
298
- jj.addToTrajectory();
299
- jj.finalizeTrajectory(0.3, `Merge failed: ${err.message}`);
300
- throw err;
301
- }
302
- }
303
- ```
304
-
305
- ### Use Case 4: Continuous Learning Loop
306
-
307
- Implement a self-improving agent:
308
-
309
- ```javascript
310
- class SelfImprovingAgent {
311
- constructor() {
312
- this.jj = new JjWrapper();
313
- }
314
-
315
- async performTask(taskDescription) {
316
- // Get AI suggestion
317
- const suggestion = JSON.parse(this.jj.getSuggestion(taskDescription));
318
-
319
- console.log(`Task: ${taskDescription}`);
320
- console.log(`AI Confidence: ${(suggestion.confidence * 100).toFixed(1)}%`);
321
- console.log(`Expected Success: ${(suggestion.expectedSuccessRate * 100).toFixed(1)}%`);
322
-
323
- // Start trajectory
324
- this.jj.startTrajectory(taskDescription);
325
-
326
- // Execute with recommended approach
327
- const startTime = Date.now();
328
- let success = false;
329
-
330
- try {
331
- for (const op of suggestion.recommendedOperations) {
332
- await this.execute(op);
333
- }
334
- success = true;
335
- } catch (err) {
336
- console.error('Task failed:', err.message);
337
- }
338
-
339
- const duration = Date.now() - startTime;
340
-
341
- // Record learning
342
- this.jj.addToTrajectory();
343
- this.jj.finalizeTrajectory(
344
- success ? 0.9 : 0.4,
345
- success
346
- ? `Completed in ${duration}ms using ${suggestion.recommendedOperations.length} operations`
347
- : `Failed after ${duration}ms`
348
- );
349
-
350
- // Check improvement
351
- const stats = JSON.parse(this.jj.getLearningStats());
352
- console.log(`Improvement rate: ${(stats.improvementRate * 100).toFixed(1)}%`);
353
-
354
- return success;
355
- }
356
-
357
- async execute(operation) {
358
- // Execute operation logic
359
- }
360
- }
361
-
362
- // Usage
363
- const agent = new SelfImprovingAgent();
364
-
365
- // Agent improves over time
366
- for (let i = 1; i <= 10; i++) {
367
- console.log(`\n--- Attempt ${i} ---`);
368
- await agent.performTask('Deploy application');
369
- }
370
- ```
371
-
372
- ## API Reference
373
-
374
- ### Core Methods
375
-
376
- | Method | Description | Returns |
377
- |--------|-------------|---------|
378
- | `new JjWrapper()` | Create wrapper instance | JjWrapper |
379
- | `status()` | Get repository status | Promise<JjResult> |
380
- | `newCommit(msg)` | Create new commit | Promise<JjResult> |
381
- | `log(limit)` | Show commit history | Promise<JjCommit[]> |
382
- | `diff(from, to)` | Show differences | Promise<JjDiff> |
383
- | `branchCreate(name, rev?)` | Create branch | Promise<JjResult> |
384
- | `rebase(source, dest)` | Rebase commits | Promise<JjResult> |
385
-
386
- ### ReasoningBank Methods
387
-
388
- | Method | Description | Returns |
389
- |--------|-------------|---------|
390
- | `startTrajectory(task)` | Begin learning trajectory | string (trajectory ID) |
391
- | `addToTrajectory()` | Add recent operations | void |
392
- | `finalizeTrajectory(score, critique?)` | Complete trajectory (score: 0.0-1.0) | void |
393
- | `getSuggestion(task)` | Get AI recommendation | JSON: DecisionSuggestion |
394
- | `getLearningStats()` | Get learning metrics | JSON: LearningStats |
395
- | `getPatterns()` | Get discovered patterns | JSON: Pattern[] |
396
- | `queryTrajectories(task, limit)` | Find similar trajectories | JSON: Trajectory[] |
397
- | `resetLearning()` | Clear learned data | void |
398
-
399
- ### AgentDB Methods
400
-
401
- | Method | Description | Returns |
402
- |--------|-------------|---------|
403
- | `getStats()` | Get operation statistics | JSON: Stats |
404
- | `getOperations(limit)` | Get recent operations | JjOperation[] |
405
- | `getUserOperations(limit)` | Get user operations only | JjOperation[] |
406
- | `clearLog()` | Clear operation log | void |
407
-
408
- ### Quantum Security Methods (v2.3.0+)
409
-
410
- | Method | Description | Returns |
411
- |--------|-------------|---------|
412
- | `generateQuantumFingerprint(data)` | Generate SHA3-512 fingerprint | Buffer (64 bytes) |
413
- | `verifyQuantumFingerprint(data, fp)` | Verify fingerprint | boolean |
414
- | `enableEncryption(key, pubKey?)` | Enable HQC-128 encryption | void |
415
- | `disableEncryption()` | Disable encryption | void |
416
- | `isEncryptionEnabled()` | Check encryption status | boolean |
417
-
418
- ## Performance Characteristics
419
-
420
- | Metric | Git | Agentic Jujutsu |
421
- |--------|-----|-----------------|
422
- | Concurrent commits | 15 ops/s | 350 ops/s (23x) |
423
- | Context switching | 500-1000ms | 50-100ms (10x) |
424
- | Conflict resolution | 30-40% auto | 87% auto (2.5x) |
425
- | Lock waiting | 50 min/day | 0 min (∞) |
426
- | Quantum fingerprints | N/A | <1ms |
427
-
428
- ## Best Practices
429
-
430
- ### 1. Trajectory Management
431
-
432
- ```javascript
433
- // ✅ Good: Meaningful task descriptions
434
- jj.startTrajectory('Implement user authentication with JWT');
435
-
436
- // ❌ Bad: Vague descriptions
437
- jj.startTrajectory('fix stuff');
438
-
439
- // ✅ Good: Honest success scores
440
- jj.finalizeTrajectory(0.7, 'Works but needs refactoring');
441
-
442
- // ❌ Bad: Always 1.0
443
- jj.finalizeTrajectory(1.0, 'Perfect!'); // Prevents learning
444
- ```
445
-
446
- ### 2. Pattern Recognition
447
-
448
- ```javascript
449
- // ✅ Good: Let patterns emerge naturally
450
- for (let i = 0; i < 10; i++) {
451
- jj.startTrajectory('Deploy feature');
452
- await deploy();
453
- jj.addToTrajectory();
454
- jj.finalizeTrajectory(wasSuccessful ? 0.9 : 0.5);
455
- }
456
-
457
- // ❌ Bad: Not recording outcomes
458
- await deploy(); // No learning
459
- ```
460
-
461
- ### 3. Multi-Agent Coordination
462
-
463
- ```javascript
464
- // ✅ Good: Concurrent operations
465
- const agents = ['agent1', 'agent2', 'agent3'];
466
- await Promise.all(agents.map(async (agent) => {
467
- const jj = new JjWrapper();
468
- // Each agent works independently
469
- await jj.newCommit(`Changes by ${agent}`);
470
- }));
471
-
472
- // ❌ Bad: Sequential with locks
473
- for (const agent of agents) {
474
- await agent.waitForLock(); // Not needed!
475
- await agent.commit();
476
- }
477
- ```
478
-
479
- ### 4. Error Handling
480
-
481
- ```javascript
482
- // ✅ Good: Record failures with details
483
- try {
484
- await jj.execute(['complex-operation']);
485
- jj.finalizeTrajectory(0.9);
486
- } catch (err) {
487
- jj.finalizeTrajectory(0.3, `Failed: ${err.message}. Root cause: ...`);
488
- }
489
-
490
- // ❌ Bad: Silent failures
491
- try {
492
- await jj.execute(['operation']);
493
- } catch (err) {
494
- // No learning from failure
495
- }
496
- ```
497
-
498
- ## Validation Rules (v2.3.1+)
499
-
500
- ### Task Description
501
- - ✅ Cannot be empty or whitespace-only
502
- - ✅ Maximum length: 10,000 bytes
503
- - ✅ Automatically trimmed
504
-
505
- ### Success Score
506
- - ✅ Must be finite (not NaN or Infinity)
507
- - ✅ Must be between 0.0 and 1.0 (inclusive)
508
-
509
- ### Operations
510
- - ✅ Must have at least one operation before finalizing
511
-
512
- ### Context
513
- - ✅ Cannot be empty
514
- - ✅ Keys cannot be empty or whitespace-only
515
- - ✅ Keys max 1,000 bytes, values max 10,000 bytes
516
-
517
- ## Troubleshooting
518
-
519
- ### Issue: Low Confidence Suggestions
520
-
521
- ```javascript
522
- const suggestion = JSON.parse(jj.getSuggestion('new task'));
523
-
524
- if (suggestion.confidence < 0.5) {
525
- // Not enough data - check learning stats
526
- const stats = JSON.parse(jj.getLearningStats());
527
- console.log(`Need more data. Current trajectories: ${stats.totalTrajectories}`);
528
-
529
- // Recommend: Record 5-10 trajectories first
530
- }
531
- ```
532
-
533
- ### Issue: Validation Errors
534
-
535
- ```javascript
536
- try {
537
- jj.startTrajectory(''); // Empty task
538
- } catch (err) {
539
- if (err.message.includes('Validation error')) {
540
- console.log('Invalid input:', err.message);
541
- // Use non-empty, meaningful task description
542
- }
543
- }
544
-
545
- try {
546
- jj.finalizeTrajectory(1.5); // Score > 1.0
547
- } catch (err) {
548
- // Use score between 0.0 and 1.0
549
- jj.finalizeTrajectory(Math.max(0, Math.min(1, score)));
550
- }
551
- ```
552
-
553
- ### Issue: No Patterns Discovered
554
-
555
- ```javascript
556
- const patterns = JSON.parse(jj.getPatterns());
557
-
558
- if (patterns.length === 0) {
559
- // Need more trajectories with >70% success
560
- // Record at least 3-5 successful trajectories
561
- }
562
- ```
563
-
564
- ## Examples
565
-
566
- ### Example 1: Simple Learning Workflow
567
-
568
- ```javascript
569
- const { JjWrapper } = require('agentic-jujutsu');
570
-
571
- async function learnFromWork() {
572
- const jj = new JjWrapper();
573
-
574
- // Start tracking
575
- jj.startTrajectory('Add user profile feature');
576
-
577
- // Do work
578
- await jj.branchCreate('feature/user-profile');
579
- await jj.newCommit('Add user profile model');
580
- await jj.newCommit('Add profile API endpoints');
581
- await jj.newCommit('Add profile UI');
582
-
583
- // Record operations
584
- jj.addToTrajectory();
585
-
586
- // Finalize with result
587
- jj.finalizeTrajectory(0.85, 'Feature complete, minor styling issues remain');
588
-
589
- // Next time, get suggestions
590
- const suggestion = JSON.parse(jj.getSuggestion('Add settings page'));
591
- console.log('AI suggests:', suggestion.reasoning);
592
- }
593
- ```
594
-
595
- ### Example 2: Multi-Agent Swarm
596
-
597
- ```javascript
598
- async function agentSwarm(taskList) {
599
- const agents = taskList.map((task, i) => ({
600
- name: `agent-${i}`,
601
- jj: new JjWrapper(),
602
- task
603
- }));
604
-
605
- // All agents work concurrently (no conflicts!)
606
- const results = await Promise.all(agents.map(async (agent) => {
607
- agent.jj.startTrajectory(agent.task);
608
-
609
- // Get AI suggestion
610
- const suggestion = JSON.parse(agent.jj.getSuggestion(agent.task));
611
-
612
- // Execute task
613
- const success = await executeTask(agent, suggestion);
614
-
615
- agent.jj.addToTrajectory();
616
- agent.jj.finalizeTrajectory(success ? 0.9 : 0.5);
617
-
618
- return { agent: agent.name, success };
619
- }));
620
-
621
- console.log('Results:', results);
622
- }
623
- ```
624
-
625
- ## Related Documentation
626
-
627
- - **NPM Package**: https://npmjs.com/package/agentic-jujutsu
628
- - **GitHub**: https://github.com/ruvnet/agentic-flow/tree/main/packages/agentic-jujutsu
629
- - **Full README**: See package README.md
630
- - **Validation Guide**: docs/VALIDATION_FIXES_v2.3.1.md
631
- - **AgentDB Guide**: docs/AGENTDB_GUIDE.md
632
-
633
- ## Version History
634
-
635
- - **v2.3.2** - Documentation updates
636
- - **v2.3.1** - Validation fixes for ReasoningBank
637
- - **v2.3.0** - Quantum-resistant security with @qudag/napi-core
638
- - **v2.1.0** - Self-learning AI with ReasoningBank
639
- - **v2.0.0** - Zero-dependency installation with embedded jj binary
640
-
641
- ---
642
-
643
- **Status**: ✅ Production Ready
644
- **License**: MIT
645
- **Maintained**: Active
1
+ ---
2
+ name: agentic-jujutsu
3
+ version: 2.3.2
4
+ description: Quantum-resistant, self-learning version control for AI agents with ReasoningBank intelligence and multi-agent coordination
5
+ ---
6
+
7
+ # Agentic Jujutsu - AI Agent Version Control
8
+
9
+ > Quantum-ready, self-learning version control designed for multiple AI agents working simultaneously without conflicts.
10
+
11
+ ## When to Use This Skill
12
+
13
+ Use **agentic-jujutsu** when you need:
14
+ - ✅ Multiple AI agents modifying code simultaneously
15
+ - ✅ Lock-free version control (23x faster than Git)
16
+ - ✅ Self-learning AI that improves from experience
17
+ - ✅ Quantum-resistant security for future-proof protection
18
+ - ✅ Automatic conflict resolution (87% success rate)
19
+ - ✅ Pattern recognition and intelligent suggestions
20
+ - ✅ Multi-agent coordination without blocking
21
+
22
+ ## Quick Start
23
+
24
+ ### Installation
25
+
26
+ ```bash
27
+ npx agentic-jujutsu
28
+ ```
29
+
30
+ ### Basic Usage
31
+
32
+ ```javascript
33
+ const { JjWrapper } = require('agentic-jujutsu');
34
+
35
+ const jj = new JjWrapper();
36
+
37
+ // Basic operations
38
+ await jj.status();
39
+ await jj.newCommit('Add feature');
40
+ await jj.log(10);
41
+
42
+ // Self-learning trajectory
43
+ const id = jj.startTrajectory('Implement authentication');
44
+ await jj.branchCreate('feature/auth');
45
+ await jj.newCommit('Add auth');
46
+ jj.addToTrajectory();
47
+ jj.finalizeTrajectory(0.9, 'Clean implementation');
48
+
49
+ // Get AI suggestions
50
+ const suggestion = JSON.parse(jj.getSuggestion('Add logout feature'));
51
+ console.log(`Confidence: ${suggestion.confidence}`);
52
+ ```
53
+
54
+ ## Core Capabilities
55
+
56
+ ### 1. Self-Learning with ReasoningBank
57
+
58
+ Track operations, learn patterns, and get intelligent suggestions:
59
+
60
+ ```javascript
61
+ // Start learning trajectory
62
+ const trajectoryId = jj.startTrajectory('Deploy to production');
63
+
64
+ // Perform operations (automatically tracked)
65
+ await jj.execute(['git', 'push', 'origin', 'main']);
66
+ await jj.branchCreate('release/v1.0');
67
+ await jj.newCommit('Release v1.0');
68
+
69
+ // Record operations to trajectory
70
+ jj.addToTrajectory();
71
+
72
+ // Finalize with success score (0.0-1.0) and critique
73
+ jj.finalizeTrajectory(0.95, 'Deployment successful, no issues');
74
+
75
+ // Later: Get AI-powered suggestions for similar tasks
76
+ const suggestion = JSON.parse(jj.getSuggestion('Deploy to staging'));
77
+ console.log('AI Recommendation:', suggestion.reasoning);
78
+ console.log('Confidence:', (suggestion.confidence * 100).toFixed(1) + '%');
79
+ console.log('Expected Success:', (suggestion.expectedSuccessRate * 100).toFixed(1) + '%');
80
+ ```
81
+
82
+ **Validation (v2.3.1)**:
83
+ - ✅ Tasks must be non-empty (max 10KB)
84
+ - ✅ Success scores must be 0.0-1.0
85
+ - ✅ Must have operations before finalizing
86
+ - ✅ Contexts cannot be empty
87
+
88
+ ### 2. Pattern Discovery
89
+
90
+ Automatically identify successful operation sequences:
91
+
92
+ ```javascript
93
+ // Get discovered patterns
94
+ const patterns = JSON.parse(jj.getPatterns());
95
+
96
+ patterns.forEach(pattern => {
97
+ console.log(`Pattern: ${pattern.name}`);
98
+ console.log(` Success rate: ${(pattern.successRate * 100).toFixed(1)}%`);
99
+ console.log(` Used ${pattern.observationCount} times`);
100
+ console.log(` Operations: ${pattern.operationSequence.join(' → ')}`);
101
+ console.log(` Confidence: ${(pattern.confidence * 100).toFixed(1)}%`);
102
+ });
103
+ ```
104
+
105
+ ### 3. Learning Statistics
106
+
107
+ Track improvement over time:
108
+
109
+ ```javascript
110
+ const stats = JSON.parse(jj.getLearningStats());
111
+
112
+ console.log('Learning Progress:');
113
+ console.log(` Total trajectories: ${stats.totalTrajectories}`);
114
+ console.log(` Patterns discovered: ${stats.totalPatterns}`);
115
+ console.log(` Average success: ${(stats.avgSuccessRate * 100).toFixed(1)}%`);
116
+ console.log(` Improvement rate: ${(stats.improvementRate * 100).toFixed(1)}%`);
117
+ console.log(` Prediction accuracy: ${(stats.predictionAccuracy * 100).toFixed(1)}%`);
118
+ ```
119
+
120
+ ### 4. Multi-Agent Coordination
121
+
122
+ Multiple agents work concurrently without conflicts:
123
+
124
+ ```javascript
125
+ // Agent 1: Developer
126
+ const dev = new JjWrapper();
127
+ dev.startTrajectory('Implement feature');
128
+ await dev.newCommit('Add feature X');
129
+ dev.addToTrajectory();
130
+ dev.finalizeTrajectory(0.85);
131
+
132
+ // Agent 2: Reviewer (learns from Agent 1)
133
+ const reviewer = new JjWrapper();
134
+ const suggestion = JSON.parse(reviewer.getSuggestion('Review feature X'));
135
+
136
+ if (suggestion.confidence > 0.7) {
137
+ console.log('High confidence approach:', suggestion.reasoning);
138
+ }
139
+
140
+ // Agent 3: Tester (benefits from both)
141
+ const tester = new JjWrapper();
142
+ const similar = JSON.parse(tester.queryTrajectories('test feature', 5));
143
+ console.log(`Found ${similar.length} similar test approaches`);
144
+ ```
145
+
146
+ ### 5. Quantum-Resistant Security (v2.3.0+)
147
+
148
+ Fast integrity verification with quantum-resistant cryptography:
149
+
150
+ ```javascript
151
+ const { generateQuantumFingerprint, verifyQuantumFingerprint } = require('agentic-jujutsu');
152
+
153
+ // Generate SHA3-512 fingerprint (NIST FIPS 202)
154
+ const data = Buffer.from('commit-data');
155
+ const fingerprint = generateQuantumFingerprint(data);
156
+ console.log('Fingerprint:', fingerprint.toString('hex'));
157
+
158
+ // Verify integrity (<1ms)
159
+ const isValid = verifyQuantumFingerprint(data, fingerprint);
160
+ console.log('Valid:', isValid);
161
+
162
+ // HQC-128 encryption for trajectories
163
+ const crypto = require('crypto');
164
+ const key = crypto.randomBytes(32).toString('base64');
165
+ jj.enableEncryption(key);
166
+ ```
167
+
168
+ ### 6. Operation Tracking with AgentDB
169
+
170
+ Automatic tracking of all operations:
171
+
172
+ ```javascript
173
+ // Operations are tracked automatically
174
+ await jj.status();
175
+ await jj.newCommit('Fix bug');
176
+ await jj.rebase('main');
177
+
178
+ // Get operation statistics
179
+ const stats = JSON.parse(jj.getStats());
180
+ console.log(`Total operations: ${stats.total_operations}`);
181
+ console.log(`Success rate: ${(stats.success_rate * 100).toFixed(1)}%`);
182
+ console.log(`Avg duration: ${stats.avg_duration_ms.toFixed(2)}ms`);
183
+
184
+ // Query recent operations
185
+ const ops = jj.getOperations(10);
186
+ ops.forEach(op => {
187
+ console.log(`${op.operationType}: ${op.command}`);
188
+ console.log(` Duration: ${op.durationMs}ms, Success: ${op.success}`);
189
+ });
190
+
191
+ // Get user operations (excludes snapshots)
192
+ const userOps = jj.getUserOperations(20);
193
+ ```
194
+
195
+ ## Advanced Use Cases
196
+
197
+ ### Use Case 1: Adaptive Workflow Optimization
198
+
199
+ Learn and improve deployment workflows:
200
+
201
+ ```javascript
202
+ async function adaptiveDeployment(jj, environment) {
203
+ // Get AI suggestion based on past deployments
204
+ const suggestion = JSON.parse(jj.getSuggestion(`Deploy to ${environment}`));
205
+
206
+ console.log(`Deploying with ${(suggestion.confidence * 100).toFixed(0)}% confidence`);
207
+ console.log(`Expected duration: ${suggestion.estimatedDurationMs}ms`);
208
+
209
+ // Start tracking
210
+ jj.startTrajectory(`Deploy to ${environment}`);
211
+
212
+ // Execute recommended operations
213
+ for (const op of suggestion.recommendedOperations) {
214
+ console.log(`Executing: ${op}`);
215
+ await executeOperation(op);
216
+ }
217
+
218
+ jj.addToTrajectory();
219
+
220
+ // Record outcome
221
+ const success = await verifyDeployment();
222
+ jj.finalizeTrajectory(
223
+ success ? 0.95 : 0.5,
224
+ success ? 'Deployment successful' : 'Issues detected'
225
+ );
226
+ }
227
+ ```
228
+
229
+ ### Use Case 2: Multi-Agent Code Review
230
+
231
+ Coordinate review across multiple agents:
232
+
233
+ ```javascript
234
+ async function coordinatedReview(agents) {
235
+ const reviews = await Promise.all(agents.map(async (agent) => {
236
+ const jj = new JjWrapper();
237
+
238
+ // Start review trajectory
239
+ jj.startTrajectory(`Review by ${agent.name}`);
240
+
241
+ // Get AI suggestion for review approach
242
+ const suggestion = JSON.parse(jj.getSuggestion('Code review'));
243
+
244
+ // Perform review
245
+ const diff = await jj.diff('@', '@-');
246
+ const issues = await agent.analyze(diff);
247
+
248
+ jj.addToTrajectory();
249
+ jj.finalizeTrajectory(
250
+ issues.length === 0 ? 0.9 : 0.6,
251
+ `Found ${issues.length} issues`
252
+ );
253
+
254
+ return { agent: agent.name, issues, suggestion };
255
+ }));
256
+
257
+ // Aggregate learning from all agents
258
+ return reviews;
259
+ }
260
+ ```
261
+
262
+ ### Use Case 3: Error Pattern Detection
263
+
264
+ Learn from failures to prevent future issues:
265
+
266
+ ```javascript
267
+ async function smartMerge(jj, branch) {
268
+ // Query similar merge attempts
269
+ const similar = JSON.parse(jj.queryTrajectories(`merge ${branch}`, 10));
270
+
271
+ // Analyze past failures
272
+ const failures = similar.filter(t => t.successScore < 0.5);
273
+
274
+ if (failures.length > 0) {
275
+ console.log('⚠️ Similar merges failed in the past:');
276
+ failures.forEach(f => {
277
+ if (f.critique) {
278
+ console.log(` - ${f.critique}`);
279
+ }
280
+ });
281
+ }
282
+
283
+ // Get AI recommendation
284
+ const suggestion = JSON.parse(jj.getSuggestion(`merge ${branch}`));
285
+
286
+ if (suggestion.confidence < 0.7) {
287
+ console.log('⚠️ Low confidence. Recommended steps:');
288
+ suggestion.recommendedOperations.forEach(op => console.log(` - ${op}`));
289
+ }
290
+
291
+ // Execute merge with tracking
292
+ jj.startTrajectory(`Merge ${branch}`);
293
+ try {
294
+ await jj.execute(['merge', branch]);
295
+ jj.addToTrajectory();
296
+ jj.finalizeTrajectory(0.9, 'Merge successful');
297
+ } catch (err) {
298
+ jj.addToTrajectory();
299
+ jj.finalizeTrajectory(0.3, `Merge failed: ${err.message}`);
300
+ throw err;
301
+ }
302
+ }
303
+ ```
304
+
305
+ ### Use Case 4: Continuous Learning Loop
306
+
307
+ Implement a self-improving agent:
308
+
309
+ ```javascript
310
+ class SelfImprovingAgent {
311
+ constructor() {
312
+ this.jj = new JjWrapper();
313
+ }
314
+
315
+ async performTask(taskDescription) {
316
+ // Get AI suggestion
317
+ const suggestion = JSON.parse(this.jj.getSuggestion(taskDescription));
318
+
319
+ console.log(`Task: ${taskDescription}`);
320
+ console.log(`AI Confidence: ${(suggestion.confidence * 100).toFixed(1)}%`);
321
+ console.log(`Expected Success: ${(suggestion.expectedSuccessRate * 100).toFixed(1)}%`);
322
+
323
+ // Start trajectory
324
+ this.jj.startTrajectory(taskDescription);
325
+
326
+ // Execute with recommended approach
327
+ const startTime = Date.now();
328
+ let success = false;
329
+
330
+ try {
331
+ for (const op of suggestion.recommendedOperations) {
332
+ await this.execute(op);
333
+ }
334
+ success = true;
335
+ } catch (err) {
336
+ console.error('Task failed:', err.message);
337
+ }
338
+
339
+ const duration = Date.now() - startTime;
340
+
341
+ // Record learning
342
+ this.jj.addToTrajectory();
343
+ this.jj.finalizeTrajectory(
344
+ success ? 0.9 : 0.4,
345
+ success
346
+ ? `Completed in ${duration}ms using ${suggestion.recommendedOperations.length} operations`
347
+ : `Failed after ${duration}ms`
348
+ );
349
+
350
+ // Check improvement
351
+ const stats = JSON.parse(this.jj.getLearningStats());
352
+ console.log(`Improvement rate: ${(stats.improvementRate * 100).toFixed(1)}%`);
353
+
354
+ return success;
355
+ }
356
+
357
+ async execute(operation) {
358
+ // Execute operation logic
359
+ }
360
+ }
361
+
362
+ // Usage
363
+ const agent = new SelfImprovingAgent();
364
+
365
+ // Agent improves over time
366
+ for (let i = 1; i <= 10; i++) {
367
+ console.log(`\n--- Attempt ${i} ---`);
368
+ await agent.performTask('Deploy application');
369
+ }
370
+ ```
371
+
372
+ ## API Reference
373
+
374
+ ### Core Methods
375
+
376
+ | Method | Description | Returns |
377
+ |--------|-------------|---------|
378
+ | `new JjWrapper()` | Create wrapper instance | JjWrapper |
379
+ | `status()` | Get repository status | Promise<JjResult> |
380
+ | `newCommit(msg)` | Create new commit | Promise<JjResult> |
381
+ | `log(limit)` | Show commit history | Promise<JjCommit[]> |
382
+ | `diff(from, to)` | Show differences | Promise<JjDiff> |
383
+ | `branchCreate(name, rev?)` | Create branch | Promise<JjResult> |
384
+ | `rebase(source, dest)` | Rebase commits | Promise<JjResult> |
385
+
386
+ ### ReasoningBank Methods
387
+
388
+ | Method | Description | Returns |
389
+ |--------|-------------|---------|
390
+ | `startTrajectory(task)` | Begin learning trajectory | string (trajectory ID) |
391
+ | `addToTrajectory()` | Add recent operations | void |
392
+ | `finalizeTrajectory(score, critique?)` | Complete trajectory (score: 0.0-1.0) | void |
393
+ | `getSuggestion(task)` | Get AI recommendation | JSON: DecisionSuggestion |
394
+ | `getLearningStats()` | Get learning metrics | JSON: LearningStats |
395
+ | `getPatterns()` | Get discovered patterns | JSON: Pattern[] |
396
+ | `queryTrajectories(task, limit)` | Find similar trajectories | JSON: Trajectory[] |
397
+ | `resetLearning()` | Clear learned data | void |
398
+
399
+ ### AgentDB Methods
400
+
401
+ | Method | Description | Returns |
402
+ |--------|-------------|---------|
403
+ | `getStats()` | Get operation statistics | JSON: Stats |
404
+ | `getOperations(limit)` | Get recent operations | JjOperation[] |
405
+ | `getUserOperations(limit)` | Get user operations only | JjOperation[] |
406
+ | `clearLog()` | Clear operation log | void |
407
+
408
+ ### Quantum Security Methods (v2.3.0+)
409
+
410
+ | Method | Description | Returns |
411
+ |--------|-------------|---------|
412
+ | `generateQuantumFingerprint(data)` | Generate SHA3-512 fingerprint | Buffer (64 bytes) |
413
+ | `verifyQuantumFingerprint(data, fp)` | Verify fingerprint | boolean |
414
+ | `enableEncryption(key, pubKey?)` | Enable HQC-128 encryption | void |
415
+ | `disableEncryption()` | Disable encryption | void |
416
+ | `isEncryptionEnabled()` | Check encryption status | boolean |
417
+
418
+ ## Performance Characteristics
419
+
420
+ | Metric | Git | Agentic Jujutsu |
421
+ |--------|-----|-----------------|
422
+ | Concurrent commits | 15 ops/s | 350 ops/s (23x) |
423
+ | Context switching | 500-1000ms | 50-100ms (10x) |
424
+ | Conflict resolution | 30-40% auto | 87% auto (2.5x) |
425
+ | Lock waiting | 50 min/day | 0 min (∞) |
426
+ | Quantum fingerprints | N/A | <1ms |
427
+
428
+ ## Best Practices
429
+
430
+ ### 1. Trajectory Management
431
+
432
+ ```javascript
433
+ // ✅ Good: Meaningful task descriptions
434
+ jj.startTrajectory('Implement user authentication with JWT');
435
+
436
+ // ❌ Bad: Vague descriptions
437
+ jj.startTrajectory('fix stuff');
438
+
439
+ // ✅ Good: Honest success scores
440
+ jj.finalizeTrajectory(0.7, 'Works but needs refactoring');
441
+
442
+ // ❌ Bad: Always 1.0
443
+ jj.finalizeTrajectory(1.0, 'Perfect!'); // Prevents learning
444
+ ```
445
+
446
+ ### 2. Pattern Recognition
447
+
448
+ ```javascript
449
+ // ✅ Good: Let patterns emerge naturally
450
+ for (let i = 0; i < 10; i++) {
451
+ jj.startTrajectory('Deploy feature');
452
+ await deploy();
453
+ jj.addToTrajectory();
454
+ jj.finalizeTrajectory(wasSuccessful ? 0.9 : 0.5);
455
+ }
456
+
457
+ // ❌ Bad: Not recording outcomes
458
+ await deploy(); // No learning
459
+ ```
460
+
461
+ ### 3. Multi-Agent Coordination
462
+
463
+ ```javascript
464
+ // ✅ Good: Concurrent operations
465
+ const agents = ['agent1', 'agent2', 'agent3'];
466
+ await Promise.all(agents.map(async (agent) => {
467
+ const jj = new JjWrapper();
468
+ // Each agent works independently
469
+ await jj.newCommit(`Changes by ${agent}`);
470
+ }));
471
+
472
+ // ❌ Bad: Sequential with locks
473
+ for (const agent of agents) {
474
+ await agent.waitForLock(); // Not needed!
475
+ await agent.commit();
476
+ }
477
+ ```
478
+
479
+ ### 4. Error Handling
480
+
481
+ ```javascript
482
+ // ✅ Good: Record failures with details
483
+ try {
484
+ await jj.execute(['complex-operation']);
485
+ jj.finalizeTrajectory(0.9);
486
+ } catch (err) {
487
+ jj.finalizeTrajectory(0.3, `Failed: ${err.message}. Root cause: ...`);
488
+ }
489
+
490
+ // ❌ Bad: Silent failures
491
+ try {
492
+ await jj.execute(['operation']);
493
+ } catch (err) {
494
+ // No learning from failure
495
+ }
496
+ ```
497
+
498
+ ## Validation Rules (v2.3.1+)
499
+
500
+ ### Task Description
501
+ - ✅ Cannot be empty or whitespace-only
502
+ - ✅ Maximum length: 10,000 bytes
503
+ - ✅ Automatically trimmed
504
+
505
+ ### Success Score
506
+ - ✅ Must be finite (not NaN or Infinity)
507
+ - ✅ Must be between 0.0 and 1.0 (inclusive)
508
+
509
+ ### Operations
510
+ - ✅ Must have at least one operation before finalizing
511
+
512
+ ### Context
513
+ - ✅ Cannot be empty
514
+ - ✅ Keys cannot be empty or whitespace-only
515
+ - ✅ Keys max 1,000 bytes, values max 10,000 bytes
516
+
517
+ ## Troubleshooting
518
+
519
+ ### Issue: Low Confidence Suggestions
520
+
521
+ ```javascript
522
+ const suggestion = JSON.parse(jj.getSuggestion('new task'));
523
+
524
+ if (suggestion.confidence < 0.5) {
525
+ // Not enough data - check learning stats
526
+ const stats = JSON.parse(jj.getLearningStats());
527
+ console.log(`Need more data. Current trajectories: ${stats.totalTrajectories}`);
528
+
529
+ // Recommend: Record 5-10 trajectories first
530
+ }
531
+ ```
532
+
533
+ ### Issue: Validation Errors
534
+
535
+ ```javascript
536
+ try {
537
+ jj.startTrajectory(''); // Empty task
538
+ } catch (err) {
539
+ if (err.message.includes('Validation error')) {
540
+ console.log('Invalid input:', err.message);
541
+ // Use non-empty, meaningful task description
542
+ }
543
+ }
544
+
545
+ try {
546
+ jj.finalizeTrajectory(1.5); // Score > 1.0
547
+ } catch (err) {
548
+ // Use score between 0.0 and 1.0
549
+ jj.finalizeTrajectory(Math.max(0, Math.min(1, score)));
550
+ }
551
+ ```
552
+
553
+ ### Issue: No Patterns Discovered
554
+
555
+ ```javascript
556
+ const patterns = JSON.parse(jj.getPatterns());
557
+
558
+ if (patterns.length === 0) {
559
+ // Need more trajectories with >70% success
560
+ // Record at least 3-5 successful trajectories
561
+ }
562
+ ```
563
+
564
+ ## Examples
565
+
566
+ ### Example 1: Simple Learning Workflow
567
+
568
+ ```javascript
569
+ const { JjWrapper } = require('agentic-jujutsu');
570
+
571
+ async function learnFromWork() {
572
+ const jj = new JjWrapper();
573
+
574
+ // Start tracking
575
+ jj.startTrajectory('Add user profile feature');
576
+
577
+ // Do work
578
+ await jj.branchCreate('feature/user-profile');
579
+ await jj.newCommit('Add user profile model');
580
+ await jj.newCommit('Add profile API endpoints');
581
+ await jj.newCommit('Add profile UI');
582
+
583
+ // Record operations
584
+ jj.addToTrajectory();
585
+
586
+ // Finalize with result
587
+ jj.finalizeTrajectory(0.85, 'Feature complete, minor styling issues remain');
588
+
589
+ // Next time, get suggestions
590
+ const suggestion = JSON.parse(jj.getSuggestion('Add settings page'));
591
+ console.log('AI suggests:', suggestion.reasoning);
592
+ }
593
+ ```
594
+
595
+ ### Example 2: Multi-Agent Swarm
596
+
597
+ ```javascript
598
+ async function agentSwarm(taskList) {
599
+ const agents = taskList.map((task, i) => ({
600
+ name: `agent-${i}`,
601
+ jj: new JjWrapper(),
602
+ task
603
+ }));
604
+
605
+ // All agents work concurrently (no conflicts!)
606
+ const results = await Promise.all(agents.map(async (agent) => {
607
+ agent.jj.startTrajectory(agent.task);
608
+
609
+ // Get AI suggestion
610
+ const suggestion = JSON.parse(agent.jj.getSuggestion(agent.task));
611
+
612
+ // Execute task
613
+ const success = await executeTask(agent, suggestion);
614
+
615
+ agent.jj.addToTrajectory();
616
+ agent.jj.finalizeTrajectory(success ? 0.9 : 0.5);
617
+
618
+ return { agent: agent.name, success };
619
+ }));
620
+
621
+ console.log('Results:', results);
622
+ }
623
+ ```
624
+
625
+ ## Related Documentation
626
+
627
+ - **NPM Package**: https://npmjs.com/package/agentic-jujutsu
628
+ - **GitHub**: https://github.com/ruvnet/agentic-flow/tree/main/packages/agentic-jujutsu
629
+ - **Full README**: See package README.md
630
+ - **Validation Guide**: docs/VALIDATION_FIXES_v2.3.1.md
631
+ - **AgentDB Guide**: docs/AGENTDB_GUIDE.md
632
+
633
+ ## Version History
634
+
635
+ - **v2.3.2** - Documentation updates
636
+ - **v2.3.1** - Validation fixes for ReasoningBank
637
+ - **v2.3.0** - Quantum-resistant security with @qudag/napi-core
638
+ - **v2.1.0** - Self-learning AI with ReasoningBank
639
+ - **v2.0.0** - Zero-dependency installation with embedded jj binary
640
+
641
+ ---
642
+
643
+ **Status**: ✅ Production Ready
644
+ **License**: MIT
645
+ **Maintained**: Active