summaryrefslogtreecommitdiff
path: root/example/help.zig
blob: 676a56aeae17d69bc9b09fd3e5b7c9ab45da3033 (plain) (blame)
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
pub fn main() !void {
    var gpa = std.heap.GeneralPurposeAllocator(.{}){};
    defer _ = gpa.deinit();

    const params = comptime clap.parseParamsComptime(
        \\-h, --help     Display this help and exit.
        \\-v, --version  Output version information and exit.
        \\
    );

    var res = try clap.parse(clap.Help, &params, clap.parsers.default, .{
        .allocator = gpa.allocator(),
    });
    defer res.deinit();

    // `clap.help` is a function that can print a simple help message. It can print any `Param`
    // where `Id` has a `description` and `value` method (`Param(Help)` is one such parameter).
    // The last argument contains options as to how `help` should print those parameters. Using
    // `.{}` means the default options.
    if (res.args.help != 0) {
        var buf: [1024]u8 = undefined;
        var stderr = std.fs.File.stderr().writer(&buf);
        try clap.help(&stderr.interface, clap.Help, &params, .{});
        return stderr.interface.flush();
    }
}

const clap = @import("clap");
const std = @import("std");