zeed 1.3.1 → 1.5.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 (229) hide show
  1. package/AGENTS.md +50 -211
  2. package/README.md +16 -0
  3. package/dist/_experiments/bitcask.cjs +2 -2
  4. package/dist/{args-FLoL3OKJ.d.cts → args-CEjib9V9.d.mts} +1 -1
  5. package/dist/{args-WC9q5kz2.d.mts → args-DEig-jw4.d.cts} +1 -1
  6. package/dist/{clipboard-BkUO-syY.d.mts → clipboard-BusqmLLY.d.cts} +1 -1
  7. package/dist/{clipboard-Cfpr331X.d.cts → clipboard-DcuuFRwa.d.mts} +1 -1
  8. package/dist/common/exec/index.d.cts +3 -3
  9. package/dist/common/exec/index.d.mts +3 -3
  10. package/dist/common/exec/pool.d.cts +1 -1
  11. package/dist/common/exec/pool.d.mts +1 -1
  12. package/dist/common/exec/progress.d.cts +1 -1
  13. package/dist/common/exec/progress.d.mts +1 -1
  14. package/dist/common/exec/promise.d.cts +1 -1
  15. package/dist/common/exec/promise.d.mts +1 -1
  16. package/dist/common/exec/queue.d.cts +1 -1
  17. package/dist/common/exec/queue.d.mts +1 -1
  18. package/dist/common/exec/throttle-debounce.d.cts +1 -1
  19. package/dist/common/exec/throttle-debounce.d.mts +1 -1
  20. package/dist/common/index.cjs +21 -0
  21. package/dist/common/index.d.cts +15 -12
  22. package/dist/common/index.d.mts +16 -13
  23. package/dist/common/index.mjs +4 -1
  24. package/dist/common/msg/channel-debug.d.cts +1 -1
  25. package/dist/common/msg/channel-debug.d.mts +1 -1
  26. package/dist/common/msg/channel-local.d.cts +1 -1
  27. package/dist/common/msg/channel-local.d.mts +1 -1
  28. package/dist/common/msg/channel-resilient.d.cts +1 -1
  29. package/dist/common/msg/channel-resilient.d.mts +1 -1
  30. package/dist/common/msg/channel-wkwebview.d.cts +2 -1
  31. package/dist/common/msg/channel-wkwebview.d.mts +2 -1
  32. package/dist/common/msg/channel.d.cts +1 -1
  33. package/dist/common/msg/channel.d.mts +1 -1
  34. package/dist/common/msg/emitter.d.cts +1 -1
  35. package/dist/common/msg/emitter.d.mts +1 -1
  36. package/dist/common/msg/index.d.cts +1 -1
  37. package/dist/common/msg/index.d.mts +1 -1
  38. package/dist/common/msg/messages.d.cts +1 -1
  39. package/dist/common/msg/messages.d.mts +1 -1
  40. package/dist/common/msg/pubsub.d.cts +1 -1
  41. package/dist/common/msg/pubsub.d.mts +1 -1
  42. package/dist/common/msg/rpc.cjs +8 -8
  43. package/dist/common/msg/rpc.cjs.map +1 -1
  44. package/dist/common/msg/rpc.mjs +8 -8
  45. package/dist/common/msg/rpc.mjs.map +1 -1
  46. package/dist/common/schema/export-json-schema.cjs +40 -31
  47. package/dist/common/schema/export-json-schema.cjs.map +1 -1
  48. package/dist/common/schema/export-json-schema.mjs +40 -31
  49. package/dist/common/schema/export-json-schema.mjs.map +1 -1
  50. package/dist/common/schema/index.cjs +21 -0
  51. package/dist/common/schema/index.d.cts +6 -3
  52. package/dist/common/schema/index.d.mts +7 -4
  53. package/dist/common/schema/index.mjs +4 -1
  54. package/dist/common/schema/sql/expr.cjs +128 -0
  55. package/dist/common/schema/sql/expr.cjs.map +1 -0
  56. package/dist/common/schema/sql/expr.d.cts +2 -0
  57. package/dist/common/schema/sql/expr.d.mts +2 -0
  58. package/dist/common/schema/sql/expr.mjs +115 -0
  59. package/dist/common/schema/sql/expr.mjs.map +1 -0
  60. package/dist/common/schema/sql/index.cjs +23 -0
  61. package/dist/common/schema/sql/index.d.cts +4 -0
  62. package/dist/common/schema/sql/index.d.mts +4 -0
  63. package/dist/common/schema/sql/index.mjs +5 -0
  64. package/dist/common/schema/sql/select.cjs +143 -0
  65. package/dist/common/schema/sql/select.cjs.map +1 -0
  66. package/dist/common/schema/sql/select.d.cts +2 -0
  67. package/dist/common/schema/sql/select.d.mts +2 -0
  68. package/dist/common/schema/sql/select.mjs +139 -0
  69. package/dist/common/schema/sql/select.mjs.map +1 -0
  70. package/dist/common/schema/sql/table.cjs +23 -0
  71. package/dist/common/schema/sql/table.cjs.map +1 -0
  72. package/dist/common/schema/sql/table.d.cts +2 -0
  73. package/dist/common/schema/sql/table.d.mts +2 -0
  74. package/dist/common/schema/sql/table.mjs +20 -0
  75. package/dist/common/schema/sql/table.mjs.map +1 -0
  76. package/dist/common/schema/type-test.d.cts +1 -1
  77. package/dist/common/schema/type-test.d.mts +1 -1
  78. package/dist/common/schema/utils.d.cts +1 -1
  79. package/dist/common/schema/utils.d.mts +1 -1
  80. package/dist/common/schema/z.d.mts +1 -1
  81. package/dist/common/storage/index.d.cts +1 -1
  82. package/dist/common/storage/index.d.mts +1 -1
  83. package/dist/common/storage/memstorage.d.cts +1 -1
  84. package/dist/common/storage/memstorage.d.mts +1 -1
  85. package/dist/common/test.d.cts +1 -1
  86. package/dist/common/test.d.mts +1 -1
  87. package/dist/common/time.d.cts +1 -1
  88. package/dist/common/time.d.mts +1 -1
  89. package/dist/common/timeout.d.cts +1 -1
  90. package/dist/common/timeout.d.mts +1 -1
  91. package/dist/common/utils.d.cts +1 -1
  92. package/dist/common/utils.d.mts +1 -1
  93. package/dist/common/uuid.d.cts +1 -1
  94. package/dist/common/uuid.d.mts +1 -1
  95. package/dist/{crypto-CyTV7Qce.d.cts → crypto-D68rVmvU.d.mts} +1 -1
  96. package/dist/{crypto-LT7EC5_d.d.mts → crypto-KzGHoCJE.d.cts} +1 -1
  97. package/dist/{env-B3vOiVY8.d.cts → env-BJXdwBKq.d.mts} +1 -1
  98. package/dist/{env-C3npYe8w.d.mts → env-HsOnA_yK.d.cts} +1 -1
  99. package/dist/expr-CCKrqOw1.d.mts +25 -0
  100. package/dist/expr-yYgSeBZ3.d.cts +25 -0
  101. package/dist/{files-CDNKX9VI.d.mts → files-4O-PxnAC.d.cts} +1 -1
  102. package/dist/{files-DdI9UZvg.d.cts → files-BlpxqSTT.d.mts} +1 -1
  103. package/dist/{files-async-1V0bu_ca.d.cts → files-async-DFLC-Nkd.d.cts} +1 -1
  104. package/dist/{files-async-cBMkRwsu.d.mts → files-async-DfuEEDjH.d.mts} +1 -1
  105. package/dist/{filestorage-CXQ9MzeW.d.cts → filestorage-BjeBZEAs.d.cts} +1 -1
  106. package/dist/{filestorage-YzM2z9sU.d.mts → filestorage-CmfztpWm.d.mts} +1 -1
  107. package/dist/{fs-DHJ9AqUk.d.cts → fs-D837bjRT.d.cts} +1 -1
  108. package/dist/{fs-DgjZdpuF.d.mts → fs-DlYLapik.d.mts} +1 -1
  109. package/dist/{glob-Bfs7ZS_i.d.mts → glob-5yW09dkR.d.mts} +1 -1
  110. package/dist/{glob-Bt150jOY.d.cts → glob-CZaZPqiy.d.cts} +1 -1
  111. package/dist/{index-DHXVOH8h.d.cts → index-CFkMqHvX.d.cts} +1 -2
  112. package/dist/{index-DMaPyx9O.d.mts → index-C_3Y_s6f.d.mts} +1 -2
  113. package/dist/index.all.cjs +21 -0
  114. package/dist/index.all.d.cts +29 -26
  115. package/dist/index.all.d.mts +30 -27
  116. package/dist/index.all.mjs +4 -1
  117. package/dist/index.browser.cjs +21 -0
  118. package/dist/index.browser.d.cts +15 -12
  119. package/dist/index.browser.d.mts +16 -13
  120. package/dist/index.browser.mjs +4 -1
  121. package/dist/index.jsr.d.cts +4 -4
  122. package/dist/index.jsr.d.mts +4 -4
  123. package/dist/index.node.cjs +21 -0
  124. package/dist/index.node.d.cts +29 -26
  125. package/dist/index.node.d.mts +30 -27
  126. package/dist/index.node.mjs +4 -1
  127. package/dist/{log-file-bsTsc9KM.d.cts → log-file-DwEDms1F.d.cts} +2 -2
  128. package/dist/{log-file-DTuImomJ.d.mts → log-file-QV1unm3z.d.mts} +2 -2
  129. package/dist/{log-file-rotation-_YruAcNc.d.cts → log-file-rotation-BpZxXYlU.d.cts} +2 -2
  130. package/dist/{log-file-rotation-FBmtp_Uz.d.mts → log-file-rotation-DanrO_2y.d.mts} +2 -2
  131. package/dist/{log-node-DlrXl3QO.d.mts → log-node-BSn7RqAc.d.mts} +1 -1
  132. package/dist/{log-node-Dk948mHX.d.cts → log-node-D_fiJL6x.d.cts} +1 -1
  133. package/dist/{log-rotation-CkyjZbK5.d.mts → log-rotation-BdGakFya.d.cts} +1 -1
  134. package/dist/{log-rotation-_d7iRm9s.d.cts → log-rotation-Ce4e-8LN.d.mts} +1 -1
  135. package/dist/{log-util-2Ls76P-0.d.cts → log-util-C0U3zCjw.d.cts} +1 -1
  136. package/dist/{log-util-Da_d19f8.d.mts → log-util-Da_UCcmt.d.mts} +1 -1
  137. package/dist/{memstorage-D5A9FwiP.d.mts → memstorage-BhWXthO8.d.mts} +1 -1
  138. package/dist/{memstorage-BcjQLdaQ.d.cts → memstorage-tvlWDYgS.d.cts} +1 -1
  139. package/dist/node/args.cjs +1 -1
  140. package/dist/node/args.d.cts +1 -1
  141. package/dist/node/args.d.mts +1 -1
  142. package/dist/node/clipboard.d.cts +1 -1
  143. package/dist/node/clipboard.d.mts +1 -1
  144. package/dist/node/crypto.cjs +1 -1
  145. package/dist/node/crypto.d.cts +1 -1
  146. package/dist/node/crypto.d.mts +1 -1
  147. package/dist/node/env.cjs +2 -2
  148. package/dist/node/env.d.cts +1 -1
  149. package/dist/node/env.d.mts +1 -1
  150. package/dist/node/files-async.cjs +1 -1
  151. package/dist/node/files-async.d.cts +1 -1
  152. package/dist/node/files-async.d.mts +1 -1
  153. package/dist/node/files.cjs +1 -1
  154. package/dist/node/files.d.cts +1 -1
  155. package/dist/node/files.d.mts +1 -1
  156. package/dist/node/filestorage.cjs +1 -1
  157. package/dist/node/filestorage.d.cts +1 -1
  158. package/dist/node/filestorage.d.mts +1 -1
  159. package/dist/node/fs.cjs +1 -1
  160. package/dist/node/fs.d.cts +1 -1
  161. package/dist/node/fs.d.mts +1 -1
  162. package/dist/node/glob.d.cts +1 -1
  163. package/dist/node/glob.d.mts +1 -1
  164. package/dist/node/index.d.cts +14 -14
  165. package/dist/node/index.d.mts +14 -14
  166. package/dist/node/log/index.d.cts +5 -5
  167. package/dist/node/log/index.d.mts +5 -5
  168. package/dist/node/log/log-context-node.cjs +1 -1
  169. package/dist/node/log/log-file-rotation.d.cts +1 -1
  170. package/dist/node/log/log-file-rotation.d.mts +1 -1
  171. package/dist/node/log/log-file.cjs +1 -1
  172. package/dist/node/log/log-file.d.cts +1 -1
  173. package/dist/node/log/log-file.d.mts +1 -1
  174. package/dist/node/log/log-node.cjs +6 -15
  175. package/dist/node/log/log-node.cjs.map +1 -1
  176. package/dist/node/log/log-node.d.cts +1 -1
  177. package/dist/node/log/log-node.d.mts +1 -1
  178. package/dist/node/log/log-node.mjs +4 -13
  179. package/dist/node/log/log-node.mjs.map +1 -1
  180. package/dist/node/log/log-rotation.cjs +1 -1
  181. package/dist/node/log/log-rotation.d.cts +1 -1
  182. package/dist/node/log/log-rotation.d.mts +1 -1
  183. package/dist/node/log/log-util.cjs +1 -1
  184. package/dist/node/log/log-util.d.cts +1 -1
  185. package/dist/node/log/log-util.d.mts +1 -1
  186. package/dist/{promise-DGgiRckN.d.cts → promise-CU_CENbU.d.cts} +1 -1
  187. package/dist/{promise-MH3xAy4S.d.mts → promise-CoWXgo4w.d.mts} +1 -1
  188. package/dist/select-DrciHdk_.d.cts +52 -0
  189. package/dist/select-F2KpP6mo.d.mts +52 -0
  190. package/dist/table-Cr8tjDIL.d.mts +19 -0
  191. package/dist/table-IkLXirT-.d.cts +19 -0
  192. package/dist/{test-CAhm15f4.d.mts → test-DcXa0MeX.d.cts} +1 -1
  193. package/dist/{test-D2plOVHF.d.cts → test-jZsc7P2c.d.mts} +1 -1
  194. package/dist/{throttle-debounce-BLFxAZ8W.d.mts → throttle-debounce-CCh0F100.d.mts} +1 -1
  195. package/dist/{throttle-debounce-Psb0ay1r.d.cts → throttle-debounce-DyFiyoAk.d.cts} +1 -1
  196. package/dist/{time-BfKJBbym.d.cts → time-BgFZe9ys.d.cts} +1 -1
  197. package/dist/{time-DxE-vjjw.d.mts → time-DSV_k3mG.d.mts} +1 -1
  198. package/dist/{timeout-CnUk6Ruj.d.mts → timeout-DDSSNZY8.d.mts} +1 -1
  199. package/dist/{timeout-CpFcK8MD.d.cts → timeout-E3ZQbJgK.d.cts} +1 -1
  200. package/dist/{type-test-BiKyEZkc.d.mts → type-test-BvzWDJz3.d.mts} +1 -1
  201. package/dist/{type-test-sM7QpfQU.d.cts → type-test-CBK-iJ9d.d.cts} +1 -1
  202. package/dist/{utils-B8DsVgFr.d.mts → utils-1RyCGkpQ.d.mts} +1 -1
  203. package/dist/{utils-BfZkD2Pt.d.mts → utils-6Culwiaf.d.cts} +1 -1
  204. package/dist/{utils-DHQBNh-Z.d.cts → utils-CDJihcg3.d.mts} +1 -1
  205. package/dist/{utils-Bctk_WhH.d.cts → utils-nCQklGHV.d.cts} +1 -1
  206. package/dist/{uuid-Cusm2nIK.d.cts → uuid-CKFZfSff.d.mts} +1 -1
  207. package/dist/{uuid-ININPGKB.d.mts → uuid-D42A8UdP.d.cts} +1 -1
  208. package/dist/z-C0fpNWZg.d.cts +1 -0
  209. package/dist/z-D_jezYmm.d.mts +1 -0
  210. package/dist/{z-collection-BmuBin--.d.mts → z-collection-BSfgRU0Q.d.mts} +1 -1
  211. package/package.json +17 -18
  212. package/src/common/schema/README.md +247 -66
  213. package/src/common/schema/export-json-schema.spec.ts +11 -7
  214. package/src/common/schema/export-json-schema.ts +59 -52
  215. package/src/common/schema/index.ts +1 -0
  216. package/src/common/schema/sql/README.md +254 -0
  217. package/src/common/schema/sql/expr.ts +99 -0
  218. package/src/common/schema/sql/index.ts +3 -0
  219. package/src/common/schema/sql/select.spec.ts +144 -0
  220. package/src/common/schema/sql/select.ts +207 -0
  221. package/src/common/schema/sql/table.ts +36 -0
  222. package/src/common/schema/README-SCHEMA.md +0 -0
  223. /package/dist/{index-BH1nuHdZ.d.cts → index-CIABef8t.d.mts} +0 -0
  224. /package/dist/{index-BL7o4fG9.d.cts → index-CliqZ9rj.d.mts} +0 -0
  225. /package/dist/{index-CP2eJYlK.d.mts → index-D6xqj1Qx.d.cts} +0 -0
  226. /package/dist/{index-DjOaHFU3.d.mts → index-DHFfG4yr.d.cts} +0 -0
  227. /package/dist/{index-sViox9YW.d.mts → index-N-OgGgfF.d.mts} +0 -0
  228. /package/dist/{z-ClMox7qS.d.mts → index-WOw4GVZo.d.cts} +0 -0
  229. /package/dist/{z-dtM4F8Lo.d.cts → index-luywJTzJ.d.mts} +0 -0
