我有一个主仓库,其中有一些我不想提交的更改。
我有一个 subrepo,其中包含已提交的更改。
我想在我的主存储库中提交更改子存储库修订,而不提交对主存储库中文件的更改。
我似乎无法做到这一点。我无法提交.hgsubstate
,并对要提交的文件进行微不足道的更改,但不会将子存储库更改提交到主存储库。
将子存储库本身的名称传递给提交,Mercurial 将更新.hgsubstate
并提交它。
ry4an@four:~$ hg init main
ry4an@four:~$ cd main
ry4an@four:~/main$ hg init sub
ry4an@four:~/main$ echo sub = sub > .hgsub
ry4an@four:~/main$ hg add .hgsub
ry4an@four:~/main$ hg commit
ry4an@four:~/main$ cd sub
ry4an@four:~/main/sub$ echo text > afile
ry4an@four:~/main/sub$ hg commit -Am first-in-sub
adding afile
ry4an@four:~/main/sub$ cd ..
ry4an@four:~/main$ hg status
ry4an@four:~/main$ echo text > dont-commit-me
ry4an@four:~/main$ hg add dont-commit-me
ry4an@four:~/main$ hg status
A dont-commit-me
ry4an@four:~/main$ cat .hgsubstate
0000000000000000000000000000000000000000 sub
ry4an@four:~/main$ hg commit -m 'subrepo only' sub
ry4an@four:~/main$ hg status
A dont-commit-me
ry4an@four:~/main$ cat .hgsubstate
dec5eaa9e22cd0a05cbba3ba02fdb0e1f243e07e sub
请注意, main 中的文件dont-commit-me
从未提交,但.hgsubstate
已更新。