summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorKomari Spaghetti <[email protected]>2022-03-11 19:04:24 +0100
committerGitHub <[email protected]>2022-03-11 19:04:24 +0100
commit8065504aba66eeddc69111508ef8a267358467a6 (patch)
tree5764b4b87b9fb4d1dd4a5d41fc5a13a704067df0 /src
parentcda1324e87e0e3b3c1f488ac93a928d1b1b3d50b (diff)
downloadraylib-8065504aba66eeddc69111508ef8a267358467a6.tar.gz
raylib-8065504aba66eeddc69111508ef8a267358467a6.zip
Simplify build.zig to not require user to specify raylib path (#2383)
We can figure out the source file location based on the location of the build.zig file. No need to require the library user to specify where raylib is stored.
Diffstat (limited to 'src')
-rw-r--r--src/build.zig156
1 files changed, 78 insertions, 78 deletions
diff --git a/src/build.zig b/src/build.zig
index 61c0e662..7834ab24 100644
--- a/src/build.zig
+++ b/src/build.zig
@@ -1,90 +1,82 @@
const std = @import("std");
-pub fn Pkg(srcdir: []const u8) type {
- return struct {
- pub fn addRaylib(b: *std.build.Builder, target: std.zig.CrossTarget) *std.build.LibExeObjStep {
- // Standard release options allow the person running `zig build` to select
- // between Debug, ReleaseSafe, ReleaseFast, and ReleaseSmall.
- const mode = b.standardReleaseOptions();
+pub fn addRaylib(b: *std.build.Builder, target: std.zig.CrossTarget) *std.build.LibExeObjStep {
+ // Standard release options allow the person running `zig build` to select
+ // between Debug, ReleaseSafe, ReleaseFast, and ReleaseSmall.
+ const mode = b.standardReleaseOptions();
- const raylib_flags = &[_][]const u8{
- "-std=gnu99",
- "-DPLATFORM_DESKTOP",
- "-DGL_SILENCE_DEPRECATION=199309L",
- "-fno-sanitize=undefined", // https://github.com/raysan5/raylib/issues/1891
- };
+ const raylib_flags = &[_][]const u8{
+ "-std=gnu99",
+ "-DPLATFORM_DESKTOP",
+ "-DGL_SILENCE_DEPRECATION=199309L",
+ "-fno-sanitize=undefined", // https://github.com/raysan5/raylib/issues/1891
+ };
- const raylib = b.addStaticLibrary("raylib", srcdir ++ "/raylib.h");
- raylib.setTarget(target);
- raylib.setBuildMode(mode);
- raylib.linkLibC();
+ const raylib = b.addStaticLibrary("raylib", srcdir ++ "/raylib.h");
+ raylib.setTarget(target);
+ raylib.setBuildMode(mode);
+ raylib.linkLibC();
- raylib.addIncludeDir(srcdir ++ "/external/glfw/include");
+ raylib.addIncludeDir(srcdir ++ "/external/glfw/include");
- raylib.addCSourceFiles(&.{
- srcdir ++ "/raudio.c",
- srcdir ++ "/rcore.c",
- srcdir ++ "/rmodels.c",
- srcdir ++ "/rshapes.c",
- srcdir ++ "/rtext.c",
- srcdir ++ "/rtextures.c",
- srcdir ++ "/utils.c",
- }, raylib_flags);
+ raylib.addCSourceFiles(&.{
+ srcdir ++ "/raudio.c",
+ srcdir ++ "/rcore.c",
+ srcdir ++ "/rmodels.c",
+ srcdir ++ "/rshapes.c",
+ srcdir ++ "/rtext.c",
+ srcdir ++ "/rtextures.c",
+ srcdir ++ "/utils.c",
+ }, raylib_flags);
- switch (raylib.target.toTarget().os.tag) {
- .windows => {
- raylib.addCSourceFiles(&.{srcdir ++ "/rglfw.c"}, raylib_flags);
- raylib.linkSystemLibrary("winmm");
- raylib.linkSystemLibrary("gdi32");
- raylib.linkSystemLibrary("opengl32");
- raylib.addIncludeDir("external/glfw/deps/mingw");
- },
- .linux => {
- raylib.addCSourceFiles(&.{srcdir ++ "/rglfw.c"}, raylib_flags);
- raylib.linkSystemLibrary("GL");
- raylib.linkSystemLibrary("rt");
- raylib.linkSystemLibrary("dl");
- raylib.linkSystemLibrary("m");
- raylib.linkSystemLibrary("X11");
- },
- .freebsd, .openbsd, .netbsd, .dragonfly => {
- raylib.addCSourceFiles(&.{srcdir ++ "/rglfw.c"}, raylib_flags);
- raylib.linkSystemLibrary("GL");
- raylib.linkSystemLibrary("rt");
- raylib.linkSystemLibrary("dl");
- raylib.linkSystemLibrary("m");
- raylib.linkSystemLibrary("X11");
- raylib.linkSystemLibrary("Xrandr");
- raylib.linkSystemLibrary("Xinerama");
- raylib.linkSystemLibrary("Xi");
- raylib.linkSystemLibrary("Xxf86vm");
- raylib.linkSystemLibrary("Xcursor");
- },
- .macos => {
- // On macos rglfw.c include Objective-C files.
- const raylib_flags_extra_macos = &[_][]const u8{
- "-ObjC",
- };
- raylib.addCSourceFiles(
- &.{srcdir ++ "/rglfw.c"},
- raylib_flags ++ raylib_flags_extra_macos,
- );
- raylib.linkFramework("Foundation");
- },
- else => {
- @panic("Unsupported OS");
- },
- }
+ switch (raylib.target.toTarget().os.tag) {
+ .windows => {
+ raylib.addCSourceFiles(&.{srcdir ++ "/rglfw.c"}, raylib_flags);
+ raylib.linkSystemLibrary("winmm");
+ raylib.linkSystemLibrary("gdi32");
+ raylib.linkSystemLibrary("opengl32");
+ raylib.addIncludeDir("external/glfw/deps/mingw");
+ },
+ .linux => {
+ raylib.addCSourceFiles(&.{srcdir ++ "/rglfw.c"}, raylib_flags);
+ raylib.linkSystemLibrary("GL");
+ raylib.linkSystemLibrary("rt");
+ raylib.linkSystemLibrary("dl");
+ raylib.linkSystemLibrary("m");
+ raylib.linkSystemLibrary("X11");
+ },
+ .freebsd, .openbsd, .netbsd, .dragonfly => {
+ raylib.addCSourceFiles(&.{srcdir ++ "/rglfw.c"}, raylib_flags);
+ raylib.linkSystemLibrary("GL");
+ raylib.linkSystemLibrary("rt");
+ raylib.linkSystemLibrary("dl");
+ raylib.linkSystemLibrary("m");
+ raylib.linkSystemLibrary("X11");
+ raylib.linkSystemLibrary("Xrandr");
+ raylib.linkSystemLibrary("Xinerama");
+ raylib.linkSystemLibrary("Xi");
+ raylib.linkSystemLibrary("Xxf86vm");
+ raylib.linkSystemLibrary("Xcursor");
+ },
+ .macos => {
+ // On macos rglfw.c include Objective-C files.
+ const raylib_flags_extra_macos = &[_][]const u8{
+ "-ObjC",
+ };
+ raylib.addCSourceFiles(
+ &.{srcdir ++ "/rglfw.c"},
+ raylib_flags ++ raylib_flags_extra_macos,
+ );
+ raylib.linkFramework("Foundation");
+ },
+ else => {
+ @panic("Unsupported OS");
+ },
+ }
- raylib.setOutputDir("./");
- raylib.install();
- return raylib;
- }
- };
+ return raylib;
}
-const lib = Pkg(".");
-
pub fn build(b: *std.build.Builder) void {
// Standard target options allows the person running `zig build` to choose
// what target to build for. Here we do not override the defaults, which
@@ -92,5 +84,13 @@ pub fn build(b: *std.build.Builder) void {
// for restricting supported target set are available.
const target = b.standardTargetOptions(.{});
- _ = lib.addRaylib(b, target);
+ const lib = addRaylib(b, target);
+ lib.setOutputDir(srcdir);
+ lib.install();
+}
+
+const srcdir = getSrcDir();
+
+fn getSrcDir() []const u8 {
+ return std.fs.path.dirname(@src().file) orelse ".";
}