mirror of
https://github.com/zigzap/zap.git
synced 2025-10-20 15:14:08 +00:00
Merge branch 'qbradley-module'
This commit is contained in:
commit
db6496cd7a
2 changed files with 29 additions and 163 deletions
181
build.zig
181
build.zig
|
@ -6,8 +6,21 @@ pub fn build(b: *std.build.Builder) !void {
|
|||
// between Debug, ReleaseSafe, ReleaseFast, and ReleaseSmall.
|
||||
const optimize = b.standardOptimizeOption(.{});
|
||||
|
||||
var ensure_step = b.step("deps", "ensure external dependencies");
|
||||
ensure_step.makeFn = ensureDeps;
|
||||
const facil_dep = b.dependency("facil.io", .{
|
||||
.target = target,
|
||||
.optimize = optimize,
|
||||
});
|
||||
|
||||
// create a module to be used internally.
|
||||
var zap_module = b.createModule(.{
|
||||
.source_file = .{ .path = "src/zap.zig" },
|
||||
});
|
||||
|
||||
// register the module so it can be referenced
|
||||
// using the package manager.
|
||||
// TODO: How to automatically integrate the
|
||||
// facil.io dependency with the module?
|
||||
try b.modules.put(b.dupe("zap"), zap_module);
|
||||
|
||||
inline for ([_]struct {
|
||||
name: []const u8,
|
||||
|
@ -47,174 +60,16 @@ pub fn build(b: *std.build.Builder) !void {
|
|||
.target = target,
|
||||
.optimize = optimize,
|
||||
});
|
||||
const zap_module = b.createModule(.{ .source_file = .{ .path = "src/zap.zig" } });
|
||||
|
||||
example.linkLibrary(facil_dep.artifact("facil.io"));
|
||||
|
||||
example.addModule("zap", zap_module);
|
||||
try addFacilio(example, "./");
|
||||
|
||||
const example_run = example.run();
|
||||
example_run_step.dependOn(&example_run.step);
|
||||
|
||||
// install the artifact - depending on the "example"
|
||||
// only after the ensure step
|
||||
// the step invoked via `zig build example` on the installed exe which
|
||||
// itself depends on the "ensure" step
|
||||
const example_build_step = b.addInstallArtifact(example);
|
||||
example.step.dependOn(ensure_step);
|
||||
example_step.dependOn(&example_build_step.step);
|
||||
}
|
||||
}
|
||||
|
||||
pub fn ensureDeps(step: *std.build.Step) !void {
|
||||
_ = step;
|
||||
const allocator = std.heap.page_allocator;
|
||||
ensureGit(allocator);
|
||||
ensureGitHook(allocator);
|
||||
try ensureSubmodule(allocator, "src/deps/facilio");
|
||||
try ensurePatch(allocator, "src/deps/facilio", "../0001-microsecond-logging.patch");
|
||||
ensureMake(allocator);
|
||||
try makeFacilioLibdump(allocator);
|
||||
}
|
||||
|
||||
pub fn addFacilio(exe: *std.build.CompileStep, comptime p: [*]const u8) !void {
|
||||
exe.linkLibC();
|
||||
|
||||
// Generate flags
|
||||
var flags = std.ArrayList([]const u8).init(std.heap.page_allocator);
|
||||
if (exe.optimize != .Debug) try flags.append("-Os");
|
||||
try flags.append("-Wno-return-type-c-linkage");
|
||||
try flags.append("-fno-sanitize=undefined");
|
||||
try flags.append("-DFIO_OVERRIDE_MALLOC");
|
||||
try flags.append("-DFIO_HTTP_EXACT_LOGGING");
|
||||
exe.addIncludePath(p ++ "src/deps/facilio/libdump/all");
|
||||
|
||||
// Add C
|
||||
exe.addCSourceFiles(&.{
|
||||
p ++ "src/deps/facilio/libdump/all/http.c",
|
||||
p ++ "src/deps/facilio/libdump/all/fiobj_numbers.c",
|
||||
p ++ "src/deps/facilio/libdump/all/fio_siphash.c",
|
||||
p ++ "src/deps/facilio/libdump/all/fiobj_str.c",
|
||||
p ++ "src/deps/facilio/libdump/all/http1.c",
|
||||
p ++ "src/deps/facilio/libdump/all/fiobj_ary.c",
|
||||
p ++ "src/deps/facilio/libdump/all/fiobj_data.c",
|
||||
p ++ "src/deps/facilio/libdump/all/fiobj_hash.c",
|
||||
p ++ "src/deps/facilio/libdump/all/websockets.c",
|
||||
p ++ "src/deps/facilio/libdump/all/fiobj_json.c",
|
||||
p ++ "src/deps/facilio/libdump/all/fio.c",
|
||||
p ++ "src/deps/facilio/libdump/all/fiobject.c",
|
||||
p ++ "src/deps/facilio/libdump/all/http_internal.c",
|
||||
p ++ "src/deps/facilio/libdump/all/fiobj_mustache.c",
|
||||
}, flags.items);
|
||||
}
|
||||
|
||||
pub fn addZap(exe: *std.build.CompileStep, comptime p: [*]const u8) !void {
|
||||
try addFacilio(exe, p);
|
||||
var b = exe.builder;
|
||||
var ensure_step = b.step("zap-deps", "ensure zap's dependencies");
|
||||
ensure_step.makeFn = ensureDeps;
|
||||
exe.step.dependOn(ensure_step);
|
||||
}
|
||||
|
||||
fn sdkPath(comptime suffix: []const u8) []const u8 {
|
||||
if (suffix[0] != '/') @compileError("suffix must be an absolute path");
|
||||
return comptime blk: {
|
||||
const root_dir = std.fs.path.dirname(@src().file) orelse ".";
|
||||
break :blk root_dir ++ suffix;
|
||||
};
|
||||
}
|
||||
|
||||
fn ensureGit(allocator: std.mem.Allocator) void {
|
||||
const result = std.ChildProcess.exec(.{
|
||||
.allocator = allocator,
|
||||
.argv = &.{ "git", "--version" },
|
||||
}) catch { // e.g. FileNotFound
|
||||
std.log.err("error: 'git --version' failed. Is git not installed?", .{});
|
||||
std.process.exit(1);
|
||||
};
|
||||
defer {
|
||||
allocator.free(result.stderr);
|
||||
allocator.free(result.stdout);
|
||||
}
|
||||
if (result.term.Exited != 0) {
|
||||
std.log.err("error: 'git --version' failed. Is git not installed?", .{});
|
||||
std.process.exit(1);
|
||||
}
|
||||
}
|
||||
|
||||
pub fn ensureGitHook(allocator: std.mem.Allocator) void {
|
||||
// only check if we ourselves are not part of a submodule
|
||||
var cwd = std.fs.cwd().openDir(sdkPath("/"), .{}) catch return;
|
||||
defer cwd.close();
|
||||
const dotgit = cwd.statFile(".git") catch return;
|
||||
if (dotgit.kind == .File) {
|
||||
// we are checked out as a submodule. No point in trying to install
|
||||
// a hook
|
||||
return;
|
||||
}
|
||||
|
||||
var child = std.ChildProcess.init(
|
||||
&.{ "cp", "precommit-hook.sh", ".git/hooks/pre-commit" },
|
||||
allocator,
|
||||
);
|
||||
child.cwd = sdkPath("/");
|
||||
child.stderr = std.io.getStdErr();
|
||||
child.stdout = std.io.getStdOut();
|
||||
_ = child.spawnAndWait() catch {
|
||||
std.log.err("Warning: unable to install git precommit-hook ", .{});
|
||||
return;
|
||||
};
|
||||
}
|
||||
|
||||
fn ensureSubmodule(allocator: std.mem.Allocator, path: []const u8) !void {
|
||||
if (std.process.getEnvVarOwned(allocator, "NO_ENSURE_SUBMODULES")) |no_ensure_submodules| {
|
||||
defer allocator.free(no_ensure_submodules);
|
||||
if (std.mem.eql(u8, no_ensure_submodules, "true")) return;
|
||||
} else |_| {}
|
||||
var child = std.ChildProcess.init(&.{ "git", "submodule", "update", "--init", path }, allocator);
|
||||
child.cwd = sdkPath("/");
|
||||
child.stderr = std.io.getStdErr();
|
||||
child.stdout = std.io.getStdOut();
|
||||
_ = try child.spawnAndWait();
|
||||
}
|
||||
|
||||
fn ensurePatch(allocator: std.mem.Allocator, path: []const u8, patch: []const u8) !void {
|
||||
if (std.process.getEnvVarOwned(allocator, "NO_ENSURE_SUBMODULES")) |no_ensure_submodules| {
|
||||
defer allocator.free(no_ensure_submodules);
|
||||
if (std.mem.eql(u8, no_ensure_submodules, "true")) return;
|
||||
} else |_| {}
|
||||
var child = std.ChildProcess.init(&.{ "git", "-C", path, "am", "-3", patch }, allocator);
|
||||
child.cwd = sdkPath("/");
|
||||
child.stderr = std.io.getStdErr();
|
||||
child.stdout = std.io.getStdOut();
|
||||
_ = try child.spawnAndWait();
|
||||
}
|
||||
|
||||
fn ensureMake(allocator: std.mem.Allocator) void {
|
||||
const result = std.ChildProcess.exec(.{
|
||||
.allocator = allocator,
|
||||
.argv = &.{ "make", "--version" },
|
||||
}) catch { // e.g. FileNotFound
|
||||
std.log.err("error: 'make --version' failed. Is make not installed?", .{});
|
||||
std.process.exit(1);
|
||||
};
|
||||
defer {
|
||||
allocator.free(result.stderr);
|
||||
allocator.free(result.stdout);
|
||||
}
|
||||
if (result.term.Exited != 0) {
|
||||
std.log.err("error: 'make --version' failed. Is make not installed?", .{});
|
||||
std.process.exit(1);
|
||||
}
|
||||
}
|
||||
|
||||
fn makeFacilioLibdump(allocator: std.mem.Allocator) !void {
|
||||
var child = std.ChildProcess.init(&.{
|
||||
"make",
|
||||
"-C",
|
||||
"./src/deps/facilio",
|
||||
"libdump",
|
||||
}, allocator);
|
||||
child.cwd = sdkPath("/");
|
||||
child.stderr = std.io.getStdErr();
|
||||
child.stdout = std.io.getStdOut();
|
||||
_ = try child.spawnAndWait();
|
||||
}
|
||||
|
|
11
build.zig.zon
Normal file
11
build.zig.zon
Normal file
|
@ -0,0 +1,11 @@
|
|||
.{
|
||||
.name = "zap",
|
||||
.version = "0.0.1",
|
||||
|
||||
.dependencies = .{
|
||||
.@"facil.io" = .{
|
||||
.url = "https://github.com/renerocksai/facil.io/archive/2c04cd1949328dd62fe5d262b9cc930e54392ab8.tar.gz",
|
||||
.hash = "12209d3b552145f24431e5a2e6a4ad59ceaa9656f7fba8af7a8aa704a8784a79f55d",
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue