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.
- package/bun.d.ts +102 -6
- package/docs/README.md +28 -0
- package/docs/bundler/bytecode.mdx +465 -0
- package/docs/bundler/{css.md → css.mdx} +97 -101
- package/docs/bundler/esbuild.mdx +253 -0
- package/docs/bundler/{executables.md → executables.mdx} +130 -221
- package/docs/bundler/fullstack.mdx +1064 -0
- package/docs/bundler/{hmr.md → hot-reloading.mdx} +74 -79
- package/docs/bundler/{html.md → html-static.mdx} +148 -111
- package/docs/bundler/index.mdx +1499 -0
- package/docs/bundler/loaders.mdx +356 -0
- package/docs/bundler/{macros.md → macros.mdx} +83 -84
- package/docs/bundler/minifier.mdx +1306 -0
- package/docs/bundler/plugins.mdx +411 -0
- package/docs/feedback.mdx +85 -0
- package/docs/guides/binary/{arraybuffer-to-array.md → arraybuffer-to-array.mdx} +3 -1
- package/docs/guides/binary/{arraybuffer-to-blob.md → arraybuffer-to-blob.mdx} +3 -1
- package/docs/guides/binary/{arraybuffer-to-buffer.md → arraybuffer-to-buffer.mdx} +3 -1
- package/docs/guides/binary/{arraybuffer-to-string.md → arraybuffer-to-string.mdx} +3 -1
- package/docs/guides/binary/{arraybuffer-to-typedarray.md → arraybuffer-to-typedarray.mdx} +3 -1
- package/docs/guides/binary/{blob-to-arraybuffer.md → blob-to-arraybuffer.mdx} +3 -1
- package/docs/guides/binary/{blob-to-dataview.md → blob-to-dataview.mdx} +3 -1
- package/docs/guides/binary/{blob-to-stream.md → blob-to-stream.mdx} +3 -1
- package/docs/guides/binary/{blob-to-string.md → blob-to-string.mdx} +3 -1
- package/docs/guides/binary/{blob-to-typedarray.md → blob-to-typedarray.mdx} +3 -1
- package/docs/guides/binary/{buffer-to-arraybuffer.md → buffer-to-arraybuffer.mdx} +3 -1
- package/docs/guides/binary/{buffer-to-blob.md → buffer-to-blob.mdx} +3 -1
- package/docs/guides/binary/{buffer-to-readablestream.md → buffer-to-readablestream.mdx} +3 -1
- package/docs/guides/binary/{buffer-to-string.md → buffer-to-string.mdx} +3 -1
- package/docs/guides/binary/{buffer-to-typedarray.md → buffer-to-typedarray.mdx} +3 -1
- package/docs/guides/binary/{dataview-to-string.md → dataview-to-string.mdx} +3 -1
- package/docs/guides/binary/{typedarray-to-arraybuffer.md → typedarray-to-arraybuffer.mdx} +3 -1
- package/docs/guides/binary/{typedarray-to-blob.md → typedarray-to-blob.mdx} +3 -1
- package/docs/guides/binary/{typedarray-to-buffer.md → typedarray-to-buffer.mdx} +3 -1
- package/docs/guides/binary/{typedarray-to-dataview.md → typedarray-to-dataview.mdx} +3 -1
- package/docs/guides/binary/{typedarray-to-readablestream.md → typedarray-to-readablestream.mdx} +3 -1
- package/docs/guides/binary/{typedarray-to-string.md → typedarray-to-string.mdx} +3 -1
- package/docs/guides/deployment/aws-lambda.mdx +204 -0
- package/docs/guides/deployment/digital-ocean.mdx +161 -0
- package/docs/guides/deployment/google-cloud-run.mdx +197 -0
- package/docs/guides/deployment/{railway.md → railway.mdx} +42 -54
- package/docs/guides/deployment/render.mdx +82 -0
- package/docs/guides/deployment/vercel.mdx +99 -0
- package/docs/guides/ecosystem/{astro.md → astro.mdx} +16 -6
- package/docs/guides/ecosystem/{discordjs.md → discordjs.mdx} +21 -18
- package/docs/guides/ecosystem/{docker.md → docker.mdx} +25 -14
- package/docs/guides/ecosystem/{drizzle.md → drizzle.mdx} +32 -22
- package/docs/guides/ecosystem/{edgedb.md → edgedb.mdx} +63 -34
- package/docs/guides/ecosystem/{elysia.md → elysia.mdx} +11 -11
- package/docs/guides/ecosystem/{express.md → express.mdx} +12 -9
- package/docs/guides/ecosystem/{hono.md → hono.mdx} +16 -8
- package/docs/guides/ecosystem/{mongoose.md → mongoose.mdx} +26 -21
- package/docs/guides/ecosystem/{neon-drizzle.md → neon-drizzle.mdx} +49 -35
- package/docs/guides/ecosystem/{neon-serverless-postgres.md → neon-serverless-postgres.mdx} +16 -11
- package/docs/guides/ecosystem/{nextjs.md → nextjs.mdx} +18 -10
- package/docs/guides/ecosystem/{nuxt.md → nuxt.mdx} +45 -11
- package/docs/guides/ecosystem/{pm2.md → pm2.mdx} +7 -9
- package/docs/guides/ecosystem/prisma-postgres.mdx +169 -0
- package/docs/guides/ecosystem/prisma.mdx +164 -0
- package/docs/guides/ecosystem/{qwik.md → qwik.mdx} +18 -11
- package/docs/guides/ecosystem/{react.md → react.mdx} +9 -7
- package/docs/guides/ecosystem/{remix.md → remix.mdx} +45 -26
- package/docs/guides/ecosystem/{sentry.md → sentry.mdx} +7 -5
- package/docs/guides/ecosystem/{solidstart.md → solidstart.mdx} +21 -13
- package/docs/guides/ecosystem/{ssr-react.md → ssr-react.mdx} +9 -11
- package/docs/guides/ecosystem/{stric.md → stric.mdx} +16 -17
- package/docs/guides/ecosystem/{sveltekit.md → sveltekit.mdx} +42 -29
- package/docs/guides/ecosystem/{systemd.md → systemd.mdx} +27 -26
- package/docs/guides/ecosystem/upstash.mdx +87 -0
- package/docs/guides/ecosystem/{vite.md → vite.mdx} +20 -14
- package/docs/guides/html-rewriter/{extract-links.md → extract-links.mdx} +11 -7
- package/docs/guides/html-rewriter/{extract-social-meta.md → extract-social-meta.mdx} +6 -2
- package/docs/guides/http/{cluster.md → cluster.mdx} +10 -7
- package/docs/guides/http/{fetch-unix.md → fetch-unix.mdx} +5 -3
- package/docs/guides/http/{fetch.md → fetch.mdx} +5 -3
- package/docs/guides/http/{file-uploads.md → file-uploads.mdx} +18 -15
- package/docs/guides/http/{hot.md → hot.mdx} +9 -7
- package/docs/guides/http/{proxy.md → proxy.mdx} +7 -5
- package/docs/guides/http/{server.md → server.mdx} +4 -2
- package/docs/guides/http/{simple.md → simple.mdx} +4 -2
- package/docs/guides/http/{stream-file.md → stream-file.mdx} +6 -4
- package/docs/guides/http/{stream-iterator.md → stream-iterator.mdx} +5 -3
- package/docs/guides/http/{stream-node-streams-in-bun.md → stream-node-streams-in-bun.mdx} +4 -2
- package/docs/guides/http/{tls.md → tls.mdx} +5 -3
- package/docs/guides/index.mdx +10 -0
- package/docs/guides/install/{add-dev.md → add-dev.mdx} +8 -6
- package/docs/guides/install/add-git.mdx +38 -0
- package/docs/guides/install/{add-optional.md → add-optional.mdx} +7 -5
- package/docs/guides/install/{add-peer.md → add-peer.mdx} +13 -11
- package/docs/guides/install/{add-tarball.md → add-tarball.mdx} +7 -5
- package/docs/guides/install/{add.md → add.mdx} +12 -10
- package/docs/guides/install/{azure-artifacts.md → azure-artifacts.mdx} +15 -12
- package/docs/guides/{runtime/cicd.md → install/cicd.mdx} +13 -13
- package/docs/guides/install/{custom-registry.md → custom-registry.mdx} +6 -4
- package/docs/guides/install/{from-npm-install-to-bun-install.md → from-npm-install-to-bun-install.mdx} +50 -34
- package/docs/guides/install/{git-diff-bun-lockfile.md → git-diff-bun-lockfile.mdx} +14 -11
- package/docs/guides/install/{jfrog-artifactory.md → jfrog-artifactory.mdx} +4 -4
- package/docs/guides/install/{npm-alias.md → npm-alias.mdx} +6 -4
- package/docs/guides/install/{registry-scope.md → registry-scope.mdx} +6 -4
- package/docs/guides/install/{trusted.md → trusted.mdx} +22 -18
- package/docs/guides/install/{workspaces.md → workspaces.mdx} +13 -13
- package/docs/guides/install/{yarnlock.md → yarnlock.mdx} +15 -9
- package/docs/guides/process/{argv.md → argv.mdx} +17 -9
- package/docs/guides/process/{ctrl-c.md → ctrl-c.mdx} +4 -2
- package/docs/guides/process/{ipc.md → ipc.mdx} +13 -10
- package/docs/guides/process/{nanoseconds.md → nanoseconds.mdx} +3 -1
- package/docs/guides/process/{os-signals.md → os-signals.mdx} +3 -1
- package/docs/guides/process/{spawn-stderr.md → spawn-stderr.mdx} +4 -1
- package/docs/guides/process/{spawn-stdout.md → spawn-stdout.mdx} +3 -1
- package/docs/guides/process/{spawn.md → spawn.mdx} +3 -1
- package/docs/guides/process/{stdin.md → stdin.mdx} +15 -7
- package/docs/guides/read-file/{arraybuffer.md → arraybuffer.mdx} +5 -3
- package/docs/guides/read-file/{buffer.md → buffer.mdx} +4 -2
- package/docs/guides/read-file/{exists.md → exists.mdx} +4 -2
- package/docs/guides/read-file/{json.md → json.mdx} +4 -2
- package/docs/guides/read-file/{mime.md → mime.mdx} +3 -1
- package/docs/guides/read-file/{stream.md → stream.mdx} +3 -1
- package/docs/guides/read-file/{string.md → string.mdx} +3 -1
- package/docs/guides/read-file/{uint8array.md → uint8array.mdx} +3 -1
- package/docs/guides/read-file/{watch.md → watch.mdx} +6 -8
- package/docs/guides/runtime/{build-time-constants.md → build-time-constants.mdx} +24 -22
- package/docs/guides/{install/cicd.md → runtime/cicd.mdx} +11 -7
- package/docs/guides/runtime/{codesign-macos-executable.md → codesign-macos-executable.mdx} +14 -9
- package/docs/guides/runtime/{define-constant.md → define-constant.mdx} +20 -16
- package/docs/guides/runtime/{delete-directory.md → delete-directory.mdx} +5 -3
- package/docs/guides/runtime/{delete-file.md → delete-file.mdx} +4 -2
- package/docs/guides/runtime/{heap-snapshot.md → heap-snapshot.mdx} +5 -3
- package/docs/guides/runtime/{import-html.md → import-html.mdx} +4 -2
- package/docs/guides/runtime/{import-json.md → import-json.mdx} +6 -4
- package/docs/guides/runtime/{import-toml.md → import-toml.mdx} +5 -3
- package/docs/guides/runtime/{import-yaml.md → import-yaml.mdx} +9 -7
- package/docs/guides/runtime/{read-env.md → read-env.mdx} +10 -5
- package/docs/guides/runtime/{set-env.md → set-env.mdx} +14 -10
- package/docs/guides/runtime/{shell.md → shell.mdx} +6 -4
- package/docs/guides/runtime/{timezone.md → timezone.mdx} +10 -7
- package/docs/guides/runtime/{tsconfig-paths.md → tsconfig-paths.mdx} +5 -3
- package/docs/guides/runtime/{typescript.md → typescript.mdx} +8 -6
- package/docs/guides/runtime/{vscode-debugger.md → vscode-debugger.mdx} +12 -11
- package/docs/guides/runtime/{web-debugger.md → web-debugger.mdx} +39 -18
- package/docs/guides/streams/{node-readable-to-arraybuffer.md → node-readable-to-arraybuffer.mdx} +3 -1
- package/docs/guides/streams/{node-readable-to-blob.md → node-readable-to-blob.mdx} +3 -1
- package/docs/guides/streams/{node-readable-to-json.md → node-readable-to-json.mdx} +3 -1
- package/docs/guides/streams/{node-readable-to-string.md → node-readable-to-string.mdx} +3 -1
- package/docs/guides/streams/{node-readable-to-uint8array.md → node-readable-to-uint8array.mdx} +3 -1
- package/docs/guides/streams/{to-array.md → to-array.mdx} +3 -1
- package/docs/guides/streams/{to-arraybuffer.md → to-arraybuffer.mdx} +3 -1
- package/docs/guides/streams/{to-blob.md → to-blob.mdx} +3 -1
- package/docs/guides/streams/{to-buffer.md → to-buffer.mdx} +3 -1
- package/docs/guides/streams/{to-json.md → to-json.mdx} +4 -2
- package/docs/guides/streams/{to-string.md → to-string.mdx} +3 -1
- package/docs/guides/streams/{to-typedarray.md → to-typedarray.mdx} +3 -1
- package/docs/guides/test/{bail.md → bail.mdx} +7 -5
- package/docs/guides/test/{coverage-threshold.md → coverage-threshold.mdx} +14 -7
- package/docs/guides/test/{coverage.md → coverage.mdx} +9 -4
- package/docs/guides/test/{happy-dom.md → happy-dom.mdx} +13 -8
- package/docs/guides/test/{migrate-from-jest.md → migrate-from-jest.mdx} +19 -37
- package/docs/guides/test/{mock-clock.md → mock-clock.mdx} +3 -1
- package/docs/guides/test/{mock-functions.md → mock-functions.mdx} +7 -5
- package/docs/guides/test/{rerun-each.md → rerun-each.mdx} +5 -3
- package/docs/guides/test/{run-tests.md → run-tests.mdx} +16 -11
- package/docs/guides/test/{skip-tests.md → skip-tests.mdx} +8 -4
- package/docs/guides/test/{snapshot.md → snapshot.mdx} +20 -13
- package/docs/guides/test/spy-on.mdx +49 -0
- package/docs/guides/test/{svelte-test.md → svelte-test.mdx} +16 -23
- package/docs/guides/test/{testing-library.md → testing-library.mdx} +18 -17
- package/docs/guides/test/{timeout.md → timeout.mdx} +5 -3
- package/docs/guides/test/{todo-tests.md → todo-tests.mdx} +13 -6
- package/docs/guides/test/{update-snapshots.md → update-snapshots.mdx} +9 -6
- package/docs/guides/test/{watch-mode.md → watch-mode.mdx} +9 -4
- package/docs/guides/util/{base64.md → base64.mdx} +3 -1
- package/docs/guides/util/{deep-equals.md → deep-equals.mdx} +5 -3
- package/docs/guides/util/{deflate.md → deflate.mdx} +3 -1
- package/docs/guides/util/{detect-bun.md → detect-bun.mdx} +3 -1
- package/docs/guides/util/{entrypoint.md → entrypoint.mdx} +4 -2
- package/docs/guides/util/{escape-html.md → escape-html.mdx} +3 -1
- package/docs/guides/util/{file-url-to-path.md → file-url-to-path.mdx} +3 -1
- package/docs/guides/util/{gzip.md → gzip.mdx} +3 -1
- package/docs/guides/util/{hash-a-password.md → hash-a-password.mdx} +3 -1
- package/docs/guides/util/{import-meta-dir.md → import-meta-dir.mdx} +4 -2
- package/docs/guides/util/{import-meta-file.md → import-meta-file.mdx} +4 -2
- package/docs/guides/util/{import-meta-path.md → import-meta-path.mdx} +4 -2
- package/docs/guides/util/{javascript-uuid.md → javascript-uuid.mdx} +3 -1
- package/docs/guides/util/{main.md → main.mdx} +19 -8
- package/docs/guides/util/{path-to-file-url.md → path-to-file-url.mdx} +3 -1
- package/docs/guides/util/{sleep.md → sleep.mdx} +3 -1
- package/docs/guides/util/{version.md → version.mdx} +6 -4
- package/docs/guides/util/{which-path-to-executable-bin.md → which-path-to-executable-bin.mdx} +4 -2
- package/docs/guides/websocket/{compression.md → compression.mdx} +5 -3
- package/docs/guides/websocket/{context.md → context.mdx} +9 -12
- package/docs/guides/websocket/{pubsub.md → pubsub.mdx} +5 -6
- package/docs/guides/websocket/{simple.md → simple.mdx} +5 -3
- package/docs/guides/write-file/{append.md → append.mdx} +3 -1
- package/docs/guides/write-file/{basic.md → basic.mdx} +3 -1
- package/docs/guides/write-file/{blob.md → blob.mdx} +3 -1
- package/docs/guides/write-file/{cat.md → cat.mdx} +4 -2
- package/docs/guides/write-file/{file-cp.md → file-cp.mdx} +3 -1
- package/docs/guides/write-file/{filesink.md → filesink.mdx} +3 -1
- package/docs/guides/write-file/{response.md → response.mdx} +3 -1
- package/docs/guides/write-file/{stdout.md → stdout.mdx} +3 -1
- package/docs/guides/write-file/{stream.md → stream.mdx} +3 -1
- package/docs/guides/write-file/{unlink.md → unlink.mdx} +3 -1
- package/docs/{index.md → index.mdx} +97 -41
- package/docs/installation.mdx +365 -0
- package/docs/{cli/bunx.md → pm/bunx.mdx} +25 -31
- package/docs/{install/catalogs.md → pm/catalogs.mdx} +18 -24
- package/docs/{cli/add.md → pm/cli/add.mdx} +61 -55
- package/docs/{install/audit.md → pm/cli/audit.mdx} +11 -8
- package/docs/{cli/install.md → pm/cli/install.mdx} +208 -81
- package/docs/{cli/link.md → pm/cli/link.mdx} +27 -19
- package/docs/{cli/outdated.md → pm/cli/outdated.mdx} +119 -12
- package/docs/{install/patch.md → pm/cli/patch.mdx} +25 -15
- package/docs/{cli/pm.md → pm/cli/pm.mdx} +96 -62
- package/docs/{cli/publish.md → pm/cli/publish.mdx} +38 -35
- package/docs/pm/cli/remove.mdx +16 -0
- package/docs/{cli/update.md → pm/cli/update.mdx} +26 -15
- package/docs/{cli/why.md → pm/cli/why.mdx} +27 -10
- package/docs/{cli/filter.md → pm/filter.mdx} +26 -14
- package/docs/{install/cache.md → pm/global-cache.mdx} +25 -12
- package/docs/{install/isolated.md → pm/isolated-installs.mdx} +32 -24
- package/docs/{install/lifecycle.md → pm/lifecycle.mdx} +20 -9
- package/docs/{install/lockfile.md → pm/lockfile.mdx} +18 -12
- package/docs/{install/npmrc.md → pm/npmrc.mdx} +30 -24
- package/docs/{install/overrides.md → pm/overrides.mdx} +47 -37
- package/docs/{install/registries.md → pm/scopes-registries.mdx} +8 -3
- package/docs/{install/security-scanner-api.md → pm/security-scanner-api.mdx} +22 -8
- package/docs/{install/workspaces.md → pm/workspaces.mdx} +17 -22
- package/docs/project/{benchmarking.md → benchmarking.mdx} +26 -11
- package/docs/project/{bindgen.md → bindgen.mdx} +12 -14
- package/docs/project/{building-windows.md → building-windows.mdx} +18 -47
- package/docs/project/{contributing.md → contributing.mdx} +56 -60
- package/docs/project/feedback.mdx +20 -0
- package/docs/project/license.mdx +78 -0
- package/docs/project/roadmap.mdx +8 -0
- package/docs/quickstart.mdx +240 -0
- package/docs/runtime/{autoimport.md → auto-install.mdx} +34 -31
- package/docs/{api/binary-data.md → runtime/binary-data.mdx} +77 -269
- package/docs/runtime/bun-apis.mdx +59 -0
- package/docs/runtime/{bunfig.md → bunfig.mdx} +95 -225
- package/docs/{api/cc.md → runtime/c-compiler.mdx} +16 -9
- package/docs/{api/spawn.md → runtime/child-process.mdx} +69 -119
- package/docs/{api/color.md → runtime/color.mdx} +6 -1
- package/docs/{api/console.md → runtime/console.mdx} +17 -7
- package/docs/{api/cookie.md → runtime/cookies.mdx} +24 -19
- package/docs/runtime/{debugger.md → debugger.mdx} +61 -51
- package/docs/runtime/environment-variables.mdx +214 -0
- package/docs/{api/ffi.md → runtime/ffi.mdx} +53 -45
- package/docs/{api/file-io.md → runtime/file-io.mdx} +41 -101
- package/docs/{api/file-system-router.md → runtime/file-system-router.mdx} +8 -2
- package/docs/{bundler/loaders.md → runtime/file-types.mdx} +56 -112
- package/docs/{api/glob.md → runtime/glob.mdx} +4 -1
- package/docs/runtime/globals.mdx +72 -0
- package/docs/{api/hashing.md → runtime/hashing.mdx} +18 -22
- package/docs/{api/html-rewriter.md → runtime/html-rewriter.mdx} +36 -30
- package/docs/runtime/http/cookies.mdx +79 -0
- package/docs/runtime/http/error-handling.mdx +40 -0
- package/docs/runtime/http/metrics.mdx +36 -0
- package/docs/runtime/http/routing.mdx +289 -0
- package/docs/runtime/http/server.mdx +647 -0
- package/docs/runtime/http/tls.mdx +101 -0
- package/docs/{api/websockets.md → runtime/http/websockets.mdx} +62 -231
- package/docs/{cli/run.md → runtime/index.mdx} +70 -108
- package/docs/runtime/jsx.mdx +115 -0
- package/docs/runtime/{modules.md → module-resolution.mdx} +83 -61
- package/docs/{api/dns.md → runtime/networking/dns.mdx} +23 -22
- package/docs/{api/fetch.md → runtime/networking/fetch.mdx} +10 -5
- package/docs/{api/tcp.md → runtime/networking/tcp.mdx} +59 -41
- package/docs/{api/udp.md → runtime/networking/udp.mdx} +14 -8
- package/docs/{api/node-api.md → runtime/node-api.mdx} +5 -0
- package/docs/runtime/{nodejs-apis.md → nodejs-compat.mdx} +9 -4
- package/docs/{bundler/plugins.md → runtime/plugins.mdx} +17 -61
- package/docs/{api/redis.md → runtime/redis.mdx} +65 -80
- package/docs/{api/s3.md → runtime/s3.mdx} +79 -66
- package/docs/{api/secrets.md → runtime/secrets.mdx} +27 -10
- package/docs/{api/semver.md → runtime/semver.mdx} +9 -4
- package/docs/runtime/{shell.md → shell.mdx} +52 -20
- package/docs/{api/sql.md → runtime/sql.mdx} +129 -99
- package/docs/{api/sqlite.md → runtime/sqlite.mdx} +162 -157
- package/docs/{api/streams.md → runtime/streams.mdx} +33 -31
- package/docs/{cli/bun-create.md → runtime/templating/create.mdx} +74 -143
- package/docs/{cli/init.md → runtime/templating/init.mdx} +24 -51
- package/docs/{api/transpiler.md → runtime/transpiler.mdx} +50 -38
- package/docs/{typescript.md → runtime/typescript.mdx} +7 -2
- package/docs/{api/utils.md → runtime/utils.mdx} +81 -50
- package/docs/runtime/{hot.md → watch-mode.mdx} +53 -37
- package/docs/runtime/web-apis.mdx +29 -0
- package/docs/{api/workers.md → runtime/workers.mdx} +28 -22
- package/docs/{api/yaml.md → runtime/yaml.mdx} +33 -232
- package/docs/snippets/cli/add.mdx +166 -0
- package/docs/snippets/cli/build.mdx +196 -0
- package/docs/snippets/cli/feedback.mdx +17 -0
- package/docs/snippets/cli/init.mdx +84 -0
- package/docs/snippets/cli/install.mdx +173 -0
- package/docs/snippets/cli/link.mdx +163 -0
- package/docs/snippets/cli/outdated.mdx +140 -0
- package/docs/snippets/cli/patch.mdx +171 -0
- package/docs/snippets/cli/publish.mdx +198 -0
- package/docs/snippets/cli/remove.mdx +146 -0
- package/docs/snippets/cli/run.mdx +293 -0
- package/docs/snippets/cli/test.mdx +100 -0
- package/docs/snippets/cli/update.mdx +144 -0
- package/docs/snippets/product-card.mdx +32 -0
- package/docs/snippets/product-tiles.mdx +94 -0
- package/docs/test/code-coverage.mdx +409 -0
- package/docs/test/configuration.mdx +467 -0
- package/docs/test/{time.md → dates-times.mdx} +23 -20
- package/docs/test/{discovery.md → discovery.mdx} +15 -10
- package/docs/test/dom.mdx +226 -0
- package/docs/{cli/test.md → test/index.mdx} +77 -94
- package/docs/test/lifecycle.mdx +348 -0
- package/docs/test/mocks.mdx +637 -0
- package/docs/test/{reporters.md → reporters.mdx} +15 -15
- package/docs/test/runtime-behavior.mdx +342 -0
- package/docs/test/snapshots.mdx +434 -0
- package/docs/test/writing-tests.mdx +635 -0
- package/docs/typescript.mdx +54 -0
- package/package.json +8 -6
- package/test.d.ts +2 -2
- package/docs/api/file.md +0 -19
- package/docs/api/globals.md +0 -387
- package/docs/api/http.md +0 -1408
- package/docs/api/import-meta.md +0 -69
- package/docs/benchmarks.md +0 -120
- package/docs/bun-flavored-toml.md +0 -42
- package/docs/bundler/css_modules.md +0 -145
- package/docs/bundler/fullstack.md +0 -418
- package/docs/bundler/index.md +0 -1735
- package/docs/bundler/intro.md +0 -75
- package/docs/bundler/vs-esbuild.md +0 -1127
- package/docs/cli/bun-completions.md +0 -3
- package/docs/cli/bun-install.md +0 -349
- package/docs/cli/bun-upgrade.md +0 -39
- package/docs/cli/info.md +0 -65
- package/docs/cli/patch-commit.md +0 -11
- package/docs/cli/remove.md +0 -7
- package/docs/cli/unlink.md +0 -9
- package/docs/contributing/upgrading-webkit.md +0 -57
- package/docs/ecosystem/elysia.md +0 -24
- package/docs/ecosystem/express.md +0 -37
- package/docs/ecosystem/hono.md +0 -18
- package/docs/ecosystem/react.md +0 -65
- package/docs/ecosystem/stric.md +0 -38
- package/docs/guides/ecosystem/prisma.md +0 -141
- package/docs/guides/ecosystem/render.md +0 -79
- package/docs/guides/install/add-git.md +0 -36
- package/docs/guides/test/spy-on.md +0 -46
- package/docs/install/index.md +0 -248
- package/docs/installation.md +0 -327
- package/docs/project/asan.md +0 -124
- package/docs/project/internals/build-process-for-ci.md +0 -75
- package/docs/project/licensing.md +0 -73
- package/docs/project/roadmap.md +0 -87
- package/docs/quickstart.md +0 -157
- package/docs/runtime/bun-apis.md +0 -207
- package/docs/runtime/env.md +0 -253
- package/docs/runtime/index.md +0 -312
- package/docs/runtime/jsx.md +0 -385
- package/docs/runtime/loaders.md +0 -130
- package/docs/runtime/plugins.md +0 -561
- package/docs/runtime/typescript.md +0 -139
- package/docs/runtime/web-apis.md +0 -128
- package/docs/test/configuration.md +0 -154
- package/docs/test/coverage.md +0 -142
- package/docs/test/dom.md +0 -75
- package/docs/test/examples/concurrent-test-glob.md +0 -132
- package/docs/test/hot.md +0 -15
- package/docs/test/lifecycle.md +0 -81
- package/docs/test/mocks.md +0 -313
- package/docs/test/runtime-behavior.md +0 -95
- package/docs/test/snapshots.md +0 -68
- package/docs/test/writing.md +0 -825
|
@@ -1,418 +0,0 @@
|
|
|
1
|
-
To get started, import HTML files and pass them to the `routes` option in `Bun.serve()`.
|
|
2
|
-
|
|
3
|
-
```ts
|
|
4
|
-
import { sql, serve } from "bun";
|
|
5
|
-
import dashboard from "./dashboard.html";
|
|
6
|
-
import homepage from "./index.html";
|
|
7
|
-
|
|
8
|
-
const server = serve({
|
|
9
|
-
routes: {
|
|
10
|
-
// ** HTML imports **
|
|
11
|
-
// Bundle & route index.html to "/". This uses HTMLRewriter to scan the HTML for `<script>` and `<link>` tags, run's Bun's JavaScript & CSS bundler on them, transpiles any TypeScript, JSX, and TSX, downlevels CSS with Bun's CSS parser and serves the result.
|
|
12
|
-
"/": homepage,
|
|
13
|
-
// Bundle & route dashboard.html to "/dashboard"
|
|
14
|
-
"/dashboard": dashboard,
|
|
15
|
-
|
|
16
|
-
// ** API endpoints ** (Bun v1.2.3+ required)
|
|
17
|
-
"/api/users": {
|
|
18
|
-
async GET(req) {
|
|
19
|
-
const users = await sql`SELECT * FROM users`;
|
|
20
|
-
return Response.json(users);
|
|
21
|
-
},
|
|
22
|
-
async POST(req) {
|
|
23
|
-
const { name, email } = await req.json();
|
|
24
|
-
const [user] =
|
|
25
|
-
await sql`INSERT INTO users (name, email) VALUES (${name}, ${email})`;
|
|
26
|
-
return Response.json(user);
|
|
27
|
-
},
|
|
28
|
-
},
|
|
29
|
-
"/api/users/:id": async req => {
|
|
30
|
-
const { id } = req.params;
|
|
31
|
-
const [user] = await sql`SELECT * FROM users WHERE id = ${id}`;
|
|
32
|
-
return Response.json(user);
|
|
33
|
-
},
|
|
34
|
-
},
|
|
35
|
-
|
|
36
|
-
// Enable development mode for:
|
|
37
|
-
// - Detailed error messages
|
|
38
|
-
// - Hot reloading (Bun v1.2.3+ required)
|
|
39
|
-
development: true,
|
|
40
|
-
|
|
41
|
-
// Prior to v1.2.3, the `fetch` option was used to handle all API requests. It is now optional.
|
|
42
|
-
// async fetch(req) {
|
|
43
|
-
// // Return 404 for unmatched routes
|
|
44
|
-
// return new Response("Not Found", { status: 404 });
|
|
45
|
-
// },
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
console.log(`Listening on ${server.url}`);
|
|
49
|
-
```
|
|
50
|
-
|
|
51
|
-
```bash
|
|
52
|
-
$ bun run app.ts
|
|
53
|
-
```
|
|
54
|
-
|
|
55
|
-
## HTML imports are routes
|
|
56
|
-
|
|
57
|
-
The web starts with HTML, and so does Bun's fullstack dev server.
|
|
58
|
-
|
|
59
|
-
To specify entrypoints to your frontend, import HTML files into your JavaScript/TypeScript/TSX/JSX files.
|
|
60
|
-
|
|
61
|
-
```ts
|
|
62
|
-
import dashboard from "./dashboard.html";
|
|
63
|
-
import homepage from "./index.html";
|
|
64
|
-
```
|
|
65
|
-
|
|
66
|
-
These HTML files are used as routes in Bun's dev server you can pass to `Bun.serve()`.
|
|
67
|
-
|
|
68
|
-
```ts
|
|
69
|
-
Bun.serve({
|
|
70
|
-
routes: {
|
|
71
|
-
"/": homepage,
|
|
72
|
-
"/dashboard": dashboard,
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
fetch(req) {
|
|
76
|
-
// ... api requests
|
|
77
|
-
},
|
|
78
|
-
});
|
|
79
|
-
```
|
|
80
|
-
|
|
81
|
-
When you make a request to `/dashboard` or `/`, Bun automatically bundles the `<script>` and `<link>` tags in the HTML files, exposes them as static routes, and serves the result.
|
|
82
|
-
|
|
83
|
-
An index.html file like this:
|
|
84
|
-
|
|
85
|
-
```html#index.html
|
|
86
|
-
<!DOCTYPE html>
|
|
87
|
-
<html>
|
|
88
|
-
<head>
|
|
89
|
-
<title>Home</title>
|
|
90
|
-
<link rel="stylesheet" href="./reset.css" />
|
|
91
|
-
<link rel="stylesheet" href="./styles.css" />
|
|
92
|
-
</head>
|
|
93
|
-
<body>
|
|
94
|
-
<div id="root"></div>
|
|
95
|
-
<script type="module" src="./sentry-and-preloads.ts"></script>
|
|
96
|
-
<script type="module" src="./my-app.tsx"></script>
|
|
97
|
-
</body>
|
|
98
|
-
</html>
|
|
99
|
-
```
|
|
100
|
-
|
|
101
|
-
Becomes something like this:
|
|
102
|
-
|
|
103
|
-
```html#index.html
|
|
104
|
-
<!DOCTYPE html>
|
|
105
|
-
<html>
|
|
106
|
-
<head>
|
|
107
|
-
<title>Home</title>
|
|
108
|
-
<link rel="stylesheet" href="/index-[hash].css" />
|
|
109
|
-
</head>
|
|
110
|
-
<body>
|
|
111
|
-
<div id="root"></div>
|
|
112
|
-
<script type="module" src="/index-[hash].js"></script>
|
|
113
|
-
</body>
|
|
114
|
-
</html>
|
|
115
|
-
```
|
|
116
|
-
|
|
117
|
-
### How to use with React
|
|
118
|
-
|
|
119
|
-
To use React in your client-side code, import `react-dom/client` and render your app.
|
|
120
|
-
|
|
121
|
-
{% codetabs %}
|
|
122
|
-
|
|
123
|
-
```ts#src/backend.ts
|
|
124
|
-
import dashboard from "../public/dashboard.html";
|
|
125
|
-
import { serve } from "bun";
|
|
126
|
-
|
|
127
|
-
serve({
|
|
128
|
-
routes: {
|
|
129
|
-
"/": dashboard,
|
|
130
|
-
},
|
|
131
|
-
|
|
132
|
-
async fetch(req) {
|
|
133
|
-
// ...api requests
|
|
134
|
-
return new Response("hello world");
|
|
135
|
-
},
|
|
136
|
-
});
|
|
137
|
-
```
|
|
138
|
-
|
|
139
|
-
```ts#src/frontend.tsx
|
|
140
|
-
import "./styles.css";
|
|
141
|
-
import { createRoot } from "react-dom/client";
|
|
142
|
-
import { App } from "./app.tsx";
|
|
143
|
-
|
|
144
|
-
document.addEventListener("DOMContentLoaded", () => {
|
|
145
|
-
const root = createRoot(document.getElementById("root"));
|
|
146
|
-
root.render(<App />);
|
|
147
|
-
});
|
|
148
|
-
```
|
|
149
|
-
|
|
150
|
-
```html#public/dashboard.html
|
|
151
|
-
<!DOCTYPE html>
|
|
152
|
-
<html>
|
|
153
|
-
<head>
|
|
154
|
-
<title>Dashboard</title>
|
|
155
|
-
</head>
|
|
156
|
-
<body>
|
|
157
|
-
<div id="root"></div>
|
|
158
|
-
<script type="module" src="../src/frontend.tsx"></script>
|
|
159
|
-
</body>
|
|
160
|
-
</html>
|
|
161
|
-
```
|
|
162
|
-
|
|
163
|
-
```css#src/styles.css
|
|
164
|
-
body {
|
|
165
|
-
background-color: red;
|
|
166
|
-
}
|
|
167
|
-
```
|
|
168
|
-
|
|
169
|
-
```tsx#src/app.tsx
|
|
170
|
-
export function App() {
|
|
171
|
-
return <div>Hello World</div>;
|
|
172
|
-
}
|
|
173
|
-
```
|
|
174
|
-
|
|
175
|
-
{% /codetabs %}
|
|
176
|
-
|
|
177
|
-
### Development mode
|
|
178
|
-
|
|
179
|
-
When building locally, enable development mode by setting `development: true` in `Bun.serve()`.
|
|
180
|
-
|
|
181
|
-
```js-diff
|
|
182
|
-
import homepage from "./index.html";
|
|
183
|
-
import dashboard from "./dashboard.html";
|
|
184
|
-
|
|
185
|
-
Bun.serve({
|
|
186
|
-
routes: {
|
|
187
|
-
"/": homepage,
|
|
188
|
-
"/dashboard": dashboard,
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
+ development: true,
|
|
192
|
-
|
|
193
|
-
fetch(req) {
|
|
194
|
-
// ... api requests
|
|
195
|
-
},
|
|
196
|
-
});
|
|
197
|
-
```
|
|
198
|
-
|
|
199
|
-
When `development` is `true`, Bun will:
|
|
200
|
-
|
|
201
|
-
- Include the `SourceMap` header in the response so that devtools can show the original source code
|
|
202
|
-
- Disable minification
|
|
203
|
-
- Re-bundle assets on each request to a .html file
|
|
204
|
-
- Enable hot module reloading (unless `hmr: false` is set)
|
|
205
|
-
|
|
206
|
-
#### Echo console logs from browser to terminal
|
|
207
|
-
|
|
208
|
-
Bun.serve() supports echoing console logs from the browser to the terminal.
|
|
209
|
-
|
|
210
|
-
To enable this, pass `console: true` in the `development` object in `Bun.serve()`.
|
|
211
|
-
|
|
212
|
-
```ts
|
|
213
|
-
import homepage from "./index.html";
|
|
214
|
-
|
|
215
|
-
Bun.serve({
|
|
216
|
-
// development can also be an object.
|
|
217
|
-
development: {
|
|
218
|
-
// Enable Hot Module Reloading
|
|
219
|
-
hmr: true,
|
|
220
|
-
|
|
221
|
-
// Echo console logs from the browser to the terminal
|
|
222
|
-
console: true,
|
|
223
|
-
},
|
|
224
|
-
|
|
225
|
-
routes: {
|
|
226
|
-
"/": homepage,
|
|
227
|
-
},
|
|
228
|
-
});
|
|
229
|
-
```
|
|
230
|
-
|
|
231
|
-
When `console: true` is set, Bun will stream console logs from the browser to the terminal. This reuses the existing WebSocket connection from HMR to send the logs.
|
|
232
|
-
|
|
233
|
-
#### Production mode
|
|
234
|
-
|
|
235
|
-
Hot reloading and `development: true` helps you iterate quickly, but in production, your server should be as fast as possible and have as few external dependencies as possible.
|
|
236
|
-
|
|
237
|
-
##### Ahead of time bundling (recommended)
|
|
238
|
-
|
|
239
|
-
As of Bun v1.2.17, you can use `Bun.build` or `bun build` to bundle your full-stack application ahead of time.
|
|
240
|
-
|
|
241
|
-
```sh
|
|
242
|
-
$ bun build --target=bun --production --outdir=dist ./src/index.ts
|
|
243
|
-
```
|
|
244
|
-
|
|
245
|
-
When Bun's bundler sees an HTML import from server-side code, it will bundle the referenced JavaScript/TypeScript/TSX/JSX and CSS files into a manifest object that Bun.serve() can use to serve the assets.
|
|
246
|
-
|
|
247
|
-
```ts
|
|
248
|
-
import { serve } from "bun";
|
|
249
|
-
import index from "./index.html";
|
|
250
|
-
|
|
251
|
-
serve({
|
|
252
|
-
routes: { "/": index },
|
|
253
|
-
});
|
|
254
|
-
```
|
|
255
|
-
|
|
256
|
-
{% details summary="Internally, the `index` variable is a manifest object that looks something like this" %}
|
|
257
|
-
|
|
258
|
-
```json
|
|
259
|
-
{
|
|
260
|
-
"index": "./index.html",
|
|
261
|
-
"files": [
|
|
262
|
-
{
|
|
263
|
-
"input": "index.html",
|
|
264
|
-
"path": "./index-f2me3qnf.js",
|
|
265
|
-
"loader": "js",
|
|
266
|
-
"isEntry": true,
|
|
267
|
-
"headers": {
|
|
268
|
-
"etag": "eet6gn75",
|
|
269
|
-
"content-type": "text/javascript;charset=utf-8"
|
|
270
|
-
}
|
|
271
|
-
},
|
|
272
|
-
{
|
|
273
|
-
"input": "index.html",
|
|
274
|
-
"path": "./index.html",
|
|
275
|
-
"loader": "html",
|
|
276
|
-
"isEntry": true,
|
|
277
|
-
"headers": {
|
|
278
|
-
"etag": "r9njjakd",
|
|
279
|
-
"content-type": "text/html;charset=utf-8"
|
|
280
|
-
}
|
|
281
|
-
},
|
|
282
|
-
{
|
|
283
|
-
"input": "index.html",
|
|
284
|
-
"path": "./index-gysa5fmk.css",
|
|
285
|
-
"loader": "css",
|
|
286
|
-
"isEntry": true,
|
|
287
|
-
"headers": {
|
|
288
|
-
"etag": "50zb7x61",
|
|
289
|
-
"content-type": "text/css;charset=utf-8"
|
|
290
|
-
}
|
|
291
|
-
},
|
|
292
|
-
{
|
|
293
|
-
"input": "logo.svg",
|
|
294
|
-
"path": "./logo-kygw735p.svg",
|
|
295
|
-
"loader": "file",
|
|
296
|
-
"isEntry": false,
|
|
297
|
-
"headers": {
|
|
298
|
-
"etag": "kygw735p",
|
|
299
|
-
"content-type": "application/octet-stream"
|
|
300
|
-
}
|
|
301
|
-
},
|
|
302
|
-
{
|
|
303
|
-
"input": "react.svg",
|
|
304
|
-
"path": "./react-ck11dneg.svg",
|
|
305
|
-
"loader": "file",
|
|
306
|
-
"isEntry": false,
|
|
307
|
-
"headers": {
|
|
308
|
-
"etag": "ck11dneg",
|
|
309
|
-
"content-type": "application/octet-stream"
|
|
310
|
-
}
|
|
311
|
-
}
|
|
312
|
-
]
|
|
313
|
-
}
|
|
314
|
-
```
|
|
315
|
-
|
|
316
|
-
{% /details %}
|
|
317
|
-
|
|
318
|
-
##### Runtime bundling
|
|
319
|
-
|
|
320
|
-
When adding a build step is too complicated, you can set `development: false` in `Bun.serve()`.
|
|
321
|
-
|
|
322
|
-
- Enable in-memory caching of bundled assets. Bun will bundle assets lazily on the first request to an `.html` file, and cache the result in memory until the server restarts.
|
|
323
|
-
- Enables `Cache-Control` headers and `ETag` headers
|
|
324
|
-
- Minifies JavaScript/TypeScript/TSX/JSX files
|
|
325
|
-
|
|
326
|
-
## Plugins
|
|
327
|
-
|
|
328
|
-
Bun's [bundler plugins](https://bun.com/docs/bundler/plugins) are also supported when bundling static routes.
|
|
329
|
-
|
|
330
|
-
To configure plugins for `Bun.serve`, add a `plugins` array in the `[serve.static]` section of your `bunfig.toml`.
|
|
331
|
-
|
|
332
|
-
### Using TailwindCSS in HTML routes
|
|
333
|
-
|
|
334
|
-
For example, enable TailwindCSS on your routes by installing and adding the `bun-plugin-tailwind` plugin:
|
|
335
|
-
|
|
336
|
-
```sh
|
|
337
|
-
$ bun add bun-plugin-tailwind
|
|
338
|
-
```
|
|
339
|
-
|
|
340
|
-
```toml#bunfig.toml
|
|
341
|
-
[serve.static]
|
|
342
|
-
plugins = ["bun-plugin-tailwind"]
|
|
343
|
-
```
|
|
344
|
-
|
|
345
|
-
This will allow you to use TailwindCSS utility classes in your HTML and CSS files. All you need to do is import `tailwindcss` somewhere:
|
|
346
|
-
|
|
347
|
-
```html#index.html
|
|
348
|
-
<!doctype html>
|
|
349
|
-
<html>
|
|
350
|
-
<head>
|
|
351
|
-
<title>Home</title>
|
|
352
|
-
<link rel="stylesheet" href="tailwindcss" />
|
|
353
|
-
</head>
|
|
354
|
-
<body>
|
|
355
|
-
<!-- the rest of your HTML... -->
|
|
356
|
-
</body>
|
|
357
|
-
</html>
|
|
358
|
-
```
|
|
359
|
-
|
|
360
|
-
Or in your CSS:
|
|
361
|
-
|
|
362
|
-
```css#style.css
|
|
363
|
-
@import "tailwindcss";
|
|
364
|
-
```
|
|
365
|
-
|
|
366
|
-
### Custom plugins
|
|
367
|
-
|
|
368
|
-
Any JS file or module which exports a [valid bundler plugin object](https://bun.com/docs/bundler/plugins#usage) (essentially an object with a `name` and `setup` field) can be placed inside the `plugins` array:
|
|
369
|
-
|
|
370
|
-
```toml#bunfig.toml
|
|
371
|
-
[serve.static]
|
|
372
|
-
plugins = ["./my-plugin-implementation.ts"]
|
|
373
|
-
```
|
|
374
|
-
|
|
375
|
-
Bun will lazily resolve and load each plugin and use them to bundle your routes.
|
|
376
|
-
|
|
377
|
-
Note: this is currently in `bunfig.toml` to make it possible to know statically which plugins are in use when we eventually integrate this with the `bun build` CLI. These plugins work in `Bun.build()`'s JS API, but are not yet supported in the CLI.
|
|
378
|
-
|
|
379
|
-
## How this works
|
|
380
|
-
|
|
381
|
-
Bun uses [`HTMLRewriter`](/docs/api/html-rewriter) to scan for `<script>` and `<link>` tags in HTML files, uses them as entrypoints for [Bun's bundler](/docs/bundler), generates an optimized bundle for the JavaScript/TypeScript/TSX/JSX and CSS files, and serves the result.
|
|
382
|
-
|
|
383
|
-
1. **`<script>` processing**
|
|
384
|
-
- Transpiles TypeScript, JSX, and TSX in `<script>` tags
|
|
385
|
-
- Bundles imported dependencies
|
|
386
|
-
- Generates sourcemaps for debugging
|
|
387
|
-
- Minifies when `development` is not `true` in `Bun.serve()`
|
|
388
|
-
|
|
389
|
-
```html
|
|
390
|
-
<script type="module" src="./counter.tsx"></script>
|
|
391
|
-
```
|
|
392
|
-
|
|
393
|
-
2. **`<link>` processing**
|
|
394
|
-
- Processes CSS imports and `<link>` tags
|
|
395
|
-
- Concatenates CSS files
|
|
396
|
-
- Rewrites `url` and asset paths to include content-addressable hashes in URLs
|
|
397
|
-
|
|
398
|
-
```html
|
|
399
|
-
<link rel="stylesheet" href="./styles.css" />
|
|
400
|
-
```
|
|
401
|
-
|
|
402
|
-
3. **`<img>` & asset processing**
|
|
403
|
-
- Links to assets are rewritten to include content-addressable hashes in URLs
|
|
404
|
-
- Small assets in CSS files are inlined into `data:` URLs, reducing the total number of HTTP requests sent over the wire
|
|
405
|
-
|
|
406
|
-
4. **Rewrite HTML**
|
|
407
|
-
- Combines all `<script>` tags into a single `<script>` tag with a content-addressable hash in the URL
|
|
408
|
-
- Combines all `<link>` tags into a single `<link>` tag with a content-addressable hash in the URL
|
|
409
|
-
- Outputs a new HTML file
|
|
410
|
-
|
|
411
|
-
5. **Serve**
|
|
412
|
-
- All the output files from the bundler are exposed as static routes, using the same mechanism internally as when you pass a `Response` object to [`static` in `Bun.serve()`](/docs/api/http#static-routes).
|
|
413
|
-
|
|
414
|
-
This works similarly to how [`Bun.build` processes HTML files](/docs/bundler/html).
|
|
415
|
-
|
|
416
|
-
## This is a work in progress
|
|
417
|
-
|
|
418
|
-
- This doesn't support `bun build` yet. It also will in the future.
|