@stackmemoryai/stackmemory 0.2.9 → 0.3.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 (575) hide show
  1. package/dist/agents/core/agent-task-manager.js +512 -0
  2. package/dist/agents/core/agent-task-manager.js.map +7 -0
  3. package/dist/agents/verifiers/base-verifier.js +129 -0
  4. package/dist/agents/verifiers/base-verifier.js.map +7 -0
  5. package/dist/agents/verifiers/formatter-verifier.js +126 -0
  6. package/dist/agents/verifiers/formatter-verifier.js.map +7 -0
  7. package/dist/agents/verifiers/llm-judge.js +248 -0
  8. package/dist/agents/verifiers/llm-judge.js.map +7 -0
  9. package/dist/cli/__tests__/index.test.js +290 -0
  10. package/dist/cli/__tests__/index.test.js.map +7 -0
  11. package/dist/cli/auto-detect.js +317 -0
  12. package/dist/cli/auto-detect.js.map +7 -0
  13. package/dist/cli/browser-test.js +29 -0
  14. package/dist/cli/browser-test.js.map +7 -0
  15. package/dist/cli/claude-sm.js +369 -0
  16. package/dist/cli/claude-sm.js.map +7 -0
  17. package/dist/cli/codex-sm.js +283 -0
  18. package/dist/cli/codex-sm.js.map +7 -0
  19. package/dist/cli/commands/agent.js +286 -0
  20. package/dist/cli/commands/agent.js.map +7 -0
  21. package/dist/cli/commands/config.js +199 -0
  22. package/dist/cli/commands/config.js.map +7 -0
  23. package/dist/cli/commands/context.js +327 -0
  24. package/dist/cli/commands/context.js.map +7 -0
  25. package/dist/cli/commands/handoff.js +191 -0
  26. package/dist/cli/commands/handoff.js.map +7 -0
  27. package/dist/cli/commands/linear-test.js +115 -0
  28. package/dist/cli/commands/linear-test.js.map +7 -0
  29. package/dist/cli/commands/linear.js +378 -0
  30. package/dist/cli/commands/linear.js.map +7 -0
  31. package/dist/cli/commands/log.js +165 -0
  32. package/dist/cli/commands/log.js.map +7 -0
  33. package/dist/cli/commands/onboard.js +349 -0
  34. package/dist/cli/commands/onboard.js.map +7 -0
  35. package/dist/cli/commands/projects.js +195 -0
  36. package/dist/cli/commands/projects.js.map +7 -0
  37. package/dist/cli/commands/search.js +152 -0
  38. package/dist/cli/commands/search.js.map +7 -0
  39. package/dist/cli/commands/session.js +179 -0
  40. package/dist/cli/commands/session.js.map +7 -0
  41. package/dist/cli/commands/tasks.js +205 -0
  42. package/dist/cli/commands/tasks.js.map +7 -0
  43. package/dist/cli/commands/webhook.js +131 -0
  44. package/dist/cli/commands/webhook.js.map +7 -0
  45. package/dist/cli/commands/worktree.js +276 -0
  46. package/dist/cli/commands/worktree.js.map +7 -0
  47. package/dist/cli/index.js +953 -0
  48. package/dist/cli/index.js.map +7 -0
  49. package/dist/cli/utils/viewer.js +92 -0
  50. package/dist/cli/utils/viewer.js.map +7 -0
  51. package/dist/core/config/__tests__/config-manager.test.js +248 -0
  52. package/dist/core/config/__tests__/config-manager.test.js.map +7 -0
  53. package/dist/core/config/config-manager.js +368 -0
  54. package/dist/core/config/config-manager.js.map +7 -0
  55. package/dist/core/config/types.js +140 -0
  56. package/dist/core/config/types.js.map +7 -0
  57. package/dist/core/context/__tests__/frame-manager.test.js +879 -0
  58. package/dist/core/context/__tests__/frame-manager.test.js.map +7 -0
  59. package/dist/core/context/auto-context.js +72 -0
  60. package/dist/core/context/auto-context.js.map +7 -0
  61. package/dist/core/context/compaction-handler.js +326 -0
  62. package/dist/core/context/compaction-handler.js.map +7 -0
  63. package/dist/core/context/frame-database.js +376 -0
  64. package/dist/core/context/frame-database.js.map +7 -0
  65. package/dist/core/context/frame-digest.js +239 -0
  66. package/dist/core/context/frame-digest.js.map +7 -0
  67. package/dist/core/context/frame-manager.js +682 -0
  68. package/dist/core/context/frame-manager.js.map +7 -0
  69. package/dist/core/context/frame-stack.js +270 -0
  70. package/dist/core/context/frame-stack.js.map +7 -0
  71. package/dist/core/context/frame-types.js +1 -0
  72. package/dist/core/context/frame-types.js.map +7 -0
  73. package/dist/core/context/index.js +33 -0
  74. package/dist/core/context/index.js.map +7 -0
  75. package/dist/core/context/model-aware-compaction.js +619 -0
  76. package/dist/core/context/model-aware-compaction.js.map +7 -0
  77. package/dist/core/context/refactored-frame-manager.js +393 -0
  78. package/dist/core/context/refactored-frame-manager.js.map +7 -0
  79. package/dist/core/database/batch-operations.js +329 -0
  80. package/dist/core/database/batch-operations.js.map +7 -0
  81. package/dist/core/database/connection-pool.js +224 -0
  82. package/dist/core/database/connection-pool.js.map +7 -0
  83. package/dist/core/database/query-cache.js +284 -0
  84. package/dist/core/database/query-cache.js.map +7 -0
  85. package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js +379 -0
  86. package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js.map +7 -0
  87. package/dist/core/digest/__tests__/frame-digest-integration.test.js +230 -0
  88. package/dist/core/digest/__tests__/frame-digest-integration.test.js.map +7 -0
  89. package/dist/core/digest/enhanced-hybrid-digest.js +267 -0
  90. package/dist/core/digest/enhanced-hybrid-digest.js.map +7 -0
  91. package/dist/core/digest/frame-digest-integration.js +172 -0
  92. package/dist/core/digest/frame-digest-integration.js.map +7 -0
  93. package/dist/core/digest/hybrid-digest-generator.js +549 -0
  94. package/dist/core/digest/hybrid-digest-generator.js.map +7 -0
  95. package/dist/core/digest/index.js +5 -0
  96. package/dist/core/digest/index.js.map +7 -0
  97. package/dist/core/digest/types.js +21 -0
  98. package/dist/core/digest/types.js.map +7 -0
  99. package/dist/core/errors/__tests__/error-handling.test.js +270 -0
  100. package/dist/core/errors/__tests__/error-handling.test.js.map +7 -0
  101. package/dist/core/errors/index.js +239 -0
  102. package/dist/core/errors/index.js.map +7 -0
  103. package/dist/core/errors/recovery.js +258 -0
  104. package/dist/core/errors/recovery.js.map +7 -0
  105. package/dist/core/merge/__tests__/conflict-scenarios.test.js +414 -0
  106. package/dist/core/merge/__tests__/conflict-scenarios.test.js.map +7 -0
  107. package/dist/core/merge/conflict-detector.js +424 -0
  108. package/dist/core/merge/conflict-detector.js.map +7 -0
  109. package/dist/core/merge/index.js +5 -0
  110. package/dist/core/merge/index.js.map +7 -0
  111. package/dist/core/merge/resolution-engine.js +565 -0
  112. package/dist/core/merge/resolution-engine.js.map +7 -0
  113. package/dist/core/merge/stack-diff.js +528 -0
  114. package/dist/core/merge/stack-diff.js.map +7 -0
  115. package/dist/core/merge/types.js +1 -0
  116. package/dist/core/merge/types.js.map +7 -0
  117. package/dist/core/monitoring/error-handler.js +278 -0
  118. package/dist/core/monitoring/error-handler.js.map +7 -0
  119. package/dist/core/monitoring/logger.js +115 -0
  120. package/dist/core/monitoring/logger.js.map +7 -0
  121. package/dist/core/monitoring/metrics.js +157 -0
  122. package/dist/core/monitoring/metrics.js.map +7 -0
  123. package/dist/core/monitoring/progress-tracker.js +174 -0
  124. package/dist/core/monitoring/progress-tracker.js.map +7 -0
  125. package/dist/core/performance/context-cache.js +269 -0
  126. package/dist/core/performance/context-cache.js.map +7 -0
  127. package/dist/core/performance/index.js +7 -0
  128. package/dist/core/performance/index.js.map +7 -0
  129. package/dist/core/performance/lazy-context-loader.js +319 -0
  130. package/dist/core/performance/lazy-context-loader.js.map +7 -0
  131. package/dist/core/performance/monitor.js +217 -0
  132. package/dist/core/performance/monitor.js.map +7 -0
  133. package/dist/core/performance/optimized-frame-context.js +326 -0
  134. package/dist/core/performance/optimized-frame-context.js.map +7 -0
  135. package/dist/core/performance/performance-benchmark.js +269 -0
  136. package/dist/core/performance/performance-benchmark.js.map +7 -0
  137. package/dist/core/performance/performance-profiler.js +318 -0
  138. package/dist/core/performance/performance-profiler.js.map +7 -0
  139. package/dist/core/performance/streaming-jsonl-parser.js +187 -0
  140. package/dist/core/performance/streaming-jsonl-parser.js.map +7 -0
  141. package/dist/core/persistence/postgres-adapter.js +345 -0
  142. package/dist/core/persistence/postgres-adapter.js.map +7 -0
  143. package/dist/core/projects/project-manager.js +699 -0
  144. package/dist/core/projects/project-manager.js.map +7 -0
  145. package/dist/core/query/__tests__/query-parser.test.js +301 -0
  146. package/dist/core/query/__tests__/query-parser.test.js.map +7 -0
  147. package/dist/core/query/__tests__/query-templates.test.js +210 -0
  148. package/dist/core/query/__tests__/query-templates.test.js.map +7 -0
  149. package/dist/core/query/query-parser.js +366 -0
  150. package/dist/core/query/query-parser.js.map +7 -0
  151. package/dist/core/query/query-templates.js +317 -0
  152. package/dist/core/query/query-templates.js.map +7 -0
  153. package/dist/core/retrieval/index.js +4 -0
  154. package/dist/core/retrieval/index.js.map +7 -0
  155. package/dist/core/retrieval/llm-context-retrieval.js +577 -0
  156. package/dist/core/retrieval/llm-context-retrieval.js.map +7 -0
  157. package/dist/core/retrieval/summary-generator.js +585 -0
  158. package/dist/core/retrieval/summary-generator.js.map +7 -0
  159. package/dist/core/retrieval/types.js +17 -0
  160. package/dist/core/retrieval/types.js.map +7 -0
  161. package/dist/core/session/index.js +11 -0
  162. package/dist/core/session/index.js.map +7 -0
  163. package/dist/core/session/session-manager.js +297 -0
  164. package/dist/core/session/session-manager.js.map +7 -0
  165. package/dist/core/trace/cli-trace-wrapper.js +110 -0
  166. package/dist/core/trace/cli-trace-wrapper.js.map +7 -0
  167. package/dist/core/trace/db-trace-wrapper.js +215 -0
  168. package/dist/core/trace/db-trace-wrapper.js.map +7 -0
  169. package/dist/core/trace/debug-trace.js +385 -0
  170. package/dist/core/trace/debug-trace.js.map +7 -0
  171. package/dist/core/trace/index.js +158 -0
  172. package/dist/core/trace/index.js.map +7 -0
  173. package/dist/core/trace/linear-api-wrapper.js +169 -0
  174. package/dist/core/trace/linear-api-wrapper.js.map +7 -0
  175. package/dist/core/trace/trace-demo.js +135 -0
  176. package/dist/core/trace/trace-demo.js.map +7 -0
  177. package/dist/core/trace/trace-detector.demo.js +138 -0
  178. package/dist/core/trace/trace-detector.demo.js.map +7 -0
  179. package/dist/core/trace/trace-detector.js +386 -0
  180. package/dist/core/trace/trace-detector.js.map +7 -0
  181. package/dist/core/trace/trace-detector.test.js +401 -0
  182. package/dist/core/trace/trace-detector.test.js.map +7 -0
  183. package/dist/core/trace/trace-store.js +341 -0
  184. package/dist/core/trace/trace-store.js.map +7 -0
  185. package/dist/core/trace/types.js +73 -0
  186. package/dist/core/trace/types.js.map +7 -0
  187. package/dist/core/types.js +1 -0
  188. package/dist/core/types.js.map +7 -0
  189. package/dist/core/utils/update-checker.js +214 -0
  190. package/dist/core/utils/update-checker.js.map +7 -0
  191. package/dist/core/worktree/worktree-manager.js +450 -0
  192. package/dist/core/worktree/worktree-manager.js.map +7 -0
  193. package/dist/features/analytics/api/analytics-api.js +283 -0
  194. package/dist/features/analytics/api/analytics-api.js.map +7 -0
  195. package/dist/features/analytics/core/analytics-service.js +267 -0
  196. package/dist/features/analytics/core/analytics-service.js.map +7 -0
  197. package/dist/features/analytics/index.js +14 -0
  198. package/dist/features/analytics/index.js.map +7 -0
  199. package/dist/features/analytics/queries/metrics-queries.js +273 -0
  200. package/dist/features/analytics/queries/metrics-queries.js.map +7 -0
  201. package/dist/features/analytics/types/metrics.js +1 -0
  202. package/dist/features/analytics/types/metrics.js.map +7 -0
  203. package/dist/features/browser/browser-mcp.js +488 -0
  204. package/dist/features/browser/browser-mcp.js.map +7 -0
  205. package/dist/features/tasks/__tests__/pebbles-task-store.test.js +747 -0
  206. package/dist/features/tasks/__tests__/pebbles-task-store.test.js.map +7 -0
  207. package/dist/features/tasks/pebbles-task-store.js +647 -0
  208. package/dist/features/tasks/pebbles-task-store.js.map +7 -0
  209. package/dist/features/tasks/task-aware-context.js +406 -0
  210. package/dist/features/tasks/task-aware-context.js.map +7 -0
  211. package/dist/index.js +21 -0
  212. package/dist/index.js.map +7 -0
  213. package/dist/integrations/linear/__tests__/auth.test.js +558 -0
  214. package/dist/integrations/linear/__tests__/auth.test.js.map +7 -0
  215. package/dist/integrations/linear/__tests__/sync-service.test.js +760 -0
  216. package/dist/integrations/linear/__tests__/sync-service.test.js.map +7 -0
  217. package/dist/integrations/linear/auth.js +308 -0
  218. package/dist/integrations/linear/auth.js.map +7 -0
  219. package/dist/integrations/linear/auto-sync.js +244 -0
  220. package/dist/integrations/linear/auto-sync.js.map +7 -0
  221. package/dist/integrations/linear/client.js +448 -0
  222. package/dist/integrations/linear/client.js.map +7 -0
  223. package/dist/integrations/linear/config.js +115 -0
  224. package/dist/integrations/linear/config.js.map +7 -0
  225. package/dist/integrations/linear/sync-manager.js +233 -0
  226. package/dist/integrations/linear/sync-manager.js.map +7 -0
  227. package/dist/integrations/linear/sync-service.js +214 -0
  228. package/dist/integrations/linear/sync-service.js.map +7 -0
  229. package/dist/integrations/linear/sync.js +565 -0
  230. package/dist/integrations/linear/sync.js.map +7 -0
  231. package/dist/integrations/linear/types.js +1 -0
  232. package/dist/integrations/linear/types.js.map +7 -0
  233. package/dist/integrations/linear/webhook-server.js +204 -0
  234. package/dist/integrations/linear/webhook-server.js.map +7 -0
  235. package/dist/integrations/linear/webhook.js +269 -0
  236. package/dist/integrations/linear/webhook.js.map +7 -0
  237. package/dist/integrations/mcp/__tests__/server.test.js +798 -0
  238. package/dist/integrations/mcp/__tests__/server.test.js.map +7 -0
  239. package/dist/integrations/mcp/handlers/context-handlers.js +253 -0
  240. package/dist/integrations/mcp/handlers/context-handlers.js.map +7 -0
  241. package/dist/integrations/mcp/handlers/index.js +134 -0
  242. package/dist/integrations/mcp/handlers/index.js.map +7 -0
  243. package/dist/integrations/mcp/handlers/linear-handlers.js +243 -0
  244. package/dist/integrations/mcp/handlers/linear-handlers.js.map +7 -0
  245. package/dist/integrations/mcp/handlers/task-handlers.js +235 -0
  246. package/dist/integrations/mcp/handlers/task-handlers.js.map +7 -0
  247. package/dist/integrations/mcp/handlers/trace-handlers.js +304 -0
  248. package/dist/integrations/mcp/handlers/trace-handlers.js.map +7 -0
  249. package/dist/integrations/mcp/index.js +19 -0
  250. package/dist/integrations/mcp/index.js.map +7 -0
  251. package/dist/integrations/mcp/refactored-server.js +331 -0
  252. package/dist/integrations/mcp/refactored-server.js.map +7 -0
  253. package/dist/integrations/mcp/server.js +1621 -0
  254. package/dist/integrations/mcp/server.js.map +7 -0
  255. package/dist/integrations/mcp/tool-definitions.js +562 -0
  256. package/dist/integrations/mcp/tool-definitions.js.map +7 -0
  257. package/dist/integrations/mcp/trace-test.js +44 -0
  258. package/dist/integrations/mcp/trace-test.js.map +7 -0
  259. package/dist/integrations/pg-aiguide/embedding-provider.js +174 -0
  260. package/dist/integrations/pg-aiguide/embedding-provider.js.map +7 -0
  261. package/dist/integrations/pg-aiguide/semantic-search.js +183 -0
  262. package/dist/integrations/pg-aiguide/semantic-search.js.map +7 -0
  263. package/dist/integrations/pg-aiguide/timescale-analytics.js +220 -0
  264. package/dist/integrations/pg-aiguide/timescale-analytics.js.map +7 -0
  265. package/dist/mcp/stackmemory-mcp-server.js +550 -0
  266. package/dist/mcp/stackmemory-mcp-server.js.map +7 -0
  267. package/dist/middleware/exponential-rate-limiter.js +285 -0
  268. package/dist/middleware/exponential-rate-limiter.js.map +7 -0
  269. package/dist/models/user.model.js +351 -0
  270. package/dist/models/user.model.js.map +7 -0
  271. package/dist/scripts/benchmark-performance.d.ts +7 -0
  272. package/dist/scripts/benchmark-performance.d.ts.map +1 -0
  273. package/dist/scripts/benchmark-performance.js +44 -0
  274. package/dist/scripts/benchmark-performance.js.map +1 -0
  275. package/dist/scripts/cleanup-duplicate-tasks.d.ts +12 -0
  276. package/dist/scripts/cleanup-duplicate-tasks.d.ts.map +1 -0
  277. package/dist/scripts/cleanup-duplicate-tasks.js +215 -0
  278. package/dist/scripts/cleanup-duplicate-tasks.js.map +1 -0
  279. package/dist/servers/production/auth-middleware.js +513 -0
  280. package/dist/servers/production/auth-middleware.js.map +7 -0
  281. package/dist/servers/railway/index.js +390 -0
  282. package/dist/servers/railway/index.js.map +7 -0
  283. package/dist/services/config-service.js +62 -0
  284. package/dist/services/config-service.js.map +7 -0
  285. package/dist/services/context-service.js +191 -0
  286. package/dist/services/context-service.js.map +7 -0
  287. package/dist/src/agents/core/agent-task-manager.d.ts +154 -0
  288. package/dist/src/agents/core/agent-task-manager.d.ts.map +1 -0
  289. package/dist/src/agents/core/agent-task-manager.js +504 -0
  290. package/dist/src/agents/core/agent-task-manager.js.map +1 -0
  291. package/dist/src/agents/verifiers/base-verifier.d.ts +112 -0
  292. package/dist/src/agents/verifiers/base-verifier.d.ts.map +1 -0
  293. package/dist/src/agents/verifiers/base-verifier.js +130 -0
  294. package/dist/src/agents/verifiers/base-verifier.js.map +1 -0
  295. package/dist/src/agents/verifiers/formatter-verifier.d.ts +14 -0
  296. package/dist/src/agents/verifiers/formatter-verifier.d.ts.map +1 -0
  297. package/dist/src/agents/verifiers/formatter-verifier.js +107 -0
  298. package/dist/src/agents/verifiers/formatter-verifier.js.map +1 -0
  299. package/dist/src/agents/verifiers/llm-judge.d.ts +46 -0
  300. package/dist/src/agents/verifiers/llm-judge.d.ts.map +1 -0
  301. package/dist/src/agents/verifiers/llm-judge.js +248 -0
  302. package/dist/src/agents/verifiers/llm-judge.js.map +1 -0
  303. package/dist/src/cli/claude-sm.js +55 -0
  304. package/dist/src/cli/claude-sm.js.map +1 -1
  305. package/dist/src/cli/commands/agent.d.ts +9 -0
  306. package/dist/src/cli/commands/agent.d.ts.map +1 -0
  307. package/dist/src/cli/commands/agent.js +303 -0
  308. package/dist/src/cli/commands/agent.js.map +1 -0
  309. package/dist/src/cli/commands/handoff.d.ts +6 -0
  310. package/dist/src/cli/commands/handoff.d.ts.map +1 -0
  311. package/dist/src/cli/commands/handoff.js +212 -0
  312. package/dist/src/cli/commands/handoff.js.map +1 -0
  313. package/dist/src/cli/index.d.ts.map +1 -1
  314. package/dist/src/cli/index.js +4 -0
  315. package/dist/src/cli/index.js.map +1 -1
  316. package/dist/src/core/context/frame-database.d.ts +59 -0
  317. package/dist/src/core/context/frame-database.d.ts.map +1 -0
  318. package/dist/src/core/context/frame-database.js +333 -0
  319. package/dist/src/core/context/frame-database.js.map +1 -0
  320. package/dist/src/core/context/frame-digest.d.ts +59 -0
  321. package/dist/src/core/context/frame-digest.d.ts.map +1 -0
  322. package/dist/src/core/context/frame-digest.js +264 -0
  323. package/dist/src/core/context/frame-digest.js.map +1 -0
  324. package/dist/src/core/context/frame-manager.d.ts +2 -0
  325. package/dist/src/core/context/frame-manager.d.ts.map +1 -1
  326. package/dist/src/core/context/frame-manager.js +7 -0
  327. package/dist/src/core/context/frame-manager.js.map +1 -1
  328. package/dist/src/core/context/frame-stack.d.ts +85 -0
  329. package/dist/src/core/context/frame-stack.d.ts.map +1 -0
  330. package/dist/src/core/context/frame-stack.js +287 -0
  331. package/dist/src/core/context/frame-stack.js.map +1 -0
  332. package/dist/src/core/context/frame-types.d.ts +67 -0
  333. package/dist/src/core/context/frame-types.d.ts.map +1 -0
  334. package/dist/src/core/context/frame-types.js +6 -0
  335. package/dist/src/core/context/frame-types.js.map +1 -0
  336. package/dist/src/core/context/index.d.ts +11 -0
  337. package/dist/src/core/context/index.d.ts.map +1 -0
  338. package/dist/src/core/context/index.js +14 -0
  339. package/dist/src/core/context/index.js.map +1 -0
  340. package/dist/src/core/context/refactored-frame-manager.d.ts +99 -0
  341. package/dist/src/core/context/refactored-frame-manager.d.ts.map +1 -0
  342. package/dist/src/core/context/refactored-frame-manager.js +340 -0
  343. package/dist/src/core/context/refactored-frame-manager.js.map +1 -0
  344. package/dist/src/core/database/batch-operations.d.ts +118 -0
  345. package/dist/src/core/database/batch-operations.d.ts.map +1 -0
  346. package/dist/src/core/database/batch-operations.js +339 -0
  347. package/dist/src/core/database/batch-operations.js.map +1 -0
  348. package/dist/src/core/database/connection-pool.d.ts +79 -0
  349. package/dist/src/core/database/connection-pool.d.ts.map +1 -0
  350. package/dist/src/core/database/connection-pool.js +236 -0
  351. package/dist/src/core/database/connection-pool.js.map +1 -0
  352. package/dist/src/core/database/query-cache.d.ts +135 -0
  353. package/dist/src/core/database/query-cache.d.ts.map +1 -0
  354. package/dist/src/core/database/query-cache.js +294 -0
  355. package/dist/src/core/database/query-cache.js.map +1 -0
  356. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts +125 -0
  357. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts.map +1 -0
  358. package/dist/src/core/digest/enhanced-hybrid-digest.js +282 -0
  359. package/dist/src/core/digest/enhanced-hybrid-digest.js.map +1 -0
  360. package/dist/src/core/digest/frame-digest-integration.d.ts +67 -0
  361. package/dist/src/core/digest/frame-digest-integration.d.ts.map +1 -0
  362. package/dist/src/core/digest/frame-digest-integration.js +198 -0
  363. package/dist/src/core/digest/frame-digest-integration.js.map +1 -0
  364. package/dist/src/core/digest/hybrid-digest-generator.d.ts +3 -3
  365. package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +1 -1
  366. package/dist/src/core/digest/hybrid-digest-generator.js.map +1 -1
  367. package/dist/src/core/digest/index.d.ts +3 -1
  368. package/dist/src/core/digest/index.d.ts.map +1 -1
  369. package/dist/src/core/digest/index.js +3 -1
  370. package/dist/src/core/digest/index.js.map +1 -1
  371. package/dist/src/core/errors/index.d.ts +13 -5
  372. package/dist/src/core/errors/index.d.ts.map +1 -1
  373. package/dist/src/core/errors/index.js +13 -5
  374. package/dist/src/core/errors/index.js.map +1 -1
  375. package/dist/src/core/merge/conflict-detector.d.ts +122 -0
  376. package/dist/src/core/merge/conflict-detector.d.ts.map +1 -0
  377. package/dist/src/core/merge/conflict-detector.js +468 -0
  378. package/dist/src/core/merge/conflict-detector.js.map +1 -0
  379. package/dist/src/core/merge/index.d.ts +9 -0
  380. package/dist/src/core/merge/index.d.ts.map +1 -0
  381. package/dist/src/core/merge/index.js +9 -0
  382. package/dist/src/core/merge/index.js.map +1 -0
  383. package/dist/src/core/merge/resolution-engine.d.ts +120 -0
  384. package/dist/src/core/merge/resolution-engine.d.ts.map +1 -0
  385. package/dist/src/core/merge/resolution-engine.js +573 -0
  386. package/dist/src/core/merge/resolution-engine.js.map +1 -0
  387. package/dist/src/core/merge/stack-diff.d.ts +97 -0
  388. package/dist/src/core/merge/stack-diff.d.ts.map +1 -0
  389. package/dist/src/core/merge/stack-diff.js +516 -0
  390. package/dist/src/core/merge/stack-diff.js.map +1 -0
  391. package/dist/src/core/merge/types.d.ts +110 -0
  392. package/dist/src/core/merge/types.d.ts.map +1 -0
  393. package/dist/src/core/merge/types.js +6 -0
  394. package/dist/src/core/merge/types.js.map +1 -0
  395. package/dist/src/core/performance/context-cache.d.ts +109 -0
  396. package/dist/src/core/performance/context-cache.d.ts.map +1 -0
  397. package/dist/src/core/performance/context-cache.js +280 -0
  398. package/dist/src/core/performance/context-cache.js.map +1 -0
  399. package/dist/src/core/performance/index.d.ts +3 -0
  400. package/dist/src/core/performance/index.d.ts.map +1 -0
  401. package/dist/src/core/performance/index.js +3 -0
  402. package/dist/src/core/performance/index.js.map +1 -0
  403. package/dist/src/core/performance/lazy-context-loader.d.ts +93 -0
  404. package/dist/src/core/performance/lazy-context-loader.d.ts.map +1 -0
  405. package/dist/src/core/performance/lazy-context-loader.js +332 -0
  406. package/dist/src/core/performance/lazy-context-loader.js.map +1 -0
  407. package/dist/src/core/performance/monitor.d.ts +48 -0
  408. package/dist/src/core/performance/monitor.d.ts.map +1 -0
  409. package/dist/src/core/performance/monitor.js +226 -0
  410. package/dist/src/core/performance/monitor.js.map +1 -0
  411. package/dist/src/core/performance/optimized-frame-context.d.ts +74 -0
  412. package/dist/src/core/performance/optimized-frame-context.d.ts.map +1 -0
  413. package/dist/src/core/performance/optimized-frame-context.js +330 -0
  414. package/dist/src/core/performance/optimized-frame-context.js.map +1 -0
  415. package/dist/src/core/performance/performance-benchmark.d.ts +50 -0
  416. package/dist/src/core/performance/performance-benchmark.d.ts.map +1 -0
  417. package/dist/src/core/performance/performance-benchmark.js +290 -0
  418. package/dist/src/core/performance/performance-benchmark.js.map +1 -0
  419. package/dist/src/core/performance/performance-profiler.d.ts +151 -0
  420. package/dist/src/core/performance/performance-profiler.d.ts.map +1 -0
  421. package/dist/src/core/performance/performance-profiler.js +346 -0
  422. package/dist/src/core/performance/performance-profiler.js.map +1 -0
  423. package/dist/src/core/performance/streaming-jsonl-parser.d.ts +41 -0
  424. package/dist/src/core/performance/streaming-jsonl-parser.d.ts.map +1 -0
  425. package/dist/src/core/performance/streaming-jsonl-parser.js +193 -0
  426. package/dist/src/core/performance/streaming-jsonl-parser.js.map +1 -0
  427. package/dist/src/core/persistence/postgres-adapter.d.ts.map +1 -1
  428. package/dist/src/core/persistence/postgres-adapter.js +18 -4
  429. package/dist/src/core/persistence/postgres-adapter.js.map +1 -1
  430. package/dist/src/core/query/query-parser.d.ts +5 -0
  431. package/dist/src/core/query/query-parser.d.ts.map +1 -1
  432. package/dist/src/core/query/query-parser.js +86 -18
  433. package/dist/src/core/query/query-parser.js.map +1 -1
  434. package/dist/src/core/query/query-templates.d.ts +44 -0
  435. package/dist/src/core/query/query-templates.d.ts.map +1 -0
  436. package/dist/src/core/query/query-templates.js +326 -0
  437. package/dist/src/core/query/query-templates.js.map +1 -0
  438. package/dist/src/core/retrieval/llm-context-retrieval.d.ts +5 -3
  439. package/dist/src/core/retrieval/llm-context-retrieval.d.ts.map +1 -1
  440. package/dist/src/core/retrieval/llm-context-retrieval.js +73 -21
  441. package/dist/src/core/retrieval/llm-context-retrieval.js.map +1 -1
  442. package/dist/src/core/trace/cli-trace-wrapper.d.ts +23 -0
  443. package/dist/src/core/trace/cli-trace-wrapper.d.ts.map +1 -0
  444. package/dist/src/core/trace/cli-trace-wrapper.js +141 -0
  445. package/dist/src/core/trace/cli-trace-wrapper.js.map +1 -0
  446. package/dist/src/core/trace/db-trace-wrapper.d.ts +36 -0
  447. package/dist/src/core/trace/db-trace-wrapper.d.ts.map +1 -0
  448. package/dist/src/core/trace/db-trace-wrapper.js +252 -0
  449. package/dist/src/core/trace/db-trace-wrapper.js.map +1 -0
  450. package/dist/src/core/trace/debug-trace.d.ts +84 -0
  451. package/dist/src/core/trace/debug-trace.d.ts.map +1 -0
  452. package/dist/src/core/trace/debug-trace.js +402 -0
  453. package/dist/src/core/trace/debug-trace.js.map +1 -0
  454. package/dist/src/core/trace/error-test.d.ts +6 -0
  455. package/dist/src/core/trace/error-test.d.ts.map +1 -0
  456. package/dist/src/core/trace/error-test.js +128 -0
  457. package/dist/src/core/trace/error-test.js.map +1 -0
  458. package/dist/src/core/trace/index.d.ts +25 -0
  459. package/dist/src/core/trace/index.d.ts.map +1 -0
  460. package/dist/src/core/trace/index.js +121 -0
  461. package/dist/src/core/trace/index.js.map +1 -0
  462. package/dist/src/core/trace/linear-api-wrapper.d.ts +17 -0
  463. package/dist/src/core/trace/linear-api-wrapper.d.ts.map +1 -0
  464. package/dist/src/core/trace/linear-api-wrapper.js +205 -0
  465. package/dist/src/core/trace/linear-api-wrapper.js.map +1 -0
  466. package/dist/src/core/trace/performance-test.d.ts +6 -0
  467. package/dist/src/core/trace/performance-test.d.ts.map +1 -0
  468. package/dist/src/core/trace/performance-test.js +111 -0
  469. package/dist/src/core/trace/performance-test.js.map +1 -0
  470. package/dist/src/core/trace/trace-demo.d.ts +8 -0
  471. package/dist/src/core/trace/trace-demo.d.ts.map +1 -0
  472. package/dist/src/core/trace/trace-demo.js +154 -0
  473. package/dist/src/core/trace/trace-demo.js.map +1 -0
  474. package/dist/src/core/trace/trace-detector.d.ts +2 -2
  475. package/dist/src/core/trace/trace-detector.d.ts.map +1 -1
  476. package/dist/src/core/trace/trace-detector.demo.js +1 -1
  477. package/dist/src/core/trace/trace-detector.demo.js.map +1 -1
  478. package/dist/src/core/trace/trace-detector.js +3 -3
  479. package/dist/src/core/trace/trace-detector.js.map +1 -1
  480. package/dist/src/features/tasks/pebbles-task-store.d.ts +9 -2
  481. package/dist/src/features/tasks/pebbles-task-store.d.ts.map +1 -1
  482. package/dist/src/features/tasks/pebbles-task-store.js +97 -18
  483. package/dist/src/features/tasks/pebbles-task-store.js.map +1 -1
  484. package/dist/src/integrations/linear/auth.d.ts.map +1 -1
  485. package/dist/src/integrations/linear/auth.js.map +1 -1
  486. package/dist/src/integrations/linear/client.d.ts +15 -1
  487. package/dist/src/integrations/linear/client.d.ts.map +1 -1
  488. package/dist/src/integrations/linear/client.js +85 -3
  489. package/dist/src/integrations/linear/client.js.map +1 -1
  490. package/dist/src/integrations/linear/sync-manager.d.ts +2 -0
  491. package/dist/src/integrations/linear/sync-manager.d.ts.map +1 -1
  492. package/dist/src/integrations/linear/sync-manager.js +16 -4
  493. package/dist/src/integrations/linear/sync-manager.js.map +1 -1
  494. package/dist/src/integrations/linear/sync-service.d.ts +23 -2
  495. package/dist/src/integrations/linear/sync-service.d.ts.map +1 -1
  496. package/dist/src/integrations/linear/sync-service.js +44 -25
  497. package/dist/src/integrations/linear/sync-service.js.map +1 -1
  498. package/dist/src/integrations/linear/sync.d.ts +6 -0
  499. package/dist/src/integrations/linear/sync.d.ts.map +1 -1
  500. package/dist/src/integrations/linear/sync.js +27 -2
  501. package/dist/src/integrations/linear/sync.js.map +1 -1
  502. package/dist/src/integrations/linear/types.d.ts +16 -1
  503. package/dist/src/integrations/linear/types.d.ts.map +1 -1
  504. package/dist/src/integrations/linear/webhook-server.d.ts.map +1 -1
  505. package/dist/src/integrations/linear/webhook-server.js +10 -8
  506. package/dist/src/integrations/linear/webhook-server.js.map +1 -1
  507. package/dist/src/integrations/linear/webhook.d.ts +13 -0
  508. package/dist/src/integrations/linear/webhook.d.ts.map +1 -1
  509. package/dist/src/integrations/linear/webhook.js +101 -14
  510. package/dist/src/integrations/linear/webhook.js.map +1 -1
  511. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts +39 -0
  512. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts.map +1 -0
  513. package/dist/src/integrations/mcp/handlers/context-handlers.js +266 -0
  514. package/dist/src/integrations/mcp/handlers/context-handlers.js.map +1 -0
  515. package/dist/src/integrations/mcp/handlers/index.d.ts +37 -0
  516. package/dist/src/integrations/mcp/handlers/index.d.ts.map +1 -0
  517. package/dist/src/integrations/mcp/handlers/index.js +134 -0
  518. package/dist/src/integrations/mcp/handlers/index.js.map +1 -0
  519. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts +33 -0
  520. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts.map +1 -0
  521. package/dist/src/integrations/mcp/handlers/linear-handlers.js +251 -0
  522. package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +1 -0
  523. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts +42 -0
  524. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts.map +1 -0
  525. package/dist/src/integrations/mcp/handlers/task-handlers.js +238 -0
  526. package/dist/src/integrations/mcp/handlers/task-handlers.js.map +1 -0
  527. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts +41 -0
  528. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts.map +1 -0
  529. package/dist/src/integrations/mcp/handlers/trace-handlers.js +298 -0
  530. package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +1 -0
  531. package/dist/src/integrations/mcp/index.d.ts +13 -0
  532. package/dist/src/integrations/mcp/index.d.ts.map +1 -0
  533. package/dist/src/integrations/mcp/index.js +17 -0
  534. package/dist/src/integrations/mcp/index.js.map +1 -0
  535. package/dist/src/integrations/mcp/refactored-server.d.ts +76 -0
  536. package/dist/src/integrations/mcp/refactored-server.d.ts.map +1 -0
  537. package/dist/src/integrations/mcp/refactored-server.js +351 -0
  538. package/dist/src/integrations/mcp/refactored-server.js.map +1 -0
  539. package/dist/src/integrations/mcp/tool-definitions.d.ts +44 -0
  540. package/dist/src/integrations/mcp/tool-definitions.d.ts.map +1 -0
  541. package/dist/src/integrations/mcp/tool-definitions.js +563 -0
  542. package/dist/src/integrations/mcp/tool-definitions.js.map +1 -0
  543. package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +1 -1
  544. package/dist/src/integrations/pg-aiguide/semantic-search.js +43 -21
  545. package/dist/src/integrations/pg-aiguide/semantic-search.js.map +1 -1
  546. package/dist/src/mcp/stackmemory-mcp-server.d.ts +9 -0
  547. package/dist/src/mcp/stackmemory-mcp-server.d.ts.map +1 -0
  548. package/dist/src/mcp/stackmemory-mcp-server.js +519 -0
  549. package/dist/src/mcp/stackmemory-mcp-server.js.map +1 -0
  550. package/dist/src/middleware/exponential-rate-limiter.d.ts +78 -0
  551. package/dist/src/middleware/exponential-rate-limiter.d.ts.map +1 -0
  552. package/dist/src/middleware/exponential-rate-limiter.js +293 -0
  553. package/dist/src/middleware/exponential-rate-limiter.js.map +1 -0
  554. package/dist/src/models/user.model.d.ts +8 -1
  555. package/dist/src/models/user.model.d.ts.map +1 -1
  556. package/dist/src/models/user.model.js +62 -14
  557. package/dist/src/models/user.model.js.map +1 -1
  558. package/dist/src/servers/production/auth-middleware.d.ts +5 -2
  559. package/dist/src/servers/production/auth-middleware.d.ts.map +1 -1
  560. package/dist/src/servers/production/auth-middleware.js +71 -34
  561. package/dist/src/servers/production/auth-middleware.js.map +1 -1
  562. package/dist/src/services/context-service.d.ts.map +1 -1
  563. package/dist/src/services/context-service.js +86 -1
  564. package/dist/src/services/context-service.js.map +1 -1
  565. package/dist/src/validation/schemas.d.ts +633 -0
  566. package/dist/src/validation/schemas.d.ts.map +1 -0
  567. package/dist/src/validation/schemas.js +347 -0
  568. package/dist/src/validation/schemas.js.map +1 -0
  569. package/dist/types/task.js +1 -0
  570. package/dist/types/task.js.map +7 -0
  571. package/dist/utils/logger.js +52 -0
  572. package/dist/utils/logger.js.map +7 -0
  573. package/dist/validation/schemas.js +218 -0
  574. package/dist/validation/schemas.js.map +7 -0
  575. package/package.json +7 -3
