@socketsecurity/lib 6.0.3 → 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 (542) hide show
  1. package/CHANGELOG.md +16 -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 +794 -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,120 +1,136 @@
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 async_exports = {};
22
- __export(async_exports, {
23
- memoizeAsync: () => memoizeAsync
24
- });
25
- module.exports = __toCommonJS(async_exports);
26
- var import_output = require("../debug/output");
27
- var import_date = require("../primordials/date");
28
- var import_map_set = require("../primordials/map-set");
29
- var import_promise = require("../primordials/promise");
30
- var import_internal = require("./_internal");
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_primordials_map_set = require('../primordials/map-set.js');
5
+ const require_primordials_date = require('../primordials/date.js');
6
+ const require_primordials_promise = require('../primordials/promise.js');
7
+ const require_debug_output = require('../debug/output.js');
8
+ const require_memo__internal = require('./_internal.js');
9
+
10
+ //#region src/memo/async.ts
11
+ /**
12
+ * @file `memoizeAsync` async-aware memoizer with the same LRU+TTL contract as
13
+ * `memoize`, plus thundering-herd dedup. Concurrent callers join an in-flight
14
+ * promise instead of starting fresh fetches, and the cache timestamp is
15
+ * refreshed on resolution so a slow fn can't land a value that's already
16
+ * "expired".
17
+ */
18
+ /**
19
+ * Memoize an async function. Similar to memoize() but handles promises
20
+ * properly.
21
+ *
22
+ * @example
23
+ * import { memoizeAsync } from '@socketsecurity/lib/memo/async'
24
+ *
25
+ * const fetchUser = memoizeAsync(
26
+ * async (id: string) => {
27
+ * const response = await fetch(`/api/users/${id}`)
28
+ * return response.json()
29
+ * },
30
+ * { ttl: 300000, name: 'fetchUser' },
31
+ * )
32
+ *
33
+ * await fetchUser('123') // Fetches from API
34
+ * await fetchUser('123') // Returns cached result
35
+ *
36
+ * @param fn - Async function to memoize.
37
+ * @param options - Memoization options.
38
+ *
39
+ * @returns Memoized version of the async function
40
+ */
31
41
  function memoizeAsync(fn, options = {}) {
32
- const {
33
- keyGen = (...args) => (0, import_internal.defaultKeyGen)(args),
34
- maxSize = Number.POSITIVE_INFINITY,
35
- name = fn.name || "anonymous",
36
- ttl = Number.POSITIVE_INFINITY
37
- } = options;
38
- const cache = new import_map_set.MapCtor();
39
- import_internal.cacheRegistry.push(() => {
40
- cache.clear();
41
- });
42
- function evictLRU() {
43
- if (cache.size >= maxSize) {
44
- const oldest = cache.keys().next().value;
45
- if (oldest !== void 0) {
46
- cache.delete(oldest);
47
- (0, import_output.debugLog)(`[memoizeAsync:${name}] clear`, {
48
- key: oldest,
49
- reason: "LRU"
50
- });
51
- }
52
- }
53
- }
54
- function isExpired(entry) {
55
- if (ttl === Number.POSITIVE_INFINITY) {
56
- return false;
57
- }
58
- return (0, import_date.DateNow)() - entry.timestamp > ttl;
59
- }
60
- function bumpRecency(key, entry) {
61
- cache.delete(key);
62
- cache.set(key, entry);
63
- }
64
- const refreshing = new import_map_set.MapCtor();
65
- return async function memoized(...args) {
66
- const key = keyGen(...args);
67
- const cached = cache.get(key);
68
- if (cached) {
69
- if (!isExpired(cached)) {
70
- cached.hits++;
71
- bumpRecency(key, cached);
72
- (0, import_output.debugLog)(`[memoizeAsync:${name}] hit`, { key, hits: cached.hits });
73
- return await cached.value;
74
- }
75
- const inflight = refreshing.get(key);
76
- if (inflight) {
77
- (0, import_output.debugLog)(`[memoizeAsync:${name}] stale-dedup`, { key });
78
- bumpRecency(key, cached);
79
- return await inflight;
80
- }
81
- cache.delete(key);
82
- }
83
- const inflightCold = refreshing.get(key);
84
- if (inflightCold) {
85
- (0, import_output.debugLog)(`[memoizeAsync:${name}] cold-dedup`, { key });
86
- return await inflightCold;
87
- }
88
- (0, import_output.debugLog)(`[memoizeAsync:${name}] miss`, { key });
89
- const promise = (async () => {
90
- try {
91
- const result = await fn(...args);
92
- refreshing.delete(key);
93
- const entry = cache.get(key);
94
- if (entry) {
95
- entry.value = (0, import_promise.PromiseResolve)(result);
96
- entry.timestamp = (0, import_date.DateNow)();
97
- }
98
- return result;
99
- } catch (error) {
100
- refreshing.delete(key);
101
- cache.delete(key);
102
- (0, import_output.debugLog)(`[memoizeAsync:${name}] error`, { key, error });
103
- throw error;
104
- }
105
- })();
106
- refreshing.set(key, promise);
107
- evictLRU();
108
- cache.set(key, {
109
- value: promise,
110
- timestamp: Date.now(),
111
- hits: 0
112
- });
113
- (0, import_output.debugLog)(`[memoizeAsync:${name}] set`, { key, cacheSize: cache.size });
114
- return await promise;
115
- };
42
+ const { keyGen = (...args) => require_memo__internal.defaultKeyGen(args), maxSize = Number.POSITIVE_INFINITY, name = fn.name || "anonymous", ttl = Number.POSITIVE_INFINITY } = options;
43
+ const cache = new require_primordials_map_set.MapCtor();
44
+ require_memo__internal.cacheRegistry.push(() => {
45
+ cache.clear();
46
+ });
47
+ function evictLRU() {
48
+ if (cache.size >= maxSize) {
49
+ const oldest = cache.keys().next().value;
50
+ /* c8 ignore next 8 - cache.size >= maxSize guarantees keys().next()
51
+ yields a defined value; the undefined branch is defensive. */
52
+ if (oldest !== void 0) {
53
+ cache.delete(oldest);
54
+ require_debug_output.debugLog(`[memoizeAsync:${name}] clear`, {
55
+ key: oldest,
56
+ reason: "LRU"
57
+ });
58
+ }
59
+ }
60
+ }
61
+ function isExpired(entry) {
62
+ /* c8 ignore next 3 */
63
+ if (ttl === Number.POSITIVE_INFINITY) return false;
64
+ return require_primordials_date.DateNow() - entry.timestamp > ttl;
65
+ }
66
+ function bumpRecency(key, entry) {
67
+ cache.delete(key);
68
+ cache.set(key, entry);
69
+ }
70
+ const refreshing = new require_primordials_map_set.MapCtor();
71
+ return async function memoized(...args) {
72
+ const key = keyGen(...args);
73
+ const cached = cache.get(key);
74
+ /* c8 ignore start */
75
+ if (cached) {
76
+ if (!isExpired(cached)) {
77
+ cached.hits++;
78
+ bumpRecency(key, cached);
79
+ require_debug_output.debugLog(`[memoizeAsync:${name}] hit`, {
80
+ key,
81
+ hits: cached.hits
82
+ });
83
+ return await cached.value;
84
+ }
85
+ const inflight = refreshing.get(key);
86
+ if (inflight) {
87
+ require_debug_output.debugLog(`[memoizeAsync:${name}] stale-dedup`, { key });
88
+ bumpRecency(key, cached);
89
+ return await inflight;
90
+ }
91
+ cache.delete(key);
92
+ }
93
+ const inflightCold = refreshing.get(key);
94
+ if (inflightCold) {
95
+ require_debug_output.debugLog(`[memoizeAsync:${name}] cold-dedup`, { key });
96
+ return await inflightCold;
97
+ }
98
+ /* c8 ignore stop */
99
+ require_debug_output.debugLog(`[memoizeAsync:${name}] miss`, { key });
100
+ const promise = (async () => {
101
+ try {
102
+ const result = await fn(...args);
103
+ refreshing.delete(key);
104
+ const entry = cache.get(key);
105
+ if (entry) {
106
+ entry.value = require_primordials_promise.PromiseResolve(result);
107
+ entry.timestamp = require_primordials_date.DateNow();
108
+ }
109
+ return result;
110
+ } catch (error) {
111
+ refreshing.delete(key);
112
+ cache.delete(key);
113
+ require_debug_output.debugLog(`[memoizeAsync:${name}] error`, {
114
+ key,
115
+ error
116
+ });
117
+ throw error;
118
+ }
119
+ })();
120
+ refreshing.set(key, promise);
121
+ evictLRU();
122
+ cache.set(key, {
123
+ value: promise,
124
+ timestamp: Date.now(),
125
+ hits: 0
126
+ });
127
+ require_debug_output.debugLog(`[memoizeAsync:${name}] set`, {
128
+ key,
129
+ cacheSize: cache.size
130
+ });
131
+ return await promise;
132
+ };
116
133
  }
