claude-auto 0.12.4

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 (327) hide show
  1. package/.claude-auto/.claude.hooks.json +25 -0
  2. package/.claude-auto/reminders/reminder-auto.md +145 -0
  3. package/.claude-auto/reminders/reminder-documentation.md +30 -0
  4. package/.claude-auto/reminders/reminder-emergent-design.md +41 -0
  5. package/.claude-auto/reminders/reminder-extreme-ownership.md +27 -0
  6. package/.claude-auto/reminders/reminder-ide-diagnostics.md +25 -0
  7. package/.claude-auto/reminders/reminder-parallelization.md +27 -0
  8. package/.claude-auto/reminders/reminder-rethink-after-revert.md +25 -0
  9. package/.claude-auto/reminders/reminder-sub-agent-rules.md +27 -0
  10. package/.claude-auto/reminders/reminder-test-title-matches-spec.md +37 -0
  11. package/.claude-auto/validators/appeal-system.md +55 -0
  12. package/.claude-auto/validators/backwards-compat.md +33 -0
  13. package/.claude-auto/validators/burst-atomicity.md +37 -0
  14. package/.claude-auto/validators/coverage-rules.md +34 -0
  15. package/.claude-auto/validators/dead-code.md +36 -0
  16. package/.claude-auto/validators/hygiene.md +34 -0
  17. package/.claude-auto/validators/infra-commit-format.md +37 -0
  18. package/.claude-auto/validators/ketchup-plan-format.md +42 -0
  19. package/.claude-auto/validators/new-code-requires-tests.md +36 -0
  20. package/.claude-auto/validators/no-comments.md +35 -0
  21. package/.claude-auto/validators/no-dangerous-git.md +35 -0
  22. package/.claude-auto/validators/tcr-workflow.md +31 -0
  23. package/.claude-auto/validators/testing-no-state-peeking.md +37 -0
  24. package/.claude-auto/validators/testing-structure.md +37 -0
  25. package/.claude-auto/validators/testing-stubs-over-mocks.md +42 -0
  26. package/.claude-auto/validators/testing-weak-assertions.md +36 -0
  27. package/.claude-auto/validators/type-organization.md +30 -0
  28. package/README.md +172 -0
  29. package/bin/cli.ts +6 -0
  30. package/dist/bin/cli.d.ts +3 -0
  31. package/dist/bin/cli.d.ts.map +1 -0
  32. package/dist/bin/cli.js +7 -0
  33. package/dist/bin/cli.js.map +1 -0
  34. package/dist/bundle/scripts/auto-continue.js +5045 -0
  35. package/dist/bundle/scripts/pre-tool-use.js +11719 -0
  36. package/dist/bundle/scripts/session-start.js +8571 -0
  37. package/dist/bundle/scripts/user-prompt-submit.js +8585 -0
  38. package/dist/scripts/auto-continue.d.ts +3 -0
  39. package/dist/scripts/auto-continue.d.ts.map +1 -0
  40. package/dist/scripts/auto-continue.js +65 -0
  41. package/dist/scripts/auto-continue.js.map +1 -0
  42. package/dist/scripts/generate-changeset.d.ts +13 -0
  43. package/dist/scripts/generate-changeset.d.ts.map +1 -0
  44. package/dist/scripts/generate-changeset.js +322 -0
  45. package/dist/scripts/generate-changeset.js.map +1 -0
  46. package/dist/scripts/pre-tool-use.d.ts +3 -0
  47. package/dist/scripts/pre-tool-use.d.ts.map +1 -0
  48. package/dist/scripts/pre-tool-use.js +78 -0
  49. package/dist/scripts/pre-tool-use.js.map +1 -0
  50. package/dist/scripts/session-start.d.ts +3 -0
  51. package/dist/scripts/session-start.d.ts.map +1 -0
  52. package/dist/scripts/session-start.js +76 -0
  53. package/dist/scripts/session-start.js.map +1 -0
  54. package/dist/scripts/user-prompt-submit.d.ts +3 -0
  55. package/dist/scripts/user-prompt-submit.d.ts.map +1 -0
  56. package/dist/scripts/user-prompt-submit.js +76 -0
  57. package/dist/scripts/user-prompt-submit.js.map +1 -0
  58. package/dist/src/activity-logger.d.ts +2 -0
  59. package/dist/src/activity-logger.d.ts.map +1 -0
  60. package/dist/src/activity-logger.js +47 -0
  61. package/dist/src/activity-logger.js.map +1 -0
  62. package/dist/src/activity-logger.test.d.ts +2 -0
  63. package/dist/src/activity-logger.test.d.ts.map +1 -0
  64. package/dist/src/activity-logger.test.js +121 -0
  65. package/dist/src/activity-logger.test.js.map +1 -0
  66. package/dist/src/clean-logs.d.ts +6 -0
  67. package/dist/src/clean-logs.d.ts.map +1 -0
  68. package/dist/src/clean-logs.js +38 -0
  69. package/dist/src/clean-logs.js.map +1 -0
  70. package/dist/src/clean-logs.test.d.ts +2 -0
  71. package/dist/src/clean-logs.test.d.ts.map +1 -0
  72. package/dist/src/clean-logs.test.js +101 -0
  73. package/dist/src/clean-logs.test.js.map +1 -0
  74. package/dist/src/cli/cli.d.ts +3 -0
  75. package/dist/src/cli/cli.d.ts.map +1 -0
  76. package/dist/src/cli/cli.js +32 -0
  77. package/dist/src/cli/cli.js.map +1 -0
  78. package/dist/src/cli/cli.test.d.ts +2 -0
  79. package/dist/src/cli/cli.test.d.ts.map +1 -0
  80. package/dist/src/cli/cli.test.js +27 -0
  81. package/dist/src/cli/cli.test.js.map +1 -0
  82. package/dist/src/cli/doctor.d.ts +7 -0
  83. package/dist/src/cli/doctor.d.ts.map +1 -0
  84. package/dist/src/cli/doctor.js +67 -0
  85. package/dist/src/cli/doctor.js.map +1 -0
  86. package/dist/src/cli/doctor.test.d.ts +2 -0
  87. package/dist/src/cli/doctor.test.d.ts.map +1 -0
  88. package/dist/src/cli/doctor.test.js +87 -0
  89. package/dist/src/cli/doctor.test.js.map +1 -0
  90. package/dist/src/cli/install.d.ts +10 -0
  91. package/dist/src/cli/install.d.ts.map +1 -0
  92. package/dist/src/cli/install.js +116 -0
  93. package/dist/src/cli/install.js.map +1 -0
  94. package/dist/src/cli/install.test.d.ts +2 -0
  95. package/dist/src/cli/install.test.d.ts.map +1 -0
  96. package/dist/src/cli/install.test.js +217 -0
  97. package/dist/src/cli/install.test.js.map +1 -0
  98. package/dist/src/cli/reminders.d.ts +12 -0
  99. package/dist/src/cli/reminders.d.ts.map +1 -0
  100. package/dist/src/cli/reminders.js +52 -0
  101. package/dist/src/cli/reminders.js.map +1 -0
  102. package/dist/src/cli/reminders.test.d.ts +2 -0
  103. package/dist/src/cli/reminders.test.d.ts.map +1 -0
  104. package/dist/src/cli/reminders.test.js +72 -0
  105. package/dist/src/cli/reminders.test.js.map +1 -0
  106. package/dist/src/cli/repair.d.ts +11 -0
  107. package/dist/src/cli/repair.d.ts.map +1 -0
  108. package/dist/src/cli/repair.js +91 -0
  109. package/dist/src/cli/repair.js.map +1 -0
  110. package/dist/src/cli/repair.test.d.ts +2 -0
  111. package/dist/src/cli/repair.test.d.ts.map +1 -0
  112. package/dist/src/cli/repair.test.js +95 -0
  113. package/dist/src/cli/repair.test.js.map +1 -0
  114. package/dist/src/cli/status.d.ts +10 -0
  115. package/dist/src/cli/status.d.ts.map +1 -0
  116. package/dist/src/cli/status.js +55 -0
  117. package/dist/src/cli/status.js.map +1 -0
  118. package/dist/src/cli/status.test.d.ts +2 -0
  119. package/dist/src/cli/status.test.d.ts.map +1 -0
  120. package/dist/src/cli/status.test.js +80 -0
  121. package/dist/src/cli/status.test.js.map +1 -0
  122. package/dist/src/clue-collector.d.ts +23 -0
  123. package/dist/src/clue-collector.d.ts.map +1 -0
  124. package/dist/src/clue-collector.js +221 -0
  125. package/dist/src/clue-collector.js.map +1 -0
  126. package/dist/src/clue-collector.test.d.ts +2 -0
  127. package/dist/src/clue-collector.test.d.ts.map +1 -0
  128. package/dist/src/clue-collector.test.js +278 -0
  129. package/dist/src/clue-collector.test.js.map +1 -0
  130. package/dist/src/commit-validator.d.ts +53 -0
  131. package/dist/src/commit-validator.d.ts.map +1 -0
  132. package/dist/src/commit-validator.js +356 -0
  133. package/dist/src/commit-validator.js.map +1 -0
  134. package/dist/src/commit-validator.test.d.ts +2 -0
  135. package/dist/src/commit-validator.test.d.ts.map +1 -0
  136. package/dist/src/commit-validator.test.js +733 -0
  137. package/dist/src/commit-validator.test.js.map +1 -0
  138. package/dist/src/config-loader.d.ts +15 -0
  139. package/dist/src/config-loader.d.ts.map +1 -0
  140. package/dist/src/config-loader.js +12 -0
  141. package/dist/src/config-loader.js.map +1 -0
  142. package/dist/src/config-loader.test.d.ts +2 -0
  143. package/dist/src/config-loader.test.d.ts.map +1 -0
  144. package/dist/src/config-loader.test.js +69 -0
  145. package/dist/src/config-loader.test.js.map +1 -0
  146. package/dist/src/debug-logger.d.ts +2 -0
  147. package/dist/src/debug-logger.d.ts.map +1 -0
  148. package/dist/src/debug-logger.js +23 -0
  149. package/dist/src/debug-logger.js.map +1 -0
  150. package/dist/src/debug-logger.test.d.ts +2 -0
  151. package/dist/src/debug-logger.test.d.ts.map +1 -0
  152. package/dist/src/debug-logger.test.js +63 -0
  153. package/dist/src/debug-logger.test.js.map +1 -0
  154. package/dist/src/default-validators.test.d.ts +2 -0
  155. package/dist/src/default-validators.test.d.ts.map +1 -0
  156. package/dist/src/default-validators.test.js +119 -0
  157. package/dist/src/default-validators.test.js.map +1 -0
  158. package/dist/src/deny-list.d.ts +3 -0
  159. package/dist/src/deny-list.d.ts.map +1 -0
  160. package/dist/src/deny-list.js +62 -0
  161. package/dist/src/deny-list.js.map +1 -0
  162. package/dist/src/deny-list.test.d.ts +2 -0
  163. package/dist/src/deny-list.test.d.ts.map +1 -0
  164. package/dist/src/deny-list.test.js +93 -0
  165. package/dist/src/deny-list.test.js.map +1 -0
  166. package/dist/src/e2e.test.d.ts +2 -0
  167. package/dist/src/e2e.test.d.ts.map +1 -0
  168. package/dist/src/e2e.test.js +82 -0
  169. package/dist/src/e2e.test.js.map +1 -0
  170. package/dist/src/gitignore-manager.d.ts +2 -0
  171. package/dist/src/gitignore-manager.d.ts.map +1 -0
  172. package/dist/src/gitignore-manager.js +45 -0
  173. package/dist/src/gitignore-manager.js.map +1 -0
  174. package/dist/src/gitignore-manager.test.d.ts +2 -0
  175. package/dist/src/gitignore-manager.test.d.ts.map +1 -0
  176. package/dist/src/gitignore-manager.test.js +65 -0
  177. package/dist/src/gitignore-manager.test.js.map +1 -0
  178. package/dist/src/hook-input.d.ts +9 -0
  179. package/dist/src/hook-input.d.ts.map +1 -0
  180. package/dist/src/hook-input.js +7 -0
  181. package/dist/src/hook-input.js.map +1 -0
  182. package/dist/src/hook-input.test.d.ts +2 -0
  183. package/dist/src/hook-input.test.d.ts.map +1 -0
  184. package/dist/src/hook-input.test.js +20 -0
  185. package/dist/src/hook-input.test.js.map +1 -0
  186. package/dist/src/hook-logger.d.ts +16 -0
  187. package/dist/src/hook-logger.d.ts.map +1 -0
  188. package/dist/src/hook-logger.js +90 -0
  189. package/dist/src/hook-logger.js.map +1 -0
  190. package/dist/src/hook-logger.test.d.ts +2 -0
  191. package/dist/src/hook-logger.test.d.ts.map +1 -0
  192. package/dist/src/hook-logger.test.js +205 -0
  193. package/dist/src/hook-logger.test.js.map +1 -0
  194. package/dist/src/hook-state.d.ts +44 -0
  195. package/dist/src/hook-state.d.ts.map +1 -0
  196. package/dist/src/hook-state.js +128 -0
  197. package/dist/src/hook-state.js.map +1 -0
  198. package/dist/src/hook-state.test.d.ts +2 -0
  199. package/dist/src/hook-state.test.d.ts.map +1 -0
  200. package/dist/src/hook-state.test.js +204 -0
  201. package/dist/src/hook-state.test.js.map +1 -0
  202. package/dist/src/hooks/auto-continue.d.ts +21 -0
  203. package/dist/src/hooks/auto-continue.d.ts.map +1 -0
  204. package/dist/src/hooks/auto-continue.js +70 -0
  205. package/dist/src/hooks/auto-continue.js.map +1 -0
  206. package/dist/src/hooks/auto-continue.test.d.ts +2 -0
  207. package/dist/src/hooks/auto-continue.test.d.ts.map +1 -0
  208. package/dist/src/hooks/auto-continue.test.js +171 -0
  209. package/dist/src/hooks/auto-continue.test.js.map +1 -0
  210. package/dist/src/hooks/pre-tool-use.d.ts +14 -0
  211. package/dist/src/hooks/pre-tool-use.d.ts.map +1 -0
  212. package/dist/src/hooks/pre-tool-use.js +66 -0
  213. package/dist/src/hooks/pre-tool-use.js.map +1 -0
  214. package/dist/src/hooks/pre-tool-use.test.d.ts +2 -0
  215. package/dist/src/hooks/pre-tool-use.test.d.ts.map +1 -0
  216. package/dist/src/hooks/pre-tool-use.test.js +255 -0
  217. package/dist/src/hooks/pre-tool-use.test.js.map +1 -0
  218. package/dist/src/hooks/session-start.d.ts +20 -0
  219. package/dist/src/hooks/session-start.d.ts.map +1 -0
  220. package/dist/src/hooks/session-start.js +27 -0
  221. package/dist/src/hooks/session-start.js.map +1 -0
  222. package/dist/src/hooks/session-start.test.d.ts +2 -0
  223. package/dist/src/hooks/session-start.test.d.ts.map +1 -0
  224. package/dist/src/hooks/session-start.test.js +125 -0
  225. package/dist/src/hooks/session-start.test.js.map +1 -0
  226. package/dist/src/hooks/user-prompt-submit.d.ts +17 -0
  227. package/dist/src/hooks/user-prompt-submit.d.ts.map +1 -0
  228. package/dist/src/hooks/user-prompt-submit.js +28 -0
  229. package/dist/src/hooks/user-prompt-submit.js.map +1 -0
  230. package/dist/src/hooks/user-prompt-submit.test.d.ts +2 -0
  231. package/dist/src/hooks/user-prompt-submit.test.d.ts.map +1 -0
  232. package/dist/src/hooks/user-prompt-submit.test.js +119 -0
  233. package/dist/src/hooks/user-prompt-submit.test.js.map +1 -0
  234. package/dist/src/hooks/validate-commit.d.ts +12 -0
  235. package/dist/src/hooks/validate-commit.d.ts.map +1 -0
  236. package/dist/src/hooks/validate-commit.js +58 -0
  237. package/dist/src/hooks/validate-commit.js.map +1 -0
  238. package/dist/src/hooks/validate-commit.test.d.ts +2 -0
  239. package/dist/src/hooks/validate-commit.test.d.ts.map +1 -0
  240. package/dist/src/hooks/validate-commit.test.js +150 -0
  241. package/dist/src/hooks/validate-commit.test.js.map +1 -0
  242. package/dist/src/index.d.ts +18 -0
  243. package/dist/src/index.d.ts.map +1 -0
  244. package/dist/src/index.js +42 -0
  245. package/dist/src/index.js.map +1 -0
  246. package/dist/src/linker.d.ts +6 -0
  247. package/dist/src/linker.d.ts.map +1 -0
  248. package/dist/src/linker.js +78 -0
  249. package/dist/src/linker.js.map +1 -0
  250. package/dist/src/linker.test.d.ts +2 -0
  251. package/dist/src/linker.test.d.ts.map +1 -0
  252. package/dist/src/linker.test.js +192 -0
  253. package/dist/src/linker.test.js.map +1 -0
  254. package/dist/src/logger.d.ts +21 -0
  255. package/dist/src/logger.d.ts.map +1 -0
  256. package/dist/src/logger.js +117 -0
  257. package/dist/src/logger.js.map +1 -0
  258. package/dist/src/logger.test.d.ts +2 -0
  259. package/dist/src/logger.test.d.ts.map +1 -0
  260. package/dist/src/logger.test.js +159 -0
  261. package/dist/src/logger.test.js.map +1 -0
  262. package/dist/src/path-resolver.d.ts +9 -0
  263. package/dist/src/path-resolver.d.ts.map +1 -0
  264. package/dist/src/path-resolver.js +52 -0
  265. package/dist/src/path-resolver.js.map +1 -0
  266. package/dist/src/reminder-loader.d.ts +24 -0
  267. package/dist/src/reminder-loader.d.ts.map +1 -0
  268. package/dist/src/reminder-loader.js +84 -0
  269. package/dist/src/reminder-loader.js.map +1 -0
  270. package/dist/src/reminder-loader.test.d.ts +2 -0
  271. package/dist/src/reminder-loader.test.d.ts.map +1 -0
  272. package/dist/src/reminder-loader.test.js +152 -0
  273. package/dist/src/reminder-loader.test.js.map +1 -0
  274. package/dist/src/root-finder.d.ts +2 -0
  275. package/dist/src/root-finder.d.ts.map +1 -0
  276. package/dist/src/root-finder.js +71 -0
  277. package/dist/src/root-finder.js.map +1 -0
  278. package/dist/src/root-finder.test.d.ts +2 -0
  279. package/dist/src/root-finder.test.d.ts.map +1 -0
  280. package/dist/src/root-finder.test.js +111 -0
  281. package/dist/src/root-finder.test.js.map +1 -0
  282. package/dist/src/settings-merger.d.ts +2 -0
  283. package/dist/src/settings-merger.d.ts.map +1 -0
  284. package/dist/src/settings-merger.js +133 -0
  285. package/dist/src/settings-merger.js.map +1 -0
  286. package/dist/src/settings-merger.test.d.ts +2 -0
  287. package/dist/src/settings-merger.test.d.ts.map +1 -0
  288. package/dist/src/settings-merger.test.js +379 -0
  289. package/dist/src/settings-merger.test.js.map +1 -0
  290. package/dist/src/settings-template.test.d.ts +2 -0
  291. package/dist/src/settings-template.test.d.ts.map +1 -0
  292. package/dist/src/settings-template.test.js +88 -0
  293. package/dist/src/settings-template.test.js.map +1 -0
  294. package/dist/src/state-manager.d.ts +5 -0
  295. package/dist/src/state-manager.d.ts.map +1 -0
  296. package/dist/src/state-manager.js +55 -0
  297. package/dist/src/state-manager.js.map +1 -0
  298. package/dist/src/state-manager.test.d.ts +2 -0
  299. package/dist/src/state-manager.test.d.ts.map +1 -0
  300. package/dist/src/state-manager.test.js +85 -0
  301. package/dist/src/state-manager.test.js.map +1 -0
  302. package/dist/src/subagent-classifier.d.ts +4 -0
  303. package/dist/src/subagent-classifier.d.ts.map +1 -0
  304. package/dist/src/subagent-classifier.js +53 -0
  305. package/dist/src/subagent-classifier.js.map +1 -0
  306. package/dist/src/subagent-classifier.test.d.ts +2 -0
  307. package/dist/src/subagent-classifier.test.d.ts.map +1 -0
  308. package/dist/src/subagent-classifier.test.js +84 -0
  309. package/dist/src/subagent-classifier.test.js.map +1 -0
  310. package/dist/src/validator-loader.d.ts +9 -0
  311. package/dist/src/validator-loader.d.ts.map +1 -0
  312. package/dist/src/validator-loader.js +71 -0
  313. package/dist/src/validator-loader.js.map +1 -0
  314. package/dist/src/validator-loader.test.d.ts +2 -0
  315. package/dist/src/validator-loader.test.d.ts.map +1 -0
  316. package/dist/src/validator-loader.test.js +140 -0
  317. package/dist/src/validator-loader.test.js.map +1 -0
  318. package/package.json +91 -0
  319. package/scripts/auto-continue.ts +39 -0
  320. package/scripts/generate-changeset.ts +405 -0
  321. package/scripts/pre-tool-use.ts +44 -0
  322. package/scripts/session-start.ts +42 -0
  323. package/scripts/tail-logs.sh +17 -0
  324. package/scripts/test-hooks.sh +910 -0
  325. package/scripts/user-prompt-submit.ts +42 -0
  326. package/templates/settings.json +48 -0
  327. package/templates/settings.local.json +48 -0
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.writeState = exports.readState = exports.mergeSettings = exports.findProjectRoot = exports.sortByPriority = exports.scanReminders = exports.parseReminder = exports.matchReminders = exports.loadReminders = exports.verifySymlink = exports.removeSymlink = exports.createSymlink = exports.generateGitignore = exports.loadDenyPatterns = exports.isDenied = exports.loadConfig = exports.DEFAULT_AUTO_DIR = exports.getStatus = exports.repair = exports.getExpectedSymlinks = exports.listReminders = exports.install = exports.doctor = exports.createCli = void 0;
4
+ var cli_js_1 = require("./cli/cli.js");
5
+ Object.defineProperty(exports, "createCli", { enumerable: true, get: function () { return cli_js_1.createCli; } });
6
+ var doctor_js_1 = require("./cli/doctor.js");
7
+ Object.defineProperty(exports, "doctor", { enumerable: true, get: function () { return doctor_js_1.doctor; } });
8
+ var install_js_1 = require("./cli/install.js");
9
+ Object.defineProperty(exports, "install", { enumerable: true, get: function () { return install_js_1.install; } });
10
+ var reminders_js_1 = require("./cli/reminders.js");
11
+ Object.defineProperty(exports, "listReminders", { enumerable: true, get: function () { return reminders_js_1.listReminders; } });
12
+ var repair_js_1 = require("./cli/repair.js");
13
+ Object.defineProperty(exports, "getExpectedSymlinks", { enumerable: true, get: function () { return repair_js_1.getExpectedSymlinks; } });
14
+ Object.defineProperty(exports, "repair", { enumerable: true, get: function () { return repair_js_1.repair; } });
15
+ var status_js_1 = require("./cli/status.js");
16
+ Object.defineProperty(exports, "getStatus", { enumerable: true, get: function () { return status_js_1.getStatus; } });
17
+ var config_loader_js_1 = require("./config-loader.js");
18
+ Object.defineProperty(exports, "DEFAULT_AUTO_DIR", { enumerable: true, get: function () { return config_loader_js_1.DEFAULT_AUTO_DIR; } });
19
+ Object.defineProperty(exports, "loadConfig", { enumerable: true, get: function () { return config_loader_js_1.loadConfig; } });
20
+ var deny_list_js_1 = require("./deny-list.js");
21
+ Object.defineProperty(exports, "isDenied", { enumerable: true, get: function () { return deny_list_js_1.isDenied; } });
22
+ Object.defineProperty(exports, "loadDenyPatterns", { enumerable: true, get: function () { return deny_list_js_1.loadDenyPatterns; } });
23
+ var gitignore_manager_js_1 = require("./gitignore-manager.js");
24
+ Object.defineProperty(exports, "generateGitignore", { enumerable: true, get: function () { return gitignore_manager_js_1.generateGitignore; } });
25
+ var linker_js_1 = require("./linker.js");
26
+ Object.defineProperty(exports, "createSymlink", { enumerable: true, get: function () { return linker_js_1.createSymlink; } });
27
+ Object.defineProperty(exports, "removeSymlink", { enumerable: true, get: function () { return linker_js_1.removeSymlink; } });
28
+ Object.defineProperty(exports, "verifySymlink", { enumerable: true, get: function () { return linker_js_1.verifySymlink; } });
29
+ var reminder_loader_js_1 = require("./reminder-loader.js");
30
+ Object.defineProperty(exports, "loadReminders", { enumerable: true, get: function () { return reminder_loader_js_1.loadReminders; } });
31
+ Object.defineProperty(exports, "matchReminders", { enumerable: true, get: function () { return reminder_loader_js_1.matchReminders; } });
32
+ Object.defineProperty(exports, "parseReminder", { enumerable: true, get: function () { return reminder_loader_js_1.parseReminder; } });
33
+ Object.defineProperty(exports, "scanReminders", { enumerable: true, get: function () { return reminder_loader_js_1.scanReminders; } });
34
+ Object.defineProperty(exports, "sortByPriority", { enumerable: true, get: function () { return reminder_loader_js_1.sortByPriority; } });
35
+ var root_finder_js_1 = require("./root-finder.js");
36
+ Object.defineProperty(exports, "findProjectRoot", { enumerable: true, get: function () { return root_finder_js_1.findProjectRoot; } });
37
+ var settings_merger_js_1 = require("./settings-merger.js");
38
+ Object.defineProperty(exports, "mergeSettings", { enumerable: true, get: function () { return settings_merger_js_1.mergeSettings; } });
39
+ var state_manager_js_1 = require("./state-manager.js");
40
+ Object.defineProperty(exports, "readState", { enumerable: true, get: function () { return state_manager_js_1.readState; } });
41
+ Object.defineProperty(exports, "writeState", { enumerable: true, get: function () { return state_manager_js_1.writeState; } });
42
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;AAAA,uCAAyC;AAAhC,mGAAA,SAAS,OAAA;AAClB,6CAAyC;AAAhC,mGAAA,MAAM,OAAA;AAEf,+CAA2C;AAAlC,qGAAA,OAAO,OAAA;AAChB,mDAAmD;AAA1C,6GAAA,aAAa,OAAA;AACtB,6CAA8D;AAArD,gHAAA,mBAAmB,OAAA;AAAE,mGAAA,MAAM,OAAA;AACpC,6CAA4C;AAAnC,sGAAA,SAAS,OAAA;AAElB,uDAAkE;AAAzD,oHAAA,gBAAgB,OAAA;AAAE,8GAAA,UAAU,OAAA;AACrC,+CAA4D;AAAnD,wGAAA,QAAQ,OAAA;AAAE,gHAAA,gBAAgB,OAAA;AACnC,+DAA2D;AAAlD,yHAAA,iBAAiB,OAAA;AAC1B,yCAA0E;AAAjE,0GAAA,aAAa,OAAA;AAAE,0GAAA,aAAa,OAAA;AAAE,0GAAA,aAAa,OAAA;AAEpD,2DAAmH;AAA1G,mHAAA,aAAa,OAAA;AAAE,oHAAA,cAAc,OAAA;AAAE,mHAAA,aAAa,OAAA;AAAE,mHAAA,aAAa,OAAA;AAAE,oHAAA,cAAc,OAAA;AACpF,mDAAmD;AAA1C,iHAAA,eAAe,OAAA;AACxB,2DAAqD;AAA5C,mHAAA,aAAa,OAAA;AACtB,uDAA2D;AAAlD,6GAAA,SAAS,OAAA;AAAE,8GAAA,UAAU,OAAA"}
@@ -0,0 +1,6 @@
1
+ export declare function getPackageDir(): string;
2
+ export declare function isLinkedMode(packagePath: string): boolean;
3
+ export declare function createSymlink(source: string, target: string): void;
4
+ export declare function removeSymlink(target: string): void;
5
+ export declare function verifySymlink(target: string, expectedSource: string): boolean;
6
+ //# sourceMappingURL=linker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"linker.d.ts","sourceRoot":"","sources":["../../src/linker.ts"],"names":[],"mappings":"AAGA,wBAAgB,aAAa,IAAI,MAAM,CAEtC;AAED,wBAAgB,YAAY,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAEzD;AAED,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI,CAalE;AAED,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAIlD;AAED,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,OAAO,CAQ7E"}
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.getPackageDir = getPackageDir;
37
+ exports.isLinkedMode = isLinkedMode;
38
+ exports.createSymlink = createSymlink;
39
+ exports.removeSymlink = removeSymlink;
40
+ exports.verifySymlink = verifySymlink;
41
+ const fs = __importStar(require("node:fs"));
42
+ const path = __importStar(require("node:path"));
43
+ function getPackageDir() {
44
+ return path.resolve(__dirname, '..', '..');
45
+ }
46
+ function isLinkedMode(packagePath) {
47
+ return fs.lstatSync(packagePath).isSymbolicLink();
48
+ }
49
+ function createSymlink(source, target) {
50
+ if (fs.existsSync(target)) {
51
+ const stats = fs.lstatSync(target);
52
+ if (stats.isSymbolicLink()) {
53
+ if (fs.readlinkSync(target) === source) {
54
+ return;
55
+ }
56
+ fs.unlinkSync(target);
57
+ }
58
+ else {
59
+ fs.renameSync(target, `${target}.backup`);
60
+ }
61
+ }
62
+ fs.symlinkSync(source, target);
63
+ }
64
+ function removeSymlink(target) {
65
+ if (fs.existsSync(target) && fs.lstatSync(target).isSymbolicLink()) {
66
+ fs.unlinkSync(target);
67
+ }
68
+ }
69
+ function verifySymlink(target, expectedSource) {
70
+ if (!fs.existsSync(target)) {
71
+ return false;
72
+ }
73
+ if (!fs.lstatSync(target).isSymbolicLink()) {
74
+ return false;
75
+ }
76
+ return fs.readlinkSync(target) === expectedSource;
77
+ }
78
+ //# sourceMappingURL=linker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"linker.js","sourceRoot":"","sources":["../../src/linker.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,sCAEC;AAED,oCAEC;AAED,sCAaC;AAED,sCAIC;AAED,sCAQC;AAxCD,4CAA8B;AAC9B,gDAAkC;AAElC,SAAgB,aAAa;IAC3B,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAC7C,CAAC;AAED,SAAgB,YAAY,CAAC,WAAmB;IAC9C,OAAO,EAAE,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,cAAc,EAAE,CAAC;AACpD,CAAC;AAED,SAAgB,aAAa,CAAC,MAAc,EAAE,MAAc;IAC1D,IAAI,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1B,MAAM,KAAK,GAAG,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACnC,IAAI,KAAK,CAAC,cAAc,EAAE,EAAE,CAAC;YAC3B,IAAI,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,MAAM,EAAE,CAAC;gBACvC,OAAO;YACT,CAAC;YACD,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACxB,CAAC;aAAM,CAAC;YACN,EAAE,CAAC,UAAU,CAAC,MAAM,EAAE,GAAG,MAAM,SAAS,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC;IACD,EAAE,CAAC,WAAW,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AACjC,CAAC;AAED,SAAgB,aAAa,CAAC,MAAc;IAC1C,IAAI,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,cAAc,EAAE,EAAE,CAAC;QACnE,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IACxB,CAAC;AACH,CAAC;AAED,SAAgB,aAAa,CAAC,MAAc,EAAE,cAAsB;IAClE,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;QAC3B,OAAO,KAAK,CAAC;IACf,CAAC;IACD,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,cAAc,EAAE,EAAE,CAAC;QAC3C,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,cAAc,CAAC;AACpD,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=linker.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"linker.test.d.ts","sourceRoot":"","sources":["../../src/linker.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,192 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ const fs = __importStar(require("node:fs"));
37
+ const os = __importStar(require("node:os"));
38
+ const path = __importStar(require("node:path"));
39
+ const vitest_1 = require("vitest");
40
+ const linker_js_1 = require("./linker.js");
41
+ (0, vitest_1.describe)('linker', () => {
42
+ (0, vitest_1.describe)('getPackageDir', () => {
43
+ (0, vitest_1.it)('returns the directory containing this package', () => {
44
+ const result = (0, linker_js_1.getPackageDir)();
45
+ (0, vitest_1.expect)(result).toBe(path.resolve(__dirname, '..', '..'));
46
+ });
47
+ });
48
+ (0, vitest_1.describe)('isLinkedMode', () => {
49
+ let tempDir;
50
+ (0, vitest_1.beforeEach)(() => {
51
+ tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'claude-auto-test-'));
52
+ });
53
+ (0, vitest_1.afterEach)(() => {
54
+ fs.rmSync(tempDir, { recursive: true, force: true });
55
+ });
56
+ (0, vitest_1.it)('returns true when package is a symlink in node_modules', () => {
57
+ const projectDir = path.join(tempDir, 'my-project');
58
+ const nodeModules = path.join(projectDir, 'node_modules');
59
+ const packagePath = path.join(nodeModules, 'claude-auto');
60
+ const realPackage = path.join(tempDir, 'real-package');
61
+ fs.mkdirSync(realPackage, { recursive: true });
62
+ fs.mkdirSync(nodeModules, { recursive: true });
63
+ fs.symlinkSync(realPackage, packagePath);
64
+ const result = (0, linker_js_1.isLinkedMode)(packagePath);
65
+ (0, vitest_1.expect)(result).toBe(true);
66
+ });
67
+ (0, vitest_1.it)('returns false when package is a regular directory', () => {
68
+ const projectDir = path.join(tempDir, 'my-project');
69
+ const nodeModules = path.join(projectDir, 'node_modules');
70
+ const packagePath = path.join(nodeModules, 'claude-auto');
71
+ fs.mkdirSync(packagePath, { recursive: true });
72
+ const result = (0, linker_js_1.isLinkedMode)(packagePath);
73
+ (0, vitest_1.expect)(result).toBe(false);
74
+ });
75
+ });
76
+ (0, vitest_1.describe)('createSymlink', () => {
77
+ let tempDir;
78
+ (0, vitest_1.beforeEach)(() => {
79
+ tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'claude-auto-test-'));
80
+ });
81
+ (0, vitest_1.afterEach)(() => {
82
+ fs.rmSync(tempDir, { recursive: true, force: true });
83
+ });
84
+ (0, vitest_1.it)('creates a symlink to the source file', () => {
85
+ const sourceFile = path.join(tempDir, 'source.txt');
86
+ const targetLink = path.join(tempDir, 'target.txt');
87
+ fs.writeFileSync(sourceFile, 'content');
88
+ (0, linker_js_1.createSymlink)(sourceFile, targetLink);
89
+ (0, vitest_1.expect)(fs.lstatSync(targetLink).isSymbolicLink()).toBe(true);
90
+ (0, vitest_1.expect)(fs.readlinkSync(targetLink)).toBe(sourceFile);
91
+ });
92
+ (0, vitest_1.it)('backs up existing non-symlink file before creating symlink', () => {
93
+ const sourceFile = path.join(tempDir, 'source.txt');
94
+ const targetLink = path.join(tempDir, 'target.txt');
95
+ fs.writeFileSync(sourceFile, 'new content');
96
+ fs.writeFileSync(targetLink, 'existing content');
97
+ (0, linker_js_1.createSymlink)(sourceFile, targetLink);
98
+ (0, vitest_1.expect)(fs.lstatSync(targetLink).isSymbolicLink()).toBe(true);
99
+ (0, vitest_1.expect)(fs.readlinkSync(targetLink)).toBe(sourceFile);
100
+ (0, vitest_1.expect)(fs.readFileSync(`${targetLink}.backup`, 'utf-8')).toBe('existing content');
101
+ });
102
+ (0, vitest_1.it)('replaces existing symlink without backup', () => {
103
+ const source1 = path.join(tempDir, 'source1.txt');
104
+ const source2 = path.join(tempDir, 'source2.txt');
105
+ const targetLink = path.join(tempDir, 'target.txt');
106
+ fs.writeFileSync(source1, 'content1');
107
+ fs.writeFileSync(source2, 'content2');
108
+ fs.symlinkSync(source1, targetLink);
109
+ (0, linker_js_1.createSymlink)(source2, targetLink);
110
+ (0, vitest_1.expect)(fs.lstatSync(targetLink).isSymbolicLink()).toBe(true);
111
+ (0, vitest_1.expect)(fs.readlinkSync(targetLink)).toBe(source2);
112
+ (0, vitest_1.expect)(fs.existsSync(`${targetLink}.backup`)).toBe(false);
113
+ });
114
+ (0, vitest_1.it)('is idempotent when symlink already points to source', () => {
115
+ const sourceFile = path.join(tempDir, 'source.txt');
116
+ const targetLink = path.join(tempDir, 'target.txt');
117
+ fs.writeFileSync(sourceFile, 'content');
118
+ fs.symlinkSync(sourceFile, targetLink);
119
+ const statsBefore = fs.lstatSync(targetLink);
120
+ (0, linker_js_1.createSymlink)(sourceFile, targetLink);
121
+ (0, vitest_1.expect)(fs.lstatSync(targetLink).isSymbolicLink()).toBe(true);
122
+ (0, vitest_1.expect)(fs.readlinkSync(targetLink)).toBe(sourceFile);
123
+ (0, vitest_1.expect)(fs.lstatSync(targetLink).ino).toBe(statsBefore.ino);
124
+ });
125
+ });
126
+ (0, vitest_1.describe)('removeSymlink', () => {
127
+ let tempDir;
128
+ (0, vitest_1.beforeEach)(() => {
129
+ tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'claude-auto-test-'));
130
+ });
131
+ (0, vitest_1.afterEach)(() => {
132
+ fs.rmSync(tempDir, { recursive: true, force: true });
133
+ });
134
+ (0, vitest_1.it)('removes a symlink', () => {
135
+ const sourceFile = path.join(tempDir, 'source.txt');
136
+ const targetLink = path.join(tempDir, 'target.txt');
137
+ fs.writeFileSync(sourceFile, 'content');
138
+ fs.symlinkSync(sourceFile, targetLink);
139
+ (0, linker_js_1.removeSymlink)(targetLink);
140
+ (0, vitest_1.expect)(fs.existsSync(targetLink)).toBe(false);
141
+ (0, vitest_1.expect)(fs.existsSync(sourceFile)).toBe(true);
142
+ });
143
+ (0, vitest_1.it)('does not remove regular files', () => {
144
+ const regularFile = path.join(tempDir, 'regular.txt');
145
+ fs.writeFileSync(regularFile, 'content');
146
+ (0, linker_js_1.removeSymlink)(regularFile);
147
+ (0, vitest_1.expect)(fs.existsSync(regularFile)).toBe(true);
148
+ });
149
+ });
150
+ (0, vitest_1.describe)('verifySymlink', () => {
151
+ let tempDir;
152
+ (0, vitest_1.beforeEach)(() => {
153
+ tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'claude-auto-test-'));
154
+ });
155
+ (0, vitest_1.afterEach)(() => {
156
+ fs.rmSync(tempDir, { recursive: true, force: true });
157
+ });
158
+ (0, vitest_1.it)('returns true when symlink points to expected target', () => {
159
+ const sourceFile = path.join(tempDir, 'source.txt');
160
+ const targetLink = path.join(tempDir, 'target.txt');
161
+ fs.writeFileSync(sourceFile, 'content');
162
+ fs.symlinkSync(sourceFile, targetLink);
163
+ const result = (0, linker_js_1.verifySymlink)(targetLink, sourceFile);
164
+ (0, vitest_1.expect)(result).toBe(true);
165
+ });
166
+ (0, vitest_1.it)('returns false when symlink points to different target', () => {
167
+ const source1 = path.join(tempDir, 'source1.txt');
168
+ const source2 = path.join(tempDir, 'source2.txt');
169
+ const targetLink = path.join(tempDir, 'target.txt');
170
+ fs.writeFileSync(source1, 'content1');
171
+ fs.writeFileSync(source2, 'content2');
172
+ fs.symlinkSync(source1, targetLink);
173
+ const result = (0, linker_js_1.verifySymlink)(targetLink, source2);
174
+ (0, vitest_1.expect)(result).toBe(false);
175
+ });
176
+ (0, vitest_1.it)('returns false when target does not exist', () => {
177
+ const sourceFile = path.join(tempDir, 'source.txt');
178
+ const targetLink = path.join(tempDir, 'target.txt');
179
+ const result = (0, linker_js_1.verifySymlink)(targetLink, sourceFile);
180
+ (0, vitest_1.expect)(result).toBe(false);
181
+ });
182
+ (0, vitest_1.it)('returns false when target is not a symlink', () => {
183
+ const sourceFile = path.join(tempDir, 'source.txt');
184
+ const regularFile = path.join(tempDir, 'regular.txt');
185
+ fs.writeFileSync(sourceFile, 'content');
186
+ fs.writeFileSync(regularFile, 'content');
187
+ const result = (0, linker_js_1.verifySymlink)(regularFile, sourceFile);
188
+ (0, vitest_1.expect)(result).toBe(false);
189
+ });
190
+ });
191
+ });
192
+ //# sourceMappingURL=linker.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"linker.test.js","sourceRoot":"","sources":["../../src/linker.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ export declare const colors: {
2
+ readonly reset: "\u001B[0m";
3
+ readonly dim: "\u001B[2m";
4
+ readonly bold: "\u001B[1m";
5
+ readonly italic: "\u001B[3m";
6
+ readonly red: "\u001B[31m";
7
+ readonly green: "\u001B[32m";
8
+ readonly pink: "\u001B[35m";
9
+ readonly yellow: "\u001B[33m";
10
+ readonly cyan: "\u001B[36m";
11
+ readonly white: "\u001B[97m";
12
+ readonly magenta: "\u001B[35m";
13
+ };
14
+ export type LogLevel = 'ACK' | 'NACK' | 'ERROR' | 'WARN' | 'SKIP' | 'INFO' | 'DENIED' | 'CONTINUE';
15
+ export interface Logger {
16
+ log: (level: LogLevel, message: string) => void;
17
+ logError: (error: unknown, context?: string) => void;
18
+ getLogFile: () => string;
19
+ }
20
+ export declare function createLogger(logDir: string, sessionId?: string): Logger;
21
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,MAAM;;;;;;;;;;;;CAYT,CAAC;AAEX,MAAM,MAAM,QAAQ,GAAG,KAAK,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,QAAQ,GAAG,UAAU,CAAC;AAanG,MAAM,WAAW,MAAM;IACrB,GAAG,EAAE,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IAChD,QAAQ,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;IACrD,UAAU,EAAE,MAAM,MAAM,CAAC;CAC1B;AAED,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAgEvE"}
@@ -0,0 +1,117 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.colors = void 0;
37
+ exports.createLogger = createLogger;
38
+ const fs = __importStar(require("node:fs"));
39
+ const path = __importStar(require("node:path"));
40
+ exports.colors = {
41
+ reset: '\x1b[0m',
42
+ dim: '\x1b[2m',
43
+ bold: '\x1b[1m',
44
+ italic: '\x1b[3m',
45
+ red: '\x1b[31m',
46
+ green: '\x1b[32m',
47
+ pink: '\x1b[35m',
48
+ yellow: '\x1b[33m',
49
+ cyan: '\x1b[36m',
50
+ white: '\x1b[97m',
51
+ magenta: '\x1b[35m',
52
+ };
53
+ const levelColors = {
54
+ ACK: `${exports.colors.bold}${exports.colors.green}`,
55
+ NACK: `${exports.colors.bold}${exports.colors.red}`,
56
+ ERROR: `${exports.colors.red}`,
57
+ SKIP: `${exports.colors.yellow}`,
58
+ WARN: `${exports.colors.pink}`,
59
+ INFO: `${exports.colors.dim}`,
60
+ DENIED: `${exports.colors.bold}${exports.colors.magenta}`,
61
+ CONTINUE: `${exports.colors.bold}${exports.colors.cyan}`,
62
+ };
63
+ function createLogger(logDir, sessionId) {
64
+ const hooksDir = path.join(logDir, 'hooks');
65
+ let logFilePath;
66
+ function ensureLogDir() {
67
+ if (!fs.existsSync(hooksDir)) {
68
+ fs.mkdirSync(hooksDir, { recursive: true });
69
+ }
70
+ }
71
+ function getLogFile() {
72
+ if (logFilePath) {
73
+ return logFilePath;
74
+ }
75
+ ensureLogDir();
76
+ if (!sessionId) {
77
+ logFilePath = path.join(hooksDir, 'unknown.log');
78
+ return logFilePath;
79
+ }
80
+ const prefix = sessionId.slice(0, 8);
81
+ const files = fs.readdirSync(hooksDir);
82
+ const existing = files.find((f) => f.startsWith(`${prefix}-`) && f.endsWith('.log'));
83
+ if (existing) {
84
+ logFilePath = path.join(hooksDir, existing);
85
+ return logFilePath;
86
+ }
87
+ const timestamp = new Date()
88
+ .toISOString()
89
+ .replace(/:/g, '-')
90
+ .replace(/\.\d{3}Z$/, '');
91
+ const filename = `${prefix}-${timestamp}.log`;
92
+ logFilePath = path.join(hooksDir, filename);
93
+ fs.appendFileSync(logFilePath, `session: ${sessionId}\n\n`);
94
+ return logFilePath;
95
+ }
96
+ function log(level, message) {
97
+ const timestamp = new Date().toISOString();
98
+ const coloredLevel = `${levelColors[level]}${level}${exports.colors.reset}`;
99
+ const dimTimestamp = `${exports.colors.dim}[${timestamp}]${exports.colors.reset}`;
100
+ const logFile = getLogFile();
101
+ fs.appendFileSync(logFile, `${dimTimestamp} ${coloredLevel}: ${message}\n`);
102
+ }
103
+ function logError(error, context) {
104
+ ensureLogDir();
105
+ const timestamp = new Date().toISOString();
106
+ const errorMsg = error instanceof Error ? `${error.message}\n${error.stack}` : String(error);
107
+ const contextStr = context ? ` [${context}]` : '';
108
+ const errLog = path.join(hooksDir, 'err.log');
109
+ fs.appendFileSync(errLog, `[${timestamp}]${contextStr} ${errorMsg}\n\n`);
110
+ }
111
+ return {
112
+ log,
113
+ logError,
114
+ getLogFile,
115
+ };
116
+ }
117
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=logger.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.test.d.ts","sourceRoot":"","sources":["../../src/logger.test.ts"],"names":[],"mappings":""}