bun-types 1.3.2-canary.20251106T140813 → 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 (316) hide show
  1. package/bun.d.ts +102 -6
  2. package/docs/bundler/bytecode.mdx +465 -0
  3. package/docs/bundler/css.mdx +1024 -0
  4. package/docs/bundler/esbuild.mdx +253 -0
  5. package/docs/bundler/executables.mdx +535 -0
  6. package/docs/bundler/fullstack.mdx +1064 -0
  7. package/docs/bundler/hot-reloading.mdx +229 -0
  8. package/docs/bundler/html-static.mdx +386 -0
  9. package/docs/bundler/index.mdx +1499 -0
  10. package/docs/bundler/loaders.mdx +356 -0
  11. package/docs/bundler/macros.mdx +328 -0
  12. package/docs/bundler/minifier.mdx +1306 -0
  13. package/docs/bundler/plugins.mdx +411 -0
  14. package/docs/feedback.mdx +85 -0
  15. package/docs/guides/binary/arraybuffer-to-array.mdx +29 -0
  16. package/docs/guides/binary/arraybuffer-to-blob.mdx +26 -0
  17. package/docs/guides/binary/arraybuffer-to-buffer.mdx +27 -0
  18. package/docs/guides/binary/arraybuffer-to-string.mdx +17 -0
  19. package/docs/guides/binary/arraybuffer-to-typedarray.mdx +41 -0
  20. package/docs/guides/binary/blob-to-arraybuffer.mdx +16 -0
  21. package/docs/guides/binary/blob-to-dataview.mdx +16 -0
  22. package/docs/guides/binary/blob-to-stream.mdx +16 -0
  23. package/docs/guides/binary/blob-to-string.mdx +17 -0
  24. package/docs/guides/binary/blob-to-typedarray.mdx +16 -0
  25. package/docs/guides/binary/buffer-to-arraybuffer.mdx +16 -0
  26. package/docs/guides/binary/buffer-to-blob.mdx +16 -0
  27. package/docs/guides/binary/buffer-to-readablestream.mdx +43 -0
  28. package/docs/guides/binary/buffer-to-string.mdx +27 -0
  29. package/docs/guides/binary/buffer-to-typedarray.mdx +16 -0
  30. package/docs/guides/binary/dataview-to-string.mdx +17 -0
  31. package/docs/guides/binary/typedarray-to-arraybuffer.mdx +27 -0
  32. package/docs/guides/binary/typedarray-to-blob.mdx +18 -0
  33. package/docs/guides/binary/typedarray-to-buffer.mdx +16 -0
  34. package/docs/guides/binary/typedarray-to-dataview.mdx +16 -0
  35. package/docs/guides/binary/typedarray-to-readablestream.mdx +43 -0
  36. package/docs/guides/binary/typedarray-to-string.mdx +18 -0
  37. package/docs/guides/deployment/aws-lambda.mdx +204 -0
  38. package/docs/guides/deployment/digital-ocean.mdx +161 -0
  39. package/docs/guides/deployment/google-cloud-run.mdx +197 -0
  40. package/docs/guides/deployment/railway.mdx +145 -0
  41. package/docs/guides/deployment/render.mdx +82 -0
  42. package/docs/guides/deployment/vercel.mdx +99 -0
  43. package/docs/guides/ecosystem/astro.mdx +82 -0
  44. package/docs/guides/ecosystem/discordjs.mdx +80 -0
  45. package/docs/guides/ecosystem/docker.mdx +151 -0
  46. package/docs/guides/ecosystem/drizzle.mdx +195 -0
  47. package/docs/guides/ecosystem/edgedb.mdx +257 -0
  48. package/docs/guides/ecosystem/elysia.mdx +31 -0
  49. package/docs/guides/ecosystem/express.mdx +43 -0
  50. package/docs/guides/ecosystem/hono.mdx +47 -0
  51. package/docs/guides/ecosystem/mongoose.mdx +92 -0
  52. package/docs/guides/ecosystem/neon-drizzle.mdx +234 -0
  53. package/docs/guides/ecosystem/neon-serverless-postgres.mdx +60 -0
  54. package/docs/guides/ecosystem/nextjs.mdx +57 -0
  55. package/docs/guides/ecosystem/nuxt.mdx +90 -0
  56. package/docs/guides/ecosystem/pm2.mdx +55 -0
  57. package/docs/guides/ecosystem/prisma-postgres.mdx +169 -0
  58. package/docs/guides/ecosystem/prisma.mdx +164 -0
  59. package/docs/guides/ecosystem/qwik.mdx +114 -0
  60. package/docs/guides/ecosystem/react.mdx +52 -0
  61. package/docs/guides/ecosystem/remix.mdx +97 -0
  62. package/docs/guides/ecosystem/sentry.mdx +54 -0
  63. package/docs/guides/ecosystem/solidstart.mdx +66 -0
  64. package/docs/guides/ecosystem/ssr-react.mdx +49 -0
  65. package/docs/guides/ecosystem/stric.mdx +54 -0
  66. package/docs/guides/ecosystem/sveltekit.mdx +138 -0
  67. package/docs/guides/ecosystem/systemd.mdx +114 -0
  68. package/docs/guides/ecosystem/upstash.mdx +87 -0
  69. package/docs/guides/ecosystem/vite.mdx +77 -0
  70. package/docs/guides/html-rewriter/extract-links.mdx +72 -0
  71. package/docs/guides/html-rewriter/extract-social-meta.mdx +97 -0
  72. package/docs/guides/http/cluster.mdx +69 -0
  73. package/docs/guides/http/fetch-unix.mdx +35 -0
  74. package/docs/guides/http/fetch.mdx +26 -0
  75. package/docs/guides/http/file-uploads.mdx +97 -0
  76. package/docs/guides/http/hot.mdx +28 -0
  77. package/docs/guides/http/proxy.mdx +26 -0
  78. package/docs/guides/http/server.mdx +48 -0
  79. package/docs/guides/http/simple.mdx +20 -0
  80. package/docs/guides/http/stream-file.mdx +50 -0
  81. package/docs/guides/http/stream-iterator.mdx +49 -0
  82. package/docs/guides/http/stream-node-streams-in-bun.mdx +22 -0
  83. package/docs/guides/http/tls.mdx +32 -0
  84. package/docs/guides/index.mdx +10 -0
  85. package/docs/guides/install/add-dev.mdx +28 -0
  86. package/docs/guides/install/add-git.mdx +38 -0
  87. package/docs/guides/install/add-optional.mdx +27 -0
  88. package/docs/guides/install/add-peer.mdx +45 -0
  89. package/docs/guides/install/add-tarball.mdx +35 -0
  90. package/docs/guides/install/add.mdx +44 -0
  91. package/docs/guides/install/azure-artifacts.mdx +76 -0
  92. package/docs/guides/install/cicd.mdx +43 -0
  93. package/docs/guides/install/custom-registry.mdx +32 -0
  94. package/docs/guides/install/from-npm-install-to-bun-install.mdx +230 -0
  95. package/docs/guides/install/git-diff-bun-lockfile.mdx +47 -0
  96. package/docs/guides/install/jfrog-artifactory.mdx +28 -0
  97. package/docs/guides/install/npm-alias.mdx +25 -0
  98. package/docs/guides/install/registry-scope.mdx +40 -0
  99. package/docs/guides/install/trusted.mdx +50 -0
  100. package/docs/guides/install/workspaces.mdx +70 -0
  101. package/docs/guides/install/yarnlock.mdx +50 -0
  102. package/docs/guides/process/argv.mdx +66 -0
  103. package/docs/guides/process/ctrl-c.mdx +18 -0
  104. package/docs/guides/process/ipc.mdx +69 -0
  105. package/docs/guides/process/nanoseconds.mdx +15 -0
  106. package/docs/guides/process/os-signals.mdx +41 -0
  107. package/docs/guides/process/spawn-stderr.mdx +34 -0
  108. package/docs/guides/process/spawn-stdout.mdx +28 -0
  109. package/docs/guides/process/spawn.mdx +43 -0
  110. package/docs/guides/process/stdin.mdx +62 -0
  111. package/docs/guides/read-file/arraybuffer.mdx +30 -0
  112. package/docs/guides/read-file/buffer.mdx +21 -0
  113. package/docs/guides/read-file/exists.mdx +18 -0
  114. package/docs/guides/read-file/json.mdx +19 -0
  115. package/docs/guides/read-file/mime.mdx +22 -0
  116. package/docs/guides/read-file/stream.mdx +28 -0
  117. package/docs/guides/read-file/string.mdx +24 -0
  118. package/docs/guides/read-file/uint8array.mdx +23 -0
  119. package/docs/guides/read-file/watch.mdx +66 -0
  120. package/docs/guides/runtime/build-time-constants.mdx +295 -0
  121. package/docs/guides/runtime/cicd.mdx +45 -0
  122. package/docs/guides/runtime/codesign-macos-executable.mdx +61 -0
  123. package/docs/guides/runtime/define-constant.mdx +149 -0
  124. package/docs/guides/runtime/delete-directory.mdx +39 -0
  125. package/docs/guides/runtime/delete-file.mdx +21 -0
  126. package/docs/guides/runtime/heap-snapshot.mdx +28 -0
  127. package/docs/guides/runtime/import-html.mdx +17 -0
  128. package/docs/guides/runtime/import-json.mdx +46 -0
  129. package/docs/guides/runtime/import-toml.mdx +32 -0
  130. package/docs/guides/runtime/import-yaml.mdx +104 -0
  131. package/docs/guides/runtime/read-env.mdx +37 -0
  132. package/docs/guides/runtime/set-env.mdx +51 -0
  133. package/docs/guides/runtime/shell.mdx +42 -0
  134. package/docs/guides/runtime/timezone.mdx +38 -0
  135. package/docs/guides/runtime/tsconfig-paths.mdx +31 -0
  136. package/docs/guides/runtime/typescript.mdx +51 -0
  137. package/docs/guides/runtime/vscode-debugger.mdx +48 -0
  138. package/docs/guides/runtime/web-debugger.mdx +103 -0
  139. package/docs/guides/streams/node-readable-to-arraybuffer.mdx +13 -0
  140. package/docs/guides/streams/node-readable-to-blob.mdx +13 -0
  141. package/docs/guides/streams/node-readable-to-json.mdx +14 -0
  142. package/docs/guides/streams/node-readable-to-string.mdx +14 -0
  143. package/docs/guides/streams/node-readable-to-uint8array.mdx +13 -0
  144. package/docs/guides/streams/to-array.mdx +16 -0
  145. package/docs/guides/streams/to-arraybuffer.mdx +16 -0
  146. package/docs/guides/streams/to-blob.mdx +16 -0
  147. package/docs/guides/streams/to-buffer.mdx +17 -0
  148. package/docs/guides/streams/to-json.mdx +16 -0
  149. package/docs/guides/streams/to-string.mdx +16 -0
  150. package/docs/guides/streams/to-typedarray.mdx +24 -0
  151. package/docs/guides/test/bail.mdx +24 -0
  152. package/docs/guides/test/coverage-threshold.mdx +67 -0
  153. package/docs/guides/test/coverage.mdx +49 -0
  154. package/docs/guides/test/happy-dom.mdx +73 -0
  155. package/docs/guides/test/migrate-from-jest.mdx +125 -0
  156. package/docs/guides/test/mock-clock.mdx +50 -0
  157. package/docs/guides/test/mock-functions.mdx +70 -0
  158. package/docs/guides/test/rerun-each.mdx +16 -0
  159. package/docs/guides/test/run-tests.mdx +116 -0
  160. package/docs/guides/test/skip-tests.mdx +43 -0
  161. package/docs/guides/test/snapshot.mdx +102 -0
  162. package/docs/guides/test/spy-on.mdx +49 -0
  163. package/docs/guides/test/svelte-test.mdx +113 -0
  164. package/docs/guides/test/testing-library.mdx +93 -0
  165. package/docs/guides/test/timeout.mdx +17 -0
  166. package/docs/guides/test/todo-tests.mdx +74 -0
  167. package/docs/guides/test/update-snapshots.mdx +49 -0
  168. package/docs/guides/test/watch-mode.mdx +24 -0
  169. package/docs/guides/util/base64.mdx +17 -0
  170. package/docs/guides/util/deep-equals.mdx +41 -0
  171. package/docs/guides/util/deflate.mdx +20 -0
  172. package/docs/guides/util/detect-bun.mdx +25 -0
  173. package/docs/guides/util/entrypoint.mdx +19 -0
  174. package/docs/guides/util/escape-html.mdx +24 -0
  175. package/docs/guides/util/file-url-to-path.mdx +16 -0
  176. package/docs/guides/util/gzip.mdx +20 -0
  177. package/docs/guides/util/hash-a-password.mdx +56 -0
  178. package/docs/guides/util/import-meta-dir.mdx +15 -0
  179. package/docs/guides/util/import-meta-file.mdx +15 -0
  180. package/docs/guides/util/import-meta-path.mdx +15 -0
  181. package/docs/guides/util/javascript-uuid.mdx +25 -0
  182. package/docs/guides/util/main.mdx +43 -0
  183. package/docs/guides/util/path-to-file-url.mdx +16 -0
  184. package/docs/guides/util/sleep.mdx +24 -0
  185. package/docs/guides/util/version.mdx +23 -0
  186. package/docs/guides/util/which-path-to-executable-bin.mdx +17 -0
  187. package/docs/guides/websocket/compression.mdx +33 -0
  188. package/docs/guides/websocket/context.mdx +74 -0
  189. package/docs/guides/websocket/pubsub.mdx +40 -0
  190. package/docs/guides/websocket/simple.mdx +35 -0
  191. package/docs/guides/write-file/append.mdx +54 -0
  192. package/docs/guides/write-file/basic.mdx +46 -0
  193. package/docs/guides/write-file/blob.mdx +30 -0
  194. package/docs/guides/write-file/cat.mdx +19 -0
  195. package/docs/guides/write-file/file-cp.mdx +18 -0
  196. package/docs/guides/write-file/filesink.mdx +54 -0
  197. package/docs/guides/write-file/response.mdx +19 -0
  198. package/docs/guides/write-file/stdout.mdx +23 -0
  199. package/docs/guides/write-file/stream.mdx +19 -0
  200. package/docs/guides/write-file/unlink.mdx +18 -0
  201. package/docs/index.mdx +133 -0
  202. package/docs/installation.mdx +365 -0
  203. package/docs/pm/bunx.mdx +83 -0
  204. package/docs/pm/catalogs.mdx +292 -0
  205. package/docs/pm/cli/add.mdx +179 -0
  206. package/docs/pm/cli/audit.mdx +60 -0
  207. package/docs/pm/cli/install.mdx +471 -0
  208. package/docs/pm/cli/link.mdx +48 -0
  209. package/docs/pm/cli/outdated.mdx +197 -0
  210. package/docs/pm/cli/patch.mdx +69 -0
  211. package/docs/pm/cli/pm.mdx +319 -0
  212. package/docs/pm/cli/publish.mdx +123 -0
  213. package/docs/pm/cli/remove.mdx +16 -0
  214. package/docs/pm/cli/update.mdx +140 -0
  215. package/docs/pm/cli/why.mdx +84 -0
  216. package/docs/pm/filter.mdx +102 -0
  217. package/docs/pm/global-cache.mdx +72 -0
  218. package/docs/pm/isolated-installs.mdx +205 -0
  219. package/docs/pm/lifecycle.mdx +57 -0
  220. package/docs/pm/lockfile.mdx +64 -0
  221. package/docs/pm/npmrc.mdx +111 -0
  222. package/docs/pm/overrides.mdx +83 -0
  223. package/docs/pm/scopes-registries.mdx +35 -0
  224. package/docs/pm/security-scanner-api.mdx +95 -0
  225. package/docs/pm/workspaces.mdx +109 -0
  226. package/docs/project/benchmarking.mdx +218 -0
  227. package/docs/project/bindgen.mdx +223 -0
  228. package/docs/project/building-windows.mdx +133 -0
  229. package/docs/project/contributing.mdx +343 -0
  230. package/docs/project/feedback.mdx +20 -0
  231. package/docs/project/license.mdx +78 -0
  232. package/docs/project/roadmap.mdx +8 -0
  233. package/docs/quickstart.mdx +240 -0
  234. package/docs/runtime/auto-install.mdx +97 -0
  235. package/docs/runtime/binary-data.mdx +846 -0
  236. package/docs/runtime/bun-apis.mdx +59 -0
  237. package/docs/runtime/bunfig.mdx +642 -0
  238. package/docs/runtime/c-compiler.mdx +204 -0
  239. package/docs/runtime/child-process.mdx +532 -0
  240. package/docs/runtime/color.mdx +267 -0
  241. package/docs/runtime/console.mdx +67 -0
  242. package/docs/runtime/cookies.mdx +454 -0
  243. package/docs/runtime/debugger.mdx +335 -0
  244. package/docs/runtime/environment-variables.mdx +214 -0
  245. package/docs/runtime/ffi.mdx +565 -0
  246. package/docs/runtime/file-io.mdx +306 -0
  247. package/docs/runtime/file-system-router.mdx +118 -0
  248. package/docs/runtime/file-types.mdx +354 -0
  249. package/docs/runtime/glob.mdx +181 -0
  250. package/docs/runtime/globals.mdx +72 -0
  251. package/docs/runtime/hashing.mdx +315 -0
  252. package/docs/runtime/html-rewriter.mdx +340 -0
  253. package/docs/runtime/http/cookies.mdx +79 -0
  254. package/docs/runtime/http/error-handling.mdx +40 -0
  255. package/docs/runtime/http/metrics.mdx +36 -0
  256. package/docs/runtime/http/routing.mdx +289 -0
  257. package/docs/runtime/http/server.mdx +647 -0
  258. package/docs/runtime/http/tls.mdx +101 -0
  259. package/docs/runtime/http/websockets.mdx +404 -0
  260. package/docs/runtime/index.mdx +223 -0
  261. package/docs/runtime/jsx.mdx +115 -0
  262. package/docs/runtime/module-resolution.mdx +342 -0
  263. package/docs/runtime/networking/dns.mdx +111 -0
  264. package/docs/runtime/networking/fetch.mdx +468 -0
  265. package/docs/runtime/networking/tcp.mdx +239 -0
  266. package/docs/runtime/networking/udp.mdx +129 -0
  267. package/docs/runtime/node-api.mdx +19 -0
  268. package/docs/runtime/nodejs-compat.mdx +468 -0
  269. package/docs/runtime/plugins.mdx +405 -0
  270. package/docs/runtime/redis.mdx +582 -0
  271. package/docs/runtime/s3.mdx +863 -0
  272. package/docs/runtime/secrets.mdx +336 -0
  273. package/docs/runtime/semver.mdx +57 -0
  274. package/docs/runtime/shell.mdx +637 -0
  275. package/docs/runtime/sql.mdx +1404 -0
  276. package/docs/runtime/sqlite.mdx +699 -0
  277. package/docs/runtime/streams.mdx +232 -0
  278. package/docs/runtime/templating/create.mdx +269 -0
  279. package/docs/runtime/templating/init.mdx +58 -0
  280. package/docs/runtime/transpiler.mdx +288 -0
  281. package/docs/runtime/typescript.mdx +58 -0
  282. package/docs/runtime/utils.mdx +922 -0
  283. package/docs/runtime/watch-mode.mdx +161 -0
  284. package/docs/runtime/web-apis.mdx +29 -0
  285. package/docs/runtime/workers.mdx +328 -0
  286. package/docs/runtime/yaml.mdx +469 -0
  287. package/docs/snippets/cli/add.mdx +166 -0
  288. package/docs/snippets/cli/build.mdx +196 -0
  289. package/docs/snippets/cli/feedback.mdx +17 -0
  290. package/docs/snippets/cli/init.mdx +84 -0
  291. package/docs/snippets/cli/install.mdx +173 -0
  292. package/docs/snippets/cli/link.mdx +163 -0
  293. package/docs/snippets/cli/outdated.mdx +140 -0
  294. package/docs/snippets/cli/patch.mdx +171 -0
  295. package/docs/snippets/cli/publish.mdx +198 -0
  296. package/docs/snippets/cli/remove.mdx +146 -0
  297. package/docs/snippets/cli/run.mdx +293 -0
  298. package/docs/snippets/cli/test.mdx +100 -0
  299. package/docs/snippets/cli/update.mdx +144 -0
  300. package/docs/snippets/product-card.mdx +32 -0
  301. package/docs/snippets/product-tiles.mdx +94 -0
  302. package/docs/test/code-coverage.mdx +409 -0
  303. package/docs/test/configuration.mdx +467 -0
  304. package/docs/test/dates-times.mdx +129 -0
  305. package/docs/test/discovery.mdx +90 -0
  306. package/docs/test/dom.mdx +226 -0
  307. package/docs/test/index.mdx +380 -0
  308. package/docs/test/lifecycle.mdx +348 -0
  309. package/docs/test/mocks.mdx +637 -0
  310. package/docs/test/reporters.mdx +117 -0
  311. package/docs/test/runtime-behavior.mdx +342 -0
  312. package/docs/test/snapshots.mdx +434 -0
  313. package/docs/test/writing-tests.mdx +635 -0
  314. package/docs/typescript.mdx +54 -0
  315. package/package.json +8 -6
  316. package/test.d.ts +2 -2
