Files
bun.sh/src/env.zig
taylor.fish 7717693c70 Dev server refactoring, part 1 (mainly IncrementalGraph) (#22010)
* `IncrementalGraph(.client).File` packs its fields in a specific way to
save space, but it makes the struct hard to use and error-prone (e.g.,
untagged unions with tags stored in a separate `flags` struct). This PR
changes `File` to have a human-readable layout, but adds methods to
convert it to and from `File.Packed`, a packed version with the same
space efficiency as before.
* Reduce the need to pass the dev allocator to functions (e.g.,
`deinit`) by storing it as a struct field via the new `DevAllocator`
type. This type has no overhead in release builds, or when
`AllocationScope` is disabled.
* Use owned pointers in `PackedMap`.
* Use `bun.ptr.Shared` for `PackedMap` instead of the old
`bun.ptr.RefPtr`.
* Add `bun.ptr.ScopedOwned`, which is like `bun.ptr.Owned`, but can
store an `AllocationScope`. No overhead in release builds or when
`AllocationScope` is disabled.
* Reduce redundant allocators in `BundleV2`.
* Add owned pointer conversions to `MutableString`.
* Make `AllocationScope` behave like a pointer, so it can be moved
without invalidating allocations. This eliminates the need for
self-references.
* Change memory cost algorithm so it doesn't rely on “dedupe bits”.
These bits used to take advantage of padding but there is now no padding
in `PackedMap`.
* Replace `VoidFieldTypes` with `useAllFields`; this eliminates the need
for `voidFieldTypesDiscardHelper`.

(For internal tracking: fixes STAB-1035, STAB-1036, STAB-1037,
STAB-1038, STAB-1039, STAB-1040, STAB-1041, STAB-1042, STAB-1043,
STAB-1044, STAB-1045)

---------

Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
Co-authored-by: Jarred Sumner <jarred@jarredsumner.com>
Co-authored-by: Claude Bot <claude-bot@bun.sh>
Co-authored-by: Claude <noreply@anthropic.com>
2025-08-22 23:04:58 -07:00

178 lines
5.6 KiB
Zig

pub const BuildTarget = enum { native, wasm, wasi };
pub const build_target: BuildTarget = brk: {
if (builtin.cpu.arch.isWasm()) {
break :brk BuildTarget.wasm;
} else {
break :brk BuildTarget.native;
}
};
pub const isWasm = build_target == .wasm;
pub const isNative = build_target == .native;
pub const isWasi = build_target == .wasi;
pub const isMac = build_target == .native and builtin.target.os.tag == .macos;
pub const isBrowser = !isWasi and isWasm;
pub const isWindows = builtin.target.os.tag == .windows;
pub const isPosix = !isWindows and !isWasm;
pub const isDebug = builtin.mode == .Debug;
pub const isTest = builtin.is_test;
pub const isLinux = builtin.target.os.tag == .linux;
pub const isAarch64 = builtin.target.cpu.arch.isAARCH64();
pub const isX86 = builtin.target.cpu.arch.isX86();
pub const isX64 = builtin.target.cpu.arch == .x86_64;
pub const isMusl = builtin.target.abi.isMusl();
pub const allow_assert = isDebug or isTest or std.builtin.Mode.ReleaseSafe == builtin.mode;
pub const ci_assert = isDebug or isTest or enable_asan or (std.builtin.Mode.ReleaseSafe == builtin.mode and is_canary);
pub const show_crash_trace = isDebug or isTest or enable_asan;
/// All calls to `@export` should be gated behind this check, so that code
/// generators that compile Zig code know not to reference and compile a ton of
/// unused code.
pub const export_cpp_apis = if (build_options.override_no_export_cpp_apis) false else (builtin.output_mode == .Obj or isTest);
/// Whether or not to enable allocation tracking when the `AllocationScope`
/// allocator is used.
pub const enableAllocScopes = isDebug or enable_asan;
pub const build_options = @import("build_options");
/// Set if compiling with `-Dno_llvm`
/// All places this is used is working around a Zig bug.
pub const zig_self_hosted_backend = build_options.zig_self_hosted_backend;
pub const reported_nodejs_version = build_options.reported_nodejs_version;
pub const baseline = build_options.baseline;
pub const enableSIMD: bool = !baseline and !zig_self_hosted_backend;
pub const git_sha = build_options.sha;
pub const git_sha_short = if (build_options.sha.len > 0) build_options.sha[0..9] else "";
pub const git_sha_shorter = if (build_options.sha.len > 0) build_options.sha[0..6] else "";
pub const is_canary = build_options.is_canary;
pub const canary_revision = if (is_canary) build_options.canary_revision else "";
pub const dump_source = isDebug and !isTest;
pub const base_path = build_options.base_path;
pub const enable_logs = build_options.enable_logs;
pub const enable_asan = build_options.enable_asan;
pub const codegen_path = build_options.codegen_path;
pub const codegen_embed = build_options.codegen_embed;
pub const version: std.SemanticVersion = build_options.version;
pub const version_string = std.fmt.comptimePrint("{d}.{d}.{d}", .{ version.major, version.minor, version.patch });
pub inline fn onlyMac() void {
if (comptime !isMac) {
unreachable;
}
}
pub const OperatingSystem = enum {
mac,
linux,
windows,
// wAsM is nOt aN oPeRaTiNg SyStEm
wasm,
pub const names = bun.ComptimeStringMap(OperatingSystem, &.{
.{ "windows", .windows },
.{ "win32", .windows },
.{ "win", .windows },
.{ "win64", .windows },
.{ "win_x64", .windows },
.{ "darwin", .mac },
.{ "macos", .mac },
.{ "macOS", .mac },
.{ "mac", .mac },
.{ "apple", .mac },
.{ "linux", .linux },
.{ "Linux", .linux },
.{ "linux-gnu", .linux },
.{ "gnu/linux", .linux },
.{ "wasm", .wasm },
});
/// user-facing name with capitalization
pub fn displayString(self: OperatingSystem) []const u8 {
return switch (self) {
.mac => "macOS",
.linux => "Linux",
.windows => "Windows",
.wasm => "WASM",
};
}
/// same format as `process.platform`
pub fn nameString(self: OperatingSystem) []const u8 {
return switch (self) {
.mac => "darwin",
.linux => "linux",
.windows => "win32",
.wasm => "wasm",
};
}
pub fn stdOSTag(self: OperatingSystem) std.Target.Os.Tag {
return switch (self) {
.mac => .macos,
.linux => .linux,
.windows => .windows,
.wasm => unreachable,
};
}
/// npm package name, `@oven-sh/bun-{os}-{arch}`
pub fn npmName(self: OperatingSystem) []const u8 {
return switch (self) {
.mac => "darwin",
.linux => "linux",
.windows => "windows",
.wasm => "wasm",
};
}
};
pub const os: OperatingSystem = if (isMac)
.mac
else if (isLinux)
.linux
else if (isWindows)
.windows
else if (isWasm)
.wasm
else
@compileError("Please add your OS to the OperatingSystem enum");
pub const Architecture = enum {
x64,
arm64,
wasm,
/// npm package name, `@oven-sh/bun-{os}-{arch}`
pub fn npmName(this: Architecture) []const u8 {
return switch (this) {
.x64 => "x64",
.arm64 => "aarch64",
.wasm => "wasm",
};
}
pub const names = bun.ComptimeStringMap(Architecture, &.{
.{ "x86_64", .x64 },
.{ "x64", .x64 },
.{ "amd64", .x64 },
.{ "aarch64", .arm64 },
.{ "arm64", .arm64 },
.{ "wasm", .wasm },
});
};
pub const arch: Architecture = if (isWasm)
.wasm
else if (isX64)
.x64
else if (isAarch64)
.arm64
else
@compileError("Please add your architecture to the Architecture enum");
const builtin = @import("builtin");
const bun = @import("bun");
const std = @import("std");