Re: Storing commits in trees

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

 



On Thu, Apr 15, 2010 at 10:32:12PM +0200, Joachim Breitner wrote:
> [Please CC me on reply, as I’m not subscribed. Thanks!]
> 
> Hi,
> 
> for a variation of the workflow implemented by git-dpm[1], a tool to
> manage the development of Debian packages in git, I wanted to refer to a
> specific commit P from a regular commit D on my master branch, without P
> being a parent of D, as I don’t want it to show up in the history.
> 
> I found out that I can store commit objects in a tree object, using git 
> $ git update-index --add --cacheinfo 160000 0ac1855f1681c05d195f219c3003a05dc8d3ac20 stored-commits/some-commit
> and refer to it via HEAD:stored-commits/some-commit. I was happy, until
> I noticed that git prune will happily delete the stored commit as soon
> as it is not referred somewhere else, and git push/pull won’t transfer
> the stored commit along the tree it is contained in.
> 
> I then found out that storing commit objects in the tree is implemented
> for git-submodules, where you in fact do not want to store the commit in
> the main repo.
> 
> Now I’m wondering if it would be feasible to offer this feature: A
> proper “commit” object within a tree that is walked by fsck_walk_tree
> and the other tree walkers?
> 
> Or is there yet another way of telling git that commit D “depends on”
> commit P?

Hi Joachim,

I encountered this problem while developing silt [1], another workflow
tool for Debian packaging, which uses a similar technique to refer to
commits from a tree (in this case, from the packaging tree to patch
commits derived from upstream).

I solved the problem by automatically creating a ref for each such
reference.  The name of the ref contains a reference to the earliest
unique commit on the branch ("earliest" is determined using the
commit date), to avoid cluttering the ref namespace every time the
ref changes.

Not only does one need to remember to push the patch refs along with
the main branch ref, the code that determines the earliest unique
commit is error prone and I agree that what would be beneficial would
be a "hard link" to a commit.

In terms of implementation, perhaps we can store a value in the lower
order bits of the mode which indicates whether this is a hard link?
This would ensure compatibility with older versions of git (S_ISGITLINK
would still hold for hard links).

[1] http://git.debian.org/?p=users/pcc-guest/silt.git;a=summary

Thanks,
-- 
Peter
--
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]