rebase: prepare reset_head() for more flags

Currently, we only accept the flag indicating whether the HEAD should be
detached not. In the next commit, we want to introduce another flag: to
toggle between emulating `reset --hard` vs `checkout -q`.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Johannes Schindelin 2018-11-12 03:44:31 -08:00 committed by Junio C Hamano
parent 3249c1251e
commit 73d6d7b24b

View File

@ -522,10 +522,13 @@ finished_rebase:
#define GIT_REFLOG_ACTION_ENVIRONMENT "GIT_REFLOG_ACTION" #define GIT_REFLOG_ACTION_ENVIRONMENT "GIT_REFLOG_ACTION"
#define RESET_HEAD_DETACH (1<<0)
static int reset_head(struct object_id *oid, const char *action, static int reset_head(struct object_id *oid, const char *action,
const char *switch_to_branch, int detach_head, const char *switch_to_branch, unsigned flags,
const char *reflog_orig_head, const char *reflog_head) const char *reflog_orig_head, const char *reflog_head)
{ {
unsigned detach_head = flags & RESET_HEAD_DETACH;
struct object_id head_oid; struct object_id head_oid;
struct tree_desc desc; struct tree_desc desc;
struct lock_file lock = LOCK_INIT; struct lock_file lock = LOCK_INIT;
@ -1500,8 +1503,8 @@ int cmd_rebase(int argc, const char **argv, const char *prefix)
"it...\n")); "it...\n"));
strbuf_addf(&msg, "rebase: checkout %s", options.onto_name); strbuf_addf(&msg, "rebase: checkout %s", options.onto_name);
if (reset_head(&options.onto->object.oid, "checkout", NULL, 1, if (reset_head(&options.onto->object.oid, "checkout", NULL,
NULL, msg.buf)) RESET_HEAD_DETACH, NULL, msg.buf))
die(_("Could not detach HEAD")); die(_("Could not detach HEAD"));
strbuf_release(&msg); strbuf_release(&msg);