Using named branches as you've described is a fine choice (though not the only choice), but I'd still suggest using a few separate clones at well known locations to facilitate this process. Pretending that http://host/hg/
is a hgweb (formerly hgwebdir) for your install (though ssh:// works great too, whatever), you'd have something like this:
http://host/hg/vendor
http://host/hg/custom
Two separate repos where data flow from vendor to custom but never the other direction. The named branch default
would be the only one in vendor
and in custom
you'd have both default
and stable
.
When you got a new code drop from the vendor you'd unpack it into the working directory of the vendor
repo, and then run:
hg addremove
hg commit -m 'new drop from vendor, version number x.x.x'
Your history in that vendor
repo will be linear, and it will never have anything you wrote.
Now in your local clone of the custom
repo you'd do:
hg update default # update to the latest head in your default branch
hg pull http://host/hg/vendor # bring in the new changes from vendor as a new head
hg merge tip # merge _your_ most recent default cset with their new drop
And then you do the work of merging your local chances on default with their new code drop. When you're happy with the merge (tests pass, etc.) you push from your local clone back to http://host/hg/custom
.
That process can be repeated as necessary, provides good separation between your history and theirs', and lets everyone on your team not responsible for accepting new code drops from vendors, to concern themselves only with a normal default/stable
setup in a single repo, http://host/hg/custom
.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…