eric 695bba18a6
Some checks failed
CI / test (ubuntu-latest, linux-x64) (push) Failing after 35s
Docs Pages / deploy (push) Failing after 1m26s
Copilot Setup Steps / copilot-setup-steps (push) Failing after 34s
CI / test (macos-14, darwin-arm64) (push) Has been cancelled
CI / test (windows-latest, windows) (push) Has been cancelled
chore(release): v0.0.7
2026-03-04 14:38:41 +01:00
2026-03-04 14:38:30 +01:00
2026-03-04 14:38:30 +01:00
2026-03-04 14:38:30 +01:00
2026-03-04 10:47:52 +01:00
2026-03-04 14:38:30 +01:00
2026-03-04 08:57:26 +01:00
2026-03-04 08:26:46 +01:00
2026-03-04 08:26:46 +01:00
2026-03-04 08:26:46 +01:00
2026-03-04 08:44:11 +01:00
2026-03-04 09:37:01 +01:00
2026-03-04 10:11:07 +01:00
2026-03-04 14:38:41 +01:00
2026-03-04 14:38:30 +01:00
2026-03-04 14:38:41 +01:00
2026-03-04 10:00:36 +01:00
2026-03-04 14:38:41 +01:00

rules_bun

Bazel rules for bun.

Rule reference

  • Generated API docs: docs/rules.md
  • Regenerate: bazel build //docs:rules_md && cp bazel-bin/docs/rules.md docs/rules.md

Use

These steps show how to consume a tagged release of rules_bun in a separate Bazel workspace.

1) Add the module dependency

In your project's MODULE.bazel, add:

bazel_dep(name = "rules_bun", version = "0.0.7")

archive_override(
	module_name = "rules_bun",
	urls = ["https://github.com/Eriyc/rules_bun/archiv0.0.5.tar.gz"],
	strip_prefix = "rules_bun-v0.0.7",
)

For channel/pre-release tags (for example v0.0.7-rc.1), use the matching folder prefix:

bazel_dep(name = "rules_bun", version = "0.0.7-rc.1")

archive_override(
	module_name = "rules_bun",
	urls = ["https://github.com/Eriyc/rules_bun/archiv0.0.5-rc.1.tar.gz"],
	strip_prefix = "rules_bun-v0.0.7-rc.1",
)

Note: keep the v prefix in the Git tag URL and strip_prefix; for bazel_dep(..., version = ...), use the module version string without the leading v.

2) Create Bun repositories with the extension

Still in MODULE.bazel, add:

bun_ext = use_extension("@rules_bun//bun:extensions.bzl", "bun")

use_repo(
	bun_ext,
	"bun_linux_x64",
	"bun_linux_aarch64",
	"bun_darwin_x64",
	"bun_darwin_aarch64",
	"bun_windows_x64",
)

3) Register toolchains

Also in MODULE.bazel, register:

register_toolchains(
	"@rules_bun//bun:darwin_aarch64_toolchain",
	"@rules_bun//bun:darwin_x64_toolchain",
	"@rules_bun//bun:linux_aarch64_toolchain",
	"@rules_bun//bun:linux_x64_toolchain",
	"@rules_bun//bun:windows_x64_toolchain",
)

4) Load rules in BUILD.bazel

load(
	"@rules_bun//bun:defs.bzl",
	"bun_binary",
	"bun_bundle",
	"bun_dev",
	"bun_test",
	"js_library",
	"ts_library",
)

5) (Optional) Use bun_install module extension

If you want Bazel-managed install repositories, add:

bun_install_ext = use_extension("@rules_bun//bun:extensions.bzl", "bun_install")

bun_install_ext.install(
	name = "npm",
	package_json = "//:package.json",
	bun_lockfile = "//:bun.lock",
)

use_repo(bun_install_ext, "npm")

6) Verify setup

Run one of your bun-backed targets, for example:

bazel test //path/to:your_bun_test

All rules_bun rule-driven Bun invocations pass --bun.

Development mode (bun_dev)

Use bun_dev for long-running local development with Bun watch mode.

load("@rules_bun//bun:defs.bzl", "bun_dev")

bun_dev(
	name = "web_dev",
	entry_point = "src/main.ts",
	# Optional: run from the entry point directory so Bun auto-loads colocated .env files.
	# working_dir = "entry_point",
)

Run it with:

bazel run //path/to:web_dev

bun_dev supports:

  • watch_mode = "watch" (default) for bun --watch
  • watch_mode = "hot" for bun --hot
  • restart_on = [...] to force full process restarts when specific files change
  • working_dir = "workspace" | "entry_point" (default: workspace)

Runtime working directory (bun_binary, bun_dev)

bun_binary and bun_dev support working_dir:

  • "workspace" (default): runs from the Bazel runfiles workspace root.
  • "entry_point": runs from the entry point file's directory.

Use "entry_point" when Bun should resolve local files such as colocated .env files relative to the program directory.

Hybrid Go + Bun + protobuf workflow

For monorepos that mix Go and Bun (including FFI):

  1. Run Bun app with native watch/HMR via bun_dev.
  2. Put generated artifacts or bridge files in restart_on (for example generated JS/TS files from proto/go steps).
  3. Rebuild Go/proto artifacts separately (for example with ibazel build) so their output files change.
  4. bun_dev detects those restart_on changes and restarts Bun, while ordinary JS edits continue to use Bun watch/HMR without full Bazel restarts.

This keeps the fast Bun JS loop while still supporting full restarts when non-JS dependencies change.

Description
Bazel rules for bun
Readme 1.8 MiB
Languages
Starlark 54.2%
Shell 28.2%
JavaScript 14.3%
Nix 1.6%
TypeScript 1%
Other 0.7%