On Thu, 14 Feb 2008, Jeff King wrote: > On Thu, Feb 14, 2008 at 10:00:58AM -0500, Nicolas Pitre wrote: > > > > When deleting a branch, is there any reason we can't add a deletion > > > entry into the reflog and keep the reflog around? This would seem to be > > > a lot safer; I know I've been burned by expecting the reflog safety net > > > to be there, and surprised that it's not when I've deleted a branch. > > > > No. That would only accumulate dead reflog files in the repository. > > How is that any different than accumulating old entries in reflog files > for branches that _do_ exist? In both cases, they should be dealt with > via time-based pruning. Branches that do exist are more likely to be interesting to you than branches that, hopefully in 99% of all cases, you willfully deleted. > > And as Junio said above, the "HEAD" reflog contains everything you moved > > to, including detached heads, and of course branch heads that might now > > be deleted. You can easily retrieve a deleted branch head from there. > > By that rationale, why do we bother keeping any reflog besides HEAD in > the first place? I can think of two reasons: > > 1. it's much more convenient to type branch@{1} than to sift through > HEAD's reflog looking for checkout events and guessing which branch > we were on Exact. But that doesn't apply to non existent branches, surely? And what would you do with the reflog of a deleted branch when a new branch is created with the same name? > 2. it's possible to change a ref without it being on the HEAD, in > which case the HEAD reflog doesn't contain the change. And in those cases this can't be due to your own modifications, hence nothing valuable is lost if you then delete that branch. > In other words, I don't see "oops, I deleted this branch and its history > is valuable to me" as significantly less likely than "oops, I got rid of > this commit and its history is valuable to me." But you still have it, in the HEAD reflog, at least for your own changes. I therefore don't see the value of having to keep named branch reflogs around just for the small convenience, especially with the semantic issues that comes with it. Nicolas - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html