bun-types 1.3.2-canary.20251105T140650 → 1.3.2

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 (370) hide show
  1. package/bun.d.ts +102 -6
  2. package/docs/README.md +28 -0
  3. package/docs/bundler/bytecode.mdx +465 -0
  4. package/docs/bundler/{css.md → css.mdx} +97 -101
  5. package/docs/bundler/esbuild.mdx +253 -0
  6. package/docs/bundler/{executables.md → executables.mdx} +130 -221
  7. package/docs/bundler/fullstack.mdx +1064 -0
  8. package/docs/bundler/{hmr.md → hot-reloading.mdx} +74 -79
  9. package/docs/bundler/{html.md → html-static.mdx} +148 -111
  10. package/docs/bundler/index.mdx +1499 -0
  11. package/docs/bundler/loaders.mdx +356 -0
  12. package/docs/bundler/{macros.md → macros.mdx} +83 -84
  13. package/docs/bundler/minifier.mdx +1306 -0
  14. package/docs/bundler/plugins.mdx +411 -0
  15. package/docs/feedback.mdx +85 -0
  16. package/docs/guides/binary/{arraybuffer-to-array.md → arraybuffer-to-array.mdx} +3 -1
  17. package/docs/guides/binary/{arraybuffer-to-blob.md → arraybuffer-to-blob.mdx} +3 -1
  18. package/docs/guides/binary/{arraybuffer-to-buffer.md → arraybuffer-to-buffer.mdx} +3 -1
  19. package/docs/guides/binary/{arraybuffer-to-string.md → arraybuffer-to-string.mdx} +3 -1
  20. package/docs/guides/binary/{arraybuffer-to-typedarray.md → arraybuffer-to-typedarray.mdx} +3 -1
  21. package/docs/guides/binary/{blob-to-arraybuffer.md → blob-to-arraybuffer.mdx} +3 -1
  22. package/docs/guides/binary/{blob-to-dataview.md → blob-to-dataview.mdx} +3 -1
  23. package/docs/guides/binary/{blob-to-stream.md → blob-to-stream.mdx} +3 -1
  24. package/docs/guides/binary/{blob-to-string.md → blob-to-string.mdx} +3 -1
  25. package/docs/guides/binary/{blob-to-typedarray.md → blob-to-typedarray.mdx} +3 -1
  26. package/docs/guides/binary/{buffer-to-arraybuffer.md → buffer-to-arraybuffer.mdx} +3 -1
  27. package/docs/guides/binary/{buffer-to-blob.md → buffer-to-blob.mdx} +3 -1
  28. package/docs/guides/binary/{buffer-to-readablestream.md → buffer-to-readablestream.mdx} +3 -1
  29. package/docs/guides/binary/{buffer-to-string.md → buffer-to-string.mdx} +3 -1
  30. package/docs/guides/binary/{buffer-to-typedarray.md → buffer-to-typedarray.mdx} +3 -1
  31. package/docs/guides/binary/{dataview-to-string.md → dataview-to-string.mdx} +3 -1
  32. package/docs/guides/binary/{typedarray-to-arraybuffer.md → typedarray-to-arraybuffer.mdx} +3 -1
  33. package/docs/guides/binary/{typedarray-to-blob.md → typedarray-to-blob.mdx} +3 -1
  34. package/docs/guides/binary/{typedarray-to-buffer.md → typedarray-to-buffer.mdx} +3 -1
  35. package/docs/guides/binary/{typedarray-to-dataview.md → typedarray-to-dataview.mdx} +3 -1
  36. package/docs/guides/binary/{typedarray-to-readablestream.md → typedarray-to-readablestream.mdx} +3 -1
  37. package/docs/guides/binary/{typedarray-to-string.md → typedarray-to-string.mdx} +3 -1
  38. package/docs/guides/deployment/aws-lambda.mdx +204 -0
  39. package/docs/guides/deployment/digital-ocean.mdx +161 -0
  40. package/docs/guides/deployment/google-cloud-run.mdx +197 -0
  41. package/docs/guides/deployment/{railway.md → railway.mdx} +42 -54
  42. package/docs/guides/deployment/render.mdx +82 -0
  43. package/docs/guides/deployment/vercel.mdx +99 -0
  44. package/docs/guides/ecosystem/{astro.md → astro.mdx} +16 -6
  45. package/docs/guides/ecosystem/{discordjs.md → discordjs.mdx} +21 -18
  46. package/docs/guides/ecosystem/{docker.md → docker.mdx} +25 -14
  47. package/docs/guides/ecosystem/{drizzle.md → drizzle.mdx} +32 -22
  48. package/docs/guides/ecosystem/{edgedb.md → edgedb.mdx} +63 -34
  49. package/docs/guides/ecosystem/{elysia.md → elysia.mdx} +11 -11
  50. package/docs/guides/ecosystem/{express.md → express.mdx} +12 -9
  51. package/docs/guides/ecosystem/{hono.md → hono.mdx} +16 -8
  52. package/docs/guides/ecosystem/{mongoose.md → mongoose.mdx} +26 -21
  53. package/docs/guides/ecosystem/{neon-drizzle.md → neon-drizzle.mdx} +49 -35
  54. package/docs/guides/ecosystem/{neon-serverless-postgres.md → neon-serverless-postgres.mdx} +16 -11
  55. package/docs/guides/ecosystem/{nextjs.md → nextjs.mdx} +18 -10
  56. package/docs/guides/ecosystem/{nuxt.md → nuxt.mdx} +45 -11
  57. package/docs/guides/ecosystem/{pm2.md → pm2.mdx} +7 -9
  58. package/docs/guides/ecosystem/prisma-postgres.mdx +169 -0
  59. package/docs/guides/ecosystem/prisma.mdx +164 -0
  60. package/docs/guides/ecosystem/{qwik.md → qwik.mdx} +18 -11
  61. package/docs/guides/ecosystem/{react.md → react.mdx} +9 -7
  62. package/docs/guides/ecosystem/{remix.md → remix.mdx} +45 -26
  63. package/docs/guides/ecosystem/{sentry.md → sentry.mdx} +7 -5
  64. package/docs/guides/ecosystem/{solidstart.md → solidstart.mdx} +21 -13
  65. package/docs/guides/ecosystem/{ssr-react.md → ssr-react.mdx} +9 -11
  66. package/docs/guides/ecosystem/{stric.md → stric.mdx} +16 -17
  67. package/docs/guides/ecosystem/{sveltekit.md → sveltekit.mdx} +42 -29
  68. package/docs/guides/ecosystem/{systemd.md → systemd.mdx} +27 -26
  69. package/docs/guides/ecosystem/upstash.mdx +87 -0
  70. package/docs/guides/ecosystem/{vite.md → vite.mdx} +20 -14
  71. package/docs/guides/html-rewriter/{extract-links.md → extract-links.mdx} +11 -7
  72. package/docs/guides/html-rewriter/{extract-social-meta.md → extract-social-meta.mdx} +6 -2
  73. package/docs/guides/http/{cluster.md → cluster.mdx} +10 -7
  74. package/docs/guides/http/{fetch-unix.md → fetch-unix.mdx} +5 -3
  75. package/docs/guides/http/{fetch.md → fetch.mdx} +5 -3
  76. package/docs/guides/http/{file-uploads.md → file-uploads.mdx} +18 -15
  77. package/docs/guides/http/{hot.md → hot.mdx} +9 -7
  78. package/docs/guides/http/{proxy.md → proxy.mdx} +7 -5
  79. package/docs/guides/http/{server.md → server.mdx} +4 -2
  80. package/docs/guides/http/{simple.md → simple.mdx} +4 -2
  81. package/docs/guides/http/{stream-file.md → stream-file.mdx} +6 -4
  82. package/docs/guides/http/{stream-iterator.md → stream-iterator.mdx} +5 -3
  83. package/docs/guides/http/{stream-node-streams-in-bun.md → stream-node-streams-in-bun.mdx} +4 -2
  84. package/docs/guides/http/{tls.md → tls.mdx} +5 -3
  85. package/docs/guides/index.mdx +10 -0
  86. package/docs/guides/install/{add-dev.md → add-dev.mdx} +8 -6
  87. package/docs/guides/install/add-git.mdx +38 -0
  88. package/docs/guides/install/{add-optional.md → add-optional.mdx} +7 -5
  89. package/docs/guides/install/{add-peer.md → add-peer.mdx} +13 -11
  90. package/docs/guides/install/{add-tarball.md → add-tarball.mdx} +7 -5
  91. package/docs/guides/install/{add.md → add.mdx} +12 -10
  92. package/docs/guides/install/{azure-artifacts.md → azure-artifacts.mdx} +15 -12
  93. package/docs/guides/{runtime/cicd.md → install/cicd.mdx} +13 -13
  94. package/docs/guides/install/{custom-registry.md → custom-registry.mdx} +6 -4
  95. package/docs/guides/install/{from-npm-install-to-bun-install.md → from-npm-install-to-bun-install.mdx} +50 -34
  96. package/docs/guides/install/{git-diff-bun-lockfile.md → git-diff-bun-lockfile.mdx} +14 -11
  97. package/docs/guides/install/{jfrog-artifactory.md → jfrog-artifactory.mdx} +4 -4
  98. package/docs/guides/install/{npm-alias.md → npm-alias.mdx} +6 -4
  99. package/docs/guides/install/{registry-scope.md → registry-scope.mdx} +6 -4
  100. package/docs/guides/install/{trusted.md → trusted.mdx} +22 -18
  101. package/docs/guides/install/{workspaces.md → workspaces.mdx} +13 -13
  102. package/docs/guides/install/{yarnlock.md → yarnlock.mdx} +15 -9
  103. package/docs/guides/process/{argv.md → argv.mdx} +17 -9
  104. package/docs/guides/process/{ctrl-c.md → ctrl-c.mdx} +4 -2
  105. package/docs/guides/process/{ipc.md → ipc.mdx} +13 -10
  106. package/docs/guides/process/{nanoseconds.md → nanoseconds.mdx} +3 -1
  107. package/docs/guides/process/{os-signals.md → os-signals.mdx} +3 -1
  108. package/docs/guides/process/{spawn-stderr.md → spawn-stderr.mdx} +4 -1
  109. package/docs/guides/process/{spawn-stdout.md → spawn-stdout.mdx} +3 -1
  110. package/docs/guides/process/{spawn.md → spawn.mdx} +3 -1
  111. package/docs/guides/process/{stdin.md → stdin.mdx} +15 -7
  112. package/docs/guides/read-file/{arraybuffer.md → arraybuffer.mdx} +5 -3
  113. package/docs/guides/read-file/{buffer.md → buffer.mdx} +4 -2
  114. package/docs/guides/read-file/{exists.md → exists.mdx} +4 -2
  115. package/docs/guides/read-file/{json.md → json.mdx} +4 -2
  116. package/docs/guides/read-file/{mime.md → mime.mdx} +3 -1
  117. package/docs/guides/read-file/{stream.md → stream.mdx} +3 -1
  118. package/docs/guides/read-file/{string.md → string.mdx} +3 -1
  119. package/docs/guides/read-file/{uint8array.md → uint8array.mdx} +3 -1
  120. package/docs/guides/read-file/{watch.md → watch.mdx} +6 -8
  121. package/docs/guides/runtime/{build-time-constants.md → build-time-constants.mdx} +24 -22
  122. package/docs/guides/{install/cicd.md → runtime/cicd.mdx} +11 -7
  123. package/docs/guides/runtime/{codesign-macos-executable.md → codesign-macos-executable.mdx} +14 -9
  124. package/docs/guides/runtime/{define-constant.md → define-constant.mdx} +20 -16
  125. package/docs/guides/runtime/{delete-directory.md → delete-directory.mdx} +5 -3
  126. package/docs/guides/runtime/{delete-file.md → delete-file.mdx} +4 -2
  127. package/docs/guides/runtime/{heap-snapshot.md → heap-snapshot.mdx} +5 -3
  128. package/docs/guides/runtime/{import-html.md → import-html.mdx} +4 -2
  129. package/docs/guides/runtime/{import-json.md → import-json.mdx} +6 -4
  130. package/docs/guides/runtime/{import-toml.md → import-toml.mdx} +5 -3
  131. package/docs/guides/runtime/{import-yaml.md → import-yaml.mdx} +9 -7
  132. package/docs/guides/runtime/{read-env.md → read-env.mdx} +10 -5
  133. package/docs/guides/runtime/{set-env.md → set-env.mdx} +14 -10
  134. package/docs/guides/runtime/{shell.md → shell.mdx} +6 -4
  135. package/docs/guides/runtime/{timezone.md → timezone.mdx} +10 -7
  136. package/docs/guides/runtime/{tsconfig-paths.md → tsconfig-paths.mdx} +5 -3
  137. package/docs/guides/runtime/{typescript.md → typescript.mdx} +8 -6
  138. package/docs/guides/runtime/{vscode-debugger.md → vscode-debugger.mdx} +12 -11
  139. package/docs/guides/runtime/{web-debugger.md → web-debugger.mdx} +39 -18
  140. package/docs/guides/streams/{node-readable-to-arraybuffer.md → node-readable-to-arraybuffer.mdx} +3 -1
  141. package/docs/guides/streams/{node-readable-to-blob.md → node-readable-to-blob.mdx} +3 -1
  142. package/docs/guides/streams/{node-readable-to-json.md → node-readable-to-json.mdx} +3 -1
  143. package/docs/guides/streams/{node-readable-to-string.md → node-readable-to-string.mdx} +3 -1
  144. package/docs/guides/streams/{node-readable-to-uint8array.md → node-readable-to-uint8array.mdx} +3 -1
  145. package/docs/guides/streams/{to-array.md → to-array.mdx} +3 -1
  146. package/docs/guides/streams/{to-arraybuffer.md → to-arraybuffer.mdx} +3 -1
  147. package/docs/guides/streams/{to-blob.md → to-blob.mdx} +3 -1
  148. package/docs/guides/streams/{to-buffer.md → to-buffer.mdx} +3 -1
  149. package/docs/guides/streams/{to-json.md → to-json.mdx} +4 -2
  150. package/docs/guides/streams/{to-string.md → to-string.mdx} +3 -1
  151. package/docs/guides/streams/{to-typedarray.md → to-typedarray.mdx} +3 -1
  152. package/docs/guides/test/{bail.md → bail.mdx} +7 -5
  153. package/docs/guides/test/{coverage-threshold.md → coverage-threshold.mdx} +14 -7
  154. package/docs/guides/test/{coverage.md → coverage.mdx} +9 -4
  155. package/docs/guides/test/{happy-dom.md → happy-dom.mdx} +13 -8
  156. package/docs/guides/test/{migrate-from-jest.md → migrate-from-jest.mdx} +19 -37
  157. package/docs/guides/test/{mock-clock.md → mock-clock.mdx} +3 -1
  158. package/docs/guides/test/{mock-functions.md → mock-functions.mdx} +7 -5
  159. package/docs/guides/test/{rerun-each.md → rerun-each.mdx} +5 -3
  160. package/docs/guides/test/{run-tests.md → run-tests.mdx} +16 -11
  161. package/docs/guides/test/{skip-tests.md → skip-tests.mdx} +8 -4
  162. package/docs/guides/test/{snapshot.md → snapshot.mdx} +20 -13
  163. package/docs/guides/test/spy-on.mdx +49 -0
  164. package/docs/guides/test/{svelte-test.md → svelte-test.mdx} +16 -23
  165. package/docs/guides/test/{testing-library.md → testing-library.mdx} +18 -17
  166. package/docs/guides/test/{timeout.md → timeout.mdx} +5 -3
  167. package/docs/guides/test/{todo-tests.md → todo-tests.mdx} +13 -6
  168. package/docs/guides/test/{update-snapshots.md → update-snapshots.mdx} +9 -6
  169. package/docs/guides/test/{watch-mode.md → watch-mode.mdx} +9 -4
  170. package/docs/guides/util/{base64.md → base64.mdx} +3 -1
  171. package/docs/guides/util/{deep-equals.md → deep-equals.mdx} +5 -3
  172. package/docs/guides/util/{deflate.md → deflate.mdx} +3 -1
  173. package/docs/guides/util/{detect-bun.md → detect-bun.mdx} +3 -1
  174. package/docs/guides/util/{entrypoint.md → entrypoint.mdx} +4 -2
  175. package/docs/guides/util/{escape-html.md → escape-html.mdx} +3 -1
  176. package/docs/guides/util/{file-url-to-path.md → file-url-to-path.mdx} +3 -1
  177. package/docs/guides/util/{gzip.md → gzip.mdx} +3 -1
  178. package/docs/guides/util/{hash-a-password.md → hash-a-password.mdx} +3 -1
  179. package/docs/guides/util/{import-meta-dir.md → import-meta-dir.mdx} +4 -2
  180. package/docs/guides/util/{import-meta-file.md → import-meta-file.mdx} +4 -2
  181. package/docs/guides/util/{import-meta-path.md → import-meta-path.mdx} +4 -2
  182. package/docs/guides/util/{javascript-uuid.md → javascript-uuid.mdx} +3 -1
  183. package/docs/guides/util/{main.md → main.mdx} +19 -8
  184. package/docs/guides/util/{path-to-file-url.md → path-to-file-url.mdx} +3 -1
  185. package/docs/guides/util/{sleep.md → sleep.mdx} +3 -1
  186. package/docs/guides/util/{version.md → version.mdx} +6 -4
  187. package/docs/guides/util/{which-path-to-executable-bin.md → which-path-to-executable-bin.mdx} +4 -2
  188. package/docs/guides/websocket/{compression.md → compression.mdx} +5 -3
  189. package/docs/guides/websocket/{context.md → context.mdx} +9 -12
  190. package/docs/guides/websocket/{pubsub.md → pubsub.mdx} +5 -6
  191. package/docs/guides/websocket/{simple.md → simple.mdx} +5 -3
  192. package/docs/guides/write-file/{append.md → append.mdx} +3 -1
  193. package/docs/guides/write-file/{basic.md → basic.mdx} +3 -1
  194. package/docs/guides/write-file/{blob.md → blob.mdx} +3 -1
  195. package/docs/guides/write-file/{cat.md → cat.mdx} +4 -2
  196. package/docs/guides/write-file/{file-cp.md → file-cp.mdx} +3 -1
  197. package/docs/guides/write-file/{filesink.md → filesink.mdx} +3 -1
  198. package/docs/guides/write-file/{response.md → response.mdx} +3 -1
  199. package/docs/guides/write-file/{stdout.md → stdout.mdx} +3 -1
  200. package/docs/guides/write-file/{stream.md → stream.mdx} +3 -1
  201. package/docs/guides/write-file/{unlink.md → unlink.mdx} +3 -1
  202. package/docs/{index.md → index.mdx} +97 -41
  203. package/docs/installation.mdx +365 -0
  204. package/docs/{cli/bunx.md → pm/bunx.mdx} +25 -31
  205. package/docs/{install/catalogs.md → pm/catalogs.mdx} +18 -24
  206. package/docs/{cli/add.md → pm/cli/add.mdx} +61 -55
  207. package/docs/{install/audit.md → pm/cli/audit.mdx} +11 -8
  208. package/docs/{cli/install.md → pm/cli/install.mdx} +208 -81
  209. package/docs/{cli/link.md → pm/cli/link.mdx} +27 -19
  210. package/docs/{cli/outdated.md → pm/cli/outdated.mdx} +119 -12
  211. package/docs/{install/patch.md → pm/cli/patch.mdx} +25 -15
  212. package/docs/{cli/pm.md → pm/cli/pm.mdx} +96 -62
  213. package/docs/{cli/publish.md → pm/cli/publish.mdx} +38 -35
  214. package/docs/pm/cli/remove.mdx +16 -0
  215. package/docs/{cli/update.md → pm/cli/update.mdx} +26 -15
  216. package/docs/{cli/why.md → pm/cli/why.mdx} +27 -10
  217. package/docs/{cli/filter.md → pm/filter.mdx} +26 -14
  218. package/docs/{install/cache.md → pm/global-cache.mdx} +25 -12
  219. package/docs/{install/isolated.md → pm/isolated-installs.mdx} +32 -24
  220. package/docs/{install/lifecycle.md → pm/lifecycle.mdx} +20 -9
  221. package/docs/{install/lockfile.md → pm/lockfile.mdx} +18 -12
  222. package/docs/{install/npmrc.md → pm/npmrc.mdx} +30 -24
  223. package/docs/{install/overrides.md → pm/overrides.mdx} +47 -37
  224. package/docs/{install/registries.md → pm/scopes-registries.mdx} +8 -3
  225. package/docs/{install/security-scanner-api.md → pm/security-scanner-api.mdx} +22 -8
  226. package/docs/{install/workspaces.md → pm/workspaces.mdx} +17 -22
  227. package/docs/project/{benchmarking.md → benchmarking.mdx} +26 -11
  228. package/docs/project/{bindgen.md → bindgen.mdx} +12 -14
  229. package/docs/project/{building-windows.md → building-windows.mdx} +18 -47
  230. package/docs/project/{contributing.md → contributing.mdx} +56 -60
  231. package/docs/project/feedback.mdx +20 -0
  232. package/docs/project/license.mdx +78 -0
  233. package/docs/project/roadmap.mdx +8 -0
  234. package/docs/quickstart.mdx +240 -0
  235. package/docs/runtime/{autoimport.md → auto-install.mdx} +34 -31
  236. package/docs/{api/binary-data.md → runtime/binary-data.mdx} +77 -269
  237. package/docs/runtime/bun-apis.mdx +59 -0
  238. package/docs/runtime/{bunfig.md → bunfig.mdx} +95 -225
  239. package/docs/{api/cc.md → runtime/c-compiler.mdx} +16 -9
  240. package/docs/{api/spawn.md → runtime/child-process.mdx} +69 -119
  241. package/docs/{api/color.md → runtime/color.mdx} +6 -1
  242. package/docs/{api/console.md → runtime/console.mdx} +17 -7
  243. package/docs/{api/cookie.md → runtime/cookies.mdx} +24 -19
  244. package/docs/runtime/{debugger.md → debugger.mdx} +61 -51
  245. package/docs/runtime/environment-variables.mdx +214 -0
  246. package/docs/{api/ffi.md → runtime/ffi.mdx} +53 -45
  247. package/docs/{api/file-io.md → runtime/file-io.mdx} +41 -101
  248. package/docs/{api/file-system-router.md → runtime/file-system-router.mdx} +8 -2
  249. package/docs/{bundler/loaders.md → runtime/file-types.mdx} +56 -112
  250. package/docs/{api/glob.md → runtime/glob.mdx} +4 -1
  251. package/docs/runtime/globals.mdx +72 -0
  252. package/docs/{api/hashing.md → runtime/hashing.mdx} +18 -22
  253. package/docs/{api/html-rewriter.md → runtime/html-rewriter.mdx} +36 -30
  254. package/docs/runtime/http/cookies.mdx +79 -0
  255. package/docs/runtime/http/error-handling.mdx +40 -0
  256. package/docs/runtime/http/metrics.mdx +36 -0
  257. package/docs/runtime/http/routing.mdx +289 -0
  258. package/docs/runtime/http/server.mdx +647 -0
  259. package/docs/runtime/http/tls.mdx +101 -0
  260. package/docs/{api/websockets.md → runtime/http/websockets.mdx} +62 -231
  261. package/docs/{cli/run.md → runtime/index.mdx} +70 -108
  262. package/docs/runtime/jsx.mdx +115 -0
  263. package/docs/runtime/{modules.md → module-resolution.mdx} +83 -61
  264. package/docs/{api/dns.md → runtime/networking/dns.mdx} +23 -22
  265. package/docs/{api/fetch.md → runtime/networking/fetch.mdx} +10 -5
  266. package/docs/{api/tcp.md → runtime/networking/tcp.mdx} +59 -41
  267. package/docs/{api/udp.md → runtime/networking/udp.mdx} +14 -8
  268. package/docs/{api/node-api.md → runtime/node-api.mdx} +5 -0
  269. package/docs/runtime/{nodejs-apis.md → nodejs-compat.mdx} +9 -4
  270. package/docs/{bundler/plugins.md → runtime/plugins.mdx} +17 -61
  271. package/docs/{api/redis.md → runtime/redis.mdx} +65 -80
  272. package/docs/{api/s3.md → runtime/s3.mdx} +79 -66
  273. package/docs/{api/secrets.md → runtime/secrets.mdx} +27 -10
  274. package/docs/{api/semver.md → runtime/semver.mdx} +9 -4
  275. package/docs/runtime/{shell.md → shell.mdx} +52 -20
  276. package/docs/{api/sql.md → runtime/sql.mdx} +129 -99
  277. package/docs/{api/sqlite.md → runtime/sqlite.mdx} +162 -157
  278. package/docs/{api/streams.md → runtime/streams.mdx} +33 -31
  279. package/docs/{cli/bun-create.md → runtime/templating/create.mdx} +74 -143
  280. package/docs/{cli/init.md → runtime/templating/init.mdx} +24 -51
  281. package/docs/{api/transpiler.md → runtime/transpiler.mdx} +50 -38
  282. package/docs/{typescript.md → runtime/typescript.mdx} +7 -2
  283. package/docs/{api/utils.md → runtime/utils.mdx} +81 -50
  284. package/docs/runtime/{hot.md → watch-mode.mdx} +53 -37
  285. package/docs/runtime/web-apis.mdx +29 -0
  286. package/docs/{api/workers.md → runtime/workers.mdx} +28 -22
  287. package/docs/{api/yaml.md → runtime/yaml.mdx} +33 -232
  288. package/docs/snippets/cli/add.mdx +166 -0
  289. package/docs/snippets/cli/build.mdx +196 -0
  290. package/docs/snippets/cli/feedback.mdx +17 -0
  291. package/docs/snippets/cli/init.mdx +84 -0
  292. package/docs/snippets/cli/install.mdx +173 -0
  293. package/docs/snippets/cli/link.mdx +163 -0
  294. package/docs/snippets/cli/outdated.mdx +140 -0
  295. package/docs/snippets/cli/patch.mdx +171 -0
  296. package/docs/snippets/cli/publish.mdx +198 -0
  297. package/docs/snippets/cli/remove.mdx +146 -0
  298. package/docs/snippets/cli/run.mdx +293 -0
  299. package/docs/snippets/cli/test.mdx +100 -0
  300. package/docs/snippets/cli/update.mdx +144 -0
  301. package/docs/snippets/product-card.mdx +32 -0
  302. package/docs/snippets/product-tiles.mdx +94 -0
  303. package/docs/test/code-coverage.mdx +409 -0
  304. package/docs/test/configuration.mdx +467 -0
  305. package/docs/test/{time.md → dates-times.mdx} +23 -20
  306. package/docs/test/{discovery.md → discovery.mdx} +15 -10
  307. package/docs/test/dom.mdx +226 -0
  308. package/docs/{cli/test.md → test/index.mdx} +77 -94
  309. package/docs/test/lifecycle.mdx +348 -0
  310. package/docs/test/mocks.mdx +637 -0
  311. package/docs/test/{reporters.md → reporters.mdx} +15 -15
  312. package/docs/test/runtime-behavior.mdx +342 -0
  313. package/docs/test/snapshots.mdx +434 -0
  314. package/docs/test/writing-tests.mdx +635 -0
  315. package/docs/typescript.mdx +54 -0
  316. package/package.json +8 -6
  317. package/test.d.ts +2 -2
  318. package/docs/api/file.md +0 -19
  319. package/docs/api/globals.md +0 -387
  320. package/docs/api/http.md +0 -1408
  321. package/docs/api/import-meta.md +0 -69
  322. package/docs/benchmarks.md +0 -120
  323. package/docs/bun-flavored-toml.md +0 -42
  324. package/docs/bundler/css_modules.md +0 -145
  325. package/docs/bundler/fullstack.md +0 -418
  326. package/docs/bundler/index.md +0 -1735
  327. package/docs/bundler/intro.md +0 -75
  328. package/docs/bundler/vs-esbuild.md +0 -1127
  329. package/docs/cli/bun-completions.md +0 -3
  330. package/docs/cli/bun-install.md +0 -349
  331. package/docs/cli/bun-upgrade.md +0 -39
  332. package/docs/cli/info.md +0 -65
  333. package/docs/cli/patch-commit.md +0 -11
  334. package/docs/cli/remove.md +0 -7
  335. package/docs/cli/unlink.md +0 -9
  336. package/docs/contributing/upgrading-webkit.md +0 -57
  337. package/docs/ecosystem/elysia.md +0 -24
  338. package/docs/ecosystem/express.md +0 -37
  339. package/docs/ecosystem/hono.md +0 -18
  340. package/docs/ecosystem/react.md +0 -65
  341. package/docs/ecosystem/stric.md +0 -38
  342. package/docs/guides/ecosystem/prisma.md +0 -141
  343. package/docs/guides/ecosystem/render.md +0 -79
  344. package/docs/guides/install/add-git.md +0 -36
  345. package/docs/guides/test/spy-on.md +0 -46
  346. package/docs/install/index.md +0 -248
  347. package/docs/installation.md +0 -327
  348. package/docs/project/asan.md +0 -124
  349. package/docs/project/internals/build-process-for-ci.md +0 -75
  350. package/docs/project/licensing.md +0 -73
  351. package/docs/project/roadmap.md +0 -87
  352. package/docs/quickstart.md +0 -157
  353. package/docs/runtime/bun-apis.md +0 -207
  354. package/docs/runtime/env.md +0 -253
  355. package/docs/runtime/index.md +0 -312
  356. package/docs/runtime/jsx.md +0 -385
  357. package/docs/runtime/loaders.md +0 -130
  358. package/docs/runtime/plugins.md +0 -561
  359. package/docs/runtime/typescript.md +0 -139
  360. package/docs/runtime/web-apis.md +0 -128
  361. package/docs/test/configuration.md +0 -154
  362. package/docs/test/coverage.md +0 -142
  363. package/docs/test/dom.md +0 -75
  364. package/docs/test/examples/concurrent-test-glob.md +0 -132
  365. package/docs/test/hot.md +0 -15
  366. package/docs/test/lifecycle.md +0 -81
  367. package/docs/test/mocks.md +0 -313
  368. package/docs/test/runtime-behavior.md +0 -95
  369. package/docs/test/snapshots.md +0 -68
  370. package/docs/test/writing.md +0 -825
