зеркало из https://github.com/microsoft/git.git
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:
Родитель
20d6b6868c
Коммит
07815e2d97
|
@ -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);
|
||||||
|
|
Загрузка…
Ссылка в новой задаче