@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,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;