@socketsecurity/lib 6.0.3 → 6.0.5

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 (542) hide show
  1. package/CHANGELOG.md +22 -0
  2. package/dist/_virtual/_rolldown/runtime.js +45 -0
  3. package/dist/abort/signal.js +53 -59
  4. package/dist/ai/discover.js +110 -110
  5. package/dist/ai/profiles.js +94 -65
  6. package/dist/ai/spawn.js +172 -194
  7. package/dist/ai/types.js +1 -17
  8. package/dist/ai/worktree.js +160 -183
  9. package/dist/ansi/constants.js +16 -38
  10. package/dist/ansi/strip.js +44 -41
  11. package/dist/archives/_internal.js +64 -73
  12. package/dist/archives/detect.js +30 -43
  13. package/dist/archives/extract.js +43 -50
  14. package/dist/archives/tar.js +197 -228
  15. package/dist/archives/types.js +1 -17
  16. package/dist/archives/zip.js +85 -121
  17. package/dist/argv/flag-predicates.js +203 -101
  18. package/dist/argv/flag-types.js +96 -113
  19. package/dist/argv/parse-args-string.d.ts +16 -14
  20. package/dist/argv/parse-args-string.js +42 -39
  21. package/dist/argv/parse.js +145 -163
  22. package/dist/arrays/_internal.js +65 -48
  23. package/dist/arrays/chunk.js +51 -40
  24. package/dist/arrays/join.js +87 -35
  25. package/dist/arrays/predicates.js +46 -28
  26. package/dist/arrays/unique.js +45 -31
  27. package/dist/bin/_internal.js +34 -42
  28. package/dist/bin/check-primordials.js +175 -233
  29. package/dist/bin/check.js +51 -72
  30. package/dist/bin/exec.js +70 -74
  31. package/dist/bin/find.js +151 -134
  32. package/dist/bin/resolve.js +180 -246
  33. package/dist/bin/shadow.js +24 -33
  34. package/dist/bin/socket-lib.js +51 -73
  35. package/dist/bin/types.js +1 -17
  36. package/dist/bin/which.js +211 -146
  37. package/dist/cacache/_internal.js +25 -40
  38. package/dist/cacache/clear.js +79 -72
  39. package/dist/cacache/read.js +48 -46
  40. package/dist/cacache/tmp.js +29 -36
  41. package/dist/cacache/types.js +1 -17
  42. package/dist/cacache/write.js +43 -48
  43. package/dist/cache/ttl/store.js +232 -288
  44. package/dist/cache/ttl/types.js +1 -17
  45. package/dist/checks/primordials-defaults.js +83 -89
  46. package/dist/checks/primordials.js +225 -277
  47. package/dist/colors/convert.js +45 -37
  48. package/dist/colors/palette.js +88 -45
  49. package/dist/colors/socket-palette.js +74 -84
  50. package/dist/colors/types.js +1 -17
  51. package/dist/compression/_internal.js +57 -72
  52. package/dist/compression/brotli.js +94 -127
  53. package/dist/compression/gzip.js +95 -121
  54. package/dist/compression/types.js +1 -17
  55. package/dist/constants/agents.js +61 -113
  56. package/dist/constants/encoding.js +19 -42
  57. package/dist/constants/github.js +12 -30
  58. package/dist/constants/licenses.js +48 -63
  59. package/dist/constants/lifecycle-script-names.js +31 -45
  60. package/dist/constants/maintained-node-versions.js +22 -37
  61. package/dist/constants/node.js +226 -167
  62. package/dist/constants/package-default-node-range.js +16 -41
  63. package/dist/constants/package-default-socket-categories.js +12 -30
  64. package/dist/constants/packages.js +77 -126
  65. package/dist/constants/platform.js +27 -49
  66. package/dist/constants/sentinels.js +23 -48
  67. package/dist/constants/socket.js +42 -87
  68. package/dist/constants/testing.js +15 -34
  69. package/dist/constants/time.js +16 -36
  70. package/dist/constants/typescript.js +32 -52
  71. package/dist/cover/code.js +111 -142
  72. package/dist/cover/formatters.js +118 -101
  73. package/dist/cover/type.js +50 -76
  74. package/dist/cover/types.js +1 -17
  75. package/dist/crypto/hash.js +54 -46
  76. package/dist/debug/_internal.js +62 -71
  77. package/dist/debug/caller-info.js +53 -64
  78. package/dist/debug/namespace.js +80 -90
  79. package/dist/debug/output.js +172 -188
  80. package/dist/debug/types.js +1 -17
  81. package/dist/dlx/_internal.js +24 -43
  82. package/dist/dlx/arborist.js +162 -160
  83. package/dist/dlx/binary-cache.js +228 -200
  84. package/dist/dlx/binary-download.js +172 -211
  85. package/dist/dlx/binary-resolution.js +165 -157
  86. package/dist/dlx/binary-types.js +1 -17
  87. package/dist/dlx/binary.js +149 -189
  88. package/dist/dlx/cache.js +45 -30
  89. package/dist/dlx/detect.js +245 -159
  90. package/dist/dlx/dir.js +67 -51
  91. package/dist/dlx/firewall.js +62 -100
  92. package/dist/dlx/lockfile.js +122 -127
  93. package/dist/dlx/manifest.js +264 -274
  94. package/dist/dlx/package.js +241 -244
  95. package/dist/dlx/packages.js +99 -96
  96. package/dist/dlx/paths.js +73 -59
  97. package/dist/dlx/spec.js +52 -60
  98. package/dist/dlx/types.js +1 -17
  99. package/dist/eco/cargo/lockfile-format.js +19 -36
  100. package/dist/eco/cargo/manifest-format.js +17 -35
  101. package/dist/eco/cargo/parse-lockfile.js +210 -237
  102. package/dist/eco/manifest/analyze-lockfile.js +46 -63
  103. package/dist/eco/manifest/detect-format.js +66 -90
  104. package/dist/eco/manifest/find-packages.js +39 -64
  105. package/dist/eco/manifest/get-package-versions.js +27 -48
  106. package/dist/eco/manifest/get-package.js +21 -40
  107. package/dist/eco/manifest/manifest-error.js +14 -35
  108. package/dist/eco/manifest/parse-lockfile.js +40 -86
  109. package/dist/eco/manifest/parse-manifest.js +26 -43
  110. package/dist/eco/manifest/parse.js +26 -47
  111. package/dist/eco/manifest/types.js +1 -17
  112. package/dist/eco/npm/bun/exec.js +23 -32
  113. package/dist/eco/npm/manifest-format.js +21 -35
  114. package/dist/eco/npm/npm/exec.js +51 -61
  115. package/dist/eco/npm/npm/extract-package-name-from-path.js +28 -50
  116. package/dist/eco/npm/npm/flags.js +80 -52
  117. package/dist/eco/npm/npm/lockfile-format.js +21 -40
  118. package/dist/eco/npm/npm/parse-git-url.js +26 -40
  119. package/dist/eco/npm/npm/parse-lockfile.js +184 -210
  120. package/dist/eco/npm/parse-package-json.js +71 -102
  121. package/dist/eco/npm/pnpm/detect-pnpm-version.js +22 -43
  122. package/dist/eco/npm/pnpm/exec.js +51 -62
  123. package/dist/eco/npm/pnpm/flags.js +75 -68
  124. package/dist/eco/npm/pnpm/lockfile-format.js +19 -36
  125. package/dist/eco/npm/pnpm/parse-lockfile.js +235 -259
  126. package/dist/eco/npm/pnpm/parse-pnpm-package-id-v5.js +37 -47
  127. package/dist/eco/npm/pnpm/parse-pnpm-package-id-v6-v9.js +36 -49
  128. package/dist/eco/npm/script.js +82 -90
  129. package/dist/eco/npm/vlt/exec.js +24 -32
  130. package/dist/eco/npm/yarnpkg/yarn/exec.js +60 -59
  131. package/dist/eco/npm/yarnpkg/yarn/lockfile-format.js +20 -36
  132. package/dist/eco/npm/yarnpkg/yarn/parse-lockfile.js +194 -242
  133. package/dist/eco/npm/yarnpkg/yarn/parse-yarn-descriptor.js +37 -61
  134. package/dist/eco/purl.js +50 -60
  135. package/dist/eco/types.js +1 -17
  136. package/dist/effects/pulse-frames.js +64 -65
  137. package/dist/effects/shimmer-keyframes.js +71 -52
  138. package/dist/effects/shimmer-terminal.js +81 -50
  139. package/dist/effects/shimmer.js +290 -153
  140. package/dist/env/boolean.js +42 -43
  141. package/dist/env/case-insensitive.js +54 -39
  142. package/dist/env/ci.js +29 -31
  143. package/dist/env/debug.js +28 -31
  144. package/dist/env/github.js +144 -59
  145. package/dist/env/home.js +38 -31
  146. package/dist/env/locale.js +59 -39
  147. package/dist/env/node-auth-token.js +28 -31
  148. package/dist/env/node-env.js +28 -31
  149. package/dist/env/npm.js +94 -47
  150. package/dist/env/number.js +50 -51
  151. package/dist/env/package-manager.js +95 -83
  152. package/dist/env/path.js +28 -31
  153. package/dist/env/pre-commit.js +30 -32
  154. package/dist/env/proxy.js +121 -122
  155. package/dist/env/rewire.js +204 -96
  156. package/dist/env/shell.js +28 -31
  157. package/dist/env/socket-cli.js +233 -81
  158. package/dist/env/socket.js +521 -156
  159. package/dist/env/string.js +43 -44
  160. package/dist/env/temp-dir.js +59 -39
  161. package/dist/env/term.js +28 -31
  162. package/dist/env/test.js +65 -43
  163. package/dist/env/types.js +1 -17
  164. package/dist/env/windows.js +78 -43
  165. package/dist/env/xdg.js +62 -39
  166. package/dist/errors/message.js +40 -46
  167. package/dist/errors/predicates.js +61 -49
  168. package/dist/errors/stack.js +24 -36
  169. package/dist/events/exit/_internal.js +86 -103
  170. package/dist/events/exit/handler.js +48 -55
  171. package/dist/events/exit/intercept.js +49 -70
  172. package/dist/events/exit/lifecycle.js +92 -101
  173. package/dist/events/exit/signals.js +25 -31
  174. package/dist/events/exit/types.js +1 -17
  175. package/dist/events/warning/handler.js +43 -40
  176. package/dist/events/warning/suppress.js +111 -90
  177. package/dist/external/@npmcli/package-json/lib/read-package.js +132 -153
  178. package/dist/external/@npmcli/package-json/lib/sort.js +73 -105
  179. package/dist/external/@npmcli/package-json.js +12705 -15140
  180. package/dist/external/@npmcli/promise-spawn.js +451 -472
  181. package/dist/external/@sinclair/typebox/value.js +7443 -9002
  182. package/dist/external/@sinclair/typebox.js +7516 -7885
  183. package/dist/external/@socketregistry/is-unicode-supported.js +31 -39
  184. package/dist/external/@socketregistry/packageurl-js.js +6127 -7369
  185. package/dist/external/@socketregistry/yocto-spinner.js +394 -455
  186. package/dist/external/@yarnpkg/extensions.js +435 -1022
  187. package/dist/external/adm-zip.js +2313 -2673
  188. package/dist/external/debug.js +700 -687
  189. package/dist/external/external-pack.js +2658 -3171
  190. package/dist/external/fast-sort.js +124 -138
  191. package/dist/external/get-east-asian-width.js +70 -64
  192. package/dist/external/libnpmexec.js +28 -31
  193. package/dist/external/npm-pack.js +43617 -50137
  194. package/dist/external/p-map.js +198 -222
  195. package/dist/external/pico-pack.js +6735 -7304
  196. package/dist/external/pony-cause.js +143 -139
  197. package/dist/external/shell-quote.js +226 -0
  198. package/dist/external/spdx-pack.js +1283 -1403
  199. package/dist/external/streaming-iterables.js +835 -1052
  200. package/dist/external/tar-fs.js +2769 -3048
  201. package/dist/external/which.js +267 -251
  202. package/dist/external/yargs-parser.js +851 -1074
  203. package/dist/external-tools/bazel/asset-names.js +98 -90
  204. package/dist/external-tools/bazel/from-download.js +52 -46
  205. package/dist/external-tools/bazel/from-path.js +27 -38
  206. package/dist/external-tools/bazel/read-bazel-version-file.js +35 -57
  207. package/dist/external-tools/bazel/resolve-asset-url.js +24 -39
  208. package/dist/external-tools/bazel/resolve-bazel-version.js +34 -56
  209. package/dist/external-tools/bazel/resolve.js +44 -58
  210. package/dist/external-tools/bazel/types.js +1 -17
  211. package/dist/external-tools/cdxgen/asset-names.js +59 -66
  212. package/dist/external-tools/cdxgen/from-download.js +52 -80
  213. package/dist/external-tools/cdxgen/from-path.js +19 -37
  214. package/dist/external-tools/cdxgen/from-vfs.js +22 -43
  215. package/dist/external-tools/cdxgen/resolve.js +48 -63
  216. package/dist/external-tools/cdxgen/types.js +1 -17
  217. package/dist/external-tools/from-download.js +107 -67
  218. package/dist/external-tools/janus/asset-names.js +44 -51
  219. package/dist/external-tools/janus/from-download.js +45 -70
  220. package/dist/external-tools/janus/from-path.js +19 -37
  221. package/dist/external-tools/janus/from-vfs.js +22 -43
  222. package/dist/external-tools/janus/resolve.js +45 -63
  223. package/dist/external-tools/janus/types.js +1 -17
  224. package/dist/external-tools/jre/asset-names.js +109 -82
  225. package/dist/external-tools/jre/detect-platform-arch.js +25 -49
  226. package/dist/external-tools/jre/from-download.js +71 -67
  227. package/dist/external-tools/jre/from-java-home.js +27 -54
  228. package/dist/external-tools/jre/from-path.js +27 -49
  229. package/dist/external-tools/jre/from-vfs.js +39 -60
  230. package/dist/external-tools/jre/resolve.js +55 -68
  231. package/dist/external-tools/jre/types.js +1 -17
  232. package/dist/external-tools/manifest.js +130 -150
  233. package/dist/external-tools/opengrep/asset-names.js +60 -72
  234. package/dist/external-tools/opengrep/from-download.js +58 -80
  235. package/dist/external-tools/opengrep/from-path.js +19 -37
  236. package/dist/external-tools/opengrep/from-vfs.js +23 -43
  237. package/dist/external-tools/opengrep/resolve.js +43 -63
  238. package/dist/external-tools/opengrep/types.js +1 -17
  239. package/dist/external-tools/sbt/asset-names.js +21 -30
  240. package/dist/external-tools/sbt/from-download.js +50 -61
  241. package/dist/external-tools/sbt/from-path.js +23 -38
  242. package/dist/external-tools/sbt/from-vfs.js +30 -44
  243. package/dist/external-tools/sbt/resolve.js +45 -63
  244. package/dist/external-tools/sbt/types.js +1 -17
  245. package/dist/external-tools/synp/asset-names.js +11 -29
  246. package/dist/external-tools/synp/from-download.js +24 -41
  247. package/dist/external-tools/synp/from-path.js +19 -37
  248. package/dist/external-tools/synp/from-vfs.js +22 -43
  249. package/dist/external-tools/synp/resolve.js +43 -62
  250. package/dist/external-tools/synp/types.js +1 -17
  251. package/dist/external-tools/trivy/asset-names.js +51 -62
  252. package/dist/external-tools/trivy/from-download.js +42 -64
  253. package/dist/external-tools/trivy/from-path.js +19 -37
  254. package/dist/external-tools/trivy/from-vfs.js +22 -43
  255. package/dist/external-tools/trivy/resolve.js +43 -63
  256. package/dist/external-tools/trivy/types.js +1 -17
  257. package/dist/external-tools/trufflehog/asset-names.js +54 -66
  258. package/dist/external-tools/trufflehog/from-download.js +44 -62
  259. package/dist/external-tools/trufflehog/from-path.js +21 -37
  260. package/dist/external-tools/trufflehog/from-vfs.js +26 -43
  261. package/dist/external-tools/trufflehog/resolve.js +43 -63
  262. package/dist/external-tools/trufflehog/types.js +1 -17
  263. package/dist/external-tools/uv/asset-names.js +64 -74
  264. package/dist/external-tools/uv/from-download.js +44 -65
  265. package/dist/external-tools/uv/from-path.js +19 -37
  266. package/dist/external-tools/uv/from-vfs.js +22 -43
  267. package/dist/external-tools/uv/resolve.js +42 -63
  268. package/dist/external-tools/uv/types.js +1 -17
  269. package/dist/fs/_internal.js +40 -42
  270. package/dist/fs/access.js +57 -54
  271. package/dist/fs/encoding.js +80 -97
  272. package/dist/fs/find-up.js +126 -125
  273. package/dist/fs/inspect.js +168 -99
  274. package/dist/fs/path-cache.js +31 -32
  275. package/dist/fs/read-dir.js +102 -79
  276. package/dist/fs/read-file.js +177 -118
  277. package/dist/fs/read-json-cache.js +150 -134
  278. package/dist/fs/read-json.js +172 -187
  279. package/dist/fs/resolve-module.js +35 -58
  280. package/dist/fs/safe.js +278 -169
  281. package/dist/fs/types.js +1 -17
  282. package/dist/fs/unique.js +52 -48
  283. package/dist/fs/validate.js +56 -40
  284. package/dist/fs/write-json.js +109 -75
  285. package/dist/git/_internal.js +251 -216
  286. package/dist/git/changed.js +191 -74
  287. package/dist/git/repo.js +118 -104
  288. package/dist/git/staged.js +172 -62
  289. package/dist/git/types.js +1 -17
  290. package/dist/git/unstaged.js +175 -62
  291. package/dist/github/constants.js +25 -33
  292. package/dist/github/errors.js +46 -38
  293. package/dist/github/fetch.js +137 -82
  294. package/dist/github/ghsa.js +217 -151
  295. package/dist/github/refs-cache.js +54 -43
  296. package/dist/github/refs-graphql.js +97 -89
  297. package/dist/github/refs-rest.js +70 -101
  298. package/dist/github/refs.js +105 -64
  299. package/dist/github/token.js +96 -48
  300. package/dist/github/types.js +1 -17
  301. package/dist/globs/_internal.js +73 -82
  302. package/dist/globs/defaults.js +40 -59
  303. package/dist/globs/match.js +93 -77
  304. package/dist/globs/matcher.js +104 -92
  305. package/dist/globs/stream.js +43 -55
  306. package/dist/globs/types.js +1 -17
  307. package/dist/http-request/_internal.js +11 -38
  308. package/dist/http-request/browser-fetch.js +19 -29
  309. package/dist/http-request/browser.js +188 -206
  310. package/dist/http-request/checksums.js +101 -65
  311. package/dist/http-request/download-types.js +1 -17
  312. package/dist/http-request/download.js +195 -196
  313. package/dist/http-request/errors.js +39 -47
  314. package/dist/http-request/headers.js +95 -80
  315. package/dist/http-request/http-request.js +10 -35
  316. package/dist/http-request/node.js +71 -97
  317. package/dist/http-request/request-attempt.js +232 -285
  318. package/dist/http-request/request-types.js +1 -17
  319. package/dist/http-request/request.js +106 -108
  320. package/dist/http-request/response-reader.js +47 -51
  321. package/dist/http-request/response-types.js +22 -38
  322. package/dist/http-request/user-agent.js +73 -55
  323. package/dist/integrity.js +105 -106
  324. package/dist/ipc/_internal.js +34 -48
  325. package/dist/ipc/directory.js +55 -63
  326. package/dist/ipc/paths.js +52 -45
  327. package/dist/ipc/types.js +1 -17
  328. package/dist/ipc/write.js +81 -74
  329. package/dist/ipc-cli/get.js +29 -56
  330. package/dist/ipc-cli/types.js +1 -17
  331. package/dist/json/edit.js +182 -242
  332. package/dist/json/format.js +202 -103
  333. package/dist/json/parse.js +206 -109
  334. package/dist/json/types.js +1 -17
  335. package/dist/links/create.js +93 -60
  336. package/dist/links/types.js +1 -17
  337. package/dist/logger/_internal.js +109 -73
  338. package/dist/logger/browser.js +45 -56
  339. package/dist/logger/colors.js +31 -49
  340. package/dist/logger/console.js +89 -112
  341. package/dist/logger/default.js +19 -33
  342. package/dist/logger/logger.js +5 -29
  343. package/dist/logger/node.js +793 -854
  344. package/dist/logger/symbols-builder.js +54 -56
  345. package/dist/logger/symbols.js +135 -118
  346. package/dist/logger/types.js +1 -17
  347. package/dist/memo/_internal.js +39 -49
  348. package/dist/memo/async.js +133 -117
  349. package/dist/memo/clear.js +25 -34
  350. package/dist/memo/decorator.js +43 -37
  351. package/dist/memo/memoize.js +97 -88
  352. package/dist/memo/once.js +42 -41
  353. package/dist/memo/types.js +1 -17
  354. package/dist/memo/weak.js +45 -41
  355. package/dist/node/async-hooks.js +9 -30
  356. package/dist/node/child-process.js +9 -30
  357. package/dist/node/crypto.js +9 -30
  358. package/dist/node/events.js +9 -30
  359. package/dist/node/fs-promises.js +9 -30
  360. package/dist/node/fs.js +9 -30
  361. package/dist/node/http.js +9 -30
  362. package/dist/node/https.js +9 -30
  363. package/dist/node/module.js +20 -34
  364. package/dist/node/os.js +9 -30
  365. package/dist/node/path.js +9 -30
  366. package/dist/node/timers-promises.js +9 -30
  367. package/dist/node/url.js +9 -30
  368. package/dist/node/util.js +9 -30
  369. package/dist/objects/getters.js +185 -126
  370. package/dist/objects/inspect.js +85 -52
  371. package/dist/objects/mutate.js +96 -76
  372. package/dist/objects/predicates.js +112 -59
  373. package/dist/objects/sort.js +120 -76
  374. package/dist/objects/types.js +1 -17
  375. package/dist/packages/edit-class.js +198 -265
  376. package/dist/packages/edit.js +79 -86
  377. package/dist/packages/exports.js +146 -157
  378. package/dist/packages/isolation.js +159 -209
  379. package/dist/packages/licenses.js +207 -189
  380. package/dist/packages/manifest.js +134 -172
  381. package/dist/packages/normalize.js +91 -102
  382. package/dist/packages/operations.d.ts +2 -0
  383. package/dist/packages/operations.js +283 -254
  384. package/dist/packages/provenance.js +195 -245
  385. package/dist/packages/specs.js +94 -84
  386. package/dist/packages/types.js +1 -17
  387. package/dist/packages/validation.js +49 -50
  388. package/dist/paths/_internal.js +82 -86
  389. package/dist/paths/conversion.js +112 -65
  390. package/dist/paths/dirnames.js +17 -42
  391. package/dist/paths/exts.js +23 -54
  392. package/dist/paths/filenames.js +21 -50
  393. package/dist/paths/globs.js +15 -38
  394. package/dist/paths/normalize.js +215 -236
  395. package/dist/paths/packages.js +34 -49
  396. package/dist/paths/predicates.js +184 -106
  397. package/dist/paths/resolve.js +146 -128
  398. package/dist/paths/rewire.js +108 -72
  399. package/dist/paths/socket.js +252 -132
  400. package/dist/paths/walk.js +55 -60
  401. package/dist/perf/_internal.js +10 -28
  402. package/dist/perf/enabled.js +21 -30
  403. package/dist/perf/metrics.js +81 -67
  404. package/dist/perf/report.js +79 -80
  405. package/dist/perf/timer.js +180 -126
  406. package/dist/perf/types.js +1 -17
  407. package/dist/pkg-ext/data.js +29 -82
  408. package/dist/pkg-ext/types.js +1 -17
  409. package/dist/primordials/array.js +120 -198
  410. package/dist/primordials/buffer.js +28 -51
  411. package/dist/primordials/date.js +26 -51
  412. package/dist/primordials/error.js +33 -59
  413. package/dist/primordials/function.js +21 -41
  414. package/dist/primordials/globals.js +25 -48
  415. package/dist/primordials/json.js +14 -30
  416. package/dist/primordials/map-set.js +88 -152
  417. package/dist/primordials/math.js +59 -116
  418. package/dist/primordials/number.js +41 -76
  419. package/dist/primordials/object.js +56 -116
  420. package/dist/primordials/promise.js +28 -52
  421. package/dist/primordials/reflect.js +24 -52
  422. package/dist/primordials/regexp.js +25 -47
  423. package/dist/primordials/string.js +114 -167
  424. package/dist/primordials/symbol.js +40 -72
  425. package/dist/primordials/uncurry.js +38 -55
  426. package/dist/primordials/url.js +27 -66
  427. package/dist/process/_internal.js +7 -32
  428. package/dist/process/abort.js +29 -35
  429. package/dist/process/lock-instance.js +26 -30
  430. package/dist/process/lock-manager.js +279 -307
  431. package/dist/process/lock-types.js +1 -17
  432. package/dist/process/spawn/_internal.js +43 -55
  433. package/dist/process/spawn/child.js +172 -211
  434. package/dist/process/spawn/errors.js +116 -113
  435. package/dist/process/spawn/stdio.js +51 -35
  436. package/dist/process/spawn/types.js +1 -17
  437. package/dist/process/transient.js +49 -66
  438. package/dist/promises/_internal.js +31 -34
  439. package/dist/promises/iterate.js +238 -102
  440. package/dist/promises/options.js +123 -101
  441. package/dist/promises/queue.js +115 -136
  442. package/dist/promises/resolvers.js +77 -46
  443. package/dist/promises/retry.js +156 -101
  444. package/dist/promises/types.js +1 -17
  445. package/dist/regexps/escape.js +32 -30
  446. package/dist/regexps/hex.js +16 -33
  447. package/dist/regexps/spec.js +53 -81
  448. package/dist/releases/github-archives.js +127 -118
  449. package/dist/releases/github-asset-url.js +162 -146
  450. package/dist/releases/github-assets.js +37 -49
  451. package/dist/releases/github-auth.js +32 -48
  452. package/dist/releases/github-downloads.js +118 -138
  453. package/dist/releases/github-listing.js +175 -145
  454. package/dist/releases/github-retry-config.js +41 -47
  455. package/dist/releases/github-types.js +1 -17
  456. package/dist/releases/socket-btm.js +273 -192
  457. package/dist/schema/parse.js +35 -36
  458. package/dist/schema/types.js +1 -17
  459. package/dist/schema/validate.js +118 -99
  460. package/dist/sea/detect.js +57 -52
  461. package/dist/secrets/_internal.js +86 -67
  462. package/dist/secrets/find.js +96 -77
  463. package/dist/secrets/keychain.js +315 -309
  464. package/dist/secrets/linux.js +133 -135
  465. package/dist/secrets/macos.js +151 -147
  466. package/dist/secrets/rc.js +182 -181
  467. package/dist/secrets/socket-api-token.js +28 -43
  468. package/dist/secrets/types.js +1 -17
  469. package/dist/secrets/windows.js +184 -242
  470. package/dist/shadow/skip.js +51 -70
  471. package/dist/shadow/types.js +1 -17
  472. package/dist/shell/parse.d.ts +26 -0
  473. package/dist/shell/parse.js +35 -0
  474. package/dist/shell/quote.d.ts +19 -0
  475. package/dist/shell/quote.js +30 -0
  476. package/dist/smol/detect.js +67 -43
  477. package/dist/smol/http.js +33 -37
  478. package/dist/smol/https.js +31 -37
  479. package/dist/smol/manifest.js +33 -37
  480. package/dist/smol/path.js +33 -37
  481. package/dist/smol/primordial.js +35 -37
  482. package/dist/smol/purl.js +34 -37
  483. package/dist/smol/versions.js +31 -37
  484. package/dist/smol/vfs.js +46 -38
  485. package/dist/sorts/_internal.js +14 -40
  486. package/dist/sorts/natural.js +57 -64
  487. package/dist/sorts/semver.js +33 -43
  488. package/dist/sorts/strings.js +24 -30
  489. package/dist/sorts/types.js +1 -17
  490. package/dist/spinner/default.js +72 -63
  491. package/dist/spinner/format.js +86 -71
  492. package/dist/spinner/spinner.js +749 -797
  493. package/dist/spinner/types.js +1 -17
  494. package/dist/spinner/with.js +193 -137
  495. package/dist/ssri/convert.js +64 -47
  496. package/dist/ssri/parse.js +38 -37
  497. package/dist/ssri/validate.js +51 -34
  498. package/dist/stdio/_internal.js +50 -46
  499. package/dist/stdio/clear.js +208 -86
  500. package/dist/stdio/divider.js +170 -97
  501. package/dist/stdio/footer.js +116 -110
  502. package/dist/stdio/header.js +117 -90
  503. package/dist/stdio/progress.js +189 -218
  504. package/dist/stdio/prompts.js +244 -168
  505. package/dist/stdio/stderr.js +173 -78
  506. package/dist/stdio/stdout.js +177 -94
  507. package/dist/streams/parallel.js +58 -50
  508. package/dist/streams/transform.js +36 -45
  509. package/dist/strings/format.js +145 -63
  510. package/dist/strings/predicates.js +56 -34
  511. package/dist/strings/search.js +52 -42
  512. package/dist/strings/transform.js +113 -72
  513. package/dist/strings/types.js +1 -17
  514. package/dist/strings/width.js +89 -82
  515. package/dist/tables/bordered.js +81 -81
  516. package/dist/tables/padding.js +36 -46
  517. package/dist/tables/simple.js +62 -70
  518. package/dist/tables/types.js +1 -17
  519. package/dist/temporal/instant.js +72 -81
  520. package/dist/temporal/now.js +40 -31
  521. package/dist/temporal/slots.js +42 -36
  522. package/dist/temporal/system.js +36 -36
  523. package/dist/temporal/temporal.js +11 -41
  524. package/dist/themes/context.js +131 -69
  525. package/dist/themes/resolve.js +207 -132
  526. package/dist/themes/themes.js +225 -194
  527. package/dist/themes/types.js +1 -17
  528. package/dist/url/parse.js +48 -51
  529. package/dist/url/predicates.js +24 -31
  530. package/dist/url/search-params.js +133 -101
  531. package/dist/url/types.js +1 -17
  532. package/dist/versions/_internal.js +31 -33
  533. package/dist/versions/compare.js +80 -58
  534. package/dist/versions/modify.js +41 -39
  535. package/dist/versions/parse.js +88 -64
  536. package/dist/versions/range.js +58 -41
  537. package/dist/versions/types.js +1 -17
  538. package/dist/words/article.js +22 -30
  539. package/dist/words/capitalize.js +25 -34
  540. package/dist/words/pluralize.js +23 -31
  541. package/dist/words/types.js +1 -17
  542. package/package.json +17 -5
