summaryrefslogtreecommitdiff
path: root/README.md
diff options
context:
space:
mode:
authorGravatar Jimmi Holst Christensen2018-11-15 12:53:46 +0100
committerGravatar Jimmi Holst Christensen2018-11-15 12:53:46 +0100
commit1a219fc680faa79f1236912b14fd58754313df87 (patch)
tree94ee1aee0dd89f0a40d1ab04156dd3dcb7965115 /README.md
parentZig fmt (diff)
downloadzig-clap-1a219fc680faa79f1236912b14fd58754313df87.tar.gz
zig-clap-1a219fc680faa79f1236912b14fd58754313df87.tar.xz
zig-clap-1a219fc680faa79f1236912b14fd58754313df87.zip
Added help function
Diffstat (limited to '')
-rw-r--r--README.md73
1 files changed, 73 insertions, 0 deletions
diff --git a/README.md b/README.md
index 68970d9..cb6a7b0 100644
--- a/README.md
+++ b/README.md
@@ -107,3 +107,76 @@ zig-clap/example/comptime-clap.zig:41:18: note: called from here
107``` 107```
108 108
109Ofc, this limits you to use only parameters that are comptime known. 109Ofc, this limits you to use only parameters that are comptime known.
110
111### `help`
112
113The `help` and `helpEx` are functions for printing a simple list of all parameters the
114program can take.
115
116```rust
117const stderr_file = try std.io.getStdErr();
118var stderr_out_stream = stderr_file.outStream();
119const stderr = &stderr_out_stream.stream;
120
121try clap.help(
122 stderr,
123 []clap.Param([]const u8){
124 clap.Param([]const u8).flag(
125 "Display this help and exit.",
126 clap.Names.prefix("help"),
127 ),
128 clap.Param([]const u8).flag(
129 "Output version information and exit.",
130 clap.Names.prefix("version"),
131 ),
132 },
133);
134```
135
136```
137 -h, --help Display this help and exit.
138 -v, --version Output version information and exit.
139```
140
141The `help` function is the simplest to call. It only takes an `OutStream` and a slice of
142`Param([]const u8)`. This function assumes that the id of each parameter is the help message.
143
144The `clap.helpEx` is the generic version of `help`. It can print a help message for any
145`Param`, but requires some extra arguments for it to work.
146
147```rust
148fn getHelp(_: void, param: clap.Param(u8)) error{}![]const u8 {
149 return switch (param.id) {
150 'h' => "Display this help and exit.",
151 'v' => "Output version information and exit.",
152 else => unreachable,
153 };
154}
155
156fn getValue(_: void, param: clap.Param(u8)) error{}![]const u8 {
157 return "";
158}
159
160const stderr_file = try std.io.getStdErr();
161var stderr_out_stream = stderr_file.outStream();
162const stderr = &stderr_out_stream.stream;
163
164try stderr.print("\n");
165try clap.helpEx(
166 stderr,
167 u8,
168 []clap.Param(u8){
169 clap.Param(u8).flag('h', clap.Names.prefix("help")),
170 clap.Param(u8).flag('v', clap.Names.prefix("version")),
171 },
172 error{},
173 {},
174 getHelp,
175 getValue,
176);
177```
178
179```
180 -h, --help Display this help and exit.
181 -v, --version Output version information and exit.
182```