summaryrefslogtreecommitdiffstats
path: root/content/blog/vimdiff.md
blob: f6135251f77c0c9a1d10c3526931e44155426860 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
---
title: "Git diff with vimdiff"
date: 2022-08-17T15:06:57+01:00
draft: false
categories: ['Computing']
tags: [vim, git]
---

### git difftool

You could just do:

> `git difftool --tool=vimdiff --no-prompt`

This will open `git diff` in vim.

To tell git to always use vimdiff:

> `git-config --global diff.tool vimdiff`
`git-config --global merge.tool vimdiff`

Omit `--global` to set these for the repo in the working directory.

Once these settings are set, you can do `git difftool` to launch it.

Another useful config is `difftool.prompt` - this will stop Vim prompting about
launching `vimdiff`:

> `git-config --global difftool.prompt false`

### Basic vimdiff

`]c`    - next difference \
`[c`    - previous difference \
`do`    - diff obtain \
`dp`    - diff put \
`zo`    - open folded text \
`zc`    - close folded text \
`:diffupdate` - re-scan the files for differences \

### IMPORTANT - READ-ONLY

By default, vimdiff opens both file in READONLY mode. To be able to make changes to the file, do `:set noro` in vim, which will remove READONLY.