@@ -1,97 +1,124 @@
1
1
  "use strict";
2
- /* Socket Lib - Built with esbuild */
3
- "use strict";
4
- var __create = Object.create;
5
- var __defProp = Object.defineProperty;
6
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
7
- var __getOwnPropNames = Object.getOwnPropertyNames;
8
- var __getProtoOf = Object.getPrototypeOf;
9
- var __hasOwnProp = Object.prototype.hasOwnProperty;
10
- var __export = (target, all) => {
11
- for (var name in all)
12
- __defProp(target, name, { get: all[name], enumerable: true });
13
- };
14
- var __copyProps = (to, from, except, desc) => {
15
- if (from && typeof from === "object" || typeof from === "function") {
16
- for (let key of __getOwnPropNames(from))
17
- if (!__hasOwnProp.call(to, key) && key !== except)
18
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
19
- }
20
- return to;
21
- };
22
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
23
- // If the importer is in node compatibility mode or this is not an ESM
24
- // file that has been converted to a CommonJS file using a Babel-
25
- // compatible transform (i.e. "__esModule" has not been set), then set
26
- // "default" to the CommonJS "module.exports" for node compatibility.
27
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
28
- mod
29
- ));
30
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
31
- var header_exports = {};
32
- __export(header_exports, {
33
- createHeader: () => createHeader,
34
- createSectionHeader: () => createSectionHeader,
35
- printHeader: () => printHeader
36
- });
37
- module.exports = __toCommonJS(header_exports);
38
- var import_yoctocolors_cjs = __toESM(require("../external/yoctocolors-cjs"));
39
- var import_format = require("../strings/format");
40
- var import_default = require("../logger/default");
41
- var import_array = require("../primordials/array");
42
- const logger = (0, import_default.getDefaultLogger)();
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_runtime = require('../_virtual/_rolldown/runtime.js');
5
+ const require_primordials_array = require('../primordials/array.js');
6
+ const require_strings_format = require('../strings/format.js');
7
+ const require_logger_default = require('../logger/default.js');
8
+ let src_external_yoctocolors_cjs = require("../external/yoctocolors-cjs");
9
+ src_external_yoctocolors_cjs = require_runtime.__toESM(src_external_yoctocolors_cjs);
10
+
11
+ //#region src/stdio/header.ts
12
+ /**
13
+ * @file Console header/banner formatting utilities. Provides consistent header
14
+ * formatting for CLI applications.
15
+ */
16
+ const logger = require_logger_default.getDefaultLogger();
17
+ /**
18
+ * Create a formatted header/banner with borders and centered title. Useful for
19
+ * marking the start of CLI output or creating visual sections.
20
+ *
21
+ * @example
22
+ * ;```ts
23
+ * console.log(
24
+ * createHeader('Socket Security Analysis', {
25
+ * width: 70,
26
+ * color: 'cyan',
27
+ * bold: true,
28
+ * padding: 2,
29
+ * }),
30
+ * )
31
+ * // Output:
32
+ * // ======================================================================
33
+ * //
34
+ * // Socket Security Analysis
35
+ * //
36
+ * // ======================================================================
37
+ * ```
38
+ *
39
+ * @param title - Title text to display in header.
40
+ * @param options - Header formatting options.
41
+ *
42
+ * @returns Formatted header string with borders and centered title
43
+ */
43
44
  function createHeader(title, options) {
44
- const {
45
- bold = true,
46
- borderChar = "=",
47
- color = "cyan",
48
- padding = 1,
49
- width = 80
50
- } = { __proto__: null, ...options };
51
- const border = (0, import_format.repeatString)(borderChar, width);
52
- let formattedTitle = title;
53
- if (color && import_yoctocolors_cjs.default[color]) {
54
- formattedTitle = import_yoctocolors_cjs.default[color](formattedTitle);
55
- }
56
- if (bold && import_yoctocolors_cjs.default.bold) {
57
- formattedTitle = import_yoctocolors_cjs.default.bold(formattedTitle);
58
- }
59
- const centeredTitle = (0, import_format.centerText)(formattedTitle, width);
60
- const paddingLine = (0, import_format.repeatString)(" ", width);
61
- const lines = [border];
62
- for (let i = 0; i < padding; i++) {
63
- (0, import_array.ArrayPrototypePush)(lines, paddingLine);
64
- }
65
- (0, import_array.ArrayPrototypePush)(lines, centeredTitle);
66
- for (let i = 0; i < padding; i++) {
67
- (0, import_array.ArrayPrototypePush)(lines, paddingLine);
68
- }
69
- (0, import_array.ArrayPrototypePush)(lines, border);
70
- return lines.join("\n");
45
+ const { bold = true, borderChar = "=", color = "cyan", padding = 1, width = 80 } = {
46
+ __proto__: null,
47
+ ...options
48
+ };
49
+ const border = /* @__PURE__ */ require_strings_format.repeatString(borderChar, width);
50
+ let formattedTitle = title;
51
+ if (color && src_external_yoctocolors_cjs.default[color]) formattedTitle = src_external_yoctocolors_cjs.default[color](formattedTitle);
52
+ if (bold && src_external_yoctocolors_cjs.default.bold) formattedTitle = src_external_yoctocolors_cjs.default.bold(formattedTitle);
53
+ const centeredTitle = /* @__PURE__ */ require_strings_format.centerText(formattedTitle, width);
54
+ const paddingLine = /* @__PURE__ */ require_strings_format.repeatString(" ", width);
55
+ const lines = [border];
56
+ for (let i = 0; i < padding; i++) require_primordials_array.ArrayPrototypePush(lines, paddingLine);
57
+ require_primordials_array.ArrayPrototypePush(lines, centeredTitle);
58
+ for (let i = 0; i < padding; i++) require_primordials_array.ArrayPrototypePush(lines, paddingLine);
59
+ require_primordials_array.ArrayPrototypePush(lines, border);
60
+ return lines.join("\n");
71
61
  }
