Re: [RFC] Plumbing-only support for storing object metadata

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Derek Fawcus <dfawcus@xxxxxxxxx> wrote:
> On Sun, Aug 17, 2008 at 11:12:36PM -0700, Shawn O. Pearce wrote:
> > Adding a new type bit is a lot more than just adding it to the pack
> > data field.  Look at the amount of code that needed to be changed to
> > support gitlink in trees, and that was "reusing" the OBJ_COMMIT type.
> > Anytime you start poking at the core object enumeration code with
> > new cases there's a lot of corners that are affected.
> 
> Actually,  I'd been thinking of how to attach metadata - but more from
> the perspective of attaching it to commits,  rather than individual
> blobs or trees.
>
> At the moment,  my workaround is simply to add well known lines to
> the end of the commit comments,

We've talked about adding additional header lines to the commit after
the "committer" or "encoding" line but before the first blank line
that ends the headers and starts the message.  Most of the code will
skip over an unknown header at this position, as we went through
that pain when we added the "encoding" header to the commit format.

However, once you start putting headers into there one has to
actually understand what they mean.  And it gets really ugly if
your tool thinks "fixed XXX\n" means something different from what
my tool thinks "fixed YYY\n" means and I use my tool against a
clone of your repository.  In other words there is no concept of
"header namespaces".

Thus far I don't think anyone has really tried adding more headers
here because nobody has come up with a concrete example of how it
is useful.
 
> I guess there'd have to be some rule - like only one indirect
> object allowed to be inserted (otherwise its awkward to check
> for loops),  and there would need to be some custom merge rules.

Loops aren't possible.  If you can create a loop you have a very
real and very valid attack against SHA-1.  You will probably be
able to use that in some way that profits you better than a loop
within some random Git repository.

You may also want to look into the "notes" idea floated on the list
in the past.  It allowed attaching trees (IIRC) to any commit, and
finding that later on in O(1) time during say git-log.  This can
be useful to attach a build report or a test report to a commit
hours after it was created.

-- 
Shawn.
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux