VCS comparison table
Linus Torvalds
torvalds at osdl.org
Mon Oct 23 19:45:13 BST 2006
On Mon, 23 Oct 2006, Jakub Narebski wrote:
>
> The place for timestamp and commiter info is in the revision metadata
> (in commit object in git). Not in revision id. Unless you think that
> "accidentally the same" doesn't happen...
Well, git and bzr really do share the same "stable" revision naming,
although in git it's more indirect, and thus "covers" more.
In git, the revision name indirectly includes the commit comments too (and
git obviously also distinguishes between "committer" and "author", and
those end up being indirectly credited in the name of the commit too). But
in a very real sense, the bzr stable ("real") revision name does
effectively contain the same things as a git ID: it's just that it's a
small subset (only committer+date+random number) of what git includes in
its names.
So you could more easily _fake_ a commit name in bzr, and depending on how
things are done it might be more open to malicious attacks for that reason
(or unintentionally - if two people apply the exact same patch from an
email, and take the author/date info from the email like hit does, you
might have clashes. But with a 64-bit random number, that's probably
unlikely, unless you also hit some other bad luck like having the
pseudo-random sequence seeded by "time()", and people just _happen_ to
apply the email at the exact same second).
The git use of hashes and parenthood information make any accidental
clashes like that a non-issue: if you have exactly the same information,
it really _is_ the same commit, since the hash includes the parenthood
too. So you're left with just malicious attacks, and those currently look
practically impossible too, of course.
So I don't think bzr and git differ in this respect. I think you can
_trust_ stable git names a lot more, but that's a separate issue.
Linus
More information about the bazaar
mailing list