62
+ /**
63
+ * Create a simple section header without padding. A lighter-weight alternative
64
+ * to `createHeader()` for subsections.
65
+ *
66
+ * @example
67
+ * ;```ts
68
+ * console.log(
69
+ * createSectionHeader('Dependencies', {
70
+ * width: 50,
71
+ * color: 'blue',
72
+ * }),
73
+ * )
74
+ * // Output:
75
+ * // --------------------------------------------------
76
+ * // Dependencies
77
+ * // --------------------------------------------------
78
+ * ```
79
+ *
80
+ * @param title - Title text to display in header.
81
+ * @param options - Header formatting options.
82
+ *
83
+ * @returns Formatted section header string
84
+ */
72
85
  function createSectionHeader(title, options) {
73
- const {
74
- borderChar = "-",
75
- color = "blue",
76
- width = 60
77
- } = { __proto__: null, ...options };
78
- return createHeader(title, {
79
- width,
80
- borderChar,
81
- padding: 0,
82
- color,
83
- bold: false
84
- });
86
+ const { borderChar = "-", color = "blue", width = 60 } = {
87
+ __proto__: null,
88
+ ...options
89
+ };
90
+ return createHeader(title, {
91
+ width,
92
+ borderChar,
93
+ padding: 0,
94
+ color,
95
+ bold: false
96
+ });
85
97
  }
