Dear diary, on Thu, Apr 14, 2005 at 11:40:09AM CEST, I got a letter
where Martin Schlemmer <[EMAIL PROTECTED]> told me that...
> (PS, can you check the fact that your mail client keeps on adding a 'Re:
> ' ...)

Hmm. I guess my ancient reply_regexp
"^((\\[|\\()([^B]|B([^u]|u([^g]|g([^ ]|AnTiMaTcH))))[^]]+(\\]|\\)))?[
 \t]*((re([\\[0-9\\]+])*|aw):[ \t]*)?" is broken... ;-)

> On Thu, 2005-04-14 at 11:11 +0200, Petr Baudis wrote:
> > I'm lost. Why do you do --update-modes? That makes no sense to me.
> > You introduce them to the cache out-of-order w.r.t. commits, that means
> > in the normal git usage they are already unrevertable.
> > 
> 
> Right, afterwards I thought I did add it to the wrong place.

So, could you please do something with it? :-)

> > What are you trying to do? Mode changes _are_ real changes. You _don't_
> > want to silence them. What you want is to even show them more explicitly
> > in show-diff.
> > 
> 
> No, you do not understand.  If you actually change the mode, it will
> show.  What now happens, is that say I track the 'linus' branch, then
> untrack, and then track 'pasky' again, the Patches will be applied, but
> not the mode changes which are stored in the cache ...  Let me show you:
> 
> -----
> $ ls -l $(./show-diff -s | cut -d: -f1)
..directroy listing with no 'x' bit..
> -----
> 
> (Note no 'x' bit ...)
> 
> And that is _after_ doing:
> 
>  $ git track linus; git track
> 
> So basically the modes that are stored in the cache are not applied ...
> Although, yes, I prob should add the relevant code to checkout-cache.

This should be fixed now, BTW. git apply didn't correctly apply the
mode changes, but now it should. Several bugs prevented it to, in fact.
;-)

> > > show-diff.c:  a531ca4078525d1c8dcf84aae0bfa89fed6e5d96
> > > --- a531ca4078525d1c8dcf84aae0bfa89fed6e5d96/show-diff.c
> > > +++ uncommitted/show-diff.c
> > > @@ -5,13 +5,18 @@
> > >   */
> > >  #include "cache.h"
> > > 
> > > -static void show_differences(char *name,
> > > +static void show_differences(struct cache_entry *ce,
> > >         void *old_contents, unsigned long long old_size)
> > >  {
> > >         static char cmd[1000];
> > > +       static char sha1[41];
> > > +       int n;
> > >         FILE *f;
> > > 
> > > -       snprintf(cmd, sizeof(cmd), "diff -L %s -u -N  - %s", name, name);
> > > +       for (n = 0; n < 20; n++)
> > > +               snprintf(&(sha1[n*2]), 3, "%02x", ce->sha1[n]);
> > > +       snprintf(cmd, sizeof(cmd), "diff -L %s/%s -L uncommitted/%s -u -N 
> > >  - %s",
> > > +               sha1, ce->name, ce->name, ce->name);
> > 
> > The "directory" sha1 is the sha1 of the tree, not of the particular
> > file - that one is in the "attributes" list (parentheses after the
> > filename), together with mode.
> > 
> 
> Does it really matter?  It is more just to get the patch prefix right,
> and I did it as it went nicely with the printed:
> 
> ----
> show-diff.c:  a531ca4078525d1c8dcf84aae0bfa89fed6e5d96
> ----
> 
> for example ...

Yes, it matters, and I don't care how nicely it wents with what you
print before.

Either print there some nonsense which is clear not to be a tree ID, or
(much more preferably) print the real tree ID there. If some tool ever
uses it (e.g. to help resolve conflicts, perhaps even actually doing a
real merge based on the patch), you just confused it.

Also, do you think you could separate this patch from the other
(--update-modes) patch? (If we actually still need the --update-modes
patch after git apply was fixed.)

Thanks,

-- 
                                Petr "Pasky" Baudis
Stuff: http://pasky.or.cz/
C++: an octopus made by nailing extra legs onto a dog. -- Steve Taylor
-
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to