I know that :Glog will populate the quickfix list with all the versions of the file in the current buffer and that I can hit <enter> on these to see the file at that particular version, but is there an easy way to see the diff of a particular version with the previous version (to easily see what has changed)?
EDIT: What I'm after is seeing each of these changes in a vertical diff in vim: git log -p -- path/to/file.txt.
This is what I use:
:Gdiff [revision]
See :help Gdiff for other options as well (vertical vs horizontal splits, etc).
For example:
:Gdiff HEAD
or if you have a revision number (ie: aaffdfdstsdgssetds):
:Gdiff aaffdfds
I believe it is as simple as:
:vert diffsplit #
Could not get fugitive to do what I want (it either doesn't do it or I don't know how to use it), but I did find the plugin which gives the desired behaviour: https://github.com/kablamo/vim-git-log.
(it does not show the diff in quickfix list but in a full sized buffer, which is OK)
First, open the file you want to diff with.
If the change is committed, enter :Gdiff HEAD~1.
If the change is NOT committed, enter :Gdiff HEAD.
When using :Glog you can simply press <cr> on the line that starts diff --git. It will open the diff. You may also want to look into :Gdiff. You may want to look at Drew Neil's vimcasts, The Fugitive Series.
For more help see
:h fugitive
:h :Glog
:h :Gdiff
You can achieve this by following these steps:
- Change focus to the quickfix window and navigate to the line corresponding to the commit you're interested in.
- Find the commit hash in the line and yank it (the hash is now in the 0register.
- Close the quickfix buffer, and do :Gdiff <C-r>0.
That should fire up the proper diff.
You can automate steps 2 and 3 by adding this mapping to your .vimrc file:
nnoremap <Leader>gd /\.git<CR>wwwyw<Esc>:cclose<CR>:Gdiff <C-r>0<CR>
Notice that the mapping assumes your cursor is at the beginning of the line (before the .git// part).
One way to see diff of a commit is this:
:Gedit [revision]
To diff with its previous version, follow these steps:
- use Glog
- navigate to the desired version
- type C, which opens the commit
- go to the line contains diff --git a/you/file b/you/fileand press<cr>
Moreover, to diff a previous version with the version in index (the working version), you can do this:
- use Glog
- navigate to the desired version
- use Gdiffin this new window without parameter. Done!
Gdiff without parameter will diff the current buffer with the one in index, which is exactly what you want
You can also consider using the plugin vim-unimpaired, which provides two maps ]q and [q to navigate the quickfix list. (Also ]Q and [Q)
I wrote a function that allows you to diff against a previous revision of the current file. I use this to view the diff between the working copy and revisions "n" times back.
Here's the code to put in your .vimrc (requires https://github.com/tpope/vim-fugitive):
"Diff the current file against n revision (instead of n commit)
function! Diffrev(...)
  let a:target = @%
  "check argument count
  if a:0 == 0
    "no revision number specified
    let a:revnum=0
  else
    "revision number specified
    let a:revnum=a:1
  endif
  let a:hash = system('git log -1 --skip='.a:revnum.' --pretty=format:"%h" ' . a:target)
  execute 'Gdiff' . a:hash
endfunc
You can call the function like so (example below diffs against 3rd revision back):
:call Diffrev(2)
来源:https://stackoverflow.com/questions/16802629/diff-of-current-and-previous-version-using-vim-fugitive