@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,130 +1,131 @@
1
1
  "use strict";
2
- /* Socket Lib - Built with esbuild */
3
- "use strict";
4
- var __create = Object.create;
5
- var __defProp = Object.defineProperty;
6
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
7
- var __getOwnPropNames = Object.getOwnPropertyNames;
8
- var __getProtoOf = Object.getPrototypeOf;
9
- var __hasOwnProp = Object.prototype.hasOwnProperty;
10
- var __export = (target, all) => {
11
- for (var name in all)
12
- __defProp(target, name, { get: all[name], enumerable: true });
13
- };
14
- var __copyProps = (to, from, except, desc) => {
15
- if (from && typeof from === "object" || typeof from === "function") {
16
- for (let key of __getOwnPropNames(from))
17
- if (!__hasOwnProp.call(to, key) && key !== except)
18
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
19
- }
20
- return to;
21
- };
22
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
23
- // If the importer is in node compatibility mode or this is not an ESM
24
- // file that has been converted to a CommonJS file using a Babel-
25
- // compatible transform (i.e. "__esModule" has not been set), then set
26
- // "default" to the CommonJS "module.exports" for node compatibility.
27
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
28
- mod
29
- ));
30
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
31
- var find_up_exports = {};
32
- __export(find_up_exports, {
33
- findUp: () => findUp,
34
- findUpSync: () => findUpSync
35
- });
36
- module.exports = __toCommonJS(find_up_exports);
37
- var import_node_process = __toESM(require("node:process"));
38
- var import_predicates = require("../arrays/predicates");
39
- var import_abort = require("../process/abort");
40
- var import_fs = require("../node/fs");
41
- var import_path = require("../node/path");
42
- var import_normalize = require("../paths/normalize");
43
- var import_walk = require("../paths/walk");
44
- var import_path2 = require("../smol/path");
45
- const abortSignal = (0, import_abort.getAbortSignal)();
46
- // @__NO_SIDE_EFFECTS__
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_runtime = require('../_virtual/_rolldown/runtime.js');
5
+ const require_paths_normalize = require('../paths/normalize.js');
6
+ const require_node_fs = require('../node/fs.js');
7
+ const require_node_path = require('../node/path.js');
8
+ const require_process_abort = require('../process/abort.js');
9
+ const require_arrays_predicates = require('../arrays/predicates.js');
10
+ const require_smol_path = require('../smol/path.js');
11
+ const require_paths_walk = require('../paths/walk.js');
12
+ let node_process = require("node:process");
13
+ node_process = require_runtime.__toESM(node_process);
14
+
15
+ //#region src/fs/find-up.ts
16
+ /**
17
+ * @file Walk parent directories to locate a file or directory by name. The
18
+ * traversal includes the filesystem root (or the caller-supplied `stopAt`
19
+ * boundary) — historically the loop exited at `dir === root` _before_
20
+ * visiting root itself, so a match at e.g. `/.foo` was never found. The
21
+ * current shape visits root, then breaks.
22
+ */
23
+ const abortSignal = require_process_abort.getAbortSignal();
24
+ /**
25
+ * Find a file or directory by traversing up parent directories. Searches from
26
+ * the starting directory upward to the filesystem root. Useful for finding
27
+ * configuration files or project roots.
28
+ *
29
+ * @example
30
+ * ;```ts
31
+ * // Find package.json starting from current directory
32
+ * const pkgPath = await findUp('package.json')
33
+ *
34
+ * // Find any of multiple config files
35
+ * const configPath = await findUp(['.config.js', '.config.json'])
36
+ *
37
+ * // Find a directory instead of file
38
+ * const nodeModules = await findUp('node_modules', { onlyDirectories: true })
39
+ * ```
40
+ *
41
+ * @param name - Filename(s) to search for.
42
+ * @param options - Search options including cwd and type filters.
43
+ *
44
+ * @returns Normalized absolute path if found, undefined otherwise
45
+ */
46
+ /* @__NO_SIDE_EFFECTS__ */
47
47
  async function findUp(name, options) {
48
- const { cwd = import_node_process.default.cwd(), signal = abortSignal } = {
49
- __proto__: null,
50
- ...options
51
- };
52
- let { onlyDirectories = false, onlyFiles = true } = {
53
- __proto__: null,
54
- ...options
55
- };
56
- if (onlyDirectories) {
57
- onlyFiles = false;
58
- }
59
- if (onlyFiles) {
60
- onlyDirectories = false;
61
- }
62
- const fs = (0, import_fs.getNodeFs)();
63
- const path = (0, import_path.getNodePath)();
64
- const names = (0, import_predicates.isArray)(name) ? name : [name];
65
- for (const dir of (0, import_walk.walkUp)(cwd)) {
66
- for (const n of names) {
67
- if (signal?.aborted) {
68
- return void 0;
69
- }
70
- const thePath = path.join(dir, n);
71
- try {
72
- const stats = await fs.promises.stat(thePath);
73
- if (!onlyDirectories && stats.isFile()) {
74
- return (0, import_normalize.normalizePath)(thePath);
75
- }
76
- if (!onlyFiles && stats.isDirectory()) {
77
- return (0, import_normalize.normalizePath)(thePath);
78
- }
79
- } catch {
80
- }
81
- }
82
- }
83
- return void 0;
48
+ const { cwd = node_process.default.cwd(), signal = abortSignal } = {
49
+ __proto__: null,
50
+ ...options
51
+ };
52
+ let { onlyDirectories = false, onlyFiles = true } = {
53
+ __proto__: null,
54
+ ...options
55
+ };
56
+ if (onlyDirectories) onlyFiles = false;
57
+ if (onlyFiles) onlyDirectories = false;
58
+ const fs = /* @__PURE__ */ require_node_fs.getNodeFs();
59
+ const path = /* @__PURE__ */ require_node_path.getNodePath();
60
+ const names = require_arrays_predicates.isArray(name) ? name : [name];
61
+ for (const dir of require_paths_walk.walkUp(cwd)) for (const n of names) {
62
+ if (signal?.aborted) return;
63
+ const thePath = path.join(dir, n);
64
+ try {
65
+ const stats = await fs.promises.stat(thePath);
66
+ if (!onlyDirectories && stats.isFile()) return /* @__PURE__ */ require_paths_normalize.normalizePath(thePath);
67
+ if (!onlyFiles && stats.isDirectory()) return /* @__PURE__ */ require_paths_normalize.normalizePath(thePath);
68
+ } catch {}
69
+ }
84
70
  }
