Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

List the "different commits"

Tags:

git

I screwed up pull with rebase (there were conflicts and I resolved them incorrectly). I think that the easiest way out now is to blow the tree and reapply my patches that are missing in the upstream (there are less than 10 of them).

So, how do I get the list of the commits that are present in the local tree but absent from the upstream master? (to be exported using format-patch).

$ git remote -v
origin  [email protected]:sam-s/vowpal_wabbit.git (fetch)
origin  [email protected]:sam-s/vowpal_wabbit.git (push)
upstream        git://github.com/JohnLangford/vowpal_wabbit.git (fetch)
upstream        git://github.com/JohnLangford/vowpal_wabbit.git (push)
like image 811
sds Avatar asked Oct 23 '25 04:10

sds


2 Answers

You can use the cherry tool;

git cherry -v origin/master

will list all patches which exist in the current HEAD, but not in master. It will prepend a + for patches which don't exist in origin/master, and a - for patches which exist in master but under a different commit (e.g. commit message changed or as a result of a rebase).

like image 147
micromoses Avatar answered Oct 25 '25 18:10

micromoses


To show the commits in local-branch but NOT in origin/master:

git log local-branch ^origin/master

Replace origin with the name of the remote (upstream in your case).

Source (and duplicate?): Using Git, show all commits that are in one branch, but not the other(s)

like image 30
Gordon Gustafson Avatar answered Oct 25 '25 18:10

Gordon Gustafson