@@ -1,13 +1,15 @@
1
1
  ---
2
- name: Proxy HTTP requests using fetch()
2
+ title: Proxy HTTP requests using fetch()
3
+ sidebarTitle: Proxy HTTP requests using fetch()
4
+ mode: center
3
5
  ---
4
6
 
5
7
  In Bun, `fetch` supports sending requests through an HTTP or HTTPS proxy. This is useful on corporate networks or when you need to ensure a request is sent through a specific IP address.
6
8
 
7
- ```ts
9
+ ```ts proxy.ts icon="/icons/typescript.svg"
8
10
  await fetch("https://example.com", {
9
11
  // The URL of the proxy server
10
- proxy: "https://username:password@proxy.example.com:8080",
12
+ proxy: "https://usertitle:password@proxy.example.com:8080",
11
13
  });
12
14
  ```
13
15
 
@@ -19,6 +21,6 @@ The `proxy` option is a URL string that specifies the proxy server. It can inclu
19
21
 
20
22
  You can also set the `$HTTP_PROXY` or `$HTTPS_PROXY` environment variable to the proxy URL. This is useful when you want to use the same proxy for all requests.
21
23
 
22
- ```sh
23
- HTTPS_PROXY=https://username:password@proxy.example.com:8080 bun run index.ts
24
+ ```sh terminal icon="terminal"
25
+ HTTPS_PROXY=https://usertitle:password@proxy.example.com:8080 bun run index.ts
24
26
  ```
