How do I merge a single commit?

你说的曾经没有我的故事 提交于 2019-12-20 11:53:49

问题


Sometimes I'm working with several branches at once. Say I have branches called master, release-1.1, and experimental. I create a new file or make a change in experimental and I want that one single change to apply to the other branches.

Can I do this in git? If I simply merge the commit into another branch, git automatically "fast-forwards" and includes any commits in between. But there must be some way to handle this use case.


回答1:


What you want to do is called cherry picking. You can cherry pick a single commit using the following command:

$ git cherry-pick <commit hash or name>

This will incorporate the change from that commit only into your current branch. Note, however, that this creates a new commit; this new commit has the exact same changes as the cherry-picked commit (and even the same commit date and author), but it is technically a new commit, so you'll see it as a new commit in, e.g., gitk. You'll also have to perform the cherry pick for each branch in which you want to see the change.




回答2:


The solution, but unfortunately the one you rather need to know before making the change, is to create separate branch only for this change (so called "topic branch"), off the earliest branch or earliest commit that makes sense, and merge this branch into any branch that needs this commit.

In some cases other solution could be to make change in maintenance branch, merge maintenance branch into stable branch, and merge stable branch into development branch.

Junio C Hamano (Git maintainer) wrote about this in his blog: Resolving conflicts/dependencies between topic branches early



来源:https://stackoverflow.com/questions/1664801/how-do-i-merge-a-single-commit

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!