claude-ketchup 0.1.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 (246) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +544 -0
  3. package/bin/cli.ts +6 -0
  4. package/bin/postinstall.ts +5 -0
  5. package/bin/preuninstall.ts +5 -0
  6. package/commands/ketchup.md +107 -0
  7. package/dist/bin/cli.d.ts +3 -0
  8. package/dist/bin/cli.d.ts.map +1 -0
  9. package/dist/bin/cli.js +7 -0
  10. package/dist/bin/cli.js.map +1 -0
  11. package/dist/bin/postinstall.d.ts +3 -0
  12. package/dist/bin/postinstall.d.ts.map +1 -0
  13. package/dist/bin/postinstall.js +6 -0
  14. package/dist/bin/postinstall.js.map +1 -0
  15. package/dist/bin/preuninstall.d.ts +3 -0
  16. package/dist/bin/preuninstall.d.ts.map +1 -0
  17. package/dist/bin/preuninstall.js +6 -0
  18. package/dist/bin/preuninstall.js.map +1 -0
  19. package/dist/scripts/pre-tool-use.d.ts +3 -0
  20. package/dist/scripts/pre-tool-use.d.ts.map +1 -0
  21. package/dist/scripts/pre-tool-use.js +43 -0
  22. package/dist/scripts/pre-tool-use.js.map +1 -0
  23. package/dist/scripts/session-start.d.ts +3 -0
  24. package/dist/scripts/session-start.d.ts.map +1 -0
  25. package/dist/scripts/session-start.js +42 -0
  26. package/dist/scripts/session-start.js.map +1 -0
  27. package/dist/scripts/user-prompt-submit.d.ts +3 -0
  28. package/dist/scripts/user-prompt-submit.d.ts.map +1 -0
  29. package/dist/scripts/user-prompt-submit.js +43 -0
  30. package/dist/scripts/user-prompt-submit.js.map +1 -0
  31. package/dist/src/clean-logs.d.ts +6 -0
  32. package/dist/src/clean-logs.d.ts.map +1 -0
  33. package/dist/src/clean-logs.js +38 -0
  34. package/dist/src/clean-logs.js.map +1 -0
  35. package/dist/src/clean-logs.test.d.ts +2 -0
  36. package/dist/src/clean-logs.test.d.ts.map +1 -0
  37. package/dist/src/clean-logs.test.js +101 -0
  38. package/dist/src/clean-logs.test.js.map +1 -0
  39. package/dist/src/cli/cli.d.ts +3 -0
  40. package/dist/src/cli/cli.d.ts.map +1 -0
  41. package/dist/src/cli/cli.js +24 -0
  42. package/dist/src/cli/cli.js.map +1 -0
  43. package/dist/src/cli/cli.test.d.ts +2 -0
  44. package/dist/src/cli/cli.test.d.ts.map +1 -0
  45. package/dist/src/cli/cli.test.js +20 -0
  46. package/dist/src/cli/cli.test.js.map +1 -0
  47. package/dist/src/cli/doctor.d.ts +7 -0
  48. package/dist/src/cli/doctor.d.ts.map +1 -0
  49. package/dist/src/cli/doctor.js +52 -0
  50. package/dist/src/cli/doctor.js.map +1 -0
  51. package/dist/src/cli/doctor.test.d.ts +2 -0
  52. package/dist/src/cli/doctor.test.d.ts.map +1 -0
  53. package/dist/src/cli/doctor.test.js +77 -0
  54. package/dist/src/cli/doctor.test.js.map +1 -0
  55. package/dist/src/cli/repair.d.ts +7 -0
  56. package/dist/src/cli/repair.d.ts.map +1 -0
  57. package/dist/src/cli/repair.js +67 -0
  58. package/dist/src/cli/repair.js.map +1 -0
  59. package/dist/src/cli/repair.test.d.ts +2 -0
  60. package/dist/src/cli/repair.test.d.ts.map +1 -0
  61. package/dist/src/cli/repair.test.js +72 -0
  62. package/dist/src/cli/repair.test.js.map +1 -0
  63. package/dist/src/cli/skills.d.ts +11 -0
  64. package/dist/src/cli/skills.d.ts.map +1 -0
  65. package/dist/src/cli/skills.js +53 -0
  66. package/dist/src/cli/skills.js.map +1 -0
  67. package/dist/src/cli/skills.test.d.ts +2 -0
  68. package/dist/src/cli/skills.test.d.ts.map +1 -0
  69. package/dist/src/cli/skills.test.js +89 -0
  70. package/dist/src/cli/skills.test.js.map +1 -0
  71. package/dist/src/cli/status.d.ts +10 -0
  72. package/dist/src/cli/status.d.ts.map +1 -0
  73. package/dist/src/cli/status.js +63 -0
  74. package/dist/src/cli/status.js.map +1 -0
  75. package/dist/src/cli/status.test.d.ts +2 -0
  76. package/dist/src/cli/status.test.d.ts.map +1 -0
  77. package/dist/src/cli/status.test.js +70 -0
  78. package/dist/src/cli/status.test.js.map +1 -0
  79. package/dist/src/clue-collector.d.ts +23 -0
  80. package/dist/src/clue-collector.d.ts.map +1 -0
  81. package/dist/src/clue-collector.js +226 -0
  82. package/dist/src/clue-collector.js.map +1 -0
  83. package/dist/src/clue-collector.test.d.ts +2 -0
  84. package/dist/src/clue-collector.test.d.ts.map +1 -0
  85. package/dist/src/clue-collector.test.js +213 -0
  86. package/dist/src/clue-collector.test.js.map +1 -0
  87. package/dist/src/debug-logger.d.ts +2 -0
  88. package/dist/src/debug-logger.d.ts.map +1 -0
  89. package/dist/src/debug-logger.js +23 -0
  90. package/dist/src/debug-logger.js.map +1 -0
  91. package/dist/src/debug-logger.test.d.ts +2 -0
  92. package/dist/src/debug-logger.test.d.ts.map +1 -0
  93. package/dist/src/debug-logger.test.js +63 -0
  94. package/dist/src/debug-logger.test.js.map +1 -0
  95. package/dist/src/deny-list.d.ts +3 -0
  96. package/dist/src/deny-list.d.ts.map +1 -0
  97. package/dist/src/deny-list.js +62 -0
  98. package/dist/src/deny-list.js.map +1 -0
  99. package/dist/src/deny-list.test.d.ts +2 -0
  100. package/dist/src/deny-list.test.d.ts.map +1 -0
  101. package/dist/src/deny-list.test.js +93 -0
  102. package/dist/src/deny-list.test.js.map +1 -0
  103. package/dist/src/e2e.test.d.ts +2 -0
  104. package/dist/src/e2e.test.d.ts.map +1 -0
  105. package/dist/src/e2e.test.js +88 -0
  106. package/dist/src/e2e.test.js.map +1 -0
  107. package/dist/src/gitignore-manager.d.ts +2 -0
  108. package/dist/src/gitignore-manager.d.ts.map +1 -0
  109. package/dist/src/gitignore-manager.js +45 -0
  110. package/dist/src/gitignore-manager.js.map +1 -0
  111. package/dist/src/gitignore-manager.test.d.ts +2 -0
  112. package/dist/src/gitignore-manager.test.d.ts.map +1 -0
  113. package/dist/src/gitignore-manager.test.js +70 -0
  114. package/dist/src/gitignore-manager.test.js.map +1 -0
  115. package/dist/src/hook-state.d.ts +43 -0
  116. package/dist/src/hook-state.d.ts.map +1 -0
  117. package/dist/src/hook-state.js +124 -0
  118. package/dist/src/hook-state.js.map +1 -0
  119. package/dist/src/hook-state.test.d.ts +2 -0
  120. package/dist/src/hook-state.test.d.ts.map +1 -0
  121. package/dist/src/hook-state.test.js +190 -0
  122. package/dist/src/hook-state.test.js.map +1 -0
  123. package/dist/src/hooks/auto-continue.d.ts +9 -0
  124. package/dist/src/hooks/auto-continue.d.ts.map +1 -0
  125. package/dist/src/hooks/auto-continue.js +56 -0
  126. package/dist/src/hooks/auto-continue.js.map +1 -0
  127. package/dist/src/hooks/auto-continue.test.d.ts +2 -0
  128. package/dist/src/hooks/auto-continue.test.d.ts.map +1 -0
  129. package/dist/src/hooks/auto-continue.test.js +141 -0
  130. package/dist/src/hooks/auto-continue.test.js.map +1 -0
  131. package/dist/src/hooks/pre-tool-use.d.ts +8 -0
  132. package/dist/src/hooks/pre-tool-use.d.ts.map +1 -0
  133. package/dist/src/hooks/pre-tool-use.js +19 -0
  134. package/dist/src/hooks/pre-tool-use.js.map +1 -0
  135. package/dist/src/hooks/pre-tool-use.test.d.ts +2 -0
  136. package/dist/src/hooks/pre-tool-use.test.d.ts.map +1 -0
  137. package/dist/src/hooks/pre-tool-use.test.js +84 -0
  138. package/dist/src/hooks/pre-tool-use.test.js.map +1 -0
  139. package/dist/src/hooks/session-start.d.ts +6 -0
  140. package/dist/src/hooks/session-start.d.ts.map +1 -0
  141. package/dist/src/hooks/session-start.js +49 -0
  142. package/dist/src/hooks/session-start.js.map +1 -0
  143. package/dist/src/hooks/session-start.test.d.ts +2 -0
  144. package/dist/src/hooks/session-start.test.d.ts.map +1 -0
  145. package/dist/src/hooks/session-start.test.js +96 -0
  146. package/dist/src/hooks/session-start.test.js.map +1 -0
  147. package/dist/src/hooks/user-prompt-submit.d.ts +6 -0
  148. package/dist/src/hooks/user-prompt-submit.d.ts.map +1 -0
  149. package/dist/src/hooks/user-prompt-submit.js +54 -0
  150. package/dist/src/hooks/user-prompt-submit.js.map +1 -0
  151. package/dist/src/hooks/user-prompt-submit.test.d.ts +2 -0
  152. package/dist/src/hooks/user-prompt-submit.test.d.ts.map +1 -0
  153. package/dist/src/hooks/user-prompt-submit.test.js +92 -0
  154. package/dist/src/hooks/user-prompt-submit.test.js.map +1 -0
  155. package/dist/src/hooks/validate-commit.d.ts +12 -0
  156. package/dist/src/hooks/validate-commit.d.ts.map +1 -0
  157. package/dist/src/hooks/validate-commit.js +58 -0
  158. package/dist/src/hooks/validate-commit.js.map +1 -0
  159. package/dist/src/hooks/validate-commit.test.d.ts +2 -0
  160. package/dist/src/hooks/validate-commit.test.d.ts.map +1 -0
  161. package/dist/src/hooks/validate-commit.test.js +150 -0
  162. package/dist/src/hooks/validate-commit.test.js.map +1 -0
  163. package/dist/src/index.d.ts +13 -0
  164. package/dist/src/index.d.ts.map +1 -0
  165. package/dist/src/index.js +38 -0
  166. package/dist/src/index.js.map +1 -0
  167. package/dist/src/linker.d.ts +6 -0
  168. package/dist/src/linker.d.ts.map +1 -0
  169. package/dist/src/linker.js +78 -0
  170. package/dist/src/linker.js.map +1 -0
  171. package/dist/src/linker.test.d.ts +2 -0
  172. package/dist/src/linker.test.d.ts.map +1 -0
  173. package/dist/src/linker.test.js +192 -0
  174. package/dist/src/linker.test.js.map +1 -0
  175. package/dist/src/logger.d.ts +21 -0
  176. package/dist/src/logger.d.ts.map +1 -0
  177. package/dist/src/logger.js +117 -0
  178. package/dist/src/logger.js.map +1 -0
  179. package/dist/src/logger.test.d.ts +2 -0
  180. package/dist/src/logger.test.d.ts.map +1 -0
  181. package/dist/src/logger.test.js +159 -0
  182. package/dist/src/logger.test.js.map +1 -0
  183. package/dist/src/postinstall.d.ts +7 -0
  184. package/dist/src/postinstall.d.ts.map +1 -0
  185. package/dist/src/postinstall.js +81 -0
  186. package/dist/src/postinstall.js.map +1 -0
  187. package/dist/src/postinstall.test.d.ts +2 -0
  188. package/dist/src/postinstall.test.d.ts.map +1 -0
  189. package/dist/src/postinstall.test.js +125 -0
  190. package/dist/src/postinstall.test.js.map +1 -0
  191. package/dist/src/preuninstall.d.ts +2 -0
  192. package/dist/src/preuninstall.d.ts.map +1 -0
  193. package/dist/src/preuninstall.js +62 -0
  194. package/dist/src/preuninstall.js.map +1 -0
  195. package/dist/src/preuninstall.test.d.ts +2 -0
  196. package/dist/src/preuninstall.test.d.ts.map +1 -0
  197. package/dist/src/preuninstall.test.js +97 -0
  198. package/dist/src/preuninstall.test.js.map +1 -0
  199. package/dist/src/root-finder.d.ts +2 -0
  200. package/dist/src/root-finder.d.ts.map +1 -0
  201. package/dist/src/root-finder.js +71 -0
  202. package/dist/src/root-finder.js.map +1 -0
  203. package/dist/src/root-finder.test.d.ts +2 -0
  204. package/dist/src/root-finder.test.d.ts.map +1 -0
  205. package/dist/src/root-finder.test.js +111 -0
  206. package/dist/src/root-finder.test.js.map +1 -0
  207. package/dist/src/settings-merger.d.ts +2 -0
  208. package/dist/src/settings-merger.d.ts.map +1 -0
  209. package/dist/src/settings-merger.js +136 -0
  210. package/dist/src/settings-merger.js.map +1 -0
  211. package/dist/src/settings-merger.test.d.ts +2 -0
  212. package/dist/src/settings-merger.test.d.ts.map +1 -0
  213. package/dist/src/settings-merger.test.js +387 -0
  214. package/dist/src/settings-merger.test.js.map +1 -0
  215. package/dist/src/skills-loader.d.ts +14 -0
  216. package/dist/src/skills-loader.d.ts.map +1 -0
  217. package/dist/src/skills-loader.js +90 -0
  218. package/dist/src/skills-loader.js.map +1 -0
  219. package/dist/src/skills-loader.test.d.ts +2 -0
  220. package/dist/src/skills-loader.test.d.ts.map +1 -0
  221. package/dist/src/skills-loader.test.js +222 -0
  222. package/dist/src/skills-loader.test.js.map +1 -0
  223. package/dist/src/state-manager.d.ts +5 -0
  224. package/dist/src/state-manager.d.ts.map +1 -0
  225. package/dist/src/state-manager.js +55 -0
  226. package/dist/src/state-manager.js.map +1 -0
  227. package/dist/src/state-manager.test.d.ts +2 -0
  228. package/dist/src/state-manager.test.d.ts.map +1 -0
  229. package/dist/src/state-manager.test.js +85 -0
  230. package/dist/src/state-manager.test.js.map +1 -0
  231. package/dist/src/subagent-classifier.d.ts +4 -0
  232. package/dist/src/subagent-classifier.d.ts.map +1 -0
  233. package/dist/src/subagent-classifier.js +53 -0
  234. package/dist/src/subagent-classifier.js.map +1 -0
  235. package/dist/src/subagent-classifier.test.d.ts +2 -0
  236. package/dist/src/subagent-classifier.test.d.ts.map +1 -0
  237. package/dist/src/subagent-classifier.test.js +88 -0
  238. package/dist/src/subagent-classifier.test.js.map +1 -0
  239. package/package.json +59 -0
  240. package/scripts/pre-tool-use.ts +10 -0
  241. package/scripts/session-start.ts +9 -0
  242. package/scripts/tail-logs.sh +17 -0
  243. package/scripts/test-hooks.sh +910 -0
  244. package/scripts/user-prompt-submit.ts +10 -0
  245. package/skills/ketchup.enforced.md +23 -0
  246. package/templates/settings.json +57 -0
