首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >git子树错误“致命:拒绝合并不相关的历史”

git子树错误“致命:拒绝合并不相关的历史”
EN

Stack Overflow用户
提问于 2016-09-02 05:23:24
回答 5查看 14.3K关注 0票数 16

我想弄清楚“git subtree”是如何工作的。我已经遵循了this page上的所有说明,但在尝试将子树项目合并到我自己的代码库(“步骤2”):fatal: refusing to merge unrelated histories时,总是出现错误。

我读过this post,当我使用--allow-unrelated-histories选项时,它似乎工作得很好。然而,我不确定我是否应该使用this...My印象,因为子树的全部意义是在一个存储库中拥有不相关的历史,所以必须添加这个选项感觉很奇怪。然而,我应该添加它吗,或者我做错了什么?

我在osx 10.11.6上使用git v2.9.3

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2017-02-10 12:37:21

票数 1
EN

Stack Overflow用户

发布于 2018-08-29 01:13:42

如果子树是使用--squash添加的,则在拉取时还需要使用--squash

git subtree pull --prefix=<folder-goes-here> <remote-goes-here> <branch-goes-here> --squash

票数 36
EN

Stack Overflow用户

发布于 2018-03-09 08:48:19

我已经在这个问题上挣扎了一段时间,我想我找到了解决方案。

我是git的新手,所以如果我使用了错误的名称,请原谅。

问题可能是在运行git subtree add命令时使用--squash选项造成的。

尝试删除子树(删除远程存储库并删除所有本地文件、提交和推送)。然后,在不使用--squash选项的情况下重做添加子树。

然后我跳到我的子树存储库,做了一些更改,提交并推送,然后跳回我的主超级项目存储库,并执行git子树拉取。它给了我一些关于工作树有修改的错误。为了解决这个问题,我做了一个git签出主机,然后是一个git推送,然后再次尝试了子树拉取。它起作用了。

希望这能有所帮助。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39281079

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档