aboutsummaryrefslogtreecommitdiff
path: root/lib/std/Build.zig
diff options
context:
space:
mode:
authorAndrew Kelley <andrew@ziglang.org>2023-01-31 00:33:45 -0700
committerAndrew Kelley <andrew@ziglang.org>2023-01-31 15:09:35 -0700
commit5129fae4e8fdb68db1efdff20679b13487501691 (patch)
tree94d4a545091873df4236372608db368d2d79cf91 /lib/std/Build.zig
parent60c4befad39a1e1689872bc78dd1b8f8d5c34887 (diff)
downloadzig-5129fae4e8fdb68db1efdff20679b13487501691.tar.gz
zig-5129fae4e8fdb68db1efdff20679b13487501691.zip
std.Build: accept host Target in create()
And only detect native target in LibExeObjStep once, in create().
Diffstat (limited to 'lib/std/Build.zig')
-rw-r--r--lib/std/Build.zig10
1 files changed, 8 insertions, 2 deletions
diff --git a/lib/std/Build.zig b/lib/std/Build.zig
index a3c579c743..c0152ef6f1 100644
--- a/lib/std/Build.zig
+++ b/lib/std/Build.zig
@@ -179,12 +179,11 @@ pub fn create(
build_root: []const u8,
cache_root: []const u8,
global_cache_root: []const u8,
+ host: NativeTargetInfo,
) !*Build {
const env_map = try allocator.create(EnvMap);
env_map.* = try process.getEnvMap(allocator);
- const host = try NativeTargetInfo.detect(.{});
-
const self = try allocator.create(Build);
self.* = Build{
.zig_exe = zig_exe,
@@ -1529,12 +1528,15 @@ test "builder.findProgram compiles" {
var arena = std.heap.ArenaAllocator.init(std.heap.page_allocator);
defer arena.deinit();
+ const host = try NativeTargetInfo.detect(.{});
+
const builder = try Build.create(
arena.allocator(),
"zig",
"zig-cache",
"zig-cache",
"zig-cache",
+ host,
);
defer builder.destroy();
_ = builder.findProgram(&[_][]const u8{}, &[_][]const u8{}) catch null;
@@ -1713,12 +1715,16 @@ test "dupePkg()" {
var arena = std.heap.ArenaAllocator.init(std.testing.allocator);
defer arena.deinit();
+
+ const host = try NativeTargetInfo.detect(.{});
+
var builder = try Build.create(
arena.allocator(),
"test",
"test",
"test",
"test",
+ host,
);
defer builder.destroy();