@@ -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,CAAC,CAAC;AACvC,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(), 'ketchup-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-ketchup');
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-ketchup');
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(), 'ketchup-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(), 'ketchup-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(), 'ketchup-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,GAChB,KAAK,GACL,MAAM,GACN,OAAO,GACP,MAAM,GACN,MAAM,GACN,MAAM,GACN,QAAQ,GACR,UAAU,CAAC;AAaf,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,CAmEvE"}
@@ -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":""}
@@ -0,0 +1,159 @@
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 logger_js_1 = require("./logger.js");
41
+ (0, vitest_1.describe)('logger', () => {
42
+ let tempDir;
43
+ (0, vitest_1.beforeEach)(() => {
44
+ tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'ketchup-logger-'));
45
+ });
46
+ (0, vitest_1.afterEach)(() => {
47
+ fs.rmSync(tempDir, { recursive: true, force: true });
48
+ });
49
+ (0, vitest_1.describe)('createLogger', () => {
50
+ (0, vitest_1.it)('creates log file in hooks subdirectory with session prefix', () => {
51
+ const logger = (0, logger_js_1.createLogger)(tempDir, 'abc12345-full-session-id');
52
+ logger.log('INFO', 'test message');
53
+ const hooksDir = path.join(tempDir, 'hooks');
54
+ const files = fs.readdirSync(hooksDir);
55
+ const logFile = files.find((f) => f.startsWith('abc12345-') && f.endsWith('.log'));
56
+ (0, vitest_1.expect)(logFile).toBeDefined();
57
+ });
58
+ (0, vitest_1.it)('creates unknown.log in hooks subdirectory when no session id', () => {
59
+ const logger = (0, logger_js_1.createLogger)(tempDir);
60
+ logger.log('INFO', 'test message');
61
+ (0, vitest_1.expect)(fs.existsSync(path.join(tempDir, 'hooks', 'unknown.log'))).toBe(true);
62
+ });
63
+ (0, vitest_1.it)('reuses existing log file for same session prefix', () => {
64
+ const hooksDir = path.join(tempDir, 'hooks');
65
+ fs.mkdirSync(hooksDir, { recursive: true });
66
+ const existingLog = path.join(hooksDir, 'abc12345-2026-01-01T00-00-00.log');
67
+ fs.writeFileSync(existingLog, 'existing content\n');
68
+ const logger = (0, logger_js_1.createLogger)(tempDir, 'abc12345-full-session-id');
69
+ logger.log('INFO', 'new message');
70
+ const content = fs.readFileSync(existingLog, 'utf8');
71
+ (0, vitest_1.expect)(content).toContain('existing content');
72
+ (0, vitest_1.expect)(content).toContain('new message');
73
+ });
74
+ (0, vitest_1.it)('creates hooks subdirectory if it does not exist', () => {
75
+ const nestedDir = path.join(tempDir, 'nested', 'logs');
76
+ const logger = (0, logger_js_1.createLogger)(nestedDir, 'session123');
77
+ logger.log('INFO', 'test');
78
+ (0, vitest_1.expect)(fs.existsSync(path.join(nestedDir, 'hooks'))).toBe(true);
79
+ });
80
+ });
81
+ (0, vitest_1.describe)('log', () => {
82
+ (0, vitest_1.it)('writes timestamped message with log level', () => {
83
+ const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
84
+ logger.log('INFO', 'hello world');
85
+ const hooksDir = path.join(tempDir, 'hooks');
86
+ const files = fs.readdirSync(hooksDir);
87
+ const logFile = files.find((f) => f.endsWith('.log'));
88
+ const content = fs.readFileSync(path.join(hooksDir, logFile), 'utf8');
89
+ (0, vitest_1.expect)(content).toMatch(/\[\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/);
90
+ (0, vitest_1.expect)(content).toContain('INFO');
91
+ (0, vitest_1.expect)(content).toContain('hello world');
92
+ });
93
+ (0, vitest_1.it)('applies color codes to log level', () => {
94
+ const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
95
+ logger.log('ACK', 'success');
96
+ const hooksDir = path.join(tempDir, 'hooks');
97
+ const files = fs.readdirSync(hooksDir);
98
+ const logFile = files.find((f) => f.endsWith('.log'));
99
+ const content = fs.readFileSync(path.join(hooksDir, logFile), 'utf8');
100
+ (0, vitest_1.expect)(content).toContain(logger_js_1.colors.bold);
101
+ (0, vitest_1.expect)(content).toContain(logger_js_1.colors.green);
102
+ });
103
+ (0, vitest_1.it)('supports all log levels', () => {
104
+ const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
105
+ const levels = ['ACK', 'NACK', 'ERROR', 'WARN', 'SKIP', 'INFO', 'DENIED', 'CONTINUE'];
106
+ for (const level of levels) {
107
+ logger.log(level, `test ${level}`);
108
+ }
109
+ const hooksDir = path.join(tempDir, 'hooks');
110
+ const files = fs.readdirSync(hooksDir);
111
+ const logFile = files.find((f) => f.endsWith('.log'));
112
+ const content = fs.readFileSync(path.join(hooksDir, logFile), 'utf8');
113
+ for (const level of levels) {
114
+ (0, vitest_1.expect)(content).toContain(level);
115
+ }
116
+ });
117
+ });
118
+ (0, vitest_1.describe)('logError', () => {
119
+ (0, vitest_1.it)('writes error to err.log in hooks subdirectory', () => {
120
+ const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
121
+ const error = new Error('test error');
122
+ logger.logError(error, 'validate-commit');
123
+ const errLog = path.join(tempDir, 'hooks', 'err.log');
124
+ (0, vitest_1.expect)(fs.existsSync(errLog)).toBe(true);
125
+ const content = fs.readFileSync(errLog, 'utf8');
126
+ (0, vitest_1.expect)(content).toMatch(/\[\d{4}-\d{2}-\d{2}T/);
127
+ (0, vitest_1.expect)(content).toContain('[validate-commit]');
128
+ (0, vitest_1.expect)(content).toContain('test error');
129
+ });
130
+ (0, vitest_1.it)('writes error without context when not provided', () => {
131
+ const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
132
+ logger.logError(new Error('bare error'));
133
+ const errLog = path.join(tempDir, 'hooks', 'err.log');
134
+ const content = fs.readFileSync(errLog, 'utf8');
135
+ (0, vitest_1.expect)(content).toContain('bare error');
136
+ (0, vitest_1.expect)(content).not.toContain('[]');
137
+ });
138
+ (0, vitest_1.it)('handles non-Error objects', () => {
139
+ const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
140
+ logger.logError('string error');
141
+ const errLog = path.join(tempDir, 'hooks', 'err.log');
142
+ const content = fs.readFileSync(errLog, 'utf8');
143
+ (0, vitest_1.expect)(content).toContain('string error');
144
+ });
145
+ });
146
+ (0, vitest_1.describe)('colors', () => {
147
+ (0, vitest_1.it)('exports ANSI color codes', () => {
148
+ (0, vitest_1.expect)(logger_js_1.colors.reset).toBe('\x1b[0m');
149
+ (0, vitest_1.expect)(logger_js_1.colors.dim).toBe('\x1b[2m');
150
+ (0, vitest_1.expect)(logger_js_1.colors.bold).toBe('\x1b[1m');
151
+ (0, vitest_1.expect)(logger_js_1.colors.red).toBe('\x1b[31m');
152
+ (0, vitest_1.expect)(logger_js_1.colors.green).toBe('\x1b[32m');
153
+ (0, vitest_1.expect)(logger_js_1.colors.yellow).toBe('\x1b[33m');
154
+ (0, vitest_1.expect)(logger_js_1.colors.cyan).toBe('\x1b[36m');
155
+ (0, vitest_1.expect)(logger_js_1.colors.magenta).toBe('\x1b[35m');
156
+ });
157
+ });
158
+ });
159
+ //# sourceMappingURL=logger.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.test.js","sourceRoot":"","sources":["../../src/logger.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ export interface PostinstallResult {
2
+ projectRoot: string;
3
+ claudeDir: string;
4
+ symlinkedFiles: string[];
5
+ }
6
+ export declare function runPostinstall(packageDir?: string): PostinstallResult;
7
+ //# sourceMappingURL=postinstall.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"postinstall.d.ts","sourceRoot":"","sources":["../../src/postinstall.ts"],"names":[],"mappings":"AAUA,MAAM,WAAW,iBAAiB;IAChC,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,EAAE,CAAC;CAC1B;AAgBD,wBAAgB,cAAc,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,iBAAiB,CA2BrE"}