From: Linus Torvalds <torvalds@osdl.org>
To: Junio C Hamano <junkio@cox.net>
Cc: git@vger.kernel.org
Subject: Re: [WISH] Store also tag dereferences in packed-refs
Date: Mon, 20 Nov 2006 08:29:38 -0800 (PST) [thread overview]
Message-ID: <Pine.LNX.4.64.0611200817330.3692@woody.osdl.org> (raw)
In-Reply-To: <7vr6vy7smi.fsf@assigned-by-dhcp.cox.net>
On Sun, 19 Nov 2006, Junio C Hamano wrote:
> Linus Torvalds <torvalds@osdl.org> writes:
>
> > So I'd suggest adding - at the very top of the ref-pack file - a line line
> >
> > # Ref-pack version 2
> >
> > which will be ignored by the current ref-pack reader (again, because it's
> > not a valid ref line), but we can use it in the future to specify further
> > extensions if we want to.
> >
> > Now somebody would just need to implement that ;)
>
> For this particular one, there is no need for version 2.
I don't think you understand.
> My current wip does:
>
> SHA-1 SP name LF
> SHA-1 SP SP name^{} LF
I think that's ugly and redundant (if "name" is ever different from the
lien above it, that would be a bug), but that's not the real problem.
The real problem is (go back to the mail that you answered, and snipped
the explanation from) this:
- you have a thousand tags
- NONE of them are "tag objects".
- as a result your ref-pack file doesn't have a _single_ of the ^{} lines
Think about it. How do you know whether you should look up the tag objects
for "-d" or not?
The answer is: you don't. You can't tell a "version 1" and "version 2"
file apart. It might be an old "version 1" file that simply doesn't _have_
dereference information. Or it might be a "version 2" file that _does_
have dereference information, but nothing to dereference.
So you either have to:
- look up each object again to see if it's a tag that should be
dereferenced
OR:
- add a "# ref-pack version 2" flag at the top of the file.
So it's not about "parsing" the new file structure. I realize that parsing
it is trivial. It's simply about knowing whether the new information
_could_ be there or not.
And once you have that flag, your _future_ extensions can add their own
version, which is an added bonus. But that means that "version 2" parsing
should _also_ ignore lines that it cannot match, so you'd better have an
escape from the new format. I personally think that using
^<sha1><lf>
instead of "<sha1><space><space><name>^{}<lf>" is better partly for that
reason: it's not only denser, it is "stricter" in the sense that there's
less room for some future extended version that could be mistaken for a
"version 2 unpeeling" line.
(But you can do the same thing with your version too. You should:
- check that there is just _one_ extra space
- verify that the name matches the previous one
- verify that it ends exactly with "^{}", so that any future extension
could add their own flags at the end.)
But regardless of which format chosen, you need the flag of "this format
is in use", exactly because the extended unpeeling information might not
_exist_.
Oh, and regardless of which format chosen, you'd need to verify that the
unpeeled object in the pack wasn't overridden, of course.
Linus
next prev parent reply other threads:[~2006-11-20 16:30 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-11-18 9:15 [WISH] Store also tag dereferences in packed-refs Marco Costalba
2006-11-18 18:38 ` Junio C Hamano
2006-11-18 18:43 ` Petr Baudis
2006-11-18 18:47 ` Marco Costalba
2006-11-18 19:04 ` Junio C Hamano
2006-11-19 0:28 ` Marco Costalba
2006-11-19 1:11 ` Linus Torvalds
2006-11-19 1:40 ` Junio C Hamano
2006-11-19 1:45 ` Junio C Hamano
2006-11-19 1:59 ` Linus Torvalds
2006-11-19 9:40 ` Marco Costalba
2006-11-19 18:05 ` Linus Torvalds
2006-11-19 19:07 ` Marco Costalba
2006-11-19 20:09 ` Marco Costalba
2006-11-19 20:36 ` Linus Torvalds
2006-11-19 20:44 ` Linus Torvalds
2006-11-19 21:01 ` Junio C Hamano
2006-11-19 21:14 ` Linus Torvalds
2006-11-19 21:24 ` Jakub Narebski
2006-11-19 23:36 ` Linus Torvalds
2006-11-20 2:35 ` Junio C Hamano
2006-11-20 9:40 ` Jakub Narebski
2006-11-20 12:56 ` Marco Costalba
2006-11-20 16:29 ` Linus Torvalds [this message]
2006-11-20 19:32 ` Junio C Hamano
2006-11-19 22:25 ` Marco Costalba
2006-11-19 23:26 ` Linus Torvalds
2006-11-19 20:18 ` Linus Torvalds
[not found] ` <200611201154.08732.jnareb@gmail.com>
[not found] ` <7vu00u2wln.fsf@assigned-by-dhcp.cox.net>
2006-11-20 11:33 ` Jakub Narebski
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.0611200817330.3692@woody.osdl.org \
--to=torvalds@osdl.org \
--cc=git@vger.kernel.org \
--cc=junkio@cox.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).