merge -h: show usage even with corrupt index

Part of a campaign to make sure "git <command> -h" works correctly
when run from distractingly bad repositories.

[jn: with rewritten log message and tests]

Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Jonathan Nieder <jrnieder@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Nguyễn Thái Ngọc Duy 2010-10-22 01:49:45 -05:00 committed by Junio C Hamano
parent cbb3167ef8
commit da53eec688
2 changed files with 13 additions and 0 deletions

View File

@ -909,6 +909,8 @@ int cmd_merge(int argc, const char **argv, const char *prefix)
const char *best_strategy = NULL, *wt_strategy = NULL; const char *best_strategy = NULL, *wt_strategy = NULL;
struct commit_list **remotes = &remoteheads; struct commit_list **remotes = &remoteheads;
if (argc == 2 && !strcmp(argv[1], "-h"))
usage_with_options(builtin_merge_usage, builtin_merge_options);
if (read_cache_unmerged()) { if (read_cache_unmerged()) {
die_resolve_conflict("merge"); die_resolve_conflict("merge");
} }

View File

@ -144,6 +144,17 @@ test_expect_success 'test option parsing' '
test_must_fail git merge test_must_fail git merge
' '
test_expect_success 'merge -h with invalid index' '
mkdir broken &&
(
cd broken &&
git init &&
>.git/index &&
test_expect_code 129 git merge -h 2>usage
) &&
grep "[Uu]sage: git merge" broken/usage
'
test_expect_success 'reject non-strategy with a git-merge-foo name' ' test_expect_success 'reject non-strategy with a git-merge-foo name' '
test_must_fail git merge -s index c1 test_must_fail git merge -s index c1
' '