On 3/29/2011 9:58 AM, Jeff King wrote:
On Fri, Mar 25, 2011 at 12:59:34PM -0500, Neal Kreitzinger wrote:
We deleted (git-rm) a file from the repo by mistake. Several commits later
we restored it (git-checkout, git-commit). Git status shows "added" for
this file. IMHO, it seems like git status should be "restored" or
"unremoved", etc, for this file. Git detects renames and copies so it seems
like it could detect restores.
I am mildly negative on the idea, though I think it is mostly just
because I would not find that information useful at all.
But what gives me pause is that it is adding a totally new dimension to
git-status. Currently status is about three things:
1. What's in your index, and how does it differ from what's in HEAD.
2. What's in your working tree, and how does it differ from what's in
your index.
3. What untracked files are in your working tree.
So it is only about HEAD, the index, and the working tree, and we only
have to look at those things. We detect copies and renames, yes, but
only in the diffs between those points.
But what you are proposing requires looking backwards in history to see
if we used to have something like the thing that has been added. So that
introduces a few questions:
1. What are we claiming to have "used to have"? Some arbitrary content
at the same path, or similar content at the same path, or similar
content at any path?
2. Which history do we look at? Do we start traversing backwards from
HEAD? If so, how far back do we go (you probably don't want to go
to the roots, which is expensive)? Is it useful to see similar
files on other branches (e.g., instead of "you are adding foo,
which is being resurrected from 'HEAD~20: remove foo'", you would
find out that "you are adding foo, which has also been added on
branch 'topic'").
3. How expensive is the test going to end up? For generating a commit
template or running "git status", it's probably OK. But keep in
mind also that people run "git status --porcelain" to generate
their shell prompt. So it needs to either be really fast, or it
needs to be easy to turn it off in some cases.
-Peff
I see your point about the current worktree/index/HEAD. I'm not a git
developer, but my idea is based on the concept that the sha-1 of the
content already exists in the object store regardless of its path(s).
I'm talking about identical blob sha-1's, not "similar" content. It
seems like the loose object directory would be easy enough the check for
duplicate blob sha-1's, but the the pack would probably be more
difficult (i'm not sure how you could do that). If this capability
doesn't fit well into fast default behavior, maybe there could be an
option to --find-restores-harder.
That being said, I see how it may not be feasible for git-status to do
that extra work. Git-status runs against "what you just did" so
hopefully I should know in my mind that I just checked something out to
restore it. However, for analyzing history it would be nice for git-log
or git-diff to be able to do that extra work of finding restores when asked.
In our workflow it would be useful because we have a utility directory
of mostly obsolete programs that needs to be deleted to eliminate noise,
but we're sure some of them will get restored once we realize they're
still needed. An interrogation command with --name-status
--find-restores-harder would give an accurate picture of what was really
added (new content) and what was simply restored (old content revived).
v/r,
neal
--
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