diff options
| author | Anders Holmberg <[email protected]> | 2021-11-27 10:46:18 +0100 |
|---|---|---|
| committer | GitHub <[email protected]> | 2021-11-27 10:46:18 +0100 |
| commit | 71f2e2b1e4f86b769f3ba62fcc0217d06a5dee11 (patch) | |
| tree | 93c4e3c51be9a2d06f7358a1eb7ca53ed07c8648 /examples/build.zig | |
| parent | 2b2141902bf700acbab00d8127a101e6b895b677 (diff) | |
| download | raylib-71f2e2b1e4f86b769f3ba62fcc0217d06a5dee11.tar.gz raylib-71f2e2b1e4f86b769f3ba62fcc0217d06a5dee11.zip | |
Add macos support to zig build system (#2175)
Diffstat (limited to 'examples/build.zig')
| -rw-r--r-- | examples/build.zig | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/examples/build.zig b/examples/build.zig index c05808bf..5c3a69d2 100644 --- a/examples/build.zig +++ b/examples/build.zig @@ -21,13 +21,20 @@ fn add_module(comptime module: []const u8, b: *std.build.Builder, target: std.zi // zig's mingw headers do not include pthread.h if (std.mem.eql(u8, "core_loading_thread", name) and target.getOsTag() == .windows) continue; - const exe = b.addExecutable(name, path); + const exe = b.addExecutable(name, null); + exe.addCSourceFile(path, switch (target.getOsTag()) { + .windows => &[_][]const u8{}, + .linux => &[_][]const u8{}, + .macos => &[_][]const u8{"-DPLATFORM_DESKTOP"}, + else => @panic("Unsupported OS"), + }); exe.setTarget(target); exe.setBuildMode(mode); exe.linkLibC(); exe.addObjectFile(switch (target.getOsTag()) { .windows => "../src/raylib.lib", .linux => "../src/libraylib.a", + .macos => "../src/libraylib.a", else => @panic("Unsupported OS"), }); @@ -49,6 +56,14 @@ fn add_module(comptime module: []const u8, b: *std.build.Builder, target: std.zi exe.linkSystemLibrary("m"); exe.linkSystemLibrary("X11"); }, + .macos => { + exe.linkFramework("Foundation"); + exe.linkFramework("Cocoa"); + exe.linkFramework("OpenGL"); + exe.linkFramework("CoreAudio"); + exe.linkFramework("CoreVideo"); + exe.linkFramework("IOKit"); + }, else => { @panic("Unsupported OS"); }, |
