@socketsecurity/lib 6.0.2 → 6.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (552) hide show
  1. package/CHANGELOG.md +34 -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.d.mts +48 -25
  6. package/dist/ai/profiles.js +95 -59
  7. package/dist/ai/spawn.d.mts +2 -2
  8. package/dist/ai/spawn.js +172 -194
  9. package/dist/ai/types.d.mts +3 -3
  10. package/dist/ai/types.js +1 -17
  11. package/dist/ai/worktree.d.mts +2 -2
  12. package/dist/ai/worktree.js +160 -183
  13. package/dist/ansi/constants.js +16 -38
  14. package/dist/ansi/strip.js +44 -41
  15. package/dist/archives/_internal.js +64 -73
  16. package/dist/archives/detect.js +30 -43
  17. package/dist/archives/extract.js +43 -50
  18. package/dist/archives/tar.js +197 -228
  19. package/dist/archives/types.js +1 -17
  20. package/dist/archives/zip.js +85 -121
  21. package/dist/argv/flag-predicates.js +203 -101
  22. package/dist/argv/flag-types.js +96 -113
  23. package/dist/argv/parse-args-string.d.ts +16 -14
  24. package/dist/argv/parse-args-string.js +42 -39
  25. package/dist/argv/parse.js +145 -163
  26. package/dist/arrays/_internal.js +65 -48
  27. package/dist/arrays/chunk.js +51 -40
  28. package/dist/arrays/join.js +87 -35
  29. package/dist/arrays/predicates.js +46 -28
  30. package/dist/arrays/unique.js +45 -31
  31. package/dist/bin/_internal.js +34 -42
  32. package/dist/bin/check-primordials.js +175 -233
  33. package/dist/bin/check.js +51 -72
  34. package/dist/bin/exec.js +70 -74
  35. package/dist/bin/find.js +151 -134
  36. package/dist/bin/resolve.js +180 -246
  37. package/dist/bin/shadow.js +24 -33
  38. package/dist/bin/socket-lib.js +51 -73
  39. package/dist/bin/types.js +1 -17
  40. package/dist/bin/which.js +211 -146
  41. package/dist/cacache/_internal.js +25 -40
  42. package/dist/cacache/clear.js +79 -72
  43. package/dist/cacache/read.js +48 -46
  44. package/dist/cacache/tmp.js +29 -36
  45. package/dist/cacache/types.js +1 -17
  46. package/dist/cacache/write.js +43 -48
  47. package/dist/cache/ttl/store.js +232 -288
  48. package/dist/cache/ttl/types.js +1 -17
  49. package/dist/checks/primordials-defaults.js +83 -89
  50. package/dist/checks/primordials.js +225 -277
  51. package/dist/colors/convert.js +45 -37
  52. package/dist/colors/palette.js +88 -45
  53. package/dist/colors/socket-palette.js +74 -84
  54. package/dist/colors/types.js +1 -17
  55. package/dist/compression/_internal.js +57 -72
  56. package/dist/compression/brotli.js +94 -127
  57. package/dist/compression/gzip.js +95 -121
  58. package/dist/compression/types.js +1 -17
  59. package/dist/constants/agents.js +61 -113
  60. package/dist/constants/encoding.js +19 -42
  61. package/dist/constants/github.js +12 -30
  62. package/dist/constants/licenses.js +48 -63
  63. package/dist/constants/lifecycle-script-names.js +31 -45
  64. package/dist/constants/maintained-node-versions.js +22 -37
  65. package/dist/constants/node.js +226 -167
  66. package/dist/constants/package-default-node-range.js +16 -41
  67. package/dist/constants/package-default-socket-categories.js +12 -30
  68. package/dist/constants/packages.js +77 -126
  69. package/dist/constants/platform.js +27 -49
  70. package/dist/constants/sentinels.js +23 -48
  71. package/dist/constants/socket.js +42 -87
  72. package/dist/constants/testing.js +15 -34
  73. package/dist/constants/time.js +16 -36
  74. package/dist/constants/typescript.js +32 -52
  75. package/dist/cover/code.js +111 -142
  76. package/dist/cover/formatters.js +118 -101
  77. package/dist/cover/type.js +50 -76
  78. package/dist/cover/types.js +1 -17
  79. package/dist/crypto/hash.js +54 -46
  80. package/dist/debug/_internal.js +62 -71
  81. package/dist/debug/caller-info.js +53 -64
  82. package/dist/debug/namespace.js +80 -90
  83. package/dist/debug/output.js +172 -188
  84. package/dist/debug/types.js +1 -17
  85. package/dist/dlx/_internal.js +24 -43
  86. package/dist/dlx/arborist.js +162 -160
  87. package/dist/dlx/binary-cache.js +228 -200
  88. package/dist/dlx/binary-download.js +172 -211
  89. package/dist/dlx/binary-resolution.js +165 -157
  90. package/dist/dlx/binary-types.js +1 -17
  91. package/dist/dlx/binary.js +149 -189
  92. package/dist/dlx/cache.js +45 -30
  93. package/dist/dlx/detect.js +245 -167
  94. package/dist/dlx/dir.js +67 -51
  95. package/dist/dlx/firewall.js +62 -100
  96. package/dist/dlx/lockfile.js +122 -127
  97. package/dist/dlx/manifest.js +264 -274
  98. package/dist/dlx/package.js +241 -244
  99. package/dist/dlx/packages.js +99 -96
  100. package/dist/dlx/paths.js +73 -59
  101. package/dist/dlx/spec.js +52 -60
  102. package/dist/dlx/types.js +1 -17
  103. package/dist/eco/cargo/lockfile-format.js +19 -36
  104. package/dist/eco/cargo/manifest-format.js +17 -35
  105. package/dist/eco/cargo/parse-lockfile.js +210 -237
  106. package/dist/eco/manifest/analyze-lockfile.js +46 -63
  107. package/dist/eco/manifest/detect-format.js +66 -90
  108. package/dist/eco/manifest/find-packages.js +39 -64
  109. package/dist/eco/manifest/get-package-versions.js +27 -48
  110. package/dist/eco/manifest/get-package.js +21 -40
  111. package/dist/eco/manifest/manifest-error.js +14 -35
  112. package/dist/eco/manifest/parse-lockfile.js +40 -86
  113. package/dist/eco/manifest/parse-manifest.js +26 -43
  114. package/dist/eco/manifest/parse.js +26 -47
  115. package/dist/eco/manifest/types.js +1 -17
  116. package/dist/eco/npm/bun/exec.js +23 -32
  117. package/dist/eco/npm/manifest-format.js +21 -35
  118. package/dist/eco/npm/npm/exec.js +51 -61
  119. package/dist/eco/npm/npm/extract-package-name-from-path.js +28 -50
  120. package/dist/eco/npm/npm/flags.js +80 -52
  121. package/dist/eco/npm/npm/lockfile-format.js +21 -40
  122. package/dist/eco/npm/npm/parse-git-url.js +26 -40
  123. package/dist/eco/npm/npm/parse-lockfile.js +184 -210
  124. package/dist/eco/npm/parse-package-json.js +71 -102
  125. package/dist/eco/npm/pnpm/detect-pnpm-version.js +22 -43
  126. package/dist/eco/npm/pnpm/exec.js +51 -62
  127. package/dist/eco/npm/pnpm/flags.js +75 -68
  128. package/dist/eco/npm/pnpm/lockfile-format.js +19 -36
  129. package/dist/eco/npm/pnpm/parse-lockfile.js +235 -259
  130. package/dist/eco/npm/pnpm/parse-pnpm-package-id-v5.js +37 -47
  131. package/dist/eco/npm/pnpm/parse-pnpm-package-id-v6-v9.js +36 -49
  132. package/dist/eco/npm/script.js +82 -90
  133. package/dist/eco/npm/vlt/exec.js +24 -32
  134. package/dist/eco/npm/yarnpkg/yarn/exec.js +60 -59
  135. package/dist/eco/npm/yarnpkg/yarn/lockfile-format.js +20 -36
  136. package/dist/eco/npm/yarnpkg/yarn/parse-lockfile.js +194 -242
  137. package/dist/eco/npm/yarnpkg/yarn/parse-yarn-descriptor.js +37 -61
  138. package/dist/eco/purl.js +50 -60
  139. package/dist/eco/types.js +1 -17
  140. package/dist/effects/pulse-frames.js +64 -65
  141. package/dist/effects/shimmer-keyframes.js +71 -52
  142. package/dist/effects/shimmer-terminal.js +81 -50
  143. package/dist/effects/shimmer.js +290 -153
  144. package/dist/env/boolean.js +42 -43
  145. package/dist/env/case-insensitive.js +54 -39
  146. package/dist/env/ci.js +29 -31
  147. package/dist/env/debug.js +28 -31
  148. package/dist/env/github.js +144 -59
  149. package/dist/env/home.js +38 -31
  150. package/dist/env/locale.js +59 -39
  151. package/dist/env/node-auth-token.js +28 -31
  152. package/dist/env/node-env.js +28 -31
  153. package/dist/env/npm.js +94 -47
  154. package/dist/env/number.js +50 -51
  155. package/dist/env/package-manager.js +95 -83
  156. package/dist/env/path.js +28 -31
  157. package/dist/env/pre-commit.js +30 -32
  158. package/dist/env/proxy.js +121 -122
  159. package/dist/env/rewire.js +204 -96
  160. package/dist/env/shell.js +28 -31
  161. package/dist/env/socket-cli.js +233 -81
  162. package/dist/env/socket.js +521 -156
  163. package/dist/env/string.js +43 -44
  164. package/dist/env/temp-dir.js +59 -39
  165. package/dist/env/term.js +28 -31
  166. package/dist/env/test.js +65 -43
  167. package/dist/env/types.js +1 -17
  168. package/dist/env/windows.js +78 -43
  169. package/dist/env/xdg.js +62 -39
  170. package/dist/errors/message.js +40 -46
  171. package/dist/errors/predicates.js +61 -49
  172. package/dist/errors/stack.js +24 -36
  173. package/dist/events/exit/_internal.js +86 -103
  174. package/dist/events/exit/handler.js +48 -55
  175. package/dist/events/exit/intercept.js +49 -70
  176. package/dist/events/exit/lifecycle.js +92 -101
  177. package/dist/events/exit/signals.js +25 -31
  178. package/dist/events/exit/types.js +1 -17
  179. package/dist/events/warning/handler.js +43 -40
  180. package/dist/events/warning/suppress.js +111 -90
  181. package/dist/external/@npmcli/package-json/lib/read-package.js +132 -153
  182. package/dist/external/@npmcli/package-json/lib/sort.js +73 -105
  183. package/dist/external/@npmcli/package-json.js +12705 -15140
  184. package/dist/external/@npmcli/promise-spawn.js +451 -472
  185. package/dist/external/@sinclair/typebox/value.js +7443 -9002
  186. package/dist/external/@sinclair/typebox.js +7516 -7885
  187. package/dist/external/@socketregistry/is-unicode-supported.js +31 -39
  188. package/dist/external/@socketregistry/packageurl-js.js +6127 -7369
  189. package/dist/external/@socketregistry/yocto-spinner.js +394 -455
  190. package/dist/external/@yarnpkg/extensions.js +435 -1022
  191. package/dist/external/adm-zip.js +2313 -2673
  192. package/dist/external/debug.js +700 -687
  193. package/dist/external/external-pack.js +2658 -3171
  194. package/dist/external/fast-sort.js +124 -138
  195. package/dist/external/get-east-asian-width.js +70 -64
  196. package/dist/external/libnpmexec.js +28 -31
  197. package/dist/external/npm-pack.js +43617 -50137
  198. package/dist/external/p-map.js +198 -222
  199. package/dist/external/pico-pack.js +6735 -7304
  200. package/dist/external/pony-cause.js +143 -139
  201. package/dist/external/shell-quote.js +226 -0
  202. package/dist/external/spdx-pack.js +1283 -1403
  203. package/dist/external/streaming-iterables.js +835 -1052
  204. package/dist/external/tar-fs.js +2769 -3048
  205. package/dist/external/which.js +267 -251
  206. package/dist/external/yargs-parser.js +851 -1074
  207. package/dist/external-tools/bazel/asset-names.js +98 -90
  208. package/dist/external-tools/bazel/from-download.js +52 -46
  209. package/dist/external-tools/bazel/from-path.js +27 -38
  210. package/dist/external-tools/bazel/read-bazel-version-file.js +35 -57
  211. package/dist/external-tools/bazel/resolve-asset-url.js +24 -39
  212. package/dist/external-tools/bazel/resolve-bazel-version.js +34 -56
  213. package/dist/external-tools/bazel/resolve.js +44 -58
  214. package/dist/external-tools/bazel/types.js +1 -17
  215. package/dist/external-tools/cdxgen/asset-names.js +59 -66
  216. package/dist/external-tools/cdxgen/from-download.js +52 -80
  217. package/dist/external-tools/cdxgen/from-path.js +19 -37
  218. package/dist/external-tools/cdxgen/from-vfs.js +22 -43
  219. package/dist/external-tools/cdxgen/resolve.js +48 -63
  220. package/dist/external-tools/cdxgen/types.js +1 -17
  221. package/dist/external-tools/from-download.js +107 -67
  222. package/dist/external-tools/janus/asset-names.js +44 -51
  223. package/dist/external-tools/janus/from-download.js +45 -70
  224. package/dist/external-tools/janus/from-path.js +19 -37
  225. package/dist/external-tools/janus/from-vfs.js +22 -43
  226. package/dist/external-tools/janus/resolve.js +45 -63
  227. package/dist/external-tools/janus/types.js +1 -17
  228. package/dist/external-tools/jre/asset-names.js +109 -82
  229. package/dist/external-tools/jre/detect-platform-arch.js +25 -49
  230. package/dist/external-tools/jre/from-download.js +71 -67
  231. package/dist/external-tools/jre/from-java-home.js +27 -54
  232. package/dist/external-tools/jre/from-path.js +27 -49
  233. package/dist/external-tools/jre/from-vfs.js +39 -60
  234. package/dist/external-tools/jre/resolve.js +55 -68
  235. package/dist/external-tools/jre/types.js +1 -17
  236. package/dist/external-tools/manifest.js +130 -150
  237. package/dist/external-tools/opengrep/asset-names.js +60 -72
  238. package/dist/external-tools/opengrep/from-download.js +58 -80
  239. package/dist/external-tools/opengrep/from-path.js +19 -37
  240. package/dist/external-tools/opengrep/from-vfs.js +23 -43
  241. package/dist/external-tools/opengrep/resolve.js +43 -63
  242. package/dist/external-tools/opengrep/types.js +1 -17
  243. package/dist/external-tools/sbt/asset-names.js +21 -30
  244. package/dist/external-tools/sbt/from-download.js +50 -61
  245. package/dist/external-tools/sbt/from-path.js +23 -38
  246. package/dist/external-tools/sbt/from-vfs.js +30 -44
  247. package/dist/external-tools/sbt/resolve.js +45 -63
  248. package/dist/external-tools/sbt/types.js +1 -17
  249. package/dist/external-tools/synp/asset-names.js +11 -29
  250. package/dist/external-tools/synp/from-download.js +24 -41
  251. package/dist/external-tools/synp/from-path.js +19 -37
  252. package/dist/external-tools/synp/from-vfs.js +22 -43
  253. package/dist/external-tools/synp/resolve.js +43 -62
  254. package/dist/external-tools/synp/types.js +1 -17
  255. package/dist/external-tools/trivy/asset-names.js +51 -62
  256. package/dist/external-tools/trivy/from-download.js +42 -64
  257. package/dist/external-tools/trivy/from-path.js +19 -37
  258. package/dist/external-tools/trivy/from-vfs.js +22 -43
  259. package/dist/external-tools/trivy/resolve.js +43 -63
  260. package/dist/external-tools/trivy/types.js +1 -17
  261. package/dist/external-tools/trufflehog/asset-names.js +54 -66
  262. package/dist/external-tools/trufflehog/from-download.js +44 -62
  263. package/dist/external-tools/trufflehog/from-path.js +21 -37
  264. package/dist/external-tools/trufflehog/from-vfs.js +26 -43
  265. package/dist/external-tools/trufflehog/resolve.js +43 -63
  266. package/dist/external-tools/trufflehog/types.js +1 -17
  267. package/dist/external-tools/uv/asset-names.js +64 -74
  268. package/dist/external-tools/uv/from-download.js +44 -65
  269. package/dist/external-tools/uv/from-path.js +19 -37
  270. package/dist/external-tools/uv/from-vfs.js +22 -43
  271. package/dist/external-tools/uv/resolve.js +42 -63
  272. package/dist/external-tools/uv/types.js +1 -17
  273. package/dist/fs/_internal.js +40 -42
  274. package/dist/fs/access.d.ts +32 -0
  275. package/dist/fs/access.js +66 -0
  276. package/dist/fs/encoding.js +80 -97
  277. package/dist/fs/find-up.js +126 -147
  278. package/dist/fs/inspect.js +168 -99
  279. package/dist/fs/path-cache.js +31 -32
  280. package/dist/fs/read-dir.js +102 -79
  281. package/dist/fs/read-file.js +177 -118
  282. package/dist/fs/read-json-cache.js +150 -134
  283. package/dist/fs/read-json.js +172 -187
  284. package/dist/fs/resolve-module.d.ts +57 -0
  285. package/dist/fs/resolve-module.js +40 -0
  286. package/dist/fs/safe.js +278 -169
  287. package/dist/fs/types.js +1 -17
  288. package/dist/fs/unique.js +52 -48
  289. package/dist/fs/validate.js +56 -43
  290. package/dist/fs/write-json.js +109 -75
  291. package/dist/git/_internal.js +251 -216
  292. package/dist/git/changed.js +191 -74
  293. package/dist/git/repo.js +118 -104
  294. package/dist/git/staged.js +172 -62
  295. package/dist/git/types.js +1 -17
  296. package/dist/git/unstaged.js +175 -62
  297. package/dist/github/constants.js +25 -33
  298. package/dist/github/errors.js +46 -38
  299. package/dist/github/fetch.js +137 -82
  300. package/dist/github/ghsa.js +217 -151
  301. package/dist/github/refs-cache.js +54 -43
  302. package/dist/github/refs-graphql.js +97 -89
  303. package/dist/github/refs-rest.js +70 -101
  304. package/dist/github/refs.js +105 -64
  305. package/dist/github/token.js +96 -48
  306. package/dist/github/types.js +1 -17
  307. package/dist/globs/_internal.js +73 -82
  308. package/dist/globs/defaults.js +40 -59
  309. package/dist/globs/match.js +93 -77
  310. package/dist/globs/matcher.js +104 -92
  311. package/dist/globs/stream.js +43 -55
  312. package/dist/globs/types.js +1 -17
  313. package/dist/http-request/_internal.js +11 -38
  314. package/dist/http-request/browser-fetch.js +19 -29
  315. package/dist/http-request/browser.js +188 -206
  316. package/dist/http-request/checksums.js +101 -65
  317. package/dist/http-request/download-types.js +1 -17
  318. package/dist/http-request/download.js +195 -196
  319. package/dist/http-request/errors.js +39 -47
  320. package/dist/http-request/headers.js +95 -80
  321. package/dist/http-request/http-request.js +10 -35
  322. package/dist/http-request/node.js +71 -97
  323. package/dist/http-request/request-attempt.js +232 -285
  324. package/dist/http-request/request-types.js +1 -17
  325. package/dist/http-request/request.js +106 -108
  326. package/dist/http-request/response-reader.js +47 -51
  327. package/dist/http-request/response-types.js +22 -38
  328. package/dist/http-request/user-agent.js +73 -55
  329. package/dist/integrity.js +105 -106
  330. package/dist/ipc/_internal.js +34 -48
  331. package/dist/ipc/directory.js +55 -63
  332. package/dist/ipc/paths.js +52 -45
  333. package/dist/ipc/types.js +1 -17
  334. package/dist/ipc/write.js +81 -74
  335. package/dist/ipc-cli/get.js +29 -56
  336. package/dist/ipc-cli/types.js +1 -17
  337. package/dist/json/edit.js +182 -242
  338. package/dist/json/format.js +202 -103
  339. package/dist/json/parse.js +206 -109
  340. package/dist/json/types.js +1 -17
  341. package/dist/links/create.js +93 -60
  342. package/dist/links/types.js +1 -17
  343. package/dist/logger/_internal.js +109 -73
  344. package/dist/logger/browser.js +45 -56
  345. package/dist/logger/colors.js +31 -49
  346. package/dist/logger/console.js +89 -112
  347. package/dist/logger/default.js +19 -33
  348. package/dist/logger/logger.js +5 -29
  349. package/dist/logger/node.js +794 -854
  350. package/dist/logger/symbols-builder.js +54 -56
  351. package/dist/logger/symbols.js +135 -118
  352. package/dist/logger/types.js +1 -17
  353. package/dist/memo/_internal.js +39 -49
  354. package/dist/memo/async.js +133 -117
  355. package/dist/memo/clear.js +25 -34
  356. package/dist/memo/decorator.js +43 -37
  357. package/dist/memo/memoize.js +97 -88
  358. package/dist/memo/once.js +42 -41
  359. package/dist/memo/types.js +1 -17
  360. package/dist/memo/weak.js +45 -41
  361. package/dist/node/async-hooks.js +9 -30
  362. package/dist/node/child-process.js +9 -30
  363. package/dist/node/crypto.js +9 -30
  364. package/dist/node/events.js +9 -30
  365. package/dist/node/fs-promises.js +9 -30
  366. package/dist/node/fs.js +9 -30
  367. package/dist/node/http.js +9 -30
  368. package/dist/node/https.js +9 -30
  369. package/dist/node/module.js +20 -34
  370. package/dist/node/os.js +9 -30
  371. package/dist/node/path.js +9 -30
  372. package/dist/node/timers-promises.js +9 -30
  373. package/dist/node/url.js +9 -30
  374. package/dist/node/util.js +9 -30
  375. package/dist/objects/getters.js +185 -126
  376. package/dist/objects/inspect.js +85 -52
  377. package/dist/objects/mutate.js +96 -76
  378. package/dist/objects/predicates.js +112 -59
  379. package/dist/objects/sort.js +120 -76
  380. package/dist/objects/types.js +1 -17
  381. package/dist/packages/edit-class.js +198 -265
  382. package/dist/packages/edit.js +79 -86
  383. package/dist/packages/exports.js +146 -157
  384. package/dist/packages/isolation.js +159 -209
  385. package/dist/packages/licenses.js +207 -189
  386. package/dist/packages/manifest.js +134 -172
  387. package/dist/packages/normalize.js +91 -102
  388. package/dist/packages/operations.d.ts +2 -0
  389. package/dist/packages/operations.js +283 -254
  390. package/dist/packages/provenance.js +195 -245
  391. package/dist/packages/specs.js +94 -84
  392. package/dist/packages/types.js +1 -17
  393. package/dist/packages/validation.js +49 -50
  394. package/dist/paths/_internal.js +82 -86
  395. package/dist/paths/conversion.js +112 -65
  396. package/dist/paths/dirnames.js +17 -42
  397. package/dist/paths/exts.js +23 -54
  398. package/dist/paths/filenames.js +21 -50
  399. package/dist/paths/globs.js +15 -38
  400. package/dist/paths/normalize.js +215 -236
  401. package/dist/paths/packages.js +34 -49
  402. package/dist/paths/predicates.js +184 -106
  403. package/dist/paths/resolve.js +146 -128
  404. package/dist/paths/rewire.js +108 -72
  405. package/dist/paths/socket.js +252 -132
  406. package/dist/paths/walk.d.ts +40 -0
  407. package/dist/paths/walk.js +58 -0
  408. package/dist/perf/_internal.js +10 -28
  409. package/dist/perf/enabled.js +21 -30
  410. package/dist/perf/metrics.js +81 -67
  411. package/dist/perf/report.js +79 -80
  412. package/dist/perf/timer.js +180 -126
  413. package/dist/perf/types.js +1 -17
  414. package/dist/pkg-ext/data.js +29 -82
  415. package/dist/pkg-ext/types.js +1 -17
  416. package/dist/primordials/array.js +120 -198
  417. package/dist/primordials/buffer.js +28 -51
  418. package/dist/primordials/date.js +26 -51
  419. package/dist/primordials/error.js +33 -59
  420. package/dist/primordials/function.js +21 -41
  421. package/dist/primordials/globals.js +25 -48
  422. package/dist/primordials/json.js +14 -30
  423. package/dist/primordials/map-set.js +88 -152
  424. package/dist/primordials/math.js +59 -116
  425. package/dist/primordials/number.js +41 -76
  426. package/dist/primordials/object.js +56 -116
  427. package/dist/primordials/promise.js +28 -52
  428. package/dist/primordials/reflect.js +24 -52
  429. package/dist/primordials/regexp.js +25 -47
  430. package/dist/primordials/string.js +114 -167
  431. package/dist/primordials/symbol.js +40 -72
  432. package/dist/primordials/uncurry.js +38 -55
  433. package/dist/primordials/url.js +27 -66
  434. package/dist/process/_internal.js +7 -32
  435. package/dist/process/abort.js +29 -35
  436. package/dist/process/lock-instance.js +26 -30
  437. package/dist/process/lock-manager.js +279 -307
  438. package/dist/process/lock-types.js +1 -17
  439. package/dist/process/spawn/_internal.js +43 -55
  440. package/dist/process/spawn/child.js +172 -211
  441. package/dist/process/spawn/errors.js +116 -113
  442. package/dist/process/spawn/stdio.js +51 -35
  443. package/dist/process/spawn/types.js +1 -17
  444. package/dist/process/transient.js +49 -66
  445. package/dist/promises/_internal.d.ts +8 -2
  446. package/dist/promises/_internal.js +31 -38
  447. package/dist/promises/iterate.js +238 -102
  448. package/dist/promises/options.js +123 -101
  449. package/dist/promises/queue.js +115 -136
  450. package/dist/promises/resolvers.js +77 -46
  451. package/dist/promises/retry.js +156 -101
  452. package/dist/promises/types.js +1 -17
  453. package/dist/regexps/escape.js +32 -30
  454. package/dist/regexps/hex.js +16 -33
  455. package/dist/regexps/spec.js +53 -81
  456. package/dist/releases/github-archives.js +127 -118
  457. package/dist/releases/github-asset-url.js +162 -155
  458. package/dist/releases/github-assets.js +37 -49
  459. package/dist/releases/github-auth.js +32 -48
  460. package/dist/releases/github-downloads.js +118 -138
  461. package/dist/releases/github-listing.js +175 -154
  462. package/dist/releases/github-retry-config.d.ts +31 -0
  463. package/dist/releases/github-retry-config.js +46 -0
  464. package/dist/releases/github-types.js +1 -17
  465. package/dist/releases/socket-btm.js +273 -192
  466. package/dist/schema/parse.js +35 -36
  467. package/dist/schema/types.js +1 -17
  468. package/dist/schema/validate.js +118 -99
  469. package/dist/sea/detect.js +57 -52
  470. package/dist/secrets/_internal.js +86 -67
  471. package/dist/secrets/find.js +96 -77
  472. package/dist/secrets/keychain.js +315 -309
  473. package/dist/secrets/linux.js +133 -135
  474. package/dist/secrets/macos.js +151 -147
  475. package/dist/secrets/rc.js +182 -181
  476. package/dist/secrets/socket-api-token.js +28 -43
  477. package/dist/secrets/types.js +1 -17
  478. package/dist/secrets/windows.js +184 -242
  479. package/dist/shadow/skip.js +51 -70
  480. package/dist/shadow/types.js +1 -17
  481. package/dist/shell/parse.d.ts +26 -0
  482. package/dist/shell/parse.js +35 -0
  483. package/dist/shell/quote.d.ts +19 -0
  484. package/dist/shell/quote.js +30 -0
  485. package/dist/smol/detect.js +67 -43
  486. package/dist/smol/http.js +33 -37
  487. package/dist/smol/https.js +31 -37
  488. package/dist/smol/manifest.js +33 -37
  489. package/dist/smol/path.d.ts +51 -0
  490. package/dist/smol/path.js +38 -0
  491. package/dist/smol/primordial.js +35 -37
  492. package/dist/smol/purl.js +34 -37
  493. package/dist/smol/versions.js +31 -37
  494. package/dist/smol/vfs.js +46 -38
  495. package/dist/sorts/_internal.js +14 -40
  496. package/dist/sorts/natural.js +57 -64
  497. package/dist/sorts/semver.js +33 -43
  498. package/dist/sorts/strings.js +24 -30
  499. package/dist/sorts/types.js +1 -17
  500. package/dist/spinner/default.js +72 -63
  501. package/dist/spinner/format.js +86 -71
  502. package/dist/spinner/spinner.js +749 -797
  503. package/dist/spinner/types.js +1 -17
  504. package/dist/spinner/with.js +193 -137
  505. package/dist/ssri/convert.js +64 -47
  506. package/dist/ssri/parse.js +38 -37
  507. package/dist/ssri/validate.js +51 -34
  508. package/dist/stdio/_internal.js +50 -46
  509. package/dist/stdio/clear.js +208 -86
  510. package/dist/stdio/divider.js +170 -97
  511. package/dist/stdio/footer.js +116 -110
  512. package/dist/stdio/header.js +117 -90
  513. package/dist/stdio/progress.js +189 -218
  514. package/dist/stdio/prompts.js +244 -168
  515. package/dist/stdio/stderr.js +173 -78
  516. package/dist/stdio/stdout.js +177 -94
  517. package/dist/streams/parallel.js +58 -50
  518. package/dist/streams/transform.js +36 -45
  519. package/dist/strings/format.js +145 -63
  520. package/dist/strings/predicates.js +56 -34
  521. package/dist/strings/search.js +52 -42
  522. package/dist/strings/transform.js +113 -72
  523. package/dist/strings/types.js +1 -17
  524. package/dist/strings/width.js +89 -82
  525. package/dist/tables/bordered.js +81 -81
  526. package/dist/tables/padding.js +36 -46
  527. package/dist/tables/simple.js +62 -70
  528. package/dist/tables/types.js +1 -17
  529. package/dist/temporal/instant.js +72 -81
  530. package/dist/temporal/now.js +40 -31
  531. package/dist/temporal/slots.js +42 -36
  532. package/dist/temporal/system.js +36 -36
  533. package/dist/temporal/temporal.js +11 -41
  534. package/dist/themes/context.js +131 -69
  535. package/dist/themes/resolve.js +207 -132
  536. package/dist/themes/themes.js +225 -194
  537. package/dist/themes/types.js +1 -17
  538. package/dist/url/parse.js +48 -51
  539. package/dist/url/predicates.js +24 -31
  540. package/dist/url/search-params.js +133 -101
  541. package/dist/url/types.js +1 -17
  542. package/dist/versions/_internal.js +31 -33
  543. package/dist/versions/compare.js +80 -58
  544. package/dist/versions/modify.js +41 -39
  545. package/dist/versions/parse.js +88 -64
  546. package/dist/versions/range.js +58 -41
  547. package/dist/versions/types.js +1 -17
  548. package/dist/words/article.js +22 -30
  549. package/dist/words/capitalize.js +25 -34
  550. package/dist/words/pluralize.js +23 -31
  551. package/dist/words/types.js +1 -17
  552. package/package.json +42 -5
