问题描述
我使用子存储库在多个项目之间共享代码。 我将这些共享存储库的“主”版本保存在一个中心位置。 这样我就可以轻松地将我在一个项目中对它们所做的更改推送到另一个项目中。 这是可行的,但理想情况下,我只想推送项目存储库,所有子存储库都应推送到他们的来源。但是 Mercurial 总是将所有子存储库推送到主存储库的源中。
这是我的设置:
Project1 (default path = Project-Central-Location/Project1)
- lib-A (default path = Library-Central-Location/lib-A)
- lib-B (default path = Library-Central-Location/lib-B)
Project2 (default path = Project-Central-Location/Project2)
- lib-A (default path = Library-Central-Location/lib-A)
Library-Central-Location
- lib-A <= push of Project1 should push lib-A to this location
- lib-B
Project-Central-Location
- Project1
- lib-A <= push of Project1 pushes lib-A to this location instead
- lib-B
- Project 2
- lib-A
解决方法
我最终使用了钩子。首先,中心位置项目内部的库需要指向对应的中心库仓库:
Project-Central-Location
- Project1
- lib-A <= (default path = Library-Central-Location/lib-A)
- lib-B <= (default path = Library-Central-Location/lib-B)
- Project 2
- lib-A <= (default path = Library-Central-Location/lib-A)
然后您需要将其添加到他们的 .hg/hgrc
文件中:
[hooks]
changegroup.hg-push = hg push
这样我就可以在每次推送项目时触发对中央库的推送。