85
- // @__NO_SIDE_EFFECTS__
71
+ /**
72
+ * Synchronously find a file or directory by traversing up parent directories.
73
+ * Searches from the starting directory upward to the filesystem root or
74
+ * `stopAt` directory. Useful for finding configuration files or project roots
75
+ * in synchronous contexts.
76
+ *
77
+ * @example
78
+ * ;```ts
79
+ * // Find package.json starting from current directory
80
+ * const pkgPath = findUpSync('package.json')
81
+ *
82
+ * // Find .git directory but stop at home directory
83
+ * const gitPath = findUpSync('.git', {
84
+ * onlyDirectories: true,
85
+ * stopAt: process.env.HOME,
86
+ * })
87
+ *
88
+ * // Find any of multiple config files
89
+ * const configPath = findUpSync(['.eslintrc.js', '.eslintrc.json'])
90
+ * ```
91
+ *
92
+ * @param name - Filename(s) to search for.
93
+ * @param options - Search options including cwd, stopAt, and type filters.
94
+ *
95
+ * @returns Normalized absolute path if found, undefined otherwise
96
+ */
97
+ /* @__NO_SIDE_EFFECTS__ */
86
98
  function findUpSync(name, options) {
87
- const { cwd = import_node_process.default.cwd(), stopAt } = {
88
- __proto__: null,
89
- ...options
90
- };
91
- let { onlyDirectories = false, onlyFiles = true } = {
92
- __proto__: null,
93
- ...options
94
- };
95
- if (onlyDirectories) {
96
- onlyFiles = false;
97
- }
98
- if (onlyFiles) {
99
- onlyDirectories = false;
100
- }
101
- const fs = (0, import_fs.getNodeFs)();
102
- const path = (0, import_path.getNodePath)();
103
- const names = (0, import_predicates.isArray)(name) ? name : [name];
104
- const smolFindUp = (0, import_path2.getSmolPath)()?.findUp;
105
- if (smolFindUp && stopAt === void 0) {
106
- const found = smolFindUp(path.resolve(cwd), names, { onlyDirectories });
107
- return found === void 0 ? void 0 : (0, import_normalize.normalizePath)(found);
108
- }
109
- for (const dir of (0, import_walk.walkUp)(cwd, { stopAt })) {
110
- for (const n of names) {
111
- const thePath = path.join(dir, n);
112
- try {
113
- const stats = fs.statSync(thePath);
114
- if (!onlyDirectories && stats.isFile()) {
115
- return (0, import_normalize.normalizePath)(thePath);
116
- }
117
- if (!onlyFiles && stats.isDirectory()) {
118
- return (0, import_normalize.normalizePath)(thePath);
119
- }
120
- } catch {
121
- }
122
- }
123
- }
124
- return void 0;
99
+ const { cwd = node_process.default.cwd(), stopAt } = {
100
+ __proto__: null,
101
+ ...options
102
+ };
103
+ let { onlyDirectories = false, onlyFiles = true } = {
104
+ __proto__: null,
105
+ ...options
106
+ };
107
+ if (onlyDirectories) onlyFiles = false;
108
+ if (onlyFiles) onlyDirectories = false;
109
+ const fs = /* @__PURE__ */ require_node_fs.getNodeFs();
110
+ const path = /* @__PURE__ */ require_node_path.getNodePath();
111
+ const names = require_arrays_predicates.isArray(name) ? name : [name];
112
+ /* c8 ignore start - native findUp arm only on socket-btm smol binaries; getSmolPath() is undefined on stock Node. */
113
+ const smolFindUp = (/* @__PURE__ */ require_smol_path.getSmolPath())?.findUp;
114
+ if (smolFindUp && stopAt === void 0) {
115
+ const found = smolFindUp(path.resolve(cwd), names, { onlyDirectories });
116
+ return found === void 0 ? void 0 : /* @__PURE__ */ require_paths_normalize.normalizePath(found);
117
+ }
118
+ /* c8 ignore stop */
119
+ for (const dir of require_paths_walk.walkUp(cwd, { stopAt })) for (const n of names) {
120
+ const thePath = path.join(dir, n);
121
+ try {
122
+ const stats = fs.statSync(thePath);
123
+ if (!onlyDirectories && stats.isFile()) return /* @__PURE__ */ require_paths_normalize.normalizePath(thePath);
124
+ if (!onlyFiles && stats.isDirectory()) return /* @__PURE__ */ require_paths_normalize.normalizePath(thePath);
125
+ } catch {}
126
+ }
125
127
  }