@@ -1,173 +1,155 @@
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 parse_exports = {};
32
- __export(parse_exports, {
33
- commonParseArgsConfig: () => commonParseArgsConfig,
34
- getPositionalArgs: () => getPositionalArgs,
35
- hasFlag: () => hasFlag,
36
- parseArgs: () => parseArgs,
37
- parseArgsWithDefaults: () => parseArgsWithDefaults
38
- });
39
- module.exports = __toCommonJS(parse_exports);
40
- var import_node_process = __toESM(require("node:process"));
41
- var import_yargs_parser = __toESM(require("../external/yargs-parser"));
42
- var import_array = require("../primordials/array");
43
- var import_object = require("../primordials/object");
44
- var import_string = require("../primordials/string");
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_array = require('../primordials/array.js');
7
+ const require_primordials_object = require('../primordials/object.js');
8
+ let node_process = require("node:process");
9
+ node_process = require_runtime.__toESM(node_process);
10
+ let src_external_yargs_parser = require("../external/yargs-parser");
11
+ src_external_yargs_parser = require_runtime.__toESM(src_external_yargs_parser);
12
+
13
+ //#region src/argv/parse.ts
14
+ /**
15
+ * @file Argument parsing utilities for CLI applications. Wraps the vendored
16
+ * yargs-parser with a Node.js parseArgs-compatible surface for booleans,
17
+ * strings, arrays, aliases, defaults, and coercion.
18
+ */
19
+ /**
20
+ * Common parseArgs configuration for Socket registry scripts.
21
+ */
45
22
  const commonParseArgsConfig = {
46
- options: {
47
- force: {
48
- type: "boolean",
49
- short: "f",
50
- default: false
51
- },
52
- quiet: {
53
- type: "boolean",
54
- short: "q",
55
- default: false
56
- }
57
- },
58
- strict: false
23
+ options: {
24
+ force: {
25
+ type: "boolean",
26
+ short: "f",
27
+ default: false
28
+ },
29
+ quiet: {
30
+ type: "boolean",
31
+ short: "q",
32
+ default: false
33
+ }
34
+ },
35
+ strict: false
59
36
  };
