Browse Source

Merge branch 'st/maint-tag' into maint

* st/maint-tag:
  tag: Add more tests about mixing incompatible modes and options
  tag: Check that options are only allowed in the appropriate mode
maint
Junio C Hamano 16 years ago
parent
commit
27f64962f1
  1. 19
      builtin-tag.c
  2. 11
      t/t7004-tag.sh

19
builtin-tag.c

@ -344,7 +344,7 @@ int cmd_tag(int argc, const char **argv, const char *prefix) @@ -344,7 +344,7 @@ int cmd_tag(int argc, const char **argv, const char *prefix)
const char *object_ref, *tag;
struct ref_lock *lock;

int annotate = 0, sign = 0, force = 0, lines = 0,
int annotate = 0, sign = 0, force = 0, lines = -1,
list = 0, delete = 0, verify = 0;
const char *msgfile = NULL, *keyid = NULL;
struct msg_arg msg = { 0, STRBUF_INIT };
@ -380,9 +380,19 @@ int cmd_tag(int argc, const char **argv, const char *prefix) @@ -380,9 +380,19 @@ int cmd_tag(int argc, const char **argv, const char *prefix)
}
if (sign)
annotate = 1;
if (argc == 0 && !(delete || verify))
list = 1;

if ((annotate || msg.given || msgfile || force) &&
(list || delete || verify))
usage_with_options(git_tag_usage, options);

if (list + delete + verify > 1)
usage_with_options(git_tag_usage, options);
if (list)
return list_tags(argv[0], lines);
return list_tags(argv[0], lines == -1 ? 0 : lines);
if (lines != -1)
die("-n option is only allowed with -l.");
if (delete)
return for_each_tag_name(argv, delete_tag);
if (verify)
@ -407,11 +417,6 @@ int cmd_tag(int argc, const char **argv, const char *prefix) @@ -407,11 +417,6 @@ int cmd_tag(int argc, const char **argv, const char *prefix)
}
}

if (argc == 0) {
if (annotate)
usage_with_options(git_tag_usage, options);
return list_tags(NULL, lines);
}
tag = argv[0];

object_ref = argc == 2 ? argv[1] : "HEAD";

11
t/t7004-tag.sh

@ -1090,4 +1090,15 @@ test_expect_success 'filename for the message is relative to cwd' ' @@ -1090,4 +1090,15 @@ test_expect_success 'filename for the message is relative to cwd' '
git cat-file tag tag-from-subdir-2 | grep "in sub directory"
'

# mixing modes and options:

test_expect_success 'mixing incompatibles modes and options is forbidden' '
test_must_fail git tag -a
test_must_fail git tag -l -v
test_must_fail git tag -n 100
test_must_fail git tag -l -m msg
test_must_fail git tag -l -F some file
test_must_fail git tag -v -s
'

test_done

Loading…
Cancel
Save