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.
|