117
- // Annotate the CommonJS export names for ESM import in node:
118
- 0 && (module.exports = {
119
- memoizeAsync
120
- });
134
+
135
+ //#endregion
136
+ exports.memoizeAsync = memoizeAsync;
@@ -1,37 +1,28 @@
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 clear_exports = {};
22
- __export(clear_exports, {
23
- clearAllMemoizationCaches: () => clearAllMemoizationCaches
24
- });
25
- module.exports = __toCommonJS(clear_exports);
26
- var import_output = require("../debug/output");
27
- var import_internal = require("./_internal");
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_debug_output = require('../debug/output.js');
5
+ const require_memo__internal = require('./_internal.js');
6
+
7
+ //#region src/memo/clear.ts
8
+ /**
9
+ * @file `clearAllMemoizationCaches` fan out to every per-cache clear function
10
+ * registered in `_internal.cacheRegistry`. Useful for tests and for callers
11
+ * that need to force recomputation across every memoize instance.
12
+ */
13
+ /**
14
+ * Clear all memoization caches. Useful for testing or when you need to force
15
+ * recomputation.
16
+ *
17
+ * @example
18
+ * ;```typescript
19
+ * clearAllMemoizationCaches()
20
+ * ```
21
+ */
28
22
  function clearAllMemoizationCaches() {
29
- (0, import_output.debugLog)("[memoize:all] clear", { action: "clear-all-caches" });
30
- for (const clear of import_internal.cacheRegistry) {
31
- clear();
32
- }
23
+ require_debug_output.debugLog("[memoize:all] clear", { action: "clear-all-caches" });
24
+ for (const clear of require_memo__internal.cacheRegistry) clear();
33
25
  }
