Command line toolkit for Zig. Inspired by cobra.
- Separate each subcommand into its own package/file.
- Command specific allocator accessible via Context (
ctx.allocator
). - Modular and composable API.
const std = @import("std");
const zigra = @import("zigra");
const Enum = enum {
Extract,
Transform,
Load,
};
const Handler = struct {
pub const Self = @This();
v: usize = 0,
pub fn init(_: *Self, _: *zigra.Context) !void {}
pub fn run(_: *Self, ctx: *zigra.Context) !void {
std.debug.print("runner {s}\n", .{ctx.cmd});
}
pub fn deinit(_: *Self) void {}
};
const SubHandler = struct {
pub const Self = @This();
verbose: bool = false,
threads: usize = 0,
kind: Enum = .Extract,
id: []const u8 = "",
pub fn init(self: *Self, ctx: *zigra.Context) !void {
try ctx.bind(bool, &self.verbose, "verbose", "v", "Verbose output");
try ctx.bind(usize, &self.threads, "threads", "t", "Number of threads to run");
try ctx.bind(Enum, &self.kind, "worker-kind", "w", "Which worker to run");
try ctx.bind([]const u8, &self.id, "uuid", "u", "Unique identifier for the worker");
}
pub fn run(self: *Self, ctx: *zigra.Context) !void {
std.debug.print("cmd: {s}\n verbose: {}\n threads: {}\n kind: {any}\n id: {s}\n", .{
ctx.cmd,
self.verbose,
self.threads,
self.kind,
self.id,
});
}
pub fn deinit(_: *Self) void {}
};
var h1 = Handler{};
var r1 = zigra.Runner.make(&h1);
var h2 = SubHandler{};
var r2 = zigra.Runner.make(&h2);
pub fn main() !void {
const allocator = std.heap.page_allocator;
var root = try zigra.Command.init(allocator, &r1, "app", "My CLI App");
var one = try zigra.Command.init(allocator, &r2, "one", "First subcommand");
try root.addSubcommand(&one);
defer root.deinit();
try root.exec();
}
./app --help
app: My CLI App
Commands:
one: First subcommand
Arguments:
--verbose, -v (true or false): Verbose output
--threads, -t (integer): Number of threads to run
--worker-kind, -w (enum): Which worker to run
--uuid, -u (string): Unique identifier for the worker
./app one --verbose=true --threads=20 --worker-kind=Extract --uuid=secret-id
cmd: one
verbose: false
threads: 20
kind: main.Enum.Extract
id: secret-id