How can I see a merge's diff to the other parent?

When viewing a merge commit in Source Tree, it shows me the diff to the "primary" parent.

How can I view the diff to the "secondary" parent?

I can do it in TortoiseGit, but I can't find out how to do it in Source Tree...

 

There is an option "Show file changes from all sides of a merge" under "Options" > "Git", but that one will show both diffs together, which is unhelpful.

Is it possible to see the diff to the one parent and the other, separately?

 

Here is how the UI of TortoiseGit does it:

sample of diff to two parents.png

3 answers

This widget could not be displayed.

Turns out this is very simple but not obvious. You just need to select both the merge commit and the parent you wish to diff against (using Ctrl/Cmd+click).

What is unfortunately missing from SourceTree is git's default behaviour for "git show <merge-commit>", which is to omit files that agree with either of the parents. This is a really good way of looking at merge commits that isn't currently available in SourceTree.

This is a useful work-around. But it's not practical and it allows for a relatively high chance of human error.

First I would need to navigate a complex commit tree looking for the parent commit.
I might confuse the branches (the different colours help, but are not bulletproof).
Or I might miss the commit and find the grandparent-2 instead of the parent-2.

Then I would need to manually check the diff, for each of the merges; instead of simply clicking the merge's node to see the diff. This is cumbersome, if I want to inspect more than just that particular merge-commit.

And then, if I want to continue inspecting the tree, I need to navigate back to the merge commit to continue.

All these actions are relatively easy with a simple tree... but not really practical on a repository with more than half a dozen contributors.

 

See the attached image for a sample of the complexity of the repository:

complex repository tree.PNG

 

I am also attaching an image to the question with an example of an application that shows the diff to the two parents.
Do you see why I find that option much more practical, straightforward, and less error-prone?

This widget could not be displayed.

Unfortunately, the "Show file changes from all sides of a merge" is the best solution SourceTree offers for this problem.

This widget could not be displayed.

You can view the diff either way in the diff panel by using the options at the bottom of the diff gear dropdown:

image2016-7-18 9:20:40.png

That option only affects the selected file.
It doesn't change the list of files.

So, if I merge e.g. the feature branch "add print version to reports page" (parent 2) into the branch development (parent 1):

  • The diff shows me as changed the files for reporting;
  • But if I choose to see the diff to parent 2 using the way you say, I should see in the list of affected files the files changed in the development branch, but instead I see the same list of files, and for each of them I see an empty diff.

question Does this make sense?

Yeah, good point.

Suggest an answer

Log in or Sign up to answer
Atlassian Summit 2018

Meet the community IRL

Atlassian Summit is an excellent opportunity for in-person support, training, and networking.

Learn more
Community showcase
Published May 30, 2018 in Sourcetree

Tip from the team: configuring Git or Mercurial in Sourcetree

Supported Platforms macOS Windows To make using Sourcetree as simple yet powerful as possible we embed (bundle) dependencies such as Git, Git LFS, and Mercurial. We strive to keep these...

712 views 1 3
Read article

Atlassian User Groups

Connect with like-minded Atlassian users at free events near you!

Find a group

Connect with like-minded Atlassian users at free events near you!

Find my local user group

Unfortunately there are no AUG chapters near you at the moment.

Start an AUG

You're one step closer to meeting fellow Atlassian users at your local meet up. Learn more about AUGs

Groups near you