@@ -1,2 +1,2 @@
1
- import { a as isFolder, c as readData, d as removeFolder, f as toHumanReadableFilePath, g as writeText, h as writeJson, i as isFile, l as readJson, m as writeData, n as ensureFolderForFile, o as isHiddenPath, p as writeBin, r as exists, s as readBin, t as ensureFolder, u as readText } from "../fs-DgjZdpuF.mjs";
1
+ import { a as isFolder, c as readData, d as removeFolder, f as toHumanReadableFilePath, g as writeText, h as writeJson, i as isFile, l as readJson, m as writeData, n as ensureFolderForFile, o as isHiddenPath, p as writeBin, r as exists, s as readBin, t as ensureFolder, u as readText } from "../fs-DlYLapik.mjs";
2
2
  export { ensureFolder, ensureFolderForFile, exists, isFile, isFolder, isHiddenPath, readBin, readData, readJson, readText, removeFolder, toHumanReadableFilePath, writeBin, writeData, writeJson, writeText };
@@ -1,2 +1,2 @@
1
- import { t as globToRegExp } from "../glob-Bt150jOY.cjs";
1
+ import { t as globToRegExp } from "../glob-CZaZPqiy.cjs";
2
2
  export { globToRegExp };
@@ -1,2 +1,2 @@
1
- import { t as globToRegExp } from "../glob-Bfs7ZS_i.mjs";
1
+ import { t as globToRegExp } from "../glob-5yW09dkR.mjs";
2
2
  export { globToRegExp };
