From: Neal Kreitzinger <nkreitzinger@gmail.com>
To: Jeff King <peff@peff.net>
Cc: Neal Kreitzinger <neal@rsss.com>, git@vger.kernel.org
Subject: Re: suggestion: git status = restored
Date: Tue, 29 Mar 2011 12:32:13 -0500 [thread overview]
Message-ID: <4D92179D.6050102@gmail.com> (raw)
In-Reply-To: <20110329145818.GC10771@sigill.intra.peff.net>
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
next prev parent reply other threads:[~2011-03-29 17:32 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-03-25 17:59 suggestion: git status = restored Neal Kreitzinger
2011-03-29 14:58 ` Jeff King
2011-03-29 17:32 ` Neal Kreitzinger [this message]
2011-03-29 18:51 ` Junio C Hamano
2011-03-29 18:56 ` Matthieu Moy
2011-03-29 21:28 ` Jeff King
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4D92179D.6050102@gmail.com \
--to=nkreitzinger@gmail.com \
--cc=git@vger.kernel.org \
--cc=neal@rsss.com \
--cc=peff@peff.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).