builtin rebase: start a new rebase only if none is in progress

To run a new rebase, there needs to be a check to assure that no other
rebase is in progress. New rebase operation cannot start until an
ongoing rebase operation completes or is terminated.

Signed-off-by: Pratik Karki <predatoramigo@gmail.com>
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Pratik Karki 2018-09-04 14:27:18 -07:00 committed by Junio C Hamano
parent 1ed9c14ff2
commit c54dacb50e

View File

@ -87,6 +87,7 @@ struct rebase_options {
REBASE_VERBOSE = 1<<1, REBASE_VERBOSE = 1<<1,
REBASE_DIFFSTAT = 1<<2, REBASE_DIFFSTAT = 1<<2,
REBASE_FORCE = 1<<3, REBASE_FORCE = 1<<3,
REBASE_INTERACTIVE_EXPLICIT = 1<<4,
} flags; } flags;
struct strbuf git_am_opt; struct strbuf git_am_opt;
}; };
@ -392,10 +393,11 @@ int cmd_rebase(int argc, const char **argv, const char *prefix)
.git_am_opt = STRBUF_INIT, .git_am_opt = STRBUF_INIT,
}; };
const char *branch_name; const char *branch_name;
int ret, flags; int ret, flags, in_progress = 0;
int ok_to_skip_pre_rebase = 0; int ok_to_skip_pre_rebase = 0;
struct strbuf msg = STRBUF_INIT; struct strbuf msg = STRBUF_INIT;
struct strbuf revisions = STRBUF_INIT; struct strbuf revisions = STRBUF_INIT;
struct strbuf buf = STRBUF_INIT;
struct object_id merge_base; struct object_id merge_base;
struct option builtin_rebase_options[] = { struct option builtin_rebase_options[] = {
OPT_STRING(0, "onto", &options.onto_name, OPT_STRING(0, "onto", &options.onto_name,
@ -447,6 +449,30 @@ int cmd_rebase(int argc, const char **argv, const char *prefix)
git_config(rebase_config, &options); git_config(rebase_config, &options);
if (is_directory(apply_dir())) {
options.type = REBASE_AM;
options.state_dir = apply_dir();
} else if (is_directory(merge_dir())) {
strbuf_reset(&buf);
strbuf_addf(&buf, "%s/rewritten", merge_dir());
if (is_directory(buf.buf)) {
options.type = REBASE_PRESERVE_MERGES;
options.flags |= REBASE_INTERACTIVE_EXPLICIT;
} else {
strbuf_reset(&buf);
strbuf_addf(&buf, "%s/interactive", merge_dir());
if(file_exists(buf.buf)) {
options.type = REBASE_INTERACTIVE;
options.flags |= REBASE_INTERACTIVE_EXPLICIT;
} else
options.type = REBASE_MERGE;
}
options.state_dir = merge_dir();
}
if (options.type != REBASE_UNSPECIFIED)
in_progress = 1;
argc = parse_options(argc, argv, prefix, argc = parse_options(argc, argv, prefix,
builtin_rebase_options, builtin_rebase_options,
builtin_rebase_usage, 0); builtin_rebase_usage, 0);
@ -455,6 +481,26 @@ int cmd_rebase(int argc, const char **argv, const char *prefix)
usage_with_options(builtin_rebase_usage, usage_with_options(builtin_rebase_usage,
builtin_rebase_options); builtin_rebase_options);
/* Make sure no rebase is in progress */
if (in_progress) {
const char *last_slash = strrchr(options.state_dir, '/');
const char *state_dir_base =
last_slash ? last_slash + 1 : options.state_dir;
const char *cmd_live_rebase =
"git rebase (--continue | --abort | --skip)";
strbuf_reset(&buf);
strbuf_addf(&buf, "rm -fr \"%s\"", options.state_dir);
die(_("It seems that there is already a %s directory, and\n"
"I wonder if you are in the middle of another rebase. "
"If that is the\n"
"case, please try\n\t%s\n"
"If that is not the case, please\n\t%s\n"
"and run me again. I am stopping in case you still "
"have something\n"
"valuable there.\n"),
state_dir_base, cmd_live_rebase, buf.buf);
}
if (!(options.flags & REBASE_NO_QUIET)) if (!(options.flags & REBASE_NO_QUIET))
strbuf_addstr(&options.git_am_opt, " -q"); strbuf_addstr(&options.git_am_opt, " -q");