From: Junio C Hamano Date: Fri, 12 Jan 2007 03:56:43 +0000 (-0800) Subject: reflog-expire: brown paper bag fix. X-Git-Tag: v1.5.0-rc2~120 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=9bbaa6cc6848b68b8bef681c2a22b57bbec3e914;p=git.git reflog-expire: brown paper bag fix. When --stale-fix is not passed, the code did not initialize the two commit objects properly. Signed-off-by: Junio C Hamano --- diff --git a/builtin-reflog.c b/builtin-reflog.c index ca22452e6..7206b7a01 100644 --- a/builtin-reflog.c +++ b/builtin-reflog.c @@ -173,7 +173,6 @@ static int keep_entry(struct commit **it, unsigned char *sha1) { struct commit *commit; - *it = NULL; if (is_null_sha1(sha1)) return 1; commit = lookup_commit_reference_gently(sha1, 1); @@ -204,15 +203,22 @@ static int expire_reflog_ent(unsigned char *osha1, unsigned char *nsha1, if (timestamp < cb->cmd->expire_total) goto prune; + old = new = NULL; if (cb->cmd->stalefix && (!keep_entry(&old, osha1) || !keep_entry(&new, nsha1))) goto prune; - if ((timestamp < cb->cmd->expire_unreachable) && - (!cb->ref_commit || - (old && !in_merge_bases(old, cb->ref_commit)) || - (new && !in_merge_bases(new, cb->ref_commit)))) - goto prune; + if (timestamp < cb->cmd->expire_unreachable) { + if (!cb->ref_commit) + goto prune; + if (!old && !is_null_sha1(osha1)) + old = lookup_commit_reference_gently(osha1, 1); + if (!new && !is_null_sha1(nsha1)) + new = lookup_commit_reference_gently(nsha1, 1); + if ((old && !in_merge_bases(old, cb->ref_commit)) || + (new && !in_merge_bases(new, cb->ref_commit))) + goto prune; + } if (cb->newlog) { char sign = (tz < 0) ? '-' : '+';