bun-types 1.3.2-canary.20251105T140650 → 1.3.2-canary.20251106T140813

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 (308) hide show
  1. package/docs/README.md +28 -0
  2. package/package.json +1 -1
  3. package/docs/api/binary-data.md +0 -1038
  4. package/docs/api/cc.md +0 -197
  5. package/docs/api/color.md +0 -262
  6. package/docs/api/console.md +0 -57
  7. package/docs/api/cookie.md +0 -449
  8. package/docs/api/dns.md +0 -110
  9. package/docs/api/fetch.md +0 -463
  10. package/docs/api/ffi.md +0 -557
  11. package/docs/api/file-io.md +0 -366
  12. package/docs/api/file-system-router.md +0 -112
  13. package/docs/api/file.md +0 -19
  14. package/docs/api/glob.md +0 -178
  15. package/docs/api/globals.md +0 -387
  16. package/docs/api/hashing.md +0 -319
  17. package/docs/api/html-rewriter.md +0 -334
  18. package/docs/api/http.md +0 -1408
  19. package/docs/api/import-meta.md +0 -69
  20. package/docs/api/node-api.md +0 -14
  21. package/docs/api/redis.md +0 -597
  22. package/docs/api/s3.md +0 -850
  23. package/docs/api/secrets.md +0 -319
  24. package/docs/api/semver.md +0 -52
  25. package/docs/api/spawn.md +0 -582
  26. package/docs/api/sql.md +0 -1374
  27. package/docs/api/sqlite.md +0 -694
  28. package/docs/api/streams.md +0 -230
  29. package/docs/api/tcp.md +0 -221
  30. package/docs/api/transpiler.md +0 -276
  31. package/docs/api/udp.md +0 -123
  32. package/docs/api/utils.md +0 -891
  33. package/docs/api/websockets.md +0 -573
  34. package/docs/api/workers.md +0 -322
  35. package/docs/api/yaml.md +0 -668
  36. package/docs/benchmarks.md +0 -120
  37. package/docs/bun-flavored-toml.md +0 -42
  38. package/docs/bundler/css.md +0 -1028
  39. package/docs/bundler/css_modules.md +0 -145
  40. package/docs/bundler/executables.md +0 -626
  41. package/docs/bundler/fullstack.md +0 -418
  42. package/docs/bundler/hmr.md +0 -234
  43. package/docs/bundler/html.md +0 -349
  44. package/docs/bundler/index.md +0 -1735
  45. package/docs/bundler/intro.md +0 -75
  46. package/docs/bundler/loaders.md +0 -410
  47. package/docs/bundler/macros.md +0 -329
  48. package/docs/bundler/plugins.md +0 -449
  49. package/docs/bundler/vs-esbuild.md +0 -1127
  50. package/docs/cli/add.md +0 -173
  51. package/docs/cli/bun-completions.md +0 -3
  52. package/docs/cli/bun-create.md +0 -338
  53. package/docs/cli/bun-install.md +0 -349
  54. package/docs/cli/bun-upgrade.md +0 -39
  55. package/docs/cli/bunx.md +0 -89
  56. package/docs/cli/filter.md +0 -90
  57. package/docs/cli/info.md +0 -65
  58. package/docs/cli/init.md +0 -85
  59. package/docs/cli/install.md +0 -344
  60. package/docs/cli/link.md +0 -40
  61. package/docs/cli/outdated.md +0 -90
  62. package/docs/cli/patch-commit.md +0 -11
  63. package/docs/cli/pm.md +0 -285
  64. package/docs/cli/publish.md +0 -120
  65. package/docs/cli/remove.md +0 -7
  66. package/docs/cli/run.md +0 -261
  67. package/docs/cli/test.md +0 -397
  68. package/docs/cli/unlink.md +0 -9
  69. package/docs/cli/update.md +0 -129
  70. package/docs/cli/why.md +0 -67
  71. package/docs/contributing/upgrading-webkit.md +0 -57
  72. package/docs/ecosystem/elysia.md +0 -24
  73. package/docs/ecosystem/express.md +0 -37
  74. package/docs/ecosystem/hono.md +0 -18
  75. package/docs/ecosystem/react.md +0 -65
  76. package/docs/ecosystem/stric.md +0 -38
  77. package/docs/guides/binary/arraybuffer-to-array.md +0 -27
  78. package/docs/guides/binary/arraybuffer-to-blob.md +0 -24
  79. package/docs/guides/binary/arraybuffer-to-buffer.md +0 -25
  80. package/docs/guides/binary/arraybuffer-to-string.md +0 -15
  81. package/docs/guides/binary/arraybuffer-to-typedarray.md +0 -39
  82. package/docs/guides/binary/blob-to-arraybuffer.md +0 -14
  83. package/docs/guides/binary/blob-to-dataview.md +0 -14
  84. package/docs/guides/binary/blob-to-stream.md +0 -14
  85. package/docs/guides/binary/blob-to-string.md +0 -15
  86. package/docs/guides/binary/blob-to-typedarray.md +0 -14
  87. package/docs/guides/binary/buffer-to-arraybuffer.md +0 -14
  88. package/docs/guides/binary/buffer-to-blob.md +0 -14
  89. package/docs/guides/binary/buffer-to-readablestream.md +0 -41
  90. package/docs/guides/binary/buffer-to-string.md +0 -25
  91. package/docs/guides/binary/buffer-to-typedarray.md +0 -14
  92. package/docs/guides/binary/dataview-to-string.md +0 -15
  93. package/docs/guides/binary/typedarray-to-arraybuffer.md +0 -25
  94. package/docs/guides/binary/typedarray-to-blob.md +0 -16
  95. package/docs/guides/binary/typedarray-to-buffer.md +0 -14
  96. package/docs/guides/binary/typedarray-to-dataview.md +0 -14
  97. package/docs/guides/binary/typedarray-to-readablestream.md +0 -41
  98. package/docs/guides/binary/typedarray-to-string.md +0 -16
  99. package/docs/guides/deployment/railway.md +0 -157
  100. package/docs/guides/ecosystem/astro.md +0 -72
  101. package/docs/guides/ecosystem/discordjs.md +0 -77
  102. package/docs/guides/ecosystem/docker.md +0 -140
  103. package/docs/guides/ecosystem/drizzle.md +0 -185
  104. package/docs/guides/ecosystem/edgedb.md +0 -228
  105. package/docs/guides/ecosystem/elysia.md +0 -31
  106. package/docs/guides/ecosystem/express.md +0 -40
  107. package/docs/guides/ecosystem/hono.md +0 -39
  108. package/docs/guides/ecosystem/mongoose.md +0 -87
  109. package/docs/guides/ecosystem/neon-drizzle.md +0 -220
  110. package/docs/guides/ecosystem/neon-serverless-postgres.md +0 -55
  111. package/docs/guides/ecosystem/nextjs.md +0 -49
  112. package/docs/guides/ecosystem/nuxt.md +0 -56
  113. package/docs/guides/ecosystem/pm2.md +0 -57
  114. package/docs/guides/ecosystem/prisma.md +0 -141
  115. package/docs/guides/ecosystem/qwik.md +0 -107
  116. package/docs/guides/ecosystem/react.md +0 -50
  117. package/docs/guides/ecosystem/remix.md +0 -78
  118. package/docs/guides/ecosystem/render.md +0 -79
  119. package/docs/guides/ecosystem/sentry.md +0 -52
  120. package/docs/guides/ecosystem/solidstart.md +0 -58
  121. package/docs/guides/ecosystem/ssr-react.md +0 -51
  122. package/docs/guides/ecosystem/stric.md +0 -55
  123. package/docs/guides/ecosystem/sveltekit.md +0 -125
  124. package/docs/guides/ecosystem/systemd.md +0 -113
  125. package/docs/guides/ecosystem/vite.md +0 -71
  126. package/docs/guides/html-rewriter/extract-links.md +0 -68
  127. package/docs/guides/html-rewriter/extract-social-meta.md +0 -93
  128. package/docs/guides/http/cluster.md +0 -66
  129. package/docs/guides/http/fetch-unix.md +0 -33
  130. package/docs/guides/http/fetch.md +0 -24
  131. package/docs/guides/http/file-uploads.md +0 -94
  132. package/docs/guides/http/hot.md +0 -26
  133. package/docs/guides/http/proxy.md +0 -24
  134. package/docs/guides/http/server.md +0 -46
  135. package/docs/guides/http/simple.md +0 -18
  136. package/docs/guides/http/stream-file.md +0 -48
  137. package/docs/guides/http/stream-iterator.md +0 -47
  138. package/docs/guides/http/stream-node-streams-in-bun.md +0 -20
  139. package/docs/guides/http/tls.md +0 -30
  140. package/docs/guides/install/add-dev.md +0 -26
  141. package/docs/guides/install/add-git.md +0 -36
  142. package/docs/guides/install/add-optional.md +0 -25
  143. package/docs/guides/install/add-peer.md +0 -43
  144. package/docs/guides/install/add-tarball.md +0 -33
  145. package/docs/guides/install/add.md +0 -42
  146. package/docs/guides/install/azure-artifacts.md +0 -73
  147. package/docs/guides/install/cicd.md +0 -41
  148. package/docs/guides/install/custom-registry.md +0 -30
  149. package/docs/guides/install/from-npm-install-to-bun-install.md +0 -214
  150. package/docs/guides/install/git-diff-bun-lockfile.md +0 -44
  151. package/docs/guides/install/jfrog-artifactory.md +0 -28
  152. package/docs/guides/install/npm-alias.md +0 -23
  153. package/docs/guides/install/registry-scope.md +0 -38
  154. package/docs/guides/install/trusted.md +0 -46
  155. package/docs/guides/install/workspaces.md +0 -70
  156. package/docs/guides/install/yarnlock.md +0 -44
  157. package/docs/guides/process/argv.md +0 -58
  158. package/docs/guides/process/ctrl-c.md +0 -16
  159. package/docs/guides/process/ipc.md +0 -66
  160. package/docs/guides/process/nanoseconds.md +0 -13
  161. package/docs/guides/process/os-signals.md +0 -39
  162. package/docs/guides/process/spawn-stderr.md +0 -31
  163. package/docs/guides/process/spawn-stdout.md +0 -26
  164. package/docs/guides/process/spawn.md +0 -41
  165. package/docs/guides/process/stdin.md +0 -54
  166. package/docs/guides/read-file/arraybuffer.md +0 -28
  167. package/docs/guides/read-file/buffer.md +0 -19
  168. package/docs/guides/read-file/exists.md +0 -16
  169. package/docs/guides/read-file/json.md +0 -17
  170. package/docs/guides/read-file/mime.md +0 -20
  171. package/docs/guides/read-file/stream.md +0 -26
  172. package/docs/guides/read-file/string.md +0 -22
  173. package/docs/guides/read-file/uint8array.md +0 -21
  174. package/docs/guides/read-file/watch.md +0 -68
  175. package/docs/guides/runtime/build-time-constants.md +0 -293
  176. package/docs/guides/runtime/cicd.md +0 -43
  177. package/docs/guides/runtime/codesign-macos-executable.md +0 -56
  178. package/docs/guides/runtime/define-constant.md +0 -145
  179. package/docs/guides/runtime/delete-directory.md +0 -37
  180. package/docs/guides/runtime/delete-file.md +0 -19
  181. package/docs/guides/runtime/heap-snapshot.md +0 -26
  182. package/docs/guides/runtime/import-html.md +0 -15
  183. package/docs/guides/runtime/import-json.md +0 -44
  184. package/docs/guides/runtime/import-toml.md +0 -30
  185. package/docs/guides/runtime/import-yaml.md +0 -102
  186. package/docs/guides/runtime/read-env.md +0 -32
  187. package/docs/guides/runtime/set-env.md +0 -47
  188. package/docs/guides/runtime/shell.md +0 -40
  189. package/docs/guides/runtime/timezone.md +0 -35
  190. package/docs/guides/runtime/tsconfig-paths.md +0 -29
  191. package/docs/guides/runtime/typescript.md +0 -49
  192. package/docs/guides/runtime/vscode-debugger.md +0 -47
  193. package/docs/guides/runtime/web-debugger.md +0 -82
  194. package/docs/guides/streams/node-readable-to-arraybuffer.md +0 -11
  195. package/docs/guides/streams/node-readable-to-blob.md +0 -11
  196. package/docs/guides/streams/node-readable-to-json.md +0 -12
  197. package/docs/guides/streams/node-readable-to-string.md +0 -12
  198. package/docs/guides/streams/node-readable-to-uint8array.md +0 -11
  199. package/docs/guides/streams/to-array.md +0 -14
  200. package/docs/guides/streams/to-arraybuffer.md +0 -14
  201. package/docs/guides/streams/to-blob.md +0 -14
  202. package/docs/guides/streams/to-buffer.md +0 -15
  203. package/docs/guides/streams/to-json.md +0 -14
  204. package/docs/guides/streams/to-string.md +0 -14
  205. package/docs/guides/streams/to-typedarray.md +0 -22
  206. package/docs/guides/test/bail.md +0 -22
  207. package/docs/guides/test/coverage-threshold.md +0 -60
  208. package/docs/guides/test/coverage.md +0 -44
  209. package/docs/guides/test/happy-dom.md +0 -68
  210. package/docs/guides/test/migrate-from-jest.md +0 -143
  211. package/docs/guides/test/mock-clock.md +0 -48
  212. package/docs/guides/test/mock-functions.md +0 -68
  213. package/docs/guides/test/rerun-each.md +0 -14
  214. package/docs/guides/test/run-tests.md +0 -111
  215. package/docs/guides/test/skip-tests.md +0 -39
  216. package/docs/guides/test/snapshot.md +0 -95
  217. package/docs/guides/test/spy-on.md +0 -46
  218. package/docs/guides/test/svelte-test.md +0 -120
  219. package/docs/guides/test/testing-library.md +0 -92
  220. package/docs/guides/test/timeout.md +0 -15
  221. package/docs/guides/test/todo-tests.md +0 -67
  222. package/docs/guides/test/update-snapshots.md +0 -46
  223. package/docs/guides/test/watch-mode.md +0 -19
  224. package/docs/guides/util/base64.md +0 -15
  225. package/docs/guides/util/deep-equals.md +0 -39
  226. package/docs/guides/util/deflate.md +0 -18
  227. package/docs/guides/util/detect-bun.md +0 -23
  228. package/docs/guides/util/entrypoint.md +0 -17
  229. package/docs/guides/util/escape-html.md +0 -22
  230. package/docs/guides/util/file-url-to-path.md +0 -14
  231. package/docs/guides/util/gzip.md +0 -18
  232. package/docs/guides/util/hash-a-password.md +0 -54
  233. package/docs/guides/util/import-meta-dir.md +0 -13
  234. package/docs/guides/util/import-meta-file.md +0 -13
  235. package/docs/guides/util/import-meta-path.md +0 -13
  236. package/docs/guides/util/javascript-uuid.md +0 -23
  237. package/docs/guides/util/main.md +0 -32
  238. package/docs/guides/util/path-to-file-url.md +0 -14
  239. package/docs/guides/util/sleep.md +0 -22
  240. package/docs/guides/util/version.md +0 -21
  241. package/docs/guides/util/which-path-to-executable-bin.md +0 -15
  242. package/docs/guides/websocket/compression.md +0 -31
  243. package/docs/guides/websocket/context.md +0 -77
  244. package/docs/guides/websocket/pubsub.md +0 -41
  245. package/docs/guides/websocket/simple.md +0 -33
  246. package/docs/guides/write-file/append.md +0 -52
  247. package/docs/guides/write-file/basic.md +0 -44
  248. package/docs/guides/write-file/blob.md +0 -28
  249. package/docs/guides/write-file/cat.md +0 -17
  250. package/docs/guides/write-file/file-cp.md +0 -16
  251. package/docs/guides/write-file/filesink.md +0 -52
  252. package/docs/guides/write-file/response.md +0 -17
  253. package/docs/guides/write-file/stdout.md +0 -21
  254. package/docs/guides/write-file/stream.md +0 -17
  255. package/docs/guides/write-file/unlink.md +0 -16
  256. package/docs/index.md +0 -77
  257. package/docs/install/audit.md +0 -57
  258. package/docs/install/cache.md +0 -59
  259. package/docs/install/catalogs.md +0 -298
  260. package/docs/install/index.md +0 -248
  261. package/docs/install/isolated.md +0 -197
  262. package/docs/install/lifecycle.md +0 -46
  263. package/docs/install/lockfile.md +0 -58
  264. package/docs/install/npmrc.md +0 -105
  265. package/docs/install/overrides.md +0 -73
  266. package/docs/install/patch.md +0 -59
  267. package/docs/install/registries.md +0 -30
  268. package/docs/install/security-scanner-api.md +0 -81
  269. package/docs/install/workspaces.md +0 -114
  270. package/docs/installation.md +0 -327
  271. package/docs/project/asan.md +0 -124
  272. package/docs/project/benchmarking.md +0 -203
  273. package/docs/project/bindgen.md +0 -225
  274. package/docs/project/building-windows.md +0 -162
  275. package/docs/project/contributing.md +0 -347
  276. package/docs/project/internals/build-process-for-ci.md +0 -75
  277. package/docs/project/licensing.md +0 -73
  278. package/docs/project/roadmap.md +0 -87
  279. package/docs/quickstart.md +0 -157
  280. package/docs/runtime/autoimport.md +0 -94
  281. package/docs/runtime/bun-apis.md +0 -207
  282. package/docs/runtime/bunfig.md +0 -772
  283. package/docs/runtime/debugger.md +0 -325
  284. package/docs/runtime/env.md +0 -253
  285. package/docs/runtime/hot.md +0 -145
  286. package/docs/runtime/index.md +0 -312
  287. package/docs/runtime/jsx.md +0 -385
  288. package/docs/runtime/loaders.md +0 -130
  289. package/docs/runtime/modules.md +0 -320
  290. package/docs/runtime/nodejs-apis.md +0 -463
  291. package/docs/runtime/plugins.md +0 -561
  292. package/docs/runtime/shell.md +0 -605
  293. package/docs/runtime/typescript.md +0 -139
  294. package/docs/runtime/web-apis.md +0 -128
  295. package/docs/test/configuration.md +0 -154
  296. package/docs/test/coverage.md +0 -142
  297. package/docs/test/discovery.md +0 -85
  298. package/docs/test/dom.md +0 -75
  299. package/docs/test/examples/concurrent-test-glob.md +0 -132
  300. package/docs/test/hot.md +0 -15
  301. package/docs/test/lifecycle.md +0 -81
  302. package/docs/test/mocks.md +0 -313
  303. package/docs/test/reporters.md +0 -117
  304. package/docs/test/runtime-behavior.md +0 -95
  305. package/docs/test/snapshots.md +0 -68
  306. package/docs/test/time.md +0 -126
  307. package/docs/test/writing.md +0 -825
  308. package/docs/typescript.md +0 -53
