aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/src/wg.c
diff options
context:
space:
mode:
authorJason A. Donenfeld <Jason@zx2c4.com>2016-07-03 20:06:33 +0200
committerJason A. Donenfeld <Jason@zx2c4.com>2016-07-03 20:45:48 +0200
commit742f038fc2d57b15d1539c3cfc7d0c2fe45ac530 (patch)
tree5713d6b29fb56bb07615cae7d778260627f71cbc /src/wg.c
parentcontrib: remove extraneous cruft (diff)
downloadwireguard-tools-742f038fc2d57b15d1539c3cfc7d0c2fe45ac530.tar.xz
wireguard-tools-742f038fc2d57b15d1539c3cfc7d0c2fe45ac530.zip
wg: improve error reporting and detection
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
Diffstat (limited to 'src/wg.c')
-rw-r--r--src/wg.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/src/wg.c b/src/wg.c
index d4d2965..ee19387 100644
--- a/src/wg.c
+++ b/src/wg.c
@@ -23,12 +23,13 @@ static const struct {
{ "pubkey", pubkey_main, "Reads a private key from stdin and writes a public key to stdout" }
};
-static void show_usage(void)
+static void show_usage(FILE *file)
{
- fprintf(stderr, "Usage: %s <cmd> [<args>]\n\n", PROG_NAME);
- fprintf(stderr, "Available subcommands:\n");
+ fprintf(file, "Usage: %s <cmd> [<args>]\n\n", PROG_NAME);
+ fprintf(file, "Available subcommands:\n");
for (size_t i = 0; i < sizeof(subcommands) / sizeof(subcommands[0]); ++i)
- fprintf(stderr, " %s: %s\n", subcommands[i].subcommand, subcommands[i].description);
+ fprintf(file, " %s: %s\n", subcommands[i].subcommand, subcommands[i].description);
+ fprintf(file, "You may pass `--help' to any of these subcommands to view usage.\n");
}
int main(int argc, char *argv[])
@@ -37,8 +38,8 @@ int main(int argc, char *argv[])
PROG_NAME = argv[0];
if (argc == 2 && (!strcmp(argv[1], "-h") || !strcmp(argv[1], "--help") || !strcmp(argv[1], "help"))) {
- show_usage();
- return 1;
+ show_usage(stdout);
+ return 0;
}
if (argc == 1) {
@@ -61,6 +62,6 @@ findsubcommand:
}
fprintf(stderr, "Invalid subcommand: `%s`\n", argv[1]);
- show_usage();
+ show_usage(stderr);
return 1;
}