34
- // Annotate the CommonJS export names for ESM import in node:
35
- 0 && (module.exports = {
36
- clearAllMemoizationCaches
37
- });
26
+
27
+ //#endregion
28
+ exports.clearAllMemoizationCaches = clearAllMemoizationCaches;
@@ -1,40 +1,46 @@
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 decorator_exports = {};
22
- __export(decorator_exports, {
23
- Memoize: () => Memoize
24
- });
25
- module.exports = __toCommonJS(decorator_exports);
26
- var import_memoize = require("./memoize");
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_memo_memoize = require('./memoize.js');
5
+
6
+ //#region src/memo/decorator.ts
7
+ /**
8
+ * @file `Memoize` class-method decorator that wraps the decorated method via
9
+ * `memoize`. Preserves `this`-context by installing the wrapper on the
10
+ * property descriptor. Defaults the cache `name` option to the property key
11
+ * for nicer debug output.
12
+ */
13
+ /**
14
+ * Create a memoized version of a method. Preserves 'this' context for class
15
+ * methods.
16
+ *
17
+ * @example
18
+ * import { Memoize } from '@socketsecurity/lib/memo/decorator'
19
+ *
20
+ * class Calculator {
21
+ * @Memoize()
22
+ * fibonacci(n: number): number {
23
+ * if (n <= 1) return n
24
+ * return this.fibonacci(n - 1) + this.fibonacci(n - 2)
25
+ * }
26
+ * }
27
+ *
28
+ * @param target - Object containing the method.
29
+ * @param propertyKey - Method name.
30
+ * @param descriptor - Property descriptor.
31
+ *
32
+ * @returns Modified descriptor with memoized method
33
+ */
27
34
  function Memoize(options = {}) {
28
- return (_target, propertyKey, descriptor) => {
29
- const originalMethod = descriptor.value;
30
- descriptor.value = (0, import_memoize.memoize)(originalMethod, {
31
- ...options,
32
- name: options.name || propertyKey
33
- });
34
- return descriptor;
35
- };
35
+ return (_target, propertyKey, descriptor) => {
36
+ const originalMethod = descriptor.value;
37
+ descriptor.value = require_memo_memoize.memoize(originalMethod, {
38
+ ...options,
39
+ name: options.name || propertyKey
40
+ });
41
+ return descriptor;
42
+ };
36
43
  }
