summaryrefslogtreecommitdiffhomepage
path: root/src/build.zig
diff options
context:
space:
mode:
authorNikolas <[email protected]>2023-02-01 11:09:03 +0100
committerGitHub <[email protected]>2023-02-01 11:09:03 +0100
commit89171a26083da40a3a78dc0f1dee466542ed7668 (patch)
tree2028caa72ca1a86de467711dd81dbfabe0f45bb2 /src/build.zig
parentc94c666d0493fa32a810863d579d34289d2bfc1b (diff)
downloadraylib-89171a26083da40a3a78dc0f1dee466542ed7668.tar.gz
raylib-89171a26083da40a3a78dc0f1dee466542ed7668.zip
Add WASM support for Zig build (#2901)
* Add WASM support for Zig build * Improve Web example building * Remove emscript example building with Zig again * Readd windows emscripten variables
Diffstat (limited to 'src/build.zig')
-rw-r--r--src/build.zig27
1 files changed, 25 insertions, 2 deletions
diff --git a/src/build.zig b/src/build.zig
index e44271e8..919db3e9 100644
--- a/src/build.zig
+++ b/src/build.zig
@@ -3,7 +3,6 @@ const std = @import("std");
pub fn addRaylib(b: *std.build.Builder, target: std.zig.CrossTarget) *std.build.LibExeObjStep {
const raylib_flags = &[_][]const u8{
"-std=gnu99",
- "-DPLATFORM_DESKTOP",
"-D_GNU_SOURCE",
"-DGL_SILENCE_DEPRECATION=199309L",
"-fno-sanitize=undefined", // https://github.com/raysan5/raylib/issues/1891
@@ -25,13 +24,15 @@ pub fn addRaylib(b: *std.build.Builder, target: std.zig.CrossTarget) *std.build.
srcdir ++ "/utils.c",
}, raylib_flags);
- switch (raylib.target.toTarget().os.tag) {
+ switch (target.getOsTag()) {
.windows => {
raylib.addCSourceFiles(&.{srcdir ++ "/rglfw.c"}, raylib_flags);
raylib.linkSystemLibrary("winmm");
raylib.linkSystemLibrary("gdi32");
raylib.linkSystemLibrary("opengl32");
raylib.addIncludePath("external/glfw/deps/mingw");
+
+ raylib.defineCMacro("PLATFORM_DESKTOP", null);
},
.linux => {
raylib.addCSourceFiles(&.{srcdir ++ "/rglfw.c"}, raylib_flags);
@@ -40,6 +41,8 @@ pub fn addRaylib(b: *std.build.Builder, target: std.zig.CrossTarget) *std.build.
raylib.linkSystemLibrary("dl");
raylib.linkSystemLibrary("m");
raylib.linkSystemLibrary("X11");
+
+ raylib.defineCMacro("PLATFORM_DESKTOP", null);
},
.freebsd, .openbsd, .netbsd, .dragonfly => {
raylib.addCSourceFiles(&.{srcdir ++ "/rglfw.c"}, raylib_flags);
@@ -53,6 +56,8 @@ pub fn addRaylib(b: *std.build.Builder, target: std.zig.CrossTarget) *std.build.
raylib.linkSystemLibrary("Xi");
raylib.linkSystemLibrary("Xxf86vm");
raylib.linkSystemLibrary("Xcursor");
+
+ raylib.defineCMacro("PLATFORM_DESKTOP", null);
},
.macos => {
// On macos rglfw.c include Objective-C files.
@@ -68,6 +73,24 @@ pub fn addRaylib(b: *std.build.Builder, target: std.zig.CrossTarget) *std.build.
raylib.linkFramework("CoreGraphics");
raylib.linkFramework("AppKit");
raylib.linkFramework("IOKit");
+
+ raylib.defineCMacro("PLATFORM_DESKTOP", null);
+ },
+ .emscripten => {
+ raylib.defineCMacro("PLATFORM_WEB", null);
+ raylib.defineCMacro("GRAPHICS_API_OPENGL_ES2", null);
+
+ if (b.sysroot == null) {
+ @panic("Pass '--sysroot \"$EMSDK/upstream/emscripten\"'");
+ }
+
+ const cache_include = std.fs.path.join(b.allocator, &.{ b.sysroot.?, "cache", "sysroot", "include" }) catch @panic("Out of memory");
+ defer b.allocator.free(cache_include);
+
+ var dir = std.fs.openDirAbsolute(cache_include, std.fs.Dir.OpenDirOptions{.access_sub_paths = true, .no_follow = true}) catch @panic("No emscripten cache. Generate it!");
+ dir.close();
+
+ raylib.addIncludePath(cache_include);
},
else => {
@panic("Unsupported OS");