在kiln exchange站点上对this question的回答中,有一条评论提到“如果你从库的一个消费者提交,其他库消费者不会立即看到这些变更集。你必须显式地将库repo上的更改拉到其他消费者中。”
我已经向项目.hgsub & .hgsubstate文件中引用的存储库添加了一些文件,但它们没有显示在projects子存储库中(因为项目正确地使用了之前分配的更改集)。
我想知道如何编辑子存储库使用的变更集。我只是编辑.hgsubstate文件(看起来有点"hackish"),还是有一个我可以使用的命令/ kiln网站选项?
发布于 2012-01-16 10:22:48
在子资料库中,hg update指向您希望主资料库使用的变更集。然后,在主存储库中,发出hg ci提交子存储库更改。Mercurial将用子存储库的当前父变更集ID自动更新.hgsubstate文件。
示例(Windows .bat文件):
REM Create main repository
hg init Example
cd Example
echo >file1
hg ci -Am file1
cd ..
REM Create another repository
hg init Library
cd Library
echo >file2
hg ci -Am file2
cd ..
REM Clone the Library into the main repository
cd Example
hg clone ..\Library
REM and configure it as a subrepository.
echo Library=Library >.hgsub
REM Commit it.
hg ci -Am "Added Library sub repository."
REM Note .hgsubstate is updated with the current subrepo changeset.
type .hgsubstate
cd ..
REM Someone updates the original Library.
cd Library
echo >file3
hg ci -Am file3
cd ..
REM Main repo isn't affected. It has a clone of Library.
cd Example
hg status -S
REM Update to the latest library
cd Library
hg pull -u
cd ..
REM View the changes to the library in the main repo.
hg status -S
REM Commit the library update in the main repo.
hg ci -m "Updated library."
REM Note .hgsubstate is updated.
type .hgsubstatehttps://stackoverflow.com/questions/8875127
复制相似问题