37
- // Annotate the CommonJS export names for ESM import in node:
38
- 0 && (module.exports = {
39
- Memoize
40
- });
44
+
45
+ //#endregion
46
+ exports.Memoize = Memoize;
@@ -1,91 +1,100 @@
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 memoize_exports = {};
22
- __export(memoize_exports, {
23
- memoize: () => memoize
24
- });
25
- module.exports = __toCommonJS(memoize_exports);
26
- var import_output = require("../debug/output");
27
- var import_date = require("../primordials/date");
28
- var import_error = require("../primordials/error");
29
- var import_map_set = require("../primordials/map-set");
30
- var import_internal = require("./_internal");
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_primordials_error = require('../primordials/error.js');
5
+ const require_primordials_map_set = require('../primordials/map-set.js');
6
+ const require_primordials_date = require('../primordials/date.js');
7
+ const require_debug_output = require('../debug/output.js');
8
+ const require_memo__internal = require('./_internal.js');
9
+
10
+ //#region src/memo/memoize.ts
11
+ /**
12
+ * @file `memoize` synchronous function memoizer with LRU eviction (Map
13
+ * insertion-order based), optional TTL, and optional custom key generator.
14
+ * Each instance registers itself with the shared `cacheRegistry` so
15
+ * `clearAllMemoizationCaches` can sweep it.
16
+ */
17
+ /**
18
+ * Memoize a function with configurable caching behavior. Caches function
19
+ * results to avoid repeated computation.
20
+ *
21
+ * @example
22
+ * import { memoize } from '@socketsecurity/lib/memo/memoize'
23
+ *
24
+ * const expensiveOperation = memoize(
25
+ * (n: number) => {
26
+ * // Heavy computation
27
+ * return Array(n)
28
+ * .fill(0)
29
+ * .reduce((a, _, i) => a + i, 0)
30
+ * },
31
+ * { maxSize: 100, ttl: 60000, name: 'sum' },
32
+ * )
33
+ *
34
+ * expensiveOperation(1000) // Computed
35
+ * expensiveOperation(1000) // Cached
36
+ *
37
+ * @param fn - Function to memoize.
38
+ * @param options - Memoization options.
39
+ *
40
+ * @returns Memoized version of the function
41
+ */
31
42
  function memoize(fn, options = {}) {
32
- const {
33
- keyGen = (...args) => (0, import_internal.defaultKeyGen)(args),
34
- maxSize = Number.POSITIVE_INFINITY,
35
- name = fn.name || "anonymous",
36
- ttl = Number.POSITIVE_INFINITY
37
- } = options;
38
- if (ttl < 0) {
39
- throw new import_error.TypeErrorCtor("TTL must be non-negative");
40
- }
41
- const cache = new import_map_set.MapCtor();
42
- import_internal.cacheRegistry.push(() => {
43
- cache.clear();
44
- });
45
- function evictLRU() {
46
- if (cache.size >= maxSize) {
47
- const oldest = cache.keys().next().value;
48
- if (oldest !== void 0) {
49
- cache.delete(oldest);
50
- (0, import_output.debugLog)(`[memoize:${name}] clear`, {
51
- key: oldest,
52
- reason: "LRU"
53
- });
54
- }
55
- }
56
- }
57
- function isExpired(entry) {
58
- if (ttl === Number.POSITIVE_INFINITY) {
59
- return false;
60
- }
61
- return (0, import_date.DateNow)() - entry.timestamp > ttl;
62
- }
63
- return function memoized(...args) {
64
- const key = keyGen(...args);
65
- const cached = cache.get(key);
66
- if (cached) {
67
- if (!isExpired(cached)) {
68
- cached.hits++;
69
- cache.delete(key);
70
- cache.set(key, cached);
71
- (0, import_output.debugLog)(`[memoize:${name}] hit`, { key, hits: cached.hits });
72
- return cached.value;
73
- }
74
- cache.delete(key);
75
- }
76
- (0, import_output.debugLog)(`[memoize:${name}] miss`, { key });
77
- const value = fn(...args);
78
- evictLRU();
79
- cache.set(key, {
80
- value,
81
- timestamp: Date.now(),
82
- hits: 0
83
- });
84
- (0, import_output.debugLog)(`[memoize:${name}] set`, { key, cacheSize: cache.size });
85
- return value;
86
- };
43
+ const { keyGen = (...args) => require_memo__internal.defaultKeyGen(args), maxSize = Number.POSITIVE_INFINITY, name = fn.name || "anonymous", ttl = Number.POSITIVE_INFINITY } = options;
44
+ if (ttl < 0) throw new require_primordials_error.TypeErrorCtor("TTL must be non-negative");
45
+ const cache = new require_primordials_map_set.MapCtor();
46
+ require_memo__internal.cacheRegistry.push(() => {
47
+ cache.clear();
48
+ });
49
+ function evictLRU() {
50
+ if (cache.size >= maxSize) {
51
+ const oldest = cache.keys().next().value;
52
+ /* c8 ignore next 8 - cache.size >= maxSize guarantees keys().next()
53
+ yields a defined value; the undefined branch is defensive. */
54
+ if (oldest !== void 0) {
55
+ cache.delete(oldest);
56
+ require_debug_output.debugLog(`[memoize:${name}] clear`, {
57
+ key: oldest,
58
+ reason: "LRU"
59
+ });
60
+ }
61
+ }
62
+ }
63
+ function isExpired(entry) {
64
+ if (ttl === Number.POSITIVE_INFINITY) return false;
65
+ return require_primordials_date.DateNow() - entry.timestamp > ttl;
66
+ }
67
+ return function memoized(...args) {
68
+ const key = keyGen(...args);
69
+ const cached = cache.get(key);
70
+ if (cached) {
71
+ if (!isExpired(cached)) {
72
+ cached.hits++;
73
+ cache.delete(key);
74
+ cache.set(key, cached);
75
+ require_debug_output.debugLog(`[memoize:${name}] hit`, {
76
+ key,
77
+ hits: cached.hits
78
+ });
79
+ return cached.value;
80
+ }
81
+ cache.delete(key);
82
+ }
83
+ require_debug_output.debugLog(`[memoize:${name}] miss`, { key });
84
+ const value = fn(...args);
85
+ evictLRU();
86
+ cache.set(key, {
87
+ value,
88
+ timestamp: Date.now(),
89
+ hits: 0
90
+ });
91
+ require_debug_output.debugLog(`[memoize:${name}] set`, {
92
+ key,
93
+ cacheSize: cache.size
94
+ });
95
+ return value;
96
+ };
87
97
  }
88
- // Annotate the CommonJS export names for ESM import in node:
89
- 0 && (module.exports = {
90
- memoize
91
- });
98
+
99
+ //#endregion
100
+ exports.memoize = memoize;