126
- // Annotate the CommonJS export names for ESM import in node:
127
- 0 && (module.exports = {
128
- findUp,
129
- findUpSync
130
- });
128
+
129
+ //#endregion
130
+ exports.findUp = findUp;
131
+ exports.findUpSync = findUpSync;
@@ -1,112 +1,181 @@
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 inspect_exports = {};
22
- __export(inspect_exports, {
23
- isDir: () => isDir,
24
- isDirEmptySync: () => isDirEmptySync,
25
- isDirSync: () => isDirSync,
26
- isSymlinkSync: () => isSymlinkSync,
27
- safeStat: () => safeStat,
28
- safeStatSync: () => safeStatSync
29
- });
30
- module.exports = __toCommonJS(inspect_exports);
31
- var import_defaults = require("../globs/defaults");
32
- var import_matcher = require("../globs/matcher");
33
- var import_fs = require("../node/fs");
34
- var import_normalize = require("../paths/normalize");
35
- // @__NO_SIDE_EFFECTS__
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_paths__internal = require('../paths/_internal.js');
5
+ const require_node_fs = require('../node/fs.js');
6
+ const require_globs_defaults = require('../globs/defaults.js');
7
+ const require_globs_matcher = require('../globs/matcher.js');
8
+
9
+ //#region src/fs/inspect.ts
10
+ /**
11
+ * @file Filesystem inspection helpers — `stat` / `lstat` wrappers that return
12
+ * `undefined` instead of throwing, and the directory / symlink / emptiness
13
+ * predicates layered on top. Every entry point catches errors and reduces
14
+ * them to a falsy result; callers that need the underlying error code should
15
+ * use `node:fs` directly.
16
+ */
17
+ /**
18
+ * Check if a path is a directory asynchronously. Returns `true` for
19
+ * directories, `false` for files or non-existent paths.
20
+ *
21
+ * @example
22
+ * ;```ts
23
+ * if (await isDir('./src')) {
24
+ * console.log('src is a directory')
25
+ * }
26
+ * ```
27
+ *
28
+ * @param filepath - Path to check.
29
+ *
30
+ * @returns `true` if path is a directory, `false` otherwise
31
+ */
32
+ /* @__NO_SIDE_EFFECTS__ */
36
33
  async function isDir(filepath) {
37
- return !!(await /* @__PURE__ */ safeStat(filepath))?.isDirectory();
34
+ return !!(await /* @__PURE__ */ safeStat(filepath))?.isDirectory();
38
35
  }