@@ -1,15 +1,15 @@
1
- import { n as parseArgs, t as ParseConfig } from "../args-FLoL3OKJ.cjs";
2
- import { t as pbcopy } from "../clipboard-Cfpr331X.cjs";
3
- import { n as setupWebCrypto, t as getWebCrypto } from "../crypto-CyTV7Qce.cjs";
4
- import { a as setupEnv, c as valueToPath, i as parseEnvStringAlt, n as getEnvVariableRelaxed, o as stringToPath, r as parseEnvString, s as toPath, t as EnvOptions } from "../env-B3vOiVY8.cjs";
5
- import { i as walkSync, n as getFingerprint, r as getStat, t as files } from "../files-DdI9UZvg.cjs";
6
- import { a as walkSyncAsync, i as getStatAsync, n as filesAsync, r as getFingerprintAsync, t as StatsBase } from "../files-async-1V0bu_ca.cjs";
7
- import { n as FileStorageOptions, t as FileStorage } from "../filestorage-CXQ9MzeW.cjs";
8
- import { a as isFolder, c as readData, d as removeFolder, f as toHumanReadableFilePath, g as writeText, h as writeJson, i as isFile, l as readJson, m as writeData, n as ensureFolderForFile, o as isHiddenPath, p as writeBin, r as exists, s as readBin, t as ensureFolder, u as readText } from "../fs-DHJ9AqUk.cjs";
9
- import { t as globToRegExp } from "../glob-Bt150jOY.cjs";
10
- import { u as createRotationStream } from "../log-rotation-_d7iRm9s.cjs";
11
- import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../log-file-rotation-_YruAcNc.cjs";
12
- import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../log-file-bsTsc9KM.cjs";
13
- import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../log-node-Dk948mHX.cjs";
14
- import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../log-util-2Ls76P-0.cjs";
1
+ import { n as parseArgs, t as ParseConfig } from "../args-DEig-jw4.cjs";
2
+ import { t as pbcopy } from "../clipboard-BusqmLLY.cjs";
3
+ import { n as setupWebCrypto, t as getWebCrypto } from "../crypto-KzGHoCJE.cjs";
4
+ import { a as setupEnv, c as valueToPath, i as parseEnvStringAlt, n as getEnvVariableRelaxed, o as stringToPath, r as parseEnvString, s as toPath, t as EnvOptions } from "../env-HsOnA_yK.cjs";
5
+ import { i as walkSync, n as getFingerprint, r as getStat, t as files } from "../files-4O-PxnAC.cjs";
6
+ import { a as walkSyncAsync, i as getStatAsync, n as filesAsync, r as getFingerprintAsync, t as StatsBase } from "../files-async-DFLC-Nkd.cjs";
7
+ import { n as FileStorageOptions, t as FileStorage } from "../filestorage-BjeBZEAs.cjs";
8
+ import { a as isFolder, c as readData, d as removeFolder, f as toHumanReadableFilePath, g as writeText, h as writeJson, i as isFile, l as readJson, m as writeData, n as ensureFolderForFile, o as isHiddenPath, p as writeBin, r as exists, s as readBin, t as ensureFolder, u as readText } from "../fs-D837bjRT.cjs";
9
+ import { t as globToRegExp } from "../glob-CZaZPqiy.cjs";
10
+ import { u as createRotationStream } from "../log-rotation-BdGakFya.cjs";
11
+ import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../log-file-rotation-BpZxXYlU.cjs";
12
+ import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../log-file-DwEDms1F.cjs";
13
+ import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../log-node-D_fiJL6x.cjs";
14
+ import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../log-util-C0U3zCjw.cjs";
15
15
  export { EnvOptions, FileStorage, FileStorageOptions, LogFileHandlerOptions, LogRotationOptions, LoggerFileHandler, LoggerNodeHandler, ParseConfig, StatsBase, colorString, colorStringList, createRotationStream, ensureFolder, ensureFolderForFile, exists, files, filesAsync, getEnvVariableRelaxed, getFingerprint, getFingerprintAsync, getLogFileRotationConfigSchemaOptions, getLogRotationConfig, getSourceLocation, getSourceLocationByPrecedingPattern, getStack, getStackLlocationList, getStat, getStatAsync, getWebCrypto, globToRegExp, isFile, isFolder, isHiddenPath, loggerStackTraceDebug, parseArgs, parseEnvString, parseEnvStringAlt, parseLogRotationConfigEnv, pbcopy, readBin, readData, readJson, readText, removeFolder, setupEnv, setupWebCrypto, stringToPath, toHumanReadableFilePath, toPath, valueToPath, walkSync, walkSyncAsync, writeBin, writeData, writeJson, writeText };
@@ -1,15 +1,15 @@
1
- import { n as parseArgs, t as ParseConfig } from "../args-WC9q5kz2.mjs";
2
- import { t as pbcopy } from "../clipboard-BkUO-syY.mjs";
3
- import { n as setupWebCrypto, t as getWebCrypto } from "../crypto-LT7EC5_d.mjs";
4
- import { a as setupEnv, c as valueToPath, i as parseEnvStringAlt, n as getEnvVariableRelaxed, o as stringToPath, r as parseEnvString, s as toPath, t as EnvOptions } from "../env-C3npYe8w.mjs";
5
- import { i as walkSync, n as getFingerprint, r as getStat, t as files } from "../files-CDNKX9VI.mjs";
6
- import { a as walkSyncAsync, i as getStatAsync, n as filesAsync, r as getFingerprintAsync, t as StatsBase } from "../files-async-cBMkRwsu.mjs";
7
- import { n as FileStorageOptions, t as FileStorage } from "../filestorage-YzM2z9sU.mjs";
8
- import { a as isFolder, c as readData, d as removeFolder, f as toHumanReadableFilePath, g as writeText, h as writeJson, i as isFile, l as readJson, m as writeData, n as ensureFolderForFile, o as isHiddenPath, p as writeBin, r as exists, s as readBin, t as ensureFolder, u as readText } from "../fs-DgjZdpuF.mjs";
9
- import { t as globToRegExp } from "../glob-Bfs7ZS_i.mjs";
10
- import { u as createRotationStream } from "../log-rotation-CkyjZbK5.mjs";
11
- import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../log-file-rotation-FBmtp_Uz.mjs";
12
- import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../log-file-DTuImomJ.mjs";
13
- import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../log-node-DlrXl3QO.mjs";
14
- import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../log-util-Da_d19f8.mjs";
1
+ import { n as parseArgs, t as ParseConfig } from "../args-CEjib9V9.mjs";
2
+ import { t as pbcopy } from "../clipboard-DcuuFRwa.mjs";
3
+ import { n as setupWebCrypto, t as getWebCrypto } from "../crypto-D68rVmvU.mjs";
4
+ import { a as setupEnv, c as valueToPath, i as parseEnvStringAlt, n as getEnvVariableRelaxed, o as stringToPath, r as parseEnvString, s as toPath, t as EnvOptions } from "../env-BJXdwBKq.mjs";
5
+ import { i as walkSync, n as getFingerprint, r as getStat, t as files } from "../files-BlpxqSTT.mjs";
6
+ import { a as walkSyncAsync, i as getStatAsync, n as filesAsync, r as getFingerprintAsync, t as StatsBase } from "../files-async-DfuEEDjH.mjs";
7
+ import { n as FileStorageOptions, t as FileStorage } from "../filestorage-CmfztpWm.mjs";
8
+ import { a as isFolder, c as readData, d as removeFolder, f as toHumanReadableFilePath, g as writeText, h as writeJson, i as isFile, l as readJson, m as writeData, n as ensureFolderForFile, o as isHiddenPath, p as writeBin, r as exists, s as readBin, t as ensureFolder, u as readText } from "../fs-DlYLapik.mjs";
9
+ import { t as globToRegExp } from "../glob-5yW09dkR.mjs";
10
+ import { u as createRotationStream } from "../log-rotation-Ce4e-8LN.mjs";
11
+ import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../log-file-rotation-DanrO_2y.mjs";
12
+ import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../log-file-QV1unm3z.mjs";
13
+ import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../log-node-BSn7RqAc.mjs";
14
+ import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../log-util-Da_UCcmt.mjs";
15
15
  export { EnvOptions, FileStorage, FileStorageOptions, LogFileHandlerOptions, LogRotationOptions, LoggerFileHandler, LoggerNodeHandler, ParseConfig, StatsBase, colorString, colorStringList, createRotationStream, ensureFolder, ensureFolderForFile, exists, files, filesAsync, getEnvVariableRelaxed, getFingerprint, getFingerprintAsync, getLogFileRotationConfigSchemaOptions, getLogRotationConfig, getSourceLocation, getSourceLocationByPrecedingPattern, getStack, getStackLlocationList, getStat, getStatAsync, getWebCrypto, globToRegExp, isFile, isFolder, isHiddenPath, loggerStackTraceDebug, parseArgs, parseEnvString, parseEnvStringAlt, parseLogRotationConfigEnv, pbcopy, readBin, readData, readJson, readText, removeFolder, setupEnv, setupWebCrypto, stringToPath, toHumanReadableFilePath, toPath, valueToPath, walkSync, walkSyncAsync, writeBin, writeData, writeJson, writeText };
@@ -1,6 +1,6 @@
1
- import { u as createRotationStream } from "../../log-rotation-_d7iRm9s.cjs";
2
- import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../../log-file-rotation-_YruAcNc.cjs";
3
- import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../../log-file-bsTsc9KM.cjs";
4
- import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../../log-node-Dk948mHX.cjs";
5
- import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../../log-util-2Ls76P-0.cjs";
1
+ import { u as createRotationStream } from "../../log-rotation-BdGakFya.cjs";
2
+ import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../../log-file-rotation-BpZxXYlU.cjs";
3
+ import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../../log-file-DwEDms1F.cjs";
4
+ import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../../log-node-D_fiJL6x.cjs";
5
+ import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../../log-util-C0U3zCjw.cjs";
6
6
  export { LogFileHandlerOptions, LogRotationOptions, LoggerFileHandler, LoggerNodeHandler, colorString, colorStringList, createRotationStream, getLogFileRotationConfigSchemaOptions, getLogRotationConfig, getSourceLocation, getSourceLocationByPrecedingPattern, getStack, getStackLlocationList, loggerStackTraceDebug, parseLogRotationConfigEnv };
@@ -1,6 +1,6 @@
1
- import { u as createRotationStream } from "../../log-rotation-CkyjZbK5.mjs";
2
- import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../../log-file-rotation-FBmtp_Uz.mjs";
3
- import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../../log-file-DTuImomJ.mjs";
4
- import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../../log-node-DlrXl3QO.mjs";
5
- import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../../log-util-Da_d19f8.mjs";
1
+ import { u as createRotationStream } from "../../log-rotation-Ce4e-8LN.mjs";
2
+ import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../../log-file-rotation-DanrO_2y.mjs";
3
+ import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../../log-file-QV1unm3z.mjs";
4
+ import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../../log-node-BSn7RqAc.mjs";
5
+ import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../../log-util-Da_UCcmt.mjs";
6
6
  export { LogFileHandlerOptions, LogRotationOptions, LoggerFileHandler, LoggerNodeHandler, colorString, colorStringList, createRotationStream, getLogFileRotationConfigSchemaOptions, getLogRotationConfig, getSourceLocation, getSourceLocationByPrecedingPattern, getStack, getStackLlocationList, loggerStackTraceDebug, parseLogRotationConfigEnv };
@@ -8,7 +8,7 @@ const require_node_log_log_file_rotation = require('./log-file-rotation.cjs');
8
8
  const require_node_log_log_file = require('./log-file.cjs');
