reflog expire: refactor & use "tip_commit" only for UE_NORMAL

Add an intermediate variable for "tip_commit" in
reflog_expiry_prepare(), and only add it to the struct if we're
handling the UE_NORMAL case.

The code behaves the same way as before, but this makes the control
flow clearer, and the shorter name allows us to fold a 4-line i/else
into a one-line ternary instead.

Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Ævar Arnfjörð Bjarmason 2021-12-22 05:06:44 +01:00 коммит произвёл Junio C Hamano
Родитель 20d6b6868c
Коммит 07815e2d97
1 изменённых файлов: 7 добавлений и 7 удалений

Просмотреть файл

@ -354,16 +354,14 @@ static void reflog_expiry_prepare(const char *refname,
{ {
struct expire_reflog_policy_cb *cb = cb_data; struct expire_reflog_policy_cb *cb = cb_data;
struct commit_list *elem; struct commit_list *elem;
struct commit *commit = NULL;
if (!cb->cmd.expire_unreachable || is_head(refname)) { if (!cb->cmd.expire_unreachable || is_head(refname)) {
cb->unreachable_expire_kind = UE_HEAD; cb->unreachable_expire_kind = UE_HEAD;
} else { } else {
cb->tip_commit = lookup_commit_reference_gently(the_repository, commit = lookup_commit_reference_gently(the_repository,
oid, 1); oid, 1);
if (!cb->tip_commit) cb->unreachable_expire_kind = commit ? UE_NORMAL : UE_ALWAYS;
cb->unreachable_expire_kind = UE_ALWAYS;
else
cb->unreachable_expire_kind = UE_NORMAL;
} }
if (cb->cmd.expire_unreachable <= cb->cmd.expire_total) if (cb->cmd.expire_unreachable <= cb->cmd.expire_total)
@ -378,7 +376,9 @@ static void reflog_expiry_prepare(const char *refname,
commit_list_insert(elem->item, &cb->mark_list); commit_list_insert(elem->item, &cb->mark_list);
break; break;
case UE_NORMAL: case UE_NORMAL:
commit_list_insert(cb->tip_commit, &cb->mark_list); commit_list_insert(commit, &cb->mark_list);
/* For reflog_expiry_cleanup() below */
cb->tip_commit = commit;
} }
cb->mark_limit = cb->cmd.expire_total; cb->mark_limit = cb->cmd.expire_total;
mark_reachable(cb); mark_reachable(cb);