@@ -0,0 +1,290 @@
1
+ import {
2
+ describe,
3
+ it,
4
+ expect,
5
+ beforeEach,
6
+ afterEach,
7
+ vi,
8
+ beforeAll
9
+ } from "vitest";
10
+ import { join } from "path";
11
+ import { mkdtempSync, rmSync, writeFileSync, existsSync, mkdirSync } from "fs";
12
+ import { tmpdir } from "os";
13
+ vi.mock("../core/monitoring/logger", () => ({
14
+ logger: {
15
+ info: vi.fn(),
16
+ error: vi.fn(),
17
+ debug: vi.fn(),
18
+ warn: vi.fn()
19
+ }
20
+ }));
21
+ vi.mock("better-sqlite3", () => ({
22
+ default: vi.fn().mockImplementation(() => ({
23
+ exec: vi.fn(),
24
+ prepare: vi.fn(() => ({
25
+ run: vi.fn(),
26
+ get: vi.fn(),
27
+ all: vi.fn(() => [])
28
+ })),
29
+ close: vi.fn()
30
+ }))
31
+ }));
32
+ vi.mock("../core/context/frame-manager", () => ({
33
+ FrameManager: vi.fn().mockImplementation(() => ({
34
+ createFrame: vi.fn(() => "frame-123"),
35
+ getActiveFramePath: vi.fn(() => []),
36
+ getStackDepth: vi.fn(() => 0),
37
+ getHotStackContext: vi.fn(() => []),
38
+ addEvent: vi.fn(),
39
+ closeFrame: vi.fn()
40
+ }))
41
+ }));
42
+ vi.mock("../features/tasks/pebbles-task-store.js", () => ({
43
+ PebblesTaskStore: vi.fn().mockImplementation(() => ({
44
+ createTask: vi.fn(() => "task-123"),
45
+ getActiveTasks: vi.fn(() => []),
46
+ getMetrics: vi.fn(() => ({
47
+ total_tasks: 0,
48
+ completion_rate: 0,
49
+ blocked_tasks: 0
50
+ }))
51
+ }))
52
+ }));
53
+ vi.mock("../integrations/linear/auth", () => ({
54
+ LinearAuthManager: vi.fn().mockImplementation(() => ({
55
+ isConfigured: vi.fn(() => false),
56
+ loadConfig: vi.fn(),
57
+ loadTokens: vi.fn()
58
+ })),
59
+ LinearOAuthSetup: vi.fn().mockImplementation(() => ({
60
+ setupInteractive: vi.fn(),
61
+ completeAuth: vi.fn(),
62
+ testConnection: vi.fn()
63
+ }))
64
+ }));
65
+ vi.mock("../integrations/linear/sync", () => ({
66
+ LinearSyncEngine: vi.fn().mockImplementation(() => ({
67
+ sync: vi.fn(() => ({
68
+ success: true,
69
+ synced: { toLinear: 1, fromLinear: 2, updated: 0 },
70
+ conflicts: [],
71
+ errors: []
72
+ }))
73
+ })),
74
+ DEFAULT_SYNC_CONFIG: {
75
+ enabled: true,
76
+ direction: "bidirectional"
77
+ }
78
+ }));
79
+ vi.mock("../integrations/linear/auto-sync.js", () => ({
80
+ initializeAutoSync: vi.fn(),
81
+ getAutoSyncService: vi.fn(() => null),
82
+ stopAutoSync: vi.fn()
83
+ }));
84
+ vi.mock("../integrations/linear/config.js", () => ({
85
+ LinearConfigManager: vi.fn().mockImplementation(() => ({
86
+ loadConfig: vi.fn(() => null),
87
+ saveConfig: vi.fn()
88
+ }))
89
+ }));
90
+ vi.mock("../core/utils/update-checker", () => ({
91
+ UpdateChecker: {
92
+ checkForUpdates: vi.fn().mockResolvedValue(void 0),
93
+ forceCheck: vi.fn().mockResolvedValue(void 0)
94
+ }
95
+ }));
96
+ vi.mock("../core/monitoring/progress-tracker", () => ({
97
+ ProgressTracker: vi.fn().mockImplementation(() => ({
98
+ getSummary: vi.fn(() => "Progress summary"),
99
+ updateLinearStatus: vi.fn()
100
+ }))
101
+ }));
102
+ vi.mock("child_process", () => ({
103
+ execSync: vi.fn(() => Buffer.from("mock git output"))
104
+ }));
105
+ const mockRegisterProjectCommands = vi.fn();
106
+ const mockRegisterLinearCommands = vi.fn();
107
+ const mockRegisterLinearTestCommand = vi.fn();
108
+ const mockCreateSessionCommands = vi.fn();
109
+ const mockRegisterWorktreeCommands = vi.fn();
110
+ const mockRegisterOnboardingCommand = vi.fn();
111
+ const mockWebhookCommand = vi.fn(() => ({ name: "webhook" }));
112
+ const mockRegisterTaskCommands = vi.fn();
113
+ const mockRegisterSearchCommands = vi.fn();
114
+ const mockRegisterLogCommands = vi.fn();
115
+ const mockRegisterContextCommands = vi.fn();
116
+ vi.mock("./commands/projects", () => ({
117
+ registerProjectCommands: mockRegisterProjectCommands
118
+ }));
119
+ vi.mock("./commands/linear", () => ({
120
+ registerLinearCommands: mockRegisterLinearCommands
121
+ }));
122
+ vi.mock("./commands/linear-test", () => ({
123
+ registerLinearTestCommand: mockRegisterLinearTestCommand
124
+ }));
125
+ vi.mock("./commands/session", () => ({
126
+ createSessionCommands: mockCreateSessionCommands
127
+ }));
128
+ vi.mock("./commands/worktree", () => ({
129
+ registerWorktreeCommands: mockRegisterWorktreeCommands
130
+ }));
131
+ vi.mock("./commands/onboard", () => ({
132
+ registerOnboardingCommand: mockRegisterOnboardingCommand
133
+ }));
134
+ vi.mock("./commands/webhook", () => ({
135
+ webhookCommand: mockWebhookCommand
136
+ }));
137
+ vi.mock("./commands/tasks", () => ({
138
+ registerTaskCommands: mockRegisterTaskCommands
139
+ }));
140
+ vi.mock("./commands/search", () => ({
141
+ registerSearchCommands: mockRegisterSearchCommands
142
+ }));
143
+ vi.mock("./commands/log", () => ({
144
+ registerLogCommands: mockRegisterLogCommands
145
+ }));
146
+ vi.mock("./commands/context", () => ({
147
+ registerContextCommands: mockRegisterContextCommands
148
+ }));
149
+ vi.mock("../core/projects/project-manager.js", () => ({
150
+ ProjectManager: {
151
+ getInstance: vi.fn(() => ({
152
+ detectProject: vi.fn()
153
+ }))
154
+ }
155
+ }));
156
+ vi.mock("../core/session/index.js", () => ({
157
+ sessionManager: {
158
+ initialize: vi.fn(),
159
+ getOrCreateSession: vi.fn(() => ({
160
+ sessionId: "test-session-123",
161
+ projectId: "test-project",
162
+ state: "active",
163
+ startedAt: Date.now() - 6e5,
164
+ branch: "main"
165
+ })),
166
+ listSessions: vi.fn(() => [])
167
+ },
168
+ FrameQueryMode: {
169
+ CURRENT_SESSION: "current_session",
170
+ ALL_ACTIVE: "all_active",
171
+ PROJECT_ACTIVE: "project_active",
172
+ HISTORICAL: "historical"
173
+ }
174
+ }));
175
+ vi.mock("../integrations/mcp/server.js", () => ({
176
+ runMCPServer: vi.fn().mockResolvedValue(void 0)
177
+ }));
178
+ describe("CLI Commands", () => {
179
+ let tempDir;
180
+ let originalArgv;
181
+ let consoleSpy;
182
+ let exitSpy;
183
+ beforeAll(() => {
184
+ process.setMaxListeners(50);
185
+ });
186
+ beforeEach(() => {
187
+ vi.resetModules();
188
+ tempDir = mkdtempSync(join(tmpdir(), "stackmemory-cli-test-"));
189
+ originalArgv = [...process.argv];
190
+ vi.spyOn(process, "cwd").mockReturnValue(tempDir);
191
+ consoleSpy = {
192
+ log: vi.spyOn(console, "log").mockImplementation(() => {
193
+ }),
194
+ error: vi.spyOn(console, "error").mockImplementation(() => {
195
+ })
196
+ };
197
+ exitSpy = vi.spyOn(process, "exit").mockImplementation((() => {
198
+ }));
199
+ });
200
+ afterEach(() => {
201
+ vi.spyOn(process, "cwd").mockRestore();
202
+ process.argv = originalArgv;
203
+ consoleSpy.log.mockRestore();
204
+ consoleSpy.error.mockRestore();
205
+ exitSpy.mockRestore();
206
+ if (tempDir) {
207
+ rmSync(tempDir, { recursive: true, force: true });
208
+ }
209
+ vi.clearAllMocks();
210
+ });
211
+ describe("init command", () => {
212
+ it("should initialize StackMemory in current directory", async () => {
213
+ const { program } = await import("../index.js");
214
+ process.argv = ["node", "stackmemory", "init"];
215
+ await program.parseAsync(process.argv);
216
+ const stackmemoryDir = join(tempDir, ".stackmemory");
217
+ expect(existsSync(stackmemoryDir)).toBe(true);
218
+ });
219
+ });
220
+ describe("status command", () => {
221
+ it("should show status when StackMemory is initialized", async () => {
222
+ const dbDir = join(tempDir, ".stackmemory");
223
+ mkdirSync(dbDir, { recursive: true });
224
+ writeFileSync(join(dbDir, "context.db"), "");
225
+ const { program } = await import("../index.js");
226
+ process.argv = ["node", "stackmemory", "status"];
227
+ await program.parseAsync(process.argv);
228
+ expect(consoleSpy.log).toHaveBeenCalled();
229
+ });
230
+ it("should show error when StackMemory is not initialized", async () => {
231
+ const { program } = await import("../index.js");
232
+ process.argv = ["node", "stackmemory", "status"];
233
+ await program.parseAsync(process.argv);
234
+ expect(consoleSpy.log).toHaveBeenCalledWith(
235
+ '\u274C StackMemory not initialized. Run "stackmemory init" first.'
236
+ );
237
+ });
238
+ });
239
+ describe("update-check command", () => {
240
+ it("should check for updates", async () => {
241
+ const { program } = await import("../index.js");
242
+ process.argv = ["node", "stackmemory", "update-check"];
243
+ await program.parseAsync(process.argv);
244
+ expect(consoleSpy.log).toHaveBeenCalledWith("\u{1F50D} Checking for updates...");
245
+ });
246
+ });
247
+ describe("mcp-server command", () => {
248
+ it("should start MCP server with default options", async () => {
249
+ const { program } = await import("../index.js");
250
+ process.argv = ["node", "stackmemory", "mcp-server"];
251
+ await program.parseAsync(process.argv);
252
+ expect(consoleSpy.log).toHaveBeenCalledWith(
253
+ "\u{1F680} Starting StackMemory MCP Server..."
254
+ );
255
+ });
256
+ it("should start MCP server with custom project path", async () => {
257
+ const customPath = "/custom/project/path";
258
+ const { program } = await import("../index.js");
259
+ process.argv = [
260
+ "node",
261
+ "stackmemory",
262
+ "mcp-server",
263
+ "--project",
264
+ customPath
265
+ ];
266
+ await program.parseAsync(process.argv);
267
+ expect(consoleSpy.log).toHaveBeenCalledWith(` Project: ${customPath}`);
268
+ });
269
+ });
270
+ describe("Command registration", () => {
271
+ it("should export program with registered commands", async () => {
272
+ const { program } = await import("../index.js");
273
+ expect(program).toBeDefined();
274
+ expect(program.commands.length).toBeGreaterThan(0);
275
+ const commandNames = program.commands.map((cmd) => cmd.name());
276
+ expect(commandNames).toContain("init");
277
+ expect(commandNames).toContain("status");
278
+ expect(commandNames).toContain("mcp-server");
279
+ });
280
+ });
281
+ describe("Error handling", () => {
282
+ it("should handle unknown commands gracefully", async () => {
283
+ const { program } = await import("../index.js");
284
+ program.exitOverride();
285
+ process.argv = ["node", "stackmemory", "unknown-command"];
286
+ await expect(program.parseAsync(process.argv)).rejects.toThrow();
287
+ });
288
+ });
289
+ });
290
+ //# sourceMappingURL=index.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/cli/__tests__/index.test.ts"],
4
+ "sourcesContent": ["/**\n * Tests for StackMemory CLI Commands\n *\n * These tests verify CLI command registration and basic functionality.\n * They use mocks to isolate the CLI from external dependencies.\n */\n\nimport {\n describe,\n it,\n expect,\n beforeEach,\n afterEach,\n vi,\n beforeAll,\n} from 'vitest';\nimport { join } from 'path';\nimport { mkdtempSync, rmSync, writeFileSync, existsSync, mkdirSync } from 'fs';\nimport { tmpdir } from 'os';\n\n// Hoist all mocks before any imports\nvi.mock('../core/monitoring/logger', () => ({\n logger: {\n info: vi.fn(),\n error: vi.fn(),\n debug: vi.fn(),\n warn: vi.fn(),\n },\n}));\n\nvi.mock('better-sqlite3', () => ({\n default: vi.fn().mockImplementation(() => ({\n exec: vi.fn(),\n prepare: vi.fn(() => ({\n run: vi.fn(),\n get: vi.fn(),\n all: vi.fn(() => []),\n })),\n close: vi.fn(),\n })),\n}));\n\nvi.mock('../core/context/frame-manager', () => ({\n FrameManager: vi.fn().mockImplementation(() => ({\n createFrame: vi.fn(() => 'frame-123'),\n getActiveFramePath: vi.fn(() => []),\n getStackDepth: vi.fn(() => 0),\n getHotStackContext: vi.fn(() => []),\n addEvent: vi.fn(),\n closeFrame: vi.fn(),\n })),\n}));\n\nvi.mock('../features/tasks/pebbles-task-store.js', () => ({\n PebblesTaskStore: vi.fn().mockImplementation(() => ({\n createTask: vi.fn(() => 'task-123'),\n getActiveTasks: vi.fn(() => []),\n getMetrics: vi.fn(() => ({\n total_tasks: 0,\n completion_rate: 0,\n blocked_tasks: 0,\n })),\n })),\n}));\n\nvi.mock('../integrations/linear/auth', () => ({\n LinearAuthManager: vi.fn().mockImplementation(() => ({\n isConfigured: vi.fn(() => false),\n loadConfig: vi.fn(),\n loadTokens: vi.fn(),\n })),\n LinearOAuthSetup: vi.fn().mockImplementation(() => ({\n setupInteractive: vi.fn(),\n completeAuth: vi.fn(),\n testConnection: vi.fn(),\n })),\n}));\n\nvi.mock('../integrations/linear/sync', () => ({\n LinearSyncEngine: vi.fn().mockImplementation(() => ({\n sync: vi.fn(() => ({\n success: true,\n synced: { toLinear: 1, fromLinear: 2, updated: 0 },\n conflicts: [],\n errors: [],\n })),\n })),\n DEFAULT_SYNC_CONFIG: {\n enabled: true,\n direction: 'bidirectional',\n },\n}));\n\nvi.mock('../integrations/linear/auto-sync.js', () => ({\n initializeAutoSync: vi.fn(),\n getAutoSyncService: vi.fn(() => null),\n stopAutoSync: vi.fn(),\n}));\n\nvi.mock('../integrations/linear/config.js', () => ({\n LinearConfigManager: vi.fn().mockImplementation(() => ({\n loadConfig: vi.fn(() => null),\n saveConfig: vi.fn(),\n })),\n}));\n\n// Mock update checker to do nothing\nvi.mock('../core/utils/update-checker', () => ({\n UpdateChecker: {\n checkForUpdates: vi.fn().mockResolvedValue(undefined),\n forceCheck: vi.fn().mockResolvedValue(undefined),\n },\n}));\n\nvi.mock('../core/monitoring/progress-tracker', () => ({\n ProgressTracker: vi.fn().mockImplementation(() => ({\n getSummary: vi.fn(() => 'Progress summary'),\n updateLinearStatus: vi.fn(),\n })),\n}));\n\nvi.mock('child_process', () => ({\n execSync: vi.fn(() => Buffer.from('mock git output')),\n}));\n\n// Mock all command registration modules\nconst mockRegisterProjectCommands = vi.fn();\nconst mockRegisterLinearCommands = vi.fn();\nconst mockRegisterLinearTestCommand = vi.fn();\nconst mockCreateSessionCommands = vi.fn();\nconst mockRegisterWorktreeCommands = vi.fn();\nconst mockRegisterOnboardingCommand = vi.fn();\nconst mockWebhookCommand = vi.fn(() => ({ name: 'webhook' }));\nconst mockRegisterTaskCommands = vi.fn();\nconst mockRegisterSearchCommands = vi.fn();\nconst mockRegisterLogCommands = vi.fn();\nconst mockRegisterContextCommands = vi.fn();\n\nvi.mock('./commands/projects', () => ({\n registerProjectCommands: mockRegisterProjectCommands,\n}));\n\nvi.mock('./commands/linear', () => ({\n registerLinearCommands: mockRegisterLinearCommands,\n}));\n\nvi.mock('./commands/linear-test', () => ({\n registerLinearTestCommand: mockRegisterLinearTestCommand,\n}));\n\nvi.mock('./commands/session', () => ({\n createSessionCommands: mockCreateSessionCommands,\n}));\n\nvi.mock('./commands/worktree', () => ({\n registerWorktreeCommands: mockRegisterWorktreeCommands,\n}));\n\nvi.mock('./commands/onboard', () => ({\n registerOnboardingCommand: mockRegisterOnboardingCommand,\n}));\n\nvi.mock('./commands/webhook', () => ({\n webhookCommand: mockWebhookCommand,\n}));\n\nvi.mock('./commands/tasks', () => ({\n registerTaskCommands: mockRegisterTaskCommands,\n}));\n\nvi.mock('./commands/search', () => ({\n registerSearchCommands: mockRegisterSearchCommands,\n}));\n\nvi.mock('./commands/log', () => ({\n registerLogCommands: mockRegisterLogCommands,\n}));\n\nvi.mock('./commands/context', () => ({\n registerContextCommands: mockRegisterContextCommands,\n}));\n\nvi.mock('../core/projects/project-manager.js', () => ({\n ProjectManager: {\n getInstance: vi.fn(() => ({\n detectProject: vi.fn(),\n })),\n },\n}));\n\nvi.mock('../core/session/index.js', () => ({\n sessionManager: {\n initialize: vi.fn(),\n getOrCreateSession: vi.fn(() => ({\n sessionId: 'test-session-123',\n projectId: 'test-project',\n state: 'active',\n startedAt: Date.now() - 600000,\n branch: 'main',\n })),\n listSessions: vi.fn(() => []),\n },\n FrameQueryMode: {\n CURRENT_SESSION: 'current_session',\n ALL_ACTIVE: 'all_active',\n PROJECT_ACTIVE: 'project_active',\n HISTORICAL: 'historical',\n },\n}));\n\nvi.mock('../integrations/mcp/server.js', () => ({\n runMCPServer: vi.fn().mockResolvedValue(undefined),\n}));\n\ndescribe('CLI Commands', () => {\n let tempDir: string;\n let originalArgv: string[];\n let consoleSpy: {\n log: ReturnType<typeof vi.spyOn>;\n error: ReturnType<typeof vi.spyOn>;\n };\n let exitSpy: ReturnType<typeof vi.spyOn>;\n\n beforeAll(() => {\n // Prevent multiple listener warnings\n process.setMaxListeners(50);\n });\n\n beforeEach(() => {\n vi.resetModules();\n\n tempDir = mkdtempSync(join(tmpdir(), 'stackmemory-cli-test-'));\n originalArgv = [...process.argv];\n\n vi.spyOn(process, 'cwd').mockReturnValue(tempDir);\n\n consoleSpy = {\n log: vi.spyOn(console, 'log').mockImplementation(() => {}),\n error: vi.spyOn(console, 'error').mockImplementation(() => {}),\n };\n\n exitSpy = vi\n .spyOn(process, 'exit')\n .mockImplementation((() => {}) as () => never);\n });\n\n afterEach(() => {\n vi.spyOn(process, 'cwd').mockRestore();\n process.argv = originalArgv;\n\n consoleSpy.log.mockRestore();\n consoleSpy.error.mockRestore();\n exitSpy.mockRestore();\n\n if (tempDir) {\n rmSync(tempDir, { recursive: true, force: true });\n }\n\n vi.clearAllMocks();\n });\n\n describe('init command', () => {\n it('should initialize StackMemory in current directory', async () => {\n const { program } = await import('../index.js');\n\n process.argv = ['node', 'stackmemory', 'init'];\n await program.parseAsync(process.argv);\n\n const stackmemoryDir = join(tempDir, '.stackmemory');\n expect(existsSync(stackmemoryDir)).toBe(true);\n });\n });\n\n describe('status command', () => {\n it('should show status when StackMemory is initialized', async () => {\n const dbDir = join(tempDir, '.stackmemory');\n mkdirSync(dbDir, { recursive: true });\n writeFileSync(join(dbDir, 'context.db'), '');\n\n const { program } = await import('../index.js');\n\n process.argv = ['node', 'stackmemory', 'status'];\n await program.parseAsync(process.argv);\n\n // Verify the command executed (it outputs session/status info)\n expect(consoleSpy.log).toHaveBeenCalled();\n });\n\n it('should show error when StackMemory is not initialized', async () => {\n const { program } = await import('../index.js');\n\n process.argv = ['node', 'stackmemory', 'status'];\n await program.parseAsync(process.argv);\n\n expect(consoleSpy.log).toHaveBeenCalledWith(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n });\n });\n\n describe('update-check command', () => {\n it('should check for updates', async () => {\n const { program } = await import('../index.js');\n\n process.argv = ['node', 'stackmemory', 'update-check'];\n await program.parseAsync(process.argv);\n\n expect(consoleSpy.log).toHaveBeenCalledWith('\uD83D\uDD0D Checking for updates...');\n });\n });\n\n describe('mcp-server command', () => {\n it('should start MCP server with default options', async () => {\n const { program } = await import('../index.js');\n\n process.argv = ['node', 'stackmemory', 'mcp-server'];\n await program.parseAsync(process.argv);\n\n expect(consoleSpy.log).toHaveBeenCalledWith(\n '\uD83D\uDE80 Starting StackMemory MCP Server...'\n );\n });\n\n it('should start MCP server with custom project path', async () => {\n const customPath = '/custom/project/path';\n\n const { program } = await import('../index.js');\n\n process.argv = [\n 'node',\n 'stackmemory',\n 'mcp-server',\n '--project',\n customPath,\n ];\n await program.parseAsync(process.argv);\n\n expect(consoleSpy.log).toHaveBeenCalledWith(` Project: ${customPath}`);\n });\n });\n\n describe('Command registration', () => {\n it('should export program with registered commands', async () => {\n const { program } = await import('../index.js');\n\n // Verify program is exported and has commands\n expect(program).toBeDefined();\n expect(program.commands.length).toBeGreaterThan(0);\n\n // Verify key commands are registered\n const commandNames = program.commands.map((cmd) => cmd.name());\n expect(commandNames).toContain('init');\n expect(commandNames).toContain('status');\n expect(commandNames).toContain('mcp-server');\n });\n });\n\n describe('Error handling', () => {\n it('should handle unknown commands gracefully', async () => {\n const { program } = await import('../index.js');\n program.exitOverride();\n\n process.argv = ['node', 'stackmemory', 'unknown-command'];\n\n await expect(program.parseAsync(process.argv)).rejects.toThrow();\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,317 @@
1
+ import { execSync } from "child_process";
2
+ import * as fs from "fs";
3
+ import * as path from "path";
4
+ class ClaudeAutoDetect {
5
+ projectRoot;
6
+ constructor(projectRoot = process.cwd()) {
7
+ this.projectRoot = projectRoot;
8
+ }
9
+ /**
10
+ * Main detection logic
11
+ */
12
+ detect() {
13
+ const result = {
14
+ shouldUseWorktree: false,
15
+ reasons: [],
16
+ confidence: "low",
17
+ suggestions: []
18
+ };
19
+ const checks = [
20
+ this.checkUncommittedChanges(),
21
+ this.checkActiveInstances(),
22
+ this.checkBranchProtection(),
23
+ this.checkFileConflicts(),
24
+ this.checkResourceUsage(),
25
+ this.checkTaskComplexity()
26
+ ];
27
+ let score = 0;
28
+ for (const check of checks) {
29
+ if (check.detected) {
30
+ score += check.weight;
31
+ result.reasons.push(check.reason);
32
+ if (check.suggestion) {
33
+ result.suggestions.push(check.suggestion);
34
+ }
35
+ }
36
+ }
37
+ if (score >= 7) {
38
+ result.shouldUseWorktree = true;
39
+ result.confidence = "high";
40
+ } else if (score >= 4) {
41
+ result.shouldUseWorktree = true;
42
+ result.confidence = "medium";
43
+ } else if (score >= 2) {
44
+ result.shouldUseWorktree = false;
45
+ result.confidence = "medium";
46
+ result.suggestions.push(
47
+ "Consider using --worktree if making significant changes"
48
+ );
49
+ }
50
+ return result;
51
+ }
52
+ /**
53
+ * Check for uncommitted changes
54
+ */
55
+ checkUncommittedChanges() {
56
+ try {
57
+ const status = execSync("git status --porcelain", {
58
+ cwd: this.projectRoot,
59
+ encoding: "utf8"
60
+ });
61
+ if (status.trim().length > 0) {
62
+ const lines = status.trim().split("\n").length;
63
+ return {
64
+ detected: true,
65
+ weight: lines > 10 ? 3 : 2,
66
+ reason: `${lines} uncommitted changes in working directory`,
67
+ suggestion: "Commit or stash changes before proceeding, or use worktree"
68
+ };
69
+ }
70
+ } catch {
71
+ }
72
+ return { detected: false, weight: 0, reason: "" };
73
+ }
74
+ /**
75
+ * Check for other active Claude instances
76
+ */
77
+ checkActiveInstances() {
78
+ const lockDir = path.join(this.projectRoot, ".claude-worktree-locks");
79
+ if (fs.existsSync(lockDir)) {
80
+ try {
81
+ const locks = fs.readdirSync(lockDir).filter((f) => f.endsWith(".lock"));
82
+ const activeLocks = locks.filter((lockFile) => {
83
+ const lockPath = path.join(lockDir, lockFile);
84
+ const stats = fs.statSync(lockPath);
85
+ const ageHours = (Date.now() - stats.mtimeMs) / (1e3 * 60 * 60);
86
+ return ageHours < 24;
87
+ });
88
+ if (activeLocks.length > 0) {
89
+ return {
90
+ detected: true,
91
+ weight: activeLocks.length >= 2 ? 4 : 3,
92
+ reason: `${activeLocks.length} other Claude instance(s) active`,
93
+ suggestion: "Use worktree to avoid conflicts with other instances"
94
+ };
95
+ }
96
+ } catch {
97
+ }
98
+ }
99
+ return { detected: false, weight: 0, reason: "" };
100
+ }
101
+ /**
102
+ * Check if on protected branch
103
+ */
104
+ checkBranchProtection() {
105
+ try {
106
+ const branch = execSync("git rev-parse --abbrev-ref HEAD", {
107
+ cwd: this.projectRoot,
108
+ encoding: "utf8"
109
+ }).trim();
110
+ const protectedBranches = [
111
+ "main",
112
+ "master",
113
+ "production",
114
+ "staging",
115
+ "develop"
116
+ ];
117
+ if (protectedBranches.includes(branch)) {
118
+ return {
119
+ detected: true,
120
+ weight: 4,
121
+ reason: `Working on protected branch: ${branch}`,
122
+ suggestion: "Create a feature branch or use worktree"
123
+ };
124
+ }
125
+ } catch {
126
+ }
127
+ return { detected: false, weight: 0, reason: "" };
128
+ }
129
+ /**
130
+ * Check for potential file conflicts
131
+ */
132
+ checkFileConflicts() {
133
+ const ideFiles = [
134
+ ".vscode/settings.json",
135
+ ".idea/workspace.xml",
136
+ ".sublime-workspace"
137
+ ];
138
+ let openIDEs = 0;
139
+ for (const ideFile of ideFiles) {
140
+ const filePath = path.join(this.projectRoot, ideFile);
141
+ if (fs.existsSync(filePath)) {
142
+ try {
143
+ const stats = fs.statSync(filePath);
144
+ const ageMinutes = (Date.now() - stats.mtimeMs) / (1e3 * 60);
145
+ if (ageMinutes < 5) {
146
+ openIDEs++;
147
+ }
148
+ } catch {
149
+ }
150
+ }
151
+ }
152
+ if (openIDEs > 1) {
153
+ return {
154
+ detected: true,
155
+ weight: 2,
156
+ reason: "Multiple IDEs/editors detected",
157
+ suggestion: "Use worktree to avoid file lock conflicts"
158
+ };
159
+ }
160
+ return { detected: false, weight: 0, reason: "" };
161
+ }
162
+ /**
163
+ * Check system resource usage
164
+ */
165
+ checkResourceUsage() {
166
+ try {
167
+ const worktrees = execSync("git worktree list", {
168
+ cwd: this.projectRoot,
169
+ encoding: "utf8"
170
+ }).trim().split("\n").length;
171
+ if (worktrees > 3) {
172
+ return {
173
+ detected: true,
174
+ weight: 1,
175
+ reason: `${worktrees} worktrees already exist`,
176
+ suggestion: "Consider cleaning up old worktrees"
177
+ };
178
+ }
179
+ } catch {
180
+ }
181
+ return { detected: false, weight: 0, reason: "" };
182
+ }
183
+ /**
184
+ * Detect task complexity from user input or context
185
+ */
186
+ checkTaskComplexity() {
187
+ try {
188
+ const recentCommit = execSync("git log -1 --pretty=%B", {
189
+ cwd: this.projectRoot,
190
+ encoding: "utf8"
191
+ }).toLowerCase();
192
+ const complexIndicators = [
193
+ "refactor",
194
+ "breaking change",
195
+ "major",
196
+ "experiment",
197
+ "prototype",
198
+ "redesign",
199
+ "migration"
200
+ ];
201
+ for (const indicator of complexIndicators) {
202
+ if (recentCommit.includes(indicator)) {
203
+ return {
204
+ detected: true,
205
+ weight: 2,
206
+ reason: "Recent complex changes detected",
207
+ suggestion: "Use worktree for experimental or major changes"
208
+ };
209
+ }
210
+ }
211
+ } catch {
212
+ }
213
+ return { detected: false, weight: 0, reason: "" };
214
+ }
215
+ /**
216
+ * Get current environment status
217
+ */
218
+ getStatus() {
219
+ const status = {
220
+ git: false,
221
+ worktrees: 0,
222
+ instances: 0,
223
+ branch: "unknown",
224
+ uncommittedChanges: 0
225
+ };
226
+ try {
227
+ execSync("git rev-parse --git-dir", {
228
+ cwd: this.projectRoot,
229
+ stdio: "ignore"
230
+ });
231
+ status.git = true;
232
+ status.branch = execSync("git rev-parse --abbrev-ref HEAD", {
233
+ cwd: this.projectRoot,
234
+ encoding: "utf8"
235
+ }).trim();
236
+ const worktreeList = execSync("git worktree list", {
237
+ cwd: this.projectRoot,
238
+ encoding: "utf8"
239
+ });
240
+ status.worktrees = worktreeList.trim().split("\n").length;
241
+ const changes = execSync("git status --porcelain", {
242
+ cwd: this.projectRoot,
243
+ encoding: "utf8"
244
+ });
245
+ status.uncommittedChanges = changes.trim() ? changes.trim().split("\n").length : 0;
246
+ } catch {
247
+ }
248
+ const lockDir = path.join(this.projectRoot, ".claude-worktree-locks");
249
+ if (fs.existsSync(lockDir)) {
250
+ try {
251
+ const locks = fs.readdirSync(lockDir).filter((f) => f.endsWith(".lock"));
252
+ status.instances = locks.filter((lockFile) => {
253
+ const lockPath = path.join(lockDir, lockFile);
254
+ const stats = fs.statSync(lockPath);
255
+ const ageHours = (Date.now() - stats.mtimeMs) / (1e3 * 60 * 60);
256
+ return ageHours < 24;
257
+ }).length;
258
+ } catch {
259
+ }
260
+ }
261
+ return status;
262
+ }
263
+ /**
264
+ * Smart recommendation based on context
265
+ */
266
+ recommend(taskDescription) {
267
+ const detection = this.detect();
268
+ const status = this.getStatus();
269
+ let taskType = "general";
270
+ if (taskDescription) {
271
+ const lower = taskDescription.toLowerCase();
272
+ if (lower.includes("ui") || lower.includes("frontend") || lower.includes("component")) {
273
+ taskType = "frontend";
274
+ } else if (lower.includes("api") || lower.includes("backend") || lower.includes("database")) {
275
+ taskType = "backend";
276
+ } else if (lower.includes("test") || lower.includes("debug") || lower.includes("fix")) {
277
+ taskType = "debugging";
278
+ } else if (lower.includes("refactor") || lower.includes("clean")) {
279
+ taskType = "refactoring";
280
+ }
281
+ }
282
+ let mode = "normal";
283
+ const flags = [];
284
+ let reason = "";
285
+ if (detection.shouldUseWorktree) {
286
+ mode = "worktree";
287
+ flags.push("--worktree");
288
+ reason = detection.reasons[0] || "Isolation recommended";
289
+ }
290
+ switch (taskType) {
291
+ case "frontend":
292
+ if (mode === "worktree") {
293
+ mode = "chrome";
294
+ flags.push("--chrome");
295
+ reason += "; Chrome automation for UI work";
296
+ }
297
+ break;
298
+ case "backend":
299
+ if (mode === "worktree") {
300
+ mode = "sandbox";
301
+ flags.push("--sandbox");
302
+ reason += "; Sandboxed for API development";
303
+ }
304
+ break;
305
+ case "refactoring":
306
+ if (mode === "normal" && status.uncommittedChanges === 0) {
307
+ reason = "Clean working directory, safe to proceed";
308
+ }
309
+ break;
310
+ }
311
+ return { mode, reason, flags };
312
+ }
313
+ }
314
+ export {
315
+ ClaudeAutoDetect
316
+ };
317
+ //# sourceMappingURL=auto-detect.js.map