98
+ /**
99
+ * Print a header directly to stdout with standard formatting. Uses fixed width
100
+ * of 55 characters with `═` borders. Simpler alternative to `createHeader()`
101
+ * for quick headers.
102
+ *
103
+ * @example
104
+ * ;```ts
105
+ * printHeader('Package Analysis')
106
+ * // Output:
107
+ * // ═══════════════════════════════════════════════════
108
+ * // Package Analysis
109
+ * // ═══════════════════════════════════════════════════
110
+ * ```
111
+ *
112
+ * @param title - Title text to display.
113
+ */
86
114
  function printHeader(title) {
87
- const border = (0, import_format.repeatString)("\u2550", 55);
88
- logger.log(border);
89
- logger.log(` ${title}`);
90
- logger.log(border);
115
+ const border = /* @__PURE__ */ require_strings_format.repeatString("", 55);
116
+ logger.log(border);
117
+ logger.log(` ${title}`);
118
+ logger.log(border);
91
119
  }
92
- // Annotate the CommonJS export names for ESM import in node:
93
- 0 && (module.exports = {
94
- createHeader,
95
- createSectionHeader,
96
- printHeader
97
- });
120
+
121
+ //#endregion
122
+ exports.createHeader = createHeader;
123
+ exports.createSectionHeader = createSectionHeader;
124
+ exports.printHeader = printHeader;
@@ -1,222 +1,193 @@
1
1
  "use strict";
