@camaradesuk/git-worktree-tools 1.6.0 → 1.8.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 (334) hide show
  1. package/README.md +371 -421
  2. package/dist/cli/cleanpr.js +11 -5
  3. package/dist/cli/cleanpr.js.map +1 -1
  4. package/dist/cli/cleanpr.test.js +12 -1
  5. package/dist/cli/cleanpr.test.js.map +1 -1
  6. package/dist/cli/newpr.js +148 -39
  7. package/dist/cli/newpr.js.map +1 -1
  8. package/dist/cli/newpr.test.js +57 -21
  9. package/dist/cli/newpr.test.js.map +1 -1
  10. package/dist/cli/prs.d.ts +22 -0
  11. package/dist/cli/prs.d.ts.map +1 -0
  12. package/dist/cli/prs.js +275 -0
  13. package/dist/cli/prs.js.map +1 -0
  14. package/dist/cli/prs.test.d.ts +8 -0
  15. package/dist/cli/prs.test.d.ts.map +1 -0
  16. package/dist/cli/prs.test.js +408 -0
  17. package/dist/cli/prs.test.js.map +1 -0
  18. package/dist/cli/wt/clean.d.ts +1 -0
  19. package/dist/cli/wt/clean.d.ts.map +1 -1
  20. package/dist/cli/wt/clean.js +11 -1
  21. package/dist/cli/wt/clean.js.map +1 -1
  22. package/dist/cli/wt/config.d.ts +1 -1
  23. package/dist/cli/wt/config.d.ts.map +1 -1
  24. package/dist/cli/wt/config.js +148 -13
  25. package/dist/cli/wt/config.js.map +1 -1
  26. package/dist/cli/wt/config.test.d.ts +5 -0
  27. package/dist/cli/wt/config.test.d.ts.map +1 -0
  28. package/dist/cli/wt/config.test.js +260 -0
  29. package/dist/cli/wt/config.test.js.map +1 -0
  30. package/dist/cli/wt/entry.test.js +11 -8
  31. package/dist/cli/wt/entry.test.js.map +1 -1
  32. package/dist/cli/wt/init.d.ts +14 -0
  33. package/dist/cli/wt/init.d.ts.map +1 -0
  34. package/dist/cli/wt/init.js +209 -0
  35. package/dist/cli/wt/init.js.map +1 -0
  36. package/dist/cli/wt/init.test.d.ts +5 -0
  37. package/dist/cli/wt/init.test.d.ts.map +1 -0
  38. package/dist/cli/wt/init.test.js +165 -0
  39. package/dist/cli/wt/init.test.js.map +1 -0
  40. package/dist/cli/wt/init.unit.test.d.ts +5 -0
  41. package/dist/cli/wt/init.unit.test.d.ts.map +1 -0
  42. package/dist/cli/wt/init.unit.test.js +432 -0
  43. package/dist/cli/wt/init.unit.test.js.map +1 -0
  44. package/dist/cli/wt/interactive-menu.d.ts +43 -0
  45. package/dist/cli/wt/interactive-menu.d.ts.map +1 -0
  46. package/dist/cli/wt/interactive-menu.js +656 -0
  47. package/dist/cli/wt/interactive-menu.js.map +1 -0
  48. package/dist/cli/wt/interactive-menu.test.d.ts +10 -0
  49. package/dist/cli/wt/interactive-menu.test.d.ts.map +1 -0
  50. package/dist/cli/wt/interactive-menu.test.js +736 -0
  51. package/dist/cli/wt/interactive-menu.test.js.map +1 -0
  52. package/dist/cli/wt/link.d.ts +9 -0
  53. package/dist/cli/wt/link.d.ts.map +1 -1
  54. package/dist/cli/wt/link.js +27 -0
  55. package/dist/cli/wt/link.js.map +1 -1
  56. package/dist/cli/wt/list.d.ts +2 -2
  57. package/dist/cli/wt/list.d.ts.map +1 -1
  58. package/dist/cli/wt/list.js +17 -17
  59. package/dist/cli/wt/list.js.map +1 -1
  60. package/dist/cli/wt/new.d.ts +7 -1
  61. package/dist/cli/wt/new.d.ts.map +1 -1
  62. package/dist/cli/wt/new.js +58 -6
  63. package/dist/cli/wt/new.js.map +1 -1
  64. package/dist/cli/wt/prs.d.ts +21 -0
  65. package/dist/cli/wt/prs.d.ts.map +1 -0
  66. package/dist/cli/wt/prs.js +251 -0
  67. package/dist/cli/wt/prs.js.map +1 -0
  68. package/dist/cli/wt/prs.test.d.ts +5 -0
  69. package/dist/cli/wt/prs.test.d.ts.map +1 -0
  70. package/dist/cli/wt/prs.test.js +410 -0
  71. package/dist/cli/wt/prs.test.js.map +1 -0
  72. package/dist/cli/wt/wt.test.js +159 -16
  73. package/dist/cli/wt/wt.test.js.map +1 -1
  74. package/dist/cli/wt.d.ts +3 -1
  75. package/dist/cli/wt.d.ts.map +1 -1
  76. package/dist/cli/wt.js +103 -3
  77. package/dist/cli/wt.js.map +1 -1
  78. package/dist/cli/wt.unit.test.d.ts +7 -0
  79. package/dist/cli/wt.unit.test.d.ts.map +1 -0
  80. package/dist/cli/wt.unit.test.js +182 -0
  81. package/dist/cli/wt.unit.test.js.map +1 -0
  82. package/dist/cli/wtconfig.js +18 -4
  83. package/dist/cli/wtconfig.js.map +1 -1
  84. package/dist/cli/wtconfig.test.js +21 -16
  85. package/dist/cli/wtconfig.test.js.map +1 -1
  86. package/dist/cli/wtlink.d.ts +2 -1
  87. package/dist/cli/wtlink.d.ts.map +1 -1
  88. package/dist/cli/wtlink.js +41 -2
  89. package/dist/cli/wtlink.js.map +1 -1
  90. package/dist/e2e/cli.e2e.test.js +6 -2
  91. package/dist/e2e/cli.e2e.test.js.map +1 -1
  92. package/dist/e2e/helpers/cli-runner.d.ts.map +1 -1
  93. package/dist/e2e/helpers/cli-runner.js +1 -0
  94. package/dist/e2e/helpers/cli-runner.js.map +1 -1
  95. package/dist/e2e/helpers/gh-mock.d.ts.map +1 -1
  96. package/dist/e2e/helpers/gh-mock.js +55 -1
  97. package/dist/e2e/helpers/gh-mock.js.map +1 -1
  98. package/dist/e2e/helpers/pty-wrapper.d.ts +15 -0
  99. package/dist/e2e/helpers/pty-wrapper.d.ts.map +1 -1
  100. package/dist/e2e/helpers/pty-wrapper.js +65 -0
  101. package/dist/e2e/helpers/pty-wrapper.js.map +1 -1
  102. package/dist/e2e/newpr/scenarios.e2e.test.js +7 -7
  103. package/dist/e2e/newpr/scenarios.e2e.test.js.map +1 -1
  104. package/dist/e2e/newpr-full-flow.e2e.test.js +1 -0
  105. package/dist/e2e/newpr-full-flow.e2e.test.js.map +1 -1
  106. package/dist/e2e/prs/prs.e2e.test.d.ts +7 -0
  107. package/dist/e2e/prs/prs.e2e.test.d.ts.map +1 -0
  108. package/dist/e2e/prs/prs.e2e.test.js +606 -0
  109. package/dist/e2e/prs/prs.e2e.test.js.map +1 -0
  110. package/dist/e2e/wt/interactive-menu.e2e.test.d.ts +8 -0
  111. package/dist/e2e/wt/interactive-menu.e2e.test.d.ts.map +1 -0
  112. package/dist/e2e/wt/interactive-menu.e2e.test.js +583 -0
  113. package/dist/e2e/wt/interactive-menu.e2e.test.js.map +1 -0
  114. package/dist/e2e/wt/wt.e2e.test.d.ts +9 -0
  115. package/dist/e2e/wt/wt.e2e.test.d.ts.map +1 -0
  116. package/dist/e2e/wt/wt.e2e.test.js +597 -0
  117. package/dist/e2e/wt/wt.e2e.test.js.map +1 -0
  118. package/dist/integration/prs.integration.test.d.ts +8 -0
  119. package/dist/integration/prs.integration.test.d.ts.map +1 -0
  120. package/dist/integration/prs.integration.test.js +478 -0
  121. package/dist/integration/prs.integration.test.js.map +1 -0
  122. package/dist/lib/ai/base-provider.d.ts +22 -0
  123. package/dist/lib/ai/base-provider.d.ts.map +1 -1
  124. package/dist/lib/ai/base-provider.js +180 -99
  125. package/dist/lib/ai/base-provider.js.map +1 -1
  126. package/dist/lib/ai/base-provider.test.js +13 -14
  127. package/dist/lib/ai/base-provider.test.js.map +1 -1
  128. package/dist/lib/ai/cli-provider.d.ts +11 -7
  129. package/dist/lib/ai/cli-provider.d.ts.map +1 -1
  130. package/dist/lib/ai/cli-provider.js +19 -49
  131. package/dist/lib/ai/cli-provider.js.map +1 -1
  132. package/dist/lib/ai/cli-provider.test.js +47 -49
  133. package/dist/lib/ai/cli-provider.test.js.map +1 -1
  134. package/dist/lib/ai/index.d.ts +2 -1
  135. package/dist/lib/ai/index.d.ts.map +1 -1
  136. package/dist/lib/ai/index.js +2 -0
  137. package/dist/lib/ai/index.js.map +1 -1
  138. package/dist/lib/ai/provider-manager.js +2 -2
  139. package/dist/lib/ai/provider-manager.js.map +1 -1
  140. package/dist/lib/ai/repo-docs.d.ts +43 -0
  141. package/dist/lib/ai/repo-docs.d.ts.map +1 -0
  142. package/dist/lib/ai/repo-docs.js +274 -0
  143. package/dist/lib/ai/repo-docs.js.map +1 -0
  144. package/dist/lib/ai/repo-docs.test.d.ts +5 -0
  145. package/dist/lib/ai/repo-docs.test.d.ts.map +1 -0
  146. package/dist/lib/ai/repo-docs.test.js +357 -0
  147. package/dist/lib/ai/repo-docs.test.js.map +1 -0
  148. package/dist/lib/ai/types.d.ts +18 -2
  149. package/dist/lib/ai/types.d.ts.map +1 -1
  150. package/dist/lib/ai/types.js.map +1 -1
  151. package/dist/lib/config-editor.d.ts +21 -0
  152. package/dist/lib/config-editor.d.ts.map +1 -0
  153. package/dist/lib/config-editor.js +729 -0
  154. package/dist/lib/config-editor.js.map +1 -0
  155. package/dist/lib/config-editor.test.d.ts +11 -0
  156. package/dist/lib/config-editor.test.d.ts.map +1 -0
  157. package/dist/lib/config-editor.test.js +526 -0
  158. package/dist/lib/config-editor.test.js.map +1 -0
  159. package/dist/lib/config-validation.d.ts +28 -0
  160. package/dist/lib/config-validation.d.ts.map +1 -0
  161. package/dist/lib/config-validation.js +590 -0
  162. package/dist/lib/config-validation.js.map +1 -0
  163. package/dist/lib/config-validation.test.d.ts +5 -0
  164. package/dist/lib/config-validation.test.d.ts.map +1 -0
  165. package/dist/lib/config-validation.test.js +398 -0
  166. package/dist/lib/config-validation.test.js.map +1 -0
  167. package/dist/lib/config.d.ts +149 -6
  168. package/dist/lib/config.d.ts.map +1 -1
  169. package/dist/lib/config.js +261 -55
  170. package/dist/lib/config.js.map +1 -1
  171. package/dist/lib/config.test.js +2 -1
  172. package/dist/lib/config.test.js.map +1 -1
  173. package/dist/lib/constants.d.ts +50 -1
  174. package/dist/lib/constants.d.ts.map +1 -1
  175. package/dist/lib/constants.js +67 -1
  176. package/dist/lib/constants.js.map +1 -1
  177. package/dist/lib/constants.test.d.ts +5 -0
  178. package/dist/lib/constants.test.d.ts.map +1 -0
  179. package/dist/lib/constants.test.js +121 -0
  180. package/dist/lib/constants.test.js.map +1 -0
  181. package/dist/lib/git.d.ts +44 -0
  182. package/dist/lib/git.d.ts.map +1 -1
  183. package/dist/lib/git.js +121 -1
  184. package/dist/lib/git.js.map +1 -1
  185. package/dist/lib/git.test.js +118 -1
  186. package/dist/lib/git.test.js.map +1 -1
  187. package/dist/lib/github.d.ts +41 -0
  188. package/dist/lib/github.d.ts.map +1 -1
  189. package/dist/lib/github.js +109 -0
  190. package/dist/lib/github.js.map +1 -1
  191. package/dist/lib/global-check.d.ts +38 -0
  192. package/dist/lib/global-check.d.ts.map +1 -0
  193. package/dist/lib/global-check.js +135 -0
  194. package/dist/lib/global-check.js.map +1 -0
  195. package/dist/lib/global-check.test.d.ts +5 -0
  196. package/dist/lib/global-check.test.d.ts.map +1 -0
  197. package/dist/lib/global-check.test.js +150 -0
  198. package/dist/lib/global-check.test.js.map +1 -0
  199. package/dist/lib/global-config.d.ts +102 -0
  200. package/dist/lib/global-config.d.ts.map +1 -0
  201. package/dist/lib/global-config.js +234 -0
  202. package/dist/lib/global-config.js.map +1 -0
  203. package/dist/lib/global-config.test.d.ts +5 -0
  204. package/dist/lib/global-config.test.d.ts.map +1 -0
  205. package/dist/lib/global-config.test.js +282 -0
  206. package/dist/lib/global-config.test.js.map +1 -0
  207. package/dist/lib/json-output.d.ts +1 -0
  208. package/dist/lib/json-output.d.ts.map +1 -1
  209. package/dist/lib/json-output.js +2 -0
  210. package/dist/lib/json-output.js.map +1 -1
  211. package/dist/lib/logger.d.ts +175 -0
  212. package/dist/lib/logger.d.ts.map +1 -0
  213. package/dist/lib/logger.js +475 -0
  214. package/dist/lib/logger.js.map +1 -0
  215. package/dist/lib/logger.test.d.ts +5 -0
  216. package/dist/lib/logger.test.d.ts.map +1 -0
  217. package/dist/lib/logger.test.js +292 -0
  218. package/dist/lib/logger.test.js.map +1 -0
  219. package/dist/lib/lswt/action-executors.d.ts.map +1 -1
  220. package/dist/lib/lswt/action-executors.js +2 -1
  221. package/dist/lib/lswt/action-executors.js.map +1 -1
  222. package/dist/lib/lswt/action-executors.test.js +3 -0
  223. package/dist/lib/lswt/action-executors.test.js.map +1 -1
  224. package/dist/lib/lswt/actions.d.ts +1 -0
  225. package/dist/lib/lswt/actions.d.ts.map +1 -1
  226. package/dist/lib/lswt/actions.js +38 -10
  227. package/dist/lib/lswt/actions.js.map +1 -1
  228. package/dist/lib/lswt/actions.test.js +34 -22
  229. package/dist/lib/lswt/actions.test.js.map +1 -1
  230. package/dist/lib/lswt/interactive.js +8 -8
  231. package/dist/lib/lswt/interactive.js.map +1 -1
  232. package/dist/lib/newpr/args.d.ts.map +1 -1
  233. package/dist/lib/newpr/args.js +9 -2
  234. package/dist/lib/newpr/args.js.map +1 -1
  235. package/dist/lib/newpr/args.test.js +1 -1
  236. package/dist/lib/newpr/args.test.js.map +1 -1
  237. package/dist/lib/newpr/types.d.ts +2 -0
  238. package/dist/lib/newpr/types.d.ts.map +1 -1
  239. package/dist/lib/prompts.d.ts +6 -0
  240. package/dist/lib/prompts.d.ts.map +1 -1
  241. package/dist/lib/prompts.js +39 -13
  242. package/dist/lib/prompts.js.map +1 -1
  243. package/dist/lib/prompts.test.js +72 -1
  244. package/dist/lib/prompts.test.js.map +1 -1
  245. package/dist/lib/prs/actions.d.ts +70 -0
  246. package/dist/lib/prs/actions.d.ts.map +1 -0
  247. package/dist/lib/prs/actions.js +444 -0
  248. package/dist/lib/prs/actions.js.map +1 -0
  249. package/dist/lib/prs/actions.test.d.ts +5 -0
  250. package/dist/lib/prs/actions.test.d.ts.map +1 -0
  251. package/dist/lib/prs/actions.test.js +313 -0
  252. package/dist/lib/prs/actions.test.js.map +1 -0
  253. package/dist/lib/prs/data.d.ts +48 -0
  254. package/dist/lib/prs/data.d.ts.map +1 -0
  255. package/dist/lib/prs/data.js +171 -0
  256. package/dist/lib/prs/data.js.map +1 -0
  257. package/dist/lib/prs/data.test.d.ts +5 -0
  258. package/dist/lib/prs/data.test.d.ts.map +1 -0
  259. package/dist/lib/prs/data.test.js +417 -0
  260. package/dist/lib/prs/data.test.js.map +1 -0
  261. package/dist/lib/prs/details.d.ts +57 -0
  262. package/dist/lib/prs/details.d.ts.map +1 -0
  263. package/dist/lib/prs/details.js +246 -0
  264. package/dist/lib/prs/details.js.map +1 -0
  265. package/dist/lib/prs/details.test.d.ts +5 -0
  266. package/dist/lib/prs/details.test.d.ts.map +1 -0
  267. package/dist/lib/prs/details.test.js +325 -0
  268. package/dist/lib/prs/details.test.js.map +1 -0
  269. package/dist/lib/prs/filters.d.ts +56 -0
  270. package/dist/lib/prs/filters.d.ts.map +1 -0
  271. package/dist/lib/prs/filters.js +171 -0
  272. package/dist/lib/prs/filters.js.map +1 -0
  273. package/dist/lib/prs/filters.test.d.ts +5 -0
  274. package/dist/lib/prs/filters.test.d.ts.map +1 -0
  275. package/dist/lib/prs/filters.test.js +312 -0
  276. package/dist/lib/prs/filters.test.js.map +1 -0
  277. package/dist/lib/prs/formatters.d.ts +83 -0
  278. package/dist/lib/prs/formatters.d.ts.map +1 -0
  279. package/dist/lib/prs/formatters.js +389 -0
  280. package/dist/lib/prs/formatters.js.map +1 -0
  281. package/dist/lib/prs/formatters.test.d.ts +2 -0
  282. package/dist/lib/prs/formatters.test.d.ts.map +1 -0
  283. package/dist/lib/prs/formatters.test.js +387 -0
  284. package/dist/lib/prs/formatters.test.js.map +1 -0
  285. package/dist/lib/prs/interactive.d.ts +50 -0
  286. package/dist/lib/prs/interactive.d.ts.map +1 -0
  287. package/dist/lib/prs/interactive.js +453 -0
  288. package/dist/lib/prs/interactive.js.map +1 -0
  289. package/dist/lib/prs/interactive.test.d.ts +5 -0
  290. package/dist/lib/prs/interactive.test.d.ts.map +1 -0
  291. package/dist/lib/prs/interactive.test.js +364 -0
  292. package/dist/lib/prs/interactive.test.js.map +1 -0
  293. package/dist/lib/prs/types.d.ts +152 -0
  294. package/dist/lib/prs/types.d.ts.map +1 -0
  295. package/dist/lib/prs/types.js +17 -0
  296. package/dist/lib/prs/types.js.map +1 -0
  297. package/dist/lib/schema.test.d.ts +10 -0
  298. package/dist/lib/schema.test.d.ts.map +1 -0
  299. package/dist/lib/schema.test.js +309 -0
  300. package/dist/lib/schema.test.js.map +1 -0
  301. package/dist/lib/wtconfig/environment.d.ts.map +1 -1
  302. package/dist/lib/wtconfig/environment.js +6 -4
  303. package/dist/lib/wtconfig/environment.js.map +1 -1
  304. package/dist/lib/wtconfig/environment.test.js +2 -7
  305. package/dist/lib/wtconfig/environment.test.js.map +1 -1
  306. package/dist/lib/wtconfig/types.d.ts +3 -1
  307. package/dist/lib/wtconfig/types.d.ts.map +1 -1
  308. package/dist/lib/wtlink/config-manifest.d.ts +101 -0
  309. package/dist/lib/wtlink/config-manifest.d.ts.map +1 -0
  310. package/dist/lib/wtlink/config-manifest.js +219 -0
  311. package/dist/lib/wtlink/config-manifest.js.map +1 -0
  312. package/dist/lib/wtlink/config-manifest.test.d.ts +2 -0
  313. package/dist/lib/wtlink/config-manifest.test.d.ts.map +1 -0
  314. package/dist/lib/wtlink/config-manifest.test.js +460 -0
  315. package/dist/lib/wtlink/config-manifest.test.js.map +1 -0
  316. package/dist/lib/wtlink/link-configs.d.ts.map +1 -1
  317. package/dist/lib/wtlink/link-configs.js +36 -11
  318. package/dist/lib/wtlink/link-configs.js.map +1 -1
  319. package/dist/lib/wtlink/main-menu.d.ts.map +1 -1
  320. package/dist/lib/wtlink/main-menu.js +58 -50
  321. package/dist/lib/wtlink/main-menu.js.map +1 -1
  322. package/dist/lib/wtlink/main-menu.test.js +42 -40
  323. package/dist/lib/wtlink/main-menu.test.js.map +1 -1
  324. package/dist/lib/wtlink/manage-manifest.d.ts +9 -0
  325. package/dist/lib/wtlink/manage-manifest.d.ts.map +1 -1
  326. package/dist/lib/wtlink/manage-manifest.js +346 -25
  327. package/dist/lib/wtlink/manage-manifest.js.map +1 -1
  328. package/dist/lib/wtlink/manage-manifest.test.js +196 -7
  329. package/dist/lib/wtlink/manage-manifest.test.js.map +1 -1
  330. package/dist/lib/wtlink/validate-manifest.d.ts.map +1 -1
  331. package/dist/lib/wtlink/validate-manifest.js +27 -6
  332. package/dist/lib/wtlink/validate-manifest.js.map +1 -1
  333. package/package.json +2 -1
  334. package/schemas/worktreerc.schema.json +441 -0
