File: build.zig

package info (click to toggle)
liboprf 0.9.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,720 kB
  • sloc: ansic: 19,331; python: 1,920; makefile: 418
file content (81 lines) | stat: -rw-r--r-- 2,685 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
const std = @import("std");
const fmt = std.fmt;
const fs = std.fs;
const heap = std.heap;
const mem = std.mem;
const Compile = std.Build.Step.Compile;

fn initLibConfig(b: *std.Build, lib: *Compile) void {
    lib.linkLibC();
    lib.addIncludePath(b.path("src/"));
    lib.addIncludePath(b.path("src/noise_xk/include"));
    lib.addIncludePath(b.path("src/noise_xk/include/karmel"));
    lib.addIncludePath(b.path("src/noise_xk/include/karmel/minimal"));
    //lib.want_lto = false;
}

pub fn build(b: *std.Build) !void {
    const root_path = b.pathFromRoot(".");
    var cwd = try fs.openDirAbsolute(root_path, .{});
    defer cwd.close();

    const src_path = "src/";
    const src_dir = try fs.Dir.openDir(cwd, src_path, .{ .iterate = true, .no_follow = true });

    const target = b.standardTargetOptions(.{});
    const optimize = b.standardOptimizeOption(.{});

    const static_lib = b.addLibrary(.{
        .name = "liboprf",
        .linkage = .static,
        .root_module = b.createModule(.{
            .target = target,
            .optimize = optimize,
        }),
    });

    const libsodium_package = b.dependency("libsodium", .{
        .target = target,
        .optimize = optimize,
        .@"test" = false, // `test` is a keyword in zig
        .static = true,
        .shared = false
    });
    static_lib.linkLibrary(libsodium_package.artifact("sodium"));
    static_lib.addIncludePath(libsodium_package.path("include"));

    b.installArtifact(static_lib);
    initLibConfig(b, static_lib);

    const flags = &.{
        "-fvisibility=hidden",
        "-fPIC",
        "-fwrapv",
    };

    static_lib.installHeadersDirectory(b.path(src_path ++ "/noise_xk/include"), "oprf/noise_xk", .{});

    const allocator = heap.page_allocator;

    var walker = try src_dir.walk(allocator);
    while (try walker.next()) |entry| {
        if(mem.startsWith(u8, entry.path, "tests")) continue;

        const name = entry.basename;
        if(mem.eql(u8, name, "xk-ex.c")) continue;

        if (mem.endsWith(u8, name, ".c")) {
            const full_path = try fmt.allocPrint(allocator, "{s}/{s}", .{ src_path, entry.path });
            static_lib.addCSourceFile(.{
                .file = b.path(full_path),
                .flags = flags,
            });
        } else if (mem.endsWith(u8, name, ".h")) {
            const full_path = try fmt.allocPrint(allocator, "{s}/{s}", .{ src_path, entry.path });
            if(!mem.startsWith(u8, entry.path, "noise_xk")) {
                const full_dest = try fmt.allocPrint(allocator, "oprf/{s}", .{ name });
                static_lib.installHeader(b.path(full_path), full_dest);
            }
        }
    }
}