当我开始 pull 的时候,使用下面的代码
git subtree pull --prefix=<本地子项目目录> <远程库仓库地址 | 远程库别名> <分支> --squash
其中
--squash
参数是把子项目的记录合成一次 commit 提交到主项目,这样主项目只是合并一次 commit 记录。
但是在我执行这句代码的时候,出现下面的错误
Working tree has modifications. Cannot add.
当我检查本地是否有没提交的保存时候,没有找到
git status
这个问题是因为
git diff-index HEAD
返回结果,即使本地没提交,解决这个问题很简单。切换到本地另一个分支然后切换回来,这样就可以解决
git checkout 其他分支
git checkout master
如果执行了上面的命令还无法使用,请告诉我。
Git subtree 管理子项目包使用小结
https://stackoverflow.com/a/18608538/6116637
本作品采用
知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议
进行许可。欢迎转载、使用、重新发布,但务必保留文章署名
林德熙
(包含链接:
http://blog.csdn.net/lindexi_gd
),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我
联系
。
1.公司封装一套组件来作为子仓库,如果在一个项目中修改了子仓库提交 推送 然后根据指令提交到子仓库
components是子仓库在该项目下得目录
git
sub
tree
push --prefix=components
git
地址 master --squash
2。 如何同步到其他项目中
git
sub
tree
pull
--prefix=components
git
地址 master --squash
这个时候报错
Work
ing
tree
has
modifi
cat
ion
s. Cannot
git
pull
不成功的情况
git
pull
不成功的原因基本上都是本地的代码修改了, 而别人已经在仓库中提交了相同文件的修改.因此在
git
看来,你不是在这个文件最新的状态下进行的修改, 因此
git
pull
有可能就会失败.
git
pull
在以下两种状态下出现失败的解决办法不同: (注意:要仔细看命令行的提示, 有时候明明
git
pull
都提示没成功了, 有很多同学还没有察觉)
1.代码已提交至本地仓库之后,
git
pull
失败
产生冲突, 接下来就解决冲突
所谓解决冲突
问题描述:
Given two non-empty binary
tree
s s and t, check whether
tree
t has
exactly the same structure and node values with a
sub
tree
of s. A
sub
tree
of s is a
tree
consists of a node in s and
all o