commit: use enum value for multiple cherry-picks
Add FROM_CHERRY_PICK_MULTI for a sequence of cherry-picks rather than using a separate variable. Signed-off-by: Phillip Wood <phillip.wood@dunelm.org.uk> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
parent
21b11c6d1d
commit
8d57f75749
|
@ -122,7 +122,6 @@ static enum commit_msg_cleanup_mode cleanup_mode;
|
||||||
static const char *cleanup_arg;
|
static const char *cleanup_arg;
|
||||||
|
|
||||||
static enum commit_whence whence;
|
static enum commit_whence whence;
|
||||||
static int sequencer_in_use;
|
|
||||||
static int use_editor = 1, include_status = 1;
|
static int use_editor = 1, include_status = 1;
|
||||||
static int have_option_m;
|
static int have_option_m;
|
||||||
static struct strbuf message = STRBUF_INIT;
|
static struct strbuf message = STRBUF_INIT;
|
||||||
|
@ -179,11 +178,9 @@ static void determine_whence(struct wt_status *s)
|
||||||
{
|
{
|
||||||
if (file_exists(git_path_merge_head(the_repository)))
|
if (file_exists(git_path_merge_head(the_repository)))
|
||||||
whence = FROM_MERGE;
|
whence = FROM_MERGE;
|
||||||
else if (file_exists(git_path_cherry_pick_head(the_repository))) {
|
else if (file_exists(git_path_cherry_pick_head(the_repository)))
|
||||||
whence = FROM_CHERRY_PICK;
|
whence = file_exists(git_path_seq_dir()) ?
|
||||||
if (file_exists(git_path_seq_dir()))
|
FROM_CHERRY_PICK_MULTI : FROM_CHERRY_PICK_SINGLE;
|
||||||
sequencer_in_use = 1;
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
whence = FROM_COMMIT;
|
whence = FROM_COMMIT;
|
||||||
if (s)
|
if (s)
|
||||||
|
@ -453,7 +450,7 @@ static const char *prepare_index(int argc, const char **argv, const char *prefix
|
||||||
if (whence != FROM_COMMIT) {
|
if (whence != FROM_COMMIT) {
|
||||||
if (whence == FROM_MERGE)
|
if (whence == FROM_MERGE)
|
||||||
die(_("cannot do a partial commit during a merge."));
|
die(_("cannot do a partial commit during a merge."));
|
||||||
else if (whence == FROM_CHERRY_PICK)
|
else if (is_from_cherry_pick(whence))
|
||||||
die(_("cannot do a partial commit during a cherry-pick."));
|
die(_("cannot do a partial commit during a cherry-pick."));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -771,7 +768,7 @@ static int prepare_to_commit(const char *index_file, const char *prefix,
|
||||||
*/
|
*/
|
||||||
else if (whence == FROM_MERGE)
|
else if (whence == FROM_MERGE)
|
||||||
hook_arg1 = "merge";
|
hook_arg1 = "merge";
|
||||||
else if (whence == FROM_CHERRY_PICK) {
|
else if (is_from_cherry_pick(whence)) {
|
||||||
hook_arg1 = "commit";
|
hook_arg1 = "commit";
|
||||||
hook_arg2 = "CHERRY_PICK_HEAD";
|
hook_arg2 = "CHERRY_PICK_HEAD";
|
||||||
}
|
}
|
||||||
|
@ -948,9 +945,9 @@ static int prepare_to_commit(const char *index_file, const char *prefix,
|
||||||
run_status(stdout, index_file, prefix, 0, s);
|
run_status(stdout, index_file, prefix, 0, s);
|
||||||
if (amend)
|
if (amend)
|
||||||
fputs(_(empty_amend_advice), stderr);
|
fputs(_(empty_amend_advice), stderr);
|
||||||
else if (whence == FROM_CHERRY_PICK) {
|
else if (is_from_cherry_pick(whence)) {
|
||||||
fputs(_(empty_cherry_pick_advice), stderr);
|
fputs(_(empty_cherry_pick_advice), stderr);
|
||||||
if (!sequencer_in_use)
|
if (whence == FROM_CHERRY_PICK_SINGLE)
|
||||||
fputs(_(empty_cherry_pick_advice_single), stderr);
|
fputs(_(empty_cherry_pick_advice_single), stderr);
|
||||||
else
|
else
|
||||||
fputs(_(empty_cherry_pick_advice_multi), stderr);
|
fputs(_(empty_cherry_pick_advice_multi), stderr);
|
||||||
|
@ -1156,7 +1153,7 @@ static int parse_and_validate_options(int argc, const char *argv[],
|
||||||
if (amend && whence != FROM_COMMIT) {
|
if (amend && whence != FROM_COMMIT) {
|
||||||
if (whence == FROM_MERGE)
|
if (whence == FROM_MERGE)
|
||||||
die(_("You are in the middle of a merge -- cannot amend."));
|
die(_("You are in the middle of a merge -- cannot amend."));
|
||||||
else if (whence == FROM_CHERRY_PICK)
|
else if (is_from_cherry_pick(whence))
|
||||||
die(_("You are in the middle of a cherry-pick -- cannot amend."));
|
die(_("You are in the middle of a cherry-pick -- cannot amend."));
|
||||||
}
|
}
|
||||||
if (fixup_message && squash_message)
|
if (fixup_message && squash_message)
|
||||||
|
@ -1179,7 +1176,7 @@ static int parse_and_validate_options(int argc, const char *argv[],
|
||||||
use_message = edit_message;
|
use_message = edit_message;
|
||||||
if (amend && !use_message && !fixup_message)
|
if (amend && !use_message && !fixup_message)
|
||||||
use_message = "HEAD";
|
use_message = "HEAD";
|
||||||
if (!use_message && whence != FROM_CHERRY_PICK && renew_authorship)
|
if (!use_message && !is_from_cherry_pick(whence) && renew_authorship)
|
||||||
die(_("--reset-author can be used only with -C, -c or --amend."));
|
die(_("--reset-author can be used only with -C, -c or --amend."));
|
||||||
if (use_message) {
|
if (use_message) {
|
||||||
use_message_buffer = read_commit_message(use_message);
|
use_message_buffer = read_commit_message(use_message);
|
||||||
|
@ -1188,7 +1185,7 @@ static int parse_and_validate_options(int argc, const char *argv[],
|
||||||
author_message_buffer = use_message_buffer;
|
author_message_buffer = use_message_buffer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (whence == FROM_CHERRY_PICK && !renew_authorship) {
|
if (is_from_cherry_pick(whence) && !renew_authorship) {
|
||||||
author_message = "CHERRY_PICK_HEAD";
|
author_message = "CHERRY_PICK_HEAD";
|
||||||
author_message_buffer = read_commit_message(author_message);
|
author_message_buffer = read_commit_message(author_message);
|
||||||
}
|
}
|
||||||
|
@ -1606,7 +1603,7 @@ int cmd_commit(int argc, const char **argv, const char *prefix)
|
||||||
reduce_heads_replace(&parents);
|
reduce_heads_replace(&parents);
|
||||||
} else {
|
} else {
|
||||||
if (!reflog_msg)
|
if (!reflog_msg)
|
||||||
reflog_msg = (whence == FROM_CHERRY_PICK)
|
reflog_msg = is_from_cherry_pick(whence)
|
||||||
? "commit (cherry-pick)"
|
? "commit (cherry-pick)"
|
||||||
: "commit";
|
: "commit";
|
||||||
commit_list_insert(current_head, &parents);
|
commit_list_insert(current_head, &parents);
|
||||||
|
|
|
@ -38,9 +38,16 @@ enum show_ignored_type {
|
||||||
enum commit_whence {
|
enum commit_whence {
|
||||||
FROM_COMMIT, /* normal */
|
FROM_COMMIT, /* normal */
|
||||||
FROM_MERGE, /* commit came from merge */
|
FROM_MERGE, /* commit came from merge */
|
||||||
FROM_CHERRY_PICK /* commit came from cherry-pick */
|
FROM_CHERRY_PICK_SINGLE, /* commit came from cherry-pick */
|
||||||
|
FROM_CHERRY_PICK_MULTI /* commit came from a sequence of cherry-picks */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static inline int is_from_cherry_pick(enum commit_whence whence)
|
||||||
|
{
|
||||||
|
return whence == FROM_CHERRY_PICK_SINGLE ||
|
||||||
|
whence == FROM_CHERRY_PICK_MULTI;
|
||||||
|
}
|
||||||
|
|
||||||
struct wt_status_change_data {
|
struct wt_status_change_data {
|
||||||
int worktree_status;
|
int worktree_status;
|
||||||
int index_status;
|
int index_status;
|
||||||
|
|
Loading…
Reference in New Issue