'How to get the changes on a branch in Git
What is the best way to get a log of commits on a branch since the time it was branched from the current branch? My solution so far is:
git log $(git merge-base HEAD branch)..branch
The documentation for git-diff indicates that git diff A...B is equivalent to git diff $(git-merge-base A B) B. On the other hand, the documentation for git-rev-parse indicates that r1...r2 is defined as r1 r2 --not $(git merge-base --all r1 r2).
Why are these different? Note that git diff HEAD...branch gives me the diffs I want, but the corresponding git log command gives me more than what I want.
In pictures, suppose this:
x---y---z---branch
/
---a---b---c---d---e---HEAD
I would like to get a log containing commits x, y, z.
git diff HEAD...branchgives these commits- however,
git log HEAD...branchgives x, y, z, c, d, e.
Solution 1:[1]
git cherry branch [newbranch]
does exactly what you are asking, when you are in the master branch.
I am also very fond of:
git diff --name-status branch [newbranch]
Which isn't exactly what you're asking, but is still very useful in the same context.
Solution 2:[2]
What you want to see is the list of outgoing commits. You can do this using
git log master..branchName
or
git log master..branchName --oneline
Where I assume that "branchName" was created as a tracking branch of "master".
Similarly, to see the incoming changes you can use:
git log branchName..master
Solution 3:[3]
This is similar to the answer I posted on: Preview a Git push
Drop these functions into your Bash profile:
- gbout - git branch outgoing
- gbin - git branch incoming
You can use this like:
- If on master: gbin branch1 <-- this will show you what's in branch1 and not in master
- If on master: gbout branch1 <-- this will show you what's in master that's not in branch 1
This will work with any branch.
function parse_git_branch {
git branch --no-color 2> /dev/null | sed -e '/^[^*]/d' -e 's/* \(.*\)/\1/'
}
function gbin {
echo branch \($1\) has these commits and \($(parse_git_branch)\) does not
git log ..$1 --no-merges --format='%h | Author:%an | Date:%ad | %s' --date=local
}
function gbout {
echo branch \($(parse_git_branch)\) has these commits and \($1\) does not
git log $1.. --no-merges --format='%h | Author:%an | Date:%ad | %s' --date=local
}
Solution 4:[4]
When already in the branch in question use
git diff master...
Which combines several features:
- it's super short
- shows the actual changes
- Allow for master having moved forward
Solution 5:[5]
Throw a -p in there to see some FILE CHANGES
git log -p master..branch
Make some aliases:
alias gbc="git branch --no-color | sed -e '/^[^\*]/d' -e 's/* \\(.*\\)/\1/'"
alias gbl='git log -p master..\`gbc\`'
See a branch's unique commits:
gbl
Solution 6:[6]
To see the log of the current branch since branching off master:
git log master...
If you are currently on master, to see the log of a different branch since it branched off master:
git log ...other-branch
Solution 7:[7]
git log --cherry-mark --oneline from_branch...to_branch
(3dots) but sometimes it shows '+' instead of '='
Solution 8:[8]
I found
git diff <branch_with_changes> <branch_to_compare_to>
more useful, since you don't only get the commit messages but the whole diff. If you are already on the branch you want to see the changes of and (for instance) want to see what has changed to the master, you can use:
git diff HEAD master
Solution 9:[9]
With Git 2.30 (Q1 2021), "git diff A...B(man)" learned "git diff --merge-base A B(man), which is a longer short-hand to say the same thing.
Thus you can do this using git diff --merge-base <branch> HEAD. This should be equivalent to git diff <branch>...HEAD but without the confusion of having to use range-notation in a diff.
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | towi |
| Solution 2 | Debajit |
| Solution 3 | Peter Mortensen |
| Solution 4 | |
| Solution 5 | |
| Solution 6 | NDavis |
| Solution 7 | nopsoft |
| Solution 8 | Dominik Ehrenberg |
| Solution 9 | Denton L |
