繁体   English   中英

在git中,如何将更改从另一个分支拉入工作树?

[英]In git, how can I pull changes from another branch into the working tree?

我在主题分支中做了一些有趣的工作。 现在,我想在提交到主分支之前清除这些更改。 因此,我想将所有这些更改放入工作树中:让工作树包含主题的分支版本, git diff显示master分支中的所有更改。

那可能吗? 我怎么做?

编辑: git merge --no-ff topic && git reset --mixed HEAD^似乎可以解决问题。 如果有人有一个更优雅的答案,我会很高兴!

不知道,如果我了解你的权利

git checkout master
git merge --no-ff --no-commit topic

我认为您正在寻找的是git merge --no-commit --no-ff

从手册页:

使用--no-commit执行合并,但假装合并失败并且不自动提交,使用户有机会在提交之前检查并进一步调整合并结果。

编辑:我们还需要指定--no-ff,因为在快速向前合并的情况下不会创建合并提交,因此git无法理解--no-commit的含义。

我认为您应该首先使用git rebase master重新设置主题分支的基础,然后使用git checkout master切换到master分支,最后与git merge --no-ff topic或快进git merge --ff-only topic (其中topic是您的主题分支的名称)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM