Meld is a great tool originally developed for linux. It is used as git diff and merge tool. In this article I ll tell you how to setup meld as git tool in wsl in some easy steps.
Step 1
Install meld on windows 10
Step 2
Create meld link as linux app in wsl
$ sudo ln -s /mnt/c/Users/pro/AppData/Local/Programs/Meld/Meld.exe /usr/local/bin/meld
Step 3
Open wsl terminal and edit your gitconfig
$ vi ~/.gitconfig
Add following lines to your .gitconfig file
[ diff ] tool = meld [difftool "meld"] cmd = meld \"$(wslpath -aw $LOCAL)\" \"$(wslpath -aw $REMOTE)\" [merge] tool = meld [mergetool "meld"] cmd = meld --auto-merge \"$(wslpath -aw $LOCAL)\" \"$(wslpath -aw $BASE)\" \"$(wslpath -aw $REMOTE)\" --output \" $(wslpath -aw $MERGED)\" --label=Local --label=Base --label=Remote --diff \"$(wslpath -aw $BASE)\" \"$(wslpath -aw $ LOCAL)\" --diff \"$(wslpath -aw $BASE)\" \"$(wslpath -aw $REMOTE)\"
data:image/s3,"s3://crabby-images/5b3f6/5b3f643915c13a21c6fc5188cadd7b89d773204b" alt=""
Step 4
use meld as difftool in git like below
$ git difftool --dir-diff master
You would see it working like below
data:image/s3,"s3://crabby-images/06ffe/06ffe0ec58cd8c5d51cf110e22aa5de6c590fb76" alt=""
But why it is showing warning icons with files and even showing error when you try to open a file
data:image/s3,"s3://crabby-images/f00d0/f00d0a7eeeaffed8a5897b0831597b433ffeed48" alt=""
This is happening due to meld is not able to find exact file paths in wsl.
Step 5
To resolve file link issue in meld for wsl we need to use –no-symlinks with git difftool command
$ git difftool --dir-diff --no-symlinks master
data:image/s3,"s3://crabby-images/43f64/43f64045e77101c9e77e5cb39ea18c95b9b99998" alt=""
Now we are all good to see file diffs. Double click on any file to see its diff with original file.
data:image/s3,"s3://crabby-images/239b3/239b35daf244d23acb011d9016a4c48ee4624b02" alt=""
Now you can compare both branches and move the code here and there.
Bonus:
You can create an alias for difftool command along with no-symlink and place it in your .bashrc file
alias ddt='git difftool --dir-diff --no-symlinks'
and use it as
$ ddt master
Recent Comments