So I'm back on the weird porcelain I mentioned months and months ago, the one which treats source trees as named collections of patches merged together in different ways, almost like stgit on steroids, only not. It occurred to me recently that packed refs provide about 50% of what I need (efficient handling of lots and lots of refs); most of the other 50% consits of a new extremely weird git merge strategy, `git-merge-patched', which merges branches A and B by finding the most recent merge-base between branch B and any branch listed in .git/refs/trunks (`trunks' being a directory holding heads which are treated this way by this weird merge strategy; the porcelain will have to keep it up to date, which shouldn't be too terribly hard), and patch(1)ing the diff between that base and the tip of branch B into branch A. (A patch rejection, of course, means merge-by-hand and commit, as usual with merge conflicts.) The idea being that if you have a tree like this: B ------------- ref trunks/latest \ ------ ref heads/some-change-foo ... -------- ref trunks/old-and-grotty then this merge strategy, when asked to merge heads/some-change-foo into trunks/old-and-grotty would spot that point B was the most recent merge point into anything in trunks/, generate a diff between point B and heads/some-change-foo, and patch it into trunks/old-and-grotty. (I *know* this is really weird, but I've got a choice of doing this or continuing to use SCCS with the world's most horrible shell script wrapper as the source code repository for ~5Gb of source, with tens of thousands of files in a flat directory structure, expanded to 50Gb because we're storing binary files in there by the astonishingly inefficient means of uuencoding them and sccsing the result: you may be sick now. I know which I'd prefer. I may be distorting git into something unrecognisable to its own father but it's that or I go insane *and* run out of disk space.) After all that setup, my question's simple. Does a `parent' in git terminology simply mean `this commit was derived in some way from the commit listed here'? If so, I suppose I can list heads/some-change-foo as one parent on these merge commits, even though the `merging' mechanism is so odd that I expect to be pelted with rotten vegetables as soon as I post this. But it's that or SCCS. (Of course this will go into a public git repository for people to laugh at. I don't expect anyone to actually *use* it.) -- Rich industrial heritage: lifeless wasteland. `The land north of Mordor has a rich industrial heritage.' - 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