reset: reject --no-(mixed|soft|hard|merge|keep) option
"git reset --no-mixed" behaved exactly like "git reset --mixed", which was nonsense. If there were only two kinds, e.g. "mixed" vs "separate", it might have made sense to make "git reset --no-mixed" behave identically to "git reset --separate" and vice-versa, but because we have many types of reset, let's just forbid "--no-mixed" and negated form of other types. Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
parent
fb7d80edca
commit
3821eb6c3d
|
@ -334,18 +334,25 @@ int cmd_reset(int argc, const char **argv, const char *prefix)
|
||||||
OPT__QUIET(&quiet, N_("be quiet, only report errors")),
|
OPT__QUIET(&quiet, N_("be quiet, only report errors")),
|
||||||
OPT_BOOL(0, "no-refresh", &no_refresh,
|
OPT_BOOL(0, "no-refresh", &no_refresh,
|
||||||
N_("skip refreshing the index after reset")),
|
N_("skip refreshing the index after reset")),
|
||||||
OPT_SET_INT(0, "mixed", &reset_type,
|
OPT_SET_INT_F(0, "mixed", &reset_type,
|
||||||
N_("reset HEAD and index"), MIXED),
|
N_("reset HEAD and index"),
|
||||||
OPT_SET_INT(0, "soft", &reset_type, N_("reset only HEAD"), SOFT),
|
MIXED, PARSE_OPT_NONEG),
|
||||||
OPT_SET_INT(0, "hard", &reset_type,
|
OPT_SET_INT_F(0, "soft", &reset_type,
|
||||||
N_("reset HEAD, index and working tree"), HARD),
|
N_("reset only HEAD"),
|
||||||
OPT_SET_INT(0, "merge", &reset_type,
|
SOFT, PARSE_OPT_NONEG),
|
||||||
N_("reset HEAD, index and working tree"), MERGE),
|
OPT_SET_INT_F(0, "hard", &reset_type,
|
||||||
OPT_SET_INT(0, "keep", &reset_type,
|
N_("reset HEAD, index and working tree"),
|
||||||
N_("reset HEAD but keep local changes"), KEEP),
|
HARD, PARSE_OPT_NONEG),
|
||||||
|
OPT_SET_INT_F(0, "merge", &reset_type,
|
||||||
|
N_("reset HEAD, index and working tree"),
|
||||||
|
MERGE, PARSE_OPT_NONEG),
|
||||||
|
OPT_SET_INT_F(0, "keep", &reset_type,
|
||||||
|
N_("reset HEAD but keep local changes"),
|
||||||
|
KEEP, PARSE_OPT_NONEG),
|
||||||
OPT_CALLBACK_F(0, "recurse-submodules", NULL,
|
OPT_CALLBACK_F(0, "recurse-submodules", NULL,
|
||||||
"reset", "control recursive updating of submodules",
|
"reset", "control recursive updating of submodules",
|
||||||
PARSE_OPT_OPTARG, option_parse_recurse_submodules_worktree_updater),
|
PARSE_OPT_OPTARG,
|
||||||
|
option_parse_recurse_submodules_worktree_updater),
|
||||||
OPT_BOOL('p', "patch", &patch_mode, N_("select hunks interactively")),
|
OPT_BOOL('p', "patch", &patch_mode, N_("select hunks interactively")),
|
||||||
OPT_BOOL('N', "intent-to-add", &intent_to_add,
|
OPT_BOOL('N', "intent-to-add", &intent_to_add,
|
||||||
N_("record only the fact that removed paths will be added later")),
|
N_("record only the fact that removed paths will be added later")),
|
||||||
|
|
|
@ -71,6 +71,16 @@ check_changes () {
|
||||||
done | test_cmp .cat_expect -
|
done | test_cmp .cat_expect -
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# no negated form for various type of resets
|
||||||
|
for opt in soft mixed hard merge keep
|
||||||
|
do
|
||||||
|
test_expect_success "no 'git reset --no-$opt'" '
|
||||||
|
test_when_finished "rm -f err" &&
|
||||||
|
test_must_fail git reset --no-$opt 2>err &&
|
||||||
|
grep "error: unknown option .no-$opt." err
|
||||||
|
'
|
||||||
|
done
|
||||||
|
|
||||||
test_expect_success 'reset --hard message' '
|
test_expect_success 'reset --hard message' '
|
||||||
hex=$(git log -1 --format="%h") &&
|
hex=$(git log -1 --format="%h") &&
|
||||||
git reset --hard >.actual &&
|
git reset --hard >.actual &&
|
||||||
|
|
Loading…
Reference in New Issue