2
- /* Socket Lib - Built with esbuild */
3
- "use strict";
4
- var __create = Object.create;
5
- var __defProp = Object.defineProperty;
6
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
7
- var __getOwnPropNames = Object.getOwnPropertyNames;
8
- var __getProtoOf = Object.getPrototypeOf;
9
- var __hasOwnProp = Object.prototype.hasOwnProperty;
10
- var __export = (target, all) => {
11
- for (var name in all)
12
- __defProp(target, name, { get: all[name], enumerable: true });
13
- };
14
- var __copyProps = (to, from, except, desc) => {
15
- if (from && typeof from === "object" || typeof from === "function") {
16
- for (let key of __getOwnPropNames(from))
17
- if (!__hasOwnProp.call(to, key) && key !== except)
18
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
19
- }
20
- return to;
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_runtime = require('../_virtual/_rolldown/runtime.js');
5
+ const require_primordials_string = require('../primordials/string.js');
6
+ const require_primordials_math = require('../primordials/math.js');
7
+ const require_primordials_date = require('../primordials/date.js');
8
+ const require_primordials_object = require('../primordials/object.js');
9
+ const require_ansi_strip = require('../ansi/strip.js');
10
+ const require_strings_format = require('../strings/format.js');
11
+ let node_process = require("node:process");
12
+ node_process = require_runtime.__toESM(node_process);
13
+ let src_external_yoctocolors_cjs = require("../external/yoctocolors-cjs");
14
+ src_external_yoctocolors_cjs = require_runtime.__toESM(src_external_yoctocolors_cjs);
15
+
16
+ //#region src/stdio/progress.ts
17
+ /**
18
+ * @file Progress bar utilities for CLI applications. Provides various progress
19
+ * indicators including bars, percentages, and spinners.
20
+ */
21
+ var ProgressBar = class {
22
+ current = 0;
23
+ total;
24
+ startTime;
25
+ lastRender = 0;
26
+ stream;
27
+ options;
28
+ terminated = false;
29
+ lastDrawnWidth = 0;
30
+ /**
31
+ * Create a new progress bar instance.
32
+ *
33
+ * @example
34
+ * ;```ts
35
+ * const bar = new ProgressBar(100, {
36
+ * width: 50,
37
+ * format: ':bar :percent :current/:total :eta',
38
+ * color: 'green',
39
+ * })
40
+ * ```
41
+ *
42
+ * @param total - Total number of units for the progress bar.
43
+ * @param options - Configuration options for the progress bar.
44
+ */
45
+ constructor(total, options) {
46
+ this.total = total;
47
+ this.startTime = require_primordials_date.DateNow();
48
+ this.stream = options?.stream || node_process.default.stderr;
49
+ this.options = {
50
+ width: 40,
51
+ format: ":bar :percent :current/:total",
52
+ complete: "█",
53
+ incomplete: "░",
54
+ head: "",
55
+ clear: false,
56
+ renderThrottle: 16,
57
+ stream: this.stream,
58
+ color: "cyan",
59
+ ...options
60
+ };
61
+ }
62
+ /**
63
+ * Update progress to a specific value and redraw the bar. Updates are
64
+ * throttled to prevent excessive rendering (default ~60fps).
65
+ *
66
+ * @example
67
+ * ;```ts
68
+ * bar.update(50)
69
+ * bar.update(75, { status: 'Processing...' })
70
+ * ```
71
+ *
72
+ * @param current - Current progress value (will be clamped to total)
73
+ * @param tokens - Optional custom tokens to replace in format string.
74
+ */
75
+ update(current, tokens) {
76
+ if (this.terminated) return;
77
+ this.current = require_primordials_math.MathMin(current, this.total);
78
+ /* c8 ignore start */
79
+ const now = require_primordials_date.DateNow();
80
+ if (now - this.lastRender < (this.options.renderThrottle ?? 16) && this.current < this.total) return;
81
+ /* c8 ignore stop */
82
+ this.lastRender = now;
83
+ this.render(tokens);
84
+ if (this.current >= this.total) this.terminate();
85
+ }
86
+ /**
87
+ * Increment progress by a specified amount. Convenience method for
88
+ * `update(current + amount)`.
89
+ *
90
+ * @example
91
+ * ;```ts
92
+ * bar.tick() // Increment by 1
93
+ * bar.tick(5) // Increment by 5
94
+ * bar.tick(1, { file: 'data.json' })
95
+ * ```
96
+ *
97
+ * @default amount 1
98
+ *
99
+ * @param amount - Amount to increment by.
100
+ * @param tokens - Optional custom tokens to replace in format string.
101
+ */
102
+ tick(amount = 1, tokens) {
103
+ this.update(this.current + amount, tokens);
104
+ }
105
+ /**
106
+ * Render the progress bar.
107
+ */
108
+ render(tokens) {
109
+ const colorFn = src_external_yoctocolors_cjs.default[this.options.color ?? "cyan"] || ((s) => s);
110
+ const percent = this.total === 0 ? 0 : require_primordials_math.MathFloor(this.current / this.total * 100);
111
+ const elapsed = require_primordials_date.DateNow() - this.startTime;
112
+ const eta = this.current === 0 ? 0 : elapsed / this.current * (this.total - this.current);
113
+ const availableWidth = this.options.width ?? 40;
114
+ const filledWidth = this.total === 0 ? 0 : require_primordials_math.MathMin(availableWidth, Math.floor(this.current / this.total * availableWidth));
115
+ const emptyWidth = require_primordials_math.MathMax(0, availableWidth - filledWidth);
116
+ const filled = /* @__PURE__ */ require_strings_format.repeatString(this.options.complete ?? "█", filledWidth);
117
+ const empty = /* @__PURE__ */ require_strings_format.repeatString(this.options.incomplete ?? "░", emptyWidth);
118
+ const bar = colorFn(filled) + empty;
119
+ let output = this.options.format ?? ":bar :percent :current/:total";
120
+ /* c8 ignore stop */
121
+ output = require_primordials_string.StringPrototypeReplace(output, ":bar", bar);
122
+ output = output.replace(":percent", `${percent}%`);
123
+ output = output.replace(":current", String(this.current));
124
+ output = output.replace(":total", String(this.total));
125
+ output = output.replace(":elapsed", this.formatTime(elapsed));
126
+ output = output.replace(":eta", this.formatTime(eta));
127
+ if (tokens) for (const [key, value] of require_primordials_object.ObjectEntries(tokens)) output = output.replace(`:${key}`, String(value));
128
+ this.clearLine();
129
+ this.stream.write(output);
130
+ this.lastDrawnWidth = (/* @__PURE__ */ require_ansi_strip.stripAnsi(output)).length;
131
+ }
132
+ /**
133
+ * Clear the current line.
134
+ */
135
+ clearLine() {
136
+ if (this.stream.isTTY) {
137
+ this.stream.cursorTo(0);
138
+ this.stream.clearLine(0);
139
+ } else if (this.lastDrawnWidth > 0) this.stream.write(`\r${/* @__PURE__ */ require_strings_format.repeatString(" ", this.lastDrawnWidth)}\r`);
140
+ }
141
+ /**
142
+ * Format time in seconds to human readable.
143
+ */
144
+ formatTime(ms) {
145
+ const seconds = require_primordials_math.MathMax(0, Math.round(ms / 1e3));
146
+ if (seconds < 60) return `${seconds}s`;
147
+ return `${require_primordials_math.MathFloor(seconds / 60)}m${seconds % 60}s`;
148
+ }
149
+ /**
150
+ * Terminate the progress bar and optionally clear it. Called automatically
151
+ * when progress reaches 100%. If `clear` option is true, removes the bar from
152
+ * terminal. Otherwise, moves to next line to preserve the final state.
153
+ */
154
+ terminate() {
155
+ /* c8 ignore start */
156
+ if (this.terminated) return;
157
+ this.terminated = true;
158
+ if (this.options.clear) this.clearLine();
159
+ else this.stream.write("\n");
160
+ /* c8 ignore stop */
161
+ }
21
162
  };
22
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
23
- // If the importer is in node compatibility mode or this is not an ESM
24
- // file that has been converted to a CommonJS file using a Babel-
25
- // compatible transform (i.e. "__esModule" has not been set), then set
26
- // "default" to the CommonJS "module.exports" for node compatibility.
27
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
28
- mod
29
- ));
30
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
31
- var progress_exports = {};
32
- __export(progress_exports, {
33
- ProgressBar: () => ProgressBar,
34
- createProgressIndicator: () => createProgressIndicator
35
- });
36
- module.exports = __toCommonJS(progress_exports);
37
- var import_node_process = __toESM(require("node:process"));
38
- var import_yoctocolors_cjs = __toESM(require("../external/yoctocolors-cjs"));
39
- var import_strip = require("../ansi/strip");
40
- var import_format = require("../strings/format");
41
- var import_date = require("../primordials/date");
42
- var import_math = require("../primordials/math");
43
- var import_object = require("../primordials/object");
44
- var import_string = require("../primordials/string");
45
- class ProgressBar {
46
- current = 0;
47
- total;
48
- startTime;
49
- lastRender = 0;
50
- stream;
51
- options;
52
- terminated = false;
53
- lastDrawnWidth = 0;
54
- /**
55
- * Create a new progress bar instance.
56
- *
57
- * @example
58
- * ;```ts
59
- * const bar = new ProgressBar(100, {
60
- * width: 50,
61
- * format: ':bar :percent :current/:total :eta',
62
- * color: 'green',
63
- * })
64
- * ```
65
- *
66
- * @param total - Total number of units for the progress bar.
67
- * @param options - Configuration options for the progress bar.
68
- */
69
- constructor(total, options) {
70
- this.total = total;
71
- this.startTime = (0, import_date.DateNow)();
72
- this.stream = options?.stream || import_node_process.default.stderr;
73
- this.options = {
74
- width: 40,
75
- format: ":bar :percent :current/:total",
76
- complete: "\u2588",
77
- incomplete: "\u2591",
78
- head: "",
79
- clear: false,
80
- // ~60fps.
81
- renderThrottle: 16,
82
- stream: this.stream,
83
- color: "cyan",
84
- ...options
85
- };
86
- }
87
- /**
88
- * Update progress to a specific value and redraw the bar. Updates are
89
- * throttled to prevent excessive rendering (default ~60fps).
90
- *
91
- * @example
92
- * ;```ts
93
- * bar.update(50)
94
- * bar.update(75, { status: 'Processing...' })
95
- * ```
96
- *
97
- * @param current - Current progress value (will be clamped to total)
98
- * @param tokens - Optional custom tokens to replace in format string.
99
- */
100
- update(current, tokens) {
101
- if (this.terminated) {
102
- return;
103
- }
104
- this.current = (0, import_math.MathMin)(current, this.total);
105
- const now = (0, import_date.DateNow)();
106
- if (now - this.lastRender < (this.options.renderThrottle ?? 16) && this.current < this.total) {
107
- return;
108
- }
109
- this.lastRender = now;
110
- this.render(tokens);
111
- if (this.current >= this.total) {
112
- this.terminate();
113
- }
114
- }
115
- /**
116
- * Increment progress by a specified amount. Convenience method for
117
- * `update(current + amount)`.
118
- *
119
- * @example
120
- * ;```ts
121
- * bar.tick() // Increment by 1
122
- * bar.tick(5) // Increment by 5
123
- * bar.tick(1, { file: 'data.json' })
124
- * ```
125
- *
126
- * @default amount 1
127
- *
128
- * @param amount - Amount to increment by.
129
- * @param tokens - Optional custom tokens to replace in format string.
130
- */
131
- tick(amount = 1, tokens) {
132
- this.update(this.current + amount, tokens);
133
- }
134
- /**
135
- * Render the progress bar.
136
- */
137
- render(tokens) {
138
- const colorName = this.options.color ?? "cyan";
139
- const colorFn = import_yoctocolors_cjs.default[colorName] || ((s) => s);
140
- const percent = this.total === 0 ? 0 : (0, import_math.MathFloor)(this.current / this.total * 100);
141
- const elapsed = (0, import_date.DateNow)() - this.startTime;
142
- const eta = this.current === 0 ? 0 : elapsed / this.current * (this.total - this.current);
143
- const availableWidth = this.options.width ?? 40;
144
- const filledWidth = this.total === 0 ? 0 : (0, import_math.MathMin)(
145
- availableWidth,
146
- Math.floor(this.current / this.total * availableWidth)
147
- );
148
- const emptyWidth = (0, import_math.MathMax)(0, availableWidth - filledWidth);
149
- const filled = (0, import_format.repeatString)(this.options.complete ?? "\u2588", filledWidth);
150
- const empty = (0, import_format.repeatString)(this.options.incomplete ?? "\u2591", emptyWidth);
151
- const bar = colorFn(filled) + empty;
152
- let output = this.options.format ?? ":bar :percent :current/:total";
153
- output = (0, import_string.StringPrototypeReplace)(output, ":bar", bar);
154
- output = output.replace(":percent", `${percent}%`);
155
- output = output.replace(":current", String(this.current));
156
- output = output.replace(":total", String(this.total));
157
- output = output.replace(":elapsed", this.formatTime(elapsed));
158
- output = output.replace(":eta", this.formatTime(eta));
159
- if (tokens) {
160
- for (const [key, value] of (0, import_object.ObjectEntries)(tokens)) {
161
- output = output.replace(`:${key}`, String(value));
162
- }
163
- }
164
- this.clearLine();
165
- this.stream.write(output);
166
- this.lastDrawnWidth = (0, import_strip.stripAnsi)(output).length;
167
- }
168
- /**
169
- * Clear the current line.
170
- */
171
- clearLine() {
172
- if (this.stream.isTTY) {
173
- this.stream.cursorTo(0);
174
- this.stream.clearLine(0);
175
- } else if (this.lastDrawnWidth > 0) {
176
- this.stream.write(`\r${(0, import_format.repeatString)(" ", this.lastDrawnWidth)}\r`);
177
- }
178
- }
179
- /**
180
- * Format time in seconds to human readable.
181
- */
182
- formatTime(ms) {
183
- const seconds = (0, import_math.MathMax)(0, Math.round(ms / 1e3));
184
- if (seconds < 60) {
185
- return `${seconds}s`;
186
- }
187
- const minutes = (0, import_math.MathFloor)(seconds / 60);
188
- const remainingSeconds = seconds % 60;
189
- return `${minutes}m${remainingSeconds}s`;
190
- }
191
- /**
192
- * Terminate the progress bar and optionally clear it. Called automatically
193
- * when progress reaches 100%. If `clear` option is true, removes the bar from
194
- * terminal. Otherwise, moves to next line to preserve the final state.
195
- */
196
- terminate() {
197
- if (this.terminated) {
198
- return;
199
- }
200
- this.terminated = true;
201
- if (this.options.clear) {
202
- this.clearLine();
203
- } else {
204
- this.stream.write("\n");
205
- }
206
- }
207
- }
163
+ /**
164
+ * Create a simple progress indicator without a graphical bar. Returns a
165
+ * formatted string showing progress as percentage and fraction.
166
+ *
167
+ * @example
168
+ * ;```ts
169
+ * createProgressIndicator(50, 100)
170
+ * // Returns: '[50%] 50/100'
171
+ *
172
+ * createProgressIndicator(3, 10, 'Files')
173
+ * // Returns: 'Files: [30%] 3/10'
174
+ * ```
175
+ *
176
+ * @param current - Current progress value.
177
+ * @param total - Total progress value.
178
+ * @param label - Optional label prefix.
179
+ *
180
+ * @returns Formatted progress indicator string
181
+ */
208
182
  function createProgressIndicator(current, total, label) {
209
- const percent = total === 0 ? 0 : (0, import_math.MathFloor)(current / total * 100);
210
- const progress = `${current}/${total}`;
211
- let output = "";
212
- if (label) {
213
- output += `${label}: `;
214
- }
215
- output += `${import_yoctocolors_cjs.default.cyan(`[${percent}%]`)} ${progress}`;
216
- return output;
183
+ const percent = total === 0 ? 0 : require_primordials_math.MathFloor(current / total * 100);
184
+ const progress = `${current}/${total}`;
185
+ let output = "";
186
+ if (label) output += `${label}: `;
187
+ output += `${src_external_yoctocolors_cjs.default.cyan(`[${percent}%]`)} ${progress}`;
188
+ return output;
217
189
  }
218
- // Annotate the CommonJS export names for ESM import in node:
219
- 0 && (module.exports = {
220
- ProgressBar,
221
- createProgressIndicator
222
- });
190
+
191
+ //#endregion
192
+ exports.ProgressBar = ProgressBar;
193
+ exports.createProgressIndicator = createProgressIndicator;