raylib-zig/project_setup.sh
2023-08-11 00:44:28 -06:00

67 lines
2.1 KiB
Bash
Executable File

#!/usr/bin/env bash
if [ "$#" -ne 1 ]; then
PROJECT_NAME='Project'
else
PROJECT_NAME=$1
fi
mkdir "$PROJECT_NAME" && cd "$PROJECT_NAME" || exit
touch build.zig
echo "generating project files..."
echo 'const std = @import("std");
const rl = @import("raylib-zig/build.zig");
pub fn build(b: *std.Build) !void {
const web_export = argsContainsWebexport(b.allocator);
if (!web_export) {
const target = b.standardTargetOptions(.{});
const optimize = b.standardOptimizeOption(.{});
var raylib = rl.getModule(b, "raylib-zig");
var raylib_math = rl.math.getModule(b, "raylib-zig");
const exe = b.addExecutable(.{ .name = "'$PROJECT_NAME'", .root_source_file = .{ .path = "src/main.zig" }, .optimize = optimize, .target = target });
rl.link(b, exe, target, optimize);
exe.addModule("raylib", raylib);
exe.addModule("raylib-math", raylib_math);
const run_cmd = b.addRunArtifact(exe);
const run_step = b.step("run", "Run '$PROJECT_NAME'");
run_step.dependOn(&run_cmd.step);
b.installArtifact(exe);
}
//web exports are completely separate, due to the amount of hackery required.
const export_step = b.step("webexport", "Export '$PROJECT_NAME' for the web");
if (web_export) {
export_step.dependOn(try rl.webExport(b, "src/main.zig", "raylib-zig"));
}
// Building for web requires a --sysroot [emscripten and stuff]
// But asking for that for all builds is not a good user experience
// So it will only actually set up the build scripts if the web export is actually going to happen.
}
fn argsContainsWebexport(allocator: std.mem.Allocator) bool {
const args = std.process.argsAlloc(allocator) catch {
return false;
};
defer allocator.free(args);
for (args) |arg| {
if (std.mem.eql(u8, "webexport", arg)) {
return true;
}
}
return false;
}
' >> build.zig
mkdir src
cp ../examples/core/basic_window.zig src/main.zig
cp ../build.zig.zon .
echo "cloning raylib-zig inside of project..."
git clone ../ raylib-zig --recursive