39
- // @__NO_SIDE_EFFECTS__
36
+ /**
37
+ * Check if a directory is empty synchronously. A directory is considered empty
38
+ * if it contains no files after applying ignore patterns. Uses glob patterns to
39
+ * filter ignored files.
40
+ *
41
+ * @example
42
+ * ;```ts
43
+ * // Check if directory is completely empty
44
+ * isDirEmptySync('./build')
45
+ *
46
+ * // Check if directory is empty, ignoring .DS_Store files
47
+ * isDirEmptySync('./cache', { ignore: ['.DS_Store'] })
48
+ * ```
49
+ *
50
+ * @param dirname - Directory path to check.
51
+ * @param options - Options including ignore patterns.
52
+ *
53
+ * @returns `true` if directory is empty (or doesn't exist), `false` otherwise
54
+ */
55
+ /* @__NO_SIDE_EFFECTS__ */
40
56
  function isDirEmptySync(dirname, options) {
41
- const { ignore = import_defaults.defaultIgnore } = {
42
- __proto__: null,
43
- ...options
44
- };
45
- const fs = (0, import_fs.getNodeFs)();
46
- try {
47
- const files = fs.readdirSync(dirname);
48
- const { length } = files;
49
- if (length === 0) {
50
- return true;
51
- }
52
- const matcher = (0, import_matcher.getGlobMatcher)(
53
- ignore,
54
- {
55
- cwd: (0, import_normalize.pathLikeToString)(dirname)
56
- }
57
- );
58
- let ignoredCount = 0;
59
- for (let i = 0; i < length; i += 1) {
60
- const file = files[i];
61
- if (file && matcher(file)) {
62
- ignoredCount += 1;
63
- }
64
- }
65
- return ignoredCount === length;
66
- } catch {
67
- return false;
68
- }
57
+ const { ignore = require_globs_defaults.defaultIgnore } = {
58
+ __proto__: null,
59
+ ...options
60
+ };
61
+ const fs = /* @__PURE__ */ require_node_fs.getNodeFs();
62
+ try {
63
+ const files = fs.readdirSync(dirname);
64
+ const { length } = files;
65
+ if (length === 0) return true;
66
+ const matcher = /* @__PURE__ */ require_globs_matcher.getGlobMatcher(ignore, { cwd: /* @__PURE__ */ require_paths__internal.pathLikeToString(dirname) });
67
+ let ignoredCount = 0;
68
+ for (let i = 0; i < length; i += 1) {
69
+ const file = files[i];
70
+ if (file && matcher(file)) ignoredCount += 1;
71
+ }
72
+ return ignoredCount === length;
73
+ } catch {
74
+ return false;
75
+ }
69
76
  }
