aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> 2023-01-02 22:06:52 -0800
committerGravatar Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> 2023-01-02 22:06:52 -0800
commitc770db7d52408bba14fe0d531b7b6bfae7b32cbd (patch)
treef5b0d358d888a722cff19390671831dcec880df3
parentcbc015d8d849ae7d96dd102f382552f814309368 (diff)
downloadbun-c770db7d52408bba14fe0d531b7b6bfae7b32cbd.tar.gz
bun-c770db7d52408bba14fe0d531b7b6bfae7b32cbd.tar.zst
bun-c770db7d52408bba14fe0d531b7b6bfae7b32cbd.zip
make it work with homebrew zig
-rw-r--r--build.zig10
1 files changed, 9 insertions, 1 deletions
diff --git a/build.zig b/build.zig
index ce86b017b..e89ad8cdf 100644
--- a/build.zig
+++ b/build.zig
@@ -44,6 +44,7 @@ const color_map = std.ComptimeStringMap([]const u8, .{
});
var compiler_rt_path: []const u8 = "";
+var compiler_rt_path_buf: [std.fs.MAX_PATH_BYTES]u8 = undefined;
fn addInternalPackages(step: *std.build.LibExeObjStep, allocator: std.mem.Allocator, zig_exe: []const u8, target: anytype) !void {
var bun = std.build.Pkg{
.name = "bun",
@@ -93,6 +94,10 @@ fn addInternalPackages(step: *std.build.LibExeObjStep, allocator: std.mem.Alloca
"{s}/../../lib/compiler_rt/stack_probe.zig",
"{s}/../../../lib/compiler_rt/stack_probe.zig",
"{s}/../../../../lib/compiler_rt/stack_probe.zig",
+ "{s}/../lib/zig/compiler_rt/stack_probe.zig",
+ "{s}/../../lib/zig/compiler_rt/stack_probe.zig",
+ "{s}/../../../lib/zig/compiler_rt/stack_probe.zig",
+ "{s}/../../../../lib/zig/compiler_rt/stack_probe.zig",
};
var found = false;
if (compiler_rt_path.len > 0) {
@@ -107,7 +112,10 @@ fn addInternalPackages(step: *std.build.LibExeObjStep, allocator: std.mem.Alloca
if (!found) brk: {
// workaround for https://github.com/ziglang/zig/issues/14099
const path = try std.fmt.allocPrint(allocator, path_fmt, .{zig_exe});
- var target_path = std.fs.path.resolve(allocator, &.{path}) catch break :brk;
+ var target_path = std.os.realpath(
+ std.fs.path.resolve(allocator, &.{path}) catch break :brk,
+ &compiler_rt_path_buf,
+ ) catch break :brk;
const compiler_rt: std.build.Pkg = .{
.name = "compiler_rt",
.source = .{ .path = target_path },