mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2024-12-25 22:08:46 +01:00
68 lines
1.9 KiB
Zig
68 lines
1.9 KiB
Zig
const std = @import("std");
|
|
|
|
pub fn build(b: *std.Build) void {
|
|
const target = b.standardTargetOptions(.{});
|
|
const optimize = b.standardOptimizeOption(.{});
|
|
const want_lto = b.option(bool, "lto", "Want -fLTO");
|
|
|
|
const lib = b.addStaticLibrary(.{
|
|
.name = "llama",
|
|
.target = target,
|
|
.optimize = optimize,
|
|
});
|
|
lib.want_lto = want_lto;
|
|
lib.linkLibCpp();
|
|
lib.addIncludePath(".");
|
|
lib.addIncludePath("examples");
|
|
lib.addCSourceFiles(&.{
|
|
"ggml.c",
|
|
}, &.{"-std=c11"});
|
|
lib.addCSourceFiles(&.{
|
|
"llama.cpp",
|
|
}, &.{"-std=c++11"});
|
|
lib.install();
|
|
|
|
const build_args = .{ .b = b, .lib = lib, .target = target, .optimize = optimize, .want_lto = want_lto };
|
|
|
|
const exe = build_example("main", build_args);
|
|
_ = build_example("quantize", build_args);
|
|
_ = build_example("perplexity", build_args);
|
|
_ = build_example("embedding", build_args);
|
|
|
|
// create "zig build run" command for ./main
|
|
|
|
const run_cmd = exe.run();
|
|
run_cmd.step.dependOn(b.getInstallStep());
|
|
if (b.args) |args| {
|
|
run_cmd.addArgs(args);
|
|
}
|
|
|
|
const run_step = b.step("run", "Run the app");
|
|
run_step.dependOn(&run_cmd.step);
|
|
}
|
|
|
|
fn build_example(comptime name: []const u8, args: anytype) *std.build.LibExeObjStep {
|
|
const b = args.b;
|
|
const lib = args.lib;
|
|
const target = args.target;
|
|
const optimize = args.optimize;
|
|
const want_lto = args.want_lto;
|
|
|
|
const exe = b.addExecutable(.{
|
|
.name = name,
|
|
.target = target,
|
|
.optimize = optimize,
|
|
});
|
|
exe.want_lto = want_lto;
|
|
exe.addIncludePath(".");
|
|
exe.addIncludePath("examples");
|
|
exe.addCSourceFiles(&.{
|
|
std.fmt.comptimePrint("examples/{s}/{s}.cpp", .{name, name}),
|
|
"examples/common.cpp",
|
|
}, &.{"-std=c++11"});
|
|
exe.linkLibrary(lib);
|
|
exe.install();
|
|
|
|
return exe;
|
|
}
|