From: Nicolas Pitre <nico@cam.org>
To: Linus Torvalds <torvalds@osdl.org>
Cc: Sergey Vlasov <vsu@altlinux.ru>, Junio C Hamano <junkio@cox.net>,
git@vger.kernel.org
Subject: Re: heads-up: git-index-pack in "next" is broken
Date: Tue, 17 Oct 2006 22:08:57 -0400 (EDT) [thread overview]
Message-ID: <Pine.LNX.4.64.0610172140270.1971@xanadu.home> (raw)
In-Reply-To: <Pine.LNX.4.64.0610171754040.3962@g5.osdl.org>
On Tue, 17 Oct 2006, Linus Torvalds wrote:
>
>
> On Tue, 17 Oct 2006, Nicolas Pitre wrote:
> > >
> > > .. and it sorts _differently_ on a big-endian vs little-endian thing,
> > > doesn't it?
> >
> > Sure. But who cares? The sorting is just there to 1) perform binary
> > searches on the list of deltas based from a given object, and 2) find a
> > list of all deltas with the same base object.
>
> _I_ care.
OK, So I do.
> The new code is messy. It's fragile, and already showed one very
> fundamental bug which depended on architectures.
My stance is that it is not fragile. Sure it had one bug that depended
on an architecture difference, but so was commit ac58c7b18e about.
The code also has many consistency checks all over so that it doesn't
write out garbage if such bugs arise. And that fundamental bug was
actually a trivial one that was caught right away by such consistency
check.
> These things matter. We have had very few bugs in git, and one of the
> reasons is (I believe) that we haven't had ad-hoc code. I get _very_
> nervous when you mix up SHA1 names with somethign totally different
> without even a flag to say which one it is. That's just nasty.
But there _is_ a flag for damn sake. Did you at least try to understand
the code and not just skim over it from 10000 feet above?
It is really simple:
- if the found union content matches with a reference union initialized
through the sha1 member then deltas[j].obj->type == OBJ_REF_DELTA
must be true.
- if the found union content matches with a reference union initialized
through the sha1 member then deltas[j].obj->type == OBJ_OFS_DELTA
must be true.
- For all deltas with deltas[j].obj->type == OBJ_REF_DELTA there can
not be more than one of them with the same union value.
- For all deltas with deltas[j].obj->type == OBJ_OFS_DELTA there can
not be more than one of them with the same union value.
There is _no_ confusion possible.
> The fact that the code then behaves (and behave_d_) differently on
> different architectures is just a sign of the problem.
Does this mean that, with your own change to xdiff that has just been
committed, you actually created a "problem"? Because this is a change
that creates different behaviors whether a 32-bit or 64-bit architecture
is used, Right?
But of course not. We want it to behave differently on 64-bit than
32-bit. My code is in the _same_ camp since I explicitly want it to
sort numbers differently whether it is a little endian or big endian
machine.
So this is not a problem this is a feature, and very by design.
> "Who cares?" is not a good question to ask for a SCM.
Please just try to understand why I'm claming this is not important in
this very case. Please do me this favor.
Nicolas
next prev parent reply other threads:[~2006-10-18 2:09 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-10-17 4:55 heads-up: git-index-pack in "next" is broken Junio C Hamano
2006-10-17 15:39 ` Nicolas Pitre
2006-10-17 16:07 ` Junio C Hamano
2006-10-17 17:00 ` Nicolas Pitre
2006-10-17 18:11 ` Junio C Hamano
2006-10-17 18:47 ` Nicolas Pitre
2006-10-17 19:36 ` Sergey Vlasov
2006-10-17 20:10 ` Junio C Hamano
2006-10-17 20:25 ` Nicolas Pitre
2006-10-17 20:23 ` Nicolas Pitre
2006-10-17 20:51 ` Linus Torvalds
2006-10-17 21:21 ` Nicolas Pitre
2006-10-17 21:46 ` Linus Torvalds
2006-10-18 0:20 ` Nicolas Pitre
2006-10-18 0:57 ` Linus Torvalds
2006-10-18 2:08 ` Nicolas Pitre [this message]
2006-10-18 3:12 ` Linus Torvalds
2006-10-18 6:09 ` Davide Libenzi
2006-10-18 14:56 ` Linus Torvalds
2006-10-18 16:17 ` Davide Libenzi
2006-10-18 16:52 ` Linus Torvalds
2006-10-18 21:21 ` Davide Libenzi
2006-10-18 21:48 ` Linus Torvalds
2006-10-18 22:34 ` Davide Libenzi
2006-10-18 1:30 ` Junio C Hamano
2006-10-18 2:23 ` Nicolas Pitre
2006-10-18 4:16 ` Junio C Hamano
2006-10-18 5:07 ` Junio C Hamano
2006-10-18 10:00 ` Johannes Schindelin
2006-10-18 13:13 ` Nicolas Pitre
2006-10-18 13:02 ` Nicolas Pitre
2006-10-17 21:54 ` Junio C Hamano
2006-10-18 1:38 ` Nicolas Pitre
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=Pine.LNX.4.64.0610172140270.1971@xanadu.home \
--to=nico@cam.org \
--cc=git@vger.kernel.org \
--cc=junkio@cox.net \
--cc=torvalds@osdl.org \
--cc=vsu@altlinux.ru \
/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).