@@ -1,449 +0,0 @@
1
- Bun provides a universal plugin API that can be used to extend both the _runtime_ and _bundler_.
2
-
3
- Plugins intercept imports and perform custom loading logic: reading files, transpiling code, etc. They can be used to add support for additional file types, like `.scss` or `.yaml`. In the context of Bun's bundler, plugins can be used to implement framework-level features like CSS extraction, macros, and client-server code co-location.
4
-
5
- ## Lifecycle hooks
6
-
7
- Plugins can register callbacks to be run at various points in the lifecycle of a bundle:
8
-
9
- - [`onStart()`](#onstart): Run once the bundler has started a bundle
10
- - [`onResolve()`](#onresolve): Run before a module is resolved
11
- - [`onLoad()`](#onload): Run before a module is loaded.
12
- - [`onEnd()`](#onend): Run after the bundle has completed
13
- - [`onBeforeParse()`](#onbeforeparse): Run zero-copy native addons in the parser thread before a file is parsed.
14
-
15
- ### Reference
16
-
17
- A rough overview of the types (please refer to Bun's `bun.d.ts` for the full type definitions):
18
-
19
- ```ts
20
- type PluginBuilder = {
21
- onStart(callback: () => void): void;
22
- onEnd(callback: (result: BuildOutput) => void | Promise<void>): void;
23
- onResolve: (
24
- args: { filter: RegExp; namespace?: string },
25
- callback: (args: { path: string; importer: string }) => {
26
- path: string;
27
- namespace?: string;
28
- } | void,
29
- ) => void;
30
- onLoad: (
31
- args: { filter: RegExp; namespace?: string },
32
- defer: () => Promise<void>,
33
- callback: (args: { path: string }) => {
34
- loader?: Loader;
35
- contents?: string;
36
- exports?: Record<string, any>;
37
- },
38
- ) => void;
39
- config: BuildConfig;
40
- };
41
-
42
- type Loader = "js" | "jsx" | "ts" | "tsx" | "css" | "json" | "toml";
43
- ```
44
-
45
- ## Usage
46
-
47
- A plugin is defined as simple JavaScript object containing a `name` property and a `setup` function.
48
-
49
- ```tsx#myPlugin.ts
50
- import type { BunPlugin } from "bun";
51
-
52
- const myPlugin: BunPlugin = {
53
- name: "Custom loader",
54
- setup(build) {
55
- // implementation
56
- },
57
- };
58
- ```
59
-
60
- This plugin can be passed into the `plugins` array when calling `Bun.build`.
61
-
62
- ```ts
63
- await Bun.build({
64
- entrypoints: ["./app.ts"],
65
- outdir: "./out",
66
- plugins: [myPlugin],
67
- });
68
- ```
69
-
70
- ## Plugin lifecycle
71
-
72
- ### Namespaces
73
-
74
- `onLoad` and `onResolve` accept an optional `namespace` string. What is a namespace?
75
-
76
- Every module has a namespace. Namespaces are used to prefix the import in transpiled code; for instance, a loader with a `filter: /\.yaml$/` and `namespace: "yaml:"` will transform an import from `./myfile.yaml` into `yaml:./myfile.yaml`.
77
-
78
- The default namespace is `"file"` and it is not necessary to specify it, for instance: `import myModule from "./my-module.ts"` is the same as `import myModule from "file:./my-module.ts"`.
79
-
80
- Other common namespaces are:
81
-
82
- - `"bun"`: for Bun-specific modules (e.g. `"bun:test"`, `"bun:sqlite"`)
83
- - `"node"`: for Node.js modules (e.g. `"node:fs"`, `"node:path"`)
84
-
85
- ### `onStart`
86
-
87
- ```ts
88
- onStart(callback: () => void): Promise<void> | void;
89
- ```
90
-
91
- Registers a callback to be run when the bundler starts a new bundle.
92
-
93
- ```ts
94
- import { plugin } from "bun";
95
-
96
- plugin({
97
- name: "onStart example",
98
-
99
- setup(build) {
100
- build.onStart(() => {
101
- console.log("Bundle started!");
102
- });
103
- },
104
- });
105
- ```
106
-
107
- The callback can return a `Promise`. After the bundle process has initialized, the bundler waits until all `onStart()` callbacks have completed before continuing.
108
-
109
- For example:
110
-
111
- ```ts
112
- const result = await Bun.build({
113
- entrypoints: ["./app.ts"],
114
- outdir: "./dist",
115
- sourcemap: "external",
116
- plugins: [
117
- {
118
- name: "Sleep for 10 seconds",
119
- setup(build) {
120
- build.onStart(async () => {
121
- await Bunlog.sleep(10_000);
122
- });
123
- },
124
- },
125
- {
126
- name: "Log bundle time to a file",
127
- setup(build) {
128
- build.onStart(async () => {
129
- const now = Date.now();
130
- await Bun.$`echo ${now} > bundle-time.txt`;
131
- });
132
- },
133
- },
134
- ],
135
- });
136
- ```
137
-
138
- In the above example, Bun will wait until the first `onStart()` (sleeping for 10 seconds) has completed, _as well as_ the second `onStart()` (writing the bundle time to a file).
139
-
140
- Note that `onStart()` callbacks (like every other lifecycle callback) do not have the ability to modify the `build.config` object. If you want to mutate `build.config`, you must do so directly in the `setup()` function.
141
-
142
- ### `onResolve`
143
-
144
- ```ts
145
- onResolve(
146
- args: { filter: RegExp; namespace?: string },
147
- callback: (args: { path: string; importer: string }) => {
148
- path: string;
149
- namespace?: string;
150
- } | void,
151
- ): void;
152
- ```
153
-
154
- To bundle your project, Bun walks down the dependency tree of all modules in your project. For each imported module, Bun actually has to find and read that module. The "finding" part is known as "resolving" a module.
155
-
156
- The `onResolve()` plugin lifecycle callback allows you to configure how a module is resolved.
157
-
158
- The first argument to `onResolve()` is an object with a `filter` and [`namespace`](#what-is-a-namespace) property. The filter is a regular expression which is run on the import string. Effectively, these allow you to filter which modules your custom resolution logic will apply to.
159
-
160
- The second argument to `onResolve()` is a callback which is run for each module import Bun finds that matches the `filter` and `namespace` defined in the first argument.
161
-
162
- The callback receives as input the _path_ to the matching module. The callback can return a _new path_ for the module. Bun will read the contents of the _new path_ and parse it as a module.
163
-
164
- For example, redirecting all imports to `images/` to `./public/images/`:
165
-
166
- ```ts
167
- import { plugin } from "bun";
168
-
169
- plugin({
170
- name: "onResolve example",
171
- setup(build) {
172
- build.onResolve({ filter: /.*/, namespace: "file" }, args => {
173
- if (args.path.startsWith("images/")) {
174
- return {
175
- path: args.path.replace("images/", "./public/images/"),
176
- };
177
- }
178
- });
179
- },
180
- });
181
- ```
182
-
183
- ### `onLoad`
184
-
185
- ```ts
186
- onLoad(
187
- args: { filter: RegExp; namespace?: string },
188
- defer: () => Promise<void>,
189
- callback: (args: { path: string, importer: string, namespace: string, kind: ImportKind }) => {
190
- loader?: Loader;
191
- contents?: string;
192
- exports?: Record<string, any>;
193
- },
194
- ): void;
195
- ```
196
-
197
- After Bun's bundler has resolved a module, it needs to read the contents of the module and parse it.
198
-
199
- The `onLoad()` plugin lifecycle callback allows you to modify the _contents_ of a module before it is read and parsed by Bun.
200
-
201
- Like `onResolve()`, the first argument to `onLoad()` allows you to filter which modules this invocation of `onLoad()` will apply to.
202
-
203
- The second argument to `onLoad()` is a callback which is run for each matching module _before_ Bun loads the contents of the module into memory.
204
-
205
- This callback receives as input the _path_ to the matching module, the _importer_ of the module (the module that imported the module), the _namespace_ of the module, and the _kind_ of the module.
206
-
207
- The callback can return a new `contents` string for the module as well as a new `loader`.
208
-
209
- For example:
210
-
211
- ```ts
212
- import { plugin } from "bun";
213
-
214
- const envPlugin: BunPlugin = {
215
- name: "env plugin",
216
- setup(build) {
217
- build.onLoad({ filter: /env/, namespace: "file" }, args => {
218
- return {
219
- contents: `export default ${JSON.stringify(process.env)}`,
220
- loader: "js",
221
- };
222
- });
223
- },
224
- });
225
-
226
- Bun.build({
227
- entrypoints: ["./app.ts"],
228
- outdir: "./dist",
229
- plugins: [envPlugin],
230
- });
231
-
232
- // import env from "env"
233
- // env.FOO === "bar"
234
- ```
235
-
236
- This plugin will transform all imports of the form `import env from "env"` into a JavaScript module that exports the current environment variables.
237
-
238
- #### `.defer()`
239
-
240
- One of the arguments passed to the `onLoad` callback is a `defer` function. This function returns a `Promise` that is resolved when all _other_ modules have been loaded.
241
-
242
- This allows you to delay execution of the `onLoad` callback until all other modules have been loaded.
243
-
244
- This is useful for returning contents of a module that depends on other modules.
245
-
246
- ##### Example: tracking and reporting unused exports
247
-
248
- ```ts
249
- import { plugin } from "bun";
250
-
251
- plugin({
252
- name: "track imports",
253
- setup(build) {
254
- const transpiler = new Bun.Transpiler();
255
-
256
- let trackedImports: Record<string, number> = {};
257
-
258
- // Each module that goes through this onLoad callback
259
- // will record its imports in `trackedImports`
260
- build.onLoad({ filter: /\.ts/ }, async ({ path }) => {
261
- const contents = await Bun.file(path).arrayBuffer();
262
-
263
- const imports = transpiler.scanImports(contents);
264
-
265
- for (const i of imports) {
266
- trackedImports[i.path] = (trackedImports[i.path] || 0) + 1;
267
- }
268
-
269
- return undefined;
270
- });
271
-
272
- build.onLoad({ filter: /stats\.json/ }, async ({ defer }) => {
273
- // Wait for all files to be loaded, ensuring
274
- // that every file goes through the above `onLoad()` function
275
- // and their imports tracked
276
- await defer();
277
-
278
- // Emit JSON containing the stats of each import
279
- return {
280
- contents: `export default ${JSON.stringify(trackedImports)}`,
281
- loader: "json",
282
- };
283
- });
284
- },
285
- });
286
- ```
287
-
288
- Note that the `.defer()` function currently has the limitation that it can only be called once per `onLoad` callback.
289
-
290
- ### `onEnd`
291
-
292
- ```ts
293
- onEnd(callback: (result: BuildOutput) => void | Promise<void>): void;
294
- ```
295
-
296
- Registers a callback to be run when the bundler completes a bundle (whether successful or not).
297
-
298
- The callback receives the `BuildOutput` object containing:
299
-
300
- - `success`: boolean indicating if the build succeeded
301
- - `outputs`: array of generated build artifacts
302
- - `logs`: array of build messages (warnings, errors, etc.)
303
-
304
- This is useful for post-processing, cleanup, notifications, or custom error handling.
305
-
306
- ```ts
307
- await Bun.build({
308
- entrypoints: ["./index.ts"],
309
- outdir: "./out",
310
- plugins: [
311
- {
312
- name: "onEnd example",
313
- setup(build) {
314
- build.onEnd(result => {
315
- if (result.success) {
316
- console.log(
317
- `✅ Build succeeded with ${result.outputs.length} outputs`,
318
- );
319
- } else {
320
- console.error(`❌ Build failed with ${result.logs.length} errors`);
321
- }
322
- });
323
- },
324
- },
325
- ],
326
- });
327
- ```
328
-
329
- The `onEnd` callbacks are called:
330
-
331
- - **Before** the build promise resolves or rejects
332
- - **After** all bundling is complete
333
- - **In the order** they were registered
334
-
335
- Multiple plugins can register `onEnd` callbacks, and they will all be called sequentially. If an `onEnd` callback returns a promise, the build will wait for it to resolve before continuing.
336
-
337
- ## Native plugins
338
-
339
- One of the reasons why Bun's bundler is so fast is that it is written in native code and leverages multi-threading to load and parse modules in parallel.
340
-
341
- However, one limitation of plugins written in JavaScript is that JavaScript itself is single-threaded.
342
-
343
- Native plugins are written as [NAPI](https://bun.com/docs/api/node-api) modules and can be run on multiple threads. This allows native plugins to run much faster than JavaScript plugins.
344
-
345
- In addition, native plugins can skip unnecessary work such as the UTF-8 -> UTF-16 conversion needed to pass strings to JavaScript.
346
-
347
- These are the following lifecycle hooks which are available to native plugins:
348
-
349
- - [`onBeforeParse()`](#onbeforeparse): Called on any thread before a file is parsed by Bun's bundler.
350
-
351
- Native plugins are NAPI modules which expose lifecycle hooks as C ABI functions.
352
-
353
- To create a native plugin, you must export a C ABI function which matches the signature of the native lifecycle hook you want to implement.
354
-
355
- ### Creating a native plugin in Rust
356
-
357
- Native plugins are NAPI modules which expose lifecycle hooks as C ABI functions.
358
-
359
- To create a native plugin, you must export a C ABI function which matches the signature of the native lifecycle hook you want to implement.
360
-
361
- ```bash
362
- bun add -g @napi-rs/cli
363
- napi new
364
- ```
365
-
366
- Then install this crate:
367
-
368
- ```bash
369
- cargo add bun-native-plugin
370
- ```
371
-
372
- Now, inside the `lib.rs` file, we'll use the `bun_native_plugin::bun` proc macro to define a function which
373
- will implement our native plugin.
374
-
375
- Here's an example implementing the `onBeforeParse` hook:
376
-
377
- ```rs
378
- use bun_native_plugin::{define_bun_plugin, OnBeforeParse, bun, Result, anyhow, BunLoader};
379
- use napi_derive::napi;
380
-
381
- /// Define the plugin and its name
382
- define_bun_plugin!("replace-foo-with-bar");
383
-
384
- /// Here we'll implement `onBeforeParse` with code that replaces all occurrences of
385
- /// `foo` with `bar`.
386
- ///
387
- /// We use the #[bun] macro to generate some of the boilerplate code.
388
- ///
389
- /// The argument of the function (`handle: &mut OnBeforeParse`) tells
390
- /// the macro that this function implements the `onBeforeParse` hook.
391
- #[bun]
392
- pub fn replace_foo_with_bar(handle: &mut OnBeforeParse) -> Result<()> {
393
- // Fetch the input source code.
394
- let input_source_code = handle.input_source_code()?;
395
-
396
- // Get the Loader for the file
397
- let loader = handle.output_loader();
398
-
399
-
400
- let output_source_code = input_source_code.replace("foo", "bar");
401
-
402
- handle.set_output_source_code(output_source_code, BunLoader::BUN_LOADER_JSX);
403
-
404
- Ok(())
405
- }
406
- ```
407
-
408
- And to use it in Bun.build():
409
-
410
- ```typescript
411
- import myNativeAddon from "./my-native-addon";
412
- Bun.build({
413
- entrypoints: ["./app.tsx"],
414
- plugins: [
415
- {
416
- name: "my-plugin",
417
-
418
- setup(build) {
419
- build.onBeforeParse(
420
- {
421
- namespace: "file",
422
- filter: "**/*.tsx",
423
- },
424
- {
425
- napiModule: myNativeAddon,
426
- symbol: "replace_foo_with_bar",
427
- // external: myNativeAddon.getSharedState()
428
- },
429
- );
430
- },
431
- },
432
- ],
433
- });
434
- ```
435
-
436
- ### `onBeforeParse`
437
-
438
- ```ts
439
- onBeforeParse(
440
- args: { filter: RegExp; namespace?: string },
441
- callback: { napiModule: NapiModule; symbol: string; external?: unknown },
442
- ): void;
443
- ```
444
-
445
- This lifecycle callback is run immediately before a file is parsed by Bun's bundler.
446
-
447
- As input, it receives the file's contents and can optionally return new source code.
448
-
449
- This callback can be called from any thread and so the napi module implementation must be thread-safe.