@@ -1,12 +1,14 @@
1
1
  ---
2
- name: Common HTTP server usage
2
+ title: Common HTTP server usage
3
+ sidebarTitle: HTTP Server with Bun
4
+ mode: center
3
5
  ---
4
6
 
5
7
  This starts an HTTP server listening on port `3000`. It demonstrates basic routing with a number of common responses and also handles POST data from standard forms or as JSON.
6
8
 
7
9
  See [`Bun.serve`](https://bun.com/docs/api/http) for details.
8
10
 
9
- ```ts
11
+ ```ts server.ts icon="/icons/typescript.svg"
10
12
  const server = Bun.serve({
11
13
  async fetch(req) {
12
14
  const path = new URL(req.url).pathname;
@@ -1,12 +1,14 @@
1
1
  ---
2
- name: Write a simple HTTP server
2
+ title: Write a simple HTTP server
3
+ sidebarTitle: Simple HTTP Server with Bun
4
+ mode: center
3
5
  ---
4
6
 
5
7
  This starts an HTTP server listening on port `3000`. It responds to all requests with a `Response` with status `200` and body `"Welcome to Bun!"`.
6
8
 
7
9
  See [`Bun.serve`](https://bun.com/docs/api/http) for details.
8
10
 
9
- ```ts
11
+ ```ts server.ts icon="/icons/typescript.svg"
10
12
  const server = Bun.serve({
11
13
  port: 3000,
12
14
  fetch(request) {
@@ -1,10 +1,12 @@
1
1
  ---
2
- name: Stream a file as an HTTP Response
2
+ title: Stream a file as an HTTP Response
3
+ sidebarTitle: Stream file response
4
+ mode: center
3
5
  ---
4
6
 
5
7
  This snippet reads a file from disk using [`Bun.file()`](https://bun.com/docs/api/file-io#reading-files-bun-file). This returns a `BunFile` instance, which can be passed directly into the `new Response` constructor.
6
8
 
7
- ```ts
9
+ ```ts server.ts icon="/icons/typescript.svg"
8
10
  const path = "/path/to/file.txt";
9
11
  const file = Bun.file(path);
10
12
  const resp = new Response(file);
@@ -14,7 +16,7 @@ const resp = new Response(file);
14
16
 
15
17
  The `Content-Type` is read from the file and automatically set on the `Response`.
16
18
 
17
- ```ts
19
+ ```ts server.ts icon="/icons/typescript.svg"
18
20
  new Response(Bun.file("./package.json")).headers.get("Content-Type");
19
21
  // => application/json;charset=utf-8
20
22
 
@@ -32,7 +34,7 @@ new Response(Bun.file("./img.png")).headers.get("Content-Type");
32
34
 
33
35
  Putting it all together with [`Bun.serve()`](https://bun.com/docs/api/http#bun-serve).
34
36
 
35
- ```ts
37
+ ```ts server.ts icon="/icons/typescript.svg"
36
38
  // static file server
37
39
  Bun.serve({
38
40
  async fetch(req) {
@@ -1,10 +1,12 @@
1
1
  ---
2
- name: Streaming HTTP Server with Async Iterators
2
+ title: Streaming HTTP Server with Async Iterators
3
+ sidebarTitle: Stream with iterators
4
+ mode: center
3
5
  ---
4
6
 
5
7
  In Bun, [`Response`](https://developer.mozilla.org/en-US/docs/Web/API/Response) objects can accept an async generator function as their body. This allows you to stream data to the client as it becomes available, rather than waiting for the entire response to be ready.
6
8
 
7
- ```ts
9
+ ```ts stream-iterator.ts icon="/icons/typescript.svg"
8
10
  Bun.serve({
9
11
  port: 3000,
10
12
  fetch(req) {
@@ -28,7 +30,7 @@ Bun.serve({
28
30
 
29
31
  You can pass any async iterable directly to `Response`:
30
32
 
31
- ```ts
33
+ ```ts stream-iterator.ts icon="/icons/typescript.svg"
32
34
  Bun.serve({
33
35
  port: 3000,
34
36
  fetch(req) {
@@ -1,12 +1,14 @@
1
1
  ---
2
- name: Streaming HTTP Server with Node.js Streams
2
+ title: Streaming HTTP Server with Node.js Streams
3
+ sidebarTitle: Stream with Node.js
4
+ mode: center
3
5
  ---
4
6
 
5
7
  In Bun, [`Response`](https://developer.mozilla.org/en-US/docs/Web/API/Response) objects can accept a Node.js [`Readable`](https://nodejs.org/api/stream.html#stream_readable_streams).
6
8
 
7
9
  This works because Bun's `Response` object allows any async iterable as its body. Node.js streams are async iterables, so you can pass them directly to `Response`.
8
10
 
9
- ```ts
11
+ ```ts server.ts icon="/icons/typescript.svg"
10
12
  import { Readable } from "stream";
11
13
  import { serve } from "bun";
12
14
  serve({
@@ -1,10 +1,12 @@
1
1
  ---
2
- name: Configure TLS on an HTTP server
2
+ title: Configure TLS on an HTTP server
3
+ sidebarTitle: Configure TLS
4
+ mode: center
3
5
  ---
4
6
 
5
7
  Set the `tls` key to configure TLS. Both `key` and `cert` are required. The `key` should be the contents of your private key; `cert` should be the contents of your issued certificate. Use [`Bun.file()`](https://bun.com/docs/api/file-io#reading-files-bun-file) to read the contents.
6
8
 
7
- ```ts
9
+ ```ts server.ts icon="/icons/typescript.svg"
8
10
  const server = Bun.serve({
9
11
  fetch: request => new Response("Welcome to Bun!"),
10
12
  tls: {
@@ -18,7 +20,7 @@ const server = Bun.serve({
18
20
 
19
21
  By default Bun trusts the default Mozilla-curated list of well-known root CAs. To override this list, pass an array of certificates as `ca`.
20
22
 
21
- ```ts
23
+ ```ts server.ts icon="/icons/typescript.svg"
22
24
  const server = Bun.serve({
23
25
  fetch: request => new Response("Welcome to Bun!"),
24
26
  tls: {
@@ -0,0 +1,10 @@
1
+ ---
2
+ title: Guides
3
+ description: A collection of code samples and walkthroughs for performing common tasks with Bun.
4
+ contextual: false
5
+ mode: center
6
+ ---
7
+
8
+ import { GuidesList } from "/snippets/guides.jsx";
9
+
10
+ <GuidesList />
@@ -1,22 +1,24 @@
1
1
  ---
2
- name: Add a development dependency
2
+ title: Add a development dependency
3
+ sidebarTitle: Add a dev dependency
4
+ mode: center
3
5
  ---
4
6
 
5
7
  To add an npm package as a development dependency, use `bun add --development`.
6
8
 
7
- ```sh
8
- $ bun add zod --dev
9
- $ bun add zod -d # shorthand
9
+ ```sh terminal icon="terminal"
10
+ bun add zod --dev
11
+ bun add zod -d # shorthand
10
12
  ```
11
13
 
12
14
  ---
13
15
 
14
16
  This will add the package to `devDependencies` in `package.json`.
15
17
 
16
- ```json-diff
18
+ ```json
17
19
  {
18
20
  "devDependencies": {
19
- + "zod": "^3.0.0"
21
+ "zod": "^3.0.0" // [!code ++]
20
22
  }
21
23
  }
22
24
  ```
@@ -0,0 +1,38 @@
1
+ ---
2
+ title: Add a Git dependency
3
+ sidebarTitle: Add a Git dependency
4
+ mode: center
5
+ ---
6
+
7
+ Bun supports directly adding GitHub repositories as dependencies of your project.
8
+
9
+ ```sh terminal icon="terminal"
10
+ bun add github:lodash/lodash
11
+ ```
12
+
13
+ ---
14
+
15
+ This will add the following line to your `package.json`:
16
+
17
+ ```json package.json icon="file-json"
18
+ {
19
+ "dependencies": {
20
+ "lodash": "github:lodash/lodash"
21
+ }
22
+ }
23
+ ```
24
+
25
+ ---
26
+
27
+ Bun supports a number of protocols for specifying Git dependencies.
28
+
29
+ ```sh terminal icon="terminal"
30
+ bun add git+https://github.com/lodash/lodash.git
31
+ bun add git+ssh://github.com/lodash/lodash.git#4.17.21
32
+ bun add git@github.com:lodash/lodash.git
33
+ bun add github:colinhacks/zod
34
+ ```
35
+
36
+ ---
37
+
38
+ See [Docs > Package manager](https://bun.com/docs/cli/install) for complete documentation of Bun's package manager.
@@ -1,21 +1,23 @@
1
1
  ---
2
- name: Add an optional dependency
2
+ title: Add an optional dependency
3
+ sidebarTitle: Add an optional dependency
4
+ mode: center
3
5
  ---
4
6
 
5
7
  To add an npm package as an optional dependency, use the `--optional` flag.
6
8
 
7
- ```sh
8
- $ bun add zod --optional
9
+ ```sh terminal icon="terminal"
10
+ bun add zod --optional
9
11
  ```
10
12
 
11
13
  ---
12
14
 
13
15
  This will add the package to `optionalDependencies` in `package.json`.
14
16
 
15
- ```json-diff
17
+ ```json package.json icon="file-json"
16
18
  {
17
19
  "optionalDependencies": {
18
- + "zod": "^3.0.0"
20
+ "zod": "^3.0.0" // [!code ++]
19
21
  }
20
22
  }
21
23
  ```
@@ -1,21 +1,23 @@
1
1
  ---
2
- name: Add a peer dependency
2
+ title: Add a peer dependency
3
+ sidebarTitle: Add a peer dependency
4
+ mode: center
3
5
  ---
4
6
 
5
7
  To add an npm package as a peer dependency, use the `--peer` flag.
6
8
 
7
- ```sh
8
- $ bun add @types/bun --peer
9
+ ```sh terminal icon="terminal"
10
+ bun add @types/bun --peer
9
11
  ```
10
12
 
11
13
  ---
12
14
 
13
15
  This will add the package to `peerDependencies` in `package.json`.
14
16
 
15
- ```json-diff
17
+ ```json package.json icon="file-json"
16
18
  {
17
19
  "peerDependencies": {
18
- + "@types/bun": "^1.3.2-canary.20251105T140650"
20
+ "@types/bun": "^1.3.1" // [!code ++]
19
21
  }
20
22
  }
21
23
  ```
@@ -24,17 +26,17 @@ This will add the package to `peerDependencies` in `package.json`.
24
26
 
25
27
  Running `bun install` will install peer dependencies by default, unless marked optional in `peerDependenciesMeta`.
26
28
 
27
- ```json-diff
29
+ ```json package.json icon="file-json"
28
30
  {
29
31
  "peerDependencies": {
30
- "@types/bun": "^1.3.2-canary.20251105T140650"
32
+ "@types/bun": "^1.3.1"
31
33
  },
32
34
  "peerDependenciesMeta": {
33
- + "@types/bun": {
34
- + "optional": true
35
- + }
35
+ "@types/bun": {
36
+ // [!code ++]
37
+ "optional": true // [!code ++]
38
+ } // [!code ++]
36
39
  }
37
-
38
40
  }
39
41
  ```
40
42
 
@@ -1,21 +1,23 @@
1
1
  ---
2
- name: Add a tarball dependency
2
+ title: Add a tarball dependency
3
+ sidebarTitle: Add a tarball dependency
4
+ mode: center
3
5
  ---
4
6
 
5
7
  Bun's package manager can install any publicly available tarball URL as a dependency of your project.
6
8
 
7
- ```sh
8
- $ bun add zod@https://registry.npmjs.org/zod/-/zod-3.21.4.tgz
9
+ ```sh terminal icon="terminal"
10
+ bun add zod@https://registry.npmjs.org/zod/-/zod-3.21.4.tgz
9
11
  ```
10
12
 
11
13
  ---
12
14
 
13
15
  Running this command will download, extract, and install the tarball to your project's `node_modules` directory. It will also add the following line to your `package.json`:
14
16
 
15
- ```json-diff#package.json
17
+ ```json package.json icon="file-json"
16
18
  {
17
19
  "dependencies": {
18
- + "zod": "https://registry.npmjs.org/zod/-/zod-3.21.4.tgz"
20
+ "zod": "https://registry.npmjs.org/zod/-/zod-3.21.4.tgz" // [!code ++]
19
21
  }
20
22
  }
21
23
  ```
@@ -1,21 +1,23 @@
1
1
  ---
2
- name: Add a dependency
2
+ title: Add a dependency
3
+ sidebarTitle: Add a dependency
4
+ mode: center
3
5
  ---
4
6
 
5
7
  To add an npm package as a dependency, use `bun add`.
6
8
 
7
- ```sh
8
- $ bun add zod
9
+ ```sh terminal icon="terminal"
10
+ bun add zod
9
11
  ```
10
12
 
11
13
  ---
12
14
 
13
15
  This will add the package to `dependencies` in `package.json`. By default, the `^` range specifier will be used, to indicate that any future minor or patch versions are acceptable.
14
16
 
15
- ```json-diff
17
+ ```json package.json icon="file-json"
16
18
  {
17
19
  "dependencies": {
18
- + "zod": "^3.0.0"
20
+ "zod": "^3.0.0" // [!code ++]
19
21
  }
20
22
  }
21
23
  ```
@@ -24,17 +26,17 @@ This will add the package to `dependencies` in `package.json`. By default, the `
24
26
 
25
27
  To "pin" to an exact version of the package, use `--exact`. This will add the package to `dependencies` without the `^`, pinning your project to the exact version you installed.
26
28
 
27
- ```sh
28
- $ bun add zod --exact
29
+ ```sh terminal icon="terminal"
30
+ bun add zod --exact
29
31
  ```
30
32
 
31
33
  ---
32
34
 
33
35
  To specify an exact version or a tag:
34
36
 
35
- ```sh
36
- $ bun add zod@3.0.0
37
- $ bun add zod@next
37
+ ```sh terminal icon="terminal"
38
+ bun add zod@3.0.0
39
+ bun add zod@next
38
40
  ```
39
41
 
40
42
  ---
@@ -1,10 +1,15 @@
1
1
  ---
2
- name: Using bun install with an Azure Artifacts npm registry
2
+ title: Using bun install with an Azure Artifacts npm registry
3
+ sidebarTitle: Azure Artifacts with Bun
4
+ mode: center
3
5
  ---
4
6
 
5
- {% callout %}
6
- In [Azure Artifact's](https://learn.microsoft.com/en-us/azure/devops/artifacts/npm/npmrc?view=azure-devops&tabs=windows%2Cclassic) instructions for `.npmrc`, they say to base64 encode the password. Do not do this for `bun install`. Bun will automatically base64 encode the password for you if needed.
7
- {% /callout %}
7
+ <Note>
8
+ In [Azure
9
+ Artifact's](https://learn.microsoft.com/en-us/azure/devops/artifacts/npm/npmrc?view=azure-devops&tabs=windows%2Cclassic)
10
+ instructions for `.npmrc`, they say to base64 encode the password. Do not do this for `bun install`. Bun will
11
+ automatically base64 encode the password for you if needed.
12
+ </Note>
8
13
 
9
14
  [Azure Artifacts](https://azure.microsoft.com/en-us/products/devops/artifacts) is a package management system for Azure DevOps. It allows you to host your own private npm registry, npm packages, and other types of packages as well.
10
15
 
@@ -16,7 +21,7 @@ In [Azure Artifact's](https://learn.microsoft.com/en-us/azure/devops/artifacts/n
16
21
 
17
22
  To use it with `bun install`, add a `bunfig.toml` file to your project with the following contents. Make sure to replace `my-azure-artifacts-user` with your Azure Artifacts username, such as `jarred1234`.
18
23
 
19
- ```toml#bunfig.toml
24
+ ```toml bunfig.toml icon="settings"
20
25
  [install.registry]
21
26
  url = "https://pkgs.dev.azure.com/my-azure-artifacts-user/_packaging/my-azure-artifacts-user/npm/registry"
22
27
  username = "my-azure-artifacts-user"
@@ -28,7 +33,7 @@ password = "$NPM_PASSWORD"
28
33
 
29
34
  Then assign your Azure Personal Access Token to the `NPM_PASSWORD` environment variable. Bun [automatically reads](https://bun.com/docs/runtime/env) `.env` files, so create a file called `.env` in your project root. There is no need to base-64 encode this token! Bun will do this for you.
30
35
 
31
- ```txt#.env
36
+ ```txt .env icon="settings"
32
37
  NPM_PASSWORD=<paste token here>
33
38
  ```
34
39
 
@@ -40,7 +45,7 @@ NPM_PASSWORD=<paste token here>
40
45
 
41
46
  To configure Azure Artifacts without `bunfig.toml`, you can set the `NPM_CONFIG_REGISTRY` environment variable. The URL should include `:username` and `:_password` as query parameters. Replace `<USERNAME>` and `<PASSWORD>` with the apprropriate values.
42
47
 
43
- ```bash#shell
48
+ ```bash terminal icon="terminal"
44
49
  NPM_CONFIG_REGISTRY=https://pkgs.dev.azure.com/my-azure-artifacts-user/_packaging/my-azure-artifacts-user/npm/registry/:username=<USERNAME>:_password=<PASSWORD>
45
50
  ```
46
51
 
@@ -52,15 +57,13 @@ NPM_CONFIG_REGISTRY=https://pkgs.dev.azure.com/my-azure-artifacts-user/_packagin
52
57
 
53
58
  In [Azure Artifact's](https://learn.microsoft.com/en-us/azure/devops/artifacts/npm/npmrc?view=azure-devops&tabs=windows%2Cclassic) instructions for `.npmrc`, they say to base64 encode the password. Do not do this for `bun install`. Bun will automatically base64 encode the password for you if needed.
54
59
 
55
- {% callout %}
56
- **Tip** — If it ends with `==`, it probably is base64 encoded.
57
- {% /callout %}
60
+ <Note>**Tip** — If it ends with `==`, it probably is base64 encoded.</Note>
58
61
 
59
62
  ---
60
63
 
61
64
  To decode a base64-encoded password, open your browser console and run:
62
65
 
63
- ```js
66
+ ```js browser icon="computer"
64
67
  atob("<base64-encoded password>");
65
68
  ```
66
69
 
@@ -68,6 +71,6 @@ atob("<base64-encoded password>");
68
71
 
69
72
  Alternatively, use the `base64` command line tool, but doing so means it may be saved in your terminal history which is not recommended:
70
73
 
71
- ```bash
74
+ ```bash terminal icon="terminal"
72
75
  echo "base64-encoded-password" | base64 --decode
73
76
  ```
@@ -1,41 +1,41 @@
1
1
  ---
2
- name: Install and run Bun in GitHub Actions
2
+ title: Install dependencies with Bun in GitHub Actions
3
+ sidebarTitle: Install Bun in GitHub Actions
4
+ mode: center
3
5
  ---
4
6
 
5
7
  Use the official [`setup-bun`](https://github.com/oven-sh/setup-bun) GitHub Action to install `bun` in your GitHub Actions runner.
6
8
 
7
- ```yaml-diff#workflow.yml
8
- name: my-workflow
9
+ ```yaml workflow.yml icon="file-code"
10
+ title: my-workflow
9
11
  jobs:
10
12
  my-job:
11
- name: my-job
13
+ title: my-job
12
14
  runs-on: ubuntu-latest
13
15
  steps:
14
16
  # ...
15
17
  - uses: actions/checkout@v4
16
- + - uses: oven-sh/setup-bun@v2
18
+ - uses: oven-sh/setup-bun@v2 // [!code ++]
17
19
 
18
20
  # run any `bun` or `bunx` command
19
- + - run: bun install
20
- + - run: bun index.ts
21
- + - run: bun run build
21
+ - run: bun install // [!code ++]
22
22
  ```
23
23
 
24
24
  ---
25
25
 
26
26
  To specify a version of Bun to install:
27
27
 
28
- ```yaml-diff#workflow.yml
29
- name: my-workflow
28
+ ```yaml workflow.yml icon="file-code"
29
+ title: my-workflow
30
30
  jobs:
31
31
  my-job:
32
- name: my-job
32
+ title: my-job
33
33
  runs-on: ubuntu-latest
34
34
  steps:
35
35
  # ...
36
36
  - uses: oven-sh/setup-bun@v2
37
- + with:
38
- + bun-version: 1.2.0 # or "latest", "canary", <sha>
37
+ with: # [!code ++]
38
+ version: "latest" # or "canary" # [!code ++]
39
39
  ```
40
40
 
41
41
  ---
@@ -1,10 +1,12 @@
1
1
  ---
2
- name: Override the default npm registry for bun install
2
+ title: Override the default npm registry for bun install
3
+ sidebarTitle: Override the default npm registry
4
+ mode: center
3
5
  ---
4
6
 
5
7
  The default registry is `registry.npmjs.org`. This can be globally configured in `bunfig.toml`.
6
8
 
7
- ```toml#bunfig.toml
9
+ ```toml bunfig.toml icon="settings"
8
10
  [install]
9
11
  # set default registry as a string
10
12
  registry = "https://registry.npmjs.org"
@@ -13,14 +15,14 @@ registry = "https://registry.npmjs.org"
13
15
  registry = { url = "https://registry.npmjs.org", token = "123456" }
14
16
 
15
17
  # if needed, set a username/password
16
- registry = "https://username:password@registry.npmjs.org"
18
+ registry = "https://usertitle:password@registry.npmjs.org"
17
19
  ```
18
20
 
19
21
  ---
20
22
 
21
23
  Your `bunfig.toml` can reference environment variables. Bun automatically loads environment variables from `.env.local`, `.env.[NODE_ENV]`, and `.env`. See [Docs > Environment variables](https://bun.com/docs/runtime/env) for more information.
22
24
 
23
- ```toml#bunfig.toml
25
+ ```toml bunfig.toml icon="settings"
24
26
  [install]
25
27
  registry = { url = "https://registry.npmjs.org", token = "$npm_token" }
26
28
  ```