oddballs: send usage() help text to standard output
Using the show_usage_if_asked() helper we introduced earlier, fix callers of usage() that want to show the help text when explicitly asked by the end-user. The help text now goes to the standard output stream for them. The callers in this step are oddballs in that their invocations of usage() are *not* guarded by if (argc == 2 && !strcmp(argv[1], "-h") usage(...); There are (unnecessarily) being clever ones that do things like if (argc != 2 || !strcmp(argv[1], "-h") usage(...); to say "I know I take only one argument, so argc != 2 is always an error regardless of what is in argv[]. Ah, by the way, even if argc is 2, "-h" is a request for usage text, so we do the same". Some like "git var -h" just do not treat "-h" any specially, and let it take the same error code paths as a parameter error. Now we cannot do the same, so these callers are rewrittin to do the show_usage_and_exit_if_asked() first and then handle the usage error the way they used to. Acked-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
parent
b821c999ca
commit
a36a822d7d
|
@ -18,7 +18,8 @@ int cmd_credential(int argc,
|
||||||
|
|
||||||
git_config(git_default_config, NULL);
|
git_config(git_default_config, NULL);
|
||||||
|
|
||||||
if (argc != 2 || !strcmp(argv[1], "-h"))
|
show_usage_if_asked(argc, argv, usage_msg);
|
||||||
|
if (argc != 2)
|
||||||
usage(usage_msg);
|
usage(usage_msg);
|
||||||
op = argv[1];
|
op = argv[1];
|
||||||
|
|
||||||
|
|
|
@ -75,6 +75,8 @@ int cmd_fetch_pack(int argc,
|
||||||
list_objects_filter_init(&args.filter_options);
|
list_objects_filter_init(&args.filter_options);
|
||||||
args.uploadpack = "git-upload-pack";
|
args.uploadpack = "git-upload-pack";
|
||||||
|
|
||||||
|
show_usage_if_asked(argc, argv, fetch_pack_usage);
|
||||||
|
|
||||||
for (i = 1; i < argc && *argv[i] == '-'; i++) {
|
for (i = 1; i < argc && *argv[i] == '-'; i++) {
|
||||||
const char *arg = argv[i];
|
const char *arg = argv[i];
|
||||||
|
|
||||||
|
|
|
@ -26,6 +26,9 @@ static char *create_temp_file(struct object_id *oid)
|
||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char usage_msg[] =
|
||||||
|
"git unpack-file <blob>";
|
||||||
|
|
||||||
int cmd_unpack_file(int argc,
|
int cmd_unpack_file(int argc,
|
||||||
const char **argv,
|
const char **argv,
|
||||||
const char *prefix UNUSED,
|
const char *prefix UNUSED,
|
||||||
|
@ -33,8 +36,9 @@ int cmd_unpack_file(int argc,
|
||||||
{
|
{
|
||||||
struct object_id oid;
|
struct object_id oid;
|
||||||
|
|
||||||
if (argc != 2 || !strcmp(argv[1], "-h"))
|
show_usage_if_asked(argc, argv, usage_msg);
|
||||||
usage("git unpack-file <blob>");
|
if (argc != 2)
|
||||||
|
usage(usage_msg);
|
||||||
if (repo_get_oid(the_repository, argv[1], &oid))
|
if (repo_get_oid(the_repository, argv[1], &oid))
|
||||||
die("Not a valid object name %s", argv[1]);
|
die("Not a valid object name %s", argv[1]);
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,8 @@ int cmd_upload_archive_writer(int argc,
|
||||||
const char *arg_cmd = "argument ";
|
const char *arg_cmd = "argument ";
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (argc != 2 || !strcmp(argv[1], "-h"))
|
show_usage_if_asked(argc, argv, upload_archive_usage);
|
||||||
|
if (argc != 2)
|
||||||
usage(upload_archive_usage);
|
usage(upload_archive_usage);
|
||||||
|
|
||||||
if (!enter_repo(argv[1], 0))
|
if (!enter_repo(argv[1], 0))
|
||||||
|
|
|
@ -221,6 +221,7 @@ int cmd_var(int argc,
|
||||||
const struct git_var *git_var;
|
const struct git_var *git_var;
|
||||||
char *val;
|
char *val;
|
||||||
|
|
||||||
|
show_usage_if_asked(argc, argv, var_usage);
|
||||||
if (argc != 2)
|
if (argc != 2)
|
||||||
usage(var_usage);
|
usage(var_usage);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue