Browse Source

hash-object: -- and --help

It was cumbersome to feed hash-object the file '-t' (you could
have said "./-t", though).  Teach it '--' that terminates the
option list, like everybody else.  There is no way to extract
usage string from the command either, so teach it "--help" as
well.

Signed-off-by: Junio C Hamano <junkio@cox.net>
maint
Junio C Hamano 20 years ago
parent
commit
9c2e7c0ca2
  1. 32
      hash-object.c

32
hash-object.c

@ -31,19 +31,30 @@ int main(int argc, char **argv)
int write_object = 0; int write_object = 0;
const char *prefix = NULL; const char *prefix = NULL;
int prefix_length = -1; int prefix_length = -1;
int no_more_flags = 0;


for (i = 1 ; i < argc; i++) { for (i = 1 ; i < argc; i++) {
if (!strcmp(argv[i], "-t")) { if (!no_more_flags && argv[i][0] == '-') {
if (argc <= ++i) if (!strcmp(argv[i], "-t")) {
die(hash_object_usage); if (argc <= ++i)
type = argv[i]; die(hash_object_usage);
} type = argv[i];
else if (!strcmp(argv[i], "-w")) { }
if (prefix_length < 0) { else if (!strcmp(argv[i], "-w")) {
prefix = setup_git_directory(); if (prefix_length < 0) {
prefix_length = prefix ? strlen(prefix) : 0; prefix = setup_git_directory();
prefix_length =
prefix ? strlen(prefix) : 0;
}
write_object = 1;
} }
write_object = 1; else if (!strcmp(argv[i], "--")) {
no_more_flags = 1;
}
else if (!strcmp(argv[i], "--help"))
usage(hash_object_usage);
else
die(hash_object_usage);
} }
else { else {
const char *arg = argv[i]; const char *arg = argv[i];
@ -51,6 +62,7 @@ int main(int argc, char **argv)
arg = prefix_filename(prefix, prefix_length, arg = prefix_filename(prefix, prefix_length,
arg); arg);
hash_object(arg, type, write_object); hash_object(arg, type, write_object);
no_more_flags = 1;
} }
} }
return 0; return 0;

Loading…
Cancel
Save