summaryrefslogtreecommitdiffhomepage
path: root/examples
diff options
context:
space:
mode:
authorAnders Holmberg <[email protected]>2021-11-27 10:46:18 +0100
committerGitHub <[email protected]>2021-11-27 10:46:18 +0100
commit71f2e2b1e4f86b769f3ba62fcc0217d06a5dee11 (patch)
tree93c4e3c51be9a2d06f7358a1eb7ca53ed07c8648 /examples
parent2b2141902bf700acbab00d8127a101e6b895b677 (diff)
downloadraylib-71f2e2b1e4f86b769f3ba62fcc0217d06a5dee11.tar.gz
raylib-71f2e2b1e4f86b769f3ba62fcc0217d06a5dee11.zip
Add macos support to zig build system (#2175)
Diffstat (limited to 'examples')
-rw-r--r--examples/build.zig17
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");
},