70
- // @__NO_SIDE_EFFECTS__
77
+ /**
78
+ * Check if a path is a directory synchronously. Returns `true` for directories,
79
+ * `false` for files or non-existent paths.
80
+ *
81
+ * @example
82
+ * ;```ts
83
+ * if (isDirSync('./src')) {
84
+ * console.log('src is a directory')
85
+ * }
86
+ * ```
87
+ *
88
+ * @param filepath - Path to check.
89
+ *
90
+ * @returns `true` if path is a directory, `false` otherwise
91
+ */
92
+ /* @__NO_SIDE_EFFECTS__ */
71
93
  function isDirSync(filepath) {
72
- return !!(/* @__PURE__ */ safeStatSync(filepath))?.isDirectory();
94
+ return !!(/* @__PURE__ */ safeStatSync(filepath))?.isDirectory();
73
95
  }
74
- // @__NO_SIDE_EFFECTS__
96
+ /**
97
+ * Check if a path is a symbolic link synchronously. Uses `lstat` to check the
98
+ * link itself, not the target.
99
+ *
100
+ * @example
101
+ * ;```ts
102
+ * if (isSymlinkSync('./my-link')) {
103
+ * console.log('Path is a symbolic link')
104
+ * }
105
+ * ```
106
+ *
107
+ * @param filepath - Path to check.
108
+ *
109
+ * @returns `true` if path is a symbolic link, `false` otherwise
110
+ */
111
+ /* @__NO_SIDE_EFFECTS__ */
75
112
  function isSymlinkSync(filepath) {
76
- const fs = (0, import_fs.getNodeFs)();
77
- try {
78
- return fs.lstatSync(filepath).isSymbolicLink();
79
- } catch {
80
- }
81
- return false;
113
+ const fs = /* @__PURE__ */ require_node_fs.getNodeFs();
114
+ try {
115
+ return fs.lstatSync(filepath).isSymbolicLink();
116
+ } catch {}
117
+ return false;
82
118
  }
83
- // @__NO_SIDE_EFFECTS__
119
+ /**
120
+ * Safely get file stats asynchronously, returning undefined on error. Useful
121
+ * for checking file existence and properties without error handling. Returns
122
+ * undefined for any error (file not found, permission denied, etc.).
123
+ *
124
+ * @example
125
+ * ;```ts
126
+ * // Check if file exists and get its stats
127
+ * const stats = await safeStat('./file.txt')
128
+ * if (stats) {
129
+ * console.log('File size:', stats.size)
130
+ * console.log('Modified:', stats.mtime)
131
+ * }
132
+ * ```
133
+ *
134
+ * @param filepath - Path to check.
135
+ *
136
+ * @returns Promise resolving to Stats object, or undefined on error
137
+ */
138
+ /* @__NO_SIDE_EFFECTS__ */
84
139
  async function safeStat(filepath) {
85
- const fs = (0, import_fs.getNodeFs)();
86
- try {
87
- return await fs.promises.stat(filepath);
88
- } catch {
89
- }
90
- return void 0;
140
+ const fs = /* @__PURE__ */ require_node_fs.getNodeFs();
141
+ try {
142
+ return await fs.promises.stat(filepath);
143
+ } catch {}
91
144
  }