9
9
  const require_node_log_log_node = require('./log-node.cjs');
10
10
  let node_process = require("node:process");
11
- node_process = require_chunk.__toESM(node_process);
11
+ node_process = require_chunk.__toESM(node_process, 1);
12
12
 
13
13
  //#region src/node/log/log-context-node.ts
14
14
  function Logger(name, level) {
@@ -1,2 +1,2 @@
1
- import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../../log-file-rotation-_YruAcNc.cjs";
1
+ import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../../log-file-rotation-BpZxXYlU.cjs";
2
2
  export { LogRotationOptions, getLogFileRotationConfigSchemaOptions, getLogRotationConfig, parseLogRotationConfigEnv };
@@ -1,2 +1,2 @@
1
- import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../../log-file-rotation-FBmtp_Uz.mjs";
1
+ import { i as parseLogRotationConfigEnv, n as getLogFileRotationConfigSchemaOptions, r as getLogRotationConfig, t as LogRotationOptions } from "../../log-file-rotation-DanrO_2y.mjs";
2
2
  export { LogRotationOptions, getLogFileRotationConfigSchemaOptions, getLogRotationConfig, parseLogRotationConfigEnv };
@@ -6,7 +6,7 @@ const require_common_data_message = require('../../common/data/message.cjs');
6
6
  const require_node_log_log_file_rotation = require('./log-file-rotation.cjs');
7
7
  const require_node_log_log_rotation = require('./log-rotation.cjs');
8
8
  let node_process = require("node:process");
9
- node_process = require_chunk.__toESM(node_process);
9
+ node_process = require_chunk.__toESM(node_process, 1);
10
10
  let node_fs = require("node:fs");
11
11
  let node_path = require("node:path");
12
12
 
@@ -1,2 +1,2 @@
1
- import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../../log-file-bsTsc9KM.cjs";
1
+ import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../../log-file-DwEDms1F.cjs";
2
2
  export { LogFileHandlerOptions, LoggerFileHandler };
@@ -1,2 +1,2 @@
1
- import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../../log-file-DTuImomJ.mjs";
1
+ import { n as LoggerFileHandler, t as LogFileHandlerOptions } from "../../log-file-QV1unm3z.mjs";
2
2
  export { LogFileHandlerOptions, LoggerFileHandler };
@@ -7,9 +7,9 @@ const require_common_data_convert = require('../../common/data/convert.cjs');
7
7
  const require_common_data_message = require('../../common/data/message.cjs');
8
8
  const require_node_log_log_util = require('./log-util.cjs');
9
9
  let node_process = require("node:process");
10
- node_process = require_chunk.__toESM(node_process);
10
+ node_process = require_chunk.__toESM(node_process, 1);
11
11
  let node_tty = require("node:tty");
12
- node_tty = require_chunk.__toESM(node_tty);
12
+ node_tty = require_chunk.__toESM(node_tty, 1);
13
13
 
14
14
  //#region src/node/log/log-node.ts
15
15
  function shouldUseColor() {
@@ -51,18 +51,9 @@ const TTY_STYLE = {
51
51
  ORANGE: "\x1B[38;5;208m",
52
52
  UNCOLOR: "\x1B[0m"
53
53
  };
54
- var COLOR = /* @__PURE__ */ function(COLOR) {
55
- COLOR[COLOR["RED"] = 1] = "RED";
56
- COLOR[COLOR["GREEN"] = 2] = "GREEN";
57
- COLOR[COLOR["BLUE"] = 4] = "BLUE";
58
- COLOR[COLOR["PURPLE"] = 5] = "PURPLE";
59
- COLOR[COLOR["GRAY"] = 7] = "GRAY";
60
- COLOR[COLOR["ORANGE"] = 8] = "ORANGE";
61
- return COLOR;
62
- }(COLOR || {});
63
54
  const colorEnd = "\x1B[0m";
64
55
  function colorString(text, colorCode) {
65
- return `${colorCode === COLOR.ORANGE ? TTY_STYLE.ORANGE : `\u001B[3${colorCode < 8 ? colorCode : `8;5;${colorCode}`}m`}${text}${colorEnd}`;
56
+ return `${colorCode === 8 ? TTY_STYLE.ORANGE : `\u001B[3${colorCode < 8 ? colorCode : `8;5;${colorCode}`}m`}${text}${colorEnd}`;
66
57
  }
67
58
  function colorStringList(list, style, bold = true) {
68
59
  return list.map((value) => {
@@ -130,7 +121,7 @@ function LoggerNodeHandler(opt = {}) {
130
121
  ], true);
131
122
  if (!line) line = require_node_log_log_util.getSourceLocation(0, true);
132
123
  } else line = require_node_log_log_util.getSourceLocation(typeof stack === "number" ? stack : 3, true);
133
- if (line) args.push(colorString(`(${line})`, COLOR.GRAY));
124
+ if (line) args.push(colorString(`(${line})`, 7));
134
125
  }
135
126
  const sep = "|";
136
127
  const charLevel = ".";
@@ -140,11 +131,11 @@ function LoggerNodeHandler(opt = {}) {
140
131
  log(...args);
141
132
  break;
142
133
  case 2:
143
- if (levelHelper) args[0] = (colors ? colorString(`W${sep}${charLevel}${charLevel} `, COLOR.ORANGE) : `W${sep}${charLevel}${charLevel} `) + args[0];
134
+ if (levelHelper) args[0] = (colors ? colorString(`W${sep}${charLevel}${charLevel} `, 8) : `W${sep}${charLevel}${charLevel} `) + args[0];
144
135
  log(...args);
145
136
  break;
146
137
  case 3:
147
- if (levelHelper) args[0] = (colors ? colorString(`E${sep}${charLevel}${charLevel}${charLevel} `, COLOR.RED) : `E${sep}${charLevel}${charLevel}${charLevel} `) + args[0];
138
+ if (levelHelper) args[0] = (colors ? colorString(`E${sep}${charLevel}${charLevel}${charLevel} `, 1) : `E${sep}${charLevel}${charLevel}${charLevel} `) + args[0];
148
139
  log(...args);
149
140
  break;
150
141
  default:
@@ -1 +1 @@
1
- {"version":3,"file":"log-node.cjs","names":["valueToBoolean","process","tty","renderMessages","getTimestamp","useNamespaceFilter","useLevelFilter","formatMilliseconds","getStack","getSourceLocationByPrecedingPattern","getSourceLocation"],"sources":["../../../src/node/log/log-node.ts"],"sourcesContent":["import type { LogHandler, LogHandlerOptions, LogMessage } from '../../common/log/log-base'\nimport process from 'node:process'\nimport tty from 'node:tty'\nimport { valueToBoolean } from '../../common/data/convert'\nimport { renderMessages } from '../../common/data/message'\nimport { LogLevelError, LogLevelInfo, LogLevelWarn } from '../../common/log/log-base'\nimport { useLevelFilter, useNamespaceFilter } from '../../common/log/log-filter'\nimport { formatMilliseconds, getTimestamp } from '../../common/time'\nimport { getSourceLocation, getSourceLocationByPrecedingPattern, getStack } from './log-util'\n\nfunction shouldUseColor(): boolean {\n try {\n return valueToBoolean(process.env.ZEED_COLOR, tty.isatty(process.stdout.fd))\n }\n catch (err) {}\n return false\n}\n\nlet defaultUseColor: boolean | undefined\n\nconst colors = [6, 2, 3, 4, 5, 1]\n\nfunction nodeSelectColorByName(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n\nconst namespaces: Record<string, any> = {}\n\nlet startTime: number | undefined\n\nfunction log(...args: any[]) {\n process.stdout.write(`${renderMessages(args)}\\n`)\n}\n\n// const _browserStyleMap = {\n// [BOLD]: { \"font-weight\": \"bold\" },\n// [UNBOLD]: { \"font-weight\": \"normal\" },\n// [BLUE]: { color: \"blue\" },\n// [GREEN]: { color: \"green\" },\n// [GREY]: { color: \"grey\" },\n// [RED]: { color: \"red\" },\n// [PURPLE]: { color: \"purple\" },\n// [ORANGE]: { color: \"orange\" },\n// [UNCOLOR]: { color: \"black\" },\n// }\n\nconst TTY_STYLE = {\n BOLD: '\\u001B[1m',\n UNBOLD: '\\u001B[2m',\n RED: '\\u001B[31m',\n GREEN: '\\u001B[32m',\n BLUE: '\\u001B[34m',\n PURPLE: '\\u001B[35m',\n GRAY: '\\u001B[37m',\n ORANGE: '\\u001B[38;5;208m',\n UNCOLOR: '\\u001B[0m',\n}\n\nenum COLOR {\n RED = 1,\n GREEN = 2,\n BLUE = 4,\n PURPLE = 5,\n GRAY = 7,\n ORANGE = 8,\n}\n\nconst colorEnd = '\\u001B[0m'\n\nexport function colorString(text: string, colorCode: number) {\n const colorStart = colorCode === COLOR.ORANGE\n ? TTY_STYLE.ORANGE\n : `\\u001B[3${colorCode < 8 ? colorCode : `8;5;${colorCode}`}m`\n return `${colorStart}${text}${colorEnd}`\n}\n\nexport function colorStringList(\n list: Array<any>,\n style: string,\n bold = true,\n) {\n return list.map((value) => {\n if (typeof value !== 'string')\n return value\n let start = style\n let end = colorEnd\n if (bold) {\n start = `${TTY_STYLE.BOLD}${start}`\n end = `${end}${TTY_STYLE.BOLD}`\n }\n return `${start}${value}${end}`\n })\n}\n\nfunction shouldUseStack(): boolean {\n try {\n return valueToBoolean(process.env.ZEED_STACK, false)\n }\n catch (err) {}\n return false\n}\n\nlet defaultUseStack: boolean | undefined\n\nexport const loggerStackTraceDebug = 'loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485'\n\nexport function LoggerNodeHandler(opt: LogHandlerOptions = {}): LogHandler {\n defaultUseColor ??= shouldUseColor()\n\n defaultUseStack ??= shouldUseStack()\n\n startTime ??= getTimestamp()\n\n const {\n level = undefined,\n filter = undefined,\n colors = defaultUseColor,\n levelHelper = true,\n nameBrackets = true,\n padding = 0,\n fill = 0,\n stack = defaultUseStack,\n time = true,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level))\n return\n if (!matchesNamespace(msg.name))\n return\n const timeNow = getTimestamp()\n const name = msg.name || ''\n let ninfo = namespaces[name || '']\n if (ninfo == null) {\n ninfo = {\n color: nodeSelectColorByName(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const timeDiffString = formatMilliseconds(timeNow - startTime!)\n\n let args: string[]\n\n let displayName = nameBrackets ? `[${name}]` : name\n\n if (padding > 0)\n displayName = displayName.padStart(padding, ' ')\n\n if (fill > 0)\n displayName = displayName.padEnd(fill, ' ')\n\n if (colors) {\n const c = ninfo.color\n args = [`${colorString(displayName, c)} | `] // nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n if (msg.level === LogLevelWarn)\n args.push(...colorStringList(msg.messages, TTY_STYLE.ORANGE))\n else if (msg.level === LogLevelError)\n args.push(...colorStringList(msg.messages, TTY_STYLE.RED))\n else\n args.push(...msg.messages)\n if (time)\n args.push(colorString(`+${timeDiffString}`, c))\n }\n else {\n args = [displayName, ...msg.messages]\n if (time)\n args.push(`+${timeDiffString}`)\n }\n\n if (msg.messages?.[0] === loggerStackTraceDebug) {\n try {\n // eslint-disable-next-line no-console\n console.log(getStack())\n }\n catch (err) { }\n }\n\n // Probably time consuming\n if (stack) {\n let line = ''\n if (typeof stack === 'boolean') {\n line = getSourceLocationByPrecedingPattern(\n ['at Function.', 'at null.log (', 'at log ('],\n true,\n )\n if (!line)\n line = getSourceLocation(0, true)\n }\n else {\n const depth = typeof stack === 'number' ? stack : 3\n line = getSourceLocation(depth, true)\n }\n if (line)\n args.push(colorString(`(${line})`, COLOR.GRAY))\n }\n\n const sep = '|'\n const charLevel = '.'\n\n switch (msg.level) {\n case LogLevelInfo:\n if (levelHelper)\n args[0] = `I${sep}${charLevel} ${args[0]}`\n log(...args)\n break\n case LogLevelWarn:\n if (levelHelper) {\n args[0] = (colors\n ? colorString(`W${sep}${charLevel}${charLevel} `, COLOR.ORANGE)\n : `W${sep}${charLevel}${charLevel} `) + args[0]\n }\n log(...args)\n break\n case LogLevelError:\n if (levelHelper) {\n args[0] = (colors\n ? colorString(`E${sep}${charLevel}${charLevel}${charLevel} `, COLOR.RED)\n : `E${sep}${charLevel}${charLevel}${charLevel} `) + args[0]\n }\n log(...args)\n break\n default:\n if (levelHelper)\n args[0] = `D${sep} ${args[0]}`\n log(...args)\n break\n }\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"log-node.cjs","names":["valueToBoolean","process","tty","renderMessages","getTimestamp","useNamespaceFilter","useLevelFilter","formatMilliseconds","getStack","getSourceLocationByPrecedingPattern","getSourceLocation"],"sources":["../../../src/node/log/log-node.ts"],"sourcesContent":["import type { LogHandler, LogHandlerOptions, LogMessage } from '../../common/log/log-base'\nimport process from 'node:process'\nimport tty from 'node:tty'\nimport { valueToBoolean } from '../../common/data/convert'\nimport { renderMessages } from '../../common/data/message'\nimport { LogLevelError, LogLevelInfo, LogLevelWarn } from '../../common/log/log-base'\nimport { useLevelFilter, useNamespaceFilter } from '../../common/log/log-filter'\nimport { formatMilliseconds, getTimestamp } from '../../common/time'\nimport { getSourceLocation, getSourceLocationByPrecedingPattern, getStack } from './log-util'\n\nfunction shouldUseColor(): boolean {\n try {\n return valueToBoolean(process.env.ZEED_COLOR, tty.isatty(process.stdout.fd))\n }\n catch (err) {}\n return false\n}\n\nlet defaultUseColor: boolean | undefined\n\nconst colors = [6, 2, 3, 4, 5, 1]\n\nfunction nodeSelectColorByName(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n\nconst namespaces: Record<string, any> = {}\n\nlet startTime: number | undefined\n\nfunction log(...args: any[]) {\n process.stdout.write(`${renderMessages(args)}\\n`)\n}\n\n// const _browserStyleMap = {\n// [BOLD]: { \"font-weight\": \"bold\" },\n// [UNBOLD]: { \"font-weight\": \"normal\" },\n// [BLUE]: { color: \"blue\" },\n// [GREEN]: { color: \"green\" },\n// [GREY]: { color: \"grey\" },\n// [RED]: { color: \"red\" },\n// [PURPLE]: { color: \"purple\" },\n// [ORANGE]: { color: \"orange\" },\n// [UNCOLOR]: { color: \"black\" },\n// }\n\nconst TTY_STYLE = {\n BOLD: '\\u001B[1m',\n UNBOLD: '\\u001B[2m',\n RED: '\\u001B[31m',\n GREEN: '\\u001B[32m',\n BLUE: '\\u001B[34m',\n PURPLE: '\\u001B[35m',\n GRAY: '\\u001B[37m',\n ORANGE: '\\u001B[38;5;208m',\n UNCOLOR: '\\u001B[0m',\n}\n\nenum COLOR {\n RED = 1,\n GREEN = 2,\n BLUE = 4,\n PURPLE = 5,\n GRAY = 7,\n ORANGE = 8,\n}\n\nconst colorEnd = '\\u001B[0m'\n\nexport function colorString(text: string, colorCode: number) {\n const colorStart = colorCode === COLOR.ORANGE\n ? TTY_STYLE.ORANGE\n : `\\u001B[3${colorCode < 8 ? colorCode : `8;5;${colorCode}`}m`\n return `${colorStart}${text}${colorEnd}`\n}\n\nexport function colorStringList(\n list: Array<any>,\n style: string,\n bold = true,\n) {\n return list.map((value) => {\n if (typeof value !== 'string')\n return value\n let start = style\n let end = colorEnd\n if (bold) {\n start = `${TTY_STYLE.BOLD}${start}`\n end = `${end}${TTY_STYLE.BOLD}`\n }\n return `${start}${value}${end}`\n })\n}\n\nfunction shouldUseStack(): boolean {\n try {\n return valueToBoolean(process.env.ZEED_STACK, false)\n }\n catch (err) {}\n return false\n}\n\nlet defaultUseStack: boolean | undefined\n\nexport const loggerStackTraceDebug = 'loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485'\n\nexport function LoggerNodeHandler(opt: LogHandlerOptions = {}): LogHandler {\n defaultUseColor ??= shouldUseColor()\n\n defaultUseStack ??= shouldUseStack()\n\n startTime ??= getTimestamp()\n\n const {\n level = undefined,\n filter = undefined,\n colors = defaultUseColor,\n levelHelper = true,\n nameBrackets = true,\n padding = 0,\n fill = 0,\n stack = defaultUseStack,\n time = true,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level))\n return\n if (!matchesNamespace(msg.name))\n return\n const timeNow = getTimestamp()\n const name = msg.name || ''\n let ninfo = namespaces[name || '']\n if (ninfo == null) {\n ninfo = {\n color: nodeSelectColorByName(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const timeDiffString = formatMilliseconds(timeNow - startTime!)\n\n let args: string[]\n\n let displayName = nameBrackets ? `[${name}]` : name\n\n if (padding > 0)\n displayName = displayName.padStart(padding, ' ')\n\n if (fill > 0)\n displayName = displayName.padEnd(fill, ' ')\n\n if (colors) {\n const c = ninfo.color\n args = [`${colorString(displayName, c)} | `] // nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n if (msg.level === LogLevelWarn)\n args.push(...colorStringList(msg.messages, TTY_STYLE.ORANGE))\n else if (msg.level === LogLevelError)\n args.push(...colorStringList(msg.messages, TTY_STYLE.RED))\n else\n args.push(...msg.messages)\n if (time)\n args.push(colorString(`+${timeDiffString}`, c))\n }\n else {\n args = [displayName, ...msg.messages]\n if (time)\n args.push(`+${timeDiffString}`)\n }\n\n if (msg.messages?.[0] === loggerStackTraceDebug) {\n try {\n // eslint-disable-next-line no-console\n console.log(getStack())\n }\n catch (err) { }\n }\n\n // Probably time consuming\n if (stack) {\n let line = ''\n if (typeof stack === 'boolean') {\n line = getSourceLocationByPrecedingPattern(\n ['at Function.', 'at null.log (', 'at log ('],\n true,\n )\n if (!line)\n line = getSourceLocation(0, true)\n }\n else {\n const depth = typeof stack === 'number' ? stack : 3\n line = getSourceLocation(depth, true)\n }\n if (line)\n args.push(colorString(`(${line})`, COLOR.GRAY))\n }\n\n const sep = '|'\n const charLevel = '.'\n\n switch (msg.level) {\n case LogLevelInfo:\n if (levelHelper)\n args[0] = `I${sep}${charLevel} ${args[0]}`\n log(...args)\n break\n case LogLevelWarn:\n if (levelHelper) {\n args[0] = (colors\n ? colorString(`W${sep}${charLevel}${charLevel} `, COLOR.ORANGE)\n : `W${sep}${charLevel}${charLevel} `) + args[0]\n }\n log(...args)\n break\n case LogLevelError:\n if (levelHelper) {\n args[0] = (colors\n ? colorString(`E${sep}${charLevel}${charLevel}${charLevel} `, COLOR.RED)\n : `E${sep}${charLevel}${charLevel}${charLevel} `) + args[0]\n }\n log(...args)\n break\n default:\n if (levelHelper)\n args[0] = `D${sep} ${args[0]}`\n log(...args)\n break\n }\n }\n}\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../../log-node-Dk948mHX.cjs";
1
+ import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../../log-node-D_fiJL6x.cjs";
2
2
  export { LoggerNodeHandler, colorString, colorStringList, loggerStackTraceDebug };
@@ -1,2 +1,2 @@
1
- import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../../log-node-DlrXl3QO.mjs";
1
+ import { i as loggerStackTraceDebug, n as colorString, r as colorStringList, t as LoggerNodeHandler } from "../../log-node-BSn7RqAc.mjs";
2
2
  export { LoggerNodeHandler, colorString, colorStringList, loggerStackTraceDebug };
@@ -47,18 +47,9 @@ const TTY_STYLE = {
47
47
  ORANGE: "\x1B[38;5;208m",
48
48
  UNCOLOR: "\x1B[0m"
49
49
  };
50
- var COLOR = /* @__PURE__ */ function(COLOR) {
51
- COLOR[COLOR["RED"] = 1] = "RED";
52
- COLOR[COLOR["GREEN"] = 2] = "GREEN";
53
- COLOR[COLOR["BLUE"] = 4] = "BLUE";
54
- COLOR[COLOR["PURPLE"] = 5] = "PURPLE";
55
- COLOR[COLOR["GRAY"] = 7] = "GRAY";
56
- COLOR[COLOR["ORANGE"] = 8] = "ORANGE";
57
- return COLOR;
58
- }(COLOR || {});
59
50
  const colorEnd = "\x1B[0m";
60
51
  function colorString(text, colorCode) {
61
- return `${colorCode === COLOR.ORANGE ? TTY_STYLE.ORANGE : `\u001B[3${colorCode < 8 ? colorCode : `8;5;${colorCode}`}m`}${text}${colorEnd}`;
52
+ return `${colorCode === 8 ? TTY_STYLE.ORANGE : `\u001B[3${colorCode < 8 ? colorCode : `8;5;${colorCode}`}m`}${text}${colorEnd}`;
62
53
  }
63
54
  function colorStringList(list, style, bold = true) {
64
55
  return list.map((value) => {
@@ -126,7 +117,7 @@ function LoggerNodeHandler(opt = {}) {
126
117
  ], true);
127
118
  if (!line) line = getSourceLocation(0, true);
128
119
  } else line = getSourceLocation(typeof stack === "number" ? stack : 3, true);
129
- if (line) args.push(colorString(`(${line})`, COLOR.GRAY));
120
+ if (line) args.push(colorString(`(${line})`, 7));
130
121
  }
131
122
  const sep = "|";
132
123
  const charLevel = ".";
@@ -136,11 +127,11 @@ function LoggerNodeHandler(opt = {}) {
136
127
  log(...args);
137
128
  break;
138
129
  case 2:
139
- if (levelHelper) args[0] = (colors ? colorString(`W${sep}${charLevel}${charLevel} `, COLOR.ORANGE) : `W${sep}${charLevel}${charLevel} `) + args[0];
130
+ if (levelHelper) args[0] = (colors ? colorString(`W${sep}${charLevel}${charLevel} `, 8) : `W${sep}${charLevel}${charLevel} `) + args[0];
140
131
  log(...args);
141
132
  break;
142
133
  case 3:
143
- if (levelHelper) args[0] = (colors ? colorString(`E${sep}${charLevel}${charLevel}${charLevel} `, COLOR.RED) : `E${sep}${charLevel}${charLevel}${charLevel} `) + args[0];
134
+ if (levelHelper) args[0] = (colors ? colorString(`E${sep}${charLevel}${charLevel}${charLevel} `, 1) : `E${sep}${charLevel}${charLevel}${charLevel} `) + args[0];
144
135
  log(...args);
145
136
  break;
146
137
  default:
@@ -1 +1 @@
1
- {"version":3,"file":"log-node.mjs","names":[],"sources":["../../../src/node/log/log-node.ts"],"sourcesContent":["import type { LogHandler, LogHandlerOptions, LogMessage } from '../../common/log/log-base'\nimport process from 'node:process'\nimport tty from 'node:tty'\nimport { valueToBoolean } from '../../common/data/convert'\nimport { renderMessages } from '../../common/data/message'\nimport { LogLevelError, LogLevelInfo, LogLevelWarn } from '../../common/log/log-base'\nimport { useLevelFilter, useNamespaceFilter } from '../../common/log/log-filter'\nimport { formatMilliseconds, getTimestamp } from '../../common/time'\nimport { getSourceLocation, getSourceLocationByPrecedingPattern, getStack } from './log-util'\n\nfunction shouldUseColor(): boolean {\n try {\n return valueToBoolean(process.env.ZEED_COLOR, tty.isatty(process.stdout.fd))\n }\n catch (err) {}\n return false\n}\n\nlet defaultUseColor: boolean | undefined\n\nconst colors = [6, 2, 3, 4, 5, 1]\n\nfunction nodeSelectColorByName(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n\nconst namespaces: Record<string, any> = {}\n\nlet startTime: number | undefined\n\nfunction log(...args: any[]) {\n process.stdout.write(`${renderMessages(args)}\\n`)\n}\n\n// const _browserStyleMap = {\n// [BOLD]: { \"font-weight\": \"bold\" },\n// [UNBOLD]: { \"font-weight\": \"normal\" },\n// [BLUE]: { color: \"blue\" },\n// [GREEN]: { color: \"green\" },\n// [GREY]: { color: \"grey\" },\n// [RED]: { color: \"red\" },\n// [PURPLE]: { color: \"purple\" },\n// [ORANGE]: { color: \"orange\" },\n// [UNCOLOR]: { color: \"black\" },\n// }\n\nconst TTY_STYLE = {\n BOLD: '\\u001B[1m',\n UNBOLD: '\\u001B[2m',\n RED: '\\u001B[31m',\n GREEN: '\\u001B[32m',\n BLUE: '\\u001B[34m',\n PURPLE: '\\u001B[35m',\n GRAY: '\\u001B[37m',\n ORANGE: '\\u001B[38;5;208m',\n UNCOLOR: '\\u001B[0m',\n}\n\nenum COLOR {\n RED = 1,\n GREEN = 2,\n BLUE = 4,\n PURPLE = 5,\n GRAY = 7,\n ORANGE = 8,\n}\n\nconst colorEnd = '\\u001B[0m'\n\nexport function colorString(text: string, colorCode: number) {\n const colorStart = colorCode === COLOR.ORANGE\n ? TTY_STYLE.ORANGE\n : `\\u001B[3${colorCode < 8 ? colorCode : `8;5;${colorCode}`}m`\n return `${colorStart}${text}${colorEnd}`\n}\n\nexport function colorStringList(\n list: Array<any>,\n style: string,\n bold = true,\n) {\n return list.map((value) => {\n if (typeof value !== 'string')\n return value\n let start = style\n let end = colorEnd\n if (bold) {\n start = `${TTY_STYLE.BOLD}${start}`\n end = `${end}${TTY_STYLE.BOLD}`\n }\n return `${start}${value}${end}`\n })\n}\n\nfunction shouldUseStack(): boolean {\n try {\n return valueToBoolean(process.env.ZEED_STACK, false)\n }\n catch (err) {}\n return false\n}\n\nlet defaultUseStack: boolean | undefined\n\nexport const loggerStackTraceDebug = 'loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485'\n\nexport function LoggerNodeHandler(opt: LogHandlerOptions = {}): LogHandler {\n defaultUseColor ??= shouldUseColor()\n\n defaultUseStack ??= shouldUseStack()\n\n startTime ??= getTimestamp()\n\n const {\n level = undefined,\n filter = undefined,\n colors = defaultUseColor,\n levelHelper = true,\n nameBrackets = true,\n padding = 0,\n fill = 0,\n stack = defaultUseStack,\n time = true,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level))\n return\n if (!matchesNamespace(msg.name))\n return\n const timeNow = getTimestamp()\n const name = msg.name || ''\n let ninfo = namespaces[name || '']\n if (ninfo == null) {\n ninfo = {\n color: nodeSelectColorByName(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const timeDiffString = formatMilliseconds(timeNow - startTime!)\n\n let args: string[]\n\n let displayName = nameBrackets ? `[${name}]` : name\n\n if (padding > 0)\n displayName = displayName.padStart(padding, ' ')\n\n if (fill > 0)\n displayName = displayName.padEnd(fill, ' ')\n\n if (colors) {\n const c = ninfo.color\n args = [`${colorString(displayName, c)} | `] // nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n if (msg.level === LogLevelWarn)\n args.push(...colorStringList(msg.messages, TTY_STYLE.ORANGE))\n else if (msg.level === LogLevelError)\n args.push(...colorStringList(msg.messages, TTY_STYLE.RED))\n else\n args.push(...msg.messages)\n if (time)\n args.push(colorString(`+${timeDiffString}`, c))\n }\n else {\n args = [displayName, ...msg.messages]\n if (time)\n args.push(`+${timeDiffString}`)\n }\n\n if (msg.messages?.[0] === loggerStackTraceDebug) {\n try {\n // eslint-disable-next-line no-console\n console.log(getStack())\n }\n catch (err) { }\n }\n\n // Probably time consuming\n if (stack) {\n let line = ''\n if (typeof stack === 'boolean') {\n line = getSourceLocationByPrecedingPattern(\n ['at Function.', 'at null.log (', 'at log ('],\n true,\n )\n if (!line)\n line = getSourceLocation(0, true)\n }\n else {\n const depth = typeof stack === 'number' ? stack : 3\n line = getSourceLocation(depth, true)\n }\n if (line)\n args.push(colorString(`(${line})`, COLOR.GRAY))\n }\n\n const sep = '|'\n const charLevel = '.'\n\n switch (msg.level) {\n case LogLevelInfo:\n if (levelHelper)\n args[0] = `I${sep}${charLevel} ${args[0]}`\n log(...args)\n break\n case LogLevelWarn:\n if (levelHelper) {\n args[0] = (colors\n ? colorString(`W${sep}${charLevel}${charLevel} `, COLOR.ORANGE)\n : `W${sep}${charLevel}${charLevel} `) + args[0]\n }\n log(...args)\n break\n case LogLevelError:\n if (levelHelper) {\n args[0] = (colors\n ? colorString(`E${sep}${charLevel}${charLevel}${charLevel} `, COLOR.RED)\n : `E${sep}${charLevel}${charLevel}${charLevel} `) + args[0]\n }\n log(...args)\n break\n default:\n if (levelHelper)\n args[0] = `D${sep} ${args[0]}`\n log(...args)\n break\n }\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"log-node.mjs","names":[],"sources":["../../../src/node/log/log-node.ts"],"sourcesContent":["import type { LogHandler, LogHandlerOptions, LogMessage } from '../../common/log/log-base'\nimport process from 'node:process'\nimport tty from 'node:tty'\nimport { valueToBoolean } from '../../common/data/convert'\nimport { renderMessages } from '../../common/data/message'\nimport { LogLevelError, LogLevelInfo, LogLevelWarn } from '../../common/log/log-base'\nimport { useLevelFilter, useNamespaceFilter } from '../../common/log/log-filter'\nimport { formatMilliseconds, getTimestamp } from '../../common/time'\nimport { getSourceLocation, getSourceLocationByPrecedingPattern, getStack } from './log-util'\n\nfunction shouldUseColor(): boolean {\n try {\n return valueToBoolean(process.env.ZEED_COLOR, tty.isatty(process.stdout.fd))\n }\n catch (err) {}\n return false\n}\n\nlet defaultUseColor: boolean | undefined\n\nconst colors = [6, 2, 3, 4, 5, 1]\n\nfunction nodeSelectColorByName(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n\nconst namespaces: Record<string, any> = {}\n\nlet startTime: number | undefined\n\nfunction log(...args: any[]) {\n process.stdout.write(`${renderMessages(args)}\\n`)\n}\n\n// const _browserStyleMap = {\n// [BOLD]: { \"font-weight\": \"bold\" },\n// [UNBOLD]: { \"font-weight\": \"normal\" },\n// [BLUE]: { color: \"blue\" },\n// [GREEN]: { color: \"green\" },\n// [GREY]: { color: \"grey\" },\n// [RED]: { color: \"red\" },\n// [PURPLE]: { color: \"purple\" },\n// [ORANGE]: { color: \"orange\" },\n// [UNCOLOR]: { color: \"black\" },\n// }\n\nconst TTY_STYLE = {\n BOLD: '\\u001B[1m',\n UNBOLD: '\\u001B[2m',\n RED: '\\u001B[31m',\n GREEN: '\\u001B[32m',\n BLUE: '\\u001B[34m',\n PURPLE: '\\u001B[35m',\n GRAY: '\\u001B[37m',\n ORANGE: '\\u001B[38;5;208m',\n UNCOLOR: '\\u001B[0m',\n}\n\nenum COLOR {\n RED = 1,\n GREEN = 2,\n BLUE = 4,\n PURPLE = 5,\n GRAY = 7,\n ORANGE = 8,\n}\n\nconst colorEnd = '\\u001B[0m'\n\nexport function colorString(text: string, colorCode: number) {\n const colorStart = colorCode === COLOR.ORANGE\n ? TTY_STYLE.ORANGE\n : `\\u001B[3${colorCode < 8 ? colorCode : `8;5;${colorCode}`}m`\n return `${colorStart}${text}${colorEnd}`\n}\n\nexport function colorStringList(\n list: Array<any>,\n style: string,\n bold = true,\n) {\n return list.map((value) => {\n if (typeof value !== 'string')\n return value\n let start = style\n let end = colorEnd\n if (bold) {\n start = `${TTY_STYLE.BOLD}${start}`\n end = `${end}${TTY_STYLE.BOLD}`\n }\n return `${start}${value}${end}`\n })\n}\n\nfunction shouldUseStack(): boolean {\n try {\n return valueToBoolean(process.env.ZEED_STACK, false)\n }\n catch (err) {}\n return false\n}\n\nlet defaultUseStack: boolean | undefined\n\nexport const loggerStackTraceDebug = 'loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485'\n\nexport function LoggerNodeHandler(opt: LogHandlerOptions = {}): LogHandler {\n defaultUseColor ??= shouldUseColor()\n\n defaultUseStack ??= shouldUseStack()\n\n startTime ??= getTimestamp()\n\n const {\n level = undefined,\n filter = undefined,\n colors = defaultUseColor,\n levelHelper = true,\n nameBrackets = true,\n padding = 0,\n fill = 0,\n stack = defaultUseStack,\n time = true,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level))\n return\n if (!matchesNamespace(msg.name))\n return\n const timeNow = getTimestamp()\n const name = msg.name || ''\n let ninfo = namespaces[name || '']\n if (ninfo == null) {\n ninfo = {\n color: nodeSelectColorByName(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const timeDiffString = formatMilliseconds(timeNow - startTime!)\n\n let args: string[]\n\n let displayName = nameBrackets ? `[${name}]` : name\n\n if (padding > 0)\n displayName = displayName.padStart(padding, ' ')\n\n if (fill > 0)\n displayName = displayName.padEnd(fill, ' ')\n\n if (colors) {\n const c = ninfo.color\n args = [`${colorString(displayName, c)} | `] // nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n if (msg.level === LogLevelWarn)\n args.push(...colorStringList(msg.messages, TTY_STYLE.ORANGE))\n else if (msg.level === LogLevelError)\n args.push(...colorStringList(msg.messages, TTY_STYLE.RED))\n else\n args.push(...msg.messages)\n if (time)\n args.push(colorString(`+${timeDiffString}`, c))\n }\n else {\n args = [displayName, ...msg.messages]\n if (time)\n args.push(`+${timeDiffString}`)\n }\n\n if (msg.messages?.[0] === loggerStackTraceDebug) {\n try {\n // eslint-disable-next-line no-console\n console.log(getStack())\n }\n catch (err) { }\n }\n\n // Probably time consuming\n if (stack) {\n let line = ''\n if (typeof stack === 'boolean') {\n line = getSourceLocationByPrecedingPattern(\n ['at Function.', 'at null.log (', 'at log ('],\n true,\n )\n if (!line)\n line = getSourceLocation(0, true)\n }\n else {\n const depth = typeof stack === 'number' ? stack : 3\n line = getSourceLocation(depth, true)\n }\n if (line)\n args.push(colorString(`(${line})`, COLOR.GRAY))\n }\n\n const sep = '|'\n const charLevel = '.'\n\n switch (msg.level) {\n case LogLevelInfo:\n if (levelHelper)\n args[0] = `I${sep}${charLevel} ${args[0]}`\n log(...args)\n break\n case LogLevelWarn:\n if (levelHelper) {\n args[0] = (colors\n ? colorString(`W${sep}${charLevel}${charLevel} `, COLOR.ORANGE)\n : `W${sep}${charLevel}${charLevel} `) + args[0]\n }\n log(...args)\n break\n case LogLevelError:\n if (levelHelper) {\n args[0] = (colors\n ? colorString(`E${sep}${charLevel}${charLevel}${charLevel} `, COLOR.RED)\n : `E${sep}${charLevel}${charLevel}${charLevel} `) + args[0]\n }\n log(...args)\n break\n default:\n if (levelHelper)\n args[0] = `D${sep} ${args[0]}`\n log(...args)\n break\n }\n }\n}\n"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
2
  const require_chunk = require('../../chunk-uaV2rQ02.cjs');
3
3
  let node_process = require("node:process");
4
- node_process = require_chunk.__toESM(node_process);
4
+ node_process = require_chunk.__toESM(node_process, 1);
5
5
  let node_fs = require("node:fs");
6
6
  let node_path = require("node:path");
7
7
  let node_fs_promises = require("node:fs/promises");
@@ -1,2 +1,2 @@
1
- import { a as RotationFileSizeUnit, c as RotationIntervalUnit, i as RotationFileSize, l as RotationOptions, n as RotatingFileStreamError, o as RotationGenerator, r as RotationCompressor, s as RotationInterval, t as RotatingFileStream, u as createRotationStream } from "../../log-rotation-_d7iRm9s.cjs";
1
+ import { a as RotationFileSizeUnit, c as RotationIntervalUnit, i as RotationFileSize, l as RotationOptions, n as RotatingFileStreamError, o as RotationGenerator, r as RotationCompressor, s as RotationInterval, t as RotatingFileStream, u as createRotationStream } from "../../log-rotation-BdGakFya.cjs";
2
2
  export { RotatingFileStream, RotatingFileStreamError, RotationCompressor, RotationFileSize, RotationFileSizeUnit, RotationGenerator, RotationInterval, RotationIntervalUnit, RotationOptions, createRotationStream };
@@ -1,2 +1,2 @@
1
- import { a as RotationFileSizeUnit, c as RotationIntervalUnit, i as RotationFileSize, l as RotationOptions, n as RotatingFileStreamError, o as RotationGenerator, r as RotationCompressor, s as RotationInterval, t as RotatingFileStream, u as createRotationStream } from "../../log-rotation-CkyjZbK5.mjs";
1
+ import { a as RotationFileSizeUnit, c as RotationIntervalUnit, i as RotationFileSize, l as RotationOptions, n as RotatingFileStreamError, o as RotationGenerator, r as RotationCompressor, s as RotationInterval, t as RotatingFileStream, u as createRotationStream } from "../../log-rotation-Ce4e-8LN.mjs";
2
2
  export { RotatingFileStream, RotatingFileStreamError, RotationCompressor, RotationFileSize, RotationFileSizeUnit, RotationGenerator, RotationInterval, RotationIntervalUnit, RotationOptions, createRotationStream };
@@ -2,7 +2,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
2
  const require_chunk = require('../../chunk-uaV2rQ02.cjs');
3
3
  const require_common_data_is = require('../../common/data/is.cjs');
4
4
  let node_process = require("node:process");
5
- node_process = require_chunk.__toESM(node_process);
5
+ node_process = require_chunk.__toESM(node_process, 1);
6
6
  let node_path = require("node:path");
7
7
 
8
8
  //#region src/node/log/log-util.ts
@@ -1,2 +1,2 @@
1
- import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../../log-util-2Ls76P-0.cjs";
1
+ import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../../log-util-C0U3zCjw.cjs";
2
2
  export { getSourceLocation, getSourceLocationByPrecedingPattern, getStack, getStackLlocationList };
@@ -1,2 +1,2 @@
1
- import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../../log-util-Da_d19f8.mjs";
1
+ import { i as getStackLlocationList, n as getSourceLocationByPrecedingPattern, r as getStack, t as getSourceLocation } from "../../log-util-Da_UCcmt.mjs";
2
2
  export { getSourceLocation, getSourceLocationByPrecedingPattern, getStack, getStackLlocationList };
@@ -33,4 +33,4 @@ declare function promisify<T>(value: Promise<T> | T): Promise<T>;
33
33
  type AsyncReturnType<T extends (...args: any) => any> = T extends ((...args: any) => Promise<infer U>) ? U : T extends ((...args: any) => infer U) ? U : any;
34
34
  //#endregion
35
35
  export { isTimeout as a, timeout as c, isPromise as i, tryTimeout as l, createPromise as n, promisify as o, immediate as r, sleep as s, AsyncReturnType as t, waitOn as u };
36
- //# sourceMappingURL=promise-DGgiRckN.d.cts.map
36
+ //# sourceMappingURL=promise-CU_CENbU.d.cts.map
@@ -33,4 +33,4 @@ declare function promisify<T>(value: Promise<T> | T): Promise<T>;
33
33
  type AsyncReturnType<T extends (...args: any) => any> = T extends ((...args: any) => Promise<infer U>) ? U : T extends ((...args: any) => infer U) ? U : any;
34
34
  //#endregion
35
35
  export { isTimeout as a, timeout as c, isPromise as i, tryTimeout as l, createPromise as n, promisify as o, immediate as r, sleep as s, AsyncReturnType as t, waitOn as u };
36
- //# sourceMappingURL=promise-MH3xAy4S.d.mts.map
36
+ //# sourceMappingURL=promise-CoWXgo4w.d.mts.map
@@ -0,0 +1,52 @@
1
+ import { n as Type, t as Infer } from "./schema-BNke0iHR.cjs";
2
+ import { n as TableColumns, r as TableShape, t as Column } from "./table-IkLXirT-.cjs";
3
+ import { t as Expr } from "./expr-yYgSeBZ3.cjs";
4
+
5
+ //#region src/common/schema/sql/select.d.ts
6
+ type RowFromTable<T> = T extends TableColumns<any, infer S> ? { [K in keyof S]: Infer<S[K]> } : never;
7
+ type RowFromSelection<S> = { [K in keyof S]: S[K] extends Column<infer T> ? T : never };
8
+ interface QueryDependencies {
9
+ readonly table: string;
10
+ readonly select: readonly string[];
11
+ readonly where: readonly string[];
12
+ readonly orderBy: readonly string[];
13
+ readonly all: readonly string[];
14
+ }
15
+ interface CompiledQuery<Row> {
16
+ readonly sql: string;
17
+ readonly params: readonly unknown[];
18
+ readonly dependencies: readonly QueryDependencies[];
19
+ readonly __row?: Row;
20
+ }
21
+ interface OrderByEntry {
22
+ col: Column;
23
+ dir: 'ASC' | 'DESC';
24
+ }
25
+ interface SelectState {
26
+ selection?: Record<string, Column>;
27
+ from?: TableColumns<any, any>;
28
+ where?: Expr;
29
+ orderBy: OrderByEntry[];
30
+ limit?: number;
31
+ offset?: number;
32
+ }
33
+ type ShapeRow<S> = { [K in keyof S]: S[K] extends Type<infer T> ? T : never };
34
+ declare class SelectBuilder<Row, Shape = unknown> {
35
+ private _state;
36
+ constructor(state: SelectState);
37
+ from<N extends string, S extends TableShape>(t: TableColumns<N, S>): SelectBuilder<Row extends void ? ShapeRow<S> : Row, S>;
38
+ pick<K extends Extract<keyof Shape, string>>(...keys: K[]): SelectBuilder<{ [P in K]: Shape[P] extends Type<infer T> ? T : never }, Shape>;
39
+ where(expr: Expr): this;
40
+ orderBy(col: Column, dir?: 'ASC' | 'DESC'): this;
41
+ limit(n: number): this;
42
+ offset(n: number): this;
43
+ toSQL(): CompiledQuery<Row>;
44
+ dependencies(): readonly QueryDependencies[];
45
+ }
46
+ declare function select(): SelectBuilder<void>;
47
+ declare function select<S extends Record<string, Column<any>>>(selection: S): SelectBuilder<RowFromSelection<S>>;
48
+ declare function from<N extends string, S extends TableShape>(t: TableColumns<N, S>): SelectBuilder<ShapeRow<S>, S>;
49
+ type InferRow<Q> = Q extends SelectBuilder<infer R> ? R : Q extends CompiledQuery<infer R> ? R : never;
50
+ //#endregion
51
+ export { RowFromTable as a, select as c, RowFromSelection as i, InferRow as n, SelectBuilder as o, QueryDependencies as r, from as s, CompiledQuery as t };
52
+ //# sourceMappingURL=select-DrciHdk_.d.cts.map
@@ -0,0 +1,52 @@
1
+ import { n as Type, t as Infer } from "./schema-eMFkYY24.mjs";
2
+ import { n as TableColumns, r as TableShape, t as Column } from "./table-Cr8tjDIL.mjs";
3
+ import { t as Expr } from "./expr-CCKrqOw1.mjs";
4
+
5
+ //#region src/common/schema/sql/select.d.ts
6
+ type RowFromTable<T> = T extends TableColumns<any, infer S> ? { [K in keyof S]: Infer<S[K]> } : never;
7
+ type RowFromSelection<S> = { [K in keyof S]: S[K] extends Column<infer T> ? T : never };
8
+ interface QueryDependencies {
9
+ readonly table: string;
10
+ readonly select: readonly string[];
11
+ readonly where: readonly string[];
12
+ readonly orderBy: readonly string[];
13
+ readonly all: readonly string[];
14
+ }
15
+ interface CompiledQuery<Row> {
16
+ readonly sql: string;
17
+ readonly params: readonly unknown[];
18
+ readonly dependencies: readonly QueryDependencies[];
19
+ readonly __row?: Row;
20
+ }
21
+ interface OrderByEntry {
22
+ col: Column;
23
+ dir: 'ASC' | 'DESC';
24
+ }
25
+ interface SelectState {
26
+ selection?: Record<string, Column>;
27
+ from?: TableColumns<any, any>;
28
+ where?: Expr;
29
+ orderBy: OrderByEntry[];
30
+ limit?: number;
31
+ offset?: number;
32
+ }
33
+ type ShapeRow<S> = { [K in keyof S]: S[K] extends Type<infer T> ? T : never };
34
+ declare class SelectBuilder<Row, Shape = unknown> {
35
+ private _state;
36
+ constructor(state: SelectState);
37
+ from<N extends string, S extends TableShape>(t: TableColumns<N, S>): SelectBuilder<Row extends void ? ShapeRow<S> : Row, S>;
38
+ pick<K extends Extract<keyof Shape, string>>(...keys: K[]): SelectBuilder<{ [P in K]: Shape[P] extends Type<infer T> ? T : never }, Shape>;
39
+ where(expr: Expr): this;
40
+ orderBy(col: Column, dir?: 'ASC' | 'DESC'): this;
41
+ limit(n: number): this;
42
+ offset(n: number): this;
43
+ toSQL(): CompiledQuery<Row>;
44
+ dependencies(): readonly QueryDependencies[];
45
+ }
46
+ declare function select(): SelectBuilder<void>;
47
+ declare function select<S extends Record<string, Column<any>>>(selection: S): SelectBuilder<RowFromSelection<S>>;
48
+ declare function from<N extends string, S extends TableShape>(t: TableColumns<N, S>): SelectBuilder<ShapeRow<S>, S>;
49
+ type InferRow<Q> = Q extends SelectBuilder<infer R> ? R : Q extends CompiledQuery<infer R> ? R : never;
50
+ //#endregion
51
+ export { RowFromTable as a, select as c, RowFromSelection as i, InferRow as n, SelectBuilder as o, QueryDependencies as r, from as s, CompiledQuery as t };
52
+ //# sourceMappingURL=select-F2KpP6mo.d.mts.map
@@ -0,0 +1,19 @@
1
+ import { n as Type, t as Infer } from "./schema-eMFkYY24.mjs";
2
+
3
+ //#region src/common/schema/sql/table.d.ts
4
+ interface Column<T = unknown> {
5
+ readonly _table: string;
6
+ readonly _name: string;
7
+ readonly _type: Type<T>;
8
+ readonly __row?: T;
9
+ }
10
+ type TableShape = Record<string, Type<any>>;
11
+ type TableColumns<N extends string, S extends TableShape> = { readonly [K in keyof S & string]: Column<Infer<S[K]>> } & {
12
+ readonly _name: N;
13
+ readonly _shape: S;
14
+ };
15
+ declare function table<N extends string, S extends TableShape>(name: N, shape: S): TableColumns<N, S>;
16
+ declare function isColumn(v: any): v is Column;
17
+ //#endregion
18
+ export { table as a, isColumn as i, TableColumns as n, TableShape as r, Column as t };
19
+ //# sourceMappingURL=table-Cr8tjDIL.d.mts.map
@@ -0,0 +1,19 @@
1
+ import { n as Type, t as Infer } from "./schema-BNke0iHR.cjs";
2
+
3
+ //#region src/common/schema/sql/table.d.ts
4
+ interface Column<T = unknown> {
5
+ readonly _table: string;
6
+ readonly _name: string;
7
+ readonly _type: Type<T>;
8
+ readonly __row?: T;
9
+ }
10
+ type TableShape = Record<string, Type<any>>;
11
+ type TableColumns<N extends string, S extends TableShape> = { readonly [K in keyof S & string]: Column<Infer<S[K]>> } & {
12
+ readonly _name: N;
13
+ readonly _shape: S;
14
+ };
15
+ declare function table<N extends string, S extends TableShape>(name: N, shape: S): TableColumns<N, S>;
16
+ declare function isColumn(v: any): v is Column;
17
+ //#endregion
18
+ export { table as a, isColumn as i, TableColumns as n, TableShape as r, Column as t };
19
+ //# sourceMappingURL=table-IkLXirT-.d.cts.map
@@ -2,4 +2,4 @@
2
2
  declare function setTestMode(): void;
3
3
  //#endregion
4
4
  export { setTestMode as t };
5
- //# sourceMappingURL=test-CAhm15f4.d.mts.map
5
+ //# sourceMappingURL=test-DcXa0MeX.d.cts.map
@@ -2,4 +2,4 @@
2
2
  declare function setTestMode(): void;
3
3
  //#endregion
4
4
  export { setTestMode as t };
5
- //# sourceMappingURL=test-D2plOVHF.d.cts.map
5
+ //# sourceMappingURL=test-jZsc7P2c.d.mts.map
@@ -35,4 +35,4 @@ declare function debounce<F extends (...args: any[]) => any | Promise<any>>(call
35
35
  };
36
36
  //#endregion
37
37
  export { throttle as n, debounce as t };
38
- //# sourceMappingURL=throttle-debounce-BLFxAZ8W.d.mts.map
38
+ //# sourceMappingURL=throttle-debounce-CCh0F100.d.mts.map