@@ -0,0 +1,229 @@
1
+ ---
2
+ title: Hot reloading
3
+ description: Hot Module Replacement (HMR) for Bun's development server
4
+ ---
5
+
6
+ Hot Module Replacement (HMR) allows you to update modules in a running application without needing a full page reload. This preserves the application state and improves the development experience.
7
+
8
+ <Note>HMR is enabled by default when using Bun's full-stack development server.</Note>
9
+
10
+ ## `import.meta.hot` API Reference
11
+
12
+ Bun implements a client-side HMR API modeled after [Vite's `import.meta.hot` API](https://vitejs.dev/guide/api-hmr.html). It can be checked for with `if (import.meta.hot)`, tree-shaking it in production.
13
+
14
+ ```ts title="index.ts" icon="/icons/typescript.svg"
15
+ if (import.meta.hot) {
16
+ // HMR APIs are available.
17
+ }
18
+ ```
19
+
20
+ However, this check is often not needed as Bun will dead-code-eliminate calls to all of the HMR APIs in production builds.
21
+
22
+ ```ts title="index.ts" icon="/icons/typescript.svg"
23
+ // This entire function call will be removed in production!
24
+ import.meta.hot.dispose(() => {
25
+ console.log("dispose");
26
+ });
27
+ ```
28
+
29
+ <Warning>
30
+ For this to work, Bun forces these APIs to be called without indirection. That means the following do not work:
31
+
32
+ ```ts title="index.ts" icon="/icons/typescript.svg"
33
+ // INVALID: Assigning `hot` to a variable
34
+ const hot = import.meta.hot;
35
+ hot.accept();
36
+
37
+ // INVALID: Assigning `import.meta` to a variable
38
+ const meta = import.meta;
39
+ meta.hot.accept();
40
+ console.log(meta.hot.data);
41
+
42
+ // INVALID: Passing to a function
43
+ doSomething(import.meta.hot.dispose);
44
+
45
+ // OK: The full phrase "import.meta.hot.<API>" must be called directly:
46
+ import.meta.hot.accept();
47
+
48
+ // OK: `data` can be passed to functions:
49
+ doSomething(import.meta.hot.data);
50
+ ```
51
+
52
+ </Warning>
53
+
54
+ <Note>
55
+ The HMR API is still a work in progress. Some features are missing. HMR can be disabled in `Bun.serve` by setting the development option to `{ hmr: false }`.
56
+ </Note>
57
+
58
+ ## API Methods
59
+
60
+ | Method | Status | Notes |
61
+ | ------------------ | ------ | --------------------------------------------------------------------- |
62
+ | `hot.accept()` | ✅ | Indicate that a hot update can be replaced gracefully. |
63
+ | `hot.data` | ✅ | Persist data between module evaluations. |
64
+ | `hot.dispose()` | ✅ | Add a callback function to run when a module is about to be replaced. |
65
+ | `hot.invalidate()` | ❌ | |
66
+ | `hot.on()` | ✅ | Attach an event listener |
67
+ | `hot.off()` | ✅ | Remove an event listener from `on`. |
68
+ | `hot.send()` | ❌ | |
69
+ | `hot.prune()` | 🚧 | NOTE: Callback is currently never called. |
70
+ | `hot.decline()` | ✅ | No-op to match Vite's `import.meta.hot` |
71
+
72
+ ## import.meta.hot.accept()
73
+
74
+ The `accept()` method indicates that a module can be hot-replaced. When called without arguments, it indicates that this module can be replaced simply by re-evaluating the file. After a hot update, importers of this module will be automatically patched.
75
+
76
+ ```ts title="index.ts" icon="/icons/typescript.svg"
77
+ // index.ts
78
+ import { getCount } from "./foo.ts";
79
+
80
+ console.log("count is ", getCount());
81
+
82
+ import.meta.hot.accept();
83
+
84
+ export function getNegativeCount() {
85
+ return -getCount();
86
+ }
87
+ ```
88
+
89
+ This creates a hot-reloading boundary for all of the files that `index.ts` imports. That means whenever `foo.ts` or any of its dependencies are saved, the update will bubble up to `index.ts` will re-evaluate. Files that import `index.ts` will then be patched to import the new version of `getNegativeCount()`. If only `index.ts` is updated, only the one file will be re-evaluated, and the counter in `foo.ts` is reused.
90
+
91
+ This may be used in combination with `import.meta.hot.data` to transfer state from the previous module to the new one.
92
+
93
+ <Info>
94
+ When no modules call `import.meta.hot.accept()` (and there isn't React Fast Refresh or a plugin calling it for you),
95
+ the page will reload when the file updates, and a console warning shows which files were invalidated. This warning is
96
+ safe to ignore if it makes more sense to rely on full page reloads.
97
+ </Info>
98
+
99
+ ### With callback
100
+
101
+ When provided one callback, `import.meta.hot.accept` will function how it does in Vite. Instead of patching the importers of this module, it will call the callback with the new module.
102
+
103
+ ```ts title="index.ts" icon="/icons/typescript.svg"
104
+ export const count = 0;
105
+
106
+ import.meta.hot.accept(newModule => {
107
+ if (newModule) {
108
+ // newModule is undefined when SyntaxError happened
109
+ console.log("updated: count is now ", newModule.count);
110
+ }
111
+ });
112
+ ```
113
+
114
+ <Tip>
115
+ Prefer using `import.meta.hot.accept()` without an argument as it usually makes your code easier to understand.
116
+ </Tip>
117
+
118
+ ### Accepting other modules
119
+
120
+ ```ts title="index.ts" icon="/icons/typescript.svg"
121
+ import { count } from "./foo";
122
+
123
+ import.meta.hot.accept("./foo", () => {
124
+ if (!newModule) return;
125
+
126
+ console.log("updated: count is now ", count);
127
+ });
128
+ ```
129
+
130
+ Indicates that a dependency's module can be accepted. When the dependency is updated, the callback will be called with the new module.
131
+
132
+ ### With multiple dependencies
133
+
134
+ ```ts title="index.ts" icon="/icons/typescript.svg"
135
+ import.meta.hot.accept(["./foo", "./bar"], newModules => {
136
+ // newModules is an array where each item corresponds to the updated module
137
+ // or undefined if that module had a syntax error
138
+ });
139
+ ```
140
+
141
+ Indicates that multiple dependencies' modules can be accepted. This variant accepts an array of dependencies, where the callback will receive the updated modules, and `undefined` for any that had errors.
142
+
143
+ ## import.meta.hot.data
144
+
145
+ `import.meta.hot.data` maintains state between module instances during hot replacement, enabling data transfer from previous to new versions. When `import.meta.hot.data` is written into, Bun will also mark this module as capable of self-accepting (equivalent of calling `import.meta.hot.accept()`).
146
+
147
+ ```jsx title="index.ts" icon="/icons/typescript.svg"
148
+ import { createRoot } from "react-dom/client";
149
+ import { App } from "./app";
150
+
151
+ const root = (import.meta.hot.data.root ??= createRoot(elem));
152
+ root.render(<App />); // re-use an existing root
153
+ ```
154
+
155
+ In production, `data` is inlined to be `{}`, meaning it cannot be used as a state holder.
156
+
157
+ <Tip>
158
+ The above pattern is recommended for stateful modules because Bun knows it can minify `{}.prop ??= value` into `value`
159
+ in production.
160
+ </Tip>
161
+
162
+ ## import.meta.hot.dispose()
163
+
164
+ Attaches an on-dispose callback. This is called:
165
+
166
+ - Just before the module is replaced with another copy (before the next is loaded)
167
+ - After the module is detached (removing all imports to this module, see `import.meta.hot.prune()`)
168
+
169
+ ```ts title="index.ts" icon="/icons/typescript.svg"
170
+ const sideEffect = setupSideEffect();
171
+
172
+ import.meta.hot.dispose(() => {
173
+ sideEffect.cleanup();
174
+ });
175
+ ```
176
+
177
+ <Warning>This callback is not called on route navigation or when the browser tab closes.</Warning>
178
+
179
+ Returning a promise will delay module replacement until the module is disposed. All dispose callbacks are called in parallel.
180
+
181
+ ## import.meta.hot.prune()
182
+
183
+ Attaches an on-prune callback. This is called when all imports to this module are removed, but the module was previously loaded.
184
+
185
+ This can be used to clean up resources that were created when the module was loaded. Unlike `import.meta.hot.dispose()`, this pairs much better with `accept` and `data` to manage stateful resources. A full example managing a WebSocket:
186
+
187
+ ```ts title="index.ts" icon="/icons/typescript.svg"
188
+ import { something } from "./something";
189
+
190
+ // Initialize or re-use a WebSocket connection
191
+ export const ws = (import.meta.hot.data.ws ??= new WebSocket(location.origin));
192
+
193
+ // If the module's import is removed, clean up the WebSocket connection.
194
+ import.meta.hot.prune(() => {
195
+ ws.close();
196
+ });
197
+ ```
198
+
199
+ <Info>
200
+ If `dispose` was used instead, the WebSocket would close and re-open on every hot update. Both versions of the code
201
+ will prevent page reloads when imported files are updated.
202
+ </Info>
203
+
204
+ ## import.meta.hot.on() and off()
205
+
206
+ `on()` and `off()` are used to listen for events from the HMR runtime. Event names are prefixed with a prefix so that plugins do not conflict with each other.
207
+
208
+ ```ts title="index.ts" icon="/icons/typescript.svg"
209
+ import.meta.hot.on("bun:beforeUpdate", () => {
210
+ console.log("before a hot update");
211
+ });
212
+ ```
213
+
214
+ When a file is replaced, all of its event listeners are automatically removed.
215
+
216
+ ### Built-in events
217
+
218
+ | Event | Emitted when |
219
+ | ---------------------- | ----------------------------------------------------------------------------------------------- |
220
+ | `bun:beforeUpdate` | before a hot update is applied. |
221
+ | `bun:afterUpdate` | after a hot update is applied. |
222
+ | `bun:beforeFullReload` | before a full page reload happens. |
223
+ | `bun:beforePrune` | before prune callbacks are called. |
224
+ | `bun:invalidate` | when a module is invalidated with `import.meta.hot.invalidate()` |
225
+ | `bun:error` | when a build or runtime error occurs |
226
+ | `bun:ws:disconnect` | when the HMR WebSocket connection is lost. This can indicate the development server is offline. |
227
+ | `bun:ws:connect` | when the HMR WebSocket connects or re-connects. |
228
+
229
+ <Note>For compatibility with Vite, the above events are also available via `vite:*` prefix instead of `bun:*`.</Note>
@@ -0,0 +1,386 @@
1
+ ---
2
+ title: HTML & static sites
3
+ description: Build static sites, landing pages, and web applications with Bun's bundler
4
+ ---
5
+
6
+ Bun's bundler has first-class support for HTML. Build static sites, landing pages, and web applications with zero configuration. Just point Bun at your HTML file and it handles everything else.
7
+
8
+ ```html title="index.html" icon="file-code"
9
+ <!doctype html>
10
+ <html>
11
+ <head>
12
+ <link rel="stylesheet" href="./styles.css" />
13
+ <script src="./app.ts" type="module"></script>
14
+ </head>
15
+ <body>
16
+ <img src="./logo.png" />
17
+ </body>
18
+ </html>
19
+ ```
20
+
21
+ To get started, pass HTML files to `bun`.
22
+
23
+ ```bash terminal icon="terminal"
24
+ bun ./index.html
25
+ ```
26
+
27
+ ```
28
+ Bun v1.2.20
29
+ ready in 6.62ms
30
+ → http://localhost:3000/
31
+ Press h + Enter to show shortcuts
32
+ ```
33
+
34
+ Bun's development server provides powerful features with zero configuration:
35
+
36
+ - **Automatic Bundling** - Bundles and serves your HTML, JavaScript, and CSS
37
+ - **Multi-Entry Support** - Handles multiple HTML entry points and glob entry points
38
+ - **Modern JavaScript** - TypeScript & JSX support out of the box
39
+ - **Smart Configuration** - Reads `tsconfig.json` for paths, JSX options, experimental decorators, and more
40
+ - **Plugins** - Plugins for TailwindCSS and more
41
+ - **ESM & CommonJS** - Use ESM and CommonJS in your JavaScript, TypeScript, and JSX files
42
+ - **CSS Bundling & Minification** - Bundles CSS from `<link>` tags and `@import` statements
43
+ - **Asset Management** - Automatic copying & hashing of images and assets; Rewrites asset paths in JavaScript, CSS, and HTML
44
+
45
+ ## Single Page Apps (SPA)
46
+
47
+ When you pass a single `.html` file to Bun, Bun will use it as a fallback route for all paths. This makes it perfect for single page apps that use client-side routing:
48
+
49
+ ```bash terminal icon="terminal"
50
+ bun index.html
51
+ ```
52
+
53
+ ```
54
+ Bun v1.2.20
55
+ ready in 6.62ms
56
+ → http://localhost:3000/
57
+ Press h + Enter to show shortcuts
58
+ ```
59
+
60
+ Your React or other SPA will work out of the box — no configuration needed. All routes like `/about`, `/users/123`, etc. will serve the same HTML file, letting your client-side router handle the navigation.
61
+
62
+ ```html title="index.html" icon="file-code"
63
+ <!doctype html>
64
+ <html>
65
+ <head>
66
+ <title>My SPA</title>
67
+ <script src="./app.tsx" type="module"></script>
68
+ </head>
69
+ <body>
70
+ <div id="root"></div>
71
+ </body>
72
+ </html>
73
+ ```
74
+
75
+ ## Multi-page apps (MPA)
76
+
77
+ Some projects have several separate routes or HTML files as entry points. To support multiple entry points, pass them all to `bun`:
78
+
79
+ ```bash terminal icon="terminal"
80
+ bun ./index.html ./about.html
81
+ ```
82
+
83
+ ```txt
84
+ Bun v1.2.20
85
+ ready in 6.62ms
86
+ → http://localhost:3000/
87
+ Routes:
88
+ / ./index.html
89
+ /about ./about.html
90
+ Press h + Enter to show shortcuts
91
+ ```
92
+
93
+ This will serve:
94
+
95
+ - `index.html` at `/`
96
+ - `about.html` at `/about`
97
+
98
+ ### Glob patterns
99
+
100
+ To specify multiple files, you can use glob patterns that end in `.html`:
101
+
102
+ ```bash terminal icon="terminal"
103
+ bun ./**/*.html
104
+ ```
105
+
106
+ ```
107
+ Bun v1.2.20
108
+ ready in 6.62ms
109
+ → http://localhost:3000/
110
+ Routes:
111
+ / ./index.html
112
+ /about ./about.html
113
+ Press h + Enter to show shortcuts
114
+ ```
115
+
116
+ ### Path normalization
117
+
118
+ The base path is chosen from the longest common prefix among all the files.
119
+
120
+ ```bash terminal icon="terminal"
121
+ bun ./index.html ./about/index.html ./about/foo/index.html
122
+ ```
123
+
124
+ ```
125
+ Bun v1.2.20
126
+ ready in 6.62ms
127
+ → http://localhost:3000/
128
+ Routes:
129
+ / ./index.html
130
+ /about ./about/index.html
131
+ /about/foo ./about/foo/index.html
132
+ Press h + Enter to show shortcuts
133
+ ```
134
+
135
+ ## JavaScript, TypeScript, and JSX
136
+
137
+ Bun's transpiler natively implements JavaScript, TypeScript, and JSX support. Learn more about loaders in Bun.
138
+
139
+ <Note>Bun's transpiler is also used at runtime.</Note>
140
+
141
+ ### ES Modules & CommonJS
142
+
143
+ You can use ESM and CJS in your JavaScript, TypeScript, and JSX files. Bun will handle the transpilation and bundling automatically.
144
+
145
+ There is no pre-build or separate optimization step. It's all done at the same time.
146
+
147
+ Learn more about module resolution in Bun.
148
+
149
+ ## CSS
150
+
151
+ Bun's CSS parser is also natively implemented (clocking in around 58,000 lines of Zig).
152
+
153
+ It's also a CSS bundler. You can use `@import` in your CSS files to import other CSS files.
154
+
155
+ For example:
156
+
157
+ <CodeGroup>
158
+
159
+ ```css styles.css icon="file-code"
160
+ @import "./abc.css";
161
+
162
+ .container {
163
+ background-color: blue;
164
+ }
165
+ ```
166
+
167
+ ```css abc.css
168
+ body {
169
+ background-color: red;
170
+ }
171
+ ```
172
+
173
+ </CodeGroup>
174
+
175
+ This outputs:
176
+
177
+ ```css
178
+ body {
179
+ background-color: red;
180
+ }
181
+
182
+ .container {
183
+ background-color: blue;
184
+ }
185
+ ```
186
+
187
+ ### Referencing local assets in CSS
188
+
189
+ You can reference local assets in your CSS files.
190
+
191
+ ```css styles.css icon="file-code"
192
+ body {
193
+ background-image: url("./logo.png");
194
+ }
195
+ ```
196
+
197
+ This will copy `./logo.png` to the output directory and rewrite the path in the CSS file to include a content hash.
198
+
199
+ ```css styles.css icon="file-code"
200
+ body {
201
+ background-image: url("./logo-[ABC123].png");
202
+ }
203
+ ```
204
+
205
+ ### Importing CSS in JavaScript
206
+
207
+ To associate a CSS file with a JavaScript file, you can import it in your JavaScript file.
208
+
209
+ ```ts app.ts icon="/icons/typescript.svg"
210
+ import "./styles.css";
211
+ import "./more-styles.css";
212
+ ```
213
+
214
+ This generates `./app.css` and `./app.js` in the output directory. All CSS files imported from JavaScript will be bundled into a single CSS file per entry point. If you import the same CSS file from multiple JavaScript files, it will only be included once in the output CSS file.
215
+
216
+ ## Plugins
217
+
218
+ The dev server supports plugins.
219
+
220
+ ### Tailwind CSS
221
+
222
+ To use TailwindCSS, install the `bun-plugin-tailwind` plugin:
223
+
224
+ ```bash terminal icon="terminal"
225
+ # Or any npm client
226
+ bun install --dev bun-plugin-tailwind
227
+ ```
228
+
229
+ Then, add the plugin to your `bunfig.toml`:
230
+
231
+ ```toml title="bunfig.toml" icon="settings"
232
+ [serve.static]
233
+ plugins = ["bun-plugin-tailwind"]
234
+ ```
235
+
236
+ Then, reference TailwindCSS in your HTML via `<link>` tag, `@import` in CSS, or import in JavaScript.
237
+
238
+ <Tabs>
239
+ <Tab title="index.html">
240
+ ```html title="index.html" icon="file-code"
241
+ {/* Reference TailwindCSS in your HTML */}
242
+ <link rel="stylesheet" href="tailwindcss" />
243
+ ```
244
+ </Tab>
245
+ <Tab title="styles.css">```css title="styles.css" icon="file-code" @import "tailwindcss"; ```</Tab>
246
+ <Tab title="app.ts">```ts title="app.ts" icon="/icons/typescript.svg" import "tailwindcss"; ```</Tab>
247
+ </Tabs>
248
+
249
+ <Info>Only one of those are necessary, not all three.</Info>
250
+
251
+ ## Echo console logs from browser to terminal
252
+
253
+ Bun's dev server supports streaming console logs from the browser to the terminal.
254
+
255
+ To enable, pass the `--console` CLI flag.
256
+
257
+ ```bash terminal icon="terminal"
258
+ bun ./index.html --console
259
+ ```
260
+
261
+ ```
262
+ Bun v1.2.20
263
+ ready in 6.62ms
264
+ → http://localhost:3000/
265
+ Press h + Enter to show shortcuts
266
+ ```
267
+
268
+ Each call to `console.log` or `console.error` will be broadcast to the terminal that started the server. This is useful to see errors from the browser in the same place you run your server. This is also useful for AI agents that watch terminal output.
269
+
270
+ Internally, this reuses the existing WebSocket connection from hot module reloading to send the logs.
271
+
272
+ ## Edit files in the browser
273
+
274
+ Bun's frontend dev server has support for Automatic Workspace Folders in Chrome DevTools, which lets you save edits to files in the browser.
275
+
276
+ ## Keyboard Shortcuts
277
+
278
+ While the server is running:
279
+
280
+ - `o + Enter` - Open in browser
281
+ - `c + Enter` - Clear console
282
+ - `q + Enter` (or `Ctrl+C`) - Quit server
283
+
284
+ ## Build for Production
285
+
286
+ When you're ready to deploy, use `bun build` to create optimized production bundles:
287
+
288
+ <Tabs>
289
+ <Tab title="CLI">
290
+ ```bash terminal icon="terminal"
291
+ bun build ./index.html --minify --outdir=dist
292
+ ```
293
+ </Tab>
294
+ <Tab title="API">
295
+ ```ts title="build.ts" icon="/icons/typescript.svg"
296
+ await Bun.build({
297
+ entrypoints: ["./index.html"],
298
+ outdir: "./dist",
299
+ minify: true,
300
+ });
301
+ ```
302
+ </Tab>
303
+ </Tabs>
304
+
305
+ <Warning>
306
+ Currently, plugins are only supported through `Bun.build`'s API or through `bunfig.toml` with the frontend dev server
307
+ - not yet supported in `bun build`'s CLI.
308
+ </Warning>
309
+
310
+ ### Watch Mode
311
+
312
+ You can run `bun build --watch` to watch for changes and rebuild automatically. This works nicely for library development.
313
+
314
+ <Info>You've never seen a watch mode this fast.</Info>
315
+
316
+ ## Plugin API
317
+
318
+ Need more control? Configure the bundler through the JavaScript API and use Bun's builtin `HTMLRewriter` to preprocess HTML.
319
+
320
+ ```ts title="build.ts" icon="/icons/typescript.svg"
321
+ await Bun.build({
322
+ entrypoints: ["./index.html"],
323
+ outdir: "./dist",
324
+ minify: true,
325
+
326
+ plugins: [
327
+ {
328
+ // A plugin that makes every HTML tag lowercase
329
+ name: "lowercase-html-plugin",
330
+ setup({ onLoad }) {
331
+ const rewriter = new HTMLRewriter().on("*", {
332
+ element(element) {
333
+ element.tagName = element.tagName.toLowerCase();
334
+ },
335
+ text(element) {
336
+ element.replace(element.text.toLowerCase());
337
+ },
338
+ });
339
+
340
+ onLoad({ filter: /\.html$/ }, async args => {
341
+ const html = await Bun.file(args.path).text();
342
+
343
+ return {
344
+ // Bun's bundler will scan the HTML for <script> tags, <link rel="stylesheet"> tags, and other assets
345
+ // and bundle them automatically
346
+ contents: rewriter.transform(html),
347
+ loader: "html",
348
+ };
349
+ });
350
+ },
351
+ },
352
+ ],
353
+ });
354
+ ```
355
+
356
+ ## What Gets Processed?
357
+
358
+ Bun automatically handles all common web assets:
359
+
360
+ - **Scripts** (`<script src>`) are run through Bun's JavaScript/TypeScript/JSX bundler
361
+ - **Stylesheets** (`<link rel="stylesheet">`) are run through Bun's CSS parser & bundler
362
+ - **Images** (`<img>`, `<picture>`) are copied and hashed
363
+ - **Media** (`<video>`, `<audio>`, `<source>`) are copied and hashed
364
+ - Any `<link>` tag with an `href` attribute pointing to a local file is rewritten to the new path, and hashed
365
+
366
+ All paths are resolved relative to your HTML file, making it easy to organize your project however you want.
367
+
368
+ <Warning>
369
+ **This is a work in progress**
370
+ - Need more plugins
371
+ - Need more configuration options for things like asset handling
372
+ - Need a way to configure CORS, headers, etc.
373
+
374
+ If you want to submit a PR, most of the code is [here](https://github.com/oven-sh/bun/blob/main/src/bun.js/api/bun/html-rewriter.ts). You could even copy paste that file into your project and use it as a starting point.
375
+
376
+ </Warning>
377
+
378
+ ## How this works
379
+
380
+ This is a small wrapper around Bun's support for HTML imports in JavaScript.
381
+
382
+ ## Adding a backend to your frontend
383
+
384
+ To add a backend to your frontend, you can use the "routes" option in `Bun.serve`.
385
+
386
+ Learn more in the full-stack docs.