92
- // @__NO_SIDE_EFFECTS__
145
+ /**
146
+ * Safely get file stats synchronously, returning undefined on error. Useful for
147
+ * checking file existence and properties without error handling. Returns
148
+ * undefined for any error (file not found, permission denied, etc.).
149
+ *
150
+ * @example
151
+ * ;```ts
152
+ * // Check if file exists and get its size
153
+ * const stats = safeStatSync('./file.txt')
154
+ * if (stats) {
155
+ * console.log('File size:', stats.size)
156
+ * console.log('Is directory:', stats.isDirectory())
157
+ * }
158
+ * ```
159
+ *
160
+ * @param filepath - Path to check.
161
+ *
162
+ * @returns Stats object, or undefined on error
163
+ */
164
+ /* @__NO_SIDE_EFFECTS__ */
93
165
  function safeStatSync(filepath) {
94
- const fs = (0, import_fs.getNodeFs)();
95
- try {
96
- return fs.statSync(filepath, {
97
- __proto__: null,
98
- throwIfNoEntry: false
99
- });
100
- } catch {
101
- }
102
- return void 0;
166
+ const fs = /* @__PURE__ */ require_node_fs.getNodeFs();
167
+ try {
168
+ return fs.statSync(filepath, {
169
+ __proto__: null,
170
+ throwIfNoEntry: false
171
+ });
172
+ } catch {}
103
173
  }
104
- // Annotate the CommonJS export names for ESM import in node:
105
- 0 && (module.exports = {
106
- isDir,
107
- isDirEmptySync,
108
- isDirSync,
109
- isSymlinkSync,
110
- safeStat,
111
- safeStatSync
112
- });
174
+
175
+ //#endregion
176
+ exports.isDir = isDir;
177
+ exports.isDirEmptySync = isDirEmptySync;
178
+ exports.isDirSync = isDirSync;
179
+ exports.isSymlinkSync = isSymlinkSync;
180
+ exports.safeStat = safeStat;
181
+ exports.safeStatSync = safeStatSync;
@@ -1,35 +1,34 @@
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 path_cache_exports = {};
22
- __export(path_cache_exports, {
23
- invalidatePathCache: () => invalidatePathCache
24
- });
25
- module.exports = __toCommonJS(path_cache_exports);
26
- var import_rewire = require("../paths/rewire");
27
- var import_internal = require("./_internal");
2
+ /* Socket Lib - Built with rolldown */
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+ const require_paths_rewire = require('../paths/rewire.js');
5
+ const require_fs__internal = require('./_internal.js');
6
+
7
+ //#region src/fs/path-cache.ts
8
+ /**
9
+ * @file Cache-invalidation entry point for the allowed-directories list used by
10
+ * `safeDelete` / `safeDeleteSync`. Loading this module registers
11
+ * `invalidatePathCache` with `paths/rewire.ts` so test-time path overrides
12
+ * flush the cache; the registration is the module's only side effect, so
13
+ * callers that just need to flush the cache imperatively can call
14
+ * `invalidatePathCache()` directly without that side effect repeating.
15
+ */
16
+ /**
17
+ * Invalidate the cached allowed directories. Called automatically by the
18
+ * paths/rewire module when paths are overridden in tests.
19
+ *
20
+ * @example
21
+ * ;```typescript
22
+ * invalidatePathCache()
23
+ * // Cached allowed directories are now cleared
24
+ * ```
25
+ *
26
+ * @internal Used for test rewiring
27
+ */
28
28
  function invalidatePathCache() {
29
- (0, import_internal.clearAllowedDirectories)();
29
+ require_fs__internal.clearAllowedDirectories();
30
30
  }
31
- (0, import_rewire.registerCacheInvalidation)(invalidatePathCache);
32
- // Annotate the CommonJS export names for ESM import in node:
33
- 0 && (module.exports = {
34
- invalidatePathCache
35
- });
31
+ require_paths_rewire.registerCacheInvalidation(invalidatePathCache);
32
+
33
+ //#endregion
34
+ exports.invalidatePathCache = invalidatePathCache;