Is there any difference between git merge --no-commit
and git cherry-pick --no-commit
?
And is there any difference in history if I commit after these two commands?
Is there any difference between git merge --no-commit
and git cherry-pick --no-commit
?
And is there any difference in history if I commit after these two commands?
While git-merge is used to join two or more development histories together, git-cherry-pick is used to apply changes introduced by some existing commits.
So then, once you commit after performing a git-merge, Git will add what's called a merge commit. In the other side, when cherry-pick(ing) commits, git will apply the changes introduced by these commits on the top of your working tree (There's no fusion between two or many branches). Put another way, Commits are cloned and put on top of your branch.
Take a look at Git Cherry-pick vs Merge Workflow to undestand the differences based on a repo maintainer real needs.
If you commit after
git merge --no-commit
, you'll actually get a merge commit. Whereas after agit cherry-pick --no-commit
you'll get a commit with a single parent.Hence, yes, there is a difference between those two commands.
In particular if you have something like
If you
cherry-pick
commitE
, you won't get modifications of commitD
. Whereas if youmerge
, you'll get both.