@@ -0,0 +1,475 @@
1
+ /**
2
+ * Logging system for git-worktree-tools
3
+ *
4
+ * Provides a singleton logger with:
5
+ * - Multiple log levels (silent, error, warn, info, debug, trace)
6
+ * - Console and file output support
7
+ * - Log file rotation
8
+ * - Timestamps and context
9
+ * - Color support for console output
10
+ *
11
+ * Configuration sources (in order of priority):
12
+ * 1. CLI flags (--verbose, --debug, --log-file)
13
+ * 2. Environment variables (GWT_LOG_LEVEL, GWT_LOG_FILE)
14
+ * 3. Config files (logLevel, logFile properties)
15
+ */
16
+ import fs from 'fs';
17
+ import path from 'path';
18
+ import { LogLevel, DEFAULT_LOG_LEVEL, MAX_LOG_FILE_SIZE, MAX_LOG_FILES, getGlobalLogDir, } from './constants.js';
19
+ import { red, yellow, cyan, gray, bold } from './colors.js';
20
+ export { LogLevel };
21
+ /**
22
+ * Parse log level from string
23
+ */
24
+ export function parseLogLevel(value) {
25
+ const normalized = value.toLowerCase().trim();
26
+ const mapping = {
27
+ silent: LogLevel.SILENT,
28
+ error: LogLevel.ERROR,
29
+ warn: LogLevel.WARN,
30
+ warning: LogLevel.WARN,
31
+ info: LogLevel.INFO,
32
+ debug: LogLevel.DEBUG,
33
+ trace: LogLevel.TRACE,
34
+ verbose: LogLevel.DEBUG,
35
+ '0': LogLevel.SILENT,
36
+ '1': LogLevel.ERROR,
37
+ '2': LogLevel.WARN,
38
+ '3': LogLevel.INFO,
39
+ '4': LogLevel.DEBUG,
40
+ '5': LogLevel.TRACE,
41
+ };
42
+ return mapping[normalized];
43
+ }
44
+ /**
45
+ * Get log level name
46
+ */
47
+ function getLevelName(level) {
48
+ const names = {
49
+ [LogLevel.SILENT]: 'SILENT',
50
+ [LogLevel.ERROR]: 'ERROR',
51
+ [LogLevel.WARN]: 'WARN',
52
+ [LogLevel.INFO]: 'INFO',
53
+ [LogLevel.DEBUG]: 'DEBUG',
54
+ [LogLevel.TRACE]: 'TRACE',
55
+ };
56
+ return names[level] || 'UNKNOWN';
57
+ }
58
+ /**
59
+ * Format a log message for console output with colors
60
+ */
61
+ function formatConsoleMessage(level, message, timestamp, useColors) {
62
+ const parts = [];
63
+ if (timestamp) {
64
+ parts.push(useColors ? gray(`[${timestamp}]`) : `[${timestamp}]`);
65
+ }
66
+ const levelStr = getLevelName(level).padEnd(5);
67
+ let formattedLevel;
68
+ let formattedMessage;
69
+ if (useColors) {
70
+ switch (level) {
71
+ case LogLevel.ERROR:
72
+ formattedLevel = red(bold(levelStr));
73
+ formattedMessage = red(message);
74
+ break;
75
+ case LogLevel.WARN:
76
+ formattedLevel = yellow(bold(levelStr));
77
+ formattedMessage = yellow(message);
78
+ break;
79
+ case LogLevel.DEBUG:
80
+ case LogLevel.TRACE:
81
+ formattedLevel = gray(levelStr);
82
+ formattedMessage = gray(message);
83
+ break;
84
+ default:
85
+ formattedLevel = cyan(levelStr);
86
+ formattedMessage = message;
87
+ }
88
+ }
89
+ else {
90
+ formattedLevel = levelStr;
91
+ formattedMessage = message;
92
+ }
93
+ parts.push(formattedLevel);
94
+ parts.push(formattedMessage);
95
+ return parts.join(' ');
96
+ }
97
+ /**
98
+ * Singleton Logger class
99
+ */
100
+ class Logger {
101
+ static instance = null;
102
+ level = DEFAULT_LOG_LEVEL;
103
+ logFile = null;
104
+ fileStream = null;
105
+ timestamps = true;
106
+ colors = true;
107
+ consoleOutput = true;
108
+ context = null;
109
+ initialized = false;
110
+ constructor() {
111
+ // Private constructor for singleton
112
+ }
113
+ /**
114
+ * Get the singleton logger instance
115
+ */
116
+ static getInstance() {
117
+ if (!Logger.instance) {
118
+ Logger.instance = new Logger();
119
+ }
120
+ return Logger.instance;
121
+ }
122
+ /**
123
+ * Initialize the logger with configuration
124
+ * Should be called early in CLI startup
125
+ */
126
+ initialize(config = {}) {
127
+ // Determine log level from multiple sources (priority order)
128
+ // 1. Explicit config (from CLI flags)
129
+ // 2. Environment variable
130
+ // 3. Default
131
+ if (config.level !== undefined) {
132
+ this.level = config.level;
133
+ }
134
+ else {
135
+ const envLevel = process.env.GWT_LOG_LEVEL;
136
+ if (envLevel) {
137
+ const parsed = parseLogLevel(envLevel);
138
+ if (parsed !== undefined) {
139
+ this.level = parsed;
140
+ }
141
+ }
142
+ }
143
+ // Determine log file from multiple sources
144
+ if (config.logFile !== undefined) {
145
+ this.logFile = config.logFile;
146
+ }
147
+ else {
148
+ const envLogFile = process.env.GWT_LOG_FILE;
149
+ if (envLogFile) {
150
+ this.logFile = envLogFile;
151
+ }
152
+ }
153
+ if (config.timestamps !== undefined) {
154
+ this.timestamps = config.timestamps;
155
+ }
156
+ if (config.colors !== undefined) {
157
+ this.colors = config.colors;
158
+ }
159
+ if (config.consoleOutput !== undefined) {
160
+ this.consoleOutput = config.consoleOutput;
161
+ }
162
+ // Set up file logging if configured
163
+ if (this.logFile) {
164
+ this.setupFileLogging(this.logFile);
165
+ }
166
+ this.initialized = true;
167
+ }
168
+ /**
169
+ * Set up file logging with rotation
170
+ */
171
+ setupFileLogging(filePath) {
172
+ try {
173
+ // Ensure directory exists
174
+ const dir = path.dirname(filePath);
175
+ fs.mkdirSync(dir, { recursive: true });
176
+ // Check if rotation is needed
177
+ if (fs.existsSync(filePath)) {
178
+ const stats = fs.statSync(filePath);
179
+ if (stats.size > MAX_LOG_FILE_SIZE) {
180
+ this.rotateLogFiles(filePath);
181
+ }
182
+ }
183
+ // Open file stream in append mode
184
+ this.fileStream = fs.createWriteStream(filePath, { flags: 'a' });
185
+ this.fileStream.on('error', (err) => {
186
+ console.error(`Logger: Failed to write to log file: ${err.message}`);
187
+ this.fileStream = null;
188
+ });
189
+ }
190
+ catch (err) {
191
+ const message = err instanceof Error ? err.message : String(err);
192
+ console.error(`Logger: Failed to set up file logging: ${message}`);
193
+ }
194
+ }
195
+ /**
196
+ * Rotate log files
197
+ */
198
+ rotateLogFiles(filePath) {
199
+ try {
200
+ // Shift existing rotated files
201
+ for (let i = MAX_LOG_FILES - 1; i >= 1; i--) {
202
+ const older = `${filePath}.${i}`;
203
+ const newer = i === 1 ? filePath : `${filePath}.${i - 1}`;
204
+ if (fs.existsSync(newer)) {
205
+ if (i === MAX_LOG_FILES - 1 && fs.existsSync(older)) {
206
+ fs.unlinkSync(older);
207
+ }
208
+ fs.renameSync(newer, older);
209
+ }
210
+ }
211
+ }
212
+ catch (err) {
213
+ const message = err instanceof Error ? err.message : String(err);
214
+ console.error(`Logger: Failed to rotate log files: ${message}`);
215
+ }
216
+ }
217
+ /**
218
+ * Set the current context (e.g., command name)
219
+ */
220
+ setContext(context) {
221
+ this.context = context;
222
+ }
223
+ /**
224
+ * Set the log level
225
+ */
226
+ setLevel(level) {
227
+ this.level = level;
228
+ }
229
+ /**
230
+ * Get the current log level
231
+ */
232
+ getLevel() {
233
+ return this.level;
234
+ }
235
+ /**
236
+ * Check if a log level is enabled
237
+ */
238
+ isLevelEnabled(level) {
239
+ return level <= this.level;
240
+ }
241
+ /**
242
+ * Check if the logger is in debug mode
243
+ */
244
+ isDebug() {
245
+ return this.level >= LogLevel.DEBUG;
246
+ }
247
+ /**
248
+ * Check if the logger is in trace mode
249
+ */
250
+ isTrace() {
251
+ return this.level >= LogLevel.TRACE;
252
+ }
253
+ /**
254
+ * Internal log method
255
+ */
256
+ log(level, message, ...args) {
257
+ this.logWithContext(level, this.context, message, ...args);
258
+ }
259
+ /**
260
+ * Internal log method with explicit context (thread-safe for child loggers)
261
+ */
262
+ logWithContext(level, context, message, ...args) {
263
+ if (level > this.level) {
264
+ return;
265
+ }
266
+ const timestamp = this.timestamps ? new Date().toISOString() : null;
267
+ const formattedMessage = args.length > 0 ? this.formatMessage(message, args) : message;
268
+ // Console output
269
+ if (this.consoleOutput || !this.fileStream) {
270
+ const consoleMsg = formatConsoleMessage(level, formattedMessage, timestamp, this.colors && process.stdout.isTTY === true);
271
+ if (level === LogLevel.ERROR) {
272
+ console.error(consoleMsg);
273
+ }
274
+ else if (level === LogLevel.WARN) {
275
+ console.warn(consoleMsg);
276
+ }
277
+ else {
278
+ console.log(consoleMsg);
279
+ }
280
+ }
281
+ // File output
282
+ if (this.fileStream) {
283
+ const entry = {
284
+ timestamp: timestamp || new Date().toISOString(),
285
+ level: getLevelName(level),
286
+ message: formattedMessage,
287
+ };
288
+ if (context) {
289
+ entry.context = context;
290
+ }
291
+ if (args.length > 0 && typeof args[0] === 'object') {
292
+ entry.data = args[0];
293
+ }
294
+ this.fileStream.write(JSON.stringify(entry) + '\n');
295
+ }
296
+ }
297
+ /**
298
+ * Format message with arguments (simple substitution)
299
+ */
300
+ formatMessage(message, args) {
301
+ let result = message;
302
+ for (const arg of args) {
303
+ const replacement = typeof arg === 'object' ? JSON.stringify(arg) : String(arg);
304
+ result = result.replace('%s', replacement);
305
+ result = result.replace('%d', replacement);
306
+ result = result.replace('%j', typeof arg === 'object' ? JSON.stringify(arg) : replacement);
307
+ result = result.replace('%o', typeof arg === 'object' ? JSON.stringify(arg) : replacement);
308
+ }
309
+ // Append remaining args if placeholders exhausted
310
+ const placeholders = (message.match(/%[sdjo]/g) || []).length;
311
+ if (args.length > placeholders) {
312
+ const extra = args
313
+ .slice(placeholders)
314
+ .map((a) => (typeof a === 'object' ? JSON.stringify(a) : String(a)));
315
+ result += ' ' + extra.join(' ');
316
+ }
317
+ return result;
318
+ }
319
+ /**
320
+ * Log an error message
321
+ */
322
+ error(message, ...args) {
323
+ this.log(LogLevel.ERROR, message, ...args);
324
+ }
325
+ /**
326
+ * Log a warning message
327
+ */
328
+ warn(message, ...args) {
329
+ this.log(LogLevel.WARN, message, ...args);
330
+ }
331
+ /**
332
+ * Log an info message
333
+ */
334
+ info(message, ...args) {
335
+ this.log(LogLevel.INFO, message, ...args);
336
+ }
337
+ /**
338
+ * Log a debug message
339
+ */
340
+ debug(message, ...args) {
341
+ this.log(LogLevel.DEBUG, message, ...args);
342
+ }
343
+ /**
344
+ * Log a trace message
345
+ */
346
+ trace(message, ...args) {
347
+ this.log(LogLevel.TRACE, message, ...args);
348
+ }
349
+ /**
350
+ * Log an error with stack trace
351
+ */
352
+ errorWithStack(err, message) {
353
+ const msg = message ? `${message}: ${err.message}` : err.message;
354
+ this.error(msg);
355
+ if (this.level >= LogLevel.DEBUG && err.stack) {
356
+ this.debug(err.stack);
357
+ }
358
+ }
359
+ /**
360
+ * Create a child logger with a specific context
361
+ */
362
+ child(context) {
363
+ return new ChildLogger(this, context);
364
+ }
365
+ /**
366
+ * Close the logger (flush file stream)
367
+ */
368
+ close() {
369
+ return new Promise((resolve) => {
370
+ if (this.fileStream) {
371
+ this.fileStream.end(() => {
372
+ this.fileStream = null;
373
+ resolve();
374
+ });
375
+ }
376
+ else {
377
+ resolve();
378
+ }
379
+ });
380
+ }
381
+ /**
382
+ * Get the default log file path
383
+ */
384
+ static getDefaultLogFilePath() {
385
+ return path.join(getGlobalLogDir(), 'wt.log');
386
+ }
387
+ /**
388
+ * Reset the singleton instance (for testing)
389
+ */
390
+ static reset() {
391
+ if (Logger.instance) {
392
+ Logger.instance.close();
393
+ Logger.instance = null;
394
+ }
395
+ }
396
+ }
397
+ /**
398
+ * Child logger with a specific context
399
+ * Uses logWithContext to avoid race conditions with concurrent logging
400
+ */
401
+ class ChildLogger {
402
+ parent;
403
+ context;
404
+ constructor(parent, context) {
405
+ this.parent = parent;
406
+ this.context = context;
407
+ }
408
+ error(message, ...args) {
409
+ this.parent.logWithContext(LogLevel.ERROR, this.context, message, ...args);
410
+ }
411
+ warn(message, ...args) {
412
+ this.parent.logWithContext(LogLevel.WARN, this.context, message, ...args);
413
+ }
414
+ info(message, ...args) {
415
+ this.parent.logWithContext(LogLevel.INFO, this.context, message, ...args);
416
+ }
417
+ debug(message, ...args) {
418
+ this.parent.logWithContext(LogLevel.DEBUG, this.context, message, ...args);
419
+ }
420
+ trace(message, ...args) {
421
+ this.parent.logWithContext(LogLevel.TRACE, this.context, message, ...args);
422
+ }
423
+ }
424
+ /**
425
+ * The singleton logger instance
426
+ */
427
+ export const logger = Logger.getInstance();
428
+ /**
429
+ * Initialize the logger from CLI arguments and config
430
+ * Call this early in CLI entry points
431
+ */
432
+ export function initializeLogger(options) {
433
+ let level;
434
+ // Priority: CLI flags > env vars > config
435
+ if (options.quiet) {
436
+ level = LogLevel.SILENT;
437
+ }
438
+ else if (options.debug) {
439
+ level = LogLevel.DEBUG;
440
+ }
441
+ else if (options.verbose !== undefined) {
442
+ if (typeof options.verbose === 'number') {
443
+ // -v = DEBUG, -vv = TRACE
444
+ level = options.verbose >= 2 ? LogLevel.TRACE : LogLevel.DEBUG;
445
+ }
446
+ else if (options.verbose) {
447
+ level = LogLevel.DEBUG;
448
+ }
449
+ }
450
+ else if (process.env.GWT_LOG_LEVEL) {
451
+ level = parseLogLevel(process.env.GWT_LOG_LEVEL);
452
+ }
453
+ else if (options.configLogLevel) {
454
+ level =
455
+ typeof options.configLogLevel === 'string'
456
+ ? parseLogLevel(options.configLogLevel)
457
+ : options.configLogLevel;
458
+ }
459
+ // Log file priority: CLI flag > env var > config
460
+ let logFile;
461
+ if (options.logFile) {
462
+ logFile = options.logFile;
463
+ }
464
+ else if (process.env.GWT_LOG_FILE) {
465
+ logFile = process.env.GWT_LOG_FILE;
466
+ }
467
+ else if (options.configLogFile) {
468
+ logFile = options.configLogFile;
469
+ }
470
+ logger.initialize({
471
+ level,
472
+ logFile,
473
+ });
474
+ }
475
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/lib/logger.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Tests for logger.ts
3
+ */
4
+ export {};
5
+ //# sourceMappingURL=logger.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.test.d.ts","sourceRoot":"","sources":["../../src/lib/logger.test.ts"],"names":[],"mappings":"AAAA;;GAEG"}