37
+ /**
38
+ * Extract positional arguments from process.argv. Useful for commands that
39
+ * accept file paths or other positional parameters.
40
+ *
41
+ * @example
42
+ * ;```typescript
43
+ * // process.argv = ["node", "script.js", "src", "lib", "--verbose"]
44
+ * getPositionalArgs() // ["src", "lib"]
45
+ * ```
46
+ */
60
47
  function getPositionalArgs(startIndex = 2) {
61
- const args = import_node_process.default.argv.slice(startIndex);
62
- const positionals = [];
63
- let i = 0;
64
- while (i < args.length) {
65
- const arg = args[i];
66
- if ((0, import_string.StringPrototypeStartsWith)(arg, "-")) {
67
- break;
68
- }
69
- positionals.push(arg);
70
- i++;
71
- }
72
- return positionals;
48
+ const args = node_process.default.argv.slice(startIndex);
49
+ const positionals = [];
50
+ let i = 0;
51
+ while (i < args.length) {
52
+ const arg = args[i];
53
+ if (require_primordials_string.StringPrototypeStartsWith(arg, "-")) break;
54
+ positionals.push(arg);
55
+ i++;
56
+ }
57
+ return positionals;
73
58
  }
74
- function hasFlag(flag, argv = import_node_process.default.argv) {
75
- return (0, import_array.ArrayPrototypeIncludes)(argv, `--${flag}`);
59
+ /**
60
+ * Check if a specific flag is present in argv.
61
+ *
62
+ * @example
63
+ * ;```typescript
64
+ * hasFlag('verbose') // true if --verbose is in process.argv
65
+ * hasFlag('force', ['--force', '--quiet']) // true
66
+ * ```
67
+ */
68
+ function hasFlag(flag, argv = node_process.default.argv) {
69
+ return require_primordials_array.ArrayPrototypeIncludes(argv, `--${flag}`);
76
70
  }
71
+ /**
72
+ * Parse command-line arguments with a Node.js parseArgs-compatible API. Uses
73
+ * yargs-parser internally for robust argument parsing.
74
+ *
75
+ * @example
76
+ * ;```typescript
77
+ * const { values, positionals } = parseArgs({
78
+ * args: ['--force', '--quiet', 'file.ts'],
79
+ * options: {
80
+ * force: { type: 'boolean' },
81
+ * quiet: { type: 'boolean', short: 'q' },
82
+ * },
83
+ * })
84
+ * ```
85
+ */
77
86
  function parseArgs(config = {}) {
78
- const {
79
- allowNegative = false,
80
- allowPositionals = true,
81
- args = import_node_process.default.argv.slice(2),
82
- configuration,
83
- options = {},
84
- strict = true
85
- } = config;
86
- const yargsOptions = {
87
- // Arrays of option names to treat as specific types.
88
- boolean: [],
89
- string: [],
90
- array: [],
91
- // Maps for aliases, defaults, and transformations.
92
- alias: {},
93
- default: {},
94
- coerce: {},
95
- "unknown-options-as-args": !strict,
96
- "parse-numbers": false,
97
- "parse-positional-numbers": false,
98
- "boolean-negation": !allowNegative,
99
- "halt-at-non-option": !allowPositionals,
100
- configuration: {
101
- // Enable kebab-case to camelCase conversion (e.g., --temp-dir → tempDir).
102
- "camel-case-expansion": true,
103
- // Disable dot notation to avoid confusing nested property parsing.
104
- "dot-notation": false,
105
- // Convert duplicate arguments into arrays automatically.
106
- "duplicate-arguments-array": true,
107
- // Flatten nested arrays from duplicate arguments for cleaner output.
108
- "flatten-duplicate-arrays": true,
109
- // Populate the '--' key with arguments after the -- separator.
110
- "populate--": true,
111
- // Allow short option grouping like -abc for -a -b -c.
112
- "short-option-groups": true,
113
- // Keep aliased keys in the result for flexibility.
114
- "strip-aliased": false,
115
- // Keep both kebab-case and camelCase keys for flexibility.
116
- "strip-dashed": false,
117
- ...configuration
118
- }
119
- };
120
- for (const { 0: key, 1: optionConfig } of (0, import_object.ObjectEntries)(options)) {
121
- const {
122
- coerce,
123
- default: defaultValue,
124
- multiple,
125
- short,
126
- type
127
- } = optionConfig;
128
- if (type === "boolean") {
129
- yargsOptions.boolean?.push(key);
130
- } else if (type === "string") {
131
- yargsOptions.string?.push(key);
132
- }
133
- if (multiple) {
134
- yargsOptions.array?.push(key);
135
- }
136
- if (short) {
137
- ;
138
- yargsOptions.alias[short] = key;
139
- }
140
- if (defaultValue !== void 0) {
141
- ;
142
- yargsOptions.default[key] = defaultValue;
143
- }
144
- if (coerce) {
145
- ;
146
- yargsOptions.coerce[key] = coerce;
147
- }
148
- }
149
- const parsed = (0, import_yargs_parser.default)(args, yargsOptions);
150
- const positionals = parsed._ || [];
151
- const { _, ...values } = parsed;
152
- const stringPositionals = positionals.map(String);
153
- return {
154
- values,
155
- positionals: stringPositionals,
156
- raw: parsed
157
- };
87
+ const { allowNegative = false, allowPositionals = true, args = node_process.default.argv.slice(2), configuration, options = {}, strict = true } = config;
88
+ const yargsOptions = {
89
+ boolean: [],
90
+ string: [],
91
+ array: [],
92
+ alias: {},
93
+ default: {},
94
+ coerce: {},
95
+ "unknown-options-as-args": !strict,
96
+ "parse-numbers": false,
97
+ "parse-positional-numbers": false,
98
+ "boolean-negation": !allowNegative,
99
+ "halt-at-non-option": !allowPositionals,
100
+ configuration: {
101
+ "camel-case-expansion": true,
102
+ "dot-notation": false,
103
+ "duplicate-arguments-array": true,
104
+ "flatten-duplicate-arrays": true,
105
+ "populate--": true,
106
+ "short-option-groups": true,
107
+ "strip-aliased": false,
108
+ "strip-dashed": false,
109
+ ...configuration
110
+ }
111
+ };
112
+ for (const { 0: key, 1: optionConfig } of require_primordials_object.ObjectEntries(options)) {
113
+ const { coerce, default: defaultValue, multiple, short, type } = optionConfig;
114
+ if (type === "boolean") yargsOptions.boolean?.push(key);
115
+ else if (type === "string") yargsOptions.string?.push(key);
116
+ if (multiple) yargsOptions.array?.push(key);
117
+ if (short) yargsOptions.alias[short] = key;
118
+ if (defaultValue !== void 0) yargsOptions.default[key] = defaultValue;
119
+ if (coerce) yargsOptions.coerce[key] = coerce;
120
+ }
121
+ const parsed = (0, src_external_yargs_parser.default)(args, yargsOptions);
122
+ const positionals = parsed._ || [];
123
+ const { _, ...values } = parsed;
124
+ return {
125
+ values,
126
+ positionals: positionals.map(String),
127
+ raw: parsed
128
+ };
158
129
  }
130
+ /**
131
+ * Parse command-line arguments with Socket defaults. Provides sensible defaults
132
+ * for Socket CLI applications.
133
+ *
134
+ * @example
135
+ * ;```typescript
136
+ * const { values, positionals } = parseArgsWithDefaults({
137
+ * args: ['--force', 'file.ts'],
138
+ * options: { force: { type: 'boolean' } },
139
+ * })
140
+ * ```
141
+ */
159
142
  function parseArgsWithDefaults(config = {}) {
160
- return parseArgs({
161
- strict: false,
162
- allowPositionals: true,
163
- ...config
164
- });
143
+ return parseArgs({
144
+ strict: false,
145
+ allowPositionals: true,
146
+ ...config
147
+ });
165
148
  }
166
- // Annotate the CommonJS export names for ESM import in node:
167
- 0 && (module.exports = {
168
- commonParseArgsConfig,
169
- getPositionalArgs,
170
- hasFlag,
171
- parseArgs,
172
- parseArgsWithDefaults
173
- });
149
+
150
+ //#endregion
151
+ exports.commonParseArgsConfig = commonParseArgsConfig;
152
+ exports.getPositionalArgs = getPositionalArgs;
153
+ exports.hasFlag = hasFlag;
154
+ exports.parseArgs = parseArgs;
155
+ exports.parseArgsWithDefaults = parseArgsWithDefaults;
@@ -1,55 +1,72 @@
1
1
  "use strict";
2
- /* Socket Lib - Built with esbuild */
3
- "use strict";
4
- var __defProp = Object.defineProperty;
5
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
- var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
- var internal_exports = {};
22
- __export(internal_exports, {
23
- getConjunctionFormatter: () => getConjunctionFormatter,
24
- getDisjunctionFormatter: () => getDisjunctionFormatter
25
- });
26
- module.exports = __toCommonJS(internal_exports);
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+
5
+ //#region src/arrays/_internal.ts
6
+ /**
7
+ * @file Private internals for `arrays/*` modules — cached `Intl.ListFormat`
8
+ * instances for conjunction (and) and disjunction (or) joins. Constructed
9
+ * lazily because `new Intl.ListFormat(...)` is a measurable startup cost.
10
+ */
27
11
  let _conjunctionFormatter;
28
12
  let _disjunctionFormatter;
29
- // @__NO_SIDE_EFFECTS__
13
+ /**
14
+ * Get a cached Intl.ListFormat instance for conjunction (and) formatting.
15
+ *
16
+ * Creates a singleton formatter for English "and" lists using the long style.
17
+ * The formatter is lazily initialized on first use and reused for performance.
18
+ *
19
+ * @private
20
+ *
21
+ * @example
22
+ * ;```ts
23
+ * const formatter = getConjunctionFormatter()
24
+ * formatter.format(['apple', 'banana', 'cherry'])
25
+ * // Returns: "apple, banana, and cherry"
26
+ * ```
27
+ *
28
+ * @returns Cached Intl.ListFormat instance configured for conjunction
29
+ * formatting.
30
+ */
31
+ /* @__NO_SIDE_EFFECTS__ */
30
32
  function getConjunctionFormatter() {
31
- if (_conjunctionFormatter === void 0) {
32
- _conjunctionFormatter = new Intl.ListFormat("en", {
33
- style: "long",
34
- // "and" lists.
35
- type: "conjunction"
36
- });
37
- }
38
- return _conjunctionFormatter;
33
+ if (_conjunctionFormatter === void 0)
34
+ /* c8 ignore start */
35
+ _conjunctionFormatter = new Intl.ListFormat("en", {
36
+ style: "long",
37
+ type: "conjunction"
38
+ });
39
+ return _conjunctionFormatter;
39
40
  }
40
- // @__NO_SIDE_EFFECTS__
41
+ /**
42
+ * Get a cached Intl.ListFormat instance for disjunction (or) formatting.
43
+ *
44
+ * Creates a singleton formatter for English "or" lists using the long style.
45
+ * The formatter is lazily initialized on first use and reused for performance.
46
+ *
47
+ * @private
48
+ *
49
+ * @example
50
+ * ;```ts
51
+ * const formatter = getDisjunctionFormatter()
52
+ * formatter.format(['red', 'blue', 'green'])
53
+ * // Returns: "red, blue, or green"
54
+ * ```
55
+ *
56
+ * @returns Cached Intl.ListFormat instance configured for disjunction
57
+ * formatting.
58
+ */
59
+ /* @__NO_SIDE_EFFECTS__ */
41
60
  function getDisjunctionFormatter() {
42
- if (_disjunctionFormatter === void 0) {
43
- _disjunctionFormatter = new Intl.ListFormat("en", {
44
- style: "long",
45
- // "or" lists.
46
- type: "disjunction"
47
- });
48
- }
49
- return _disjunctionFormatter;
61
+ if (_disjunctionFormatter === void 0)
62
+ /* c8 ignore start */
63
+ _disjunctionFormatter = new Intl.ListFormat("en", {
64
+ style: "long",
65
+ type: "disjunction"
66
+ });
67
+ return _disjunctionFormatter;
50
68
  }
51
- // Annotate the CommonJS export names for ESM import in node:
52
- 0 && (module.exports = {
53
- getConjunctionFormatter,
54
- getDisjunctionFormatter
55
- });
69
+
70
+ //#endregion
71
+ exports.getConjunctionFormatter = getConjunctionFormatter;
72
+ exports.getDisjunctionFormatter = getDisjunctionFormatter;
@@ -1,43 +1,54 @@
1
1
  "use strict";
2
- /* Socket Lib - Built with esbuild */
3
- "use strict";
4
- var __defProp = Object.defineProperty;
5
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
- var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
- var chunk_exports = {};
22
- __export(chunk_exports, {
23
- arrayChunk: () => arrayChunk
24
- });
25
- module.exports = __toCommonJS(chunk_exports);
26
- var import_error = require("../primordials/error");
27
- // @__NO_SIDE_EFFECTS__
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_primordials_error = require('../primordials/error.js');
5
+
6
+ //#region src/arrays/chunk.ts
7
+ /**
8
+ * @file Split an array into fixed-size chunks. The last chunk holds the
9
+ * leftover when length is not evenly divisible.
10
+ */
11
+ /**
12
+ * Split an array into chunks of a specified size.
13
+ *
14
+ * Divides an array into smaller arrays of the specified chunk size. The last
15
+ * chunk may contain fewer elements if the array length is not evenly divisible
16
+ * by the chunk size.
17
+ *
18
+ * @example
19
+ * ;```ts
20
+ * // Split into pairs (default)
21
+ * arrayChunk([1, 2, 3, 4, 5])
22
+ * // Returns: [[1, 2], [3, 4], [5]]
23
+ *
24
+ * // Split into groups of 3
25
+ * arrayChunk(['a', 'b', 'c', 'd', 'e', 'f', 'g'], 3)
26
+ * // Returns: [['a', 'b', 'c'], ['d', 'e', 'f'], ['g']]
27
+ *
28
+ * // Works with readonly arrays
29
+ * const readonlyArr = [1, 2, 3] as const
30
+ * arrayChunk(readonlyArr)
31
+ * // Returns: [[1, 2], [3]]
32
+ * ```
33
+ *
34
+ * @default 2
35
+ *
36
+ * @param arr - The array to split into chunks (can be readonly)
37
+ * @param size - Size of each chunk. Must be greater than 0.
38
+ *
39
+ * @returns Array of chunks, where each chunk is an array of elements
40
+ *
41
+ * @throws {Error} If chunk size is less than or equal to 0
42
+ */
43
+ /* @__NO_SIDE_EFFECTS__ */
28
44
  function arrayChunk(arr, size) {
29
- const chunkSize = size ?? 2;
30
- if (chunkSize <= 0) {
31
- throw new import_error.ErrorCtor("Chunk size must be greater than 0");
32
- }
33
- const { length } = arr;
34
- const chunks = [];
35
- for (let i = 0; i < length; i += chunkSize) {
36
- chunks.push(arr.slice(i, i + chunkSize));
37
- }
38
- return chunks;
45
+ const chunkSize = size ?? 2;
46
+ if (chunkSize <= 0) throw new require_primordials_error.ErrorCtor("Chunk size must be greater than 0");
47
+ const { length } = arr;
48
+ const chunks = [];
49
+ for (let i = 0; i < length; i += chunkSize) chunks.push(arr.slice(i, i + chunkSize));
50
+ return chunks;
39
51
  }
40
- // Annotate the CommonJS export names for ESM import in node:
41
- 0 && (module.exports = {
42
- arrayChunk
43
- });
52
+
53
+ //#endregion
54
+ exports.arrayChunk = arrayChunk;